@xplortech/apollo-core 1.0.0-beta.18 → 1.0.0-beta.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (459) hide show
  1. package/CHANGELOG.md +106 -0
  2. package/build/style.css +2758 -1516
  3. package/dist/apollo-core/apollo-core.css +14 -4597
  4. package/dist/apollo-core/apollo-core.esm.js +1 -2
  5. package/dist/apollo-core/index.esm.js +0 -2
  6. package/dist/apollo-core/p-09b2f746.entry.js +1 -0
  7. package/dist/apollo-core/p-1b1e7207.entry.js +1 -0
  8. package/dist/apollo-core/p-20389bb6.entry.js +1 -0
  9. package/dist/apollo-core/p-25983fde.entry.js +1 -0
  10. package/dist/apollo-core/p-2f90296c.js +10 -0
  11. package/dist/apollo-core/p-4a348764.entry.js +1 -0
  12. package/dist/apollo-core/p-4e2b69e8.entry.js +1 -0
  13. package/dist/apollo-core/p-84bf6b2d.entry.js +1 -0
  14. package/dist/apollo-core/p-880c0359.entry.js +1 -0
  15. package/dist/apollo-core/p-8e47a5be.entry.js +1 -0
  16. package/dist/apollo-core/p-93958292.entry.js +1 -0
  17. package/dist/apollo-core/p-93c27db5.entry.js +1 -0
  18. package/dist/apollo-core/p-ad90fe4d.js +1 -2
  19. package/dist/apollo-core/p-b2327e2c.entry.js +1 -0
  20. package/dist/apollo-core/p-c3a12469.entry.js +1 -0
  21. package/dist/apollo-core/p-c55b5d9c.entry.js +1 -0
  22. package/dist/apollo-core/p-e369d7af.entry.js +1 -0
  23. package/dist/apollo-core/p-e60ecaef.entry.js +1 -0
  24. package/dist/apollo-core/p-f929c958.js +1 -0
  25. package/dist/cjs/apollo-core.cjs.js +3 -12
  26. package/dist/cjs/{index-000e170c.js → index-54ba5804.js} +216 -768
  27. package/dist/cjs/index.cjs.js +0 -2
  28. package/dist/cjs/loader.cjs.js +3 -6
  29. package/dist/cjs/regular-872f5226.js +16043 -0
  30. package/dist/cjs/v4-14140ff3.js +0 -2
  31. package/dist/cjs/xpl-application-shell.cjs.entry.js +13 -10
  32. package/dist/cjs/xpl-avatar_12.cjs.entry.js +299 -0
  33. package/dist/cjs/xpl-backdrop.cjs.entry.js +5 -3
  34. package/dist/cjs/xpl-button-row.cjs.entry.js +1 -6
  35. package/dist/cjs/xpl-choicelist.cjs.entry.js +1 -10
  36. package/dist/cjs/xpl-divider.cjs.entry.js +1 -4
  37. package/dist/cjs/xpl-dropdown-group_3.cjs.entry.js +4 -16
  38. package/dist/cjs/xpl-dropdown_2.cjs.entry.js +12 -14
  39. package/dist/cjs/xpl-grid-item.cjs.entry.js +1 -3
  40. package/dist/cjs/xpl-grid.cjs.entry.js +1 -3
  41. package/dist/cjs/xpl-input.cjs.entry.js +25 -22
  42. package/dist/cjs/xpl-list.cjs.entry.js +25 -4
  43. package/dist/cjs/xpl-main-nav.cjs.entry.js +4 -3
  44. package/dist/cjs/xpl-pagination.cjs.entry.js +2 -7
  45. package/dist/cjs/xpl-select.cjs.entry.js +25 -51
  46. package/dist/cjs/xpl-toggle.cjs.entry.js +4 -9
  47. package/dist/collection/collection-manifest.json +3 -6
  48. package/dist/collection/components/xpl-application-shell/xpl-application-shell.js +109 -125
  49. package/dist/collection/components/xpl-avatar/xpl-avatar.js +144 -151
  50. package/dist/collection/components/xpl-backdrop/xpl-backdrop.js +28 -27
  51. package/dist/collection/components/xpl-badge/xpl-badge.js +39 -44
  52. package/dist/collection/components/xpl-breadcrumbs/xpl-breadcrumb-item/xpl-breadcrumb-item.js +5 -3
  53. package/dist/collection/components/xpl-breadcrumbs/xpl-breadcrumbs/xpl-breadcrumbs.js +5 -3
  54. package/dist/collection/components/xpl-button/xpl-button.js +188 -228
  55. package/dist/collection/components/xpl-button-row/xpl-button-row.js +104 -106
  56. package/dist/collection/components/xpl-checkbox/xpl-checkbox.js +171 -182
  57. package/dist/collection/components/xpl-choicelist/xpl-choicelist.js +126 -134
  58. package/dist/collection/components/xpl-content-area/xpl-content-area.js +31 -28
  59. package/dist/collection/components/xpl-divider/xpl-divider.js +23 -27
  60. package/dist/collection/components/xpl-dropdown/xpl-dropdown-group/xpl-dropdown-group.js +41 -47
  61. package/dist/collection/components/xpl-dropdown/xpl-dropdown-heading/xpl-dropdown-heading.js +22 -27
  62. package/dist/collection/components/xpl-dropdown/xpl-dropdown-option/xpl-dropdown-option.js +55 -83
  63. package/dist/collection/components/xpl-dropdown/xpl-dropdown.js +161 -169
  64. package/dist/collection/components/xpl-grid/xpl-grid.js +1 -2
  65. package/dist/collection/components/xpl-grid-item/xpl-grid-item.js +74 -76
  66. package/dist/collection/components/xpl-input/xpl-input.js +419 -397
  67. package/dist/collection/components/xpl-list/xpl-list.js +77 -43
  68. package/dist/collection/components/xpl-main-nav/xpl-main-nav.js +54 -48
  69. package/dist/collection/components/xpl-nav-item/xpl-nav-item.js +49 -48
  70. package/dist/collection/components/xpl-pagination/xpl-pagination.js +128 -117
  71. package/dist/collection/components/xpl-radio/xpl-radio.js +148 -158
  72. package/dist/collection/components/xpl-secondary-nav/xpl-secondary-nav.js +4 -3
  73. package/dist/collection/components/xpl-select/xpl-select.js +235 -306
  74. package/dist/collection/components/xpl-table/xpl-table.js +148 -215
  75. package/dist/collection/components/xpl-tag/xpl-tag.js +25 -25
  76. package/dist/collection/components/xpl-toggle/xpl-toggle.js +135 -138
  77. package/dist/collection/components/xpl-utility-bar/xpl-utility-bar.js +52 -79
  78. package/dist/custom-elements/index.d.ts +219 -0
  79. package/dist/custom-elements/index.js +20201 -0
  80. package/dist/esm/apollo-core.js +3 -9
  81. package/dist/esm/{index-56581b5c.js → index-3df6db84.js} +217 -768
  82. package/dist/esm/index.js +0 -2
  83. package/dist/esm/loader.js +3 -6
  84. package/dist/esm/polyfills/css-shim.js +1 -1
  85. package/dist/esm/regular-86225e9d.js +16041 -0
  86. package/dist/esm/v4-929670b7.js +0 -2
  87. package/dist/esm/xpl-application-shell.entry.js +13 -10
  88. package/dist/esm/xpl-avatar_12.entry.js +284 -0
  89. package/dist/esm/xpl-backdrop.entry.js +5 -3
  90. package/dist/esm/xpl-button-row.entry.js +1 -6
  91. package/dist/esm/xpl-choicelist.entry.js +1 -10
  92. package/dist/esm/xpl-divider.entry.js +1 -4
  93. package/dist/esm/xpl-dropdown-group_3.entry.js +4 -16
  94. package/dist/esm/xpl-dropdown_2.entry.js +12 -14
  95. package/dist/esm/xpl-grid-item.entry.js +1 -3
  96. package/dist/esm/xpl-grid.entry.js +1 -3
  97. package/dist/esm/xpl-input.entry.js +25 -22
  98. package/dist/esm/xpl-list.entry.js +25 -4
  99. package/dist/esm/xpl-main-nav.entry.js +4 -3
  100. package/dist/esm/xpl-pagination.entry.js +2 -7
  101. package/dist/esm/xpl-select.entry.js +25 -51
  102. package/dist/esm/xpl-toggle.entry.js +4 -9
  103. package/dist/stories/application-shell.stories.js +8 -18
  104. package/dist/stories/avatar.stories.js +0 -1
  105. package/dist/stories/backdrop.stories.js +0 -1
  106. package/dist/stories/badge.stories.js +0 -1
  107. package/dist/stories/breadcrumbs.stories.js +0 -1
  108. package/dist/stories/button-row.stories.js +0 -1
  109. package/dist/stories/button.stories.js +5 -18
  110. package/dist/stories/checkbox.stories.js +0 -1
  111. package/dist/stories/choicelist.stories.js +0 -1
  112. package/dist/stories/content-area.stories.js +0 -1
  113. package/dist/stories/divider.stories.js +0 -1
  114. package/dist/stories/dropdown.stories.js +65 -74
  115. package/dist/stories/grid.stories.js +0 -1
  116. package/dist/stories/input.stories.js +0 -1
  117. package/dist/stories/list.stories.js +2 -3
  118. package/dist/stories/main-nav.stories.js +0 -1
  119. package/dist/stories/pagination.stories.js +0 -1
  120. package/dist/stories/radio.stories.js +0 -1
  121. package/dist/stories/secondary-nav.stories.js +0 -1
  122. package/dist/stories/select.stories.js +32 -109
  123. package/dist/stories/table.stories.js +7 -24
  124. package/dist/stories/tabs.stories.js +0 -1
  125. package/dist/stories/toggle.stories.js +0 -1
  126. package/dist/stories/utility-bar.stories.js +6 -2
  127. package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/application-shell.stories.d.ts +5 -14
  128. package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/button.stories.d.ts +2 -10
  129. package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/dropdown.stories.d.ts +1 -17
  130. package/dist/types/Users/fernandogelin/Projects/apollo-admin/packages/apollo/.stencil/stories/select.stories.d.ts +74 -0
  131. package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/table.stories.d.ts +1 -22
  132. package/dist/types/components/xpl-application-shell/xpl-application-shell.d.ts +1 -6
  133. package/dist/types/components/xpl-button/xpl-button.d.ts +0 -6
  134. package/dist/types/components/xpl-choicelist/xpl-choicelist.d.ts +1 -2
  135. package/dist/types/components/xpl-dropdown/xpl-dropdown-group/xpl-dropdown-group.d.ts +0 -1
  136. package/dist/types/components/xpl-dropdown/xpl-dropdown-option/xpl-dropdown-option.d.ts +1 -7
  137. package/dist/types/components/xpl-dropdown/xpl-dropdown.d.ts +5 -7
  138. package/dist/types/components/xpl-input/xpl-input.d.ts +2 -0
  139. package/dist/types/components/xpl-list/xpl-list.d.ts +3 -2
  140. package/dist/types/components/xpl-select/xpl-select.d.ts +1 -21
  141. package/dist/types/components/xpl-table/xpl-table.d.ts +7 -29
  142. package/dist/types/components/xpl-utility-bar/xpl-utility-bar.d.ts +1 -5
  143. package/dist/types/components.d.ts +21 -276
  144. package/dist/types/stencil-public-runtime.d.ts +23 -97
  145. package/loader/index.d.ts +1 -9
  146. package/loader/package.json +0 -1
  147. package/package.json +28 -21
  148. package/LICENSE +0 -21
  149. package/dist/apollo-core/apollo-core.esm.js.map +0 -1
  150. package/dist/apollo-core/index.esm.js.map +0 -1
  151. package/dist/apollo-core/p-1fa46bc3.entry.js +0 -2
  152. package/dist/apollo-core/p-1fa46bc3.entry.js.map +0 -1
  153. package/dist/apollo-core/p-29f4679d.entry.js +0 -2
  154. package/dist/apollo-core/p-29f4679d.entry.js.map +0 -1
  155. package/dist/apollo-core/p-3f3cc34e.entry.js +0 -2
  156. package/dist/apollo-core/p-3f3cc34e.entry.js.map +0 -1
  157. package/dist/apollo-core/p-5372bf3e.entry.js +0 -2
  158. package/dist/apollo-core/p-5372bf3e.entry.js.map +0 -1
  159. package/dist/apollo-core/p-5ceaec87.entry.js +0 -2
  160. package/dist/apollo-core/p-5ceaec87.entry.js.map +0 -1
  161. package/dist/apollo-core/p-60d4d252.entry.js +0 -2
  162. package/dist/apollo-core/p-60d4d252.entry.js.map +0 -1
  163. package/dist/apollo-core/p-6797b2b7.entry.js +0 -7
  164. package/dist/apollo-core/p-6797b2b7.entry.js.map +0 -1
  165. package/dist/apollo-core/p-6acc4122.entry.js +0 -2
  166. package/dist/apollo-core/p-6acc4122.entry.js.map +0 -1
  167. package/dist/apollo-core/p-787bac91.entry.js +0 -2
  168. package/dist/apollo-core/p-787bac91.entry.js.map +0 -1
  169. package/dist/apollo-core/p-7a8e818a.entry.js +0 -2
  170. package/dist/apollo-core/p-7a8e818a.entry.js.map +0 -1
  171. package/dist/apollo-core/p-807d8de9.entry.js +0 -2
  172. package/dist/apollo-core/p-807d8de9.entry.js.map +0 -1
  173. package/dist/apollo-core/p-ad90fe4d.js.map +0 -1
  174. package/dist/apollo-core/p-bcb81e30.entry.js +0 -2
  175. package/dist/apollo-core/p-bcb81e30.entry.js.map +0 -1
  176. package/dist/apollo-core/p-da5a8e74.entry.js +0 -2
  177. package/dist/apollo-core/p-da5a8e74.entry.js.map +0 -1
  178. package/dist/apollo-core/p-e0541e23.entry.js +0 -2
  179. package/dist/apollo-core/p-e0541e23.entry.js.map +0 -1
  180. package/dist/apollo-core/p-e215fc5f.entry.js +0 -2
  181. package/dist/apollo-core/p-e215fc5f.entry.js.map +0 -1
  182. package/dist/apollo-core/p-e8953b60.js +0 -3
  183. package/dist/apollo-core/p-e8953b60.js.map +0 -1
  184. package/dist/apollo-core/p-efa8a79d.entry.js +0 -2
  185. package/dist/apollo-core/p-efa8a79d.entry.js.map +0 -1
  186. package/dist/cjs/apollo-core.cjs.js.map +0 -1
  187. package/dist/cjs/index-000e170c.js.map +0 -1
  188. package/dist/cjs/index.cjs.js.map +0 -1
  189. package/dist/cjs/loader.cjs.js.map +0 -1
  190. package/dist/cjs/v4-14140ff3.js.map +0 -1
  191. package/dist/cjs/xpl-application-shell.cjs.entry.js.map +0 -1
  192. package/dist/cjs/xpl-avatar_15.cjs.entry.js +0 -2278
  193. package/dist/cjs/xpl-avatar_15.cjs.entry.js.map +0 -1
  194. package/dist/cjs/xpl-backdrop.cjs.entry.js.map +0 -1
  195. package/dist/cjs/xpl-button-row.cjs.entry.js.map +0 -1
  196. package/dist/cjs/xpl-choicelist.cjs.entry.js.map +0 -1
  197. package/dist/cjs/xpl-divider.cjs.entry.js.map +0 -1
  198. package/dist/cjs/xpl-dropdown-group_3.cjs.entry.js.map +0 -1
  199. package/dist/cjs/xpl-dropdown_2.cjs.entry.js.map +0 -1
  200. package/dist/cjs/xpl-grid-item.cjs.entry.js.map +0 -1
  201. package/dist/cjs/xpl-grid.cjs.entry.js.map +0 -1
  202. package/dist/cjs/xpl-input.cjs.entry.js.map +0 -1
  203. package/dist/cjs/xpl-list.cjs.entry.js.map +0 -1
  204. package/dist/cjs/xpl-main-nav.cjs.entry.js.map +0 -1
  205. package/dist/cjs/xpl-pagination.cjs.entry.js.map +0 -1
  206. package/dist/cjs/xpl-select.cjs.entry.js.map +0 -1
  207. package/dist/cjs/xpl-toggle.cjs.entry.js.map +0 -1
  208. package/dist/collection/components/xpl-application-shell/xpl-application-shell.js.map +0 -1
  209. package/dist/collection/components/xpl-avatar/xpl-avatar.js.map +0 -1
  210. package/dist/collection/components/xpl-backdrop/xpl-backdrop.js.map +0 -1
  211. package/dist/collection/components/xpl-badge/xpl-badge.js.map +0 -1
  212. package/dist/collection/components/xpl-breadcrumbs/xpl-breadcrumb-item/xpl-breadcrumb-item.js.map +0 -1
  213. package/dist/collection/components/xpl-breadcrumbs/xpl-breadcrumbs/xpl-breadcrumbs.js.map +0 -1
  214. package/dist/collection/components/xpl-button/xpl-button.js.map +0 -1
  215. package/dist/collection/components/xpl-button-row/xpl-button-row.js.map +0 -1
  216. package/dist/collection/components/xpl-checkbox/xpl-checkbox.js.map +0 -1
  217. package/dist/collection/components/xpl-choicelist/choice.js +0 -2
  218. package/dist/collection/components/xpl-choicelist/choice.js.map +0 -1
  219. package/dist/collection/components/xpl-choicelist/xpl-choicelist.js.map +0 -1
  220. package/dist/collection/components/xpl-content-area/xpl-content-area.js.map +0 -1
  221. package/dist/collection/components/xpl-dashboard/xpl-dashboard.js +0 -8
  222. package/dist/collection/components/xpl-dashboard/xpl-dashboard.js.map +0 -1
  223. package/dist/collection/components/xpl-data-card/xpl-data-card.js +0 -162
  224. package/dist/collection/components/xpl-data-card/xpl-data-card.js.map +0 -1
  225. package/dist/collection/components/xpl-divider/xpl-divider.js.map +0 -1
  226. package/dist/collection/components/xpl-dropdown/dropdownoption.js +0 -2
  227. package/dist/collection/components/xpl-dropdown/dropdownoption.js.map +0 -1
  228. package/dist/collection/components/xpl-dropdown/xpl-dropdown-group/xpl-dropdown-group.js.map +0 -1
  229. package/dist/collection/components/xpl-dropdown/xpl-dropdown-heading/xpl-dropdown-heading.js.map +0 -1
  230. package/dist/collection/components/xpl-dropdown/xpl-dropdown-option/xpl-dropdown-option.js.map +0 -1
  231. package/dist/collection/components/xpl-dropdown/xpl-dropdown.js.map +0 -1
  232. package/dist/collection/components/xpl-grid/xpl-grid.js.map +0 -1
  233. package/dist/collection/components/xpl-grid-item/xpl-grid-item.js.map +0 -1
  234. package/dist/collection/components/xpl-icon/xpl-icon.css +0 -5
  235. package/dist/collection/components/xpl-icon/xpl-icon.js +0 -93
  236. package/dist/collection/components/xpl-icon/xpl-icon.js.map +0 -1
  237. package/dist/collection/components/xpl-input/xpl-input.js.map +0 -1
  238. package/dist/collection/components/xpl-list/listitem.js +0 -2
  239. package/dist/collection/components/xpl-list/listitem.js.map +0 -1
  240. package/dist/collection/components/xpl-list/xpl-list.js.map +0 -1
  241. package/dist/collection/components/xpl-main-nav/xpl-main-nav.js.map +0 -1
  242. package/dist/collection/components/xpl-nav-item/xpl-nav-item.js.map +0 -1
  243. package/dist/collection/components/xpl-pagination/xpl-pagination.js.map +0 -1
  244. package/dist/collection/components/xpl-radio/xpl-radio.js.map +0 -1
  245. package/dist/collection/components/xpl-secondary-nav/xpl-secondary-nav.js.map +0 -1
  246. package/dist/collection/components/xpl-select/xpl-select.js.map +0 -1
  247. package/dist/collection/components/xpl-table/xpl-table.js.map +0 -1
  248. package/dist/collection/components/xpl-tag/xpl-tag.js.map +0 -1
  249. package/dist/collection/components/xpl-toggle/xpl-toggle.js.map +0 -1
  250. package/dist/collection/components/xpl-utility-bar/xpl-utility-bar.js.map +0 -1
  251. package/dist/components/index.d.ts +0 -39
  252. package/dist/components/index.js +0 -82
  253. package/dist/components/index.js.map +0 -1
  254. package/dist/components/v4.js +0 -77
  255. package/dist/components/v4.js.map +0 -1
  256. package/dist/components/xpl-application-shell.d.ts +0 -11
  257. package/dist/components/xpl-application-shell.js +0 -80
  258. package/dist/components/xpl-application-shell.js.map +0 -1
  259. package/dist/components/xpl-avatar.d.ts +0 -11
  260. package/dist/components/xpl-avatar.js +0 -8
  261. package/dist/components/xpl-avatar.js.map +0 -1
  262. package/dist/components/xpl-avatar2.js +0 -51
  263. package/dist/components/xpl-avatar2.js.map +0 -1
  264. package/dist/components/xpl-backdrop.d.ts +0 -11
  265. package/dist/components/xpl-backdrop.js +0 -8
  266. package/dist/components/xpl-backdrop.js.map +0 -1
  267. package/dist/components/xpl-backdrop2.js +0 -35
  268. package/dist/components/xpl-backdrop2.js.map +0 -1
  269. package/dist/components/xpl-badge.d.ts +0 -11
  270. package/dist/components/xpl-badge.js +0 -8
  271. package/dist/components/xpl-badge.js.map +0 -1
  272. package/dist/components/xpl-badge2.js +0 -38
  273. package/dist/components/xpl-badge2.js.map +0 -1
  274. package/dist/components/xpl-breadcrumb-item.d.ts +0 -11
  275. package/dist/components/xpl-breadcrumb-item.js +0 -36
  276. package/dist/components/xpl-breadcrumb-item.js.map +0 -1
  277. package/dist/components/xpl-breadcrumbs.d.ts +0 -11
  278. package/dist/components/xpl-breadcrumbs.js +0 -31
  279. package/dist/components/xpl-breadcrumbs.js.map +0 -1
  280. package/dist/components/xpl-button-row.d.ts +0 -11
  281. package/dist/components/xpl-button-row.js +0 -50
  282. package/dist/components/xpl-button-row.js.map +0 -1
  283. package/dist/components/xpl-button.d.ts +0 -11
  284. package/dist/components/xpl-button.js +0 -8
  285. package/dist/components/xpl-button.js.map +0 -1
  286. package/dist/components/xpl-button2.js +0 -85
  287. package/dist/components/xpl-button2.js.map +0 -1
  288. package/dist/components/xpl-checkbox.d.ts +0 -11
  289. package/dist/components/xpl-checkbox.js +0 -8
  290. package/dist/components/xpl-checkbox.js.map +0 -1
  291. package/dist/components/xpl-checkbox2.js +0 -59
  292. package/dist/components/xpl-checkbox2.js.map +0 -1
  293. package/dist/components/xpl-choicelist.d.ts +0 -11
  294. package/dist/components/xpl-choicelist.js +0 -85
  295. package/dist/components/xpl-choicelist.js.map +0 -1
  296. package/dist/components/xpl-content-area.d.ts +0 -11
  297. package/dist/components/xpl-content-area.js +0 -34
  298. package/dist/components/xpl-content-area.js.map +0 -1
  299. package/dist/components/xpl-dashboard.d.ts +0 -11
  300. package/dist/components/xpl-dashboard.js +0 -31
  301. package/dist/components/xpl-dashboard.js.map +0 -1
  302. package/dist/components/xpl-data-card.d.ts +0 -11
  303. package/dist/components/xpl-data-card.js +0 -80
  304. package/dist/components/xpl-data-card.js.map +0 -1
  305. package/dist/components/xpl-divider.d.ts +0 -11
  306. package/dist/components/xpl-divider.js +0 -36
  307. package/dist/components/xpl-divider.js.map +0 -1
  308. package/dist/components/xpl-dropdown-group.d.ts +0 -11
  309. package/dist/components/xpl-dropdown-group.js +0 -8
  310. package/dist/components/xpl-dropdown-group.js.map +0 -1
  311. package/dist/components/xpl-dropdown-group2.js +0 -69
  312. package/dist/components/xpl-dropdown-group2.js.map +0 -1
  313. package/dist/components/xpl-dropdown-heading.d.ts +0 -11
  314. package/dist/components/xpl-dropdown-heading.js +0 -8
  315. package/dist/components/xpl-dropdown-heading.js.map +0 -1
  316. package/dist/components/xpl-dropdown-heading2.js +0 -31
  317. package/dist/components/xpl-dropdown-heading2.js.map +0 -1
  318. package/dist/components/xpl-dropdown-option.d.ts +0 -11
  319. package/dist/components/xpl-dropdown-option.js +0 -8
  320. package/dist/components/xpl-dropdown-option.js.map +0 -1
  321. package/dist/components/xpl-dropdown-option2.js +0 -89
  322. package/dist/components/xpl-dropdown-option2.js.map +0 -1
  323. package/dist/components/xpl-dropdown.d.ts +0 -11
  324. package/dist/components/xpl-dropdown.js +0 -8
  325. package/dist/components/xpl-dropdown.js.map +0 -1
  326. package/dist/components/xpl-dropdown2.js +0 -147
  327. package/dist/components/xpl-dropdown2.js.map +0 -1
  328. package/dist/components/xpl-grid-item.d.ts +0 -11
  329. package/dist/components/xpl-grid-item.js +0 -45
  330. package/dist/components/xpl-grid-item.js.map +0 -1
  331. package/dist/components/xpl-grid.d.ts +0 -11
  332. package/dist/components/xpl-grid.js +0 -50
  333. package/dist/components/xpl-grid.js.map +0 -1
  334. package/dist/components/xpl-icon.d.ts +0 -11
  335. package/dist/components/xpl-icon.js +0 -8
  336. package/dist/components/xpl-icon.js.map +0 -1
  337. package/dist/components/xpl-icon2.js +0 -1850
  338. package/dist/components/xpl-icon2.js.map +0 -1
  339. package/dist/components/xpl-input.d.ts +0 -11
  340. package/dist/components/xpl-input.js +0 -2574
  341. package/dist/components/xpl-input.js.map +0 -1
  342. package/dist/components/xpl-list.d.ts +0 -11
  343. package/dist/components/xpl-list.js +0 -73
  344. package/dist/components/xpl-list.js.map +0 -1
  345. package/dist/components/xpl-main-nav.d.ts +0 -11
  346. package/dist/components/xpl-main-nav.js +0 -44
  347. package/dist/components/xpl-main-nav.js.map +0 -1
  348. package/dist/components/xpl-nav-item.d.ts +0 -11
  349. package/dist/components/xpl-nav-item.js +0 -44
  350. package/dist/components/xpl-nav-item.js.map +0 -1
  351. package/dist/components/xpl-pagination.d.ts +0 -11
  352. package/dist/components/xpl-pagination.js +0 -100
  353. package/dist/components/xpl-pagination.js.map +0 -1
  354. package/dist/components/xpl-radio.d.ts +0 -11
  355. package/dist/components/xpl-radio.js +0 -8
  356. package/dist/components/xpl-radio.js.map +0 -1
  357. package/dist/components/xpl-radio2.js +0 -57
  358. package/dist/components/xpl-radio2.js.map +0 -1
  359. package/dist/components/xpl-secondary-nav.d.ts +0 -11
  360. package/dist/components/xpl-secondary-nav.js +0 -31
  361. package/dist/components/xpl-secondary-nav.js.map +0 -1
  362. package/dist/components/xpl-select.d.ts +0 -11
  363. package/dist/components/xpl-select.js +0 -712
  364. package/dist/components/xpl-select.js.map +0 -1
  365. package/dist/components/xpl-table.d.ts +0 -11
  366. package/dist/components/xpl-table.js +0 -170
  367. package/dist/components/xpl-table.js.map +0 -1
  368. package/dist/components/xpl-tag.d.ts +0 -11
  369. package/dist/components/xpl-tag.js +0 -8
  370. package/dist/components/xpl-tag.js.map +0 -1
  371. package/dist/components/xpl-tag2.js +0 -33
  372. package/dist/components/xpl-tag2.js.map +0 -1
  373. package/dist/components/xpl-toggle.d.ts +0 -11
  374. package/dist/components/xpl-toggle.js +0 -61
  375. package/dist/components/xpl-toggle.js.map +0 -1
  376. package/dist/components/xpl-utility-bar.d.ts +0 -11
  377. package/dist/components/xpl-utility-bar.js +0 -55
  378. package/dist/components/xpl-utility-bar.js.map +0 -1
  379. package/dist/esm/apollo-core.js.map +0 -1
  380. package/dist/esm/index-56581b5c.js.map +0 -1
  381. package/dist/esm/index.js.map +0 -1
  382. package/dist/esm/loader.js.map +0 -1
  383. package/dist/esm/v4-929670b7.js.map +0 -1
  384. package/dist/esm/xpl-application-shell.entry.js.map +0 -1
  385. package/dist/esm/xpl-avatar_15.entry.js +0 -2260
  386. package/dist/esm/xpl-avatar_15.entry.js.map +0 -1
  387. package/dist/esm/xpl-backdrop.entry.js.map +0 -1
  388. package/dist/esm/xpl-button-row.entry.js.map +0 -1
  389. package/dist/esm/xpl-choicelist.entry.js.map +0 -1
  390. package/dist/esm/xpl-divider.entry.js.map +0 -1
  391. package/dist/esm/xpl-dropdown-group_3.entry.js.map +0 -1
  392. package/dist/esm/xpl-dropdown_2.entry.js.map +0 -1
  393. package/dist/esm/xpl-grid-item.entry.js.map +0 -1
  394. package/dist/esm/xpl-grid.entry.js.map +0 -1
  395. package/dist/esm/xpl-input.entry.js.map +0 -1
  396. package/dist/esm/xpl-list.entry.js.map +0 -1
  397. package/dist/esm/xpl-main-nav.entry.js.map +0 -1
  398. package/dist/esm/xpl-pagination.entry.js.map +0 -1
  399. package/dist/esm/xpl-select.entry.js.map +0 -1
  400. package/dist/esm/xpl-toggle.entry.js.map +0 -1
  401. package/dist/stories/application-shell.stories.js.map +0 -1
  402. package/dist/stories/avatar.stories.js.map +0 -1
  403. package/dist/stories/backdrop.stories.js.map +0 -1
  404. package/dist/stories/badge.stories.js.map +0 -1
  405. package/dist/stories/breadcrumbs.stories.js.map +0 -1
  406. package/dist/stories/button-row.stories.js.map +0 -1
  407. package/dist/stories/button.stories.js.map +0 -1
  408. package/dist/stories/checkbox.stories.js.map +0 -1
  409. package/dist/stories/choicelist.stories.js.map +0 -1
  410. package/dist/stories/content-area.stories.js.map +0 -1
  411. package/dist/stories/dashboard.stories.js +0 -51
  412. package/dist/stories/dashboard.stories.js.map +0 -1
  413. package/dist/stories/data-card.stories.js +0 -70
  414. package/dist/stories/data-card.stories.js.map +0 -1
  415. package/dist/stories/divider.stories.js.map +0 -1
  416. package/dist/stories/dropdown.stories.js.map +0 -1
  417. package/dist/stories/grid.stories.js.map +0 -1
  418. package/dist/stories/icons.stories.js +0 -69
  419. package/dist/stories/icons.stories.js.map +0 -1
  420. package/dist/stories/input.stories.js.map +0 -1
  421. package/dist/stories/list.stories.js.map +0 -1
  422. package/dist/stories/main-nav.stories.js.map +0 -1
  423. package/dist/stories/pagination.stories.js.map +0 -1
  424. package/dist/stories/radio.stories.js.map +0 -1
  425. package/dist/stories/secondary-nav.stories.js.map +0 -1
  426. package/dist/stories/select.stories.js.map +0 -1
  427. package/dist/stories/table.stories.js.map +0 -1
  428. package/dist/stories/tabs.stories.js.map +0 -1
  429. package/dist/stories/toggle.stories.js.map +0 -1
  430. package/dist/stories/utility-bar.stories.js.map +0 -1
  431. package/dist/types/Users/roc/Sites/apollo/.stencil/stories/dashboard.stories.d.ts +0 -31
  432. package/dist/types/Users/roc/Sites/apollo/.stencil/stories/data-card.stories.d.ts +0 -71
  433. package/dist/types/Users/roc/Sites/apollo/.stencil/stories/icons.stories.d.ts +0 -77
  434. package/dist/types/Users/roc/Sites/apollo/.stencil/stories/select.stories.d.ts +0 -134
  435. package/dist/types/components/xpl-choicelist/choice.d.ts +0 -6
  436. package/dist/types/components/xpl-dashboard/xpl-dashboard.d.ts +0 -3
  437. package/dist/types/components/xpl-data-card/xpl-data-card.d.ts +0 -38
  438. package/dist/types/components/xpl-dropdown/dropdownoption.d.ts +0 -11
  439. package/dist/types/components/xpl-icon/xpl-icon.d.ts +0 -17
  440. package/dist/types/components/xpl-list/listitem.d.ts +0 -16
  441. /package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/avatar.stories.d.ts +0 -0
  442. /package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/backdrop.stories.d.ts +0 -0
  443. /package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/badge.stories.d.ts +0 -0
  444. /package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/breadcrumbs.stories.d.ts +0 -0
  445. /package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/button-row.stories.d.ts +0 -0
  446. /package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/checkbox.stories.d.ts +0 -0
  447. /package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/choicelist.stories.d.ts +0 -0
  448. /package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/content-area.stories.d.ts +0 -0
  449. /package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/divider.stories.d.ts +0 -0
  450. /package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/grid.stories.d.ts +0 -0
  451. /package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/input.stories.d.ts +0 -0
  452. /package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/list.stories.d.ts +0 -0
  453. /package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/main-nav.stories.d.ts +0 -0
  454. /package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/pagination.stories.d.ts +0 -0
  455. /package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/radio.stories.d.ts +0 -0
  456. /package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/secondary-nav.stories.d.ts +0 -0
  457. /package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/tabs.stories.d.ts +0 -0
  458. /package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/toggle.stories.d.ts +0 -0
  459. /package/dist/types/Users/{roc/Sites → fernandogelin/Projects/apollo-admin/packages}/apollo/.stencil/stories/utility-bar.stories.d.ts +0 -0
