Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
c39856f
commit e8dab0e
Showing
19 changed files
with
7,522 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,5 @@ | ||
{ | ||
"presets": ["es2015", "stage-2"], | ||
"plugins": ["transform-runtime"], | ||
"comments": false | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
dist/* | ||
node_modules/* | ||
build/* |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
env: | ||
browser: true | ||
commonjs: true | ||
es6: true | ||
extends: 'eslint:recommended' | ||
plugins: | ||
- html | ||
settings: | ||
html/html-extensions: | ||
- ".html" | ||
- ".vue" | ||
parserOptions: | ||
sourceType: module | ||
rules: | ||
indent: | ||
- error | ||
- 4 | ||
linebreak-style: | ||
- error | ||
- unix | ||
quotes: | ||
- error | ||
- single | ||
semi: | ||
- error | ||
- always |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
.DS_Store | ||
node_modules/ | ||
npm-debug.log |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,200 @@ | ||
# vue-hotel-datepicker | ||
A Vue component based on the [Hotel Datepicker](https://github.com/benitolopez/hotel-datepicker) by @benitolopez | ||
|
||
## Installation | ||
|
||
#### NPM | ||
|
||
Install the package: | ||
|
||
``` | ||
npm install vue-hotel-datepicker | ||
``` | ||
|
||
```javascript | ||
import HotelDatePicker from 'vue-hotel-datepicker' | ||
|
||
export default { | ||
components: { | ||
HotelDatePicker, | ||
}, | ||
} | ||
``` | ||
|
||
```html | ||
<HotelDatePicker DatePickerID="01"/> | ||
``` | ||
|
||
|
||
## Props/Options | ||
|
||
### placeholder | ||
- Type: `String` | ||
- Default: `Check-in ► Check-out` | ||
The input placeholder text | ||
|
||
### value | ||
- Type: `String` | ||
- Default: `' '` | ||
The default value of the input | ||
|
||
### format | ||
|
||
- Type: `String` | ||
- Default: `YYYY-MM-DD` | ||
|
||
The date format string. | ||
|
||
### infoFormat | ||
|
||
- Type: `String` | ||
- Default: `YYYY-MM-DD` | ||
|
||
The date format string in the info box. If not set, it uses the `format` option. | ||
|
||
### separator | ||
|
||
- Type: `String` | ||
- Default: ` ► ` | ||
|
||
The separator string used between date strings. | ||
|
||
### startOfWeek | ||
|
||
- Type: `String` | ||
- Default: `sunday` | ||
|
||
Default start week: `sunday` or `monday`. | ||
|
||
### startDate | ||
|
||
- Type: `Date` or `String` | ||
- Default: `new Date()` | ||
|
||
The start view date. All the dates before this date will be disabled. | ||
|
||
### endDate | ||
|
||
- Type: `Date` or `String` or `Boolean` | ||
- Default: `false` | ||
|
||
The end view date. All the dates after this date will be disabled. | ||
|
||
### minNights | ||
|
||
- Type: `Number` | ||
- Default: `1` | ||
|
||
Minimum nights required to select a range of dates. | ||
|
||
### maxNights | ||
|
||
- Type: `Number` | ||
- Default: `0` | ||
|
||
Maximum nights required to select a range of dates. | ||
|
||
### selectForward | ||
|
||
- Type: `Boolean` | ||
- Default: `false` | ||
|
||
If `true`, the selection of the second date must be after the first date. If `false`, you can select a range of dates in both directions. | ||
|
||
### disabledDates | ||
|
||
- Type: `Array` | ||
- Default: `[]` | ||
|
||
An array of strings in this format: `YYYY-MM-DD`. All the dates passed to the list will be disabled. | ||
|
||
### disabledDaysOfWeek | ||
|
||
- Type: `Array` | ||
- Default: `[]` | ||
|
||
An array of strings in this format: `['Monday', 'Tuesday', 'Wednesday', 'Thursday', 'Friday', 'Saturday', 'Sunday']`. All the days passed to the list will be disabled. | ||
|
||
### allowedRanges | ||
- Type: `Array` | ||
- Default: `[]` | ||
|
||
An array of numbers. Example: `[7,10,14]`. | ||
After selecting the start date the calendar will be updated only allowing the checkout 7, 10 or 14 days after. | ||
|
||
### enableCheckout | ||
|
||
- Type: `Boolean` | ||
- Default: `false` | ||
|
||
If `true`, allows the checkout on a disabled date. But with a criteria. Let's say we have these disabled dates: `03 April 2020` and `04 April 2020`. With this option enabled, an user can still select the first date (`03 April 2020`) for the checkout. But not `04 April 2020`. | ||
|
||
### animationSpeed | ||
|
||
- Type: `String` | ||
- Default: `.5s` | ||
|
||
The duration (in seconds) of the animation (open/close datepicker). | ||
|
||
### hoveringTooltip | ||
|
||
- Type: `Boolean` or `Function` | ||
- Default: `true` | ||
|
||
Shows a tooltip when hovering a date. It can be a custom function: | ||
|
||
```js | ||
hoveringTooltip: function(nights, startTime, hoverTime) { | ||
return nights; | ||
} | ||
``` | ||
|
||
### showBottomBar | ||
|
||
- Type: `Boolean` | ||
- Default: `true` | ||
|
||
Show/hide the toolbar. | ||
|
||
### showCloseButton | ||
- Type: `Boolean` | ||
- Default: `false` | ||
|
||
Show/hide the close button. | ||
|
||
### autoClose | ||
|
||
- Type: `Boolean` | ||
- Default: `true` | ||
|
||
Close the datepicker after the selection of the second date. | ||
|
||
### i18n | ||
|
||
- Type: `Object` | ||
|
||
Default: | ||
|
||
```js | ||
i18n: { | ||
selected: 'Your stay:', | ||
night: 'Night', | ||
nights: 'Nights', | ||
button: 'Close', | ||
'day-names': ['Sun', 'Mon', 'Tue', 'Wed', 'Thur', 'Fri', 'Sat'], | ||
'month-names': ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December'], | ||
'error-more': 'Date range should not be more than 1 night', | ||
'error-more-plural': 'Date range should not be more than %d nights', | ||
'error-less': 'Date range should not be less than 1 night', | ||
'error-less-plural': 'Date range should not be less than %d nights', | ||
'info-more': 'Please select a date range longer than 1 night', | ||
'info-more-plural': 'Please select a date range longer than %d nights', | ||
'info-range': 'Please select a date range between %d and %d nights', | ||
'info-default': 'Please select a date range' | ||
} | ||
``` | ||
|
||
## Events | ||
|
||
### dateChanged | ||
Emited everytime a new date is selected, passing the new date and the previously selected date |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,59 @@ | ||
const path = require('path') | ||
|
||
module.exports = { | ||
entry: { | ||
main: [path.resolve(__dirname, '../src/main.js')], | ||
}, | ||
output: { | ||
path: path.resolve(__dirname, '../dist'), | ||
publicPath: '/', | ||
filename: 'build.js', | ||
}, | ||
resolve: { | ||
extensions: ['.json', '.js', '.vue'], | ||
alias: { | ||
components: path.resolve(__dirname, '../src/components'), | ||
}, | ||
}, | ||
module: { | ||
rules: [ | ||
{ | ||
test: /\.vue$/, | ||
loader: 'vue-loader', | ||
options: { | ||
loaders: { | ||
scss: 'vue-style-loader!css-loader!sass-loader', // <style lang="scss"> | ||
sass: 'vue-style-loader!css-loader!sass-loader?indentedSyntax' // <style lang="sass"> | ||
} | ||
} | ||
}, | ||
{ | ||
test: /\.js$/, | ||
use: 'babel-loader', | ||
exclude: /node_modules/ | ||
}, | ||
{ | ||
test: /\.(png|jpe?g|gif|svg)(\?.*)?$/, | ||
use: { | ||
loader: 'url-loader', | ||
options: { | ||
limit: 10000, | ||
name: 'images/[name].[hash:7].[ext]', | ||
}, | ||
}, | ||
}, | ||
|
||
{ | ||
test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/, | ||
use: { | ||
loader: 'url-loader', | ||
options: { | ||
limit: 10000, | ||
name: 'fonts/[name].[hash:7].[ext]', | ||
}, | ||
}, | ||
}, | ||
|
||
], | ||
}, | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,42 @@ | ||
const config = require('./webpack.base.conf') | ||
const HtmlWebpackPlugin = require('html-webpack-plugin') | ||
const webpack = require('webpack') | ||
const path = require('path') | ||
|
||
config.devtool = '#eval-source-map' | ||
|
||
config.devServer = { | ||
host: 'localhost', | ||
port: 1805, | ||
historyApiFallback: true, | ||
hotOnly: true, | ||
overlay: true, | ||
noInfo: true, | ||
} | ||
|
||
config.module.rules = (config.module.rules || []).concat([ | ||
{ | ||
test: /\.css$/, | ||
use: [ | ||
{ loader: 'style-loader' }, | ||
{ loader: 'css-loader' }, | ||
], | ||
}, | ||
]) | ||
|
||
config.plugins = (config.plugins || []).concat([ | ||
new webpack.DefinePlugin({ | ||
'process.env.NODE_ENV': JSON.stringify(process.env.NODE_ENV), | ||
}), | ||
|
||
new HtmlWebpackPlugin({ | ||
title: 'BookUp', | ||
filename: 'index.html', | ||
template: path.resolve(__dirname, '../src/index.html'), | ||
}), | ||
|
||
new webpack.optimize.OccurrenceOrderPlugin(), | ||
new webpack.NoEmitOnErrorsPlugin(), | ||
]) | ||
|
||
module.exports = config |
Oops, something went wrong.