@lanrenbang/basecoat-ultra 0.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (55) hide show
  1. package/CHANGELOG-cn.md +54 -0
  2. package/CHANGELOG.md +54 -0
  3. package/LICENSE +21 -0
  4. package/README-cn.md +186 -0
  5. package/README.md +173 -0
  6. package/dist/css/basecoat.cdn.css +7389 -0
  7. package/dist/css/basecoat.cdn.min.css +2 -0
  8. package/dist/css/basecoat.css +1797 -0
  9. package/dist/css/datepicker.css +382 -0
  10. package/dist/css/datepicker.min.css +1 -0
  11. package/dist/css/resizable.css +96 -0
  12. package/dist/css/resizable.min.css +1 -0
  13. package/dist/js/accordion.js +20 -0
  14. package/dist/js/accordion.min.js +13 -0
  15. package/dist/js/all.js +17 -0
  16. package/dist/js/all.min.js +17 -0
  17. package/dist/js/basecoat.js +75 -0
  18. package/dist/js/basecoat.min.js +56 -0
  19. package/dist/js/carousel.js +104 -0
  20. package/dist/js/carousel.min.js +41 -0
  21. package/dist/js/catppuccin-theme-switcher.js +136 -0
  22. package/dist/js/catppuccin-theme-switcher.min.js +73 -0
  23. package/dist/js/command.js +132 -0
  24. package/dist/js/command.min.js +76 -0
  25. package/dist/js/datepicker.js +2367 -0
  26. package/dist/js/datepicker.min.js +1422 -0
  27. package/dist/js/dialog.js +20 -0
  28. package/dist/js/dialog.min.js +11 -0
  29. package/dist/js/dropdown-menu.js +148 -0
  30. package/dist/js/dropdown-menu.min.js +75 -0
  31. package/dist/js/input-otp.js +94 -0
  32. package/dist/js/input-otp.min.js +38 -0
  33. package/dist/js/lighting.js +80 -0
  34. package/dist/js/lighting.min.js +44 -0
  35. package/dist/js/popover.js +72 -0
  36. package/dist/js/popover.min.js +34 -0
  37. package/dist/js/resizable.js +534 -0
  38. package/dist/js/resizable.min.js +284 -0
  39. package/dist/js/select.js +246 -0
  40. package/dist/js/select.min.js +131 -0
  41. package/dist/js/sheet.js +85 -0
  42. package/dist/js/sheet.min.js +40 -0
  43. package/dist/js/sidebar.js +87 -0
  44. package/dist/js/sidebar.min.js +53 -0
  45. package/dist/js/slider.js +18 -0
  46. package/dist/js/slider.min.js +10 -0
  47. package/dist/js/tabs.js +53 -0
  48. package/dist/js/tabs.min.js +40 -0
  49. package/dist/js/toast.js +137 -0
  50. package/dist/js/toast.min.js +83 -0
  51. package/dist/js/toggle.js +36 -0
  52. package/dist/js/toggle.min.js +20 -0
  53. package/dist/theme/catppuccin/index.css +448 -0
  54. package/dist/theme/catppuccin/index.min.css +1 -0
  55. package/package.json +46 -0