@@ -1,2574 +0,0 @@
1
- import { proxyCustomElement, HTMLElement as HTMLElement$1, h, Host } from '@stencil/core/internal/client';
2
- import { d as defineCustomElement$2 } from './xpl-icon2.js';
3
- import { v as v4 } from './v4.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
2445
- ? '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'
2446
- : '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>`;
2447
- const XplInput$1 = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement$1 {
2448
- constructor() {
2449
- super();
2450
- this.__registerHost();
2451
- this._id = undefined;
2452
- this.autocomplete = undefined;
2453
- this.dateFormat = 'Y-m-d';
2454
- this.description = undefined;
2455
- this.disabled = undefined;
2456
- this.error = undefined;
2457
- this.label = undefined;
2458
- this.max = undefined;
2459
- this.maxCharacterCount = undefined;
2460
- this.min = undefined;
2461
- this.mode = 'single';
2462
- this.multiline = false;
2463
- this.name = undefined;
2464
- this.placeholder = undefined;
2465
- this.post = undefined;
2466
- this.pre = undefined;
2467
- this.readonly = undefined;
2468
- this.required = undefined;
2469
- this.step = undefined;
2470
- this.type = 'text';
2471
- this.value = undefined;
2472
- this.characterCount = 0;
2473
- this.passwordVisible = false;
2474
- }
2475
- updateCharacterCount() {
2476
- this.characterCount = this.input.value.length;
2477
- }
2478
- componentWillLoad() {
2479
- if (this._id === undefined || this._id === null || this._id === '')
2480
- this._id = v4();
2481
- if (this.multiline && this.maxCharacterCount !== undefined) {
2482
- this.characterCount =
2483
- this.value !== undefined ? this.value.length : 0;
2484
- }
2485
- }
2486
- componentDidLoad() {
2487
- if (this.type === 'date') {
2488
- flatpickr(this.input, {
2489
- allowInput: true,
2490
- dateFormat: this.dateFormat,
2491
- defaultDate: this.value,
2492
- maxDate: this.max,
2493
- minDate: this.min,
2494
- mode: this.mode,
2495
- nextArrow: arrowSvg(),
2496
- prevArrow: arrowSvg(true),
2497
- });
2498
- }
2499
- }
2500
- render() {
2501
- let className = 'xpl-input';
2502
- if (this.disabled)
2503
- className += ' xpl-input--disabled';
2504
- let hasError = false;
2505
- if (this.error !== undefined)
2506
- hasError = true;
2507
- if (this.multiline &&
2508
- this.maxCharacterCount !== undefined &&
2509
- this.characterCount > this.maxCharacterCount)
2510
- hasError = true;
2511
- if (hasError)
2512
- className += ' xpl-input--error';
2513
- let type = this.type;
2514
- if (type === 'password' && this.passwordVisible) {
2515
- type = 'text';
2516
- }
2517
- 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 ? (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) => {
2518
- this.input = el;
2519
- }, required: this.required, step: this.step, type: type, value: this.value })) : (h("textarea", { disabled: this.disabled, id: this._id, name: this.name, onInput: () => this.updateCharacterCount(), placeholder: this.placeholder, readonly: this.readonly, ref: (el) => {
2520
- this.input = el;
2521
- }, required: this.required }, this.value)), this.type === 'date' && (h("xpl-icon", { class: "xpl-input-calendar", icon: "calendar-month", size: 24 })), this.type === 'password' && (h("button", { "aria-label": "Toggle password visibility", class: "xpl-input-password", onClick: () => {
2522
- this.passwordVisible = !this.passwordVisible;
2523
- }, role: "presentation" }, h("xpl-icon", { icon: this.passwordVisible ? 'eye-closed' : 'eye', size: 24 }))), 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))));
2524
- }
2525
- }, [0, "xpl-input", {
2526
- "_id": [1],
2527
- "autocomplete": [1],
2528
- "dateFormat": [1, "date-format"],
2529
- "description": [1],
2530
- "disabled": [4],
2531
- "error": [1],
2532
- "label": [1],
2533
- "max": [8],
2534
- "maxCharacterCount": [2, "max-character-count"],
2535
- "min": [8],
2536
- "mode": [1],
2537
- "multiline": [4],
2538
- "name": [1],
2539
- "placeholder": [1],
2540
- "post": [1],
2541
- "pre": [1],
2542
- "readonly": [4],
2543
- "required": [4],
2544
- "step": [2],
2545
- "type": [1],
2546
- "value": [1],
2547
- "characterCount": [32],
2548
- "passwordVisible": [32]
2549
- }]);
2550
- function defineCustomElement$1() {
2551
- if (typeof customElements === "undefined") {
2552
- return;
2553
- }
2554
- const components = ["xpl-input", "xpl-icon"];
2555
- components.forEach(tagName => { switch (tagName) {
2556
- case "xpl-input":
2557
- if (!customElements.get(tagName)) {
2558
- customElements.define(tagName, XplInput$1);
2559
- }
2560
- break;
2561
- case "xpl-icon":
2562
- if (!customElements.get(tagName)) {
2563
- defineCustomElement$2();
2564
- }
2565
- break;
2566
- } });
2567
- }
2568
-
2569
- const XplInput = XplInput$1;
2570
- const defineCustomElement = defineCustomElement$1;
2571
-
2572
- export { XplInput, defineCustomElement };
2573
-
2574
- //# sourceMappingURL=xpl-input.js.map