@xplortech/apollo-core 0.3.0 → 0.4.1

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