forked from ankurk91/vue-flatpickr-component
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathApp.vue
275 lines (251 loc) · 9.49 KB
/
App.vue
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
<template>
<section class="container">
<nav class="navbar navbar-default">
<div class="container-fluid">
<div class="navbar-header">
<a class="navbar-brand" href="#">Vue-flatPickr Demo</a>
</div>
<ul class="nav navbar-nav navbar-right">
<li><a href="https://www.npmjs.com/package/vue-flatpickr-component" target="_blank"> npm</a></li>
<li><a href="https://github.com/ankurk91/vue-flatpickr-component" target="_blank"> Github</a></li>
</ul>
</div>
</nav>
<div class="row">
<div class="col-md-8">
<div class="row">
<div class="col-md-4">
<div class="form-group">
<button type="button" class="btn btn-default" @click.prevent="setNewDate()">
Set new date programmatically
</button>
</div>
</div>
<div class="col-md-4">
<div class="form-group">
<button type="button" class="btn btn-default" @click.prevent="updateConfig()">
Reactive configs (Change mode)
</button>
</div>
</div>
<div class="col-md-4">
<div class="form-group">
<button type="button" class="btn btn-default" @click.prevent="changeTheme()">
Change theme
</button>
</div>
</div>
</div>
<form method="post" action="/" @submit.prevent="submit()">
<div class="form-group">
<label>Select date (basic)</label>
<flat-pickr v-model="form.dateBasic" :config="configs.basic"></flat-pickr>
</div>
<div class="form-group">
<label>Select date (wrap)</label>
<div class="input-group">
<flat-pickr v-model="form.date"
placeholder="Select date"
:config="configs.wrap"
:required="true"
input-class="form-control input date-input"
name="date-name"
>
</flat-pickr>
<div class="input-group-btn">
<button class="btn btn-default" type="button" title="Toggle" data-toggle>
<i class="glyphicon glyphicon-calendar"><span aria-hidden="true" class="sr-only">Toggle</span></i>
</button>
<button class="btn btn-default" type="button" title="Clear" data-clear>
<i class="glyphicon glyphicon-remove"><span aria-hidden="true" class="sr-only">Clear</span></i>
</button>
</div>
</div>
</div>
<div class="form-group">
<label for="datetime-input">Select datetime</label>
<flat-pickr :config="configs.dateTimePicker" id="datetime-input" v-model="form.dateTime"
placeholder="Date Time"></flat-pickr>
</div>
<div class="form-group">
<label>Select time</label>
<div class="input-group">
<flat-pickr :config="configs.timePicker" v-model="form.time" placeholder="Time"></flat-pickr>
<div class="input-group-btn">
<button class="btn btn-default" type="button" title="Toggle" data-toggle>
<i class="glyphicon glyphicon-time"><span aria-hidden="true" class="sr-only">Toggle</span></i>
</button>
</div>
</div>
</div>
<div class="form-group">
<label>Select date (localization)</label>
<flat-pickr :config="configs.locale" v-model="form.dateLocale"></flat-pickr>
</div>
<div class="form-group">
<label>Works in modals as well </label>
<button type="button" class="btn btn-info" data-toggle="modal" data-target="#date-modal">Open in
modal
</button>
</div>
<div class="form-group">
<label>Select date (inline)</label>
<flat-pickr :config="configs.inline" v-model="form.dateInline"></flat-pickr>
</div>
<div class="form-group" :class="{'has-error' : errors.has('date-of-birth')}">
<label>Select date (vee-validate)</label>
<flat-pickr v-model="form.dateValidate"
name="date-of-birth"
v-validate="{required:true}"
placeholder="Date of birth"
></flat-pickr>
<span v-show="errors.has('date-of-birth')" class="help-block">{{ errors.first('date-of-birth') }}</span>
</div>
<div class="form-group">
<label>Select date (confirm plugin)</label>
<flat-pickr :config="configs.plugins" v-model="form.datePlugin"></flat-pickr>
</div>
<hr>
<div class="form-group">
<button class="btn btn-primary" type="submit"><i class="glyphicon glyphicon-ok"></i> Validate form</button>
</div>
</form>
</div>
<aside class="col-md-4">
<div class="panel panel-info">
<div class="panel-heading">
Links
</div>
<div class="panel-body">
<ul>
<li><a href="https://github.com/ankurk91/vue-flatpickr-component" target="_blank">Github</a></li>
<li><a href="https://www.npmjs.com/package/vue-flatpickr-component" target="_blank">npm</a></li>
<li><a href="https://chmln.github.io/flatpickr" rel="noreferrer" target="_blank">Flatpickr</a></li>
<li><a
href="https://chrome.google.com/webstore/detail/vuejs-devtools/nhdogjmejiglipccpnnnanhbledajbpd?hl=en"
rel="noreferrer" target="_blank">Vue.js Dev tools</a></li>
<li><a href="https://github.com/logaretm/vee-validate" target="_blank">vee-validate</a></li>
</ul>
</div>
</div>
</aside>
</div>
<!-- bs modal -->
<div class="modal fade" tabindex="-1" role="dialog" id="date-modal">
<div class="modal-dialog" role="document">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-label="Close"><span
aria-hidden="true">×</span></button>
<h4 class="modal-title">Modal example</h4>
</div>
<div class="modal-body">
<form method="post" action="/" onsubmit="return false">
<div class="form-group">
<label>Select a date</label>
<flat-pickr v-model="form.dateModal"></flat-pickr>
</div>
<pre>{{form.dateModal}}</pre>
</form>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-default" data-dismiss="modal">Close</button>
<button type="button" class="btn btn-primary" data-dismiss="modal">Save</button>
</div>
</div>
</div>
</div>
</section>
</template>
<script type="text/javascript">
import Vue from 'vue';
import flatPickr from '../src/index';
// Need to add base css for flatpickr
import 'flatpickr/dist/flatpickr.css';
// l10n is optional
const Hindi = require("flatpickr/dist/l10n/hi.js").hi;
// Plugins are optional
// https://chmln.github.io/flatpickr/plugins/
import ConfirmDatePlugin from 'flatpickr/dist/plugins/confirmDate/confirmDate';
import 'flatpickr/dist/plugins/confirmDate/confirmDate.css';
export default {
name: 'app',
data() {
return {
form: {
dateBasic: new Date(),
dateTime: null,
time: null,
date: '2017-01-01',
dateLocale: null,
dateInline: null,
dateModal: '',
dateValidate: null,
datePlugin: null
},
configs: {
basic: {},
wrap: {
wrap: true,
altFormat: 'M j, Y',
altInput: true,
dateFormat: "Y-m-d",
},
timePicker: {
wrap: true,
enableTime: true,
enableSeconds: true,
noCalendar: true
},
dateTimePicker: {
enableTime: true,
dateFormat: 'd-m-Y H:i'
},
locale: {
// https://chmln.github.io/flatpickr/localization/
locale: Hindi,
// https://chmln.github.io/flatpickr/events/
onChange: this.onChange
},
inline: {
inline: true
},
plugins: {
enableTime: true,
plugins: [new ConfirmDatePlugin({confirmText: 'Done'})]
}
},
}
},
components: {
flatPickr
},
methods: {
setNewDate() {
console.log('Set new date');
this.form.dateBasic = '2018-12-01';
},
updateConfig() {
console.log('Update config');
this.configs.basic = {
mode: 'range',
};
},
changeTheme() {
require('flatpickr/dist/themes/material_blue.css');
},
onChange(selectedDates, dateStr, instance) {
console.log('Date change hook was called');
},
submit() {
console.log('Form submit event');
console.log(this.form);
// http://vee-validate.logaretm.com/examples.html#component-example
this.$validator.validateAll().then(result => {
// eslint-disable-next-line
alert(`Form validation result: ${result}`);
});
}
}
}
</script>