@@ -0,0 +1,2367 @@
1
+ var HOOKS = [
2
+ "onChange",
3
+ "onClose",
4
+ "onDayCreate",
5
+ "onDestroy",
6
+ "onKeyDown",
7
+ "onMonthChange",
8
+ "onOpen",
9
+ "onParseConfig",
10
+ "onReady",
11
+ "onValueUpdate",
12
+ "onYearChange",
13
+ "onPreCalendarPosition"
14
+ ];
15
+ var defaults = {
16
+ _disable: [],
17
+ allowInput: false,
18
+ allowInvalidPreload: false,
19
+ altFormat: "F j, Y",
20
+ altInput: false,
21
+ altInputClass: "form-control input",
22
+ animate: typeof window === "object" && window.navigator.userAgent.indexOf("MSIE") === -1,
23
+ ariaDateFormat: "F j, Y",
24
+ autoFillDefaultTime: true,
25
+ clickOpens: true,
26
+ closeOnSelect: true,
27
+ conjunction: ", ",
28
+ dateFormat: "Y-m-d",
29
+ defaultHour: 12,
30
+ defaultMinute: 0,
31
+ defaultSeconds: 0,
32
+ disable: [],
33
+ disableMobile: false,
34
+ enableSeconds: false,
35
+ enableTime: false,
36
+ errorHandler: function(err) {
37
+ return typeof console !== "undefined" && console.warn(err);
38
+ },
39
+ getWeek: function(givenDate) {
40
+ var date = new Date(givenDate.getTime());
41
+ date.setHours(0, 0, 0, 0);
42
+ date.setDate(date.getDate() + 3 - (date.getDay() + 6) % 7);
43
+ var week1 = new Date(date.getFullYear(), 0, 4);
44
+ return 1 + Math.round(((date.getTime() - week1.getTime()) / 864e5 - 3 + (week1.getDay() + 6) % 7) / 7);
45
+ },
46
+ hourIncrement: 1,
47
+ ignoredFocusElements: [],
48
+ inline: false,
49
+ locale: "default",
50
+ minuteIncrement: 5,
51
+ mode: "single",
52
+ monthSelectorType: "dropdown",
53
+ nextArrow: "<svg version='1.1' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' viewBox='0 0 17 17'><g></g><path d='M13.207 8.472l-7.854 7.854-0.707-0.707 7.146-7.146-7.146-7.148 0.707-0.707 7.854 7.854z' /></svg>",
54
+ noCalendar: false,
55
+ now: /* @__PURE__ */ new Date(),
56
+ onChange: [],
57
+ onClose: [],
58
+ onDayCreate: [],
59
+ onDestroy: [],
60
+ onKeyDown: [],
61
+ onMonthChange: [],
62
+ onOpen: [],
63
+ onParseConfig: [],
64
+ onReady: [],
65
+ onValueUpdate: [],
66
+ onYearChange: [],
67
+ onPreCalendarPosition: [],
68
+ plugins: [],
69
+ position: "auto",
70
+ positionElement: void 0,
71
+ prevArrow: "<svg version='1.1' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' viewBox='0 0 17 17'><g></g><path d='M5.207 8.471l7.146 7.147-0.707 0.707-7.853-7.854 7.854-7.853 0.707 0.707-7.147 7.146z' /></svg>",
72
+ shorthandCurrentMonth: false,
73
+ showMonths: 1,
74
+ static: false,
75
+ time_24hr: false,
76
+ weekNumbers: false,
77
+ wrap: false
78
+ };
79
+ var english = {
80
+ weekdays: {
81
+ shorthand: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"],
82
+ longhand: [
83
+ "Sunday",
84
+ "Monday",
85
+ "Tuesday",
86
+ "Wednesday",
87
+ "Thursday",
88
+ "Friday",
89
+ "Saturday"
90
+ ]
91
+ },
92
+ months: {
93
+ shorthand: [
94
+ "Jan",
95
+ "Feb",
96
+ "Mar",
97
+ "Apr",
98
+ "May",
99
+ "Jun",
100
+ "Jul",
101
+ "Aug",
102
+ "Sep",
103
+ "Oct",
104
+ "Nov",
105
+ "Dec"
106
+ ],
107
+ longhand: [
108
+ "January",
109
+ "February",
110
+ "March",
111
+ "April",
112
+ "May",
113
+ "June",
114
+ "July",
115
+ "August",
116
+ "September",
117
+ "October",
118
+ "November",
119
+ "December"
120
+ ]
121
+ },
122
+ daysInMonth: [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31],
123
+ firstDayOfWeek: 0,
124
+ ordinal: function(nth) {
125
+ var s = nth % 100;
126
+ if (s > 3 && s < 21)
127
+ return "th";
128
+ switch (s % 10) {
129
+ case 1:
130
+ return "st";
131
+ case 2:
132
+ return "nd";
133
+ case 3:
134
+ return "rd";
135
+ default:
136
+ return "th";
137
+ }
138
+ },
139
+ rangeSeparator: " to ",
140
+ weekAbbreviation: "Wk",
141
+ scrollTitle: "Scroll to increment",
142
+ toggleTitle: "Click to toggle",
143
+ amPM: ["AM", "PM"],
144
+ yearAriaLabel: "Year",
145
+ monthAriaLabel: "Month",
146
+ hourAriaLabel: "Hour",
147
+ minuteAriaLabel: "Minute",
148
+ time_24hr: false
149
+ };
150
+ var pad = function(number, length) {
151
+ if (length === void 0) {
152
+ length = 2;
153
+ }
154
+ return ("000" + number).slice(length * -1);
155
+ };
156
+ var int = function(bool) {
157
+ return bool === true ? 1 : 0;
158
+ };
159
+ function debounce(fn, wait) {
160
+ var t;
161
+ return function() {
162
+ var _this = this;
163
+ var args = arguments;
164
+ clearTimeout(t);
165
+ t = setTimeout(function() {
166
+ return fn.apply(_this, args);
167
+ }, wait);
168
+ };
169
+ }
170
+ var arrayify = function(obj) {
171
+ return obj instanceof Array ? obj : [obj];
172
+ };
173
+ function toggleClass(elem, className, bool) {
174
+ if (bool === true)
175
+ return elem.classList.add(className);
176
+ elem.classList.remove(className);
177
+ }
178
+ function createElement(tag, className, content) {
179
+ var e = window.document.createElement(tag);
180
+ className = className || "";
181
+ content = content || "";
182
+ e.className = className;
183
+ if (content !== void 0)
184
+ e.textContent = content;
185
+ return e;
186
+ }
187
+ function clearNode(node) {
188
+ while (node.firstChild)
189
+ node.removeChild(node.firstChild);
190
+ }
191
+ function findParent(node, condition) {
192
+ if (condition(node))
193
+ return node;
194
+ else if (node.parentNode)
195
+ return findParent(node.parentNode, condition);
196
+ return void 0;
197
+ }
198
+ function createNumberInput(inputClassName, opts) {
199
+ var wrapper = createElement("div", "numInputWrapper"), numInput = createElement("input", "numInput " + inputClassName), arrowUp = createElement("span", "arrowUp"), arrowDown = createElement("span", "arrowDown");
200
+ if (navigator.userAgent.indexOf("MSIE 9.0") === -1) {
201
+ numInput.type = "number";
202
+ } else {
203
+ numInput.type = "text";
204
+ numInput.pattern = "\\d*";
205
+ }
206
+ if (opts !== void 0)
207
+ for (var key in opts)
208
+ numInput.setAttribute(key, opts[key]);
209
+ wrapper.appendChild(numInput);
210
+ wrapper.appendChild(arrowUp);
211
+ wrapper.appendChild(arrowDown);
212
+ return wrapper;
213
+ }
214
+ function getEventTarget(event) {
215
+ try {
216
+ if (typeof event.composedPath === "function") {
217
+ var path = event.composedPath();
218
+ return path[0];
219
+ }
220
+ return event.target;
221
+ } catch (error) {
222
+ return event.target;
223
+ }
224
+ }
225
+ var doNothing = function() {
226
+ return void 0;
227
+ };
228
+ var monthToStr = function(monthNumber, shorthand, locale) {
229
+ return locale.months[shorthand ? "shorthand" : "longhand"][monthNumber];
230
+ };
231
+ var revFormat = {
232
+ D: doNothing,
233
+ F: function(dateObj, monthName, locale) {
234
+ dateObj.setMonth(locale.months.longhand.indexOf(monthName));
235
+ },
236
+ G: function(dateObj, hour) {
237
+ dateObj.setHours((dateObj.getHours() >= 12 ? 12 : 0) + parseFloat(hour));
238
+ },
239
+ H: function(dateObj, hour) {
240
+ dateObj.setHours(parseFloat(hour));
241
+ },
242
+ J: function(dateObj, day) {
243
+ dateObj.setDate(parseFloat(day));
244
+ },
245
+ K: function(dateObj, amPM, locale) {
246
+ dateObj.setHours(dateObj.getHours() % 12 + 12 * int(new RegExp(locale.amPM[1], "i").test(amPM)));
247
+ },
248
+ M: function(dateObj, shortMonth, locale) {
249
+ dateObj.setMonth(locale.months.shorthand.indexOf(shortMonth));
250
+ },
251
+ S: function(dateObj, seconds) {
252
+ dateObj.setSeconds(parseFloat(seconds));
253
+ },
254
+ U: function(_, unixSeconds) {
255
+ return new Date(parseFloat(unixSeconds) * 1e3);
256
+ },
257
+ W: function(dateObj, weekNum, locale) {
258
+ var weekNumber = parseInt(weekNum);
259
+ var date = new Date(dateObj.getFullYear(), 0, 2 + (weekNumber - 1) * 7, 0, 0, 0, 0);
260
+ date.setDate(date.getDate() - date.getDay() + locale.firstDayOfWeek);
261
+ return date;
262
+ },
263
+ Y: function(dateObj, year) {
264
+ dateObj.setFullYear(parseFloat(year));
265
+ },
266
+ Z: function(_, ISODate) {
267
+ return new Date(ISODate);
268
+ },
269
+ d: function(dateObj, day) {
270
+ dateObj.setDate(parseFloat(day));
271
+ },
272
+ h: function(dateObj, hour) {
273
+ dateObj.setHours((dateObj.getHours() >= 12 ? 12 : 0) + parseFloat(hour));
274
+ },
275
+ i: function(dateObj, minutes) {
276
+ dateObj.setMinutes(parseFloat(minutes));
277
+ },
278
+ j: function(dateObj, day) {
279
+ dateObj.setDate(parseFloat(day));
280
+ },
281
+ l: doNothing,
282
+ m: function(dateObj, month) {
283
+ dateObj.setMonth(parseFloat(month) - 1);
284
+ },
285
+ n: function(dateObj, month) {
286
+ dateObj.setMonth(parseFloat(month) - 1);
287
+ },
288
+ s: function(dateObj, seconds) {
289
+ dateObj.setSeconds(parseFloat(seconds));
290
+ },
291
+ u: function(_, unixMillSeconds) {
292
+ return new Date(parseFloat(unixMillSeconds));
293
+ },
294
+ w: doNothing,
295
+ y: function(dateObj, year) {
296
+ dateObj.setFullYear(2e3 + parseFloat(year));
297
+ }
298
+ };
299
+ var tokenRegex = {
300
+ D: "",
301
+ F: "",
302
+ G: "(\\d\\d|\\d)",
303
+ H: "(\\d\\d|\\d)",
304
+ J: "(\\d\\d|\\d)\\w+",
305
+ K: "",
306
+ M: "",
307
+ S: "(\\d\\d|\\d)",
308
+ U: "(.+)",
309
+ W: "(\\d\\d|\\d)",
310
+ Y: "(\\d{4})",
311
+ Z: "(.+)",
312
+ d: "(\\d\\d|\\d)",
313
+ h: "(\\d\\d|\\d)",
314
+ i: "(\\d\\d|\\d)",
315
+ j: "(\\d\\d|\\d)",
316
+ l: "",
317
+ m: "(\\d\\d|\\d)",
318
+ n: "(\\d\\d|\\d)",
319
+ s: "(\\d\\d|\\d)",
320
+ u: "(.+)",
321
+ w: "(\\d\\d|\\d)",
322
+ y: "(\\d{2})"
323
+ };
324
+ var formats = {
325
+ Z: function(date) {
326
+ return date.toISOString();
327
+ },
328
+ D: function(date, locale, options) {
329
+ return locale.weekdays.shorthand[formats.w(date, locale, options)];
330
+ },
331
+ F: function(date, locale, options) {
332
+ return monthToStr(formats.n(date, locale, options) - 1, false, locale);
333
+ },
334
+ G: function(date, locale, options) {
335
+ return pad(formats.h(date, locale, options));
336
+ },
337
+ H: function(date) {
338
+ return pad(date.getHours());
339
+ },
340
+ J: function(date, locale) {
341
+ return locale.ordinal !== void 0 ? date.getDate() + locale.ordinal(date.getDate()) : date.getDate();
342
+ },
343
+ K: function(date, locale) {
344
+ return locale.amPM[int(date.getHours() > 11)];
345
+ },
346
+ M: function(date, locale) {
347
+ return monthToStr(date.getMonth(), true, locale);
348
+ },
349
+ S: function(date) {
350
+ return pad(date.getSeconds());
351
+ },
352
+ U: function(date) {
353
+ return date.getTime() / 1e3;
354
+ },
355
+ W: function(date, _, options) {
356
+ return options.getWeek(date);
357
+ },
358
+ Y: function(date) {
359
+ return pad(date.getFullYear(), 4);
360
+ },
361
+ d: function(date) {
362
+ return pad(date.getDate());
363
+ },
364
+ h: function(date) {
365
+ return date.getHours() % 12 ? date.getHours() % 12 : 12;
366
+ },
367
+ i: function(date) {
368
+ return pad(date.getMinutes());
369
+ },
370
+ j: function(date) {
371
+ return date.getDate();
372
+ },
373
+ l: function(date, locale) {
374
+ return locale.weekdays.longhand[date.getDay()];
375
+ },
376
+ m: function(date) {
377
+ return pad(date.getMonth() + 1);
378
+ },
379
+ n: function(date) {
380
+ return date.getMonth() + 1;
381
+ },
382
+ s: function(date) {
383
+ return date.getSeconds();
384
+ },
385
+ u: function(date) {
386
+ return date.getTime();
387
+ },
388
+ w: function(date) {
389
+ return date.getDay();
390
+ },
391
+ y: function(date) {
392
+ return String(date.getFullYear()).substring(2);
393
+ }
394
+ };
395
+ var createDateFormatter = function(_a) {
396
+ var _b = _a.config, config = _b === void 0 ? defaults : _b, _c = _a.l10n, l10n = _c === void 0 ? english : _c, _d = _a.isMobile, isMobile = _d === void 0 ? false : _d;
397
+ return function(dateObj, frmt, overrideLocale) {
398
+ var locale = overrideLocale || l10n;
399
+ if (config.formatDate !== void 0 && !isMobile) {
400
+ return config.formatDate(dateObj, frmt, locale);
401
+ }
402
+ return frmt.split("").map(function(c, i, arr) {
403
+ return formats[c] && arr[i - 1] !== "\\" ? formats[c](dateObj, locale, config) : c !== "\\" ? c : "";
404
+ }).join("");
405
+ };
406
+ };
407
+ var createDateParser = function(_a) {
408
+ var _b = _a.config, config = _b === void 0 ? defaults : _b, _c = _a.l10n, l10n = _c === void 0 ? english : _c;
409
+ return function(date, givenFormat, timeless, customLocale) {
410
+ if (date !== 0 && !date)
411
+ return void 0;
412
+ var locale = customLocale || l10n;
413
+ var parsedDate;
414
+ var dateOrig = date;
415
+ if (date instanceof Date)
416
+ parsedDate = new Date(date.getTime());
417
+ else if (typeof date !== "string" && date.toFixed !== void 0)
418
+ parsedDate = new Date(date);
419
+ else if (typeof date === "string") {
420
+ var format = givenFormat || (config || defaults).dateFormat;
421
+ var datestr = String(date).trim();
422
+ if (datestr === "today") {
423
+ parsedDate = /* @__PURE__ */ new Date();
424
+ timeless = true;
425
+ } else if (config && config.parseDate) {
426
+ parsedDate = config.parseDate(date, format);
427
+ } else if (/Z$/.test(datestr) || /GMT$/.test(datestr)) {
428
+ parsedDate = new Date(date);
429
+ } else {
430
+ var matched = void 0, ops = [];
431
+ for (var i = 0, matchIndex = 0, regexStr = ""; i < format.length; i++) {
432
+ var token = format[i];
433
+ var isBackSlash = token === "\\";
434
+ var escaped = format[i - 1] === "\\" || isBackSlash;
435
+ if (tokenRegex[token] && !escaped) {
436
+ regexStr += tokenRegex[token];
437
+ var match = new RegExp(regexStr).exec(date);
438
+ if (match && (matched = true)) {
439
+ ops[token !== "Y" ? "push" : "unshift"]({
440
+ fn: revFormat[token],
441
+ val: match[++matchIndex]
442
+ });
443
+ }
444
+ } else if (!isBackSlash)
445
+ regexStr += ".";
446
+ }
447
+ parsedDate = !config || !config.noCalendar ? new Date((/* @__PURE__ */ new Date()).getFullYear(), 0, 1, 0, 0, 0, 0) : new Date((/* @__PURE__ */ new Date()).setHours(0, 0, 0, 0));
448
+ ops.forEach(function(_a2) {
449
+ var fn = _a2.fn, val = _a2.val;
450
+ return parsedDate = fn(parsedDate, val, locale) || parsedDate;
451
+ });
452
+ parsedDate = matched ? parsedDate : void 0;
453
+ }
454
+ }
455
+ if (!(parsedDate instanceof Date && !isNaN(parsedDate.getTime()))) {
456
+ config.errorHandler(new Error("Invalid date provided: " + dateOrig));
457
+ return void 0;
458
+ }
459
+ if (timeless === true)
460
+ parsedDate.setHours(0, 0, 0, 0);
461
+ return parsedDate;
462
+ };
463
+ };
464
+ function compareDates(date1, date2, timeless) {
465
+ if (timeless === void 0) {
466
+ timeless = true;
467
+ }
468
+ if (timeless !== false) {
469
+ return new Date(date1.getTime()).setHours(0, 0, 0, 0) - new Date(date2.getTime()).setHours(0, 0, 0, 0);
470
+ }
471
+ return date1.getTime() - date2.getTime();
472
+ }
473
+ var isBetween = function(ts, ts1, ts2) {
474
+ return ts > Math.min(ts1, ts2) && ts < Math.max(ts1, ts2);
475
+ };
476
+ var calculateSecondsSinceMidnight = function(hours, minutes, seconds) {
477
+ return hours * 3600 + minutes * 60 + seconds;
478
+ };
479
+ var parseSeconds = function(secondsSinceMidnight) {
480
+ var hours = Math.floor(secondsSinceMidnight / 3600), minutes = (secondsSinceMidnight - hours * 3600) / 60;
481
+ return [hours, minutes, secondsSinceMidnight - hours * 3600 - minutes * 60];
482
+ };
483
+ var duration = {
484
+ DAY: 864e5
485
+ };
486
+ function getDefaultHours(config) {
487
+ var hours = config.defaultHour;
488
+ var minutes = config.defaultMinute;
489
+ var seconds = config.defaultSeconds;
490
+ if (config.minDate !== void 0) {
491
+ var minHour = config.minDate.getHours();
492
+ var minMinutes = config.minDate.getMinutes();
493
+ var minSeconds = config.minDate.getSeconds();
494
+ if (hours < minHour) {
495
+ hours = minHour;
496
+ }
497
+ if (hours === minHour && minutes < minMinutes) {
498
+ minutes = minMinutes;
499
+ }
500
+ if (hours === minHour && minutes === minMinutes && seconds < minSeconds)
501
+ seconds = config.minDate.getSeconds();
502
+ }
503
+ if (config.maxDate !== void 0) {
504
+ var maxHr = config.maxDate.getHours();
505
+ var maxMinutes = config.maxDate.getMinutes();
506
+ hours = Math.min(hours, maxHr);
507
+ if (hours === maxHr)
508
+ minutes = Math.min(maxMinutes, minutes);
509
+ if (hours === maxHr && minutes === maxMinutes)
510
+ seconds = config.maxDate.getSeconds();
511
+ }
512
+ return { hours, minutes, seconds };
513
+ }
514
+ if (typeof Object.assign !== "function") {
515
+ Object.assign = function(target) {
516
+ var args = [];
517
+ for (var _i = 1; _i < arguments.length; _i++) {
518
+ args[_i - 1] = arguments[_i];
519
+ }
520
+ if (!target) {
521
+ throw TypeError("Cannot convert undefined or null to object");
522
+ }
523
+ var _loop_1 = function(source2) {
524
+ if (source2) {
525
+ Object.keys(source2).forEach(function(key) {
526
+ return target[key] = source2[key];
527
+ });
528
+ }
529
+ };
530
+ for (var _a = 0, args_1 = args; _a < args_1.length; _a++) {
531
+ var source = args_1[_a];
532
+ _loop_1(source);
533
+ }
534
+ return target;
535
+ };
536
+ }
537
+ var __assign = function() {
538
+ __assign = Object.assign || function(t) {
539
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
540
+ s = arguments[i];
541
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
542
+ t[p] = s[p];
543
+ }
544
+ return t;
545
+ };
546
+ return __assign.apply(this, arguments);
547
+ };
548
+ var __spreadArrays = function() {
549
+ for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;
550
+ for (var r = Array(s), k = 0, i = 0; i < il; i++)
551
+ for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)
552
+ r[k] = a[j];
553
+ return r;
554
+ };
555
+ var DEBOUNCED_CHANGE_MS = 300;
556
+ function FlatpickrInstance(element, instanceConfig) {
557
+ var self = {
558
+ config: __assign(__assign({}, defaults), flatpickr.defaultConfig),
559
+ l10n: english
560
+ };
561
+ self.parseDate = createDateParser({ config: self.config, l10n: self.l10n });
562
+ self._handlers = [];
563
+ self.pluginElements = [];
564
+ self.loadedPlugins = [];
565
+ self._bind = bind;
566
+ self._setHoursFromDate = setHoursFromDate;
567
+ self._positionCalendar = positionCalendar;
568
+ self.changeMonth = changeMonth;
569
+ self.changeYear = changeYear;
570
+ self.clear = clear;
571
+ self.close = close;
572
+ self.onMouseOver = onMouseOver;
573
+ self._createElement = createElement;
574
+ self.createDay = createDay;
575
+ self.destroy = destroy;
576
+ self.isEnabled = isEnabled;
577
+ self.jumpToDate = jumpToDate;
578
+ self.updateValue = updateValue;
579
+ self.open = open;
580
+ self.redraw = redraw;
581
+ self.set = set;
582
+ self.setDate = setDate;
583
+ self.toggle = toggle;
584
+ function setupHelperFunctions() {
585
+ self.utils = {
586
+ getDaysInMonth: function(month, yr) {
587
+ if (month === void 0) {
588
+ month = self.currentMonth;
589
+ }
590
+ if (yr === void 0) {
591
+ yr = self.currentYear;
592
+ }
593
+ if (month === 1 && (yr % 4 === 0 && yr % 100 !== 0 || yr % 400 === 0))
594
+ return 29;
595
+ return self.l10n.daysInMonth[month];
596
+ }
597
+ };
598
+ }
599
+ function init() {
600
+ self.element = self.input = element;
601
+ self.isOpen = false;
602
+ parseConfig();
603
+ setupLocale();
604
+ setupInputs();
605
+ setupDates();
606
+ setupHelperFunctions();
607
+ if (!self.isMobile)
608
+ build();
609
+ bindEvents();
610
+ if (self.selectedDates.length || self.config.noCalendar) {
611
+ if (self.config.enableTime) {
612
+ setHoursFromDate(self.config.noCalendar ? self.latestSelectedDateObj : void 0);
613
+ }
614
+ updateValue(false);
615
+ }
616
+ setCalendarWidth();
617
+ var isSafari = /^((?!chrome|android).)*safari/i.test(navigator.userAgent);
618
+ if (!self.isMobile && isSafari) {
619
+ positionCalendar();
620
+ }
621
+ triggerEvent("onReady");
622
+ }
623
+ function getClosestActiveElement() {
624
+ var _a;
625
+ return ((_a = self.calendarContainer) === null || _a === void 0 ? void 0 : _a.getRootNode()).activeElement || document.activeElement;
626
+ }
627
+ function bindToInstance(fn) {
628
+ return fn.bind(self);
629
+ }
630
+ function setCalendarWidth() {
631
+ var config = self.config;
632
+ if (config.weekNumbers === false && config.showMonths === 1) {
633
+ return;
634
+ } else if (config.noCalendar !== true) {
635
+ window.requestAnimationFrame(function() {
636
+ if (self.calendarContainer !== void 0) {
637
+ self.calendarContainer.style.visibility = "hidden";
638
+ self.calendarContainer.style.display = "block";
639
+ }
640
+ if (self.daysContainer !== void 0) {
641
+ var daysWidth = (self.days.offsetWidth + 1) * config.showMonths;
642
+ self.daysContainer.style.width = daysWidth + "px";
643
+ self.calendarContainer.style.width = daysWidth + (self.weekWrapper !== void 0 ? self.weekWrapper.offsetWidth : 0) + "px";
644
+ self.calendarContainer.style.removeProperty("visibility");
645
+ self.calendarContainer.style.removeProperty("display");
646
+ }
647
+ });
648
+ }
649
+ }
650
+ function updateTime(e) {
651
+ if (self.selectedDates.length === 0) {
652
+ var defaultDate = self.config.minDate === void 0 || compareDates(/* @__PURE__ */ new Date(), self.config.minDate) >= 0 ? /* @__PURE__ */ new Date() : new Date(self.config.minDate.getTime());
653
+ var defaults2 = getDefaultHours(self.config);
654
+ defaultDate.setHours(defaults2.hours, defaults2.minutes, defaults2.seconds, defaultDate.getMilliseconds());
655
+ self.selectedDates = [defaultDate];
656
+ self.latestSelectedDateObj = defaultDate;
657
+ }
658
+ if (e !== void 0 && e.type !== "blur") {
659
+ timeWrapper(e);
660
+ }
661
+ var prevValue = self._input.value;
662
+ setHoursFromInputs();
663
+ updateValue();
664
+ if (self._input.value !== prevValue) {
665
+ self._debouncedChange();
666
+ }
667
+ }
668
+ function ampm2military(hour, amPM) {
669
+ return hour % 12 + 12 * int(amPM === self.l10n.amPM[1]);
670
+ }
671
+ function military2ampm(hour) {
672
+ switch (hour % 24) {
673
+ case 0:
674
+ case 12:
675
+ return 12;
676
+ default:
677
+ return hour % 12;
678
+ }
679
+ }
680
+ function setHoursFromInputs() {
681
+ if (self.hourElement === void 0 || self.minuteElement === void 0)
682
+ return;
683
+ var hours = (parseInt(self.hourElement.value.slice(-2), 10) || 0) % 24, minutes = (parseInt(self.minuteElement.value, 10) || 0) % 60, seconds = self.secondElement !== void 0 ? (parseInt(self.secondElement.value, 10) || 0) % 60 : 0;
684
+ if (self.amPM !== void 0) {
685
+ hours = ampm2military(hours, self.amPM.textContent);
686
+ }
687
+ var limitMinHours = self.config.minTime !== void 0 || self.config.minDate && self.minDateHasTime && self.latestSelectedDateObj && compareDates(self.latestSelectedDateObj, self.config.minDate, true) === 0;
688
+ var limitMaxHours = self.config.maxTime !== void 0 || self.config.maxDate && self.maxDateHasTime && self.latestSelectedDateObj && compareDates(self.latestSelectedDateObj, self.config.maxDate, true) === 0;
689
+ if (self.config.maxTime !== void 0 && self.config.minTime !== void 0 && self.config.minTime > self.config.maxTime) {
690
+ var minBound = calculateSecondsSinceMidnight(self.config.minTime.getHours(), self.config.minTime.getMinutes(), self.config.minTime.getSeconds());
691
+ var maxBound = calculateSecondsSinceMidnight(self.config.maxTime.getHours(), self.config.maxTime.getMinutes(), self.config.maxTime.getSeconds());
692
+ var currentTime = calculateSecondsSinceMidnight(hours, minutes, seconds);
693
+ if (currentTime > maxBound && currentTime < minBound) {
694
+ var result = parseSeconds(minBound);
695
+ hours = result[0];
696
+ minutes = result[1];
697
+ seconds = result[2];
698
+ }
699
+ } else {
700
+ if (limitMaxHours) {
701
+ var maxTime = self.config.maxTime !== void 0 ? self.config.maxTime : self.config.maxDate;
702
+ hours = Math.min(hours, maxTime.getHours());
703
+ if (hours === maxTime.getHours())
704
+ minutes = Math.min(minutes, maxTime.getMinutes());
705
+ if (minutes === maxTime.getMinutes())
706
+ seconds = Math.min(seconds, maxTime.getSeconds());
707
+ }
708
+ if (limitMinHours) {
709
+ var minTime = self.config.minTime !== void 0 ? self.config.minTime : self.config.minDate;
710
+ hours = Math.max(hours, minTime.getHours());
711
+ if (hours === minTime.getHours() && minutes < minTime.getMinutes())
712
+ minutes = minTime.getMinutes();
713
+ if (minutes === minTime.getMinutes())
714
+ seconds = Math.max(seconds, minTime.getSeconds());
715
+ }
716
+ }
717
+ setHours(hours, minutes, seconds);
718
+ }
719
+ function setHoursFromDate(dateObj) {
720
+ var date = dateObj || self.latestSelectedDateObj;
721
+ if (date && date instanceof Date) {
722
+ setHours(date.getHours(), date.getMinutes(), date.getSeconds());
723
+ }
724
+ }
725
+ function setHours(hours, minutes, seconds) {
726
+ if (self.latestSelectedDateObj !== void 0) {
727
+ self.latestSelectedDateObj.setHours(hours % 24, minutes, seconds || 0, 0);
728
+ }
729
+ if (!self.hourElement || !self.minuteElement || self.isMobile)
730
+ return;
731
+ self.hourElement.value = pad(!self.config.time_24hr ? (12 + hours) % 12 + 12 * int(hours % 12 === 0) : hours);
732
+ self.minuteElement.value = pad(minutes);
733
+ if (self.amPM !== void 0)
734
+ self.amPM.textContent = self.l10n.amPM[int(hours >= 12)];
735
+ if (self.secondElement !== void 0)
736
+ self.secondElement.value = pad(seconds);
737
+ }
738
+ function onYearInput(event) {
739
+ var eventTarget = getEventTarget(event);
740
+ var year = parseInt(eventTarget.value) + (event.delta || 0);
741
+ if (year / 1e3 > 1 || event.key === "Enter" && !/[^\d]/.test(year.toString())) {
742
+ changeYear(year);
743
+ }
744
+ }
745
+ function bind(element2, event, handler, options) {
746
+ if (event instanceof Array)
747
+ return event.forEach(function(ev) {
748
+ return bind(element2, ev, handler, options);
749
+ });
750
+ if (element2 instanceof Array)
751
+ return element2.forEach(function(el) {
752
+ return bind(el, event, handler, options);
753
+ });
754
+ element2.addEventListener(event, handler, options);
755
+ self._handlers.push({
756
+ remove: function() {
757
+ return element2.removeEventListener(event, handler, options);
758
+ }
759
+ });
760
+ }
761
+ function triggerChange() {
762
+ triggerEvent("onChange");
763
+ }
764
+ function bindEvents() {
765
+ if (self.config.wrap) {
766
+ ["open", "close", "toggle", "clear"].forEach(function(evt) {
767
+ Array.prototype.forEach.call(self.element.querySelectorAll("[data-" + evt + "]"), function(el) {
768
+ return bind(el, "click", self[evt]);
769
+ });
770
+ });
771
+ }
772
+ if (self.isMobile) {
773
+ setupMobile();
774
+ return;
775
+ }
776
+ var debouncedResize = debounce(onResize, 50);
777
+ self._debouncedChange = debounce(triggerChange, DEBOUNCED_CHANGE_MS);
778
+ if (self.daysContainer && !/iPhone|iPad|iPod/i.test(navigator.userAgent))
779
+ bind(self.daysContainer, "mouseover", function(e) {
780
+ if (self.config.mode === "range")
781
+ onMouseOver(getEventTarget(e));
782
+ });
783
+ bind(self._input, "keydown", onKeyDown);
784
+ if (self.calendarContainer !== void 0) {
785
+ bind(self.calendarContainer, "keydown", onKeyDown);
786
+ }
787
+ if (!self.config.inline && !self.config.static)
788
+ bind(window, "resize", debouncedResize);
789
+ if (window.ontouchstart !== void 0)
790
+ bind(window.document, "touchstart", documentClick);
791
+ else
792
+ bind(window.document, "mousedown", documentClick);
793
+ bind(window.document, "focus", documentClick, { capture: true });
794
+ if (self.config.clickOpens === true) {
795
+ bind(self._input, "focus", self.open);
796
+ bind(self._input, "click", self.open);
797
+ }
798
+ if (self.daysContainer !== void 0) {
799
+ bind(self.monthNav, "click", onMonthNavClick);
800
+ bind(self.monthNav, ["keyup", "increment"], onYearInput);
801
+ bind(self.daysContainer, "click", selectDate);
802
+ }
803
+ if (self.timeContainer !== void 0 && self.minuteElement !== void 0 && self.hourElement !== void 0) {
804
+ var selText = function(e) {
805
+ return getEventTarget(e).select();
806
+ };
807
+ bind(self.timeContainer, ["increment"], updateTime);
808
+ bind(self.timeContainer, "blur", updateTime, { capture: true });
809
+ bind(self.timeContainer, "click", timeIncrement);
810
+ bind([self.hourElement, self.minuteElement], ["focus", "click"], selText);
811
+ if (self.secondElement !== void 0)
812
+ bind(self.secondElement, "focus", function() {
813
+ return self.secondElement && self.secondElement.select();
814
+ });
815
+ if (self.amPM !== void 0) {
816
+ bind(self.amPM, "click", function(e) {
817
+ updateTime(e);
818
+ });
819
+ }
820
+ }
821
+ if (self.config.allowInput) {
822
+ bind(self._input, "blur", onBlur);
823
+ }
824
+ }
825
+ function jumpToDate(jumpDate, triggerChange2) {
826
+ var jumpTo = jumpDate !== void 0 ? self.parseDate(jumpDate) : self.latestSelectedDateObj || (self.config.minDate && self.config.minDate > self.now ? self.config.minDate : self.config.maxDate && self.config.maxDate < self.now ? self.config.maxDate : self.now);
827
+ var oldYear = self.currentYear;
828
+ var oldMonth = self.currentMonth;
829
+ try {
830
+ if (jumpTo !== void 0) {
831
+ self.currentYear = jumpTo.getFullYear();
832
+ self.currentMonth = jumpTo.getMonth();
833
+ }
834
+ } catch (e) {
835
+ e.message = "Invalid date supplied: " + jumpTo;
836
+ self.config.errorHandler(e);
837
+ }
838
+ if (triggerChange2 && self.currentYear !== oldYear) {
839
+ triggerEvent("onYearChange");
840
+ buildMonthSwitch();
841
+ }
842
+ if (triggerChange2 && (self.currentYear !== oldYear || self.currentMonth !== oldMonth)) {
843
+ triggerEvent("onMonthChange");
844
+ }
845
+ self.redraw();
846
+ }
847
+ function timeIncrement(e) {
848
+ var eventTarget = getEventTarget(e);
849
+ if (~eventTarget.className.indexOf("arrow"))
850
+ incrementNumInput(e, eventTarget.classList.contains("arrowUp") ? 1 : -1);
851
+ }
852
+ function incrementNumInput(e, delta, inputElem) {
853
+ var target = e && getEventTarget(e);
854
+ var input = inputElem || target && target.parentNode && target.parentNode.firstChild;
855
+ var event = createEvent("increment");
856
+ event.delta = delta;
857
+ input && input.dispatchEvent(event);
858
+ }
859
+ function build() {
860
+ var fragment = window.document.createDocumentFragment();
861
+ self.calendarContainer = createElement("div", "flatpickr-calendar");
862
+ self.calendarContainer.tabIndex = -1;
863
+ if (!self.config.noCalendar) {
864
+ fragment.appendChild(buildMonthNav());
865
+ self.innerContainer = createElement("div", "flatpickr-innerContainer");
866
+ if (self.config.weekNumbers) {
867
+ var _a = buildWeeks(), weekWrapper = _a.weekWrapper, weekNumbers = _a.weekNumbers;
868
+ self.innerContainer.appendChild(weekWrapper);
869
+ self.weekNumbers = weekNumbers;
870
+ self.weekWrapper = weekWrapper;
871
+ }
872
+ self.rContainer = createElement("div", "flatpickr-rContainer");
873
+ self.rContainer.appendChild(buildWeekdays());
874
+ if (!self.daysContainer) {
875
+ self.daysContainer = createElement("div", "flatpickr-days");
876
+ self.daysContainer.tabIndex = -1;
877
+ }
878
+ buildDays();
879
+ self.rContainer.appendChild(self.daysContainer);
880
+ self.innerContainer.appendChild(self.rContainer);
881
+ fragment.appendChild(self.innerContainer);
882
+ }
883
+ if (self.config.enableTime) {
884
+ fragment.appendChild(buildTime());
885
+ }
886
+ toggleClass(self.calendarContainer, "rangeMode", self.config.mode === "range");
887
+ toggleClass(self.calendarContainer, "animate", self.config.animate === true);
888
+ toggleClass(self.calendarContainer, "multiMonth", self.config.showMonths > 1);
889
+ self.calendarContainer.appendChild(fragment);
890
+ var customAppend = self.config.appendTo !== void 0 && self.config.appendTo.nodeType !== void 0;
891
+ if (self.config.inline || self.config.static) {
892
+ self.calendarContainer.classList.add(self.config.inline ? "inline" : "static");
893
+ if (self.config.inline) {
894
+ if (!customAppend && self.element.parentNode)
895
+ self.element.parentNode.insertBefore(self.calendarContainer, self._input.nextSibling);
896
+ else if (self.config.appendTo !== void 0)
897
+ self.config.appendTo.appendChild(self.calendarContainer);
898
+ }
899
+ if (self.config.static) {
900
+ var wrapper = createElement("div", "flatpickr-wrapper");
901
+ if (self.element.parentNode)
902
+ self.element.parentNode.insertBefore(wrapper, self.element);
903
+ wrapper.appendChild(self.element);
904
+ if (self.altInput)
905
+ wrapper.appendChild(self.altInput);
906
+ wrapper.appendChild(self.calendarContainer);
907
+ }
908
+ }
909
+ if (!self.config.static && !self.config.inline)
910
+ (self.config.appendTo !== void 0 ? self.config.appendTo : window.document.body).appendChild(self.calendarContainer);
911
+ }
912
+ function createDay(className, date, _dayNumber, i) {
913
+ var dateIsEnabled = isEnabled(date, true), dayElement = createElement("span", className, date.getDate().toString());
914
+ dayElement.dateObj = date;
915
+ dayElement.$i = i;
916
+ dayElement.setAttribute("aria-label", self.formatDate(date, self.config.ariaDateFormat));
917
+ if (className.indexOf("hidden") === -1 && compareDates(date, self.now) === 0) {
918
+ self.todayDateElem = dayElement;
919
+ dayElement.classList.add("today");
920
+ dayElement.setAttribute("aria-current", "date");
921
+ }
922
+ if (dateIsEnabled) {
923
+ dayElement.tabIndex = -1;
924
+ if (isDateSelected(date)) {
925
+ dayElement.classList.add("selected");
926
+ self.selectedDateElem = dayElement;
927
+ if (self.config.mode === "range") {
928
+ toggleClass(dayElement, "startRange", self.selectedDates[0] && compareDates(date, self.selectedDates[0], true) === 0);
929
+ toggleClass(dayElement, "endRange", self.selectedDates[1] && compareDates(date, self.selectedDates[1], true) === 0);
930
+ if (className === "nextMonthDay")
931
+ dayElement.classList.add("inRange");
932
+ }
933
+ }
934
+ } else {
935
+ dayElement.classList.add("flatpickr-disabled");
936
+ }
937
+ if (self.config.mode === "range") {
938
+ if (isDateInRange(date) && !isDateSelected(date))
939
+ dayElement.classList.add("inRange");
940
+ }
941
+ if (self.weekNumbers && self.config.showMonths === 1 && className !== "prevMonthDay" && i % 7 === 6) {
942
+ self.weekNumbers.insertAdjacentHTML("beforeend", "<span class='flatpickr-day'>" + self.config.getWeek(date) + "</span>");
943
+ }
944
+ triggerEvent("onDayCreate", dayElement);
945
+ return dayElement;
946
+ }
947
+ function focusOnDayElem(targetNode) {
948
+ targetNode.focus();
949
+ if (self.config.mode === "range")
950
+ onMouseOver(targetNode);
951
+ }
952
+ function getFirstAvailableDay(delta) {
953
+ var startMonth = delta > 0 ? 0 : self.config.showMonths - 1;
954
+ var endMonth = delta > 0 ? self.config.showMonths : -1;
955
+ for (var m = startMonth; m != endMonth; m += delta) {
956
+ var month = self.daysContainer.children[m];
957
+ var startIndex = delta > 0 ? 0 : month.children.length - 1;
958
+ var endIndex = delta > 0 ? month.children.length : -1;
959
+ for (var i = startIndex; i != endIndex; i += delta) {
960
+ var c = month.children[i];
961
+ if (c.className.indexOf("hidden") === -1 && isEnabled(c.dateObj))
962
+ return c;
963
+ }
964
+ }
965
+ return void 0;
966
+ }
967
+ function getNextAvailableDay(current, delta) {
968
+ var givenMonth = current.className.indexOf("Month") === -1 ? current.dateObj.getMonth() : self.currentMonth;
969
+ var endMonth = delta > 0 ? self.config.showMonths : -1;
970
+ var loopDelta = delta > 0 ? 1 : -1;
971
+ for (var m = givenMonth - self.currentMonth; m != endMonth; m += loopDelta) {
972
+ var month = self.daysContainer.children[m];
973
+ var startIndex = givenMonth - self.currentMonth === m ? current.$i + delta : delta < 0 ? month.children.length - 1 : 0;
974
+ var numMonthDays = month.children.length;
975
+ for (var i = startIndex; i >= 0 && i < numMonthDays && i != (delta > 0 ? numMonthDays : -1); i += loopDelta) {
976
+ var c = month.children[i];
977
+ if (c.className.indexOf("hidden") === -1 && isEnabled(c.dateObj) && Math.abs(current.$i - i) >= Math.abs(delta))
978
+ return focusOnDayElem(c);
979
+ }
980
+ }
981
+ self.changeMonth(loopDelta);
982
+ focusOnDay(getFirstAvailableDay(loopDelta), 0);
983
+ return void 0;
984
+ }
985
+ function focusOnDay(current, offset) {
986
+ var activeElement = getClosestActiveElement();
987
+ var dayFocused = isInView(activeElement || document.body);
988
+ var startElem = current !== void 0 ? current : dayFocused ? activeElement : self.selectedDateElem !== void 0 && isInView(self.selectedDateElem) ? self.selectedDateElem : self.todayDateElem !== void 0 && isInView(self.todayDateElem) ? self.todayDateElem : getFirstAvailableDay(offset > 0 ? 1 : -1);
989
+ if (startElem === void 0) {
990
+ self._input.focus();
991
+ } else if (!dayFocused) {
992
+ focusOnDayElem(startElem);
993
+ } else {
994
+ getNextAvailableDay(startElem, offset);
995
+ }
996
+ }
997
+ function buildMonthDays(year, month) {
998
+ var firstOfMonth = (new Date(year, month, 1).getDay() - self.l10n.firstDayOfWeek + 7) % 7;
999
+ var prevMonthDays = self.utils.getDaysInMonth((month - 1 + 12) % 12, year);
1000
+ var daysInMonth = self.utils.getDaysInMonth(month, year), days = window.document.createDocumentFragment(), isMultiMonth = self.config.showMonths > 1, prevMonthDayClass = isMultiMonth ? "prevMonthDay hidden" : "prevMonthDay", nextMonthDayClass = isMultiMonth ? "nextMonthDay hidden" : "nextMonthDay";
1001
+ var dayNumber = prevMonthDays + 1 - firstOfMonth, dayIndex = 0;
1002
+ for (; dayNumber <= prevMonthDays; dayNumber++, dayIndex++) {
1003
+ days.appendChild(createDay("flatpickr-day " + prevMonthDayClass, new Date(year, month - 1, dayNumber), dayNumber, dayIndex));
1004
+ }
1005
+ for (dayNumber = 1; dayNumber <= daysInMonth; dayNumber++, dayIndex++) {
1006
+ days.appendChild(createDay("flatpickr-day", new Date(year, month, dayNumber), dayNumber, dayIndex));
1007
+ }
1008
+ for (var dayNum = daysInMonth + 1; dayNum <= 42 - firstOfMonth && (self.config.showMonths === 1 || dayIndex % 7 !== 0); dayNum++, dayIndex++) {
1009
+ days.appendChild(createDay("flatpickr-day " + nextMonthDayClass, new Date(year, month + 1, dayNum % daysInMonth), dayNum, dayIndex));
1010
+ }
1011
+ var dayContainer = createElement("div", "dayContainer");
1012
+ dayContainer.appendChild(days);
1013
+ return dayContainer;
1014
+ }
1015
+ function buildDays() {
1016
+ if (self.daysContainer === void 0) {
1017
+ return;
1018
+ }
1019
+ clearNode(self.daysContainer);
1020
+ if (self.weekNumbers)
1021
+ clearNode(self.weekNumbers);
1022
+ var frag = document.createDocumentFragment();
1023
+ for (var i = 0; i < self.config.showMonths; i++) {
1024
+ var d = new Date(self.currentYear, self.currentMonth, 1);
1025
+ d.setMonth(self.currentMonth + i);
1026
+ frag.appendChild(buildMonthDays(d.getFullYear(), d.getMonth()));
1027
+ }
1028
+ self.daysContainer.appendChild(frag);
1029
+ self.days = self.daysContainer.firstChild;
1030
+ if (self.config.mode === "range" && self.selectedDates.length === 1) {
1031
+ onMouseOver();
1032
+ }
1033
+ }
1034
+ function buildMonthSwitch() {
1035
+ if (self.config.showMonths > 1 || self.config.monthSelectorType !== "dropdown")
1036
+ return;
1037
+ var shouldBuildMonth = function(month2) {
1038
+ if (self.config.minDate !== void 0 && self.currentYear === self.config.minDate.getFullYear() && month2 < self.config.minDate.getMonth()) {
1039
+ return false;
1040
+ }
1041
+ return !(self.config.maxDate !== void 0 && self.currentYear === self.config.maxDate.getFullYear() && month2 > self.config.maxDate.getMonth());
1042
+ };
1043
+ self.monthsDropdownContainer.tabIndex = -1;
1044
+ self.monthsDropdownContainer.innerHTML = "";
1045
+ for (var i = 0; i < 12; i++) {
1046
+ if (!shouldBuildMonth(i))
1047
+ continue;
1048
+ var month = createElement("option", "flatpickr-monthDropdown-month");
1049
+ month.value = new Date(self.currentYear, i).getMonth().toString();
1050
+ month.textContent = monthToStr(i, self.config.shorthandCurrentMonth, self.l10n);
1051
+ month.tabIndex = -1;
1052
+ if (self.currentMonth === i) {
1053
+ month.selected = true;
1054
+ }
1055
+ self.monthsDropdownContainer.appendChild(month);
1056
+ }
1057
+ }
1058
+ function buildMonth() {
1059
+ var container = createElement("div", "flatpickr-month");
1060
+ var monthNavFragment = window.document.createDocumentFragment();
1061
+ var monthElement;
1062
+ if (self.config.showMonths > 1 || self.config.monthSelectorType === "static") {
1063
+ monthElement = createElement("span", "cur-month");
1064
+ } else {
1065
+ self.monthsDropdownContainer = createElement("select", "flatpickr-monthDropdown-months");
1066
+ self.monthsDropdownContainer.setAttribute("aria-label", self.l10n.monthAriaLabel);
1067
+ bind(self.monthsDropdownContainer, "change", function(e) {
1068
+ var target = getEventTarget(e);
1069
+ var selectedMonth = parseInt(target.value, 10);
1070
+ self.changeMonth(selectedMonth - self.currentMonth);
1071
+ triggerEvent("onMonthChange");
1072
+ });
1073
+ buildMonthSwitch();
1074
+ monthElement = self.monthsDropdownContainer;
1075
+ }
1076
+ var yearInput = createNumberInput("cur-year", { tabindex: "-1" });
1077
+ var yearElement = yearInput.getElementsByTagName("input")[0];
1078
+ yearElement.setAttribute("aria-label", self.l10n.yearAriaLabel);
1079
+ if (self.config.minDate) {
1080
+ yearElement.setAttribute("min", self.config.minDate.getFullYear().toString());
1081
+ }
1082
+ if (self.config.maxDate) {
1083
+ yearElement.setAttribute("max", self.config.maxDate.getFullYear().toString());
1084
+ yearElement.disabled = !!self.config.minDate && self.config.minDate.getFullYear() === self.config.maxDate.getFullYear();
1085
+ }
1086
+ var currentMonth = createElement("div", "flatpickr-current-month");
1087
+ currentMonth.appendChild(monthElement);
1088
+ currentMonth.appendChild(yearInput);
1089
+ monthNavFragment.appendChild(currentMonth);
1090
+ container.appendChild(monthNavFragment);
1091
+ return {
1092
+ container,
1093
+ yearElement,
1094
+ monthElement
1095
+ };
1096
+ }
1097
+ function buildMonths() {
1098
+ clearNode(self.monthNav);
1099
+ self.monthNav.appendChild(self.prevMonthNav);
1100
+ if (self.config.showMonths) {
1101
+ self.yearElements = [];
1102
+ self.monthElements = [];
1103
+ }
1104
+ for (var m = self.config.showMonths; m--; ) {
1105
+ var month = buildMonth();
1106
+ self.yearElements.push(month.yearElement);
1107
+ self.monthElements.push(month.monthElement);
1108
+ self.monthNav.appendChild(month.container);
1109
+ }
1110
+ self.monthNav.appendChild(self.nextMonthNav);
1111
+ }
1112
+ function buildMonthNav() {
1113
+ self.monthNav = createElement("div", "flatpickr-months");
1114
+ self.yearElements = [];
1115
+ self.monthElements = [];
1116
+ self.prevMonthNav = createElement("span", "flatpickr-prev-month");
1117
+ self.prevMonthNav.innerHTML = self.config.prevArrow;
1118
+ self.nextMonthNav = createElement("span", "flatpickr-next-month");
1119
+ self.nextMonthNav.innerHTML = self.config.nextArrow;
1120
+ buildMonths();
1121
+ Object.defineProperty(self, "_hidePrevMonthArrow", {
1122
+ get: function() {
1123
+ return self.__hidePrevMonthArrow;
1124
+ },
1125
+ set: function(bool) {
1126
+ if (self.__hidePrevMonthArrow !== bool) {
1127
+ toggleClass(self.prevMonthNav, "flatpickr-disabled", bool);
1128
+ self.__hidePrevMonthArrow = bool;
1129
+ }
1130
+ }
1131
+ });
1132
+ Object.defineProperty(self, "_hideNextMonthArrow", {
1133
+ get: function() {
1134
+ return self.__hideNextMonthArrow;
1135
+ },
1136
+ set: function(bool) {
1137
+ if (self.__hideNextMonthArrow !== bool) {
1138
+ toggleClass(self.nextMonthNav, "flatpickr-disabled", bool);
1139
+ self.__hideNextMonthArrow = bool;
1140
+ }
1141
+ }
1142
+ });
1143
+ self.currentYearElement = self.yearElements[0];
1144
+ updateNavigationCurrentMonth();
1145
+ return self.monthNav;
1146
+ }
1147
+ function buildTime() {
1148
+ self.calendarContainer.classList.add("hasTime");
1149
+ if (self.config.noCalendar)
1150
+ self.calendarContainer.classList.add("noCalendar");
1151
+ var defaults2 = getDefaultHours(self.config);
1152
+ self.timeContainer = createElement("div", "flatpickr-time");
1153
+ self.timeContainer.tabIndex = -1;
1154
+ var separator = createElement("span", "flatpickr-time-separator", ":");
1155
+ var hourInput = createNumberInput("flatpickr-hour", {
1156
+ "aria-label": self.l10n.hourAriaLabel
1157
+ });
1158
+ self.hourElement = hourInput.getElementsByTagName("input")[0];
1159
+ var minuteInput = createNumberInput("flatpickr-minute", {
1160
+ "aria-label": self.l10n.minuteAriaLabel
1161
+ });
1162
+ self.minuteElement = minuteInput.getElementsByTagName("input")[0];
1163
+ self.hourElement.tabIndex = self.minuteElement.tabIndex = -1;
1164
+ self.hourElement.value = pad(self.latestSelectedDateObj ? self.latestSelectedDateObj.getHours() : self.config.time_24hr ? defaults2.hours : military2ampm(defaults2.hours));
1165
+ self.minuteElement.value = pad(self.latestSelectedDateObj ? self.latestSelectedDateObj.getMinutes() : defaults2.minutes);
1166
+ self.hourElement.setAttribute("step", self.config.hourIncrement.toString());
1167
+ self.minuteElement.setAttribute("step", self.config.minuteIncrement.toString());
1168
+ self.hourElement.setAttribute("min", self.config.time_24hr ? "0" : "1");
1169
+ self.hourElement.setAttribute("max", self.config.time_24hr ? "23" : "12");
1170
+ self.hourElement.setAttribute("maxlength", "2");
1171
+ self.minuteElement.setAttribute("min", "0");
1172
+ self.minuteElement.setAttribute("max", "59");
1173
+ self.minuteElement.setAttribute("maxlength", "2");
1174
+ self.timeContainer.appendChild(hourInput);
1175
+ self.timeContainer.appendChild(separator);
1176
+ self.timeContainer.appendChild(minuteInput);
1177
+ if (self.config.time_24hr)
1178
+ self.timeContainer.classList.add("time24hr");
1179
+ if (self.config.enableSeconds) {
1180
+ self.timeContainer.classList.add("hasSeconds");
1181
+ var secondInput = createNumberInput("flatpickr-second");
1182
+ self.secondElement = secondInput.getElementsByTagName("input")[0];
1183
+ self.secondElement.value = pad(self.latestSelectedDateObj ? self.latestSelectedDateObj.getSeconds() : defaults2.seconds);
1184
+ self.secondElement.setAttribute("step", self.minuteElement.getAttribute("step"));
1185
+ self.secondElement.setAttribute("min", "0");
1186
+ self.secondElement.setAttribute("max", "59");
1187
+ self.secondElement.setAttribute("maxlength", "2");
1188
+ self.timeContainer.appendChild(createElement("span", "flatpickr-time-separator", ":"));
1189
+ self.timeContainer.appendChild(secondInput);
1190
+ }
1191
+ if (!self.config.time_24hr) {
1192
+ self.amPM = createElement("span", "flatpickr-am-pm", self.l10n.amPM[int((self.latestSelectedDateObj ? self.hourElement.value : self.config.defaultHour) > 11)]);
1193
+ self.amPM.title = self.l10n.toggleTitle;
1194
+ self.amPM.tabIndex = -1;
1195
+ self.timeContainer.appendChild(self.amPM);
1196
+ }
1197
+ return self.timeContainer;
1198
+ }
1199
+ function buildWeekdays() {
1200
+ if (!self.weekdayContainer)
1201
+ self.weekdayContainer = createElement("div", "flatpickr-weekdays");
1202
+ else
1203
+ clearNode(self.weekdayContainer);
1204
+ for (var i = self.config.showMonths; i--; ) {
1205
+ var container = createElement("div", "flatpickr-weekdaycontainer");
1206
+ self.weekdayContainer.appendChild(container);
1207
+ }
1208
+ updateWeekdays();
1209
+ return self.weekdayContainer;
1210
+ }
1211
+ function updateWeekdays() {
1212
+ if (!self.weekdayContainer) {
1213
+ return;
1214
+ }
1215
+ var firstDayOfWeek = self.l10n.firstDayOfWeek;
1216
+ var weekdays = __spreadArrays(self.l10n.weekdays.shorthand);
1217
+ if (firstDayOfWeek > 0 && firstDayOfWeek < weekdays.length) {
1218
+ weekdays = __spreadArrays(weekdays.splice(firstDayOfWeek, weekdays.length), weekdays.splice(0, firstDayOfWeek));
1219
+ }
1220
+ for (var i = self.config.showMonths; i--; ) {
1221
+ self.weekdayContainer.children[i].innerHTML = "\n <span class='flatpickr-weekday'>\n " + weekdays.join("</span><span class='flatpickr-weekday'>") + "\n </span>\n ";
1222
+ }
1223
+ }
1224
+ function buildWeeks() {
1225
+ self.calendarContainer.classList.add("hasWeeks");
1226
+ var weekWrapper = createElement("div", "flatpickr-weekwrapper");
1227
+ weekWrapper.appendChild(createElement("span", "flatpickr-weekday", self.l10n.weekAbbreviation));
1228
+ var weekNumbers = createElement("div", "flatpickr-weeks");
1229
+ weekWrapper.appendChild(weekNumbers);
1230
+ return {
1231
+ weekWrapper,
1232
+ weekNumbers
1233
+ };
1234
+ }
1235
+ function changeMonth(value, isOffset) {
1236
+ if (isOffset === void 0) {
1237
+ isOffset = true;
1238
+ }
1239
+ var delta = isOffset ? value : value - self.currentMonth;
1240
+ if (delta < 0 && self._hidePrevMonthArrow === true || delta > 0 && self._hideNextMonthArrow === true)
1241
+ return;
1242
+ self.currentMonth += delta;
1243
+ if (self.currentMonth < 0 || self.currentMonth > 11) {
1244
+ self.currentYear += self.currentMonth > 11 ? 1 : -1;
1245
+ self.currentMonth = (self.currentMonth + 12) % 12;
1246
+ triggerEvent("onYearChange");
1247
+ buildMonthSwitch();
1248
+ }
1249
+ buildDays();
1250
+ triggerEvent("onMonthChange");
1251
+ updateNavigationCurrentMonth();
1252
+ }
1253
+ function clear(triggerChangeEvent, toInitial) {
1254
+ if (triggerChangeEvent === void 0) {
1255
+ triggerChangeEvent = true;
1256
+ }
1257
+ if (toInitial === void 0) {
1258
+ toInitial = true;
1259
+ }
1260
+ self.input.value = "";
1261
+ if (self.altInput !== void 0)
1262
+ self.altInput.value = "";
1263
+ if (self.mobileInput !== void 0)
1264
+ self.mobileInput.value = "";
1265
+ self.selectedDates = [];
1266
+ self.latestSelectedDateObj = void 0;
1267
+ if (toInitial === true) {
1268
+ self.currentYear = self._initialDate.getFullYear();
1269
+ self.currentMonth = self._initialDate.getMonth();
1270
+ }
1271
+ if (self.config.enableTime === true) {
1272
+ var _a = getDefaultHours(self.config), hours = _a.hours, minutes = _a.minutes, seconds = _a.seconds;
1273
+ setHours(hours, minutes, seconds);
1274
+ }
1275
+ self.redraw();
1276
+ if (triggerChangeEvent)
1277
+ triggerEvent("onChange");
1278
+ }
1279
+ function close() {
1280
+ self.isOpen = false;
1281
+ if (!self.isMobile) {
1282
+ if (self.calendarContainer !== void 0) {
1283
+ self.calendarContainer.classList.remove("open");
1284
+ }
1285
+ if (self._input !== void 0) {
1286
+ self._input.classList.remove("active");
1287
+ }
1288
+ }
1289
+ triggerEvent("onClose");
1290
+ }
1291
+ function destroy() {
1292
+ if (self.config !== void 0)
1293
+ triggerEvent("onDestroy");
1294
+ for (var i = self._handlers.length; i--; ) {
1295
+ self._handlers[i].remove();
1296
+ }
1297
+ self._handlers = [];
1298
+ if (self.mobileInput) {
1299
+ if (self.mobileInput.parentNode)
1300
+ self.mobileInput.parentNode.removeChild(self.mobileInput);
1301
+ self.mobileInput = void 0;
1302
+ } else if (self.calendarContainer && self.calendarContainer.parentNode) {
1303
+ if (self.config.static && self.calendarContainer.parentNode) {
1304
+ var wrapper = self.calendarContainer.parentNode;
1305
+ wrapper.lastChild && wrapper.removeChild(wrapper.lastChild);
1306
+ if (wrapper.parentNode) {
1307
+ while (wrapper.firstChild)
1308
+ wrapper.parentNode.insertBefore(wrapper.firstChild, wrapper);
1309
+ wrapper.parentNode.removeChild(wrapper);
1310
+ }
1311
+ } else
1312
+ self.calendarContainer.parentNode.removeChild(self.calendarContainer);
1313
+ }
1314
+ if (self.altInput) {
1315
+ self.input.type = "text";
1316
+ if (self.altInput.parentNode)
1317
+ self.altInput.parentNode.removeChild(self.altInput);
1318
+ delete self.altInput;
1319
+ }
1320
+ if (self.input) {
1321
+ self.input.type = self.input._type;
1322
+ self.input.classList.remove("flatpickr-input");
1323
+ self.input.removeAttribute("readonly");
1324
+ }
1325
+ [
1326
+ "_showTimeInput",
1327
+ "latestSelectedDateObj",
1328
+ "_hideNextMonthArrow",
1329
+ "_hidePrevMonthArrow",
1330
+ "__hideNextMonthArrow",
1331
+ "__hidePrevMonthArrow",
1332
+ "isMobile",
1333
+ "isOpen",
1334
+ "selectedDateElem",
1335
+ "minDateHasTime",
1336
+ "maxDateHasTime",
1337
+ "days",
1338
+ "daysContainer",
1339
+ "_input",
1340
+ "_positionElement",
1341
+ "innerContainer",
1342
+ "rContainer",
1343
+ "monthNav",
1344
+ "todayDateElem",
1345
+ "calendarContainer",
1346
+ "weekdayContainer",
1347
+ "prevMonthNav",
1348
+ "nextMonthNav",
1349
+ "monthsDropdownContainer",
1350
+ "currentMonthElement",
1351
+ "currentYearElement",
1352
+ "navigationCurrentMonth",
1353
+ "selectedDateElem",
1354
+ "config"
1355
+ ].forEach(function(k) {
1356
+ try {
1357
+ delete self[k];
1358
+ } catch (_) {
1359
+ }
1360
+ });
1361
+ }
1362
+ function isCalendarElem(elem) {
1363
+ return self.calendarContainer.contains(elem);
1364
+ }
1365
+ function documentClick(e) {
1366
+ if (self.isOpen && !self.config.inline) {
1367
+ var eventTarget_1 = getEventTarget(e);
1368
+ var isCalendarElement = isCalendarElem(eventTarget_1);
1369
+ var isInput = eventTarget_1 === self.input || eventTarget_1 === self.altInput || self.element.contains(eventTarget_1) || e.path && e.path.indexOf && (~e.path.indexOf(self.input) || ~e.path.indexOf(self.altInput));
1370
+ var lostFocus = !isInput && !isCalendarElement && !isCalendarElem(e.relatedTarget);
1371
+ var isIgnored = !self.config.ignoredFocusElements.some(function(elem) {
1372
+ return elem.contains(eventTarget_1);
1373
+ });
1374
+ if (lostFocus && isIgnored) {
1375
+ if (self.config.allowInput) {
1376
+ self.setDate(self._input.value, false, self.config.altInput ? self.config.altFormat : self.config.dateFormat);
1377
+ }
1378
+ if (self.timeContainer !== void 0 && self.minuteElement !== void 0 && self.hourElement !== void 0 && self.input.value !== "" && self.input.value !== void 0) {
1379
+ updateTime();
1380
+ }
1381
+ self.close();
1382
+ if (self.config && self.config.mode === "range" && self.selectedDates.length === 1)
1383
+ self.clear(false);
1384
+ }
1385
+ }
1386
+ }
1387
+ function changeYear(newYear) {
1388
+ if (!newYear || self.config.minDate && newYear < self.config.minDate.getFullYear() || self.config.maxDate && newYear > self.config.maxDate.getFullYear())
1389
+ return;
1390
+ var newYearNum = newYear, isNewYear = self.currentYear !== newYearNum;
1391
+ self.currentYear = newYearNum || self.currentYear;
1392
+ if (self.config.maxDate && self.currentYear === self.config.maxDate.getFullYear()) {
1393
+ self.currentMonth = Math.min(self.config.maxDate.getMonth(), self.currentMonth);
1394
+ } else if (self.config.minDate && self.currentYear === self.config.minDate.getFullYear()) {
1395
+ self.currentMonth = Math.max(self.config.minDate.getMonth(), self.currentMonth);
1396
+ }
1397
+ if (isNewYear) {
1398
+ self.redraw();
1399
+ triggerEvent("onYearChange");
1400
+ buildMonthSwitch();
1401
+ }
1402
+ }
1403
+ function isEnabled(date, timeless) {
1404
+ var _a;
1405
+ if (timeless === void 0) {
1406
+ timeless = true;
1407
+ }
1408
+ var dateToCheck = self.parseDate(date, void 0, timeless);
1409
+ if (self.config.minDate && dateToCheck && compareDates(dateToCheck, self.config.minDate, timeless !== void 0 ? timeless : !self.minDateHasTime) < 0 || self.config.maxDate && dateToCheck && compareDates(dateToCheck, self.config.maxDate, timeless !== void 0 ? timeless : !self.maxDateHasTime) > 0)
1410
+ return false;
1411
+ if (!self.config.enable && self.config.disable.length === 0)
1412
+ return true;
1413
+ if (dateToCheck === void 0)
1414
+ return false;
1415
+ var bool = !!self.config.enable, array = (_a = self.config.enable) !== null && _a !== void 0 ? _a : self.config.disable;
1416
+ for (var i = 0, d = void 0; i < array.length; i++) {
1417
+ d = array[i];
1418
+ if (typeof d === "function" && d(dateToCheck))
1419
+ return bool;
1420
+ else if (d instanceof Date && dateToCheck !== void 0 && d.getTime() === dateToCheck.getTime())
1421
+ return bool;
1422
+ else if (typeof d === "string") {
1423
+ var parsed = self.parseDate(d, void 0, true);
1424
+ return parsed && parsed.getTime() === dateToCheck.getTime() ? bool : !bool;
1425
+ } else if (typeof d === "object" && dateToCheck !== void 0 && d.from && d.to && dateToCheck.getTime() >= d.from.getTime() && dateToCheck.getTime() <= d.to.getTime())
1426
+ return bool;
1427
+ }
1428
+ return !bool;
1429
+ }
1430
+ function isInView(elem) {
1431
+ if (self.daysContainer !== void 0)
1432
+ return elem.className.indexOf("hidden") === -1 && elem.className.indexOf("flatpickr-disabled") === -1 && self.daysContainer.contains(elem);
1433
+ return false;
1434
+ }
1435
+ function onBlur(e) {
1436
+ var isInput = e.target === self._input;
1437
+ var valueChanged = self._input.value.trimEnd() !== getDateStr();
1438
+ if (isInput && valueChanged && !(e.relatedTarget && isCalendarElem(e.relatedTarget))) {
1439
+ self.setDate(self._input.value, true, e.target === self.altInput ? self.config.altFormat : self.config.dateFormat);
1440
+ }
1441
+ }
1442
+ function onKeyDown(e) {
1443
+ var eventTarget = getEventTarget(e);
1444
+ var isInput = self.config.wrap ? element.contains(eventTarget) : eventTarget === self._input;
1445
+ var allowInput = self.config.allowInput;
1446
+ var allowKeydown = self.isOpen && (!allowInput || !isInput);
1447
+ var allowInlineKeydown = self.config.inline && isInput && !allowInput;
1448
+ if (e.keyCode === 13 && isInput) {
1449
+ if (allowInput) {
1450
+ self.setDate(self._input.value, true, eventTarget === self.altInput ? self.config.altFormat : self.config.dateFormat);
1451
+ self.close();
1452
+ return eventTarget.blur();
1453
+ } else {
1454
+ self.open();
1455
+ }
1456
+ } else if (isCalendarElem(eventTarget) || allowKeydown || allowInlineKeydown) {
1457
+ var isTimeObj = !!self.timeContainer && self.timeContainer.contains(eventTarget);
1458
+ switch (e.keyCode) {
1459
+ case 13:
1460
+ if (isTimeObj) {
1461
+ e.preventDefault();
1462
+ updateTime();
1463
+ focusAndClose();
1464
+ } else
1465
+ selectDate(e);
1466
+ break;
1467
+ case 27:
1468
+ e.preventDefault();
1469
+ focusAndClose();
1470
+ break;
1471
+ case 8:
1472
+ case 46:
1473
+ if (isInput && !self.config.allowInput) {
1474
+ e.preventDefault();
1475
+ self.clear();
1476
+ }
1477
+ break;
1478
+ case 37:
1479
+ case 39:
1480
+ if (!isTimeObj && !isInput) {
1481
+ e.preventDefault();
1482
+ var activeElement = getClosestActiveElement();
1483
+ if (self.daysContainer !== void 0 && (allowInput === false || activeElement && isInView(activeElement))) {
1484
+ var delta_1 = e.keyCode === 39 ? 1 : -1;
1485
+ if (!e.ctrlKey)
1486
+ focusOnDay(void 0, delta_1);
1487
+ else {
1488
+ e.stopPropagation();
1489
+ changeMonth(delta_1);
1490
+ focusOnDay(getFirstAvailableDay(1), 0);
1491
+ }
1492
+ }
1493
+ } else if (self.hourElement)
1494
+ self.hourElement.focus();
1495
+ break;
1496
+ case 38:
1497
+ case 40:
1498
+ e.preventDefault();
1499
+ var delta = e.keyCode === 40 ? 1 : -1;
1500
+ if (self.daysContainer && eventTarget.$i !== void 0 || eventTarget === self.input || eventTarget === self.altInput) {
1501
+ if (e.ctrlKey) {
1502
+ e.stopPropagation();
1503
+ changeYear(self.currentYear - delta);
1504
+ focusOnDay(getFirstAvailableDay(1), 0);
1505
+ } else if (!isTimeObj)
1506
+ focusOnDay(void 0, delta * 7);
1507
+ } else if (eventTarget === self.currentYearElement) {
1508
+ changeYear(self.currentYear - delta);
1509
+ } else if (self.config.enableTime) {
1510
+ if (!isTimeObj && self.hourElement)
1511
+ self.hourElement.focus();
1512
+ updateTime(e);
1513
+ self._debouncedChange();
1514
+ }
1515
+ break;
1516
+ case 9:
1517
+ if (isTimeObj) {
1518
+ var elems = [
1519
+ self.hourElement,
1520
+ self.minuteElement,
1521
+ self.secondElement,
1522
+ self.amPM
1523
+ ].concat(self.pluginElements).filter(function(x) {
1524
+ return x;
1525
+ });
1526
+ var i = elems.indexOf(eventTarget);
1527
+ if (i !== -1) {
1528
+ var target = elems[i + (e.shiftKey ? -1 : 1)];
1529
+ e.preventDefault();
1530
+ (target || self._input).focus();
1531
+ }
1532
+ } else if (!self.config.noCalendar && self.daysContainer && self.daysContainer.contains(eventTarget) && e.shiftKey) {
1533
+ e.preventDefault();
1534
+ self._input.focus();
1535
+ }
1536
+ break;
1537
+ }
1538
+ }
1539
+ if (self.amPM !== void 0 && eventTarget === self.amPM) {
1540
+ switch (e.key) {
1541
+ case self.l10n.amPM[0].charAt(0):
1542
+ case self.l10n.amPM[0].charAt(0).toLowerCase():
1543
+ self.amPM.textContent = self.l10n.amPM[0];
1544
+ setHoursFromInputs();
1545
+ updateValue();
1546
+ break;
1547
+ case self.l10n.amPM[1].charAt(0):
1548
+ case self.l10n.amPM[1].charAt(0).toLowerCase():
1549
+ self.amPM.textContent = self.l10n.amPM[1];
1550
+ setHoursFromInputs();
1551
+ updateValue();
1552
+ break;
1553
+ }
1554
+ }
1555
+ if (isInput || isCalendarElem(eventTarget)) {
1556
+ triggerEvent("onKeyDown", e);
1557
+ }
1558
+ }
1559
+ function onMouseOver(elem, cellClass) {
1560
+ if (cellClass === void 0) {
1561
+ cellClass = "flatpickr-day";
1562
+ }
1563
+ if (self.selectedDates.length !== 1 || elem && (!elem.classList.contains(cellClass) || elem.classList.contains("flatpickr-disabled")))
1564
+ return;
1565
+ var hoverDate = elem ? elem.dateObj.getTime() : self.days.firstElementChild.dateObj.getTime(), initialDate = self.parseDate(self.selectedDates[0], void 0, true).getTime(), rangeStartDate = Math.min(hoverDate, self.selectedDates[0].getTime()), rangeEndDate = Math.max(hoverDate, self.selectedDates[0].getTime());
1566
+ var containsDisabled = false;
1567
+ var minRange = 0, maxRange = 0;
1568
+ for (var t = rangeStartDate; t < rangeEndDate; t += duration.DAY) {
1569
+ if (!isEnabled(new Date(t), true)) {
1570
+ containsDisabled = containsDisabled || t > rangeStartDate && t < rangeEndDate;
1571
+ if (t < initialDate && (!minRange || t > minRange))
1572
+ minRange = t;
1573
+ else if (t > initialDate && (!maxRange || t < maxRange))
1574
+ maxRange = t;
1575
+ }
1576
+ }
1577
+ var hoverableCells = Array.from(self.rContainer.querySelectorAll("*:nth-child(-n+" + self.config.showMonths + ") > ." + cellClass));
1578
+ hoverableCells.forEach(function(dayElem) {
1579
+ var date = dayElem.dateObj;
1580
+ var timestamp = date.getTime();
1581
+ var outOfRange = minRange > 0 && timestamp < minRange || maxRange > 0 && timestamp > maxRange;
1582
+ if (outOfRange) {
1583
+ dayElem.classList.add("notAllowed");
1584
+ ["inRange", "startRange", "endRange"].forEach(function(c) {
1585
+ dayElem.classList.remove(c);
1586
+ });
1587
+ return;
1588
+ } else if (containsDisabled && !outOfRange)
1589
+ return;
1590
+ ["startRange", "inRange", "endRange", "notAllowed"].forEach(function(c) {
1591
+ dayElem.classList.remove(c);
1592
+ });
1593
+ if (elem !== void 0) {
1594
+ elem.classList.add(hoverDate <= self.selectedDates[0].getTime() ? "startRange" : "endRange");
1595
+ if (initialDate < hoverDate && timestamp === initialDate)
1596
+ dayElem.classList.add("startRange");
1597
+ else if (initialDate > hoverDate && timestamp === initialDate)
1598
+ dayElem.classList.add("endRange");
1599
+ if (timestamp >= minRange && (maxRange === 0 || timestamp <= maxRange) && isBetween(timestamp, initialDate, hoverDate))
1600
+ dayElem.classList.add("inRange");
1601
+ }
1602
+ });
1603
+ }
1604
+ function onResize() {
1605
+ if (self.isOpen && !self.config.static && !self.config.inline)
1606
+ positionCalendar();
1607
+ }
1608
+ function open(e, positionElement) {
1609
+ if (positionElement === void 0) {
1610
+ positionElement = self._positionElement;
1611
+ }
1612
+ if (self.isMobile === true) {
1613
+ if (e) {
1614
+ e.preventDefault();
1615
+ var eventTarget = getEventTarget(e);
1616
+ if (eventTarget) {
1617
+ eventTarget.blur();
1618
+ }
1619
+ }
1620
+ if (self.mobileInput !== void 0) {
1621
+ self.mobileInput.focus();
1622
+ self.mobileInput.click();
1623
+ }
1624
+ triggerEvent("onOpen");
1625
+ return;
1626
+ } else if (self._input.disabled || self.config.inline) {
1627
+ return;
1628
+ }
1629
+ var wasOpen = self.isOpen;
1630
+ self.isOpen = true;
1631
+ if (!wasOpen) {
1632
+ self.calendarContainer.classList.add("open");
1633
+ self._input.classList.add("active");
1634
+ triggerEvent("onOpen");
1635
+ positionCalendar(positionElement);
1636
+ }
1637
+ if (self.config.enableTime === true && self.config.noCalendar === true) {
1638
+ if (self.config.allowInput === false && (e === void 0 || !self.timeContainer.contains(e.relatedTarget))) {
1639
+ setTimeout(function() {
1640
+ return self.hourElement.select();
1641
+ }, 50);
1642
+ }
1643
+ }
1644
+ }
1645
+ function minMaxDateSetter(type) {
1646
+ return function(date) {
1647
+ var dateObj = self.config["_" + type + "Date"] = self.parseDate(date, self.config.dateFormat);
1648
+ var inverseDateObj = self.config["_" + (type === "min" ? "max" : "min") + "Date"];
1649
+ if (dateObj !== void 0) {
1650
+ self[type === "min" ? "minDateHasTime" : "maxDateHasTime"] = dateObj.getHours() > 0 || dateObj.getMinutes() > 0 || dateObj.getSeconds() > 0;
1651
+ }
1652
+ if (self.selectedDates) {
1653
+ self.selectedDates = self.selectedDates.filter(function(d) {
1654
+ return isEnabled(d);
1655
+ });
1656
+ if (!self.selectedDates.length && type === "min")
1657
+ setHoursFromDate(dateObj);
1658
+ updateValue();
1659
+ }
1660
+ if (self.daysContainer) {
1661
+ redraw();
1662
+ if (dateObj !== void 0)
1663
+ self.currentYearElement[type] = dateObj.getFullYear().toString();
1664
+ else
1665
+ self.currentYearElement.removeAttribute(type);
1666
+ self.currentYearElement.disabled = !!inverseDateObj && dateObj !== void 0 && inverseDateObj.getFullYear() === dateObj.getFullYear();
1667
+ }
1668
+ };
1669
+ }
1670
+ function parseConfig() {
1671
+ var boolOpts = [
1672
+ "wrap",
1673
+ "weekNumbers",
1674
+ "allowInput",
1675
+ "allowInvalidPreload",
1676
+ "clickOpens",
1677
+ "time_24hr",
1678
+ "enableTime",
1679
+ "noCalendar",
1680
+ "altInput",
1681
+ "shorthandCurrentMonth",
1682
+ "inline",
1683
+ "static",
1684
+ "enableSeconds",
1685
+ "disableMobile"
1686
+ ];
1687
+ var userConfig = __assign(__assign({}, JSON.parse(JSON.stringify(element.dataset || {}))), instanceConfig);
1688
+ var formats2 = {};
1689
+ self.config.parseDate = userConfig.parseDate;
1690
+ self.config.formatDate = userConfig.formatDate;
1691
+ Object.defineProperty(self.config, "enable", {
1692
+ get: function() {
1693
+ return self.config._enable;
1694
+ },
1695
+ set: function(dates) {
1696
+ self.config._enable = parseDateRules(dates);
1697
+ }
1698
+ });
1699
+ Object.defineProperty(self.config, "disable", {
1700
+ get: function() {
1701
+ return self.config._disable;
1702
+ },
1703
+ set: function(dates) {
1704
+ self.config._disable = parseDateRules(dates);
1705
+ }
1706
+ });
1707
+ var timeMode = userConfig.mode === "time";
1708
+ if (!userConfig.dateFormat && (userConfig.enableTime || timeMode)) {
1709
+ var defaultDateFormat = flatpickr.defaultConfig.dateFormat || defaults.dateFormat;
1710
+ formats2.dateFormat = userConfig.noCalendar || timeMode ? "H:i" + (userConfig.enableSeconds ? ":S" : "") : defaultDateFormat + " H:i" + (userConfig.enableSeconds ? ":S" : "");
1711
+ }
1712
+ if (userConfig.altInput && (userConfig.enableTime || timeMode) && !userConfig.altFormat) {
1713
+ var defaultAltFormat = flatpickr.defaultConfig.altFormat || defaults.altFormat;
1714
+ formats2.altFormat = userConfig.noCalendar || timeMode ? "h:i" + (userConfig.enableSeconds ? ":S K" : " K") : defaultAltFormat + (" h:i" + (userConfig.enableSeconds ? ":S" : "") + " K");
1715
+ }
1716
+ Object.defineProperty(self.config, "minDate", {
1717
+ get: function() {
1718
+ return self.config._minDate;
1719
+ },
1720
+ set: minMaxDateSetter("min")
1721
+ });
1722
+ Object.defineProperty(self.config, "maxDate", {
1723
+ get: function() {
1724
+ return self.config._maxDate;
1725
+ },
1726
+ set: minMaxDateSetter("max")
1727
+ });
1728
+ var minMaxTimeSetter = function(type) {
1729
+ return function(val) {
1730
+ self.config[type === "min" ? "_minTime" : "_maxTime"] = self.parseDate(val, "H:i:S");
1731
+ };
1732
+ };
1733
+ Object.defineProperty(self.config, "minTime", {
1734
+ get: function() {
1735
+ return self.config._minTime;
1736
+ },
1737
+ set: minMaxTimeSetter("min")
1738
+ });
1739
+ Object.defineProperty(self.config, "maxTime", {
1740
+ get: function() {
1741
+ return self.config._maxTime;
1742
+ },
1743
+ set: minMaxTimeSetter("max")
1744
+ });
1745
+ if (userConfig.mode === "time") {
1746
+ self.config.noCalendar = true;
1747
+ self.config.enableTime = true;
1748
+ }
1749
+ Object.assign(self.config, formats2, userConfig);
1750
+ for (var i = 0; i < boolOpts.length; i++)
1751
+ self.config[boolOpts[i]] = self.config[boolOpts[i]] === true || self.config[boolOpts[i]] === "true";
1752
+ HOOKS.filter(function(hook) {
1753
+ return self.config[hook] !== void 0;
1754
+ }).forEach(function(hook) {
1755
+ self.config[hook] = arrayify(self.config[hook] || []).map(bindToInstance);
1756
+ });
1757
+ self.isMobile = !self.config.disableMobile && !self.config.inline && self.config.mode === "single" && !self.config.disable.length && !self.config.enable && !self.config.weekNumbers && /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent);
1758
+ for (var i = 0; i < self.config.plugins.length; i++) {
1759
+ var pluginConf = self.config.plugins[i](self) || {};
1760
+ for (var key in pluginConf) {
1761
+ if (HOOKS.indexOf(key) > -1) {
1762
+ self.config[key] = arrayify(pluginConf[key]).map(bindToInstance).concat(self.config[key]);
1763
+ } else if (typeof userConfig[key] === "undefined")
1764
+ self.config[key] = pluginConf[key];
1765
+ }
1766
+ }
1767
+ if (!userConfig.altInputClass) {
1768
+ self.config.altInputClass = getInputElem().className + " " + self.config.altInputClass;
1769
+ }
1770
+ triggerEvent("onParseConfig");
1771
+ }
1772
+ function getInputElem() {
1773
+ return self.config.wrap ? element.querySelector("[data-input]") : element;
1774
+ }
1775
+ function setupLocale() {
1776
+ if (typeof self.config.locale !== "object" && typeof flatpickr.l10ns[self.config.locale] === "undefined")
1777
+ self.config.errorHandler(new Error("flatpickr: invalid locale " + self.config.locale));
1778
+ self.l10n = __assign(__assign({}, flatpickr.l10ns.default), typeof self.config.locale === "object" ? self.config.locale : self.config.locale !== "default" ? flatpickr.l10ns[self.config.locale] : void 0);
1779
+ tokenRegex.D = "(" + self.l10n.weekdays.shorthand.join("|") + ")";
1780
+ tokenRegex.l = "(" + self.l10n.weekdays.longhand.join("|") + ")";
1781
+ tokenRegex.M = "(" + self.l10n.months.shorthand.join("|") + ")";
1782
+ tokenRegex.F = "(" + self.l10n.months.longhand.join("|") + ")";
1783
+ tokenRegex.K = "(" + self.l10n.amPM[0] + "|" + self.l10n.amPM[1] + "|" + self.l10n.amPM[0].toLowerCase() + "|" + self.l10n.amPM[1].toLowerCase() + ")";
1784
+ var userConfig = __assign(__assign({}, instanceConfig), JSON.parse(JSON.stringify(element.dataset || {})));
1785
+ if (userConfig.time_24hr === void 0 && flatpickr.defaultConfig.time_24hr === void 0) {
1786
+ self.config.time_24hr = self.l10n.time_24hr;
1787
+ }
1788
+ self.formatDate = createDateFormatter(self);
1789
+ self.parseDate = createDateParser({ config: self.config, l10n: self.l10n });
1790
+ }
1791
+ function positionCalendar(customPositionElement) {
1792
+ if (typeof self.config.position === "function") {
1793
+ return void self.config.position(self, customPositionElement);
1794
+ }
1795
+ if (self.calendarContainer === void 0)
1796
+ return;
1797
+ triggerEvent("onPreCalendarPosition");
1798
+ var positionElement = customPositionElement || self._positionElement;
1799
+ var calendarHeight = Array.prototype.reduce.call(self.calendarContainer.children, (function(acc, child) {
1800
+ return acc + child.offsetHeight;
1801
+ }), 0), calendarWidth = self.calendarContainer.offsetWidth, configPos = self.config.position.split(" "), configPosVertical = configPos[0], configPosHorizontal = configPos.length > 1 ? configPos[1] : null, inputBounds = positionElement.getBoundingClientRect(), distanceFromBottom = window.innerHeight - inputBounds.bottom, showOnTop = configPosVertical === "above" || configPosVertical !== "below" && distanceFromBottom < calendarHeight && inputBounds.top > calendarHeight;
1802
+ var top = window.pageYOffset + inputBounds.top + (!showOnTop ? positionElement.offsetHeight + 2 : -calendarHeight - 2);
1803
+ toggleClass(self.calendarContainer, "arrowTop", !showOnTop);
1804
+ toggleClass(self.calendarContainer, "arrowBottom", showOnTop);
1805
+ if (self.config.inline)
1806
+ return;
1807
+ var left = window.pageXOffset + inputBounds.left;
1808
+ var isCenter = false;
1809
+ var isRight = false;
1810
+ if (configPosHorizontal === "center") {
1811
+ left -= (calendarWidth - inputBounds.width) / 2;
1812
+ isCenter = true;
1813
+ } else if (configPosHorizontal === "right") {
1814
+ left -= calendarWidth - inputBounds.width;
1815
+ isRight = true;
1816
+ }
1817
+ toggleClass(self.calendarContainer, "arrowLeft", !isCenter && !isRight);
1818
+ toggleClass(self.calendarContainer, "arrowCenter", isCenter);
1819
+ toggleClass(self.calendarContainer, "arrowRight", isRight);
1820
+ var right = window.document.body.offsetWidth - (window.pageXOffset + inputBounds.right);
1821
+ var rightMost = left + calendarWidth > window.document.body.offsetWidth;
1822
+ var centerMost = right + calendarWidth > window.document.body.offsetWidth;
1823
+ toggleClass(self.calendarContainer, "rightMost", rightMost);
1824
+ if (self.config.static)
1825
+ return;
1826
+ self.calendarContainer.style.top = top + "px";
1827
+ if (!rightMost) {
1828
+ self.calendarContainer.style.left = left + "px";
1829
+ self.calendarContainer.style.right = "auto";
1830
+ } else if (!centerMost) {
1831
+ self.calendarContainer.style.left = "auto";
1832
+ self.calendarContainer.style.right = right + "px";
1833
+ } else {
1834
+ var doc = getDocumentStyleSheet();
1835
+ if (doc === void 0)
1836
+ return;
1837
+ var bodyWidth = window.document.body.offsetWidth;
1838
+ var centerLeft = Math.max(0, bodyWidth / 2 - calendarWidth / 2);
1839
+ var centerBefore = ".flatpickr-calendar.centerMost:before";
1840
+ var centerAfter = ".flatpickr-calendar.centerMost:after";
1841
+ var centerIndex = doc.cssRules.length;
1842
+ var centerStyle = "{left:" + inputBounds.left + "px;right:auto;}";
1843
+ toggleClass(self.calendarContainer, "rightMost", false);
1844
+ toggleClass(self.calendarContainer, "centerMost", true);
1845
+ doc.insertRule(centerBefore + "," + centerAfter + centerStyle, centerIndex);
1846
+ self.calendarContainer.style.left = centerLeft + "px";
1847
+ self.calendarContainer.style.right = "auto";
1848
+ }
1849
+ }
1850
+ function getDocumentStyleSheet() {
1851
+ var editableSheet = null;
1852
+ for (var i = 0; i < document.styleSheets.length; i++) {
1853
+ var sheet = document.styleSheets[i];
1854
+ if (!sheet.cssRules)
1855
+ continue;
1856
+ try {
1857
+ sheet.cssRules;
1858
+ } catch (err) {
1859
+ continue;
1860
+ }
1861
+ editableSheet = sheet;
1862
+ break;
1863
+ }
1864
+ return editableSheet != null ? editableSheet : createStyleSheet();
1865
+ }
1866
+ function createStyleSheet() {
1867
+ var style = document.createElement("style");
1868
+ document.head.appendChild(style);
1869
+ return style.sheet;
1870
+ }
1871
+ function redraw() {
1872
+ if (self.config.noCalendar || self.isMobile)
1873
+ return;
1874
+ buildMonthSwitch();
1875
+ updateNavigationCurrentMonth();
1876
+ buildDays();
1877
+ }
1878
+ function focusAndClose() {
1879
+ self._input.focus();
1880
+ if (window.navigator.userAgent.indexOf("MSIE") !== -1 || navigator.msMaxTouchPoints !== void 0) {
1881
+ setTimeout(self.close, 0);
1882
+ } else {
1883
+ self.close();
1884
+ }
1885
+ }
1886
+ function selectDate(e) {
1887
+ e.preventDefault();
1888
+ e.stopPropagation();
1889
+ var isSelectable = function(day) {
1890
+ return day.classList && day.classList.contains("flatpickr-day") && !day.classList.contains("flatpickr-disabled") && !day.classList.contains("notAllowed");
1891
+ };
1892
+ var t = findParent(getEventTarget(e), isSelectable);
1893
+ if (t === void 0)
1894
+ return;
1895
+ var target = t;
1896
+ var selectedDate = self.latestSelectedDateObj = new Date(target.dateObj.getTime());
1897
+ var shouldChangeMonth = (selectedDate.getMonth() < self.currentMonth || selectedDate.getMonth() > self.currentMonth + self.config.showMonths - 1) && self.config.mode !== "range";
1898
+ self.selectedDateElem = target;
1899
+ if (self.config.mode === "single")
1900
+ self.selectedDates = [selectedDate];
1901
+ else if (self.config.mode === "multiple") {
1902
+ var selectedIndex = isDateSelected(selectedDate);
1903
+ if (selectedIndex)
1904
+ self.selectedDates.splice(parseInt(selectedIndex), 1);
1905
+ else
1906
+ self.selectedDates.push(selectedDate);
1907
+ } else if (self.config.mode === "range") {
1908
+ if (self.selectedDates.length === 2) {
1909
+ self.clear(false, false);
1910
+ }
1911
+ self.latestSelectedDateObj = selectedDate;
1912
+ self.selectedDates.push(selectedDate);
1913
+ if (compareDates(selectedDate, self.selectedDates[0], true) !== 0)
1914
+ self.selectedDates.sort(function(a, b) {
1915
+ return a.getTime() - b.getTime();
1916
+ });
1917
+ }
1918
+ setHoursFromInputs();
1919
+ if (shouldChangeMonth) {
1920
+ var isNewYear = self.currentYear !== selectedDate.getFullYear();
1921
+ self.currentYear = selectedDate.getFullYear();
1922
+ self.currentMonth = selectedDate.getMonth();
1923
+ if (isNewYear) {
1924
+ triggerEvent("onYearChange");
1925
+ buildMonthSwitch();
1926
+ }
1927
+ triggerEvent("onMonthChange");
1928
+ }
1929
+ updateNavigationCurrentMonth();
1930
+ buildDays();
1931
+ updateValue();
1932
+ if (!shouldChangeMonth && self.config.mode !== "range" && self.config.showMonths === 1)
1933
+ focusOnDayElem(target);
1934
+ else if (self.selectedDateElem !== void 0 && self.hourElement === void 0) {
1935
+ self.selectedDateElem && self.selectedDateElem.focus();
1936
+ }
1937
+ if (self.hourElement !== void 0)
1938
+ self.hourElement !== void 0 && self.hourElement.focus();
1939
+ if (self.config.closeOnSelect) {
1940
+ var single = self.config.mode === "single" && !self.config.enableTime;
1941
+ var range = self.config.mode === "range" && self.selectedDates.length === 2 && !self.config.enableTime;
1942
+ if (single || range) {
1943
+ focusAndClose();
1944
+ }
1945
+ }
1946
+ triggerChange();
1947
+ }
1948
+ var CALLBACKS = {
1949
+ locale: [setupLocale, updateWeekdays],
1950
+ showMonths: [buildMonths, setCalendarWidth, buildWeekdays],
1951
+ minDate: [jumpToDate],
1952
+ maxDate: [jumpToDate],
1953
+ positionElement: [updatePositionElement],
1954
+ clickOpens: [
1955
+ function() {
1956
+ if (self.config.clickOpens === true) {
1957
+ bind(self._input, "focus", self.open);
1958
+ bind(self._input, "click", self.open);
1959
+ } else {
1960
+ self._input.removeEventListener("focus", self.open);
1961
+ self._input.removeEventListener("click", self.open);
1962
+ }
1963
+ }
1964
+ ]
1965
+ };
1966
+ function set(option, value) {
1967
+ if (option !== null && typeof option === "object") {
1968
+ Object.assign(self.config, option);
1969
+ for (var key in option) {
1970
+ if (CALLBACKS[key] !== void 0)
1971
+ CALLBACKS[key].forEach(function(x) {
1972
+ return x();
1973
+ });
1974
+ }
1975
+ } else {
1976
+ self.config[option] = value;
1977
+ if (CALLBACKS[option] !== void 0)
1978
+ CALLBACKS[option].forEach(function(x) {
1979
+ return x();
1980
+ });
1981
+ else if (HOOKS.indexOf(option) > -1)
1982
+ self.config[option] = arrayify(value);
1983
+ }
1984
+ self.redraw();
1985
+ updateValue(true);
1986
+ }
1987
+ function setSelectedDate(inputDate, format) {
1988
+ var dates = [];
1989
+ if (inputDate instanceof Array)
1990
+ dates = inputDate.map(function(d) {
1991
+ return self.parseDate(d, format);
1992
+ });
1993
+ else if (inputDate instanceof Date || typeof inputDate === "number")
1994
+ dates = [self.parseDate(inputDate, format)];
1995
+ else if (typeof inputDate === "string") {
1996
+ switch (self.config.mode) {
1997
+ case "single":
1998
+ case "time":
1999
+ dates = [self.parseDate(inputDate, format)];
2000
+ break;
2001
+ case "multiple":
2002
+ dates = inputDate.split(self.config.conjunction).map(function(date) {
2003
+ return self.parseDate(date, format);
2004
+ });
2005
+ break;
2006
+ case "range":
2007
+ dates = inputDate.split(self.l10n.rangeSeparator).map(function(date) {
2008
+ return self.parseDate(date, format);
2009
+ });
2010
+ break;
2011
+ }
2012
+ } else
2013
+ self.config.errorHandler(new Error("Invalid date supplied: " + JSON.stringify(inputDate)));
2014
+ self.selectedDates = self.config.allowInvalidPreload ? dates : dates.filter(function(d) {
2015
+ return d instanceof Date && isEnabled(d, false);
2016
+ });
2017
+ if (self.config.mode === "range")
2018
+ self.selectedDates.sort(function(a, b) {
2019
+ return a.getTime() - b.getTime();
2020
+ });
2021
+ }
2022
+ function setDate(date, triggerChange2, format) {
2023
+ if (triggerChange2 === void 0) {
2024
+ triggerChange2 = false;
2025
+ }
2026
+ if (format === void 0) {
2027
+ format = self.config.dateFormat;
2028
+ }
2029
+ if (date !== 0 && !date || date instanceof Array && date.length === 0)
2030
+ return self.clear(triggerChange2);
2031
+ setSelectedDate(date, format);
2032
+ self.latestSelectedDateObj = self.selectedDates[self.selectedDates.length - 1];
2033
+ self.redraw();
2034
+ jumpToDate(void 0, triggerChange2);
2035
+ setHoursFromDate();
2036
+ if (self.selectedDates.length === 0) {
2037
+ self.clear(false);
2038
+ }
2039
+ updateValue(triggerChange2);
2040
+ if (triggerChange2)
2041
+ triggerEvent("onChange");
2042
+ }
2043
+ function parseDateRules(arr) {
2044
+ return arr.slice().map(function(rule) {
2045
+ if (typeof rule === "string" || typeof rule === "number" || rule instanceof Date) {
2046
+ return self.parseDate(rule, void 0, true);
2047
+ } else if (rule && typeof rule === "object" && rule.from && rule.to)
2048
+ return {
2049
+ from: self.parseDate(rule.from, void 0),
2050
+ to: self.parseDate(rule.to, void 0)
2051
+ };
2052
+ return rule;
2053
+ }).filter(function(x) {
2054
+ return x;
2055
+ });
2056
+ }
2057
+ function setupDates() {
2058
+ self.selectedDates = [];
2059
+ self.now = self.parseDate(self.config.now) || /* @__PURE__ */ new Date();
2060
+ var preloadedDate = self.config.defaultDate || ((self.input.nodeName === "INPUT" || self.input.nodeName === "TEXTAREA") && self.input.placeholder && self.input.value === self.input.placeholder ? null : self.input.value);
2061
+ if (preloadedDate)
2062
+ setSelectedDate(preloadedDate, self.config.dateFormat);
2063
+ self._initialDate = self.selectedDates.length > 0 ? self.selectedDates[0] : self.config.minDate && self.config.minDate.getTime() > self.now.getTime() ? self.config.minDate : self.config.maxDate && self.config.maxDate.getTime() < self.now.getTime() ? self.config.maxDate : self.now;
2064
+ self.currentYear = self._initialDate.getFullYear();
2065
+ self.currentMonth = self._initialDate.getMonth();
2066
+ if (self.selectedDates.length > 0)
2067
+ self.latestSelectedDateObj = self.selectedDates[0];
2068
+ if (self.config.minTime !== void 0)
2069
+ self.config.minTime = self.parseDate(self.config.minTime, "H:i");
2070
+ if (self.config.maxTime !== void 0)
2071
+ self.config.maxTime = self.parseDate(self.config.maxTime, "H:i");
2072
+ self.minDateHasTime = !!self.config.minDate && (self.config.minDate.getHours() > 0 || self.config.minDate.getMinutes() > 0 || self.config.minDate.getSeconds() > 0);
2073
+ self.maxDateHasTime = !!self.config.maxDate && (self.config.maxDate.getHours() > 0 || self.config.maxDate.getMinutes() > 0 || self.config.maxDate.getSeconds() > 0);
2074
+ }
2075
+ function setupInputs() {
2076
+ self.input = getInputElem();
2077
+ if (!self.input) {
2078
+ self.config.errorHandler(new Error("Invalid input element specified"));
2079
+ return;
2080
+ }
2081
+ self.input._type = self.input.type;
2082
+ self.input.type = "text";
2083
+ self.input.classList.add("flatpickr-input");
2084
+ self._input = self.input;
2085
+ if (self.config.altInput) {
2086
+ self.altInput = createElement(self.input.nodeName, self.config.altInputClass);
2087
+ self._input = self.altInput;
2088
+ self.altInput.placeholder = self.input.placeholder;
2089
+ self.altInput.disabled = self.input.disabled;
2090
+ self.altInput.required = self.input.required;
2091
+ self.altInput.tabIndex = self.input.tabIndex;
2092
+ self.altInput.type = "text";
2093
+ self.input.setAttribute("type", "hidden");
2094
+ if (!self.config.static && self.input.parentNode)
2095
+ self.input.parentNode.insertBefore(self.altInput, self.input.nextSibling);
2096
+ }
2097
+ if (!self.config.allowInput)
2098
+ self._input.setAttribute("readonly", "readonly");
2099
+ updatePositionElement();
2100
+ }
2101
+ function updatePositionElement() {
2102
+ self._positionElement = self.config.positionElement || self._input;
2103
+ }
2104
+ function setupMobile() {
2105
+ var inputType = self.config.enableTime ? self.config.noCalendar ? "time" : "datetime-local" : "date";
2106
+ self.mobileInput = createElement("input", self.input.className + " flatpickr-mobile");
2107
+ self.mobileInput.tabIndex = 1;
2108
+ self.mobileInput.type = inputType;
2109
+ self.mobileInput.disabled = self.input.disabled;
2110
+ self.mobileInput.required = self.input.required;
2111
+ self.mobileInput.placeholder = self.input.placeholder;
2112
+ self.mobileFormatStr = inputType === "datetime-local" ? "Y-m-d\\TH:i:S" : inputType === "date" ? "Y-m-d" : "H:i:S";
2113
+ if (self.selectedDates.length > 0) {
2114
+ self.mobileInput.defaultValue = self.mobileInput.value = self.formatDate(self.selectedDates[0], self.mobileFormatStr);
2115
+ }
2116
+ if (self.config.minDate)
2117
+ self.mobileInput.min = self.formatDate(self.config.minDate, "Y-m-d");
2118
+ if (self.config.maxDate)
2119
+ self.mobileInput.max = self.formatDate(self.config.maxDate, "Y-m-d");
2120
+ if (self.input.getAttribute("step"))
2121
+ self.mobileInput.step = String(self.input.getAttribute("step"));
2122
+ self.input.type = "hidden";
2123
+ if (self.altInput !== void 0)
2124
+ self.altInput.type = "hidden";
2125
+ try {
2126
+ if (self.input.parentNode)
2127
+ self.input.parentNode.insertBefore(self.mobileInput, self.input.nextSibling);
2128
+ } catch (_a) {
2129
+ }
2130
+ bind(self.mobileInput, "change", function(e) {
2131
+ self.setDate(getEventTarget(e).value, false, self.mobileFormatStr);
2132
+ triggerEvent("onChange");
2133
+ triggerEvent("onClose");
2134
+ });
2135
+ }
2136
+ function toggle(e) {
2137
+ if (self.isOpen === true)
2138
+ return self.close();
2139
+ self.open(e);
2140
+ }
2141
+ function triggerEvent(event, data) {
2142
+ if (self.config === void 0)
2143
+ return;
2144
+ var hooks = self.config[event];
2145
+ if (hooks !== void 0 && hooks.length > 0) {
2146
+ for (var i = 0; hooks[i] && i < hooks.length; i++)
2147
+ hooks[i](self.selectedDates, self.input.value, self, data);
2148
+ }
2149
+ if (event === "onChange") {
2150
+ self.input.dispatchEvent(createEvent("change"));
2151
+ self.input.dispatchEvent(createEvent("input"));
2152
+ }
2153
+ }
2154
+ function createEvent(name) {
2155
+ var e = document.createEvent("Event");
2156
+ e.initEvent(name, true, true);
2157
+ return e;
2158
+ }
2159
+ function isDateSelected(date) {
2160
+ for (var i = 0; i < self.selectedDates.length; i++) {
2161
+ var selectedDate = self.selectedDates[i];
2162
+ if (selectedDate instanceof Date && compareDates(selectedDate, date) === 0)
2163
+ return "" + i;
2164
+ }
2165
+ return false;
2166
+ }
2167
+ function isDateInRange(date) {
2168
+ if (self.config.mode !== "range" || self.selectedDates.length < 2)
2169
+ return false;
2170
+ return compareDates(date, self.selectedDates[0]) >= 0 && compareDates(date, self.selectedDates[1]) <= 0;
2171
+ }
2172
+ function updateNavigationCurrentMonth() {
2173
+ if (self.config.noCalendar || self.isMobile || !self.monthNav)
2174
+ return;
2175
+ self.yearElements.forEach(function(yearElement, i) {
2176
+ var d = new Date(self.currentYear, self.currentMonth, 1);
2177
+ d.setMonth(self.currentMonth + i);
2178
+ if (self.config.showMonths > 1 || self.config.monthSelectorType === "static") {
2179
+ self.monthElements[i].textContent = monthToStr(d.getMonth(), self.config.shorthandCurrentMonth, self.l10n) + " ";
2180
+ } else {
2181
+ self.monthsDropdownContainer.value = d.getMonth().toString();
2182
+ }
2183
+ yearElement.value = d.getFullYear().toString();
2184
+ });
2185
+ self._hidePrevMonthArrow = self.config.minDate !== void 0 && (self.currentYear === self.config.minDate.getFullYear() ? self.currentMonth <= self.config.minDate.getMonth() : self.currentYear < self.config.minDate.getFullYear());
2186
+ self._hideNextMonthArrow = self.config.maxDate !== void 0 && (self.currentYear === self.config.maxDate.getFullYear() ? self.currentMonth + 1 > self.config.maxDate.getMonth() : self.currentYear > self.config.maxDate.getFullYear());
2187
+ }
2188
+ function getDateStr(specificFormat) {
2189
+ var format = specificFormat || (self.config.altInput ? self.config.altFormat : self.config.dateFormat);
2190
+ return self.selectedDates.map(function(dObj) {
2191
+ return self.formatDate(dObj, format);
2192
+ }).filter(function(d, i, arr) {
2193
+ return self.config.mode !== "range" || self.config.enableTime || arr.indexOf(d) === i;
2194
+ }).join(self.config.mode !== "range" ? self.config.conjunction : self.l10n.rangeSeparator);
2195
+ }
2196
+ function updateValue(triggerChange2) {
2197
+ if (triggerChange2 === void 0) {
2198
+ triggerChange2 = true;
2199
+ }
2200
+ if (self.mobileInput !== void 0 && self.mobileFormatStr) {
2201
+ self.mobileInput.value = self.latestSelectedDateObj !== void 0 ? self.formatDate(self.latestSelectedDateObj, self.mobileFormatStr) : "";
2202
+ }
2203
+ self.input.value = getDateStr(self.config.dateFormat);
2204
+ if (self.altInput !== void 0) {
2205
+ self.altInput.value = getDateStr(self.config.altFormat);
2206
+ }
2207
+ if (triggerChange2 !== false)
2208
+ triggerEvent("onValueUpdate");
2209
+ }
2210
+ function onMonthNavClick(e) {
2211
+ var eventTarget = getEventTarget(e);
2212
+ var isPrevMonth = self.prevMonthNav.contains(eventTarget);
2213
+ var isNextMonth = self.nextMonthNav.contains(eventTarget);
2214
+ if (isPrevMonth || isNextMonth) {
2215
+ changeMonth(isPrevMonth ? -1 : 1);
2216
+ } else if (self.yearElements.indexOf(eventTarget) >= 0) {
2217
+ eventTarget.select();
2218
+ } else if (eventTarget.classList.contains("arrowUp")) {
2219
+ self.changeYear(self.currentYear + 1);
2220
+ } else if (eventTarget.classList.contains("arrowDown")) {
2221
+ self.changeYear(self.currentYear - 1);
2222
+ }
2223
+ }
2224
+ function timeWrapper(e) {
2225
+ e.preventDefault();
2226
+ var isKeyDown = e.type === "keydown", eventTarget = getEventTarget(e), input = eventTarget;
2227
+ if (self.amPM !== void 0 && eventTarget === self.amPM) {
2228
+ self.amPM.textContent = self.l10n.amPM[int(self.amPM.textContent === self.l10n.amPM[0])];
2229
+ }
2230
+ var min = parseFloat(input.getAttribute("min")), max = parseFloat(input.getAttribute("max")), step = parseFloat(input.getAttribute("step")), curValue = parseInt(input.value, 10), delta = e.delta || (isKeyDown ? e.which === 38 ? 1 : -1 : 0);
2231
+ var newValue = curValue + step * delta;
2232
+ if (typeof input.value !== "undefined" && input.value.length === 2) {
2233
+ var isHourElem = input === self.hourElement, isMinuteElem = input === self.minuteElement;
2234
+ if (newValue < min) {
2235
+ newValue = max + newValue + int(!isHourElem) + (int(isHourElem) && int(!self.amPM));
2236
+ if (isMinuteElem)
2237
+ incrementNumInput(void 0, -1, self.hourElement);
2238
+ } else if (newValue > max) {
2239
+ newValue = input === self.hourElement ? newValue - max - int(!self.amPM) : min;
2240
+ if (isMinuteElem)
2241
+ incrementNumInput(void 0, 1, self.hourElement);
2242
+ }
2243
+ if (self.amPM && isHourElem && (step === 1 ? newValue + curValue === 23 : Math.abs(newValue - curValue) > step)) {
2244
+ self.amPM.textContent = self.l10n.amPM[int(self.amPM.textContent === self.l10n.amPM[0])];
2245
+ }
2246
+ input.value = pad(newValue);
2247
+ }
2248
+ }
2249
+ init();
2250
+ return self;
2251
+ }
2252
+ function _flatpickr(nodeList, config) {
2253
+ var nodes = Array.prototype.slice.call(nodeList).filter(function(x) {
2254
+ return x instanceof HTMLElement;
2255
+ });
2256
+ var instances = [];
2257
+ for (var i = 0; i < nodes.length; i++) {
2258
+ var node = nodes[i];
2259
+ try {
2260
+ if (node.getAttribute("data-fp-omit") !== null)
2261
+ continue;
2262
+ if (node._flatpickr !== void 0) {
2263
+ node._flatpickr.destroy();
2264
+ node._flatpickr = void 0;
2265
+ }
2266
+ node._flatpickr = FlatpickrInstance(node, config || {});
2267
+ instances.push(node._flatpickr);
2268
+ } catch (e) {
2269
+ console.error(e);
2270
+ }
2271
+ }
2272
+ return instances.length === 1 ? instances[0] : instances;
2273
+ }
2274
+ if (typeof HTMLElement !== "undefined" && typeof HTMLCollection !== "undefined" && typeof NodeList !== "undefined") {
2275
+ HTMLCollection.prototype.flatpickr = NodeList.prototype.flatpickr = function(config) {
2276
+ return _flatpickr(this, config);
2277
+ };
2278
+ HTMLElement.prototype.flatpickr = function(config) {
2279
+ return _flatpickr([this], config);
2280
+ };
2281
+ }
2282
+ var flatpickr = function(selector, config) {
2283
+ if (typeof selector === "string") {
2284
+ return _flatpickr(window.document.querySelectorAll(selector), config);
2285
+ } else if (selector instanceof Node) {
2286
+ return _flatpickr([selector], config);
2287
+ } else {
2288
+ return _flatpickr(selector, config);
2289
+ }
2290
+ };
2291
+ flatpickr.defaultConfig = {};
2292
+ flatpickr.l10ns = {
2293
+ en: __assign({}, english),
2294
+ default: __assign({}, english)
2295
+ };
2296
+ flatpickr.localize = function(l10n) {
2297
+ flatpickr.l10ns.default = __assign(__assign({}, flatpickr.l10ns.default), l10n);
2298
+ };
2299
+ flatpickr.setDefaults = function(config) {
2300
+ flatpickr.defaultConfig = __assign(__assign({}, flatpickr.defaultConfig), config);
2301
+ };
2302
+ flatpickr.parseDate = createDateParser({});
2303
+ flatpickr.formatDate = createDateFormatter({});
2304
+ flatpickr.compareDates = compareDates;
2305
+ if (typeof jQuery !== "undefined" && typeof jQuery.fn !== "undefined") {
2306
+ jQuery.fn.flatpickr = function(config) {
2307
+ return _flatpickr(this, config);
2308
+ };
2309
+ }
2310
+ Date.prototype.fp_incr = function(days) {
2311
+ return new Date(this.getFullYear(), this.getMonth(), this.getDate() + (typeof days === "string" ? parseInt(days, 10) : days));
2312
+ };
2313
+ if (typeof window !== "undefined") {
2314
+ window.flatpickr = flatpickr;
2315
+ }
2316
+ const initDatepicker = (root = document) => {
2317
+ const inputs = root.querySelectorAll(".datepicker");
2318
+ inputs.forEach((input) => {
2319
+ if (input._flatpickr) return;
2320
+ const mode = input.dataset.mode || "single";
2321
+ const enableTime = input.dataset.enableTime === "true";
2322
+ const noCalendar = input.dataset.noCalendar === "true";
2323
+ const inline = input.dataset.inline === "true";
2324
+ const dateFormat = input.dataset.dateFormat || (enableTime && noCalendar ? "H:i" : "Y-m-d");
2325
+ flatpickr(input, {
2326
+ mode,
2327
+ enableTime,
2328
+ noCalendar,
2329
+ inline,
2330
+ dateFormat,
2331
+ allowInput: true,
2332
+ // Allow manual typing
2333
+ shorthandCurrentMonth: true,
2334
+ // Display month shorthand (e.g. "Dec" instead of "December")
2335
+ prevArrow: '<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="w-4 h-4"><path d="m15 18-6-6 6-6"/></svg>',
2336
+ nextArrow: '<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" class="w-4 h-4"><path d="m9 18 6-6-6-6"/></svg>',
2337
+ static: true
2338
+ // Position relative to wrapper, helps with scroll
2339
+ // Custom class names to hook into our CSS
2340
+ // flatpickr doesn't fully support class replacements, but we can append
2341
+ });
2342
+ });
2343
+ };
2344
+ if (typeof window !== "undefined") {
2345
+ const observer = new MutationObserver((mutations) => {
2346
+ mutations.forEach((mutation) => {
2347
+ if (mutation.type === "childList") {
2348
+ mutation.addedNodes.forEach((node) => {
2349
+ if (node.nodeType === 1) {
2350
+ if (node.classList?.contains("datepicker")) {
2351
+ initDatepicker(node.parentNode);
2352
+ } else if (node.querySelector?.(".datepicker")) {
2353
+ initDatepicker(node);
2354
+ }
2355
+ }
2356
+ });
2357
+ }
2358
+ });
2359
+ });
2360
+ document.addEventListener("DOMContentLoaded", () => {
2361
+ initDatepicker();
2362
+ observer.observe(document.body, { childList: true, subtree: true });
2363
+ });
2364
+ }
2365
+ export {
2366
+ initDatepicker
2367
+ };