voyager-ionic-core 7.5.1 → 7.6.0

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 (1918) hide show
  1. package/components/action-sheet.js +299 -289
  2. package/components/alert.js +477 -467
  3. package/components/animation.js +992 -976
  4. package/components/backdrop.js +56 -56
  5. package/components/button-active.js +56 -56
  6. package/components/button.js +236 -236
  7. package/components/buttons.js +29 -29
  8. package/components/capacitor.js +4 -4
  9. package/components/checkbox.js +172 -170
  10. package/components/config.js +142 -142
  11. package/components/cubic-bezier.js +49 -49
  12. package/components/data.js +1055 -1055
  13. package/components/dir.js +5 -5
  14. package/components/focus-visible.js +63 -63
  15. package/components/form-controller.js +45 -49
  16. package/components/framework-delegate.js +121 -121
  17. package/components/gesture-controller.js +182 -182
  18. package/components/haptic.js +150 -150
  19. package/components/hardware-back-button.js +48 -48
  20. package/components/helpers.js +257 -257
  21. package/components/icon.js +133 -133
  22. package/components/index.js +95 -95
  23. package/components/index2.js +163 -163
  24. package/components/index3.js +417 -417
  25. package/components/index4.js +257 -259
  26. package/components/index5.js +0 -22
  27. package/components/index6.js +3 -3
  28. package/components/index8.js +58 -59
  29. package/components/index9.js +171 -171
  30. package/components/input-shims.js +488 -475
  31. package/components/input.utils.js +107 -106
  32. package/components/ion-accordion-group.d.ts +2 -2
  33. package/components/ion-accordion-group.js +223 -213
  34. package/components/ion-accordion.d.ts +2 -2
  35. package/components/ion-accordion.js +326 -326
  36. package/components/ion-action-sheet.d.ts +2 -2
  37. package/components/ion-alert.d.ts +2 -2
  38. package/components/ion-app.d.ts +2 -2
  39. package/components/ion-app.js +93 -93
  40. package/components/ion-avatar.d.ts +2 -2
  41. package/components/ion-avatar.js +23 -23
  42. package/components/ion-back-button.d.ts +2 -2
  43. package/components/ion-back-button.js +102 -102
  44. package/components/ion-backdrop.d.ts +2 -2
  45. package/components/ion-badge.d.ts +2 -2
  46. package/components/ion-badge.js +29 -29
  47. package/components/ion-breadcrumb.d.ts +2 -2
  48. package/components/ion-breadcrumb.js +111 -111
  49. package/components/ion-breadcrumbs.d.ts +2 -2
  50. package/components/ion-breadcrumbs.js +139 -139
  51. package/components/ion-button.d.ts +2 -2
  52. package/components/ion-buttons.d.ts +2 -2
  53. package/components/ion-card-content.d.ts +2 -2
  54. package/components/ion-card-content.js +27 -27
  55. package/components/ion-card-header.d.ts +2 -2
  56. package/components/ion-card-header.js +33 -33
  57. package/components/ion-card-subtitle.d.ts +2 -2
  58. package/components/ion-card-subtitle.js +30 -30
  59. package/components/ion-card-title.d.ts +2 -2
  60. package/components/ion-card-title.js +30 -30
  61. package/components/ion-card.d.ts +2 -2
  62. package/components/ion-card.js +78 -78
  63. package/components/ion-checkbox.d.ts +2 -2
  64. package/components/ion-chip.d.ts +2 -2
  65. package/components/ion-chip.js +41 -41
  66. package/components/ion-col.d.ts +2 -2
  67. package/components/ion-col.js +156 -156
  68. package/components/ion-content.d.ts +2 -2
  69. package/components/ion-content.js +394 -394
  70. package/components/ion-datetime-button.d.ts +2 -2
  71. package/components/ion-datetime-button.js +348 -348
  72. package/components/ion-datetime.d.ts +2 -2
  73. package/components/ion-datetime.js +1722 -1684
  74. package/components/ion-fab-button.d.ts +2 -2
  75. package/components/ion-fab-button.js +109 -109
  76. package/components/ion-fab-list.d.ts +2 -2
  77. package/components/ion-fab-list.js +45 -45
  78. package/components/ion-fab.d.ts +2 -2
  79. package/components/ion-fab.js +76 -76
  80. package/components/ion-footer.d.ts +2 -2
  81. package/components/ion-footer.js +124 -124
  82. package/components/ion-grid.d.ts +2 -2
  83. package/components/ion-grid.js +27 -27
  84. package/components/ion-header.d.ts +2 -2
  85. package/components/ion-header.js +299 -299
  86. package/components/ion-img.d.ts +2 -2
  87. package/components/ion-img.js +97 -97
  88. package/components/ion-infinite-scroll-content.d.ts +2 -2
  89. package/components/ion-infinite-scroll-content.js +49 -49
  90. package/components/ion-infinite-scroll.d.ts +2 -2
  91. package/components/ion-infinite-scroll.js +187 -179
  92. package/components/ion-input.d.ts +2 -2
  93. package/components/ion-input.js +482 -450
  94. package/components/ion-item-divider.d.ts +2 -2
  95. package/components/ion-item-divider.js +36 -36
  96. package/components/ion-item-group.d.ts +2 -2
  97. package/components/ion-item-group.js +28 -28
  98. package/components/ion-item-option.d.ts +2 -2
  99. package/components/ion-item-option.js +69 -69
  100. package/components/ion-item-options.d.ts +2 -2
  101. package/components/ion-item-options.js +50 -50
  102. package/components/ion-item-sliding.d.ts +2 -2
  103. package/components/ion-item-sliding.js +404 -404
  104. package/components/ion-item.d.ts +2 -2
  105. package/components/ion-label.d.ts +2 -2
  106. package/components/ion-list-header.d.ts +2 -2
  107. package/components/ion-list.d.ts +2 -2
  108. package/components/ion-loading.d.ts +2 -2
  109. package/components/ion-loading.js +257 -247
  110. package/components/ion-menu-button.d.ts +2 -2
  111. package/components/ion-menu-button.js +77 -77
  112. package/components/ion-menu-toggle.d.ts +2 -2
  113. package/components/ion-menu-toggle.js +41 -41
  114. package/components/ion-menu.d.ts +2 -2
  115. package/components/ion-menu.js +631 -619
  116. package/components/ion-modal.d.ts +2 -2
  117. package/components/ion-modal.js +1451 -1441
  118. package/components/ion-nav-link.d.ts +2 -2
  119. package/components/ion-nav-link.js +47 -47
  120. package/components/ion-nav.d.ts +2 -2
  121. package/components/ion-nav.js +910 -910
  122. package/components/ion-note.d.ts +2 -2
  123. package/components/ion-picker-column-internal.d.ts +2 -2
  124. package/components/ion-picker-column.d.ts +2 -2
  125. package/components/ion-picker-internal.d.ts +2 -2
  126. package/components/ion-picker.d.ts +2 -2
  127. package/components/ion-picker.js +263 -253
  128. package/components/ion-popover.d.ts +2 -2
  129. package/components/ion-progress-bar.d.ts +2 -2
  130. package/components/ion-progress-bar.js +57 -57
  131. package/components/ion-radio-group.d.ts +2 -2
  132. package/components/ion-radio.d.ts +2 -2
  133. package/components/ion-range.d.ts +2 -2
  134. package/components/ion-range.js +593 -591
  135. package/components/ion-refresher-content.d.ts +2 -2
  136. package/components/ion-refresher-content.js +63 -63
  137. package/components/ion-refresher.d.ts +2 -2
  138. package/components/ion-refresher.js +747 -740
  139. package/components/ion-reorder-group.d.ts +2 -2
  140. package/components/ion-reorder-group.js +259 -259
  141. package/components/ion-reorder.d.ts +2 -2
  142. package/components/ion-reorder.js +41 -41
  143. package/components/ion-ripple-effect.d.ts +2 -2
  144. package/components/ion-route-redirect.d.ts +2 -2
  145. package/components/ion-route-redirect.js +34 -34
  146. package/components/ion-route.d.ts +2 -2
  147. package/components/ion-route.js +56 -56
  148. package/components/ion-router-link.d.ts +2 -2
  149. package/components/ion-router-link.js +45 -45
  150. package/components/ion-router-outlet.d.ts +2 -2
  151. package/components/ion-router-outlet.js +193 -193
  152. package/components/ion-router.d.ts +2 -2
  153. package/components/ion-router.js +632 -632
  154. package/components/ion-row.d.ts +2 -2
  155. package/components/ion-row.js +20 -20
  156. package/components/ion-searchbar.d.ts +2 -2
  157. package/components/ion-searchbar.js +406 -397
  158. package/components/ion-segment-button.d.ts +2 -2
  159. package/components/ion-segment-button.js +117 -117
  160. package/components/ion-segment.d.ts +2 -2
  161. package/components/ion-segment.js +427 -401
  162. package/components/ion-select-option.d.ts +2 -2
  163. package/components/ion-select-option.js +27 -27
  164. package/components/ion-select-popover.d.ts +2 -2
  165. package/components/ion-select.d.ts +2 -2
  166. package/components/ion-select.js +778 -763
  167. package/components/ion-skeleton-text.d.ts +2 -2
  168. package/components/ion-skeleton-text.js +45 -32
  169. package/components/ion-spinner.d.ts +2 -2
  170. package/components/ion-split-pane.d.ts +2 -2
  171. package/components/ion-split-pane.js +145 -145
  172. package/components/ion-tab-bar.d.ts +2 -2
  173. package/components/ion-tab-bar.js +79 -79
  174. package/components/ion-tab-button.d.ts +2 -2
  175. package/components/ion-tab-button.js +106 -106
  176. package/components/ion-tab.d.ts +2 -2
  177. package/components/ion-tab.js +72 -72
  178. package/components/ion-tabs.d.ts +2 -2
  179. package/components/ion-tabs.js +160 -160
  180. package/components/ion-text.d.ts +2 -2
  181. package/components/ion-text.js +26 -26
  182. package/components/ion-textarea.d.ts +2 -2
  183. package/components/ion-textarea.js +424 -392
  184. package/components/ion-thumbnail.d.ts +2 -2
  185. package/components/ion-thumbnail.js +20 -20
  186. package/components/ion-title.d.ts +2 -2
  187. package/components/ion-title.js +57 -57
  188. package/components/ion-toast.d.ts +2 -2
  189. package/components/ion-toast.js +819 -464
  190. package/components/ion-toggle.d.ts +2 -2
  191. package/components/ion-toggle.js +243 -241
  192. package/components/ion-toolbar.d.ts +2 -2
  193. package/components/ion-toolbar.js +71 -71
  194. package/components/ionic-global.js +163 -163
  195. package/components/ios.transition.js +598 -598
  196. package/components/item.js +301 -301
  197. package/components/keyboard-controller.js +128 -128
  198. package/components/keyboard.js +62 -62
  199. package/components/keyboard2.js +59 -59
  200. package/components/label.js +85 -85
  201. package/components/list-header.js +35 -35
  202. package/components/list.js +52 -52
  203. package/components/lock-controller.js +24 -24
  204. package/components/md.transition.js +44 -44
  205. package/components/menu-toggle-util.js +2 -2
  206. package/components/notch-controller.js +120 -120
  207. package/components/note.js +29 -29
  208. package/components/overlays.js +496 -495
  209. package/components/picker-column-internal.js +350 -345
  210. package/components/picker-column.js +334 -334
  211. package/components/picker-internal.js +470 -470
  212. package/components/popover.js +1156 -1146
  213. package/components/radio-group.js +162 -151
  214. package/components/radio.js +248 -209
  215. package/components/ripple-effect.js +81 -81
  216. package/components/select-popover.js +163 -163
  217. package/components/spinner.js +182 -182
  218. package/components/status-tap.js +26 -26
  219. package/components/swipe-back.js +65 -65
  220. package/components/theme.js +23 -23
  221. package/components/watch-options.js +37 -26
  222. package/css/core.css +66 -0
  223. package/css/core.css.map +1 -1
  224. package/css/display.css +44 -0
  225. package/css/display.css.map +1 -1
  226. package/css/float-elements.css +44 -0
  227. package/css/float-elements.css.map +1 -1
  228. package/css/global.bundle.css +88 -0
  229. package/css/global.bundle.css.map +1 -1
  230. package/css/ionic-swiper.css +22 -0
  231. package/css/ionic-swiper.css.map +1 -1
  232. package/css/ionic.bundle.css.map +1 -1
  233. package/css/padding.css +44 -0
  234. package/css/padding.css.map +1 -1
  235. package/css/structure.css +44 -0
  236. package/css/structure.css.map +1 -1
  237. package/css/text-alignment.css +44 -0
  238. package/css/text-alignment.css.map +1 -1
  239. package/css/text-transformation.css +44 -0
  240. package/css/text-transformation.css.map +1 -1
  241. package/css/typography.css +44 -0
  242. package/css/typography.css.map +1 -1
  243. package/css/utils.bundle.css +220 -0
  244. package/css/utils.bundle.css.map +1 -1
  245. package/dist/cjs/animation-9b401d39.js +1062 -0
  246. package/dist/cjs/{app-globals-fe1ad535.js → app-globals-0af482c7.js} +1 -1
  247. package/dist/cjs/button-active-a5185907.js +69 -0
  248. package/dist/cjs/{capacitor-2ffba62a.js → capacitor-c04564bf.js} +5 -5
  249. package/dist/cjs/compare-with-utils-df1001d7.js +44 -0
  250. package/dist/cjs/config-4f60b98a.js +199 -0
  251. package/dist/cjs/cubic-bezier-f2dccc53.js +92 -0
  252. package/dist/cjs/data-36b9094e.js +1622 -0
  253. package/dist/cjs/{dir-f1e0ca26.js → dir-94c21456.js} +5 -5
  254. package/dist/cjs/focus-visible-7a0ce04f.js +77 -0
  255. package/dist/cjs/form-controller-7d42a722.js +66 -0
  256. package/dist/cjs/framework-delegate-1c29b14a.js +144 -0
  257. package/dist/cjs/gesture-controller-c40c045a.js +197 -0
  258. package/dist/cjs/haptic-b882e0bb.js +212 -0
  259. package/dist/cjs/hardware-back-button-76833cac.js +76 -0
  260. package/dist/cjs/helpers-76bb7efb.js +441 -0
  261. package/dist/cjs/{index-cc7dfb7c.js → index-5915f9b3.js} +3 -3
  262. package/dist/cjs/index-b4f986cd.js +198 -0
  263. package/dist/cjs/{index-305a23dc.js → index-bbb4336c.js} +184 -63
  264. package/dist/cjs/index-c8d52405.js +10 -0
  265. package/dist/cjs/index-ce101dc9.js +308 -0
  266. package/dist/cjs/index-d1b59ffa.js +459 -0
  267. package/dist/cjs/{index-10873539.js → index-da15e99c.js} +60 -61
  268. package/dist/cjs/index-f8f13389.js +243 -0
  269. package/dist/cjs/index.cjs.js +113 -113
  270. package/dist/cjs/input-shims-a23bb0f4.js +601 -0
  271. package/dist/cjs/input.utils-3d0166a2.js +138 -0
  272. package/dist/cjs/ion-accordion_2.cjs.entry.js +491 -481
  273. package/dist/cjs/ion-action-sheet.cjs.entry.js +262 -252
  274. package/dist/cjs/ion-alert.cjs.entry.js +442 -432
  275. package/dist/cjs/ion-app_8.cjs.entry.js +1153 -1153
  276. package/dist/cjs/ion-avatar_3.cjs.entry.js +29 -29
  277. package/dist/cjs/ion-back-button.cjs.entry.js +73 -73
  278. package/dist/cjs/ion-backdrop.cjs.entry.js +40 -40
  279. package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +194 -194
  280. package/dist/cjs/ion-button_2.cjs.entry.js +303 -303
  281. package/dist/cjs/ion-card_5.cjs.entry.js +105 -105
  282. package/dist/cjs/ion-checkbox.cjs.entry.js +149 -147
  283. package/dist/cjs/ion-chip.cjs.entry.js +20 -20
  284. package/dist/cjs/ion-col_3.cjs.entry.js +136 -136
  285. package/dist/cjs/ion-datetime-button.cjs.entry.js +325 -325
  286. package/dist/cjs/ion-datetime_3.cjs.entry.js +2185 -2137
  287. package/dist/cjs/ion-fab_3.cjs.entry.js +152 -152
  288. package/dist/cjs/ion-img.cjs.entry.js +79 -79
  289. package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +198 -190
  290. package/dist/cjs/ion-input.cjs.entry.js +426 -394
  291. package/dist/cjs/ion-item-option_3.cjs.entry.js +459 -459
  292. package/dist/cjs/ion-item_8.cjs.entry.js +447 -434
  293. package/dist/cjs/ion-loading.cjs.entry.js +220 -210
  294. package/dist/cjs/ion-menu_3.cjs.entry.js +670 -658
  295. package/dist/cjs/ion-modal.cjs.entry.js +1415 -1405
  296. package/dist/cjs/ion-nav_2.cjs.entry.js +904 -904
  297. package/dist/cjs/ion-picker-column-internal.cjs.entry.js +331 -327
  298. package/dist/cjs/ion-picker-internal.cjs.entry.js +455 -455
  299. package/dist/cjs/ion-popover.cjs.entry.js +1110 -1100
  300. package/dist/cjs/ion-progress-bar.cjs.entry.js +40 -40
  301. package/dist/cjs/ion-radio_2.cjs.entry.js +322 -309
  302. package/dist/cjs/ion-range.cjs.entry.js +558 -556
  303. package/dist/cjs/ion-refresher_2.cjs.entry.js +786 -779
  304. package/dist/cjs/ion-reorder_2.cjs.entry.js +269 -269
  305. package/dist/cjs/ion-ripple-effect.cjs.entry.js +66 -66
  306. package/dist/cjs/ion-route_4.cjs.entry.js +693 -693
  307. package/dist/cjs/ion-searchbar.cjs.entry.js +363 -354
  308. package/dist/cjs/ion-segment_2.cjs.entry.js +509 -483
  309. package/dist/cjs/ion-select_3.cjs.entry.js +784 -768
  310. package/dist/cjs/ion-spinner.cjs.entry.js +46 -46
  311. package/dist/cjs/ion-split-pane.cjs.entry.js +117 -117
  312. package/dist/cjs/ion-tab-bar_2.cjs.entry.js +142 -142
  313. package/dist/cjs/ion-tab_2.cjs.entry.js +187 -187
  314. package/dist/cjs/ion-text.cjs.entry.js +13 -13
  315. package/dist/cjs/ion-textarea.cjs.entry.js +381 -349
  316. package/dist/cjs/ion-toast.cjs.entry.js +771 -419
  317. package/dist/cjs/ion-toggle.cjs.entry.js +227 -225
  318. package/dist/cjs/ionic-global-f4a2093b.js +230 -0
  319. package/dist/cjs/ionic.cjs.js +5 -5
  320. package/dist/cjs/ios.transition-6787b799.js +654 -0
  321. package/dist/cjs/keyboard-0272231f.js +81 -0
  322. package/dist/cjs/{keyboard-38f2bb7b.js → keyboard-af1bb365.js} +62 -62
  323. package/dist/cjs/keyboard-controller-c05e747a.js +167 -0
  324. package/dist/cjs/loader.cjs.js +4 -4
  325. package/dist/cjs/lock-controller-6585a42a.js +40 -0
  326. package/dist/cjs/md.transition-e033d20a.js +59 -0
  327. package/dist/cjs/notch-controller-9735e7ac.js +155 -0
  328. package/dist/cjs/overlays-27a6fb16.js +716 -0
  329. package/dist/cjs/spinner-configs-282fd50a.js +147 -0
  330. package/dist/cjs/status-tap-415acac6.js +42 -0
  331. package/dist/cjs/swipe-back-e37a1a5c.js +81 -0
  332. package/dist/cjs/theme-d1c573d2.js +48 -0
  333. package/dist/cjs/watch-options-f5f3e158.js +49 -0
  334. package/dist/collection/collection-manifest.json +7 -7
  335. package/dist/collection/components/accordion/accordion.ios.css +44 -0
  336. package/dist/collection/components/accordion/accordion.js +410 -410
  337. package/dist/collection/components/accordion/accordion.md.css +22 -0
  338. package/dist/collection/components/accordion/test/a11y/accordion.e2e.js +31 -31
  339. package/dist/collection/components/accordion/test/accordion.e2e.js +24 -24
  340. package/dist/collection/components/accordion/test/accordion.spec.js +195 -0
  341. package/dist/collection/components/accordion/test/basic/accordion.e2e.js +26 -26
  342. package/dist/collection/components/accordion/test/multiple/accordion.e2e.js +18 -18
  343. package/dist/collection/components/accordion/test/nested/accordion.e2e.js +16 -16
  344. package/dist/collection/components/accordion/test/standalone/accordion.e2e.js +6 -6
  345. package/dist/collection/components/accordion-group/accordion-group.ios.css +44 -0
  346. package/dist/collection/components/accordion-group/accordion-group.js +422 -412
  347. package/dist/collection/components/accordion-group/accordion-group.md.css +68 -2
  348. package/dist/collection/components/action-sheet/action-sheet.ios.css +62 -5
  349. package/dist/collection/components/action-sheet/action-sheet.js +739 -729
  350. package/dist/collection/components/action-sheet/action-sheet.md.css +62 -5
  351. package/dist/collection/components/action-sheet/animations/ios.enter.js +18 -18
  352. package/dist/collection/components/action-sheet/animations/ios.leave.js +12 -12
  353. package/dist/collection/components/action-sheet/animations/md.enter.js +18 -18
  354. package/dist/collection/components/action-sheet/animations/md.leave.js +12 -12
  355. package/dist/collection/components/action-sheet/test/a11y/action-sheet.e2e.js +59 -59
  356. package/dist/collection/components/action-sheet/test/action-sheet-id.spec.js +32 -0
  357. package/dist/collection/components/action-sheet/test/basic/action-sheet-rendering.e2e.js +33 -33
  358. package/dist/collection/components/action-sheet/test/basic/action-sheet.e2e.js +118 -59
  359. package/dist/collection/components/action-sheet/test/basic/action-sheet.spec.js +18 -0
  360. package/dist/collection/components/action-sheet/test/basic/fixture.js +23 -23
  361. package/dist/collection/components/action-sheet/test/is-open/action-sheet.e2e.js +25 -25
  362. package/dist/collection/components/action-sheet/test/translucent/action-sheet.e2e.js +10 -10
  363. package/dist/collection/components/action-sheet/test/trigger/action-sheet.e2e.js +21 -21
  364. package/dist/collection/components/alert/alert.ios.css +122 -5
  365. package/dist/collection/components/alert/alert.js +977 -967
  366. package/dist/collection/components/alert/alert.md.css +152 -7
  367. package/dist/collection/components/alert/animations/ios.enter.js +19 -19
  368. package/dist/collection/components/alert/animations/ios.leave.js +13 -13
  369. package/dist/collection/components/alert/animations/md.enter.js +19 -19
  370. package/dist/collection/components/alert/animations/md.leave.js +10 -10
  371. package/dist/collection/components/alert/test/a11y/alert.e2e.js +139 -91
  372. package/dist/collection/components/alert/test/alert-id.spec.js +32 -0
  373. package/dist/collection/components/alert/test/alert.spec.js +37 -0
  374. package/dist/collection/components/alert/test/basic/alert-tablet.e2e.js +40 -0
  375. package/dist/collection/components/alert/test/basic/alert.e2e.js +96 -96
  376. package/dist/collection/components/alert/test/is-open/alert.e2e.js +25 -25
  377. package/dist/collection/components/alert/test/standalone/alert.e2e.js +9 -9
  378. package/dist/collection/components/alert/test/trigger/alert.e2e.js +21 -21
  379. package/dist/collection/components/app/app.js +116 -116
  380. package/dist/collection/components/app/test/safe-area/app.e2e.js +24 -24
  381. package/dist/collection/components/avatar/avatar.ios.css +44 -0
  382. package/dist/collection/components/avatar/avatar.js +17 -17
  383. package/dist/collection/components/avatar/avatar.md.css +44 -0
  384. package/dist/collection/components/avatar/test/basic/avatar.e2e.js +12 -12
  385. package/dist/collection/components/back-button/back-button.ios.css +44 -0
  386. package/dist/collection/components/back-button/back-button.js +214 -214
  387. package/dist/collection/components/back-button/back-button.md.css +44 -0
  388. package/dist/collection/components/back-button/test/a11y/back-button.e2e.js +6 -6
  389. package/dist/collection/components/back-button/test/back-button.spec.js +86 -0
  390. package/dist/collection/components/back-button/test/basic/back-button.e2e.js +6 -6
  391. package/dist/collection/components/back-button/test/toolbar/back-button.e2e.js +6 -6
  392. package/dist/collection/components/backdrop/backdrop.ios.css +44 -0
  393. package/dist/collection/components/backdrop/backdrop.js +131 -131
  394. package/dist/collection/components/backdrop/backdrop.md.css +44 -0
  395. package/dist/collection/components/badge/badge.ios.css +44 -0
  396. package/dist/collection/components/badge/badge.js +49 -49
  397. package/dist/collection/components/badge/badge.md.css +44 -0
  398. package/dist/collection/components/badge/test/a11y/badge.e2e.js +6 -6
  399. package/dist/collection/components/badge/test/basic/badge.e2e.js +6 -6
  400. package/dist/collection/components/breadcrumb/breadcrumb.ios.css +44 -0
  401. package/dist/collection/components/breadcrumb/breadcrumb.js +395 -395
  402. package/dist/collection/components/breadcrumb/breadcrumb.md.css +44 -0
  403. package/dist/collection/components/breadcrumb/test/aria.spec.js +22 -0
  404. package/dist/collection/components/breadcrumbs/breadcrumbs.ios.css +22 -0
  405. package/dist/collection/components/breadcrumbs/breadcrumbs.js +247 -247
  406. package/dist/collection/components/breadcrumbs/breadcrumbs.md.css +22 -0
  407. package/dist/collection/components/breadcrumbs/test/a11y/breadcrumbs.e2e.js +12 -12
  408. package/dist/collection/components/breadcrumbs/test/basic/breadcrumbs.e2e.js +6 -6
  409. package/dist/collection/components/breadcrumbs/test/breadcrumbs.spec.js +58 -0
  410. package/dist/collection/components/breadcrumbs/test/collapsed/breadcrumbs.e2e.js +6 -6
  411. package/dist/collection/components/breadcrumbs/test/reactive/breadcrumbs.e2e.js +43 -43
  412. package/dist/collection/components/button/button.ios.css +66 -0
  413. package/dist/collection/components/button/button.js +541 -541
  414. package/dist/collection/components/button/button.md.css +44 -0
  415. package/dist/collection/components/button/test/a11y/button.e2e.js +21 -21
  416. package/dist/collection/components/button/test/basic/button.e2e.js +32 -32
  417. package/dist/collection/components/button/test/clear/button.e2e.js +6 -6
  418. package/dist/collection/components/button/test/expand/button.e2e.js +6 -6
  419. package/dist/collection/components/button/test/form-reference/button.e2e.js +84 -84
  420. package/dist/collection/components/button/test/form-reference/button.spec.js +26 -0
  421. package/dist/collection/components/button/test/icon/button.e2e.js +6 -6
  422. package/dist/collection/components/button/test/outline/button.e2e.js +6 -6
  423. package/dist/collection/components/button/test/round/button.e2e.js +6 -6
  424. package/dist/collection/components/button/test/size/button.e2e.js +22 -22
  425. package/dist/collection/components/button/test/strong/button.e2e.js +22 -22
  426. package/dist/collection/components/button/test/wrap/button.e2e.js +73 -73
  427. package/dist/collection/components/buttons/buttons.ios.css +66 -0
  428. package/dist/collection/components/buttons/buttons.js +46 -46
  429. package/dist/collection/components/buttons/buttons.md.css +66 -0
  430. package/dist/collection/components/buttons/test/a11y/buttons.e2e.js +21 -21
  431. package/dist/collection/components/card/card.ios.css +44 -0
  432. package/dist/collection/components/card/card.js +251 -251
  433. package/dist/collection/components/card/card.md.css +44 -0
  434. package/dist/collection/components/card/test/a11y/card.e2e.js +6 -6
  435. package/dist/collection/components/card/test/aria.spec.js +16 -0
  436. package/dist/collection/components/card/test/basic/card.e2e.js +38 -38
  437. package/dist/collection/components/card-content/card-content.ios.css +44 -0
  438. package/dist/collection/components/card-content/card-content.js +21 -21
  439. package/dist/collection/components/card-content/card-content.md.css +44 -0
  440. package/dist/collection/components/card-header/card-header.ios.css +44 -0
  441. package/dist/collection/components/card-header/card-header.js +70 -70
  442. package/dist/collection/components/card-header/card-header.md.css +44 -0
  443. package/dist/collection/components/card-header/test/basic/card-header.e2e.js +6 -6
  444. package/dist/collection/components/card-subtitle/card-subtitle.ios.css +44 -0
  445. package/dist/collection/components/card-subtitle/card-subtitle.js +50 -50
  446. package/dist/collection/components/card-subtitle/card-subtitle.md.css +44 -0
  447. package/dist/collection/components/card-title/card-title.ios.css +44 -0
  448. package/dist/collection/components/card-title/card-title.js +50 -50
  449. package/dist/collection/components/card-title/card-title.md.css +44 -0
  450. package/dist/collection/components/checkbox/checkbox.ios.css +69 -9
  451. package/dist/collection/components/checkbox/checkbox.js +418 -415
  452. package/dist/collection/components/checkbox/checkbox.md.css +69 -9
  453. package/dist/collection/components/checkbox/test/a11y/checkbox.e2e.js +14 -14
  454. package/dist/collection/components/checkbox/test/basic/checkbox.e2e.js +50 -50
  455. package/dist/collection/components/checkbox/test/checkbox.spec.js +34 -0
  456. package/dist/collection/components/checkbox/test/color/checkbox.e2e.js +11 -11
  457. package/dist/collection/components/checkbox/test/indeterminate/checkbox.e2e.js +6 -6
  458. package/dist/collection/components/checkbox/test/item/checkbox.e2e.js +29 -29
  459. package/dist/collection/components/checkbox/test/label/checkbox.e2e.js +75 -75
  460. package/dist/collection/components/checkbox/test/legacy/basic/checkbox.e2e.js +45 -45
  461. package/dist/collection/components/checkbox/test/legacy/indeterminate/checkbox.e2e.js +6 -6
  462. package/dist/collection/components/checkbox/test/states/checkbox.e2e.js +21 -21
  463. package/dist/collection/components/chip/chip.ios.css +22 -0
  464. package/dist/collection/components/chip/chip.js +90 -90
  465. package/dist/collection/components/chip/chip.md.css +22 -0
  466. package/dist/collection/components/chip/test/a11y/chip.e2e.js +19 -19
  467. package/dist/collection/components/chip/test/basic/chip.e2e.js +42 -42
  468. package/dist/collection/components/chip/test/states/chip.e2e.js +14 -14
  469. package/dist/collection/components/col/col.css +66 -0
  470. package/dist/collection/components/col/col.js +536 -536
  471. package/dist/collection/components/content/content.css +22 -0
  472. package/dist/collection/components/content/content.js +745 -745
  473. package/dist/collection/components/content/test/basic/content.e2e.js +6 -6
  474. package/dist/collection/components/content/test/fixed/content.e2e.js +6 -6
  475. package/dist/collection/components/content/test/fullscreen/content.e2e.js +6 -6
  476. package/dist/collection/components/content/test/standalone/content.e2e.js +5 -5
  477. package/dist/collection/components/datetime/datetime.ios.css +69 -4
  478. package/dist/collection/components/datetime/datetime.js +2246 -2208
  479. package/dist/collection/components/datetime/datetime.md.css +69 -8
  480. package/dist/collection/components/datetime/test/a11y/datetime.e2e.js +73 -7
  481. package/dist/collection/components/datetime/test/a11y/datetime.spec.js +43 -0
  482. package/dist/collection/components/datetime/test/basic/datetime.e2e.js +241 -241
  483. package/dist/collection/components/datetime/test/color/datetime.e2e.js +9 -9
  484. package/dist/collection/components/datetime/test/comparison.spec.js +43 -0
  485. package/dist/collection/components/datetime/test/custom/datetime.e2e.js +37 -37
  486. package/dist/collection/components/datetime/test/data.spec.js +456 -0
  487. package/dist/collection/components/datetime/test/datetime.e2e.js +29 -29
  488. package/dist/collection/components/datetime/test/disable-dates/datetime.e2e.js +119 -119
  489. package/dist/collection/components/datetime/test/disabled/datetime.e2e.js +68 -0
  490. package/dist/collection/components/datetime/test/disabled/datetime.spec.js +33 -0
  491. package/dist/collection/components/datetime/test/display/datetime.e2e.js +86 -86
  492. package/dist/collection/components/datetime/test/first-day-of-week/datetime.e2e.js +6 -6
  493. package/dist/collection/components/datetime/test/format.spec.js +124 -0
  494. package/dist/collection/components/datetime/test/helpers.spec.js +72 -0
  495. package/dist/collection/components/datetime/test/highlighted-dates/datetime.e2e.js +76 -76
  496. package/dist/collection/components/datetime/test/hour-cycle/datetime.e2e.js +21 -21
  497. package/dist/collection/components/datetime/test/locale/datetime.e2e.js +98 -98
  498. package/dist/collection/components/datetime/test/manipulation.spec.js +433 -0
  499. package/dist/collection/components/datetime/test/minmax/datetime.e2e.js +178 -178
  500. package/dist/collection/components/datetime/test/month-year-picker/datetime.e2e.js +17 -17
  501. package/dist/collection/components/datetime/test/multiple/datetime.e2e.js +170 -170
  502. package/dist/collection/components/datetime/test/parse.spec.js +222 -0
  503. package/dist/collection/components/datetime/test/position/datetime.e2e.js +14 -14
  504. package/dist/collection/components/datetime/test/prefer-wheel/datetime.e2e.js +263 -263
  505. package/dist/collection/components/datetime/test/presentation/datetime.e2e.js +137 -137
  506. package/dist/collection/components/datetime/test/readonly/datetime.e2e.js +113 -0
  507. package/dist/collection/components/datetime/test/set-value/datetime.e2e.js +40 -40
  508. package/dist/collection/components/datetime/test/state.spec.js +114 -0
  509. package/dist/collection/components/datetime/test/time-label/datetime.e2e.js +13 -13
  510. package/dist/collection/components/datetime/test/values/datetime.e2e.js +77 -77
  511. package/dist/collection/components/datetime/utils/comparison.js +22 -22
  512. package/dist/collection/components/datetime/utils/data.js +394 -394
  513. package/dist/collection/components/datetime/utils/format.js +143 -143
  514. package/dist/collection/components/datetime/utils/helpers.js +74 -74
  515. package/dist/collection/components/datetime/utils/manipulation.js +274 -274
  516. package/dist/collection/components/datetime/utils/parse.js +139 -139
  517. package/dist/collection/components/datetime/utils/state.js +123 -123
  518. package/dist/collection/components/datetime-button/datetime-button.css +22 -0
  519. package/dist/collection/components/datetime-button/datetime-button.js +399 -399
  520. package/dist/collection/components/datetime-button/test/a11y/datetime-button.e2e.js +11 -11
  521. package/dist/collection/components/datetime-button/test/basic/datetime-button.e2e.js +123 -123
  522. package/dist/collection/components/datetime-button/test/disabled/datetime-button.e2e.js +13 -13
  523. package/dist/collection/components/datetime-button/test/multiple/datetime-button.e2e.js +38 -38
  524. package/dist/collection/components/datetime-button/test/overlays/datetime-button.e2e.js +102 -102
  525. package/dist/collection/components/fab/fab.css +112 -36
  526. package/dist/collection/components/fab/fab.js +179 -179
  527. package/dist/collection/components/fab/test/basic/fab.e2e.js +50 -50
  528. package/dist/collection/components/fab/test/custom-size/fab.e2e.js +6 -6
  529. package/dist/collection/components/fab/test/safe-area/fab.e2e.js +63 -0
  530. package/dist/collection/components/fab/test/states/fab.e2e.js +6 -6
  531. package/dist/collection/components/fab/test/translucent/fab.e2e.js +17 -17
  532. package/dist/collection/components/fab-button/fab-button.ios.css +44 -0
  533. package/dist/collection/components/fab-button/fab-button.js +374 -374
  534. package/dist/collection/components/fab-button/fab-button.md.css +44 -0
  535. package/dist/collection/components/fab-button/test/a11y/fab-button.e2e.js +6 -6
  536. package/dist/collection/components/fab-list/fab-list.css +46 -2
  537. package/dist/collection/components/fab-list/fab-list.js +79 -79
  538. package/dist/collection/components/footer/footer.ios.css +44 -0
  539. package/dist/collection/components/footer/footer.js +135 -135
  540. package/dist/collection/components/footer/footer.md.css +44 -0
  541. package/dist/collection/components/footer/footer.utils.js +25 -25
  542. package/dist/collection/components/footer/test/basic/footer.e2e.js +18 -18
  543. package/dist/collection/components/footer/test/fade/footer.e2e.js +10 -10
  544. package/dist/collection/components/footer/test/scroll-target/footer.e2e.js +15 -15
  545. package/dist/collection/components/footer/test/with-tabs/footer.e2e.js +6 -6
  546. package/dist/collection/components/grid/grid.css +66 -0
  547. package/dist/collection/components/grid/grid.js +44 -44
  548. package/dist/collection/components/grid/test/basic/grid.e2e.js +6 -6
  549. package/dist/collection/components/grid/test/offsets/grid.e2e.js +6 -6
  550. package/dist/collection/components/grid/test/padding/grid.e2e.js +6 -6
  551. package/dist/collection/components/grid/test/sizes/grid.e2e.js +6 -6
  552. package/dist/collection/components/header/header.ios.css +48 -1
  553. package/dist/collection/components/header/header.js +181 -181
  554. package/dist/collection/components/header/header.md.css +44 -0
  555. package/dist/collection/components/header/header.utils.js +148 -148
  556. package/dist/collection/components/header/test/a11y/header.e2e.js +18 -18
  557. package/dist/collection/components/header/test/basic/header.e2e.js +23 -23
  558. package/dist/collection/components/header/test/condense/header.e2e.js +25 -25
  559. package/dist/collection/components/header/test/fade/header.e2e.js +10 -10
  560. package/dist/collection/components/header/test/scroll-target/header.e2e.js +15 -15
  561. package/dist/collection/components/icon/test/basic/icon.e2e.js +6 -6
  562. package/dist/collection/components/icon/test/dir/icon.e2e.js +11 -11
  563. package/dist/collection/components/img/img.js +177 -177
  564. package/dist/collection/components/img/test/basic/img.e2e.js +62 -62
  565. package/dist/collection/components/img/test/draggable/img.e2e.js +10 -10
  566. package/dist/collection/components/infinite-scroll/infinite-scroll.js +279 -271
  567. package/dist/collection/components/infinite-scroll/test/basic/infinite-scroll.e2e.js +11 -11
  568. package/dist/collection/components/infinite-scroll/test/scroll-target/infinite-scroll.e2e.js +11 -11
  569. package/dist/collection/components/infinite-scroll/test/small-dom-update/infinite-scroll.e2e.js +31 -0
  570. package/dist/collection/components/infinite-scroll/test/top/infinite-scroll.e2e.js +11 -11
  571. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.ios.css +44 -0
  572. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +86 -86
  573. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.md.css +44 -0
  574. package/dist/collection/components/infinite-scroll-content/test/infinite-scroll-content.spec.js +37 -0
  575. package/dist/collection/components/input/input.ios.css +91 -18
  576. package/dist/collection/components/input/input.js +1234 -1200
  577. package/dist/collection/components/input/input.md.css +167 -22
  578. package/dist/collection/components/input/input.utils.js +22 -22
  579. package/dist/collection/components/input/test/a11y/input.e2e.js +12 -12
  580. package/dist/collection/components/input/test/basic/input.e2e.js +63 -63
  581. package/dist/collection/components/input/test/bottom-content/input.e2e.js +89 -89
  582. package/dist/collection/components/input/test/card/input.e2e.js +6 -6
  583. package/dist/collection/components/input/test/clear-on-edit/input.e2e.js +25 -25
  584. package/dist/collection/components/input/test/color/input.e2e.js +88 -88
  585. package/dist/collection/components/input/test/fill/input.e2e.js +63 -63
  586. package/dist/collection/components/input/test/highlight/input.e2e.js +52 -52
  587. package/dist/collection/components/input/test/input.e2e.js +6 -6
  588. package/dist/collection/components/input/test/input.spec.js +85 -0
  589. package/dist/collection/components/input/test/item/input.e2e.js +11 -11
  590. package/dist/collection/components/input/test/item/input.spec.js +24 -0
  591. package/dist/collection/components/input/test/label-placement/input.e2e.js +104 -104
  592. package/dist/collection/components/input/test/legacy/a11y/input.e2e.js +15 -15
  593. package/dist/collection/components/input/test/legacy/basic/input.e2e.js +102 -102
  594. package/dist/collection/components/input/test/legacy/clear-on-edit/input.e2e.js +44 -44
  595. package/dist/collection/components/input/test/legacy/input-events.e2e.js +56 -56
  596. package/dist/collection/components/input/test/legacy/masking/input.e2e.js +15 -15
  597. package/dist/collection/components/input/test/legacy/spec/input.e2e.js +8 -8
  598. package/dist/collection/components/input/test/slot/input.e2e.js +51 -0
  599. package/dist/collection/components/input/test/states/input.e2e.js +11 -11
  600. package/dist/collection/components/item/item.ios.css +145 -15
  601. package/dist/collection/components/item/item.js +614 -614
  602. package/dist/collection/components/item/item.md.css +192 -18
  603. package/dist/collection/components/item/test/a11y/item.e2e.js +47 -47
  604. package/dist/collection/components/item/test/a11y/item.spec.js +48 -0
  605. package/dist/collection/components/item/test/alignment/item.e2e.js +6 -6
  606. package/dist/collection/components/item/test/basic/item.e2e.js +32 -6
  607. package/dist/collection/components/item/test/buttons/item.e2e.js +18 -18
  608. package/dist/collection/components/item/test/colors/item.e2e.js +6 -6
  609. package/dist/collection/components/item/test/counter/item.e2e.js +34 -34
  610. package/dist/collection/components/item/test/css-variables/item.e2e.js +6 -6
  611. package/dist/collection/components/item/test/disabled/item.e2e.js +6 -7
  612. package/dist/collection/components/item/test/dividers/item.e2e.js +6 -6
  613. package/dist/collection/components/item/test/groups/item.e2e.js +8 -8
  614. package/dist/collection/components/item/test/highlight/item.e2e.js +6 -6
  615. package/dist/collection/components/item/test/icons/item.e2e.js +6 -6
  616. package/dist/collection/components/item/test/images/item.e2e.js +6 -6
  617. package/dist/collection/components/item/test/inputs/item.e2e.js +139 -139
  618. package/dist/collection/components/item/test/legacy/alignment/item.e2e.js +6 -6
  619. package/dist/collection/components/item/test/legacy/disabled/item.e2e.js +6 -6
  620. package/dist/collection/components/item/test/legacy/fill/item.e2e.js +6 -6
  621. package/dist/collection/components/item/test/legacy/form/item.e2e.js +6 -6
  622. package/dist/collection/components/item/test/lines/item.e2e.js +6 -6
  623. package/dist/collection/components/item/test/media/item.e2e.js +6 -6
  624. package/dist/collection/components/item/test/reorder/item.e2e.js +8 -8
  625. package/dist/collection/components/item/test/slotted-inputs/item.e2e.js +6 -6
  626. package/dist/collection/components/item/test/states/item.e2e.js +6 -6
  627. package/dist/collection/components/item-divider/item-divider.ios.css +101 -8
  628. package/dist/collection/components/item-divider/item-divider.js +71 -71
  629. package/dist/collection/components/item-divider/item-divider.md.css +101 -8
  630. package/dist/collection/components/item-divider/test/a11y/item-divider.e2e.js +11 -11
  631. package/dist/collection/components/item-divider/test/basic/item-divider.e2e.js +38 -16
  632. package/dist/collection/components/item-divider/test/spec/item-divider.e2e.js +8 -8
  633. package/dist/collection/components/item-group/item-group.ios.css +44 -0
  634. package/dist/collection/components/item-group/item-group.js +22 -22
  635. package/dist/collection/components/item-group/item-group.md.css +44 -0
  636. package/dist/collection/components/item-option/item-option.ios.css +44 -10
  637. package/dist/collection/components/item-option/item-option.js +197 -197
  638. package/dist/collection/components/item-option/item-option.md.css +44 -10
  639. package/dist/collection/components/item-options/item-options.ios.css +66 -0
  640. package/dist/collection/components/item-options/item-options.js +110 -110
  641. package/dist/collection/components/item-options/item-options.md.css +66 -0
  642. package/dist/collection/components/item-sliding/item-sliding.css +22 -0
  643. package/dist/collection/components/item-sliding/item-sliding.js +538 -538
  644. package/dist/collection/components/item-sliding/test/a11y/item-sliding.e2e.js +5 -5
  645. package/dist/collection/components/item-sliding/test/async/item-sliding.e2e.js +25 -25
  646. package/dist/collection/components/item-sliding/test/basic/item-sliding.e2e.js +140 -63
  647. package/dist/collection/components/item-sliding/test/icons/item-sliding.e2e.js +20 -20
  648. package/dist/collection/components/item-sliding/test/scroll-target/item-sliding.e2e.js +18 -18
  649. package/dist/collection/components/item-sliding/test/test.utils.js +20 -20
  650. package/dist/collection/components/label/label.ios.css +81 -4
  651. package/dist/collection/components/label/label.js +174 -174
  652. package/dist/collection/components/label/label.md.css +80 -3
  653. package/dist/collection/components/label/test/a11y/label.e2e.js +21 -21
  654. package/dist/collection/components/label/test/basic/label.e2e.js +21 -21
  655. package/dist/collection/components/label/test/color/label.e2e.js +21 -21
  656. package/dist/collection/components/label/test/headings/label.e2e.js +5 -5
  657. package/dist/collection/components/list/list.ios.css +81 -1
  658. package/dist/collection/components/list/list.js +101 -101
  659. package/dist/collection/components/list/list.md.css +107 -3
  660. package/dist/collection/components/list/test/a11y/list.e2e.js +6 -6
  661. package/dist/collection/components/list/test/basic/list.e2e.js +6 -6
  662. package/dist/collection/components/list/test/inset/list.e2e.js +16 -16
  663. package/dist/collection/components/list/test/lines/list.e2e.js +158 -15
  664. package/dist/collection/components/list-header/list-header.ios.css +81 -2
  665. package/dist/collection/components/list-header/list-header.js +69 -69
  666. package/dist/collection/components/list-header/list-header.md.css +81 -2
  667. package/dist/collection/components/list-header/test/a11y/list-header.e2e.js +6 -6
  668. package/dist/collection/components/list-header/test/basic/list-header.e2e.js +34 -6
  669. package/dist/collection/components/loading/animations/ios.enter.js +19 -19
  670. package/dist/collection/components/loading/animations/ios.leave.js +13 -13
  671. package/dist/collection/components/loading/animations/md.enter.js +19 -19
  672. package/dist/collection/components/loading/animations/md.leave.js +13 -13
  673. package/dist/collection/components/loading/loading.ios.css +44 -0
  674. package/dist/collection/components/loading/loading.js +730 -720
  675. package/dist/collection/components/loading/loading.md.css +44 -0
  676. package/dist/collection/components/loading/test/a11y/loading.e2e.js +26 -26
  677. package/dist/collection/components/loading/test/basic/loading.e2e.js +60 -60
  678. package/dist/collection/components/loading/test/basic/loading.spec.js +16 -0
  679. package/dist/collection/components/loading/test/is-open/loading.e2e.js +17 -17
  680. package/dist/collection/components/loading/test/loading-id.spec.js +32 -0
  681. package/dist/collection/components/loading/test/loading.spec.js +37 -0
  682. package/dist/collection/components/loading/test/standalone/loading.e2e.js +13 -13
  683. package/dist/collection/components/loading/test/trigger/loading.e2e.js +21 -21
  684. package/dist/collection/components/menu/menu.ios.css +48 -4
  685. package/dist/collection/components/menu/menu.js +956 -944
  686. package/dist/collection/components/menu/menu.md.css +48 -4
  687. package/dist/collection/components/menu/test/a11y/menu.e2e.js +13 -13
  688. package/dist/collection/components/menu/test/basic/menu.e2e.js +102 -102
  689. package/dist/collection/components/menu/test/disable/menu.e2e.js +44 -44
  690. package/dist/collection/components/menu/test/focus-trap/menu.e2e.js +61 -61
  691. package/dist/collection/components/menu/test/multiple/menu.e2e.js +49 -49
  692. package/dist/collection/components/menu/test/safe-area/menu.e2e.js +54 -54
  693. package/dist/collection/components/menu-button/menu-button.ios.css +44 -0
  694. package/dist/collection/components/menu-button/menu-button.js +173 -173
  695. package/dist/collection/components/menu-button/menu-button.md.css +44 -0
  696. package/dist/collection/components/menu-button/test/a11y/menu-button.e2e.js +12 -12
  697. package/dist/collection/components/menu-button/test/async/menu-button.e2e.js +12 -12
  698. package/dist/collection/components/menu-button/test/basic/menu-button.e2e.js +6 -6
  699. package/dist/collection/components/menu-toggle/menu-toggle-util.js +2 -2
  700. package/dist/collection/components/menu-toggle/menu-toggle.js +93 -93
  701. package/dist/collection/components/menu-toggle/test/basic/menu-toggle.e2e.js +33 -33
  702. package/dist/collection/components/modal/animations/ios.enter.js +81 -81
  703. package/dist/collection/components/modal/animations/ios.leave.js +74 -74
  704. package/dist/collection/components/modal/animations/md.enter.js +21 -21
  705. package/dist/collection/components/modal/animations/md.leave.js +15 -15
  706. package/dist/collection/components/modal/animations/sheet.js +43 -43
  707. package/dist/collection/components/modal/gestures/sheet.js +289 -289
  708. package/dist/collection/components/modal/gestures/swipe-to-close.js +248 -247
  709. package/dist/collection/components/modal/gestures/utils.js +39 -39
  710. package/dist/collection/components/modal/modal.ios.css +46 -2
  711. package/dist/collection/components/modal/modal.js +1290 -1280
  712. package/dist/collection/components/modal/modal.md.css +44 -0
  713. package/dist/collection/components/modal/test/a11y/modal.e2e.js +12 -12
  714. package/dist/collection/components/modal/test/a11y/modal.spec.js +22 -0
  715. package/dist/collection/components/modal/test/basic/modal.e2e.js +110 -110
  716. package/dist/collection/components/modal/test/basic/modal.spec.js +16 -0
  717. package/dist/collection/components/modal/test/can-dismiss/modal-card.e2e.js +44 -44
  718. package/dist/collection/components/modal/test/can-dismiss/modal-sheet.e2e.js +62 -62
  719. package/dist/collection/components/modal/test/can-dismiss/modal.e2e.js +16 -16
  720. package/dist/collection/components/modal/test/can-dismiss/modal.spec.js +191 -0
  721. package/dist/collection/components/modal/test/card/modal-card.e2e.js +69 -69
  722. package/dist/collection/components/modal/test/card/modal-tablet.e2e.js +67 -67
  723. package/dist/collection/components/modal/test/card-nav/modal.e2e.js +26 -26
  724. package/dist/collection/components/modal/test/card-refresher/modal.e2e.js +14 -14
  725. package/dist/collection/components/modal/test/card-scroll-target/modal.e2e.js +34 -34
  726. package/dist/collection/components/modal/test/custom/modal.e2e.js +16 -16
  727. package/dist/collection/components/modal/test/custom-dialog/modal.e2e.js +12 -12
  728. package/dist/collection/components/modal/test/dark-mode/model.e2e.js +12 -12
  729. package/dist/collection/components/modal/test/fixtures.js +21 -21
  730. package/dist/collection/components/modal/test/inline/modal.e2e.js +34 -34
  731. package/dist/collection/components/modal/test/is-open/modal.e2e.js +17 -17
  732. package/dist/collection/components/modal/test/modal-id.spec.js +32 -0
  733. package/dist/collection/components/modal/test/sheet/modal.e2e.js +178 -178
  734. package/dist/collection/components/modal/test/standalone/modal.e2e.js +12 -12
  735. package/dist/collection/components/modal/test/trigger/modal.e2e.js +23 -23
  736. package/dist/collection/components/modal/utils.js +55 -55
  737. package/dist/collection/components/modal/utils.spec.js +7 -7
  738. package/dist/collection/components/nav/nav.css +22 -0
  739. package/dist/collection/components/nav/nav.js +1748 -1748
  740. package/dist/collection/components/nav/test/basic/nav.e2e.js +58 -58
  741. package/dist/collection/components/nav/test/modal-navigation/nav.e2e.js +52 -52
  742. package/dist/collection/components/nav/test/nav-controller.spec.js +749 -0
  743. package/dist/collection/components/nav/test/nested/nav.e2e.js +54 -54
  744. package/dist/collection/components/nav/test/routing/nav.e2e.js +75 -75
  745. package/dist/collection/components/nav/view-controller.js +52 -52
  746. package/dist/collection/components/nav-link/nav-link-utils.js +16 -16
  747. package/dist/collection/components/nav-link/nav-link.js +106 -106
  748. package/dist/collection/components/note/note.ios.css +44 -0
  749. package/dist/collection/components/note/note.js +49 -49
  750. package/dist/collection/components/note/note.md.css +44 -0
  751. package/dist/collection/components/note/test/a11y/note.e2e.js +59 -16
  752. package/dist/collection/components/note/test/basic/note.e2e.js +33 -33
  753. package/dist/collection/components/picker/animations/ios.enter.js +18 -18
  754. package/dist/collection/components/picker/animations/ios.leave.js +14 -14
  755. package/dist/collection/components/picker/picker.ios.css +45 -1
  756. package/dist/collection/components/picker/picker.js +782 -772
  757. package/dist/collection/components/picker/picker.md.css +45 -1
  758. package/dist/collection/components/picker/test/basic/picker.e2e.js +17 -17
  759. package/dist/collection/components/picker/test/is-open/picker.e2e.js +17 -17
  760. package/dist/collection/components/picker/test/picker-id.spec.js +32 -0
  761. package/dist/collection/components/picker/test/trigger/picker.e2e.js +21 -21
  762. package/dist/collection/components/picker-column/picker-column.ios.css +44 -0
  763. package/dist/collection/components/picker-column/picker-column.js +377 -377
  764. package/dist/collection/components/picker-column/picker-column.md.css +44 -0
  765. package/dist/collection/components/picker-column/test/picker-column-aria.spec.js +35 -0
  766. package/dist/collection/components/picker-column/test/picker-column-dynamic.spec.js +29 -0
  767. package/dist/collection/components/picker-column/test/picker-column.spec.js +17 -0
  768. package/dist/collection/components/picker-column/test/standalone/picker-column.e2e.js +27 -27
  769. package/dist/collection/components/picker-column/test/test.utils.js +29 -29
  770. package/dist/collection/components/picker-column-internal/picker-column-internal.ios.css +33 -3
  771. package/dist/collection/components/picker-column-internal/picker-column-internal.js +523 -501
  772. package/dist/collection/components/picker-column-internal/picker-column-internal.md.css +55 -3
  773. package/dist/collection/components/picker-column-internal/test/basic/picker-column-internal.e2e.js +53 -53
  774. package/dist/collection/components/picker-column-internal/test/disabled/picker-column-internal.e2e.js +66 -37
  775. package/dist/collection/components/picker-internal/picker-internal.ios.css +46 -2
  776. package/dist/collection/components/picker-internal/picker-internal.js +517 -517
  777. package/dist/collection/components/picker-internal/picker-internal.md.css +46 -2
  778. package/dist/collection/components/picker-internal/test/a11y/picker-internal.e2e.js +6 -6
  779. package/dist/collection/components/picker-internal/test/basic/picker-internal.e2e.js +76 -71
  780. package/dist/collection/components/picker-internal/test/keyboard-entry/picker-internal.e2e.js +39 -39
  781. package/dist/collection/components/popover/animations/ios.enter.js +79 -79
  782. package/dist/collection/components/popover/animations/ios.leave.js +28 -28
  783. package/dist/collection/components/popover/animations/md.enter.js +58 -58
  784. package/dist/collection/components/popover/animations/md.leave.js +19 -19
  785. package/dist/collection/components/popover/popover.ios.css +48 -4
  786. package/dist/collection/components/popover/popover.js +1189 -1179
  787. package/dist/collection/components/popover/popover.md.css +46 -2
  788. package/dist/collection/components/popover/test/adjustment/popover.e2e.js +22 -22
  789. package/dist/collection/components/popover/test/arrow/popover.e2e.js +15 -15
  790. package/dist/collection/components/popover/test/async/popover.e2e.js +29 -29
  791. package/dist/collection/components/popover/test/basic/popover.e2e.js +108 -108
  792. package/dist/collection/components/popover/test/basic/popover.spec.js +16 -0
  793. package/dist/collection/components/popover/test/dismiss-on-select/popover.e2e.js +26 -26
  794. package/dist/collection/components/popover/test/fixture.js +16 -16
  795. package/dist/collection/components/popover/test/inline/popover.e2e.js +18 -18
  796. package/dist/collection/components/popover/test/is-open/popover.e2e.js +5 -5
  797. package/dist/collection/components/popover/test/nested/popover.e2e.js +81 -81
  798. package/dist/collection/components/popover/test/popover-id.spec.js +32 -0
  799. package/dist/collection/components/popover/test/position/popover.e2e.js +18 -18
  800. package/dist/collection/components/popover/test/reference/popover.e2e.js +14 -14
  801. package/dist/collection/components/popover/test/size/popover.e2e.js +29 -29
  802. package/dist/collection/components/popover/test/standalone/popover.e2e.js +7 -7
  803. package/dist/collection/components/popover/test/test.utils.js +23 -23
  804. package/dist/collection/components/popover/test/trigger/popover.e2e.js +35 -35
  805. package/dist/collection/components/popover/test/util.spec.js +53 -0
  806. package/dist/collection/components/popover/utils.js +606 -606
  807. package/dist/collection/components/progress-bar/progress-bar.ios.css +22 -0
  808. package/dist/collection/components/progress-bar/progress-bar.js +145 -145
  809. package/dist/collection/components/progress-bar/progress-bar.md.css +22 -0
  810. package/dist/collection/components/progress-bar/test/basic/progress-bar.e2e.js +6 -6
  811. package/dist/collection/components/progress-bar/test/buffer/progress-bar.e2e.js +10 -10
  812. package/dist/collection/components/progress-bar/test/determinate/progress-bar.e2e.js +10 -10
  813. package/dist/collection/components/radio/radio.ios.css +70 -10
  814. package/dist/collection/components/radio/radio.js +454 -447
  815. package/dist/collection/components/radio/radio.md.css +70 -10
  816. package/dist/collection/components/radio/test/a11y/radio.e2e.js +40 -40
  817. package/dist/collection/components/radio/test/color/radio.e2e.js +11 -11
  818. package/dist/collection/components/radio/test/item/radio.e2e.js +37 -37
  819. package/dist/collection/components/radio/test/label-placement/radio.e2e.js +70 -70
  820. package/dist/collection/components/radio/test/legacy/a11y/radio.e2e.js +29 -29
  821. package/dist/collection/components/radio/test/legacy/basic/radio.e2e.js +43 -43
  822. package/dist/collection/components/radio/test/radio.spec.js +60 -0
  823. package/dist/collection/components/radio/test/states/radio.e2e.js +21 -21
  824. package/dist/collection/components/radio-group/radio-group.js +280 -247
  825. package/dist/collection/components/radio-group/test/basic/radio-group.e2e.js +35 -35
  826. package/dist/collection/components/radio-group/test/fixtures.js +22 -22
  827. package/dist/collection/components/radio-group/test/form/radio-group.e2e.js +39 -39
  828. package/dist/collection/components/radio-group/test/legacy/basic/radio-group.e2e.js +59 -59
  829. package/dist/collection/components/radio-group/test/legacy/form/radio-group.e2e.js +22 -22
  830. package/dist/collection/components/radio-group/test/legacy/search/radio-group.e2e.js +27 -27
  831. package/dist/collection/components/radio-group/test/radio-group-events.e2e.js +42 -42
  832. package/dist/collection/components/radio-group/test/radio-group.spec.js +69 -0
  833. package/dist/collection/components/radio-group/test/search/radio-group.e2e.js +23 -23
  834. package/dist/collection/components/range/range.ios.css +45 -7
  835. package/dist/collection/components/range/range.js +1001 -998
  836. package/dist/collection/components/range/range.md.css +45 -7
  837. package/dist/collection/components/range/test/a11y/range.e2e.js +46 -46
  838. package/dist/collection/components/range/test/active-bar-start/range.e2e.js +6 -6
  839. package/dist/collection/components/range/test/basic/range.e2e.js +23 -23
  840. package/dist/collection/components/range/test/color/range.e2e.js +6 -6
  841. package/dist/collection/components/range/test/custom/range.e2e.js +6 -6
  842. package/dist/collection/components/range/test/item/range.e2e.js +28 -28
  843. package/dist/collection/components/range/test/label/range.e2e.js +99 -99
  844. package/dist/collection/components/range/test/label/range.spec.js +23 -0
  845. package/dist/collection/components/range/test/legacy/a11y/range.e2e.js +25 -25
  846. package/dist/collection/components/range/test/legacy/active-bar-start/range.e2e.js +6 -6
  847. package/dist/collection/components/range/test/legacy/basic/range.e2e.js +61 -61
  848. package/dist/collection/components/range/test/legacy/range-events.e2e.js +80 -80
  849. package/dist/collection/components/range/test/legacy/scroll-target/range.e2e.js +23 -23
  850. package/dist/collection/components/range/test/range-events.e2e.js +135 -135
  851. package/dist/collection/components/range/test/range.spec.js +221 -0
  852. package/dist/collection/components/range/test/scroll-target/range.e2e.js +23 -23
  853. package/dist/collection/components/range/test/states/range.e2e.js +21 -21
  854. package/dist/collection/components/refresher/refresher.ios.css +44 -0
  855. package/dist/collection/components/refresher/refresher.js +806 -806
  856. package/dist/collection/components/refresher/refresher.md.css +44 -0
  857. package/dist/collection/components/refresher/refresher.utils.js +148 -141
  858. package/dist/collection/components/refresher/test/basic/refresher.e2e.js +25 -25
  859. package/dist/collection/components/refresher/test/scroll-target/refresher.e2e.js +25 -25
  860. package/dist/collection/components/refresher/test/test.utils.js +5 -5
  861. package/dist/collection/components/refresher-content/refresher-content.js +131 -131
  862. package/dist/collection/components/refresher-content/test/refresher-content.spec.js +46 -0
  863. package/dist/collection/components/reorder/reorder.ios.css +23 -34
  864. package/dist/collection/components/reorder/reorder.js +37 -37
  865. package/dist/collection/components/reorder/reorder.md.css +23 -34
  866. package/dist/collection/components/reorder-group/reorder-group.css +22 -0
  867. package/dist/collection/components/reorder-group/reorder-group.js +327 -327
  868. package/dist/collection/components/reorder-group/test/a11y/reorder-group.e2e.js +6 -6
  869. package/dist/collection/components/reorder-group/test/basic/reorder-group.e2e.js +11 -11
  870. package/dist/collection/components/reorder-group/test/interactive/reorder-group.e2e.js +21 -21
  871. package/dist/collection/components/reorder-group/test/nested/reorder-group.e2e.js +21 -21
  872. package/dist/collection/components/reorder-group/test/scroll-target/reorder-group.e2e.js +21 -21
  873. package/dist/collection/components/ripple-effect/ripple-effect.css +22 -0
  874. package/dist/collection/components/ripple-effect/ripple-effect.js +135 -135
  875. package/dist/collection/components/ripple-effect/test/basic/ripple-effect.e2e.js +48 -48
  876. package/dist/collection/components/route/route.js +151 -151
  877. package/dist/collection/components/route-redirect/route-redirect.js +76 -76
  878. package/dist/collection/components/router/router.js +472 -472
  879. package/dist/collection/components/router/test/basic/router.e2e.js +55 -55
  880. package/dist/collection/components/router/test/guards/href/router.e2e.js +51 -51
  881. package/dist/collection/components/router/test/guards/link/router.e2e.js +51 -51
  882. package/dist/collection/components/router/test/guards/push/router.e2e.js +51 -51
  883. package/dist/collection/components/router/test/guards/router.e2e.js +5 -5
  884. package/dist/collection/components/router/test/guards/test.utils.js +2 -2
  885. package/dist/collection/components/router/test/matching.spec.js +250 -0
  886. package/dist/collection/components/router/test/parser.spec.js +133 -0
  887. package/dist/collection/components/router/test/path.spec.js +218 -0
  888. package/dist/collection/components/router/test/router.spec.js +55 -0
  889. package/dist/collection/components/router/utils/debug.js +14 -14
  890. package/dist/collection/components/router/utils/dom.js +56 -56
  891. package/dist/collection/components/router/utils/matching.js +150 -150
  892. package/dist/collection/components/router/utils/parser.js +52 -52
  893. package/dist/collection/components/router/utils/path.js +66 -66
  894. package/dist/collection/components/router-link/router-link.css +22 -0
  895. package/dist/collection/components/router-link/router-link.js +157 -157
  896. package/dist/collection/components/router-outlet/router-outlet.css +22 -0
  897. package/dist/collection/components/router-outlet/router-outlet.js +459 -459
  898. package/dist/collection/components/router-outlet/test/basic/router-outlet.e2e.js +31 -31
  899. package/dist/collection/components/row/row.css +66 -0
  900. package/dist/collection/components/row/row.js +15 -15
  901. package/dist/collection/components/searchbar/searchbar.ios.css +44 -0
  902. package/dist/collection/components/searchbar/searchbar.js +893 -884
  903. package/dist/collection/components/searchbar/searchbar.md.css +56 -6
  904. package/dist/collection/components/searchbar/test/a11y/searchbar.e2e.js +11 -11
  905. package/dist/collection/components/searchbar/test/basic/searchbar.e2e.js +116 -91
  906. package/dist/collection/components/searchbar/test/events/searchbar.e2e.js +55 -55
  907. package/dist/collection/components/searchbar/test/searchbar.spec.js +15 -0
  908. package/dist/collection/components/segment/segment.ios.css +66 -0
  909. package/dist/collection/components/segment/segment.js +633 -607
  910. package/dist/collection/components/segment/segment.md.css +66 -0
  911. package/dist/collection/components/segment/test/a11y/segment.e2e.js +37 -37
  912. package/dist/collection/components/segment/test/basic/segment.e2e.js +22 -22
  913. package/dist/collection/components/segment/test/custom/segment.e2e.js +6 -6
  914. package/dist/collection/components/segment/test/icon/segment.e2e.js +6 -6
  915. package/dist/collection/components/segment/test/modes/segment.e2e.js +15 -15
  916. package/dist/collection/components/segment/test/scrollable/segment.e2e.js +12 -12
  917. package/dist/collection/components/segment/test/segment-events.e2e.js +97 -97
  918. package/dist/collection/components/segment/test/segment.spec.js +37 -0
  919. package/dist/collection/components/segment/test/toolbar/segment.e2e.js +21 -21
  920. package/dist/collection/components/segment/test/wrap/segment.e2e.js +21 -21
  921. package/dist/collection/components/segment-button/segment-button.ios.css +44 -0
  922. package/dist/collection/components/segment-button/segment-button.js +217 -217
  923. package/dist/collection/components/segment-button/segment-button.md.css +44 -0
  924. package/dist/collection/components/select/select.ios.css +138 -22
  925. package/dist/collection/components/select/select.js +1201 -1184
  926. package/dist/collection/components/select/select.md.css +189 -26
  927. package/dist/collection/components/select/test/a11y/select.e2e.js +14 -14
  928. package/dist/collection/components/select/test/async/select.e2e.js +14 -14
  929. package/dist/collection/components/select/test/basic/select.e2e.js +140 -140
  930. package/dist/collection/components/select/test/card/select.e2e.js +6 -6
  931. package/dist/collection/components/select/test/color/select.e2e.js +22 -22
  932. package/dist/collection/components/select/test/compare-with/select.e2e.js +33 -33
  933. package/dist/collection/components/select/test/custom/select.e2e.js +19 -19
  934. package/dist/collection/components/select/test/disabled/select.e2e.js +17 -17
  935. package/dist/collection/components/select/test/fill/select.e2e.js +63 -63
  936. package/dist/collection/components/select/test/highlight/select.e2e.js +74 -74
  937. package/dist/collection/components/select/test/item/select.e2e.js +26 -11
  938. package/dist/collection/components/select/test/label/select.e2e.js +141 -141
  939. package/dist/collection/components/select/test/legacy/async/select.e2e.js +8 -8
  940. package/dist/collection/components/select/test/legacy/basic/select.e2e.js +108 -108
  941. package/dist/collection/components/select/test/legacy/compare-with/select.e2e.js +33 -33
  942. package/dist/collection/components/select/test/legacy/custom/custom.e2e.js +5 -5
  943. package/dist/collection/components/select/test/legacy/single-value/select.e2e.js +8 -8
  944. package/dist/collection/components/select/test/legacy/spec/select.e2e.js +6 -6
  945. package/dist/collection/components/select/test/legacy/standalone/select.e2e.js +11 -11
  946. package/dist/collection/components/select/test/legacy/wrapping/select.e2e.js +17 -17
  947. package/dist/collection/components/select/test/popover-size/select.e2e.js +63 -63
  948. package/dist/collection/components/select/test/select.spec.js +59 -0
  949. package/dist/collection/components/select/test/slot/select.e2e.js +67 -0
  950. package/dist/collection/components/select/test/states/select.e2e.js +21 -21
  951. package/dist/collection/components/select/test/toggle-icon/select.e2e.js +14 -14
  952. package/dist/collection/components/select/test/wrapping/select.e2e.js +16 -16
  953. package/dist/collection/components/select-option/select-option.js +60 -60
  954. package/dist/collection/components/select-popover/select-popover.ios.css +66 -0
  955. package/dist/collection/components/select-popover/select-popover.js +197 -197
  956. package/dist/collection/components/select-popover/select-popover.md.css +66 -0
  957. package/dist/collection/components/select-popover/test/basic/select-popover.e2e.js +52 -52
  958. package/dist/collection/components/select-popover/test/fixtures.js +33 -33
  959. package/dist/collection/components/skeleton-text/skeleton-text.css +22 -0
  960. package/dist/collection/components/skeleton-text/skeleton-text.js +87 -48
  961. package/dist/collection/components/skeleton-text/test/basic/skeleton-text.e2e.js +6 -6
  962. package/dist/collection/components/skeleton-text/test/custom/skeleton-text.e2e.js +6 -6
  963. package/dist/collection/components/slides/IonicSlides.js +95 -95
  964. package/dist/collection/components/spinner/spinner-configs.js +121 -121
  965. package/dist/collection/components/spinner/spinner.css +22 -0
  966. package/dist/collection/components/spinner/spinner.js +137 -137
  967. package/dist/collection/components/spinner/test/basic/spinner.e2e.js +10 -10
  968. package/dist/collection/components/spinner/test/color/spinner.e2e.js +10 -10
  969. package/dist/collection/components/spinner/test/resize/spinner.e2e.js +8 -8
  970. package/dist/collection/components/split-pane/split-pane.ios.css +66 -0
  971. package/dist/collection/components/split-pane/split-pane.js +225 -225
  972. package/dist/collection/components/split-pane/split-pane.md.css +66 -0
  973. package/dist/collection/components/split-pane/test/basic/split-pane.e2e.js +18 -18
  974. package/dist/collection/components/split-pane/test/multiple/split-pane.e2e.js +31 -0
  975. package/dist/collection/components/tab/tab.js +170 -170
  976. package/dist/collection/components/tab-bar/tab-bar.ios.css +70 -4
  977. package/dist/collection/components/tab-bar/tab-bar.js +177 -177
  978. package/dist/collection/components/tab-bar/tab-bar.md.css +70 -4
  979. package/dist/collection/components/tab-bar/test/basic/tab-bar.e2e.js +43 -0
  980. package/dist/collection/components/tab-bar/test/custom/tab-bar.e2e.js +6 -6
  981. package/dist/collection/components/tab-bar/test/translucent/tab-bar.e2e.js +14 -14
  982. package/dist/collection/components/tab-button/tab-button.ios.css +47 -3
  983. package/dist/collection/components/tab-button/tab-button.js +267 -267
  984. package/dist/collection/components/tab-button/tab-button.md.css +47 -3
  985. package/dist/collection/components/tab-button/test/a11y/tab-button.e2e.js +6 -6
  986. package/dist/collection/components/tab-button/test/basic/tab-button.e2e.js +16 -16
  987. package/dist/collection/components/tab-button/test/layout/tab-button.e2e.js +26 -26
  988. package/dist/collection/components/tab-button/test/states/tab-button.e2e.js +26 -26
  989. package/dist/collection/components/tabs/tabs.css +22 -0
  990. package/dist/collection/components/tabs/tabs.js +344 -344
  991. package/dist/collection/components/tabs/test/basic/tabs.e2e.js +24 -24
  992. package/dist/collection/components/tabs/test/placements/tabs.e2e.js +17 -17
  993. package/dist/collection/components/text/test/basic/text.e2e.js +11 -11
  994. package/dist/collection/components/text/text.css +22 -0
  995. package/dist/collection/components/text/text.js +47 -47
  996. package/dist/collection/components/textarea/test/a11y/textarea.e2e.js +12 -12
  997. package/dist/collection/components/textarea/test/autogrow/textarea.e2e.js +31 -31
  998. package/dist/collection/components/textarea/test/bottom-content/textarea.e2e.js +82 -82
  999. package/dist/collection/components/textarea/test/card/textarea.e2e.js +6 -6
  1000. package/dist/collection/components/textarea/test/clear-on-edit/textarea.e2e.js +17 -17
  1001. package/dist/collection/components/textarea/test/color/textarea.e2e.js +88 -88
  1002. package/dist/collection/components/textarea/test/cols/textarea.e2e.js +11 -11
  1003. package/dist/collection/components/textarea/test/fill/textarea.e2e.js +63 -63
  1004. package/dist/collection/components/textarea/test/highlight/textarea.e2e.js +52 -52
  1005. package/dist/collection/components/textarea/test/item/textarea.e2e.js +11 -11
  1006. package/dist/collection/components/textarea/test/label-placement/textarea.e2e.js +150 -150
  1007. package/dist/collection/components/textarea/test/legacy/a11y/textarea.e2e.js +15 -15
  1008. package/dist/collection/components/textarea/test/legacy/autogrow/textarea.e2e.js +31 -31
  1009. package/dist/collection/components/textarea/test/legacy/basic/textarea.e2e.js +30 -30
  1010. package/dist/collection/components/textarea/test/legacy/clear-on-edit/textarea.e2e.js +17 -17
  1011. package/dist/collection/components/textarea/test/slot/textarea.e2e.js +51 -0
  1012. package/dist/collection/components/textarea/test/states/textarea.e2e.js +11 -11
  1013. package/dist/collection/components/textarea/test/textarea-events.e2e.js +57 -57
  1014. package/dist/collection/components/textarea/test/textarea.spec.js +59 -0
  1015. package/dist/collection/components/textarea/textarea.ios.css +144 -24
  1016. package/dist/collection/components/textarea/textarea.js +1050 -1016
  1017. package/dist/collection/components/textarea/textarea.md.css +205 -34
  1018. package/dist/collection/components/thumbnail/test/basic/thumbnail.e2e.js +28 -28
  1019. package/dist/collection/components/thumbnail/thumbnail.css +22 -0
  1020. package/dist/collection/components/thumbnail/thumbnail.js +15 -15
  1021. package/dist/collection/components/title/test/a11y/title.e2e.js +17 -17
  1022. package/dist/collection/components/title/test/basic/title.e2e.js +13 -13
  1023. package/dist/collection/components/title/title.ios.css +24 -2
  1024. package/dist/collection/components/title/title.js +119 -119
  1025. package/dist/collection/components/title/title.md.css +22 -0
  1026. package/dist/collection/components/toast/animations/ios.enter.js +21 -20
  1027. package/dist/collection/components/toast/animations/ios.leave.js +18 -18
  1028. package/dist/collection/components/toast/animations/md.enter.js +23 -22
  1029. package/dist/collection/components/toast/animations/md.leave.js +6 -6
  1030. package/dist/collection/components/toast/animations/utils.js +62 -56
  1031. package/dist/collection/components/toast/gestures/swipe-to-dismiss.js +267 -0
  1032. package/dist/collection/components/toast/test/a11y/toast.e2e.js +92 -92
  1033. package/dist/collection/components/toast/test/basic/toast.e2e.js +101 -101
  1034. package/dist/collection/components/toast/test/is-open/toast.e2e.js +17 -17
  1035. package/dist/collection/components/toast/test/layout/toast.e2e.js +9 -9
  1036. package/dist/collection/components/toast/test/position-anchor/toast.e2e.js +37 -37
  1037. package/dist/collection/components/toast/test/standalone/toast.e2e.js +10 -10
  1038. package/dist/collection/components/toast/test/swipe-gesture/toast.e2e.js +84 -0
  1039. package/dist/collection/components/toast/test/toast-config.spec.js +25 -0
  1040. package/dist/collection/components/toast/test/toast-id.spec.js +32 -0
  1041. package/dist/collection/components/toast/test/toast.spec.js +200 -0
  1042. package/dist/collection/components/toast/test/trigger/toast.e2e.js +21 -21
  1043. package/dist/collection/components/toast/toast.ios.css +55 -11
  1044. package/dist/collection/components/toast/toast.js +1065 -952
  1045. package/dist/collection/components/toast/toast.md.css +55 -1
  1046. package/dist/collection/components/toggle/test/a11y/toggle.e2e.js +6 -6
  1047. package/dist/collection/components/toggle/test/color/toggle.e2e.js +11 -11
  1048. package/dist/collection/components/toggle/test/enable-on-off-labels/toggle.e2e.js +27 -27
  1049. package/dist/collection/components/toggle/test/item/toggle.e2e.js +52 -52
  1050. package/dist/collection/components/toggle/test/label/toggle.e2e.js +65 -65
  1051. package/dist/collection/components/toggle/test/legacy/basic/toggle.e2e.js +69 -69
  1052. package/dist/collection/components/toggle/test/legacy/enable-on-off-labels/toggle.e2e.js +23 -23
  1053. package/dist/collection/components/toggle/test/legacy/sizes/toggle.e2e.js +6 -6
  1054. package/dist/collection/components/toggle/test/sizes/toggle.e2e.js +6 -6
  1055. package/dist/collection/components/toggle/test/states/toggle.e2e.js +16 -16
  1056. package/dist/collection/components/toggle/test/toggle.spec.js +67 -0
  1057. package/dist/collection/components/toggle/toggle.ios.css +69 -9
  1058. package/dist/collection/components/toggle/toggle.js +487 -484
  1059. package/dist/collection/components/toggle/toggle.md.css +69 -9
  1060. package/dist/collection/components/toolbar/test/basic/toolbar.e2e.js +7 -7
  1061. package/dist/collection/components/toolbar/test/colors/toolbar.e2e.js +6 -6
  1062. package/dist/collection/components/toolbar/toolbar.ios.css +44 -0
  1063. package/dist/collection/components/toolbar/toolbar.js +100 -100
  1064. package/dist/collection/components/toolbar/toolbar.md.css +44 -0
  1065. package/dist/collection/css/test/a11y/typography.e2e.js +6 -6
  1066. package/dist/collection/global/config.js +51 -51
  1067. package/dist/collection/global/ionic-global.js +54 -54
  1068. package/dist/collection/global/test/config-controller.spec.js +77 -0
  1069. package/dist/collection/utils/animation/animation-utils.js +91 -91
  1070. package/dist/collection/utils/animation/animation.js +906 -890
  1071. package/dist/collection/utils/animation/cubic-bezier.js +49 -49
  1072. package/dist/collection/utils/animation/test/animation.spec.js +447 -0
  1073. package/dist/collection/utils/animation/test/animationbuilder/animation.e2e.js +26 -26
  1074. package/dist/collection/utils/animation/test/basic/animation.e2e.js +12 -12
  1075. package/dist/collection/utils/animation/test/display/animation.e2e.js +18 -18
  1076. package/dist/collection/utils/animation/test/hooks/animation.e2e.js +39 -39
  1077. package/dist/collection/utils/animation/test/multiple/animation.e2e.js +27 -27
  1078. package/dist/collection/utils/browser/index.js +0 -22
  1079. package/dist/collection/utils/config.js +20 -20
  1080. package/dist/collection/utils/content/content.utils.spec.js +121 -121
  1081. package/dist/collection/utils/content/index.js +58 -59
  1082. package/dist/collection/utils/floating-point/floating-point.spec.js +14 -14
  1083. package/dist/collection/utils/floating-point/index.js +5 -5
  1084. package/dist/collection/utils/focus-visible.js +63 -63
  1085. package/dist/collection/utils/forms/compare-with-utils.js +39 -0
  1086. package/dist/collection/utils/forms/form-controller.js +45 -49
  1087. package/dist/collection/utils/forms/index.js +1 -0
  1088. package/dist/collection/utils/forms/notch-controller.js +120 -120
  1089. package/dist/collection/utils/framework-delegate.js +121 -121
  1090. package/dist/collection/utils/gesture/button-active.js +56 -56
  1091. package/dist/collection/utils/gesture/gesture-controller.js +182 -182
  1092. package/dist/collection/utils/gesture/index.js +222 -222
  1093. package/dist/collection/utils/gesture/listener.js +36 -36
  1094. package/dist/collection/utils/gesture/pointer-events.js +113 -113
  1095. package/dist/collection/utils/gesture/recognizers.js +46 -46
  1096. package/dist/collection/utils/gesture/swipe-back.js +65 -65
  1097. package/dist/collection/utils/hardware-back-button.js +48 -48
  1098. package/dist/collection/utils/helpers.js +258 -258
  1099. package/dist/collection/utils/helpers.spec.js +28 -28
  1100. package/dist/collection/utils/input-shims/hacks/common.js +61 -53
  1101. package/dist/collection/utils/input-shims/hacks/hide-caret.js +19 -19
  1102. package/dist/collection/utils/input-shims/hacks/input-blurring.js +47 -47
  1103. package/dist/collection/utils/input-shims/hacks/scroll-assist.js +225 -225
  1104. package/dist/collection/utils/input-shims/hacks/scroll-data.js +29 -29
  1105. package/dist/collection/utils/input-shims/hacks/scroll-padding.js +21 -21
  1106. package/dist/collection/utils/input-shims/hacks/test/scroll-assist.e2e.js +97 -97
  1107. package/dist/collection/utils/input-shims/input-shims.js +87 -81
  1108. package/dist/collection/utils/keyboard/keyboard-controller.js +128 -128
  1109. package/dist/collection/utils/keyboard/keyboard.js +59 -59
  1110. package/dist/collection/utils/keyboard/test/keyboard-controller.spec.js +21 -0
  1111. package/dist/collection/utils/keyboard/test/keyboard.spec.js +214 -0
  1112. package/dist/collection/utils/lock-controller.js +24 -24
  1113. package/dist/collection/utils/logging/index.js +3 -3
  1114. package/dist/collection/utils/media.js +13 -13
  1115. package/dist/collection/utils/menu-controller/animations/base.js +8 -8
  1116. package/dist/collection/utils/menu-controller/animations/overlay.js +21 -21
  1117. package/dist/collection/utils/menu-controller/animations/push.js +20 -20
  1118. package/dist/collection/utils/menu-controller/animations/reveal.js +6 -6
  1119. package/dist/collection/utils/menu-controller/index.js +204 -206
  1120. package/dist/collection/utils/native/capacitor.js +4 -4
  1121. package/dist/collection/utils/native/haptic.js +151 -151
  1122. package/dist/collection/utils/native/keyboard.js +47 -47
  1123. package/dist/collection/utils/native/native-interface.js +15 -15
  1124. package/dist/collection/utils/native/status-bar.js +36 -36
  1125. package/dist/collection/utils/overlays.js +495 -494
  1126. package/dist/collection/utils/platform.js +56 -56
  1127. package/dist/collection/utils/rtl/dir.js +5 -5
  1128. package/dist/collection/utils/rtl/dir.spec.js +17 -17
  1129. package/dist/collection/utils/sanitization/index.js +122 -122
  1130. package/dist/collection/utils/sanitization/test/sanitization.spec.js +43 -0
  1131. package/dist/collection/utils/slot-mutation-controller.js +86 -85
  1132. package/dist/collection/utils/status-tap.js +26 -26
  1133. package/dist/collection/utils/tap-click/index.js +171 -171
  1134. package/dist/collection/utils/tap-click/test/tap-click.e2e.js +12 -12
  1135. package/dist/collection/utils/test/aria.spec.js +79 -0
  1136. package/dist/collection/utils/test/attributes.spec.js +53 -0
  1137. package/dist/collection/utils/test/framework-delegate/framework-delegate.e2e.js +25 -25
  1138. package/dist/collection/utils/test/hardware-back-button.spec.js +53 -0
  1139. package/dist/collection/utils/test/overlays/overlays.e2e.js +137 -137
  1140. package/dist/collection/utils/test/overlays/overlays.spec.js +102 -0
  1141. package/dist/collection/utils/test/platform.spec.js +132 -0
  1142. package/dist/collection/utils/test/platform.utils.js +77 -77
  1143. package/dist/collection/utils/test/playwright/drag-element.js +69 -69
  1144. package/dist/collection/utils/test/playwright/generator.js +48 -25
  1145. package/dist/collection/utils/test/playwright/matchers/index.js +3 -3
  1146. package/dist/collection/utils/test/playwright/matchers/toHaveReceivedEvent.js +21 -21
  1147. package/dist/collection/utils/test/playwright/matchers/toHaveReceivedEventDetail.js +28 -28
  1148. package/dist/collection/utils/test/playwright/matchers/toHaveReceivedEventTimes.js +22 -22
  1149. package/dist/collection/utils/test/playwright/page/event-spy.js +110 -110
  1150. package/dist/collection/utils/test/playwright/page/utils/goto.js +52 -52
  1151. package/dist/collection/utils/test/playwright/page/utils/locator.js +8 -8
  1152. package/dist/collection/utils/test/playwright/page/utils/set-content.js +44 -35
  1153. package/dist/collection/utils/test/playwright/page/utils/set-ion-viewport.js +19 -19
  1154. package/dist/collection/utils/test/playwright/page/utils/spy-on-event.js +4 -4
  1155. package/dist/collection/utils/test/playwright/page/utils/wait-for-changes.js +48 -48
  1156. package/dist/collection/utils/test/playwright/playwright-page.js +35 -35
  1157. package/dist/collection/utils/test/playwright/viewports/index.js +13 -13
  1158. package/dist/collection/utils/test/press-keys.js +77 -77
  1159. package/dist/collection/utils/test/ready.spec.js +39 -0
  1160. package/dist/collection/utils/test/theme.spec.js +56 -0
  1161. package/dist/collection/utils/theme.js +23 -23
  1162. package/dist/collection/utils/transition/index.js +163 -163
  1163. package/dist/collection/utils/transition/ios.transition.js +598 -598
  1164. package/dist/collection/utils/transition/md.transition.js +44 -44
  1165. package/dist/collection/utils/watch-options.js +37 -26
  1166. package/dist/docs.json +196 -39
  1167. package/dist/esm/animation-dde8cc0d.js +1060 -0
  1168. package/dist/esm/{app-globals-ec816a70.js → app-globals-722340c4.js} +1 -1
  1169. package/dist/esm/button-active-c6ee4f50.js +67 -0
  1170. package/dist/esm/capacitor-59395cbd.js +13 -0
  1171. package/dist/esm/compare-with-utils-a96ff2ea.js +41 -0
  1172. package/dist/esm/config-49c88215.js +193 -0
  1173. package/dist/esm/cubic-bezier-fe2083dc.js +90 -0
  1174. package/dist/esm/data-f5c75b4e.js +1575 -0
  1175. package/dist/esm/{dir-912e3e13.js → dir-babeabeb.js} +5 -5
  1176. package/dist/esm/focus-visible-dd40d69f.js +75 -0
  1177. package/dist/esm/form-controller-548aa79c.js +64 -0
  1178. package/dist/esm/framework-delegate-bc1fd82a.js +140 -0
  1179. package/dist/esm/gesture-controller-1bf57181.js +195 -0
  1180. package/dist/esm/haptic-554688a5.js +206 -0
  1181. package/dist/esm/hardware-back-button-b2bc76db.js +71 -0
  1182. package/dist/esm/helpers-ae653409.js +418 -0
  1183. package/dist/esm/{index-b49b173c.js → index-08d686eb.js} +184 -63
  1184. package/dist/esm/index-0c12c22b.js +306 -0
  1185. package/dist/esm/index-1932b201.js +231 -0
  1186. package/dist/esm/index-2cf77112.js +457 -0
  1187. package/dist/esm/index-82eeb47f.js +196 -0
  1188. package/dist/esm/{index-595d62c9.js → index-9b0d46f4.js} +3 -3
  1189. package/dist/esm/index-a5d50daf.js +7 -0
  1190. package/dist/esm/{index-746a238e.js → index-b9e742e5.js} +60 -61
  1191. package/dist/esm/index.js +113 -113
  1192. package/dist/esm/input-shims-6539ce13.js +599 -0
  1193. package/dist/esm/input.utils-a5a2d164.js +135 -0
  1194. package/dist/esm/ion-accordion_2.entry.js +491 -481
  1195. package/dist/esm/ion-action-sheet.entry.js +262 -252
  1196. package/dist/esm/ion-alert.entry.js +442 -432
  1197. package/dist/esm/ion-app_8.entry.js +1153 -1153
  1198. package/dist/esm/ion-avatar_3.entry.js +29 -29
  1199. package/dist/esm/ion-back-button.entry.js +73 -73
  1200. package/dist/esm/ion-backdrop.entry.js +40 -40
  1201. package/dist/esm/ion-breadcrumb_2.entry.js +194 -194
  1202. package/dist/esm/ion-button_2.entry.js +303 -303
  1203. package/dist/esm/ion-card_5.entry.js +105 -105
  1204. package/dist/esm/ion-checkbox.entry.js +149 -147
  1205. package/dist/esm/ion-chip.entry.js +20 -20
  1206. package/dist/esm/ion-col_3.entry.js +136 -136
  1207. package/dist/esm/ion-datetime-button.entry.js +325 -325
  1208. package/dist/esm/ion-datetime_3.entry.js +2185 -2137
  1209. package/dist/esm/ion-fab_3.entry.js +152 -152
  1210. package/dist/esm/ion-img.entry.js +79 -79
  1211. package/dist/esm/ion-infinite-scroll_2.entry.js +198 -190
  1212. package/dist/esm/ion-input.entry.js +426 -394
  1213. package/dist/esm/ion-item-option_3.entry.js +459 -459
  1214. package/dist/esm/ion-item_8.entry.js +447 -434
  1215. package/dist/esm/ion-loading.entry.js +220 -210
  1216. package/dist/esm/ion-menu_3.entry.js +670 -658
  1217. package/dist/esm/ion-modal.entry.js +1415 -1405
  1218. package/dist/esm/ion-nav_2.entry.js +904 -904
  1219. package/dist/esm/ion-picker-column-internal.entry.js +331 -327
  1220. package/dist/esm/ion-picker-internal.entry.js +455 -455
  1221. package/dist/esm/ion-popover.entry.js +1110 -1100
  1222. package/dist/esm/ion-progress-bar.entry.js +40 -40
  1223. package/dist/esm/ion-radio_2.entry.js +322 -309
  1224. package/dist/esm/ion-range.entry.js +558 -556
  1225. package/dist/esm/ion-refresher_2.entry.js +786 -779
  1226. package/dist/esm/ion-reorder_2.entry.js +269 -269
  1227. package/dist/esm/ion-ripple-effect.entry.js +66 -66
  1228. package/dist/esm/ion-route_4.entry.js +693 -693
  1229. package/dist/esm/ion-searchbar.entry.js +363 -354
  1230. package/dist/esm/ion-segment_2.entry.js +509 -483
  1231. package/dist/esm/ion-select_3.entry.js +784 -768
  1232. package/dist/esm/ion-spinner.entry.js +46 -46
  1233. package/dist/esm/ion-split-pane.entry.js +117 -117
  1234. package/dist/esm/ion-tab-bar_2.entry.js +142 -142
  1235. package/dist/esm/ion-tab_2.entry.js +187 -187
  1236. package/dist/esm/ion-text.entry.js +13 -13
  1237. package/dist/esm/ion-textarea.entry.js +381 -349
  1238. package/dist/esm/ion-toast.entry.js +771 -419
  1239. package/dist/esm/ion-toggle.entry.js +227 -225
  1240. package/dist/esm/ionic-global-c0cda98e.js +224 -0
  1241. package/dist/esm/ionic.js +6 -6
  1242. package/dist/esm/ios.transition-802a84a6.js +651 -0
  1243. package/dist/esm/keyboard-52278bd7.js +146 -0
  1244. package/dist/esm/keyboard-73175e24.js +79 -0
  1245. package/dist/esm/keyboard-controller-ec5c2bfa.js +165 -0
  1246. package/dist/esm/loader.js +5 -5
  1247. package/dist/esm/lock-controller-316928be.js +38 -0
  1248. package/dist/esm/md.transition-43c2874d.js +57 -0
  1249. package/dist/esm/notch-controller-fea7f9c5.js +153 -0
  1250. package/dist/esm/overlays-32ef481d.js +693 -0
  1251. package/dist/esm/spinner-configs-964f7cf3.js +145 -0
  1252. package/dist/esm/status-tap-2b93b1b5.js +40 -0
  1253. package/dist/esm/swipe-back-18cb49f7.js +79 -0
  1254. package/dist/esm/theme-01f3f29c.js +43 -0
  1255. package/dist/esm/watch-options-c2911ace.js +47 -0
  1256. package/dist/esm-es5/animation-dde8cc0d.js +4 -0
  1257. package/dist/esm-es5/app-globals-722340c4.js +4 -0
  1258. package/dist/esm-es5/{button-active-d926d4f4.js → button-active-c6ee4f50.js} +1 -1
  1259. package/dist/esm-es5/{capacitor-b4979570.js → capacitor-59395cbd.js} +1 -1
  1260. package/dist/esm-es5/compare-with-utils-a96ff2ea.js +4 -0
  1261. package/dist/esm-es5/config-49c88215.js +4 -0
  1262. package/dist/esm-es5/cubic-bezier-fe2083dc.js +4 -0
  1263. package/dist/esm-es5/data-f5c75b4e.js +4 -0
  1264. package/dist/esm-es5/{dir-912e3e13.js → dir-babeabeb.js} +1 -1
  1265. package/dist/esm-es5/focus-visible-dd40d69f.js +4 -0
  1266. package/dist/esm-es5/form-controller-548aa79c.js +4 -0
  1267. package/dist/esm-es5/framework-delegate-bc1fd82a.js +4 -0
  1268. package/dist/esm-es5/{gesture-controller-0fa396c4.js → gesture-controller-1bf57181.js} +1 -1
  1269. package/dist/esm-es5/{haptic-1243b917.js → haptic-554688a5.js} +1 -1
  1270. package/dist/esm-es5/hardware-back-button-b2bc76db.js +4 -0
  1271. package/dist/esm-es5/helpers-ae653409.js +4 -0
  1272. package/dist/esm-es5/index-08d686eb.js +5 -0
  1273. package/dist/esm-es5/index-0c12c22b.js +4 -0
  1274. package/dist/esm-es5/{index-a09eac70.js → index-1932b201.js} +1 -1
  1275. package/dist/esm-es5/index-2cf77112.js +4 -0
  1276. package/dist/esm-es5/index-82eeb47f.js +4 -0
  1277. package/dist/esm-es5/index-b9e742e5.js +4 -0
  1278. package/dist/esm-es5/index.js +1 -1
  1279. package/dist/esm-es5/input-shims-6539ce13.js +4 -0
  1280. package/dist/esm-es5/input.utils-a5a2d164.js +4 -0
  1281. package/dist/esm-es5/ion-accordion_2.entry.js +1 -1
  1282. package/dist/esm-es5/ion-action-sheet.entry.js +1 -1
  1283. package/dist/esm-es5/ion-alert.entry.js +1 -1
  1284. package/dist/esm-es5/ion-app_8.entry.js +1 -1
  1285. package/dist/esm-es5/ion-avatar_3.entry.js +1 -1
  1286. package/dist/esm-es5/ion-back-button.entry.js +1 -1
  1287. package/dist/esm-es5/ion-backdrop.entry.js +1 -1
  1288. package/dist/esm-es5/ion-breadcrumb_2.entry.js +1 -1
  1289. package/dist/esm-es5/ion-button_2.entry.js +1 -1
  1290. package/dist/esm-es5/ion-card_5.entry.js +1 -1
  1291. package/dist/esm-es5/ion-checkbox.entry.js +1 -1
  1292. package/dist/esm-es5/ion-chip.entry.js +1 -1
  1293. package/dist/esm-es5/ion-col_3.entry.js +1 -1
  1294. package/dist/esm-es5/ion-datetime-button.entry.js +1 -1
  1295. package/dist/esm-es5/ion-datetime_3.entry.js +1 -1
  1296. package/dist/esm-es5/ion-fab_3.entry.js +1 -1
  1297. package/dist/esm-es5/ion-img.entry.js +1 -1
  1298. package/dist/esm-es5/ion-infinite-scroll_2.entry.js +1 -1
  1299. package/dist/esm-es5/ion-input.entry.js +1 -1
  1300. package/dist/esm-es5/ion-item-option_3.entry.js +1 -1
  1301. package/dist/esm-es5/ion-item_8.entry.js +1 -1
  1302. package/dist/esm-es5/ion-loading.entry.js +1 -1
  1303. package/dist/esm-es5/ion-menu_3.entry.js +1 -1
  1304. package/dist/esm-es5/ion-modal.entry.js +1 -1
  1305. package/dist/esm-es5/ion-nav_2.entry.js +1 -1
  1306. package/dist/esm-es5/ion-picker-column-internal.entry.js +1 -1
  1307. package/dist/esm-es5/ion-picker-internal.entry.js +1 -1
  1308. package/dist/esm-es5/ion-popover.entry.js +1 -1
  1309. package/dist/esm-es5/ion-progress-bar.entry.js +1 -1
  1310. package/dist/esm-es5/ion-radio_2.entry.js +1 -1
  1311. package/dist/esm-es5/ion-range.entry.js +1 -1
  1312. package/dist/esm-es5/ion-refresher_2.entry.js +1 -1
  1313. package/dist/esm-es5/ion-reorder_2.entry.js +1 -1
  1314. package/dist/esm-es5/ion-ripple-effect.entry.js +1 -1
  1315. package/dist/esm-es5/ion-route_4.entry.js +1 -1
  1316. package/dist/esm-es5/ion-searchbar.entry.js +1 -1
  1317. package/dist/esm-es5/ion-segment_2.entry.js +1 -1
  1318. package/dist/esm-es5/ion-select_3.entry.js +1 -1
  1319. package/dist/esm-es5/ion-spinner.entry.js +1 -1
  1320. package/dist/esm-es5/ion-split-pane.entry.js +1 -1
  1321. package/dist/esm-es5/ion-tab-bar_2.entry.js +1 -1
  1322. package/dist/esm-es5/ion-tab_2.entry.js +1 -1
  1323. package/dist/esm-es5/ion-text.entry.js +1 -1
  1324. package/dist/esm-es5/ion-textarea.entry.js +1 -1
  1325. package/dist/esm-es5/ion-toast.entry.js +1 -1
  1326. package/dist/esm-es5/ion-toggle.entry.js +1 -1
  1327. package/dist/esm-es5/ionic-global-c0cda98e.js +4 -0
  1328. package/dist/esm-es5/ionic.js +1 -1
  1329. package/dist/esm-es5/{ios.transition-4d1322d6.js → ios.transition-802a84a6.js} +1 -1
  1330. package/dist/esm-es5/{keyboard-b551279d.js → keyboard-52278bd7.js} +1 -1
  1331. package/dist/esm-es5/{keyboard-b063f012.js → keyboard-73175e24.js} +1 -1
  1332. package/dist/esm-es5/keyboard-controller-ec5c2bfa.js +4 -0
  1333. package/dist/esm-es5/loader.js +1 -1
  1334. package/dist/esm-es5/md.transition-43c2874d.js +4 -0
  1335. package/dist/esm-es5/notch-controller-fea7f9c5.js +4 -0
  1336. package/dist/esm-es5/overlays-32ef481d.js +4 -0
  1337. package/dist/esm-es5/spinner-configs-964f7cf3.js +4 -0
  1338. package/dist/esm-es5/status-tap-2b93b1b5.js +4 -0
  1339. package/dist/esm-es5/swipe-back-18cb49f7.js +4 -0
  1340. package/dist/esm-es5/watch-options-c2911ace.js +4 -0
  1341. package/dist/html.html-data.json +17 -4
  1342. package/dist/ionic/index.esm.js +1 -1
  1343. package/dist/ionic/ionic.esm.js +1 -1
  1344. package/dist/ionic/ionic.js +15 -15
  1345. package/dist/ionic/p-012c3ceb.system.js +4 -0
  1346. package/dist/ionic/p-013013a3.js +4 -0
  1347. package/dist/ionic/p-01d14eba.system.entry.js +4 -0
  1348. package/dist/ionic/p-042e6f4b.entry.js +4 -0
  1349. package/dist/ionic/{p-819ff3b9.system.js → p-08e01816.system.js} +1 -1
  1350. package/dist/ionic/{p-f919c026.entry.js → p-0add7211.entry.js} +1 -1
  1351. package/dist/ionic/p-0bd51c34.system.js +4 -0
  1352. package/dist/ionic/{p-6f6646bf.system.entry.js → p-0e53f8ea.system.entry.js} +1 -1
  1353. package/dist/ionic/{p-6ea2e653.entry.js → p-1161a793.entry.js} +1 -1
  1354. package/dist/ionic/{p-96ba8eac.entry.js → p-1208f939.entry.js} +1 -1
  1355. package/dist/ionic/p-16756e94.system.entry.js +4 -0
  1356. package/dist/ionic/p-1786bc72.js +4 -0
  1357. package/dist/ionic/{p-1ecba429.entry.js → p-17da5ed1.entry.js} +1 -1
  1358. package/dist/ionic/p-18ba8221.entry.js +4 -0
  1359. package/dist/ionic/p-1b19c04b.entry.js +4 -0
  1360. package/dist/ionic/p-1cca10d6.system.js +4 -0
  1361. package/dist/ionic/p-1e4371bd.js +4 -0
  1362. package/dist/ionic/{p-fcf47f80.entry.js → p-2092f39f.entry.js} +1 -1
  1363. package/dist/ionic/p-251666e2.entry.js +4 -0
  1364. package/dist/ionic/{p-7423746f.entry.js → p-270e1a1d.entry.js} +1 -1
  1365. package/dist/ionic/{p-419eb426.js → p-27281edd.js} +1 -1
  1366. package/dist/ionic/p-28249b10.system.entry.js +4 -0
  1367. package/dist/ionic/p-28a2c2a2.entry.js +4 -0
  1368. package/dist/ionic/{p-6129af0a.system.entry.js → p-2938823a.system.entry.js} +1 -1
  1369. package/dist/ionic/p-29d03b3a.js +4 -0
  1370. package/dist/ionic/{p-17240d90.js → p-2aea8b1e.js} +1 -1
  1371. package/dist/ionic/p-2b7827c7.js +4 -0
  1372. package/dist/ionic/p-2d3b9fa3.system.entry.js +4 -0
  1373. package/dist/ionic/p-2d539df1.entry.js +4 -0
  1374. package/dist/ionic/p-31b2326e.system.js +4 -0
  1375. package/dist/ionic/{p-e028178a.system.js → p-31fcb233.system.js} +1 -1
  1376. package/dist/ionic/p-32ad210f.system.js +4 -0
  1377. package/dist/ionic/{p-aa377971.system.js → p-33a37fad.system.js} +1 -1
  1378. package/dist/ionic/p-350f7292.system.entry.js +4 -0
  1379. package/dist/ionic/{p-cabd2c6d.entry.js → p-353b349d.entry.js} +1 -1
  1380. package/dist/ionic/p-36d187af.js +4 -0
  1381. package/dist/ionic/p-376a6063.js +4 -0
  1382. package/dist/ionic/p-38c337e7.system.js +4 -0
  1383. package/dist/ionic/p-38f2c6bb.system.js +4 -0
  1384. package/dist/ionic/{p-9e106f58.entry.js → p-3a45a82b.entry.js} +1 -1
  1385. package/dist/ionic/{p-3bad5c1a.js → p-3a75d7fd.js} +1 -1
  1386. package/dist/ionic/p-3dd98a73.entry.js +4 -0
  1387. package/dist/ionic/p-3e6b47e8.system.entry.js +4 -0
  1388. package/dist/ionic/p-3f5179b5.entry.js +4 -0
  1389. package/dist/ionic/p-40f68333.system.js +4 -0
  1390. package/dist/ionic/p-4155f352.system.js +4 -0
  1391. package/dist/ionic/{p-b287ab05.js → p-4180a747.js} +1 -1
  1392. package/dist/ionic/p-4233cc1e.system.entry.js +4 -0
  1393. package/dist/ionic/{p-b923f3d7.js → p-42f189f4.js} +1 -1
  1394. package/dist/ionic/p-459d13d5.js +4 -0
  1395. package/dist/ionic/p-4609d030.system.js +4 -0
  1396. package/dist/ionic/p-46d400b4.system.entry.js +4 -0
  1397. package/dist/ionic/{p-cf62e1c8.js → p-47b6ba5b.js} +1 -1
  1398. package/dist/ionic/p-4d67d27a.entry.js +4 -0
  1399. package/dist/ionic/p-4f255d5a.system.js +4 -0
  1400. package/dist/ionic/p-4fb51e61.system.entry.js +4 -0
  1401. package/dist/ionic/{p-c575a7b8.system.entry.js → p-517a9885.system.entry.js} +1 -1
  1402. package/dist/ionic/{p-8083aadb.entry.js → p-51a087d6.entry.js} +1 -1
  1403. package/dist/ionic/p-53ec4f1c.system.js +4 -0
  1404. package/dist/ionic/{p-6f8a95a3.system.entry.js → p-564af202.system.entry.js} +2 -2
  1405. package/dist/ionic/{p-0ac3fb2c.entry.js → p-588fdf40.entry.js} +1 -1
  1406. package/dist/ionic/p-5b365ca7.system.js +4 -0
  1407. package/dist/ionic/{p-c42c86c0.system.entry.js → p-5bebc7b3.system.entry.js} +1 -1
  1408. package/dist/ionic/p-5e4eec2e.entry.js +4 -0
  1409. package/dist/ionic/{p-2a8eeef7.system.js → p-5e745192.system.js} +1 -1
  1410. package/dist/ionic/{p-76378400.js → p-5ecae037.js} +1 -1
  1411. package/dist/ionic/{p-c679fcb5.entry.js → p-5eda1d7d.entry.js} +1 -1
  1412. package/dist/ionic/{p-1289b3b5.system.entry.js → p-6577aea9.system.entry.js} +2 -2
  1413. package/dist/ionic/p-66d633fb.js +4 -0
  1414. package/dist/ionic/{p-0bbede6a.system.entry.js → p-6ad34705.system.entry.js} +1 -1
  1415. package/dist/ionic/p-6de472cb.js +4 -0
  1416. package/dist/ionic/{p-ce7d67a7.system.entry.js → p-6de62649.system.entry.js} +2 -2
  1417. package/dist/ionic/{p-8a2801f1.system.entry.js → p-6e70dd1a.system.entry.js} +1 -1
  1418. package/dist/ionic/{p-61b192a4.system.entry.js → p-6f8dbe92.system.entry.js} +1 -1
  1419. package/dist/ionic/{p-0b00b937.entry.js → p-6fbecbda.entry.js} +1 -1
  1420. package/dist/ionic/p-72f6ff89.js +4 -0
  1421. package/dist/ionic/p-765f4dde.entry.js +4 -0
  1422. package/dist/ionic/p-7798c78a.system.js +4 -0
  1423. package/dist/ionic/p-78aadecb.entry.js +4 -0
  1424. package/dist/ionic/p-790220fd.system.js +4 -0
  1425. package/dist/ionic/p-7d92bf15.system.entry.js +4 -0
  1426. package/dist/ionic/p-80fa068e.entry.js +4 -0
  1427. package/dist/ionic/p-82e3d633.system.js +4 -0
  1428. package/dist/ionic/p-8314281e.system.js +4 -0
  1429. package/dist/ionic/p-8804a472.system.entry.js +4 -0
  1430. package/dist/ionic/p-888db766.system.js +4 -0
  1431. package/dist/ionic/p-88d5fbd3.js +4 -0
  1432. package/dist/ionic/p-88fde0e0.entry.js +4 -0
  1433. package/dist/ionic/p-8985cdb6.system.js +4 -0
  1434. package/dist/ionic/p-8aa1d0b7.system.js +4 -0
  1435. package/dist/ionic/p-8acae6b0.system.entry.js +4 -0
  1436. package/dist/ionic/p-8d69a624.entry.js +4 -0
  1437. package/dist/ionic/p-8f5d30f5.entry.js +4 -0
  1438. package/dist/ionic/{p-beb864e4.system.entry.js → p-908475e7.system.entry.js} +1 -1
  1439. package/dist/ionic/p-91d33c4a.js +4 -0
  1440. package/dist/ionic/p-953009b1.entry.js +4 -0
  1441. package/dist/ionic/{p-eb8dc56f.system.entry.js → p-958d6ebe.system.entry.js} +2 -2
  1442. package/dist/ionic/{p-78030c1f.system.entry.js → p-9709ebd8.system.entry.js} +1 -1
  1443. package/dist/ionic/p-9738fd82.js +5 -0
  1444. package/dist/ionic/p-979d4f5c.system.js +4 -0
  1445. package/dist/ionic/{p-c4a5de01.entry.js → p-98f3d827.entry.js} +1 -1
  1446. package/dist/ionic/p-9b7f0b0f.entry.js +4 -0
  1447. package/dist/ionic/p-9e447eb1.system.js +4 -0
  1448. package/dist/ionic/p-9eec42cc.system.entry.js +4 -0
  1449. package/dist/ionic/p-9f6ee2c0.system.entry.js +4 -0
  1450. package/dist/ionic/p-a0bb7b92.system.entry.js +4 -0
  1451. package/dist/ionic/p-a0d7bb5e.system.js +4 -0
  1452. package/dist/ionic/p-a1987850.entry.js +4 -0
  1453. package/dist/ionic/{p-8209372c.entry.js → p-a3277a67.entry.js} +1 -1
  1454. package/dist/ionic/{p-4e6e43c1.entry.js → p-a4afcc88.entry.js} +1 -1
  1455. package/dist/ionic/p-a9978d08.entry.js +4 -0
  1456. package/dist/ionic/p-ada96dd0.system.entry.js +4 -0
  1457. package/dist/ionic/p-afd6ca9d.entry.js +4 -0
  1458. package/dist/ionic/p-b3b3efba.system.entry.js +4 -0
  1459. package/dist/ionic/p-b4a51c42.system.js +4 -0
  1460. package/dist/ionic/p-b56d0866.system.entry.js +4 -0
  1461. package/dist/ionic/{p-4e50b8d1.entry.js → p-b5f9f14c.entry.js} +1 -1
  1462. package/dist/ionic/{p-eab10949.system.entry.js → p-b6f5e4f2.system.entry.js} +1 -1
  1463. package/dist/ionic/p-b6f9d32a.entry.js +4 -0
  1464. package/dist/ionic/p-b7010c69.system.entry.js +4 -0
  1465. package/dist/ionic/{p-181b7c2a.js → p-c3c3333a.js} +1 -1
  1466. package/dist/ionic/p-c468af8a.system.js +4 -0
  1467. package/dist/ionic/p-c61cc894.js +4 -0
  1468. package/dist/ionic/p-c7c8429a.system.js +4 -0
  1469. package/dist/ionic/p-c847fb35.system.entry.js +4 -0
  1470. package/dist/ionic/{p-e0f52215.system.entry.js → p-c91ccbfa.system.entry.js} +1 -1
  1471. package/dist/ionic/p-c9a21dfd.system.entry.js +4 -0
  1472. package/dist/ionic/p-cabad15b.system.js +4 -0
  1473. package/dist/ionic/{p-8c1805f4.system.entry.js → p-caf21b46.system.entry.js} +1 -1
  1474. package/dist/ionic/p-cce9f61a.system.entry.js +4 -0
  1475. package/dist/ionic/{p-de68588d.js → p-cdbeaadc.js} +1 -1
  1476. package/dist/ionic/{p-108f9d49.entry.js → p-cfe57b1b.entry.js} +1 -1
  1477. package/dist/ionic/p-d032f825.system.entry.js +4 -0
  1478. package/dist/ionic/{p-31119a15.entry.js → p-d37b441e.entry.js} +1 -1
  1479. package/dist/ionic/p-d3b030b8.system.js +5 -0
  1480. package/dist/ionic/p-d51674c5.system.js +4 -0
  1481. package/dist/ionic/p-d8d84afa.system.js +4 -0
  1482. package/dist/ionic/p-dc6af8e9.entry.js +4 -0
  1483. package/dist/ionic/{p-3818f63f.entry.js → p-ddb30596.entry.js} +1 -1
  1484. package/dist/ionic/p-ddbb2d5b.system.js +4 -0
  1485. package/dist/ionic/p-de6f8b28.system.js +4 -0
  1486. package/dist/ionic/p-de756e5c.js +4 -0
  1487. package/dist/ionic/p-dee7c1d0.system.entry.js +4 -0
  1488. package/dist/ionic/{p-e0f0d55f.system.js → p-e24ce1e5.system.js} +1 -1
  1489. package/dist/ionic/p-e3584231.system.js +4 -0
  1490. package/dist/ionic/{p-c4f2dce7.system.js → p-e673a0a2.system.js} +1 -1
  1491. package/dist/ionic/p-e6d68e02.system.entry.js +4 -0
  1492. package/dist/ionic/{p-012952cd.system.entry.js → p-e7ea9815.system.entry.js} +2 -2
  1493. package/dist/ionic/{p-db1a1e00.entry.js → p-e94c392d.entry.js} +1 -1
  1494. package/dist/ionic/{p-a04bfada.entry.js → p-ea69616e.entry.js} +1 -1
  1495. package/dist/ionic/p-eef72e06.js +4 -0
  1496. package/dist/ionic/p-ef126ae8.system.entry.js +4 -0
  1497. package/dist/ionic/p-f0445d82.system.entry.js +4 -0
  1498. package/dist/ionic/p-f233f1e0.system.js +4 -0
  1499. package/dist/ionic/p-f5d2dc9b.js +4 -0
  1500. package/dist/ionic/p-f656e032.system.entry.js +4 -0
  1501. package/dist/ionic/p-f70970cf.js +4 -0
  1502. package/dist/ionic/p-f8a5bb89.entry.js +4 -0
  1503. package/dist/ionic/p-fba0a6e7.system.entry.js +4 -0
  1504. package/dist/ionic/p-feae5133.entry.js +4 -0
  1505. package/dist/ionic/p-ff4b7e40.system.js +4 -0
  1506. package/dist/types/components/accordion/accordion.d.ts +62 -62
  1507. package/dist/types/components/accordion-group/accordion-group-interface.d.ts +3 -3
  1508. package/dist/types/components/accordion-group/accordion-group.d.ts +76 -76
  1509. package/dist/types/components/action-sheet/action-sheet-interface.d.ts +25 -25
  1510. package/dist/types/components/action-sheet/action-sheet.d.ts +149 -149
  1511. package/dist/types/components/action-sheet/test/basic/fixture.d.ts +7 -7
  1512. package/dist/types/components/alert/alert-interface.d.ts +45 -45
  1513. package/dist/types/components/alert/alert.d.ts +181 -181
  1514. package/dist/types/components/app/app.d.ts +15 -15
  1515. package/dist/types/components/avatar/avatar.d.ts +1 -1
  1516. package/dist/types/components/back-button/back-button.d.ts +41 -41
  1517. package/dist/types/components/backdrop/backdrop.d.ts +22 -22
  1518. package/dist/types/components/badge/badge.d.ts +7 -7
  1519. package/dist/types/components/breadcrumb/breadcrumb-interface.d.ts +4 -4
  1520. package/dist/types/components/breadcrumb/breadcrumb.d.ts +87 -87
  1521. package/dist/types/components/breadcrumbs/breadcrumbs.d.ts +39 -39
  1522. package/dist/types/components/button/button.d.ts +121 -121
  1523. package/dist/types/components/buttons/buttons.d.ts +14 -14
  1524. package/dist/types/components/card/card.d.ts +57 -57
  1525. package/dist/types/components/card-content/card-content.d.ts +1 -1
  1526. package/dist/types/components/card-header/card-header.d.ts +13 -13
  1527. package/dist/types/components/card-subtitle/card-subtitle.d.ts +7 -7
  1528. package/dist/types/components/card-title/card-title.d.ts +7 -7
  1529. package/dist/types/components/checkbox/checkbox-interface.d.ts +4 -4
  1530. package/dist/types/components/checkbox/checkbox.d.ts +112 -111
  1531. package/dist/types/components/chip/chip.d.ts +15 -15
  1532. package/dist/types/components/col/col.d.ts +128 -128
  1533. package/dist/types/components/content/content-interface.d.ts +6 -6
  1534. package/dist/types/components/content/content.d.ts +129 -129
  1535. package/dist/types/components/datetime/datetime-interface.d.ts +15 -15
  1536. package/dist/types/components/datetime/datetime.d.ts +407 -407
  1537. package/dist/types/components/datetime/utils/data.d.ts +11 -11
  1538. package/dist/types/components/datetime/utils/manipulation.d.ts +25 -25
  1539. package/dist/types/components/datetime/utils/state.d.ts +8 -8
  1540. package/dist/types/components/datetime-button/datetime-button.d.ts +59 -59
  1541. package/dist/types/components/fab/fab.d.ts +33 -33
  1542. package/dist/types/components/fab-button/fab-button.d.ts +88 -88
  1543. package/dist/types/components/fab-list/fab-list.d.ts +11 -11
  1544. package/dist/types/components/footer/footer.d.ts +27 -27
  1545. package/dist/types/components/grid/grid.d.ts +5 -5
  1546. package/dist/types/components/header/header.d.ts +31 -31
  1547. package/dist/types/components/header/header.utils.d.ts +7 -7
  1548. package/dist/types/components/img/img.d.ts +30 -30
  1549. package/dist/types/components/infinite-scroll/infinite-scroll-interface.d.ts +1 -1
  1550. package/dist/types/components/infinite-scroll/infinite-scroll.d.ts +65 -58
  1551. package/dist/types/components/infinite-scroll-content/infinite-scroll-content.d.ts +23 -23
  1552. package/dist/types/components/input/input-interface.d.ts +6 -6
  1553. package/dist/types/components/input/input.d.ts +321 -315
  1554. package/dist/types/components/item/item.d.ts +111 -111
  1555. package/dist/types/components/item-divider/item-divider.d.ts +16 -16
  1556. package/dist/types/components/item-group/item-group.d.ts +1 -1
  1557. package/dist/types/components/item-option/item-option.d.ts +44 -44
  1558. package/dist/types/components/item-options/item-options.d.ts +13 -13
  1559. package/dist/types/components/item-sliding/item-sliding-interface.d.ts +1 -1
  1560. package/dist/types/components/item-sliding/item-sliding.d.ts +75 -75
  1561. package/dist/types/components/label/label.d.ts +30 -30
  1562. package/dist/types/components/list/list.d.ts +17 -17
  1563. package/dist/types/components/list-header/list-header.d.ts +11 -11
  1564. package/dist/types/components/loading/loading-interface.d.ts +16 -16
  1565. package/dist/types/components/loading/loading.d.ts +152 -152
  1566. package/dist/types/components/menu/menu-interface.d.ts +39 -39
  1567. package/dist/types/components/menu/menu.d.ts +140 -140
  1568. package/dist/types/components/menu-button/menu-button.d.ts +30 -30
  1569. package/dist/types/components/menu-toggle/menu-toggle.d.ts +21 -21
  1570. package/dist/types/components/modal/animations/sheet.d.ts +4 -4
  1571. package/dist/types/components/modal/gestures/sheet.d.ts +30 -30
  1572. package/dist/types/components/modal/gestures/swipe-to-close.d.ts +1 -1
  1573. package/dist/types/components/modal/modal-interface.d.ts +27 -27
  1574. package/dist/types/components/modal/modal.d.ts +265 -265
  1575. package/dist/types/components/modal/test/fixtures.d.ts +7 -7
  1576. package/dist/types/components/nav/nav-interface.d.ts +40 -40
  1577. package/dist/types/components/nav/nav.d.ts +247 -247
  1578. package/dist/types/components/nav/view-controller.d.ts +13 -13
  1579. package/dist/types/components/nav-link/nav-link.d.ts +19 -19
  1580. package/dist/types/components/note/note.d.ts +7 -7
  1581. package/dist/types/components/picker/picker-interface.d.ts +43 -43
  1582. package/dist/types/components/picker/picker.d.ts +149 -149
  1583. package/dist/types/components/picker-column/picker-column.d.ts +39 -39
  1584. package/dist/types/components/picker-column-internal/picker-column-internal-interfaces.d.ts +3 -3
  1585. package/dist/types/components/picker-column-internal/picker-column-internal.d.ts +93 -89
  1586. package/dist/types/components/picker-internal/picker-internal-interfaces.d.ts +4 -4
  1587. package/dist/types/components/picker-internal/picker-internal.d.ts +94 -94
  1588. package/dist/types/components/popover/popover-interface.d.ts +26 -26
  1589. package/dist/types/components/popover/popover.d.ts +279 -279
  1590. package/dist/types/components/popover/test/fixture.d.ts +5 -5
  1591. package/dist/types/components/popover/utils.d.ts +25 -25
  1592. package/dist/types/components/progress-bar/progress-bar.d.ts +27 -27
  1593. package/dist/types/components/radio/radio.d.ts +100 -99
  1594. package/dist/types/components/radio-group/radio-group-interface.d.ts +5 -4
  1595. package/dist/types/components/radio-group/radio-group.d.ts +51 -44
  1596. package/dist/types/components/radio-group/test/fixtures.d.ts +5 -5
  1597. package/dist/types/components/range/range-interface.d.ts +7 -7
  1598. package/dist/types/components/range/range.d.ts +193 -192
  1599. package/dist/types/components/refresher/refresher-interface.d.ts +3 -3
  1600. package/dist/types/components/refresher/refresher.d.ts +132 -132
  1601. package/dist/types/components/refresher-content/refresher-content.d.ts +44 -44
  1602. package/dist/types/components/reorder/reorder.d.ts +3 -3
  1603. package/dist/types/components/reorder-group/reorder-group-interface.d.ts +5 -5
  1604. package/dist/types/components/reorder-group/reorder-group.d.ts +53 -53
  1605. package/dist/types/components/ripple-effect/ripple-effect.d.ts +20 -20
  1606. package/dist/types/components/route/route-interface.d.ts +1 -1
  1607. package/dist/types/components/route/route.d.ts +43 -43
  1608. package/dist/types/components/route-redirect/route-redirect.d.ts +33 -33
  1609. package/dist/types/components/router/router.d.ts +74 -73
  1610. package/dist/types/components/router/utils/dom.d.ts +2 -2
  1611. package/dist/types/components/router/utils/interface.d.ts +31 -31
  1612. package/dist/types/components/router/utils/matching.d.ts +6 -6
  1613. package/dist/types/components/router-link/router-link.d.ts +34 -34
  1614. package/dist/types/components/router-outlet/router-outlet.d.ts +41 -41
  1615. package/dist/types/components/row/row.d.ts +1 -1
  1616. package/dist/types/components/searchbar/searchbar-interface.d.ts +6 -6
  1617. package/dist/types/components/searchbar/searchbar.d.ts +235 -233
  1618. package/dist/types/components/segment/segment-interface.d.ts +3 -3
  1619. package/dist/types/components/segment/segment.d.ts +82 -82
  1620. package/dist/types/components/segment-button/segment-button.d.ts +36 -36
  1621. package/dist/types/components/select/select-interface.d.ts +3 -3
  1622. package/dist/types/components/select/select.d.ts +238 -233
  1623. package/dist/types/components/select-option/select-option.d.ts +11 -11
  1624. package/dist/types/components/select-popover/select-popover-interface.d.ts +8 -8
  1625. package/dist/types/components/select-popover/select-popover.d.ts +39 -39
  1626. package/dist/types/components/select-popover/test/fixtures.d.ts +12 -12
  1627. package/dist/types/components/skeleton-text/skeleton-text.d.ts +15 -7
  1628. package/dist/types/components/spinner/spinner-configs.d.ts +96 -96
  1629. package/dist/types/components/spinner/spinner-interface.d.ts +14 -14
  1630. package/dist/types/components/spinner/spinner.d.ts +21 -21
  1631. package/dist/types/components/split-pane/split-pane.d.ts +33 -33
  1632. package/dist/types/components/tab/tab.d.ts +21 -21
  1633. package/dist/types/components/tab-bar/tab-bar-interface.d.ts +4 -4
  1634. package/dist/types/components/tab-bar/tab-bar.d.ts +34 -34
  1635. package/dist/types/components/tab-button/tab-button.d.ts +56 -56
  1636. package/dist/types/components/tabs/tabs-interface.d.ts +4 -4
  1637. package/dist/types/components/tabs/tabs.d.ts +52 -52
  1638. package/dist/types/components/text/text.d.ts +7 -7
  1639. package/dist/types/components/textarea/textarea-interface.d.ts +6 -6
  1640. package/dist/types/components/textarea/textarea.d.ts +275 -269
  1641. package/dist/types/components/thumbnail/thumbnail.d.ts +1 -1
  1642. package/dist/types/components/title/title.d.ts +21 -21
  1643. package/dist/types/components/toast/animations/utils.d.ts +15 -4
  1644. package/dist/types/components/toast/gestures/swipe-to-dismiss.d.ts +9 -0
  1645. package/dist/types/components/toast/toast-interface.d.ts +37 -35
  1646. package/dist/types/components/toast/toast.d.ts +241 -214
  1647. package/dist/types/components/toggle/toggle-interface.d.ts +4 -4
  1648. package/dist/types/components/toggle/toggle.d.ts +117 -116
  1649. package/dist/types/components/toolbar/toolbar.d.ts +11 -11
  1650. package/dist/types/components.d.ts +679 -16
  1651. package/dist/types/global/config.d.ts +6 -6
  1652. package/dist/types/interface.d.ts +1 -5
  1653. package/dist/types/jest.d.ts +5 -0
  1654. package/dist/types/stencil-public-runtime.d.ts +10 -0
  1655. package/dist/types/utils/animation/animation-interface.d.ts +205 -205
  1656. package/dist/types/utils/browser/index.d.ts +17 -8
  1657. package/dist/types/utils/config.d.ts +175 -175
  1658. package/dist/types/utils/content/index.d.ts +1 -1
  1659. package/dist/types/utils/element-interface.d.ts +6 -6
  1660. package/dist/types/utils/focus-visible.d.ts +5 -4
  1661. package/dist/types/utils/forms/compare-with-utils.d.ts +18 -0
  1662. package/dist/types/utils/forms/form-controller.d.ts +3 -3
  1663. package/dist/types/utils/forms/index.d.ts +1 -0
  1664. package/dist/types/utils/forms/notch-controller.d.ts +2 -2
  1665. package/dist/types/utils/framework-delegate.d.ts +3 -3
  1666. package/dist/types/utils/gesture/gesture-controller.d.ts +49 -49
  1667. package/dist/types/utils/gesture/index.d.ts +31 -31
  1668. package/dist/types/utils/gesture/listener.d.ts +2 -2
  1669. package/dist/types/utils/gesture/pointer-events.d.ts +12 -12
  1670. package/dist/types/utils/gesture/recognizers.d.ts +4 -4
  1671. package/dist/types/utils/hardware-back-button.d.ts +4 -0
  1672. package/dist/types/utils/helpers.d.ts +8 -8
  1673. package/dist/types/utils/input-shims/hacks/scroll-data.d.ts +4 -4
  1674. package/dist/types/utils/keyboard/keyboard-controller.d.ts +3 -3
  1675. package/dist/types/utils/lock-controller.d.ts +1 -1
  1676. package/dist/types/utils/native/haptic.d.ts +38 -38
  1677. package/dist/types/utils/native/keyboard.d.ts +29 -29
  1678. package/dist/types/utils/native/native-interface.d.ts +15 -15
  1679. package/dist/types/utils/native/status-bar.d.ts +8 -8
  1680. package/dist/types/utils/overlays-interface.d.ts +27 -27
  1681. package/dist/types/utils/overlays.d.ts +29 -28
  1682. package/dist/types/utils/platform.d.ts +16 -16
  1683. package/dist/types/utils/sanitization/index.d.ts +2 -2
  1684. package/dist/types/utils/slot-mutation-controller.d.ts +3 -3
  1685. package/dist/types/utils/test/platform.utils.d.ts +67 -67
  1686. package/dist/types/utils/test/playwright/generator.d.ts +16 -7
  1687. package/dist/types/utils/test/playwright/matchers/index.d.ts +3 -3
  1688. package/dist/types/utils/test/playwright/matchers/toHaveReceivedEvent.d.ts +2 -2
  1689. package/dist/types/utils/test/playwright/matchers/toHaveReceivedEventDetail.d.ts +2 -2
  1690. package/dist/types/utils/test/playwright/matchers/toHaveReceivedEventTimes.d.ts +2 -2
  1691. package/dist/types/utils/test/playwright/page/event-spy.d.ts +15 -15
  1692. package/dist/types/utils/test/playwright/page/utils/goto.d.ts +3 -3
  1693. package/dist/types/utils/test/playwright/page/utils/locator.d.ts +15 -15
  1694. package/dist/types/utils/test/playwright/playwright-declarations.d.ts +92 -92
  1695. package/dist/types/utils/test/playwright/playwright-page.d.ts +3 -3
  1696. package/dist/types/utils/test/playwright/viewports/index.d.ts +12 -12
  1697. package/dist/types/utils/test/press-keys.d.ts +14 -14
  1698. package/dist/types/utils/transition/index.d.ts +6 -6
  1699. package/dist/types/utils/watch-options.d.ts +9 -1
  1700. package/hydrate/index.d.ts +1 -1
  1701. package/hydrate/index.js +30673 -29948
  1702. package/package.json +10 -12
  1703. package/dist/cjs/animation-c8bdd3c7.js +0 -1046
  1704. package/dist/cjs/button-active-c0ff1915.js +0 -69
  1705. package/dist/cjs/config-d5882735.js +0 -199
  1706. package/dist/cjs/cubic-bezier-6b9222ad.js +0 -92
  1707. package/dist/cjs/data-c8d21093.js +0 -1622
  1708. package/dist/cjs/focus-visible-a7545600.js +0 -77
  1709. package/dist/cjs/form-controller-5e223b54.js +0 -70
  1710. package/dist/cjs/framework-delegate-c0873a6f.js +0 -144
  1711. package/dist/cjs/gesture-controller-b46721be.js +0 -197
  1712. package/dist/cjs/haptic-678abc9f.js +0 -212
  1713. package/dist/cjs/hardware-back-button-b67c8e75.js +0 -76
  1714. package/dist/cjs/helpers-ea4ccbcb.js +0 -441
  1715. package/dist/cjs/index-0ee995e4.js +0 -459
  1716. package/dist/cjs/index-306a7476.js +0 -32
  1717. package/dist/cjs/index-5e7529f6.js +0 -310
  1718. package/dist/cjs/index-9f379eaa.js +0 -198
  1719. package/dist/cjs/index-eccba000.js +0 -243
  1720. package/dist/cjs/input-shims-da7dc0de.js +0 -588
  1721. package/dist/cjs/input.utils-0fe3097c.js +0 -137
  1722. package/dist/cjs/ionic-global-fb752503.js +0 -230
  1723. package/dist/cjs/ios.transition-5af5991e.js +0 -654
  1724. package/dist/cjs/keyboard-controller-50beb83a.js +0 -167
  1725. package/dist/cjs/keyboard-fd7db491.js +0 -81
  1726. package/dist/cjs/lock-controller-4ae2eb59.js +0 -40
  1727. package/dist/cjs/md.transition-1e740a6a.js +0 -59
  1728. package/dist/cjs/notch-controller-f4f6af5d.js +0 -155
  1729. package/dist/cjs/overlays-1a734051.js +0 -714
  1730. package/dist/cjs/spinner-configs-f7b5105b.js +0 -147
  1731. package/dist/cjs/status-tap-778e8054.js +0 -42
  1732. package/dist/cjs/swipe-back-7e843e77.js +0 -81
  1733. package/dist/cjs/theme-fbc56b3b.js +0 -48
  1734. package/dist/cjs/watch-options-f3f77e54.js +0 -38
  1735. package/dist/collection/components/item/test/text/item.e2e.js +0 -14
  1736. package/dist/esm/animation-92066c62.js +0 -1044
  1737. package/dist/esm/button-active-d926d4f4.js +0 -67
  1738. package/dist/esm/capacitor-b4979570.js +0 -13
  1739. package/dist/esm/config-96c9ace3.js +0 -193
  1740. package/dist/esm/cubic-bezier-66542bc5.js +0 -90
  1741. package/dist/esm/data-44d9e816.js +0 -1575
  1742. package/dist/esm/focus-visible-85493433.js +0 -75
  1743. package/dist/esm/form-controller-ed77647a.js +0 -68
  1744. package/dist/esm/framework-delegate-aa433dea.js +0 -140
  1745. package/dist/esm/gesture-controller-0fa396c4.js +0 -195
  1746. package/dist/esm/haptic-1243b917.js +0 -206
  1747. package/dist/esm/hardware-back-button-39299f84.js +0 -71
  1748. package/dist/esm/helpers-3379ba19.js +0 -418
  1749. package/dist/esm/index-7a14ecec.js +0 -29
  1750. package/dist/esm/index-a09eac70.js +0 -231
  1751. package/dist/esm/index-df55802d.js +0 -308
  1752. package/dist/esm/index-f0cc4e14.js +0 -196
  1753. package/dist/esm/index-ff313b19.js +0 -457
  1754. package/dist/esm/input-shims-d78a3c77.js +0 -586
  1755. package/dist/esm/input.utils-ec063df4.js +0 -134
  1756. package/dist/esm/ionic-global-246ca78f.js +0 -224
  1757. package/dist/esm/ios.transition-4d1322d6.js +0 -651
  1758. package/dist/esm/keyboard-b063f012.js +0 -79
  1759. package/dist/esm/keyboard-b551279d.js +0 -146
  1760. package/dist/esm/keyboard-controller-0c2dce71.js +0 -165
  1761. package/dist/esm/lock-controller-e8c6c051.js +0 -38
  1762. package/dist/esm/md.transition-66b425d0.js +0 -57
  1763. package/dist/esm/notch-controller-8c9c0e54.js +0 -153
  1764. package/dist/esm/overlays-cec6bac8.js +0 -692
  1765. package/dist/esm/spinner-configs-d09fbbbb.js +0 -145
  1766. package/dist/esm/status-tap-9aeeaca5.js +0 -40
  1767. package/dist/esm/swipe-back-cd4295f3.js +0 -79
  1768. package/dist/esm/theme-17531cdf.js +0 -43
  1769. package/dist/esm/watch-options-355a920a.js +0 -36
  1770. package/dist/esm-es5/animation-92066c62.js +0 -4
  1771. package/dist/esm-es5/app-globals-ec816a70.js +0 -4
  1772. package/dist/esm-es5/config-96c9ace3.js +0 -4
  1773. package/dist/esm-es5/cubic-bezier-66542bc5.js +0 -4
  1774. package/dist/esm-es5/data-44d9e816.js +0 -4
  1775. package/dist/esm-es5/focus-visible-85493433.js +0 -4
  1776. package/dist/esm-es5/form-controller-ed77647a.js +0 -4
  1777. package/dist/esm-es5/framework-delegate-aa433dea.js +0 -4
  1778. package/dist/esm-es5/hardware-back-button-39299f84.js +0 -4
  1779. package/dist/esm-es5/helpers-3379ba19.js +0 -4
  1780. package/dist/esm-es5/index-746a238e.js +0 -4
  1781. package/dist/esm-es5/index-b49b173c.js +0 -5
  1782. package/dist/esm-es5/index-df55802d.js +0 -4
  1783. package/dist/esm-es5/index-f0cc4e14.js +0 -4
  1784. package/dist/esm-es5/index-ff313b19.js +0 -4
  1785. package/dist/esm-es5/input-shims-d78a3c77.js +0 -4
  1786. package/dist/esm-es5/input.utils-ec063df4.js +0 -4
  1787. package/dist/esm-es5/ionic-global-246ca78f.js +0 -4
  1788. package/dist/esm-es5/keyboard-controller-0c2dce71.js +0 -4
  1789. package/dist/esm-es5/md.transition-66b425d0.js +0 -4
  1790. package/dist/esm-es5/notch-controller-8c9c0e54.js +0 -4
  1791. package/dist/esm-es5/overlays-cec6bac8.js +0 -4
  1792. package/dist/esm-es5/spinner-configs-d09fbbbb.js +0 -4
  1793. package/dist/esm-es5/status-tap-9aeeaca5.js +0 -4
  1794. package/dist/esm-es5/swipe-back-cd4295f3.js +0 -4
  1795. package/dist/esm-es5/watch-options-355a920a.js +0 -4
  1796. package/dist/ionic/p-015187e5.system.js +0 -4
  1797. package/dist/ionic/p-06ac429a.js +0 -5
  1798. package/dist/ionic/p-091c8792.system.js +0 -4
  1799. package/dist/ionic/p-0b7c25ee.system.entry.js +0 -4
  1800. package/dist/ionic/p-0f1f59da.system.entry.js +0 -4
  1801. package/dist/ionic/p-19fba51c.entry.js +0 -4
  1802. package/dist/ionic/p-1a463b1e.system.entry.js +0 -4
  1803. package/dist/ionic/p-1edb53a1.entry.js +0 -4
  1804. package/dist/ionic/p-1f260a7b.entry.js +0 -4
  1805. package/dist/ionic/p-1f81b5be.entry.js +0 -4
  1806. package/dist/ionic/p-276afddd.js +0 -4
  1807. package/dist/ionic/p-28ea45b9.js +0 -4
  1808. package/dist/ionic/p-29073efe.system.entry.js +0 -4
  1809. package/dist/ionic/p-2b89ea1b.system.js +0 -4
  1810. package/dist/ionic/p-303bf1e8.system.entry.js +0 -4
  1811. package/dist/ionic/p-32083c2d.js +0 -4
  1812. package/dist/ionic/p-33a8349a.system.entry.js +0 -4
  1813. package/dist/ionic/p-34259245.system.entry.js +0 -4
  1814. package/dist/ionic/p-35b26732.entry.js +0 -4
  1815. package/dist/ionic/p-35e399bd.entry.js +0 -4
  1816. package/dist/ionic/p-3632220b.system.js +0 -4
  1817. package/dist/ionic/p-38089641.entry.js +0 -4
  1818. package/dist/ionic/p-38c5fe2b.system.entry.js +0 -4
  1819. package/dist/ionic/p-3a58e3a4.system.entry.js +0 -4
  1820. package/dist/ionic/p-3d726a67.system.js +0 -4
  1821. package/dist/ionic/p-3f3da911.system.entry.js +0 -4
  1822. package/dist/ionic/p-41477ad9.system.js +0 -4
  1823. package/dist/ionic/p-4215652f.system.entry.js +0 -4
  1824. package/dist/ionic/p-446230d7.js +0 -4
  1825. package/dist/ionic/p-44bc8b45.system.js +0 -4
  1826. package/dist/ionic/p-479cdbf8.system.js +0 -4
  1827. package/dist/ionic/p-4f97c112.entry.js +0 -4
  1828. package/dist/ionic/p-54200074.entry.js +0 -4
  1829. package/dist/ionic/p-54f6cd27.system.entry.js +0 -4
  1830. package/dist/ionic/p-56dc022e.system.js +0 -4
  1831. package/dist/ionic/p-572cce26.system.entry.js +0 -4
  1832. package/dist/ionic/p-5b976d70.entry.js +0 -4
  1833. package/dist/ionic/p-5bf16a18.js +0 -4
  1834. package/dist/ionic/p-613d4042.system.js +0 -4
  1835. package/dist/ionic/p-629aa3fd.system.js +0 -5
  1836. package/dist/ionic/p-62e7d4fa.js +0 -4
  1837. package/dist/ionic/p-64475ab5.system.js +0 -4
  1838. package/dist/ionic/p-673846f6.entry.js +0 -4
  1839. package/dist/ionic/p-6ce0a709.system.entry.js +0 -4
  1840. package/dist/ionic/p-755b2917.system.js +0 -4
  1841. package/dist/ionic/p-772f6c84.system.js +0 -4
  1842. package/dist/ionic/p-815c2fba.system.js +0 -4
  1843. package/dist/ionic/p-818b2e75.entry.js +0 -4
  1844. package/dist/ionic/p-81c818e7.js +0 -4
  1845. package/dist/ionic/p-81ef7437.system.entry.js +0 -4
  1846. package/dist/ionic/p-87411e39.system.js +0 -4
  1847. package/dist/ionic/p-8b1be026.js +0 -4
  1848. package/dist/ionic/p-8c15eda7.system.js +0 -4
  1849. package/dist/ionic/p-8cf94fc1.js +0 -4
  1850. package/dist/ionic/p-8d6728a1.system.entry.js +0 -4
  1851. package/dist/ionic/p-8e24ebbc.js +0 -4
  1852. package/dist/ionic/p-8f01a9a2.system.js +0 -4
  1853. package/dist/ionic/p-939e0fa1.system.js +0 -4
  1854. package/dist/ionic/p-9ab6f3e6.system.js +0 -4
  1855. package/dist/ionic/p-9dc85536.system.entry.js +0 -4
  1856. package/dist/ionic/p-9e852ff1.system.js +0 -4
  1857. package/dist/ionic/p-9f2e0db9.js +0 -4
  1858. package/dist/ionic/p-a164e3ab.system.entry.js +0 -4
  1859. package/dist/ionic/p-a200a7fc.entry.js +0 -4
  1860. package/dist/ionic/p-a34fc12e.system.entry.js +0 -4
  1861. package/dist/ionic/p-a9c32660.entry.js +0 -4
  1862. package/dist/ionic/p-ab4cff27.system.js +0 -4
  1863. package/dist/ionic/p-ad48dd13.system.js +0 -4
  1864. package/dist/ionic/p-afb6658f.entry.js +0 -4
  1865. package/dist/ionic/p-b132c2c0.system.js +0 -4
  1866. package/dist/ionic/p-b24aa895.js +0 -4
  1867. package/dist/ionic/p-b3c68723.system.js +0 -4
  1868. package/dist/ionic/p-b4b4bb29.system.js +0 -4
  1869. package/dist/ionic/p-b61a2fa0.system.entry.js +0 -4
  1870. package/dist/ionic/p-b753ec0d.system.entry.js +0 -4
  1871. package/dist/ionic/p-b8c3f071.system.js +0 -4
  1872. package/dist/ionic/p-b912e055.system.js +0 -4
  1873. package/dist/ionic/p-bb055450.system.entry.js +0 -4
  1874. package/dist/ionic/p-bba2ce59.system.js +0 -4
  1875. package/dist/ionic/p-c105bd36.entry.js +0 -4
  1876. package/dist/ionic/p-c44fe9fd.js +0 -4
  1877. package/dist/ionic/p-c49672d8.system.js +0 -4
  1878. package/dist/ionic/p-c87827ca.system.js +0 -4
  1879. package/dist/ionic/p-c8c9d699.system.entry.js +0 -4
  1880. package/dist/ionic/p-c92f0a6d.system.entry.js +0 -4
  1881. package/dist/ionic/p-c956e82c.system.entry.js +0 -4
  1882. package/dist/ionic/p-ca5cf574.js +0 -4
  1883. package/dist/ionic/p-cc196b34.js +0 -4
  1884. package/dist/ionic/p-ccdcb022.system.js +0 -4
  1885. package/dist/ionic/p-cd2d17c3.system.entry.js +0 -4
  1886. package/dist/ionic/p-cf0c93e3.system.entry.js +0 -4
  1887. package/dist/ionic/p-d1de1188.js +0 -4
  1888. package/dist/ionic/p-d35217be.entry.js +0 -4
  1889. package/dist/ionic/p-d6e53e66.entry.js +0 -4
  1890. package/dist/ionic/p-e1d5752d.system.entry.js +0 -4
  1891. package/dist/ionic/p-e25cb483.entry.js +0 -4
  1892. package/dist/ionic/p-e65ebe96.entry.js +0 -4
  1893. package/dist/ionic/p-e74faf2a.entry.js +0 -4
  1894. package/dist/ionic/p-eac263dd.entry.js +0 -4
  1895. package/dist/ionic/p-eb7d0922.js +0 -4
  1896. package/dist/ionic/p-f4309ac7.entry.js +0 -4
  1897. package/dist/ionic/p-f5bf698b.entry.js +0 -4
  1898. package/dist/ionic/p-f7566bad.entry.js +0 -4
  1899. package/dist/ionic/p-f9fa802c.system.entry.js +0 -4
  1900. package/dist/ionic/p-fa8d4788.system.js +0 -4
  1901. package/dist/ionic/p-ff5a10f9.system.js +0 -4
  1902. /package/dist/esm-es5/{index-595d62c9.js → index-9b0d46f4.js} +0 -0
  1903. /package/dist/esm-es5/{index-7a14ecec.js → index-a5d50daf.js} +0 -0
  1904. /package/dist/esm-es5/{lock-controller-e8c6c051.js → lock-controller-316928be.js} +0 -0
  1905. /package/dist/esm-es5/{theme-17531cdf.js → theme-01f3f29c.js} +0 -0
  1906. /package/dist/ionic/{p-1b8e1d03.js → p-06fee233.js} +0 -0
  1907. /package/dist/ionic/{p-63eb0acd.js → p-23a9d086.js} +0 -0
  1908. /package/dist/ionic/{p-7c2bac85.js → p-2408c236.js} +0 -0
  1909. /package/dist/ionic/{p-7b021525.js → p-41d5544e.js} +0 -0
  1910. /package/dist/ionic/{p-1d072d3d.js → p-47794def.js} +0 -0
  1911. /package/dist/ionic/{p-185e427e.js → p-4b3623da.js} +0 -0
  1912. /package/dist/ionic/{p-0e94957a.system.js → p-792919fd.system.js} +0 -0
  1913. /package/dist/ionic/{p-b347cfd1.js → p-7b30edcc.js} +0 -0
  1914. /package/dist/ionic/{p-e0b06b65.js → p-bb3615f7.js} +0 -0
  1915. /package/dist/ionic/{p-53b2a46f.js → p-ccd02320.js} +0 -0
  1916. /package/dist/ionic/{p-76fce40e.js → p-d47265c8.js} +0 -0
  1917. /package/dist/ionic/{p-c18d6eac.js → p-f0c2a614.js} +0 -0
  1918. /package/dist/ionic/{p-6dbfe5d4.js → p-fb813dab.js} +0 -0
@@ -23,13 +23,13 @@ import { d as defineCustomElement$3 } from './popover.js';
23
23
  import { d as defineCustomElement$2 } from './ripple-effect.js';
24
24
 
25
25
  const isYearDisabled = (refYear, minParts, maxParts) => {
26
- if (minParts && minParts.year > refYear) {
27
- return true;
28
- }
29
- if (maxParts && maxParts.year < refYear) {
30
- return true;
31
- }
32
- return false;
26
+ if (minParts && minParts.year > refYear) {
27
+ return true;
28
+ }
29
+ if (maxParts && maxParts.year < refYear) {
30
+ return true;
31
+ }
32
+ return false;
33
33
  };
34
34
  /**
35
35
  * Returns true if a given day should
@@ -37,104 +37,104 @@ const isYearDisabled = (refYear, minParts, maxParts) => {
37
37
  * or the max/min dates.
38
38
  */
39
39
  const isDayDisabled = (refParts, minParts, maxParts, dayValues) => {
40
- /**
41
- * If this is a filler date (i.e. padding)
42
- * then the date is disabled.
43
- */
44
- if (refParts.day === null) {
45
- return true;
46
- }
47
- /**
48
- * If user passed in a list of acceptable day values
49
- * check to make sure that the date we are looking
50
- * at is in this array.
51
- */
52
- if (dayValues !== undefined && !dayValues.includes(refParts.day)) {
53
- return true;
54
- }
55
- /**
56
- * Given a min date, perform the following
57
- * checks. If any of them are true, then the
58
- * day should be disabled:
59
- * 1. Is the current year < the min allowed year?
60
- * 2. Is the current year === min allowed year,
61
- * but the current month < the min allowed month?
62
- * 3. Is the current year === min allowed year, the
63
- * current month === min allow month, but the current
64
- * day < the min allowed day?
65
- */
66
- if (minParts && isBefore(refParts, minParts)) {
67
- return true;
68
- }
69
- /**
70
- * Given a max date, perform the following
71
- * checks. If any of them are true, then the
72
- * day should be disabled:
73
- * 1. Is the current year > the max allowed year?
74
- * 2. Is the current year === max allowed year,
75
- * but the current month > the max allowed month?
76
- * 3. Is the current year === max allowed year, the
77
- * current month === max allow month, but the current
78
- * day > the max allowed day?
79
- */
80
- if (maxParts && isAfter(refParts, maxParts)) {
81
- return true;
82
- }
83
- /**
84
- * If none of these checks
85
- * passed then the date should
86
- * be interactive.
87
- */
88
- return false;
40
+ /**
41
+ * If this is a filler date (i.e. padding)
42
+ * then the date is disabled.
43
+ */
44
+ if (refParts.day === null) {
45
+ return true;
46
+ }
47
+ /**
48
+ * If user passed in a list of acceptable day values
49
+ * check to make sure that the date we are looking
50
+ * at is in this array.
51
+ */
52
+ if (dayValues !== undefined && !dayValues.includes(refParts.day)) {
53
+ return true;
54
+ }
55
+ /**
56
+ * Given a min date, perform the following
57
+ * checks. If any of them are true, then the
58
+ * day should be disabled:
59
+ * 1. Is the current year < the min allowed year?
60
+ * 2. Is the current year === min allowed year,
61
+ * but the current month < the min allowed month?
62
+ * 3. Is the current year === min allowed year, the
63
+ * current month === min allow month, but the current
64
+ * day < the min allowed day?
65
+ */
66
+ if (minParts && isBefore(refParts, minParts)) {
67
+ return true;
68
+ }
69
+ /**
70
+ * Given a max date, perform the following
71
+ * checks. If any of them are true, then the
72
+ * day should be disabled:
73
+ * 1. Is the current year > the max allowed year?
74
+ * 2. Is the current year === max allowed year,
75
+ * but the current month > the max allowed month?
76
+ * 3. Is the current year === max allowed year, the
77
+ * current month === max allow month, but the current
78
+ * day > the max allowed day?
79
+ */
80
+ if (maxParts && isAfter(refParts, maxParts)) {
81
+ return true;
82
+ }
83
+ /**
84
+ * If none of these checks
85
+ * passed then the date should
86
+ * be interactive.
87
+ */
88
+ return false;
89
89
  };
90
90
  /**
91
91
  * Given a locale, a date, the selected date(s), and today's date,
92
92
  * generate the state for a given calendar day button.
93
93
  */
94
94
  const getCalendarDayState = (locale, refParts, activeParts, todayParts, minParts, maxParts, dayValues) => {
95
- /**
96
- * activeParts signals what day(s) are currently selected in the datetime.
97
- * If multiple="true", this will be an array, but the logic in this util
98
- * is the same whether we have one selected day or many because we're only
99
- * calculating the state for one button. So, we treat a single activeParts value
100
- * the same as an array of length one.
101
- */
102
- const activePartsArray = Array.isArray(activeParts) ? activeParts : [activeParts];
103
- /**
104
- * The day button is active if it is selected, or in other words, if refParts
105
- * matches at least one selected date.
106
- */
107
- const isActive = activePartsArray.find((parts) => isSameDay(refParts, parts)) !== undefined;
108
- const isToday = isSameDay(refParts, todayParts);
109
- const disabled = isDayDisabled(refParts, minParts, maxParts, dayValues);
110
- /**
111
- * Note that we always return one object regardless of whether activeParts
112
- * was an array, since we pare down to one value for isActive.
113
- */
114
- return {
115
- disabled,
116
- isActive,
117
- isToday,
118
- ariaSelected: isActive ? 'true' : null,
119
- ariaLabel: generateDayAriaLabel(locale, isToday, refParts),
120
- text: refParts.day != null ? getDay(locale, refParts) : null,
121
- };
95
+ /**
96
+ * activeParts signals what day(s) are currently selected in the datetime.
97
+ * If multiple="true", this will be an array, but the logic in this util
98
+ * is the same whether we have one selected day or many because we're only
99
+ * calculating the state for one button. So, we treat a single activeParts value
100
+ * the same as an array of length one.
101
+ */
102
+ const activePartsArray = Array.isArray(activeParts) ? activeParts : [activeParts];
103
+ /**
104
+ * The day button is active if it is selected, or in other words, if refParts
105
+ * matches at least one selected date.
106
+ */
107
+ const isActive = activePartsArray.find((parts) => isSameDay(refParts, parts)) !== undefined;
108
+ const isToday = isSameDay(refParts, todayParts);
109
+ const disabled = isDayDisabled(refParts, minParts, maxParts, dayValues);
110
+ /**
111
+ * Note that we always return one object regardless of whether activeParts
112
+ * was an array, since we pare down to one value for isActive.
113
+ */
114
+ return {
115
+ disabled,
116
+ isActive,
117
+ isToday,
118
+ ariaSelected: isActive ? 'true' : null,
119
+ ariaLabel: generateDayAriaLabel(locale, isToday, refParts),
120
+ text: refParts.day != null ? getDay(locale, refParts) : null,
121
+ };
122
122
  };
123
123
  /**
124
124
  * Returns `true` if the month is disabled given the
125
125
  * current date value and min/max date constraints.
126
126
  */
127
127
  const isMonthDisabled = (refParts, { minParts, maxParts, }) => {
128
- // If the year is disabled then the month is disabled.
129
- if (isYearDisabled(refParts.year, minParts, maxParts)) {
130
- return true;
131
- }
132
- // If the date value is before the min date, then the month is disabled.
133
- // If the date value is after the max date, then the month is disabled.
134
- if ((minParts && isBefore(refParts, minParts)) || (maxParts && isAfter(refParts, maxParts))) {
135
- return true;
136
- }
137
- return false;
128
+ // If the year is disabled then the month is disabled.
129
+ if (isYearDisabled(refParts.year, minParts, maxParts)) {
130
+ return true;
131
+ }
132
+ // If the date value is before the min date, then the month is disabled.
133
+ // If the date value is after the max date, then the month is disabled.
134
+ if ((minParts && isBefore(refParts, minParts)) || (maxParts && isAfter(refParts, maxParts))) {
135
+ return true;
136
+ }
137
+ return false;
138
138
  };
139
139
  /**
140
140
  * Given a working date, an optional minimum date range,
@@ -142,21 +142,21 @@ const isMonthDisabled = (refParts, { minParts, maxParts, }) => {
142
142
  * previous navigation button is disabled.
143
143
  */
144
144
  const isPrevMonthDisabled = (refParts, minParts, maxParts) => {
145
- const prevMonth = Object.assign(Object.assign({}, getPreviousMonth(refParts)), { day: null });
146
- return isMonthDisabled(prevMonth, {
147
- minParts,
148
- maxParts,
149
- });
145
+ const prevMonth = Object.assign(Object.assign({}, getPreviousMonth(refParts)), { day: null });
146
+ return isMonthDisabled(prevMonth, {
147
+ minParts,
148
+ maxParts,
149
+ });
150
150
  };
151
151
  /**
152
152
  * Given a working date and a maximum date range,
153
153
  * determine if the next navigation button is disabled.
154
154
  */
155
155
  const isNextMonthDisabled = (refParts, maxParts) => {
156
- const nextMonth = Object.assign(Object.assign({}, getNextMonth(refParts)), { day: null });
157
- return isMonthDisabled(nextMonth, {
158
- maxParts,
159
- });
156
+ const nextMonth = Object.assign(Object.assign({}, getNextMonth(refParts)), { day: null });
157
+ return isMonthDisabled(nextMonth, {
158
+ maxParts,
159
+ });
160
160
  };
161
161
  /**
162
162
  * Given the value of the highlightedDates property
@@ -164,1667 +164,1705 @@ const isNextMonthDisabled = (refParts, maxParts) => {
164
164
  * that date, or undefined if none are found.
165
165
  */
166
166
  const getHighlightStyles = (highlightedDates, dateIsoString, el) => {
167
- if (Array.isArray(highlightedDates)) {
168
- const dateStringWithoutTime = dateIsoString.split('T')[0];
169
- const matchingHighlight = highlightedDates.find((hd) => hd.date === dateStringWithoutTime);
170
- if (matchingHighlight) {
171
- return {
172
- textColor: matchingHighlight.textColor,
173
- backgroundColor: matchingHighlight.backgroundColor,
174
- };
175
- }
176
- }
177
- else {
178
- /**
179
- * Wrap in a try-catch to prevent exceptions in the user's function
180
- * from interrupting the calendar's rendering.
181
- */
182
- try {
183
- return highlightedDates(dateIsoString);
167
+ if (Array.isArray(highlightedDates)) {
168
+ const dateStringWithoutTime = dateIsoString.split('T')[0];
169
+ const matchingHighlight = highlightedDates.find((hd) => hd.date === dateStringWithoutTime);
170
+ if (matchingHighlight) {
171
+ return {
172
+ textColor: matchingHighlight.textColor,
173
+ backgroundColor: matchingHighlight.backgroundColor,
174
+ };
175
+ }
184
176
  }
185
- catch (e) {
186
- printIonError('Exception thrown from provided `highlightedDates` callback. Please check your function and try again.', el, e);
177
+ else {
178
+ /**
179
+ * Wrap in a try-catch to prevent exceptions in the user's function
180
+ * from interrupting the calendar's rendering.
181
+ */
182
+ try {
183
+ return highlightedDates(dateIsoString);
184
+ }
185
+ catch (e) {
186
+ printIonError('Exception thrown from provided `highlightedDates` callback. Please check your function and try again.', el, e);
187
+ }
187
188
  }
188
- }
189
- return undefined;
189
+ return undefined;
190
190
  };
191
191
 
192
- const datetimeIosCss = ":host{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;background:var(--background);overflow:hidden}ion-picker-column-internal{min-width:26px}:host(.datetime-size-fixed){width:auto;height:auto}:host(.datetime-size-fixed:not(.datetime-prefer-wheel)){max-width:350px}:host(.datetime-size-fixed.datetime-prefer-wheel){min-width:350px;max-width:-webkit-max-content;max-width:-moz-max-content;max-width:max-content}:host(.datetime-size-cover){width:100%}:host .calendar-body,:host .datetime-year{opacity:0}:host(:not(.datetime-ready)) .datetime-year{position:absolute;pointer-events:none}:host(.datetime-ready) .calendar-body{opacity:1}:host(.datetime-ready) .datetime-year{display:none;opacity:1}:host .wheel-order-year-first .day-column{-ms-flex-order:3;order:3;text-align:end}:host .wheel-order-year-first .month-column{-ms-flex-order:2;order:2;text-align:end}:host .wheel-order-year-first .year-column{-ms-flex-order:1;order:1;text-align:start}:host .datetime-calendar,:host .datetime-year{display:-ms-flexbox;display:flex;-ms-flex:1 1 auto;flex:1 1 auto;-ms-flex-flow:column;flex-flow:column}:host(.show-month-and-year) .datetime-year{display:-ms-flexbox;display:flex}@supports (background: -webkit-named-image(apple-pay-logo-black)) and (not (aspect-ratio: 1/1)){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{position:absolute;visibility:hidden;pointer-events:none}@supports (inset-inline-start: 0){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{inset-inline-start:-99999px}}@supports not (inset-inline-start: 0){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{left:-99999px}:host-context([dir=rtl]):host(.show-month-and-year) .calendar-next-prev,:host-context([dir=rtl]).show-month-and-year .calendar-next-prev,:host-context([dir=rtl]):host(.show-month-and-year) .calendar-days-of-week,:host-context([dir=rtl]).show-month-and-year .calendar-days-of-week,:host-context([dir=rtl]):host(.show-month-and-year) .calendar-body,:host-context([dir=rtl]).show-month-and-year .calendar-body,:host-context([dir=rtl]):host(.show-month-and-year) .datetime-time,:host-context([dir=rtl]).show-month-and-year .datetime-time{left:unset;right:unset;right:-99999px}@supports selector(:dir(rtl)){:host(.show-month-and-year) .calendar-next-prev:dir(rtl),:host(.show-month-and-year) .calendar-days-of-week:dir(rtl),:host(.show-month-and-year) .calendar-body:dir(rtl),:host(.show-month-and-year) .datetime-time:dir(rtl){left:unset;right:unset;right:-99999px}}}}@supports (not (background: -webkit-named-image(apple-pay-logo-black))) or ((background: -webkit-named-image(apple-pay-logo-black)) and (aspect-ratio: 1/1)){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{display:none}}:host(.month-year-picker-open) .datetime-footer{display:none}:host(.datetime-readonly),:host(.datetime-disabled){pointer-events:none}:host(.datetime-disabled){opacity:0.4}:host .datetime-header .datetime-title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}:host .datetime-action-buttons.has-clear-button{width:100%}:host .datetime-action-buttons ion-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}.datetime-action-buttons .datetime-action-buttons-container{display:-ms-flexbox;display:flex}:host .calendar-action-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host .calendar-action-buttons ion-item,:host .calendar-action-buttons ion-button{--background:translucent}:host .calendar-action-buttons ion-item ion-label{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}:host .calendar-action-buttons ion-item ion-icon{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:0;padding-inline-end:0;padding-top:0;padding-bottom:0}:host .calendar-days-of-week{display:grid;grid-template-columns:repeat(7, 1fr);text-align:center}.calendar-days-of-week .day-of-week{-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto;margin-top:0;margin-bottom:0}:host .calendar-body{display:-ms-flexbox;display:flex;-ms-flex-positive:1;flex-grow:1;-webkit-scroll-snap-type:x mandatory;-ms-scroll-snap-type:x mandatory;scroll-snap-type:x mandatory;overflow-x:scroll;overflow-y:hidden;scrollbar-width:none;outline:none}:host .calendar-body .calendar-month{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;scroll-snap-align:start;scroll-snap-stop:always;-ms-flex-negative:0;flex-shrink:0;width:100%}:host .calendar-body .calendar-month-disabled{scroll-snap-align:none}:host .calendar-body::-webkit-scrollbar{display:none}:host .calendar-body .calendar-month-grid{display:grid;grid-template-columns:repeat(7, 1fr)}:host .calendar-day-wrapper{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;min-width:0;min-height:0;overflow:visible}.calendar-day{border-radius:50%;-webkit-padding-start:0px;padding-inline-start:0px;-webkit-padding-end:0px;padding-inline-end:0px;padding-top:0px;padding-bottom:0px;-webkit-margin-start:0px;margin-inline-start:0px;-webkit-margin-end:0px;margin-inline-end:0px;margin-top:0px;margin-bottom:0px;display:-ms-flexbox;display:flex;position:relative;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;border:none;outline:none;background:none;color:currentColor;font-family:var(--ion-font-family, inherit);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;z-index:0}:host .calendar-day[disabled]{pointer-events:none;opacity:0.4}.calendar-day:focus{background:rgba(var(--ion-color-base-rgb), 0.2);-webkit-box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2);box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2)}:host .datetime-time{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host(.datetime-presentation-time) .datetime-time{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0}:host ion-popover{--height:200px}:host .time-header{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}:host .time-body{border-radius:8px;-webkit-padding-start:12px;padding-inline-start:12px;-webkit-padding-end:12px;padding-inline-end:12px;padding-top:6px;padding-bottom:6px;display:-ms-flexbox;display:flex;border:none;background:var(--ion-color-step-300, #edeef0);color:var(--ion-text-color, #000);font-family:inherit;font-size:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}:host .time-body-active{color:var(--ion-color-base)}:host(.in-item){position:static}:host(.show-month-and-year) .calendar-action-buttons ion-item{--color:var(--ion-color-base)}:host{--background:var(--ion-color-light, #ffffff);--background-rgb:var(--ion-color-light-rgb);--title-color:var(--ion-color-step-600, #666666)}:host(.datetime-presentation-date-time:not(.datetime-prefer-wheel)),:host(.datetime-presentation-time-date:not(.datetime-prefer-wheel)),:host(.datetime-presentation-date:not(.datetime-prefer-wheel)){min-height:350px}:host .datetime-header{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:16px;padding-bottom:16px;border-bottom:0.55px solid var(--ion-color-step-200, #cccccc);font-size:min(0.875rem, 22.4px)}:host .datetime-header .datetime-title{color:var(--title-color)}:host .datetime-header .datetime-selected-date{margin-top:10px}:host .calendar-action-buttons ion-item{--padding-start:16px;--background-hover:transparent;--background-activated:transparent;font-size:min(1rem, 25.6px);font-weight:600}:host .calendar-action-buttons ion-item ion-icon,:host .calendar-action-buttons ion-buttons ion-button{color:var(--ion-color-base)}:host .calendar-action-buttons ion-buttons{padding-left:0;padding-right:0;padding-top:8px;padding-bottom:0}:host .calendar-action-buttons ion-buttons ion-button{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}:host .calendar-days-of-week{-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px;padding-top:0;padding-bottom:0;color:var(--ion-color-step-300, #b3b3b3);font-size:min(0.75rem, 19.2px);font-weight:600;line-height:24px;text-transform:uppercase}@supports (border-radius: mod(1px, 1px)){.calendar-days-of-week .day-of-week{width:clamp(20px, calc(mod(min(1rem, 24px), 24px) * 10), 100%);height:24px;overflow:hidden}.calendar-day{border-radius:max(8px, mod(min(1rem, 24px), 24px) * 10)}}@supports ((border-radius: mod(1px, 1px)) and (background: -webkit-named-image(apple-pay-logo-black)) and (not (contain-intrinsic-size: none))) or (not (border-radius: mod(1px, 1px))){.calendar-days-of-week .day-of-week{width:auto;height:auto;overflow:initial}.calendar-day{border-radius:32px}}:host .calendar-body .calendar-month .calendar-month-grid{-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px;padding-top:8px;padding-bottom:8px;-ms-flex-align:center;align-items:center;height:calc(100% - 16px)}:host .calendar-day-wrapper{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:4px;padding-inline-end:4px;padding-top:4px;padding-bottom:4px;height:0;min-height:1rem}:host .calendar-day{width:40px;min-width:40px;height:40px;font-size:min(1.25rem, 32px)}.calendar-day.calendar-day-active{background:rgba(var(--ion-color-base-rgb), 0.2)}:host .calendar-day.calendar-day-today{color:var(--ion-color-base)}:host .calendar-day.calendar-day-active{color:var(--ion-color-base);font-weight:600}:host .calendar-day.calendar-day-today.calendar-day-active{color:var(--ion-color-contrast)}:host .datetime-time{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:8px;padding-bottom:16px;font-size:min(1rem, 25.6px)}:host .datetime-time .time-header{font-weight:600}:host .datetime-buttons{-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px;padding-top:8px;padding-bottom:8px;border-top:0.55px solid var(--ion-color-step-200, #cccccc)}:host .datetime-buttons ::slotted(ion-buttons),:host .datetime-buttons ion-buttons{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:justify;justify-content:space-between}:host .datetime-action-buttons{width:100%}";
192
+ const datetimeIosCss = ":host{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;background:var(--background);overflow:hidden}ion-picker-column-internal{min-width:26px}:host(.datetime-size-fixed){width:auto;height:auto}:host(.datetime-size-fixed:not(.datetime-prefer-wheel)){max-width:350px}:host(.datetime-size-fixed.datetime-prefer-wheel){min-width:350px;max-width:-webkit-max-content;max-width:-moz-max-content;max-width:max-content}:host(.datetime-size-cover){width:100%}:host .calendar-body,:host .datetime-year{opacity:0}:host(:not(.datetime-ready)) .datetime-year{position:absolute;pointer-events:none}:host(.datetime-ready) .calendar-body{opacity:1}:host(.datetime-ready) .datetime-year{display:none;opacity:1}:host .wheel-order-year-first .day-column{-ms-flex-order:3;order:3;text-align:end}:host .wheel-order-year-first .month-column{-ms-flex-order:2;order:2;text-align:end}:host .wheel-order-year-first .year-column{-ms-flex-order:1;order:1;text-align:start}:host .datetime-calendar,:host .datetime-year{display:-ms-flexbox;display:flex;-ms-flex:1 1 auto;flex:1 1 auto;-ms-flex-flow:column;flex-flow:column}:host(.show-month-and-year) .datetime-year{display:-ms-flexbox;display:flex}@supports (background: -webkit-named-image(apple-pay-logo-black)) and (not (aspect-ratio: 1/1)){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{position:absolute;visibility:hidden;pointer-events:none}@supports (inset-inline-start: 0){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{inset-inline-start:-99999px}}@supports not (inset-inline-start: 0){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{left:-99999px}:host-context([dir=rtl]):host(.show-month-and-year) .calendar-next-prev,:host-context([dir=rtl]).show-month-and-year .calendar-next-prev,:host-context([dir=rtl]):host(.show-month-and-year) .calendar-days-of-week,:host-context([dir=rtl]).show-month-and-year .calendar-days-of-week,:host-context([dir=rtl]):host(.show-month-and-year) .calendar-body,:host-context([dir=rtl]).show-month-and-year .calendar-body,:host-context([dir=rtl]):host(.show-month-and-year) .datetime-time,:host-context([dir=rtl]).show-month-and-year .datetime-time{left:unset;right:unset;right:-99999px}@supports selector(:dir(rtl)){:host(.show-month-and-year:dir(rtl)) .calendar-next-prev,:host(.show-month-and-year:dir(rtl)) .calendar-days-of-week,:host(.show-month-and-year:dir(rtl)) .calendar-body,:host(.show-month-and-year:dir(rtl)) .datetime-time{left:unset;right:unset;right:-99999px}}}}@supports (not (background: -webkit-named-image(apple-pay-logo-black))) or ((background: -webkit-named-image(apple-pay-logo-black)) and (aspect-ratio: 1/1)){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{display:none}}:host(.month-year-picker-open) .datetime-footer{display:none}:host(.datetime-disabled){pointer-events:none}:host(.datetime-disabled) .calendar-days-of-week,:host(.datetime-disabled) .datetime-time{opacity:0.4}:host(.datetime-readonly){pointer-events:none;}:host(.datetime-readonly) .calendar-action-buttons,:host(.datetime-readonly) .calendar-body,:host(.datetime-readonly) .datetime-year{pointer-events:initial}:host(.datetime-readonly) .calendar-day[disabled]:not(.calendar-day-constrained),:host(.datetime-readonly) .datetime-action-buttons ion-button[disabled]{opacity:1}:host .datetime-header .datetime-title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}:host .datetime-action-buttons.has-clear-button{width:100%}:host .datetime-action-buttons ion-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}.datetime-action-buttons .datetime-action-buttons-container{display:-ms-flexbox;display:flex}:host .calendar-action-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host .calendar-action-buttons ion-item,:host .calendar-action-buttons ion-button{--background:translucent}:host .calendar-action-buttons ion-item ion-label{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;width:auto}:host .calendar-action-buttons ion-item ion-icon{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:0;padding-inline-end:0;padding-top:0;padding-bottom:0}:host .calendar-days-of-week{display:grid;grid-template-columns:repeat(7, 1fr);text-align:center}.calendar-days-of-week .day-of-week{-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto;margin-top:0;margin-bottom:0}:host .calendar-body{display:-ms-flexbox;display:flex;-ms-flex-positive:1;flex-grow:1;-webkit-scroll-snap-type:x mandatory;-ms-scroll-snap-type:x mandatory;scroll-snap-type:x mandatory;overflow-x:scroll;overflow-y:hidden;scrollbar-width:none;outline:none}:host .calendar-body .calendar-month{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;scroll-snap-align:start;scroll-snap-stop:always;-ms-flex-negative:0;flex-shrink:0;width:100%}:host .calendar-body .calendar-month-disabled{scroll-snap-align:none}:host .calendar-body::-webkit-scrollbar{display:none}:host .calendar-body .calendar-month-grid{display:grid;grid-template-columns:repeat(7, 1fr)}:host .calendar-day-wrapper{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;min-width:0;min-height:0;overflow:visible}.calendar-day{border-radius:50%;-webkit-padding-start:0px;padding-inline-start:0px;-webkit-padding-end:0px;padding-inline-end:0px;padding-top:0px;padding-bottom:0px;-webkit-margin-start:0px;margin-inline-start:0px;-webkit-margin-end:0px;margin-inline-end:0px;margin-top:0px;margin-bottom:0px;display:-ms-flexbox;display:flex;position:relative;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;border:none;outline:none;background:none;color:currentColor;font-family:var(--ion-font-family, inherit);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;z-index:0}:host .calendar-day[disabled]{pointer-events:none;opacity:0.4}.calendar-day:focus{background:rgba(var(--ion-color-base-rgb), 0.2);-webkit-box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2);box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2)}:host .datetime-time{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host(.datetime-presentation-time) .datetime-time{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0}:host ion-popover{--height:200px}:host .time-header{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}:host .time-body{border-radius:8px;-webkit-padding-start:12px;padding-inline-start:12px;-webkit-padding-end:12px;padding-inline-end:12px;padding-top:6px;padding-bottom:6px;display:-ms-flexbox;display:flex;border:none;background:var(--ion-color-step-300, #edeef0);color:var(--ion-text-color, #000);font-family:inherit;font-size:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}:host .time-body-active{color:var(--ion-color-base)}:host(.in-item){position:static}:host(.show-month-and-year) .calendar-action-buttons ion-item{--color:var(--ion-color-base)}:host{--background:var(--ion-color-light, #ffffff);--background-rgb:var(--ion-color-light-rgb);--title-color:var(--ion-color-step-600, #666666)}:host(.datetime-presentation-date-time:not(.datetime-prefer-wheel)),:host(.datetime-presentation-time-date:not(.datetime-prefer-wheel)),:host(.datetime-presentation-date:not(.datetime-prefer-wheel)){min-height:350px}:host .datetime-header{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:16px;padding-bottom:16px;border-bottom:0.55px solid var(--ion-color-step-200, #cccccc);font-size:min(0.875rem, 22.4px)}:host .datetime-header .datetime-title{color:var(--title-color)}:host .datetime-header .datetime-selected-date{margin-top:10px}:host .calendar-action-buttons ion-item{--padding-start:16px;--background-hover:transparent;--background-activated:transparent;font-size:min(1rem, 25.6px);font-weight:600}:host .calendar-action-buttons ion-item ion-icon,:host .calendar-action-buttons ion-buttons ion-button{color:var(--ion-color-base)}:host .calendar-action-buttons ion-buttons{padding-left:0;padding-right:0;padding-top:8px;padding-bottom:0}:host .calendar-action-buttons ion-buttons ion-button{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}:host .calendar-days-of-week{-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px;padding-top:0;padding-bottom:0;color:var(--ion-color-step-300, #b3b3b3);font-size:min(0.75rem, 19.2px);font-weight:600;line-height:24px;text-transform:uppercase}@supports (border-radius: mod(1px, 1px)){.calendar-days-of-week .day-of-week{width:clamp(20px, calc(mod(min(1rem, 24px), 24px) * 10), 100%);height:24px;overflow:hidden}.calendar-day{border-radius:max(8px, mod(min(1rem, 24px), 24px) * 10)}}@supports ((border-radius: mod(1px, 1px)) and (background: -webkit-named-image(apple-pay-logo-black)) and (not (contain-intrinsic-size: none))) or (not (border-radius: mod(1px, 1px))){.calendar-days-of-week .day-of-week{width:auto;height:auto;overflow:initial}.calendar-day{border-radius:32px}}:host .calendar-body .calendar-month .calendar-month-grid{-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px;padding-top:8px;padding-bottom:8px;-ms-flex-align:center;align-items:center;height:calc(100% - 16px)}:host .calendar-day-wrapper{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:4px;padding-inline-end:4px;padding-top:4px;padding-bottom:4px;height:0;min-height:1rem}:host .calendar-day{width:40px;min-width:40px;height:40px;font-size:min(1.25rem, 32px)}.calendar-day.calendar-day-active{background:rgba(var(--ion-color-base-rgb), 0.2)}:host .calendar-day.calendar-day-today{color:var(--ion-color-base)}:host .calendar-day.calendar-day-active{color:var(--ion-color-base);font-weight:600}:host .calendar-day.calendar-day-today.calendar-day-active{color:var(--ion-color-contrast)}:host .datetime-time{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:8px;padding-bottom:16px;font-size:min(1rem, 25.6px)}:host .datetime-time .time-header{font-weight:600}:host .datetime-buttons{-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px;padding-top:8px;padding-bottom:8px;border-top:0.55px solid var(--ion-color-step-200, #cccccc)}:host .datetime-buttons ::slotted(ion-buttons),:host .datetime-buttons ion-buttons{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:justify;justify-content:space-between}:host .datetime-action-buttons{width:100%}";
193
193
 
194
- const datetimeMdCss = ":host{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;background:var(--background);overflow:hidden}ion-picker-column-internal{min-width:26px}:host(.datetime-size-fixed){width:auto;height:auto}:host(.datetime-size-fixed:not(.datetime-prefer-wheel)){max-width:350px}:host(.datetime-size-fixed.datetime-prefer-wheel){min-width:350px;max-width:-webkit-max-content;max-width:-moz-max-content;max-width:max-content}:host(.datetime-size-cover){width:100%}:host .calendar-body,:host .datetime-year{opacity:0}:host(:not(.datetime-ready)) .datetime-year{position:absolute;pointer-events:none}:host(.datetime-ready) .calendar-body{opacity:1}:host(.datetime-ready) .datetime-year{display:none;opacity:1}:host .wheel-order-year-first .day-column{-ms-flex-order:3;order:3;text-align:end}:host .wheel-order-year-first .month-column{-ms-flex-order:2;order:2;text-align:end}:host .wheel-order-year-first .year-column{-ms-flex-order:1;order:1;text-align:start}:host .datetime-calendar,:host .datetime-year{display:-ms-flexbox;display:flex;-ms-flex:1 1 auto;flex:1 1 auto;-ms-flex-flow:column;flex-flow:column}:host(.show-month-and-year) .datetime-year{display:-ms-flexbox;display:flex}@supports (background: -webkit-named-image(apple-pay-logo-black)) and (not (aspect-ratio: 1/1)){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{position:absolute;visibility:hidden;pointer-events:none}@supports (inset-inline-start: 0){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{inset-inline-start:-99999px}}@supports not (inset-inline-start: 0){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{left:-99999px}:host-context([dir=rtl]):host(.show-month-and-year) .calendar-next-prev,:host-context([dir=rtl]).show-month-and-year .calendar-next-prev,:host-context([dir=rtl]):host(.show-month-and-year) .calendar-days-of-week,:host-context([dir=rtl]).show-month-and-year .calendar-days-of-week,:host-context([dir=rtl]):host(.show-month-and-year) .calendar-body,:host-context([dir=rtl]).show-month-and-year .calendar-body,:host-context([dir=rtl]):host(.show-month-and-year) .datetime-time,:host-context([dir=rtl]).show-month-and-year .datetime-time{left:unset;right:unset;right:-99999px}@supports selector(:dir(rtl)){:host(.show-month-and-year) .calendar-next-prev:dir(rtl),:host(.show-month-and-year) .calendar-days-of-week:dir(rtl),:host(.show-month-and-year) .calendar-body:dir(rtl),:host(.show-month-and-year) .datetime-time:dir(rtl){left:unset;right:unset;right:-99999px}}}}@supports (not (background: -webkit-named-image(apple-pay-logo-black))) or ((background: -webkit-named-image(apple-pay-logo-black)) and (aspect-ratio: 1/1)){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{display:none}}:host(.month-year-picker-open) .datetime-footer{display:none}:host(.datetime-readonly),:host(.datetime-disabled){pointer-events:none}:host(.datetime-disabled){opacity:0.4}:host .datetime-header .datetime-title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}:host .datetime-action-buttons.has-clear-button{width:100%}:host .datetime-action-buttons ion-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}.datetime-action-buttons .datetime-action-buttons-container{display:-ms-flexbox;display:flex}:host .calendar-action-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host .calendar-action-buttons ion-item,:host .calendar-action-buttons ion-button{--background:translucent}:host .calendar-action-buttons ion-item ion-label{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}:host .calendar-action-buttons ion-item ion-icon{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:0;padding-inline-end:0;padding-top:0;padding-bottom:0}:host .calendar-days-of-week{display:grid;grid-template-columns:repeat(7, 1fr);text-align:center}.calendar-days-of-week .day-of-week{-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto;margin-top:0;margin-bottom:0}:host .calendar-body{display:-ms-flexbox;display:flex;-ms-flex-positive:1;flex-grow:1;-webkit-scroll-snap-type:x mandatory;-ms-scroll-snap-type:x mandatory;scroll-snap-type:x mandatory;overflow-x:scroll;overflow-y:hidden;scrollbar-width:none;outline:none}:host .calendar-body .calendar-month{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;scroll-snap-align:start;scroll-snap-stop:always;-ms-flex-negative:0;flex-shrink:0;width:100%}:host .calendar-body .calendar-month-disabled{scroll-snap-align:none}:host .calendar-body::-webkit-scrollbar{display:none}:host .calendar-body .calendar-month-grid{display:grid;grid-template-columns:repeat(7, 1fr)}:host .calendar-day-wrapper{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;min-width:0;min-height:0;overflow:visible}.calendar-day{border-radius:50%;-webkit-padding-start:0px;padding-inline-start:0px;-webkit-padding-end:0px;padding-inline-end:0px;padding-top:0px;padding-bottom:0px;-webkit-margin-start:0px;margin-inline-start:0px;-webkit-margin-end:0px;margin-inline-end:0px;margin-top:0px;margin-bottom:0px;display:-ms-flexbox;display:flex;position:relative;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;border:none;outline:none;background:none;color:currentColor;font-family:var(--ion-font-family, inherit);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;z-index:0}:host .calendar-day[disabled]{pointer-events:none;opacity:0.4}.calendar-day:focus{background:rgba(var(--ion-color-base-rgb), 0.2);-webkit-box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2);box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2)}:host .datetime-time{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host(.datetime-presentation-time) .datetime-time{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0}:host ion-popover{--height:200px}:host .time-header{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}:host .time-body{border-radius:8px;-webkit-padding-start:12px;padding-inline-start:12px;-webkit-padding-end:12px;padding-inline-end:12px;padding-top:6px;padding-bottom:6px;display:-ms-flexbox;display:flex;border:none;background:var(--ion-color-step-300, #edeef0);color:var(--ion-text-color, #000);font-family:inherit;font-size:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}:host .time-body-active{color:var(--ion-color-base)}:host(.in-item){position:static}:host(.show-month-and-year) .calendar-action-buttons ion-item{--color:var(--ion-color-base)}:host{--background:var(--ion-color-step-100, #ffffff);--title-color:var(--ion-color-contrast)}:host .datetime-header{-webkit-padding-start:20px;padding-inline-start:20px;-webkit-padding-end:20px;padding-inline-end:20px;padding-top:20px;padding-bottom:20px;background:var(--ion-color-base);color:var(--title-color)}:host .datetime-header .datetime-title{font-size:0.75rem;text-transform:uppercase}:host .datetime-header .datetime-selected-date{margin-top:30px;font-size:2.125rem}:host .datetime-calendar .calendar-action-buttons ion-item{--padding-start:20px}:host .calendar-action-buttons ion-item,:host .calendar-action-buttons ion-button{--color:var(--ion-color-step-650, #595959)}:host .calendar-days-of-week{-webkit-padding-start:10px;padding-inline-start:10px;-webkit-padding-end:10px;padding-inline-end:10px;padding-top:0px;padding-bottom:0px;color:var(--ion-color-step-500, gray);font-size:0.875rem;line-height:36px}:host .calendar-body .calendar-month .calendar-month-grid{-webkit-padding-start:10px;padding-inline-start:10px;-webkit-padding-end:10px;padding-inline-end:10px;padding-top:4px;padding-bottom:4px;grid-template-rows:repeat(6, 1fr)}:host .calendar-day{width:42px;min-width:42px;height:42px;font-size:0.875rem}:host .calendar-day.calendar-day-today{border:1px solid var(--ion-color-base);color:var(--ion-color-base)}:host .calendar-day.calendar-day-active{color:var(--ion-color-contrast)}.calendar-day.calendar-day-active{border:1px solid var(--ion-color-base);background:var(--ion-color-base)}:host .datetime-time{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:8px;padding-bottom:8px}:host .time-header{color:var(--ion-color-step-650, #595959)}:host(.datetime-presentation-month) .datetime-year,:host(.datetime-presentation-year) .datetime-year,:host(.datetime-presentation-month-year) .datetime-year{margin-top:20px;margin-bottom:20px}:host .datetime-buttons{-webkit-padding-start:10px;padding-inline-start:10px;-webkit-padding-end:10px;padding-inline-end:10px;padding-top:10px;padding-bottom:10px;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:end;justify-content:flex-end}:host .datetime-view-buttons ion-button{color:var(--ion-color-step-800, #333333)}";
194
+ const datetimeMdCss = ":host{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;background:var(--background);overflow:hidden}ion-picker-column-internal{min-width:26px}:host(.datetime-size-fixed){width:auto;height:auto}:host(.datetime-size-fixed:not(.datetime-prefer-wheel)){max-width:350px}:host(.datetime-size-fixed.datetime-prefer-wheel){min-width:350px;max-width:-webkit-max-content;max-width:-moz-max-content;max-width:max-content}:host(.datetime-size-cover){width:100%}:host .calendar-body,:host .datetime-year{opacity:0}:host(:not(.datetime-ready)) .datetime-year{position:absolute;pointer-events:none}:host(.datetime-ready) .calendar-body{opacity:1}:host(.datetime-ready) .datetime-year{display:none;opacity:1}:host .wheel-order-year-first .day-column{-ms-flex-order:3;order:3;text-align:end}:host .wheel-order-year-first .month-column{-ms-flex-order:2;order:2;text-align:end}:host .wheel-order-year-first .year-column{-ms-flex-order:1;order:1;text-align:start}:host .datetime-calendar,:host .datetime-year{display:-ms-flexbox;display:flex;-ms-flex:1 1 auto;flex:1 1 auto;-ms-flex-flow:column;flex-flow:column}:host(.show-month-and-year) .datetime-year{display:-ms-flexbox;display:flex}@supports (background: -webkit-named-image(apple-pay-logo-black)) and (not (aspect-ratio: 1/1)){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{position:absolute;visibility:hidden;pointer-events:none}@supports (inset-inline-start: 0){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{inset-inline-start:-99999px}}@supports not (inset-inline-start: 0){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{left:-99999px}:host-context([dir=rtl]):host(.show-month-and-year) .calendar-next-prev,:host-context([dir=rtl]).show-month-and-year .calendar-next-prev,:host-context([dir=rtl]):host(.show-month-and-year) .calendar-days-of-week,:host-context([dir=rtl]).show-month-and-year .calendar-days-of-week,:host-context([dir=rtl]):host(.show-month-and-year) .calendar-body,:host-context([dir=rtl]).show-month-and-year .calendar-body,:host-context([dir=rtl]):host(.show-month-and-year) .datetime-time,:host-context([dir=rtl]).show-month-and-year .datetime-time{left:unset;right:unset;right:-99999px}@supports selector(:dir(rtl)){:host(.show-month-and-year:dir(rtl)) .calendar-next-prev,:host(.show-month-and-year:dir(rtl)) .calendar-days-of-week,:host(.show-month-and-year:dir(rtl)) .calendar-body,:host(.show-month-and-year:dir(rtl)) .datetime-time{left:unset;right:unset;right:-99999px}}}}@supports (not (background: -webkit-named-image(apple-pay-logo-black))) or ((background: -webkit-named-image(apple-pay-logo-black)) and (aspect-ratio: 1/1)){:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{display:none}}:host(.month-year-picker-open) .datetime-footer{display:none}:host(.datetime-disabled){pointer-events:none}:host(.datetime-disabled) .calendar-days-of-week,:host(.datetime-disabled) .datetime-time{opacity:0.4}:host(.datetime-readonly){pointer-events:none;}:host(.datetime-readonly) .calendar-action-buttons,:host(.datetime-readonly) .calendar-body,:host(.datetime-readonly) .datetime-year{pointer-events:initial}:host(.datetime-readonly) .calendar-day[disabled]:not(.calendar-day-constrained),:host(.datetime-readonly) .datetime-action-buttons ion-button[disabled]{opacity:1}:host .datetime-header .datetime-title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}:host .datetime-action-buttons.has-clear-button{width:100%}:host .datetime-action-buttons ion-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}.datetime-action-buttons .datetime-action-buttons-container{display:-ms-flexbox;display:flex}:host .calendar-action-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host .calendar-action-buttons ion-item,:host .calendar-action-buttons ion-button{--background:translucent}:host .calendar-action-buttons ion-item ion-label{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;width:auto}:host .calendar-action-buttons ion-item ion-icon{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:0;padding-inline-end:0;padding-top:0;padding-bottom:0}:host .calendar-days-of-week{display:grid;grid-template-columns:repeat(7, 1fr);text-align:center}.calendar-days-of-week .day-of-week{-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto;margin-top:0;margin-bottom:0}:host .calendar-body{display:-ms-flexbox;display:flex;-ms-flex-positive:1;flex-grow:1;-webkit-scroll-snap-type:x mandatory;-ms-scroll-snap-type:x mandatory;scroll-snap-type:x mandatory;overflow-x:scroll;overflow-y:hidden;scrollbar-width:none;outline:none}:host .calendar-body .calendar-month{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;scroll-snap-align:start;scroll-snap-stop:always;-ms-flex-negative:0;flex-shrink:0;width:100%}:host .calendar-body .calendar-month-disabled{scroll-snap-align:none}:host .calendar-body::-webkit-scrollbar{display:none}:host .calendar-body .calendar-month-grid{display:grid;grid-template-columns:repeat(7, 1fr)}:host .calendar-day-wrapper{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;min-width:0;min-height:0;overflow:visible}.calendar-day{border-radius:50%;-webkit-padding-start:0px;padding-inline-start:0px;-webkit-padding-end:0px;padding-inline-end:0px;padding-top:0px;padding-bottom:0px;-webkit-margin-start:0px;margin-inline-start:0px;-webkit-margin-end:0px;margin-inline-end:0px;margin-top:0px;margin-bottom:0px;display:-ms-flexbox;display:flex;position:relative;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;border:none;outline:none;background:none;color:currentColor;font-family:var(--ion-font-family, inherit);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;z-index:0}:host .calendar-day[disabled]{pointer-events:none;opacity:0.4}.calendar-day:focus{background:rgba(var(--ion-color-base-rgb), 0.2);-webkit-box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2);box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2)}:host .datetime-time{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host(.datetime-presentation-time) .datetime-time{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0}:host ion-popover{--height:200px}:host .time-header{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}:host .time-body{border-radius:8px;-webkit-padding-start:12px;padding-inline-start:12px;-webkit-padding-end:12px;padding-inline-end:12px;padding-top:6px;padding-bottom:6px;display:-ms-flexbox;display:flex;border:none;background:var(--ion-color-step-300, #edeef0);color:var(--ion-text-color, #000);font-family:inherit;font-size:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}:host .time-body-active{color:var(--ion-color-base)}:host(.in-item){position:static}:host(.show-month-and-year) .calendar-action-buttons ion-item{--color:var(--ion-color-base)}:host{--background:var(--ion-color-step-100, #ffffff);--title-color:var(--ion-color-contrast)}:host .datetime-header{-webkit-padding-start:20px;padding-inline-start:20px;-webkit-padding-end:20px;padding-inline-end:20px;padding-top:20px;padding-bottom:20px;background:var(--ion-color-base);color:var(--title-color)}:host .datetime-header .datetime-title{font-size:0.75rem;text-transform:uppercase}:host .datetime-header .datetime-selected-date{margin-top:30px;font-size:2.125rem}:host .datetime-calendar .calendar-action-buttons ion-item{--padding-start:20px}:host .calendar-action-buttons ion-item,:host .calendar-action-buttons ion-button{--color:var(--ion-color-step-650, #595959)}:host .calendar-days-of-week{-webkit-padding-start:10px;padding-inline-start:10px;-webkit-padding-end:10px;padding-inline-end:10px;padding-top:0px;padding-bottom:0px;color:var(--ion-color-step-500, gray);font-size:0.875rem;line-height:36px}:host .calendar-body .calendar-month .calendar-month-grid{-webkit-padding-start:10px;padding-inline-start:10px;-webkit-padding-end:10px;padding-inline-end:10px;padding-top:4px;padding-bottom:4px;grid-template-rows:repeat(6, 1fr)}:host .calendar-day{width:42px;min-width:42px;height:42px;font-size:0.875rem}:host .calendar-day.calendar-day-today{border:1px solid var(--ion-color-base);color:var(--ion-color-base)}:host .calendar-day.calendar-day-active{color:var(--ion-color-contrast)}.calendar-day.calendar-day-active{border:1px solid var(--ion-color-base);background:var(--ion-color-base)}:host .datetime-time{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:8px;padding-bottom:8px}:host .time-header{color:var(--ion-color-step-650, #595959)}:host(.datetime-presentation-month) .datetime-year,:host(.datetime-presentation-year) .datetime-year,:host(.datetime-presentation-month-year) .datetime-year{margin-top:20px;margin-bottom:20px}:host .datetime-buttons{-webkit-padding-start:10px;padding-inline-start:10px;-webkit-padding-end:10px;padding-inline-end:10px;padding-top:10px;padding-bottom:10px;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:end;justify-content:flex-end}";
195
195
 
196
196
  const Datetime = /*@__PURE__*/ proxyCustomElement(class Datetime extends HTMLElement {
197
- constructor() {
198
- super();
199
- this.__registerHost();
200
- this.__attachShadow();
201
- this.ionCancel = createEvent(this, "ionCancel", 7);
202
- this.ionChange = createEvent(this, "ionChange", 7);
203
- this.ionValueChange = createEvent(this, "ionValueChange", 7);
204
- this.ionFocus = createEvent(this, "ionFocus", 7);
205
- this.ionBlur = createEvent(this, "ionBlur", 7);
206
- this.ionStyle = createEvent(this, "ionStyle", 7);
207
- this.ionRender = createEvent(this, "ionRender", 7);
208
- this.inputId = `ion-dt-${datetimeIds++}`;
209
- this.prevPresentation = null;
210
- this.warnIfIncorrectValueUsage = () => {
211
- const { multiple, value } = this;
212
- if (!multiple && Array.isArray(value)) {
213
- /**
214
- * We do some processing on the `value` array so
215
- * that it looks more like an array when logged to
216
- * the console.
217
- * Example given ['a', 'b']
218
- * Default toString() behavior: a,b
219
- * Custom behavior: ['a', 'b']
220
- */
221
- printIonWarning(`ion-datetime was passed an array of values, but multiple="false". This is incorrect usage and may result in unexpected behaviors. To dismiss this warning, pass a string to the "value" property when multiple="false".
197
+ constructor() {
198
+ super();
199
+ this.__registerHost();
200
+ this.__attachShadow();
201
+ this.ionCancel = createEvent(this, "ionCancel", 7);
202
+ this.ionChange = createEvent(this, "ionChange", 7);
203
+ this.ionValueChange = createEvent(this, "ionValueChange", 7);
204
+ this.ionFocus = createEvent(this, "ionFocus", 7);
205
+ this.ionBlur = createEvent(this, "ionBlur", 7);
206
+ this.ionStyle = createEvent(this, "ionStyle", 7);
207
+ this.ionRender = createEvent(this, "ionRender", 7);
208
+ this.inputId = `ion-dt-${datetimeIds++}`;
209
+ this.prevPresentation = null;
210
+ this.warnIfIncorrectValueUsage = () => {
211
+ const { multiple, value } = this;
212
+ if (!multiple && Array.isArray(value)) {
213
+ /**
214
+ * We do some processing on the `value` array so
215
+ * that it looks more like an array when logged to
216
+ * the console.
217
+ * Example given ['a', 'b']
218
+ * Default toString() behavior: a,b
219
+ * Custom behavior: ['a', 'b']
220
+ */
221
+ printIonWarning(`ion-datetime was passed an array of values, but multiple="false". This is incorrect usage and may result in unexpected behaviors. To dismiss this warning, pass a string to the "value" property when multiple="false".
222
222
 
223
223
  Value Passed: [${value.map((v) => `'${v}'`).join(', ')}]
224
224
  `, this.el);
225
- }
226
- };
227
- this.setValue = (value) => {
228
- this.value = value;
229
- this.ionChange.emit({ value });
230
- };
231
- /**
232
- * Returns the DatetimePart interface
233
- * to use when rendering an initial set of
234
- * data. This should be used when rendering an
235
- * interface in an environment where the `value`
236
- * may not be set. This function works
237
- * by returning the first selected date and then
238
- * falling back to defaultParts if no active date
239
- * is selected.
240
- */
241
- this.getActivePartsWithFallback = () => {
242
- var _a;
243
- const { defaultParts } = this;
244
- return (_a = this.getActivePart()) !== null && _a !== void 0 ? _a : defaultParts;
245
- };
246
- this.getActivePart = () => {
247
- const { activeParts } = this;
248
- return Array.isArray(activeParts) ? activeParts[0] : activeParts;
249
- };
250
- this.closeParentOverlay = () => {
251
- const popoverOrModal = this.el.closest('ion-modal, ion-popover');
252
- if (popoverOrModal) {
253
- popoverOrModal.dismiss();
254
- }
255
- };
256
- this.setWorkingParts = (parts) => {
257
- this.workingParts = Object.assign({}, parts);
258
- };
259
- this.setActiveParts = (parts, removeDate = false) => {
260
- const { multiple, minParts, maxParts, activeParts } = this;
261
- /**
262
- * When setting the active parts, it is possible
263
- * to set invalid data. For example,
264
- * when updating January 31 to February,
265
- * February 31 does not exist. As a result
266
- * we need to validate the active parts and
267
- * ensure that we are only setting valid dates.
268
- * Additionally, we need to update the working parts
269
- * too in the event that the validated parts are different.
270
- */
271
- const validatedParts = validateParts(parts, minParts, maxParts);
272
- this.setWorkingParts(validatedParts);
273
- if (multiple) {
274
- const activePartsArray = Array.isArray(activeParts) ? activeParts : [activeParts];
275
- if (removeDate) {
276
- this.activeParts = activePartsArray.filter((p) => !isSameDay(p, validatedParts));
277
- }
278
- else {
279
- this.activeParts = [...activePartsArray, validatedParts];
280
- }
281
- }
282
- else {
283
- this.activeParts = Object.assign({}, validatedParts);
284
- }
285
- const hasSlottedButtons = this.el.querySelector('[slot="buttons"]') !== null;
286
- if (hasSlottedButtons || this.showDefaultButtons) {
287
- return;
288
- }
289
- this.confirm();
290
- };
291
- this.initializeKeyboardListeners = () => {
292
- const calendarBodyRef = this.calendarBodyRef;
293
- if (!calendarBodyRef) {
294
- return;
295
- }
296
- const root = this.el.shadowRoot;
297
- /**
298
- * Get a reference to the month
299
- * element we are currently viewing.
300
- */
301
- const currentMonth = calendarBodyRef.querySelector('.calendar-month:nth-of-type(2)');
302
- /**
303
- * When focusing the calendar body, we want to pass focus
304
- * to the working day, but other days should
305
- * only be accessible using the arrow keys. Pressing
306
- * Tab should jump between bodies of selectable content.
307
- */
308
- const checkCalendarBodyFocus = (ev) => {
309
- var _a;
310
- const record = ev[0];
311
- /**
312
- * If calendar body was already focused
313
- * when this fired or if the calendar body
314
- * if not currently focused, we should not re-focus
315
- * the inner day.
316
- */
317
- if (((_a = record.oldValue) === null || _a === void 0 ? void 0 : _a.includes('ion-focused')) || !calendarBodyRef.classList.contains('ion-focused')) {
318
- return;
319
- }
320
- this.focusWorkingDay(currentMonth);
321
- };
322
- const mo = new MutationObserver(checkCalendarBodyFocus);
323
- mo.observe(calendarBodyRef, { attributeFilter: ['class'], attributeOldValue: true });
324
- this.destroyKeyboardMO = () => {
325
- mo === null || mo === void 0 ? void 0 : mo.disconnect();
326
- };
327
- /**
328
- * We must use keydown not keyup as we want
329
- * to prevent scrolling when using the arrow keys.
330
- */
331
- calendarBodyRef.addEventListener('keydown', (ev) => {
332
- const activeElement = root.activeElement;
333
- if (!activeElement || !activeElement.classList.contains('calendar-day')) {
334
- return;
335
- }
336
- const parts = getPartsFromCalendarDay(activeElement);
337
- let partsToFocus;
338
- switch (ev.key) {
339
- case 'ArrowDown':
340
- ev.preventDefault();
341
- partsToFocus = getNextWeek(parts);
342
- break;
343
- case 'ArrowUp':
344
- ev.preventDefault();
345
- partsToFocus = getPreviousWeek(parts);
346
- break;
347
- case 'ArrowRight':
348
- ev.preventDefault();
349
- partsToFocus = getNextDay(parts);
350
- break;
351
- case 'ArrowLeft':
352
- ev.preventDefault();
353
- partsToFocus = getPreviousDay(parts);
354
- break;
355
- case 'Home':
356
- ev.preventDefault();
357
- partsToFocus = getStartOfWeek(parts);
358
- break;
359
- case 'End':
360
- ev.preventDefault();
361
- partsToFocus = getEndOfWeek(parts);
362
- break;
363
- case 'PageUp':
364
- ev.preventDefault();
365
- partsToFocus = ev.shiftKey ? getPreviousYear(parts) : getPreviousMonth(parts);
366
- break;
367
- case 'PageDown':
368
- ev.preventDefault();
369
- partsToFocus = ev.shiftKey ? getNextYear(parts) : getNextMonth(parts);
370
- break;
371
- /**
372
- * Do not preventDefault here
373
- * as we do not want to override other
374
- * browser defaults such as pressing Enter/Space
375
- * to select a day.
376
- */
377
- default:
378
- return;
379
- }
380
- /**
381
- * If the day we want to move focus to is
382
- * disabled, do not do anything.
383
- */
384
- if (isDayDisabled(partsToFocus, this.minParts, this.maxParts)) {
385
- return;
386
- }
387
- this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), partsToFocus));
225
+ }
226
+ };
227
+ this.setValue = (value) => {
228
+ this.value = value;
229
+ this.ionChange.emit({ value });
230
+ };
388
231
  /**
389
- * Give view a chance to re-render
390
- * then move focus to the new working day
232
+ * Returns the DatetimePart interface
233
+ * to use when rendering an initial set of
234
+ * data. This should be used when rendering an
235
+ * interface in an environment where the `value`
236
+ * may not be set. This function works
237
+ * by returning the first selected date and then
238
+ * falling back to defaultParts if no active date
239
+ * is selected.
391
240
  */
392
- requestAnimationFrame(() => this.focusWorkingDay(currentMonth));
393
- });
394
- };
395
- this.focusWorkingDay = (currentMonth) => {
396
- /**
397
- * Get the number of padding days so
398
- * we know how much to offset our next selector by
399
- * to grab the correct calendar-day element.
400
- */
401
- const padding = currentMonth.querySelectorAll('.calendar-day-padding');
402
- const { day } = this.workingParts;
403
- if (day === null) {
404
- return;
405
- }
406
- /**
407
- * Get the calendar day element
408
- * and focus it.
409
- */
410
- const dayEl = currentMonth.querySelector(`.calendar-day-wrapper:nth-of-type(${padding.length + day}) .calendar-day`);
411
- if (dayEl) {
412
- dayEl.focus();
413
- }
414
- };
415
- this.processMinParts = () => {
416
- const { min, defaultParts } = this;
417
- if (min === undefined) {
418
- this.minParts = undefined;
419
- return;
420
- }
421
- this.minParts = parseMinParts(min, defaultParts);
422
- };
423
- this.processMaxParts = () => {
424
- const { max, defaultParts } = this;
425
- if (max === undefined) {
426
- this.maxParts = undefined;
427
- return;
428
- }
429
- this.maxParts = parseMaxParts(max, defaultParts);
430
- };
431
- this.initializeCalendarListener = () => {
432
- const calendarBodyRef = this.calendarBodyRef;
433
- if (!calendarBodyRef) {
434
- return;
435
- }
436
- /**
437
- * For performance reasons, we only render 3
438
- * months at a time: The current month, the previous
439
- * month, and the next month. We have a scroll listener
440
- * on the calendar body to append/prepend new months.
441
- *
442
- * We can do this because Stencil is smart enough to not
443
- * re-create the .calendar-month containers, but rather
444
- * update the content within those containers.
445
- *
446
- * As an added bonus, WebKit has some troubles with
447
- * scroll-snap-stop: always, so not rendering all of
448
- * the months in a row allows us to mostly sidestep
449
- * that issue.
450
- */
451
- const months = calendarBodyRef.querySelectorAll('.calendar-month');
452
- const startMonth = months[0];
453
- const workingMonth = months[1];
454
- const endMonth = months[2];
455
- const mode = getIonMode(this);
456
- const needsiOSRubberBandFix = mode === 'ios' && typeof navigator !== 'undefined' && navigator.maxTouchPoints > 1;
457
- /**
458
- * Before setting up the scroll listener,
459
- * scroll the middle month into view.
460
- * scrollIntoView() will scroll entire page
461
- * if element is not in viewport. Use scrollLeft instead.
462
- */
463
- writeTask(() => {
464
- calendarBodyRef.scrollLeft = startMonth.clientWidth * (isRTL(this.el) ? -1 : 1);
465
- const getChangedMonth = (parts) => {
466
- const box = calendarBodyRef.getBoundingClientRect();
467
- /**
468
- * If the current scroll position is all the way to the left
469
- * then we have scrolled to the previous month.
470
- * Otherwise, assume that we have scrolled to the next
471
- * month. We have a tolerance of 2px to account for
472
- * sub pixel rendering.
473
- *
474
- * Check below the next line ensures that we did not
475
- * swipe and abort (i.e. we swiped but we are still on the current month).
476
- */
477
- const month = calendarBodyRef.scrollLeft <= 2 ? startMonth : endMonth;
478
- /**
479
- * The edge of the month must be lined up with
480
- * the edge of the calendar body in order for
481
- * the component to update. Otherwise, it
482
- * may be the case that the user has paused their
483
- * swipe or the browser has not finished snapping yet.
484
- * Rather than check if the x values are equal,
485
- * we give it a tolerance of 2px to account for
486
- * sub pixel rendering.
487
- */
488
- const monthBox = month.getBoundingClientRect();
489
- if (Math.abs(monthBox.x - box.x) > 2)
490
- return;
491
- /**
492
- * If we're force-rendering a month, assume we've
493
- * scrolled to that and return it.
494
- *
495
- * If forceRenderDate is ever used in a context where the
496
- * forced month is not immediately auto-scrolled to, this
497
- * should be updated to also check whether `month` has the
498
- * same month and year as the forced date.
499
- */
500
- const { forceRenderDate } = this;
501
- if (forceRenderDate !== undefined) {
502
- return { month: forceRenderDate.month, year: forceRenderDate.year, day: forceRenderDate.day };
503
- }
504
- /**
505
- * From here, we can determine if the start
506
- * month or the end month was scrolled into view.
507
- * If no month was changed, then we can return from
508
- * the scroll callback early.
509
- */
510
- if (month === startMonth) {
511
- return getPreviousMonth(parts);
512
- }
513
- else if (month === endMonth) {
514
- return getNextMonth(parts);
515
- }
516
- else {
517
- return;
518
- }
241
+ this.getActivePartsWithFallback = () => {
242
+ var _a;
243
+ const { defaultParts } = this;
244
+ return (_a = this.getActivePart()) !== null && _a !== void 0 ? _a : defaultParts;
519
245
  };
520
- const updateActiveMonth = () => {
521
- if (needsiOSRubberBandFix) {
522
- calendarBodyRef.style.removeProperty('pointer-events');
523
- appliediOSRubberBandFix = false;
524
- }
525
- /**
526
- * If the month did not change
527
- * then we can return early.
528
- */
529
- const newDate = getChangedMonth(this.workingParts);
530
- if (!newDate)
531
- return;
532
- const { month, day, year } = newDate;
533
- if (isMonthDisabled({ month, year, day: null }, {
534
- minParts: Object.assign(Object.assign({}, this.minParts), { day: null }),
535
- maxParts: Object.assign(Object.assign({}, this.maxParts), { day: null }),
536
- })) {
537
- return;
538
- }
539
- /**
540
- * Prevent scrolling for other browsers
541
- * to give the DOM time to update and the container
542
- * time to properly snap.
543
- */
544
- calendarBodyRef.style.setProperty('overflow', 'hidden');
545
- /**
546
- * Use a writeTask here to ensure
547
- * that the state is updated and the
548
- * correct month is scrolled into view
549
- * in the same frame. This is not
550
- * typically a problem on newer devices
551
- * but older/slower device may have a flicker
552
- * if we did not do this.
553
- */
554
- writeTask(() => {
555
- this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), { month, day: day, year }));
556
- calendarBodyRef.scrollLeft = workingMonth.clientWidth * (isRTL(this.el) ? -1 : 1);
557
- calendarBodyRef.style.removeProperty('overflow');
558
- if (this.resolveForceDateScrolling) {
559
- this.resolveForceDateScrolling();
246
+ this.getActivePart = () => {
247
+ const { activeParts } = this;
248
+ return Array.isArray(activeParts) ? activeParts[0] : activeParts;
249
+ };
250
+ this.closeParentOverlay = () => {
251
+ const popoverOrModal = this.el.closest('ion-modal, ion-popover');
252
+ if (popoverOrModal) {
253
+ popoverOrModal.dismiss();
560
254
  }
561
- });
562
255
  };
563
- /**
564
- * When the container finishes scrolling we
565
- * need to update the DOM with the selected month.
566
- */
567
- let scrollTimeout;
568
- /**
569
- * We do not want to attempt to set pointer-events
570
- * multiple times within a single swipe gesture as
571
- * that adds unnecessary work to the main thread.
572
- */
573
- let appliediOSRubberBandFix = false;
574
- const scrollCallback = () => {
575
- if (scrollTimeout) {
576
- clearTimeout(scrollTimeout);
577
- }
578
- /**
579
- * On iOS it is possible to quickly rubber band
580
- * the scroll area before the scroll timeout has fired.
581
- * This results in users reaching the end of the scrollable
582
- * container before the DOM has updated.
583
- * By setting `pointer-events: none` we can ensure that
584
- * subsequent swipes do not happen while the container
585
- * is snapping.
586
- */
587
- if (!appliediOSRubberBandFix && needsiOSRubberBandFix) {
588
- calendarBodyRef.style.setProperty('pointer-events', 'none');
589
- appliediOSRubberBandFix = true;
590
- }
591
- // Wait ~3 frames
592
- scrollTimeout = setTimeout(updateActiveMonth, 50);
256
+ this.setWorkingParts = (parts) => {
257
+ this.workingParts = Object.assign({}, parts);
593
258
  };
594
- calendarBodyRef.addEventListener('scroll', scrollCallback);
595
- this.destroyCalendarListener = () => {
596
- calendarBodyRef.removeEventListener('scroll', scrollCallback);
259
+ this.setActiveParts = (parts, removeDate = false) => {
260
+ /** if the datetime component is in readonly mode,
261
+ * allow browsing of the calendar without changing
262
+ * the set value
263
+ */
264
+ if (this.readonly) {
265
+ return;
266
+ }
267
+ const { multiple, minParts, maxParts, activeParts } = this;
268
+ /**
269
+ * When setting the active parts, it is possible
270
+ * to set invalid data. For example,
271
+ * when updating January 31 to February,
272
+ * February 31 does not exist. As a result
273
+ * we need to validate the active parts and
274
+ * ensure that we are only setting valid dates.
275
+ * Additionally, we need to update the working parts
276
+ * too in the event that the validated parts are different.
277
+ */
278
+ const validatedParts = validateParts(parts, minParts, maxParts);
279
+ this.setWorkingParts(validatedParts);
280
+ if (multiple) {
281
+ const activePartsArray = Array.isArray(activeParts) ? activeParts : [activeParts];
282
+ if (removeDate) {
283
+ this.activeParts = activePartsArray.filter((p) => !isSameDay(p, validatedParts));
284
+ }
285
+ else {
286
+ this.activeParts = [...activePartsArray, validatedParts];
287
+ }
288
+ }
289
+ else {
290
+ this.activeParts = Object.assign({}, validatedParts);
291
+ }
292
+ const hasSlottedButtons = this.el.querySelector('[slot="buttons"]') !== null;
293
+ if (hasSlottedButtons || this.showDefaultButtons) {
294
+ return;
295
+ }
296
+ this.confirm();
297
+ };
298
+ this.initializeKeyboardListeners = () => {
299
+ const calendarBodyRef = this.calendarBodyRef;
300
+ if (!calendarBodyRef) {
301
+ return;
302
+ }
303
+ const root = this.el.shadowRoot;
304
+ /**
305
+ * Get a reference to the month
306
+ * element we are currently viewing.
307
+ */
308
+ const currentMonth = calendarBodyRef.querySelector('.calendar-month:nth-of-type(2)');
309
+ /**
310
+ * When focusing the calendar body, we want to pass focus
311
+ * to the working day, but other days should
312
+ * only be accessible using the arrow keys. Pressing
313
+ * Tab should jump between bodies of selectable content.
314
+ */
315
+ const checkCalendarBodyFocus = (ev) => {
316
+ var _a;
317
+ const record = ev[0];
318
+ /**
319
+ * If calendar body was already focused
320
+ * when this fired or if the calendar body
321
+ * if not currently focused, we should not re-focus
322
+ * the inner day.
323
+ */
324
+ if (((_a = record.oldValue) === null || _a === void 0 ? void 0 : _a.includes('ion-focused')) || !calendarBodyRef.classList.contains('ion-focused')) {
325
+ return;
326
+ }
327
+ this.focusWorkingDay(currentMonth);
328
+ };
329
+ const mo = new MutationObserver(checkCalendarBodyFocus);
330
+ mo.observe(calendarBodyRef, { attributeFilter: ['class'], attributeOldValue: true });
331
+ this.destroyKeyboardMO = () => {
332
+ mo === null || mo === void 0 ? void 0 : mo.disconnect();
333
+ };
334
+ /**
335
+ * We must use keydown not keyup as we want
336
+ * to prevent scrolling when using the arrow keys.
337
+ */
338
+ calendarBodyRef.addEventListener('keydown', (ev) => {
339
+ const activeElement = root.activeElement;
340
+ if (!activeElement || !activeElement.classList.contains('calendar-day')) {
341
+ return;
342
+ }
343
+ const parts = getPartsFromCalendarDay(activeElement);
344
+ let partsToFocus;
345
+ switch (ev.key) {
346
+ case 'ArrowDown':
347
+ ev.preventDefault();
348
+ partsToFocus = getNextWeek(parts);
349
+ break;
350
+ case 'ArrowUp':
351
+ ev.preventDefault();
352
+ partsToFocus = getPreviousWeek(parts);
353
+ break;
354
+ case 'ArrowRight':
355
+ ev.preventDefault();
356
+ partsToFocus = getNextDay(parts);
357
+ break;
358
+ case 'ArrowLeft':
359
+ ev.preventDefault();
360
+ partsToFocus = getPreviousDay(parts);
361
+ break;
362
+ case 'Home':
363
+ ev.preventDefault();
364
+ partsToFocus = getStartOfWeek(parts);
365
+ break;
366
+ case 'End':
367
+ ev.preventDefault();
368
+ partsToFocus = getEndOfWeek(parts);
369
+ break;
370
+ case 'PageUp':
371
+ ev.preventDefault();
372
+ partsToFocus = ev.shiftKey ? getPreviousYear(parts) : getPreviousMonth(parts);
373
+ break;
374
+ case 'PageDown':
375
+ ev.preventDefault();
376
+ partsToFocus = ev.shiftKey ? getNextYear(parts) : getNextMonth(parts);
377
+ break;
378
+ /**
379
+ * Do not preventDefault here
380
+ * as we do not want to override other
381
+ * browser defaults such as pressing Enter/Space
382
+ * to select a day.
383
+ */
384
+ default:
385
+ return;
386
+ }
387
+ /**
388
+ * If the day we want to move focus to is
389
+ * disabled, do not do anything.
390
+ */
391
+ if (isDayDisabled(partsToFocus, this.minParts, this.maxParts)) {
392
+ return;
393
+ }
394
+ this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), partsToFocus));
395
+ /**
396
+ * Give view a chance to re-render
397
+ * then move focus to the new working day
398
+ */
399
+ requestAnimationFrame(() => this.focusWorkingDay(currentMonth));
400
+ });
401
+ };
402
+ this.focusWorkingDay = (currentMonth) => {
403
+ /**
404
+ * Get the number of padding days so
405
+ * we know how much to offset our next selector by
406
+ * to grab the correct calendar-day element.
407
+ */
408
+ const padding = currentMonth.querySelectorAll('.calendar-day-padding');
409
+ const { day } = this.workingParts;
410
+ if (day === null) {
411
+ return;
412
+ }
413
+ /**
414
+ * Get the calendar day element
415
+ * and focus it.
416
+ */
417
+ const dayEl = currentMonth.querySelector(`.calendar-day-wrapper:nth-of-type(${padding.length + day}) .calendar-day`);
418
+ if (dayEl) {
419
+ dayEl.focus();
420
+ }
421
+ };
422
+ this.processMinParts = () => {
423
+ const { min, defaultParts } = this;
424
+ if (min === undefined) {
425
+ this.minParts = undefined;
426
+ return;
427
+ }
428
+ this.minParts = parseMinParts(min, defaultParts);
429
+ };
430
+ this.processMaxParts = () => {
431
+ const { max, defaultParts } = this;
432
+ if (max === undefined) {
433
+ this.maxParts = undefined;
434
+ return;
435
+ }
436
+ this.maxParts = parseMaxParts(max, defaultParts);
437
+ };
438
+ this.initializeCalendarListener = () => {
439
+ const calendarBodyRef = this.calendarBodyRef;
440
+ if (!calendarBodyRef) {
441
+ return;
442
+ }
443
+ /**
444
+ * For performance reasons, we only render 3
445
+ * months at a time: The current month, the previous
446
+ * month, and the next month. We have a scroll listener
447
+ * on the calendar body to append/prepend new months.
448
+ *
449
+ * We can do this because Stencil is smart enough to not
450
+ * re-create the .calendar-month containers, but rather
451
+ * update the content within those containers.
452
+ *
453
+ * As an added bonus, WebKit has some troubles with
454
+ * scroll-snap-stop: always, so not rendering all of
455
+ * the months in a row allows us to mostly sidestep
456
+ * that issue.
457
+ */
458
+ const months = calendarBodyRef.querySelectorAll('.calendar-month');
459
+ const startMonth = months[0];
460
+ const workingMonth = months[1];
461
+ const endMonth = months[2];
462
+ const mode = getIonMode(this);
463
+ const needsiOSRubberBandFix = mode === 'ios' && typeof navigator !== 'undefined' && navigator.maxTouchPoints > 1;
464
+ /**
465
+ * Before setting up the scroll listener,
466
+ * scroll the middle month into view.
467
+ * scrollIntoView() will scroll entire page
468
+ * if element is not in viewport. Use scrollLeft instead.
469
+ */
470
+ writeTask(() => {
471
+ calendarBodyRef.scrollLeft = startMonth.clientWidth * (isRTL(this.el) ? -1 : 1);
472
+ const getChangedMonth = (parts) => {
473
+ const box = calendarBodyRef.getBoundingClientRect();
474
+ /**
475
+ * If the current scroll position is all the way to the left
476
+ * then we have scrolled to the previous month.
477
+ * Otherwise, assume that we have scrolled to the next
478
+ * month. We have a tolerance of 2px to account for
479
+ * sub pixel rendering.
480
+ *
481
+ * Check below the next line ensures that we did not
482
+ * swipe and abort (i.e. we swiped but we are still on the current month).
483
+ */
484
+ const month = calendarBodyRef.scrollLeft <= 2 ? startMonth : endMonth;
485
+ /**
486
+ * The edge of the month must be lined up with
487
+ * the edge of the calendar body in order for
488
+ * the component to update. Otherwise, it
489
+ * may be the case that the user has paused their
490
+ * swipe or the browser has not finished snapping yet.
491
+ * Rather than check if the x values are equal,
492
+ * we give it a tolerance of 2px to account for
493
+ * sub pixel rendering.
494
+ */
495
+ const monthBox = month.getBoundingClientRect();
496
+ if (Math.abs(monthBox.x - box.x) > 2)
497
+ return;
498
+ /**
499
+ * If we're force-rendering a month, assume we've
500
+ * scrolled to that and return it.
501
+ *
502
+ * If forceRenderDate is ever used in a context where the
503
+ * forced month is not immediately auto-scrolled to, this
504
+ * should be updated to also check whether `month` has the
505
+ * same month and year as the forced date.
506
+ */
507
+ const { forceRenderDate } = this;
508
+ if (forceRenderDate !== undefined) {
509
+ return { month: forceRenderDate.month, year: forceRenderDate.year, day: forceRenderDate.day };
510
+ }
511
+ /**
512
+ * From here, we can determine if the start
513
+ * month or the end month was scrolled into view.
514
+ * If no month was changed, then we can return from
515
+ * the scroll callback early.
516
+ */
517
+ if (month === startMonth) {
518
+ return getPreviousMonth(parts);
519
+ }
520
+ else if (month === endMonth) {
521
+ return getNextMonth(parts);
522
+ }
523
+ else {
524
+ return;
525
+ }
526
+ };
527
+ const updateActiveMonth = () => {
528
+ if (needsiOSRubberBandFix) {
529
+ calendarBodyRef.style.removeProperty('pointer-events');
530
+ appliediOSRubberBandFix = false;
531
+ }
532
+ /**
533
+ * If the month did not change
534
+ * then we can return early.
535
+ */
536
+ const newDate = getChangedMonth(this.workingParts);
537
+ if (!newDate)
538
+ return;
539
+ const { month, day, year } = newDate;
540
+ if (isMonthDisabled({ month, year, day: null }, {
541
+ minParts: Object.assign(Object.assign({}, this.minParts), { day: null }),
542
+ maxParts: Object.assign(Object.assign({}, this.maxParts), { day: null }),
543
+ })) {
544
+ return;
545
+ }
546
+ /**
547
+ * Prevent scrolling for other browsers
548
+ * to give the DOM time to update and the container
549
+ * time to properly snap.
550
+ */
551
+ calendarBodyRef.style.setProperty('overflow', 'hidden');
552
+ /**
553
+ * Use a writeTask here to ensure
554
+ * that the state is updated and the
555
+ * correct month is scrolled into view
556
+ * in the same frame. This is not
557
+ * typically a problem on newer devices
558
+ * but older/slower device may have a flicker
559
+ * if we did not do this.
560
+ */
561
+ writeTask(() => {
562
+ this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), { month, day: day, year }));
563
+ calendarBodyRef.scrollLeft = workingMonth.clientWidth * (isRTL(this.el) ? -1 : 1);
564
+ calendarBodyRef.style.removeProperty('overflow');
565
+ if (this.resolveForceDateScrolling) {
566
+ this.resolveForceDateScrolling();
567
+ }
568
+ });
569
+ };
570
+ /**
571
+ * When the container finishes scrolling we
572
+ * need to update the DOM with the selected month.
573
+ */
574
+ let scrollTimeout;
575
+ /**
576
+ * We do not want to attempt to set pointer-events
577
+ * multiple times within a single swipe gesture as
578
+ * that adds unnecessary work to the main thread.
579
+ */
580
+ let appliediOSRubberBandFix = false;
581
+ const scrollCallback = () => {
582
+ if (scrollTimeout) {
583
+ clearTimeout(scrollTimeout);
584
+ }
585
+ /**
586
+ * On iOS it is possible to quickly rubber band
587
+ * the scroll area before the scroll timeout has fired.
588
+ * This results in users reaching the end of the scrollable
589
+ * container before the DOM has updated.
590
+ * By setting `pointer-events: none` we can ensure that
591
+ * subsequent swipes do not happen while the container
592
+ * is snapping.
593
+ */
594
+ if (!appliediOSRubberBandFix && needsiOSRubberBandFix) {
595
+ calendarBodyRef.style.setProperty('pointer-events', 'none');
596
+ appliediOSRubberBandFix = true;
597
+ }
598
+ // Wait ~3 frames
599
+ scrollTimeout = setTimeout(updateActiveMonth, 50);
600
+ };
601
+ calendarBodyRef.addEventListener('scroll', scrollCallback);
602
+ this.destroyCalendarListener = () => {
603
+ calendarBodyRef.removeEventListener('scroll', scrollCallback);
604
+ };
605
+ });
597
606
  };
598
- });
599
- };
600
- /**
601
- * Clean up all listeners except for the overlay
602
- * listener. This is so that we can re-create the listeners
603
- * if the datetime has been hidden/presented by a modal or popover.
604
- */
605
- this.destroyInteractionListeners = () => {
606
- const { destroyCalendarListener, destroyKeyboardMO } = this;
607
- if (destroyCalendarListener !== undefined) {
608
- destroyCalendarListener();
609
- }
610
- if (destroyKeyboardMO !== undefined) {
611
- destroyKeyboardMO();
612
- }
613
- };
614
- this.processValue = (value) => {
615
- const hasValue = value !== null && value !== undefined && (!Array.isArray(value) || value.length > 0);
616
- const valueToProcess = hasValue ? parseDate(value) : this.defaultParts;
617
- const { minParts, maxParts, workingParts, el } = this;
618
- this.warnIfIncorrectValueUsage();
619
- /**
620
- * Return early if the value wasn't parsed correctly, such as
621
- * if an improperly formatted date string was provided.
622
- */
623
- if (!valueToProcess) {
624
- return;
625
- }
626
- /**
627
- * Datetime should only warn of out of bounds values
628
- * if set by the user. If the `value` is undefined,
629
- * we will default to today's date which may be out
630
- * of bounds. In this case, the warning makes it look
631
- * like the developer did something wrong which is
632
- * not true.
633
- */
634
- if (hasValue) {
635
- warnIfValueOutOfBounds(valueToProcess, minParts, maxParts);
636
- }
637
- /**
638
- * If there are multiple values, pick an arbitrary one to clamp to. This way,
639
- * if the values are across months, we always show at least one of them. Note
640
- * that the values don't necessarily have to be in order.
641
- */
642
- const singleValue = Array.isArray(valueToProcess) ? valueToProcess[0] : valueToProcess;
643
- const targetValue = clampDate(singleValue, minParts, maxParts);
644
- const { month, day, year, hour, minute } = targetValue;
645
- const ampm = parseAmPm(hour);
646
- /**
647
- * Since `activeParts` indicates a value that
648
- * been explicitly selected either by the
649
- * user or the app, only update `activeParts`
650
- * if the `value` property is set.
651
- */
652
- if (hasValue) {
653
- if (Array.isArray(valueToProcess)) {
654
- this.activeParts = [...valueToProcess];
655
- }
656
- else {
657
- this.activeParts = {
658
- month,
659
- day,
660
- year,
661
- hour,
662
- minute,
663
- ampm,
664
- };
665
- }
666
- }
667
- else {
668
607
  /**
669
- * Reset the active parts if the value is not set.
670
- * This will clear the selected calendar day when
671
- * performing a clear action or using the reset() method.
608
+ * Clean up all listeners except for the overlay
609
+ * listener. This is so that we can re-create the listeners
610
+ * if the datetime has been hidden/presented by a modal or popover.
672
611
  */
612
+ this.destroyInteractionListeners = () => {
613
+ const { destroyCalendarListener, destroyKeyboardMO } = this;
614
+ if (destroyCalendarListener !== undefined) {
615
+ destroyCalendarListener();
616
+ }
617
+ if (destroyKeyboardMO !== undefined) {
618
+ destroyKeyboardMO();
619
+ }
620
+ };
621
+ this.processValue = (value) => {
622
+ const hasValue = value !== null && value !== undefined && (!Array.isArray(value) || value.length > 0);
623
+ const valueToProcess = hasValue ? parseDate(value) : this.defaultParts;
624
+ const { minParts, maxParts, workingParts, el } = this;
625
+ this.warnIfIncorrectValueUsage();
626
+ /**
627
+ * Return early if the value wasn't parsed correctly, such as
628
+ * if an improperly formatted date string was provided.
629
+ */
630
+ if (!valueToProcess) {
631
+ return;
632
+ }
633
+ /**
634
+ * Datetime should only warn of out of bounds values
635
+ * if set by the user. If the `value` is undefined,
636
+ * we will default to today's date which may be out
637
+ * of bounds. In this case, the warning makes it look
638
+ * like the developer did something wrong which is
639
+ * not true.
640
+ */
641
+ if (hasValue) {
642
+ warnIfValueOutOfBounds(valueToProcess, minParts, maxParts);
643
+ }
644
+ /**
645
+ * If there are multiple values, pick an arbitrary one to clamp to. This way,
646
+ * if the values are across months, we always show at least one of them. Note
647
+ * that the values don't necessarily have to be in order.
648
+ */
649
+ const singleValue = Array.isArray(valueToProcess) ? valueToProcess[0] : valueToProcess;
650
+ const targetValue = clampDate(singleValue, minParts, maxParts);
651
+ const { month, day, year, hour, minute } = targetValue;
652
+ const ampm = parseAmPm(hour);
653
+ /**
654
+ * Since `activeParts` indicates a value that
655
+ * been explicitly selected either by the
656
+ * user or the app, only update `activeParts`
657
+ * if the `value` property is set.
658
+ */
659
+ if (hasValue) {
660
+ if (Array.isArray(valueToProcess)) {
661
+ this.activeParts = [...valueToProcess];
662
+ }
663
+ else {
664
+ this.activeParts = {
665
+ month,
666
+ day,
667
+ year,
668
+ hour,
669
+ minute,
670
+ ampm,
671
+ };
672
+ }
673
+ }
674
+ else {
675
+ /**
676
+ * Reset the active parts if the value is not set.
677
+ * This will clear the selected calendar day when
678
+ * performing a clear action or using the reset() method.
679
+ */
680
+ this.activeParts = [];
681
+ }
682
+ /**
683
+ * Only animate if:
684
+ * 1. We're using grid style (wheel style pickers should just jump to new value)
685
+ * 2. The month and/or year actually changed, and both are defined (otherwise there's nothing to animate to)
686
+ * 3. The calendar body is visible (prevents animation when in collapsed datetime-button, for example)
687
+ * 4. The month/year picker is not open (since you wouldn't see the animation anyway)
688
+ */
689
+ const didChangeMonth = (month !== undefined && month !== workingParts.month) || (year !== undefined && year !== workingParts.year);
690
+ const bodyIsVisible = el.classList.contains('datetime-ready');
691
+ const { isGridStyle, showMonthAndYear } = this;
692
+ if (isGridStyle && didChangeMonth && bodyIsVisible && !showMonthAndYear) {
693
+ this.animateToDate(targetValue);
694
+ }
695
+ else {
696
+ /**
697
+ * We only need to do this if we didn't just animate to a new month,
698
+ * since that calls prevMonth/nextMonth which calls setWorkingParts for us.
699
+ */
700
+ this.setWorkingParts({
701
+ month,
702
+ day,
703
+ year,
704
+ hour,
705
+ minute,
706
+ ampm,
707
+ });
708
+ }
709
+ };
710
+ this.animateToDate = async (targetValue) => {
711
+ const { workingParts } = this;
712
+ /**
713
+ * Tell other render functions that we need to force the
714
+ * target month to appear in place of the actual next/prev month.
715
+ * Because this is a State variable, a rerender will be triggered
716
+ * automatically, updating the rendered months.
717
+ */
718
+ this.forceRenderDate = targetValue;
719
+ /**
720
+ * Flag that we've started scrolling to the forced date.
721
+ * The resolve function will be called by the datetime's
722
+ * scroll listener when it's done updating everything.
723
+ * This is a replacement for making prev/nextMonth async,
724
+ * since the logic we're waiting on is in a listener.
725
+ */
726
+ const forceDateScrollingPromise = new Promise((resolve) => {
727
+ this.resolveForceDateScrolling = resolve;
728
+ });
729
+ /**
730
+ * Animate smoothly to the forced month. This will also update
731
+ * workingParts and correct the surrounding months for us.
732
+ */
733
+ const targetMonthIsBefore = isBefore(targetValue, workingParts);
734
+ targetMonthIsBefore ? this.prevMonth() : this.nextMonth();
735
+ await forceDateScrollingPromise;
736
+ this.resolveForceDateScrolling = undefined;
737
+ this.forceRenderDate = undefined;
738
+ };
739
+ this.onFocus = () => {
740
+ this.ionFocus.emit();
741
+ };
742
+ this.onBlur = () => {
743
+ this.ionBlur.emit();
744
+ };
745
+ this.hasValue = () => {
746
+ return this.value != null;
747
+ };
748
+ this.nextMonth = () => {
749
+ const calendarBodyRef = this.calendarBodyRef;
750
+ if (!calendarBodyRef) {
751
+ return;
752
+ }
753
+ const nextMonth = calendarBodyRef.querySelector('.calendar-month:last-of-type');
754
+ if (!nextMonth) {
755
+ return;
756
+ }
757
+ const left = nextMonth.offsetWidth * 2;
758
+ calendarBodyRef.scrollTo({
759
+ top: 0,
760
+ left: left * (isRTL(this.el) ? -1 : 1),
761
+ behavior: 'smooth',
762
+ });
763
+ };
764
+ this.prevMonth = () => {
765
+ const calendarBodyRef = this.calendarBodyRef;
766
+ if (!calendarBodyRef) {
767
+ return;
768
+ }
769
+ const prevMonth = calendarBodyRef.querySelector('.calendar-month:first-of-type');
770
+ if (!prevMonth) {
771
+ return;
772
+ }
773
+ calendarBodyRef.scrollTo({
774
+ top: 0,
775
+ left: 0,
776
+ behavior: 'smooth',
777
+ });
778
+ };
779
+ this.toggleMonthAndYearView = () => {
780
+ this.showMonthAndYear = !this.showMonthAndYear;
781
+ };
782
+ this.showMonthAndYear = false;
673
783
  this.activeParts = [];
674
- }
675
- /**
676
- * Only animate if:
677
- * 1. We're using grid style (wheel style pickers should just jump to new value)
678
- * 2. The month and/or year actually changed, and both are defined (otherwise there's nothing to animate to)
679
- * 3. The calendar body is visible (prevents animation when in collapsed datetime-button, for example)
680
- * 4. The month/year picker is not open (since you wouldn't see the animation anyway)
681
- */
682
- const didChangeMonth = (month !== undefined && month !== workingParts.month) || (year !== undefined && year !== workingParts.year);
683
- const bodyIsVisible = el.classList.contains('datetime-ready');
684
- const { isGridStyle, showMonthAndYear } = this;
685
- if (isGridStyle && didChangeMonth && bodyIsVisible && !showMonthAndYear) {
686
- this.animateToDate(targetValue);
687
- }
688
- else {
689
- /**
690
- * We only need to do this if we didn't just animate to a new month,
691
- * since that calls prevMonth/nextMonth which calls setWorkingParts for us.
692
- */
693
- this.setWorkingParts({
694
- month,
695
- day,
696
- year,
697
- hour,
698
- minute,
699
- ampm,
700
- });
701
- }
702
- };
703
- this.animateToDate = async (targetValue) => {
704
- const { workingParts } = this;
705
- /**
706
- * Tell other render functions that we need to force the
707
- * target month to appear in place of the actual next/prev month.
708
- * Because this is a State variable, a rerender will be triggered
709
- * automatically, updating the rendered months.
710
- */
711
- this.forceRenderDate = targetValue;
712
- /**
713
- * Flag that we've started scrolling to the forced date.
714
- * The resolve function will be called by the datetime's
715
- * scroll listener when it's done updating everything.
716
- * This is a replacement for making prev/nextMonth async,
717
- * since the logic we're waiting on is in a listener.
718
- */
719
- const forceDateScrollingPromise = new Promise((resolve) => {
720
- this.resolveForceDateScrolling = resolve;
721
- });
722
- /**
723
- * Animate smoothly to the forced month. This will also update
724
- * workingParts and correct the surrounding months for us.
725
- */
726
- const targetMonthIsBefore = isBefore(targetValue, workingParts);
727
- targetMonthIsBefore ? this.prevMonth() : this.nextMonth();
728
- await forceDateScrollingPromise;
729
- this.resolveForceDateScrolling = undefined;
730
- this.forceRenderDate = undefined;
731
- };
732
- this.onFocus = () => {
733
- this.ionFocus.emit();
734
- };
735
- this.onBlur = () => {
736
- this.ionBlur.emit();
737
- };
738
- this.hasValue = () => {
739
- return this.value != null;
740
- };
741
- this.nextMonth = () => {
742
- const calendarBodyRef = this.calendarBodyRef;
743
- if (!calendarBodyRef) {
744
- return;
745
- }
746
- const nextMonth = calendarBodyRef.querySelector('.calendar-month:last-of-type');
747
- if (!nextMonth) {
748
- return;
749
- }
750
- const left = nextMonth.offsetWidth * 2;
751
- calendarBodyRef.scrollTo({
752
- top: 0,
753
- left: left * (isRTL(this.el) ? -1 : 1),
754
- behavior: 'smooth',
755
- });
756
- };
757
- this.prevMonth = () => {
758
- const calendarBodyRef = this.calendarBodyRef;
759
- if (!calendarBodyRef) {
760
- return;
761
- }
762
- const prevMonth = calendarBodyRef.querySelector('.calendar-month:first-of-type');
763
- if (!prevMonth) {
764
- return;
765
- }
766
- calendarBodyRef.scrollTo({
767
- top: 0,
768
- left: 0,
769
- behavior: 'smooth',
770
- });
771
- };
772
- this.toggleMonthAndYearView = () => {
773
- this.showMonthAndYear = !this.showMonthAndYear;
774
- };
775
- this.showMonthAndYear = false;
776
- this.activeParts = [];
777
- this.workingParts = {
778
- month: 5,
779
- day: 28,
780
- year: 2021,
781
- hour: 13,
782
- minute: 52,
783
- ampm: 'pm',
784
- };
785
- this.isTimePopoverOpen = false;
786
- this.forceRenderDate = undefined;
787
- this.color = 'primary';
788
- this.name = this.inputId;
789
- this.disabled = false;
790
- this.readonly = false;
791
- this.isDateEnabled = undefined;
792
- this.min = undefined;
793
- this.max = undefined;
794
- this.presentation = 'date-time';
795
- this.cancelText = 'Cancel';
796
- this.doneText = 'Done';
797
- this.clearText = 'Clear';
798
- this.yearValues = undefined;
799
- this.monthValues = undefined;
800
- this.dayValues = undefined;
801
- this.hourValues = undefined;
802
- this.minuteValues = undefined;
803
- this.locale = 'default';
804
- this.firstDayOfWeek = 0;
805
- this.titleSelectedDatesFormatter = undefined;
806
- this.multiple = false;
807
- this.highlightedDates = undefined;
808
- this.value = undefined;
809
- this.showDefaultTitle = false;
810
- this.showDefaultButtons = false;
811
- this.showClearButton = false;
812
- this.showDefaultTimeLabel = true;
813
- this.hourCycle = undefined;
814
- this.size = 'fixed';
815
- this.preferWheel = false;
816
- }
817
- disabledChanged() {
818
- this.emitStyle();
819
- }
820
- minChanged() {
821
- this.processMinParts();
822
- }
823
- maxChanged() {
824
- this.processMaxParts();
825
- }
826
- get isGridStyle() {
827
- const { presentation, preferWheel } = this;
828
- const hasDatePresentation = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
829
- return hasDatePresentation && !preferWheel;
830
- }
831
- yearValuesChanged() {
832
- this.parsedYearValues = convertToArrayOfNumbers(this.yearValues);
833
- }
834
- monthValuesChanged() {
835
- this.parsedMonthValues = convertToArrayOfNumbers(this.monthValues);
836
- }
837
- dayValuesChanged() {
838
- this.parsedDayValues = convertToArrayOfNumbers(this.dayValues);
839
- }
840
- hourValuesChanged() {
841
- this.parsedHourValues = convertToArrayOfNumbers(this.hourValues);
842
- }
843
- minuteValuesChanged() {
844
- this.parsedMinuteValues = convertToArrayOfNumbers(this.minuteValues);
845
- }
846
- /**
847
- * Update the datetime value when the value changes
848
- */
849
- async valueChanged() {
850
- const { value } = this;
851
- if (this.hasValue()) {
852
- this.processValue(value);
784
+ this.workingParts = {
785
+ month: 5,
786
+ day: 28,
787
+ year: 2021,
788
+ hour: 13,
789
+ minute: 52,
790
+ ampm: 'pm',
791
+ };
792
+ this.isTimePopoverOpen = false;
793
+ this.forceRenderDate = undefined;
794
+ this.color = 'primary';
795
+ this.name = this.inputId;
796
+ this.disabled = false;
797
+ this.readonly = false;
798
+ this.isDateEnabled = undefined;
799
+ this.min = undefined;
800
+ this.max = undefined;
801
+ this.presentation = 'date-time';
802
+ this.cancelText = 'Cancel';
803
+ this.doneText = 'Done';
804
+ this.clearText = 'Clear';
805
+ this.yearValues = undefined;
806
+ this.monthValues = undefined;
807
+ this.dayValues = undefined;
808
+ this.hourValues = undefined;
809
+ this.minuteValues = undefined;
810
+ this.locale = 'default';
811
+ this.firstDayOfWeek = 0;
812
+ this.titleSelectedDatesFormatter = undefined;
813
+ this.multiple = false;
814
+ this.highlightedDates = undefined;
815
+ this.value = undefined;
816
+ this.showDefaultTitle = false;
817
+ this.showDefaultButtons = false;
818
+ this.showClearButton = false;
819
+ this.showDefaultTimeLabel = true;
820
+ this.hourCycle = undefined;
821
+ this.size = 'fixed';
822
+ this.preferWheel = false;
853
823
  }
854
- this.emitStyle();
855
- this.ionValueChange.emit({ value });
856
- }
857
- /**
858
- * Confirms the selected datetime value, updates the
859
- * `value` property, and optionally closes the popover
860
- * or modal that the datetime was presented in.
861
- */
862
- async confirm(closeOverlay = false) {
863
- const { isCalendarPicker, activeParts } = this;
864
- /**
865
- * We only update the value if the presentation is not a calendar picker.
866
- */
867
- if (activeParts !== undefined || !isCalendarPicker) {
868
- const activePartsIsArray = Array.isArray(activeParts);
869
- if (activePartsIsArray && activeParts.length === 0) {
870
- this.setValue(undefined);
871
- }
872
- else {
873
- this.setValue(convertDataToISO(activeParts));
874
- }
824
+ disabledChanged() {
825
+ this.emitStyle();
875
826
  }
876
- if (closeOverlay) {
877
- this.closeParentOverlay();
827
+ minChanged() {
828
+ this.processMinParts();
878
829
  }
879
- }
880
- /**
881
- * Resets the internal state of the datetime but does not update the value.
882
- * Passing a valid ISO-8601 string will reset the state of the component to the provided date.
883
- * If no value is provided, the internal state will be reset to the clamped value of the min, max and today.
884
- */
885
- async reset(startDate) {
886
- this.processValue(startDate);
887
- }
888
- /**
889
- * Emits the ionCancel event and
890
- * optionally closes the popover
891
- * or modal that the datetime was
892
- * presented in.
893
- */
894
- async cancel(closeOverlay = false) {
895
- this.ionCancel.emit();
896
- if (closeOverlay) {
897
- this.closeParentOverlay();
830
+ maxChanged() {
831
+ this.processMaxParts();
898
832
  }
899
- }
900
- get isCalendarPicker() {
901
- const { presentation } = this;
902
- return presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
903
- }
904
- connectedCallback() {
905
- this.clearFocusVisible = startFocusVisible(this.el).destroy;
906
- }
907
- disconnectedCallback() {
908
- if (this.clearFocusVisible) {
909
- this.clearFocusVisible();
910
- this.clearFocusVisible = undefined;
833
+ get isGridStyle() {
834
+ const { presentation, preferWheel } = this;
835
+ const hasDatePresentation = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
836
+ return hasDatePresentation && !preferWheel;
837
+ }
838
+ yearValuesChanged() {
839
+ this.parsedYearValues = convertToArrayOfNumbers(this.yearValues);
840
+ }
841
+ monthValuesChanged() {
842
+ this.parsedMonthValues = convertToArrayOfNumbers(this.monthValues);
843
+ }
844
+ dayValuesChanged() {
845
+ this.parsedDayValues = convertToArrayOfNumbers(this.dayValues);
846
+ }
847
+ hourValuesChanged() {
848
+ this.parsedHourValues = convertToArrayOfNumbers(this.hourValues);
849
+ }
850
+ minuteValuesChanged() {
851
+ this.parsedMinuteValues = convertToArrayOfNumbers(this.minuteValues);
911
852
  }
912
- }
913
- initializeListeners() {
914
- this.initializeCalendarListener();
915
- this.initializeKeyboardListeners();
916
- }
917
- componentDidLoad() {
918
- /**
919
- * If a scrollable element is hidden using `display: none`,
920
- * it will not have a scroll height meaning we cannot scroll elements
921
- * into view. As a result, we will need to wait for the datetime to become
922
- * visible if used inside of a modal or a popover otherwise the scrollable
923
- * areas will not have the correct values snapped into place.
924
- */
925
- const visibleCallback = (entries) => {
926
- const ev = entries[0];
927
- if (!ev.isIntersecting) {
928
- return;
929
- }
930
- this.initializeListeners();
931
- /**
932
- * TODO FW-2793: Datetime needs a frame to ensure that it
933
- * can properly scroll contents into view. As a result
934
- * we hide the scrollable content until after that frame
935
- * so users do not see the content quickly shifting. The downside
936
- * is that the content will pop into view a frame after. Maybe there
937
- * is a better way to handle this?
938
- */
939
- writeTask(() => {
940
- this.el.classList.add('datetime-ready');
941
- });
942
- };
943
- const visibleIO = new IntersectionObserver(visibleCallback, { threshold: 0.01 });
944
853
  /**
945
- * Use raf to avoid a race condition between the component loading and
946
- * its display animation starting (such as when shown in a modal). This
947
- * could cause the datetime to start at a visibility of 0, erroneously
948
- * triggering the `hiddenIO` observer below.
854
+ * Update the datetime value when the value changes
949
855
  */
950
- raf(() => visibleIO === null || visibleIO === void 0 ? void 0 : visibleIO.observe(this.el));
856
+ async valueChanged() {
857
+ const { value } = this;
858
+ if (this.hasValue()) {
859
+ this.processValue(value);
860
+ }
861
+ this.emitStyle();
862
+ this.ionValueChange.emit({ value });
863
+ }
951
864
  /**
952
- * We need to clean up listeners when the datetime is hidden
953
- * in a popover/modal so that we can properly scroll containers
954
- * back into view if they are re-presented. When the datetime is hidden
955
- * the scroll areas have scroll widths/heights of 0px, so any snapping
956
- * we did originally has been lost.
865
+ * Confirms the selected datetime value, updates the
866
+ * `value` property, and optionally closes the popover
867
+ * or modal that the datetime was presented in.
957
868
  */
958
- const hiddenCallback = (entries) => {
959
- const ev = entries[0];
960
- if (ev.isIntersecting) {
961
- return;
962
- }
963
- this.destroyInteractionListeners();
964
- /**
965
- * When datetime is hidden, we need to make sure that
966
- * the month/year picker is closed. Otherwise,
967
- * it will be open when the datetime re-appears
968
- * and the scroll area of the calendar grid will be 0.
969
- * As a result, the wrong month will be shown.
970
- */
971
- this.showMonthAndYear = false;
972
- writeTask(() => {
973
- this.el.classList.remove('datetime-ready');
974
- });
975
- };
976
- const hiddenIO = new IntersectionObserver(hiddenCallback, { threshold: 0 });
977
- raf(() => hiddenIO === null || hiddenIO === void 0 ? void 0 : hiddenIO.observe(this.el));
869
+ async confirm(closeOverlay = false) {
870
+ const { isCalendarPicker, activeParts } = this;
871
+ /**
872
+ * We only update the value if the presentation is not a calendar picker.
873
+ */
874
+ if (activeParts !== undefined || !isCalendarPicker) {
875
+ const activePartsIsArray = Array.isArray(activeParts);
876
+ if (activePartsIsArray && activeParts.length === 0) {
877
+ this.setValue(undefined);
878
+ }
879
+ else {
880
+ this.setValue(convertDataToISO(activeParts));
881
+ }
882
+ }
883
+ if (closeOverlay) {
884
+ this.closeParentOverlay();
885
+ }
886
+ }
978
887
  /**
979
- * Datetime uses Ionic components that emit
980
- * ionFocus and ionBlur. These events are
981
- * composed meaning they will cross
982
- * the shadow dom boundary. We need to
983
- * stop propagation on these events otherwise
984
- * developers will see 2 ionFocus or 2 ionBlur
985
- * events at a time.
888
+ * Resets the internal state of the datetime but does not update the value.
889
+ * Passing a valid ISO-8601 string will reset the state of the component to the provided date.
890
+ * If no value is provided, the internal state will be reset to the clamped value of the min, max and today.
986
891
  */
987
- const root = getElementRoot(this.el);
988
- root.addEventListener('ionFocus', (ev) => ev.stopPropagation());
989
- root.addEventListener('ionBlur', (ev) => ev.stopPropagation());
990
- }
991
- /**
992
- * When the presentation is changed, all calendar content is recreated,
993
- * so we need to re-init behavior with the new elements.
994
- */
995
- componentDidRender() {
996
- const { presentation, prevPresentation, calendarBodyRef, minParts, preferWheel } = this;
892
+ async reset(startDate) {
893
+ this.processValue(startDate);
894
+ }
997
895
  /**
998
- * TODO(FW-2165)
999
- * Remove this when https://bugs.webkit.org/show_bug.cgi?id=235960 is fixed.
1000
- * When using `min`, we add `scroll-snap-align: none`
1001
- * to the disabled month so that users cannot scroll to it.
1002
- * This triggers a bug in WebKit where the scroll position is reset.
1003
- * Since the month change logic is handled by a scroll listener,
1004
- * this causes the month to change leading to `scroll-snap-align`
1005
- * changing again, thus changing the scroll position again and causing
1006
- * an infinite loop.
1007
- * This issue only applies to the calendar grid, so we can disable
1008
- * it if the calendar grid is not being used.
896
+ * Emits the ionCancel event and
897
+ * optionally closes the popover
898
+ * or modal that the datetime was
899
+ * presented in.
1009
900
  */
1010
- const hasCalendarGrid = !preferWheel && ['date-time', 'time-date', 'date'].includes(presentation);
1011
- if (minParts !== undefined && hasCalendarGrid && calendarBodyRef) {
1012
- const workingMonth = calendarBodyRef.querySelector('.calendar-month:nth-of-type(1)');
1013
- if (workingMonth) {
1014
- calendarBodyRef.scrollLeft = workingMonth.clientWidth * (isRTL(this.el) ? -1 : 1);
1015
- }
901
+ async cancel(closeOverlay = false) {
902
+ this.ionCancel.emit();
903
+ if (closeOverlay) {
904
+ this.closeParentOverlay();
905
+ }
1016
906
  }
1017
- if (prevPresentation === null) {
1018
- this.prevPresentation = presentation;
1019
- return;
907
+ get isCalendarPicker() {
908
+ const { presentation } = this;
909
+ return presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
1020
910
  }
1021
- if (presentation === prevPresentation) {
1022
- return;
911
+ connectedCallback() {
912
+ this.clearFocusVisible = startFocusVisible(this.el).destroy;
1023
913
  }
1024
- this.prevPresentation = presentation;
1025
- this.destroyInteractionListeners();
1026
- this.initializeListeners();
1027
- /**
1028
- * The month/year picker from the date interface
1029
- * should be closed as it is not available in non-date
1030
- * interfaces.
1031
- */
1032
- this.showMonthAndYear = false;
1033
- raf(() => {
1034
- this.ionRender.emit();
1035
- });
1036
- }
1037
- componentWillLoad() {
1038
- const { el, highlightedDates, multiple, presentation, preferWheel } = this;
1039
- if (multiple) {
1040
- if (presentation !== 'date') {
1041
- printIonWarning('Multiple date selection is only supported for presentation="date".', el);
1042
- }
1043
- if (preferWheel) {
1044
- printIonWarning('Multiple date selection is not supported with preferWheel="true".', el);
1045
- }
914
+ disconnectedCallback() {
915
+ if (this.clearFocusVisible) {
916
+ this.clearFocusVisible();
917
+ this.clearFocusVisible = undefined;
918
+ }
1046
919
  }
1047
- if (highlightedDates !== undefined) {
1048
- if (presentation !== 'date' && presentation !== 'date-time' && presentation !== 'time-date') {
1049
- printIonWarning('The highlightedDates property is only supported with the date, date-time, and time-date presentations.', el);
1050
- }
1051
- if (preferWheel) {
1052
- printIonWarning('The highlightedDates property is not supported with preferWheel="true".', el);
1053
- }
920
+ initializeListeners() {
921
+ this.initializeCalendarListener();
922
+ this.initializeKeyboardListeners();
1054
923
  }
1055
- const hourValues = (this.parsedHourValues = convertToArrayOfNumbers(this.hourValues));
1056
- const minuteValues = (this.parsedMinuteValues = convertToArrayOfNumbers(this.minuteValues));
1057
- const monthValues = (this.parsedMonthValues = convertToArrayOfNumbers(this.monthValues));
1058
- const yearValues = (this.parsedYearValues = convertToArrayOfNumbers(this.yearValues));
1059
- const dayValues = (this.parsedDayValues = convertToArrayOfNumbers(this.dayValues));
1060
- const todayParts = (this.todayParts = parseDate(getToday()));
1061
- this.defaultParts = getClosestValidDate(todayParts, monthValues, dayValues, yearValues, hourValues, minuteValues);
1062
- this.processMinParts();
1063
- this.processMaxParts();
1064
- this.processValue(this.value);
1065
- this.emitStyle();
1066
- }
1067
- emitStyle() {
1068
- this.ionStyle.emit({
1069
- interactive: true,
1070
- datetime: true,
1071
- 'interactive-disabled': this.disabled,
1072
- });
1073
- }
1074
- /**
1075
- * Universal render methods
1076
- * These are pieces of datetime that
1077
- * are rendered independently of presentation.
1078
- */
1079
- renderFooter() {
1080
- const { showDefaultButtons, showClearButton } = this;
1081
- const hasSlottedButtons = this.el.querySelector('[slot="buttons"]') !== null;
1082
- if (!hasSlottedButtons && !showDefaultButtons && !showClearButton) {
1083
- return;
924
+ componentDidLoad() {
925
+ /**
926
+ * If a scrollable element is hidden using `display: none`,
927
+ * it will not have a scroll height meaning we cannot scroll elements
928
+ * into view. As a result, we will need to wait for the datetime to become
929
+ * visible if used inside of a modal or a popover otherwise the scrollable
930
+ * areas will not have the correct values snapped into place.
931
+ */
932
+ const visibleCallback = (entries) => {
933
+ const ev = entries[0];
934
+ if (!ev.isIntersecting) {
935
+ return;
936
+ }
937
+ this.initializeListeners();
938
+ /**
939
+ * TODO FW-2793: Datetime needs a frame to ensure that it
940
+ * can properly scroll contents into view. As a result
941
+ * we hide the scrollable content until after that frame
942
+ * so users do not see the content quickly shifting. The downside
943
+ * is that the content will pop into view a frame after. Maybe there
944
+ * is a better way to handle this?
945
+ */
946
+ writeTask(() => {
947
+ this.el.classList.add('datetime-ready');
948
+ });
949
+ };
950
+ const visibleIO = new IntersectionObserver(visibleCallback, { threshold: 0.01 });
951
+ /**
952
+ * Use raf to avoid a race condition between the component loading and
953
+ * its display animation starting (such as when shown in a modal). This
954
+ * could cause the datetime to start at a visibility of 0, erroneously
955
+ * triggering the `hiddenIO` observer below.
956
+ */
957
+ raf(() => visibleIO === null || visibleIO === void 0 ? void 0 : visibleIO.observe(this.el));
958
+ /**
959
+ * We need to clean up listeners when the datetime is hidden
960
+ * in a popover/modal so that we can properly scroll containers
961
+ * back into view if they are re-presented. When the datetime is hidden
962
+ * the scroll areas have scroll widths/heights of 0px, so any snapping
963
+ * we did originally has been lost.
964
+ */
965
+ const hiddenCallback = (entries) => {
966
+ const ev = entries[0];
967
+ if (ev.isIntersecting) {
968
+ return;
969
+ }
970
+ this.destroyInteractionListeners();
971
+ /**
972
+ * When datetime is hidden, we need to make sure that
973
+ * the month/year picker is closed. Otherwise,
974
+ * it will be open when the datetime re-appears
975
+ * and the scroll area of the calendar grid will be 0.
976
+ * As a result, the wrong month will be shown.
977
+ */
978
+ this.showMonthAndYear = false;
979
+ writeTask(() => {
980
+ this.el.classList.remove('datetime-ready');
981
+ });
982
+ };
983
+ const hiddenIO = new IntersectionObserver(hiddenCallback, { threshold: 0 });
984
+ raf(() => hiddenIO === null || hiddenIO === void 0 ? void 0 : hiddenIO.observe(this.el));
985
+ /**
986
+ * Datetime uses Ionic components that emit
987
+ * ionFocus and ionBlur. These events are
988
+ * composed meaning they will cross
989
+ * the shadow dom boundary. We need to
990
+ * stop propagation on these events otherwise
991
+ * developers will see 2 ionFocus or 2 ionBlur
992
+ * events at a time.
993
+ */
994
+ const root = getElementRoot(this.el);
995
+ root.addEventListener('ionFocus', (ev) => ev.stopPropagation());
996
+ root.addEventListener('ionBlur', (ev) => ev.stopPropagation());
1084
997
  }
1085
- const clearButtonClick = () => {
1086
- this.reset();
1087
- this.setValue(undefined);
1088
- };
1089
- /**
1090
- * By default we render two buttons:
1091
- * Cancel - Dismisses the datetime and
1092
- * does not update the `value` prop.
1093
- * OK - Dismisses the datetime and
1094
- * updates the `value` prop.
1095
- */
1096
- return (h("div", { class: "datetime-footer" }, h("div", { class: "datetime-buttons" }, h("div", { class: {
1097
- ['datetime-action-buttons']: true,
1098
- ['has-clear-button']: this.showClearButton,
1099
- } }, h("slot", { name: "buttons" }, h("ion-buttons", null, showDefaultButtons && (h("ion-button", { id: "cancel-button", color: this.color, onClick: () => this.cancel(true) }, this.cancelText)), h("div", { class: "datetime-action-buttons-container" }, showClearButton && (h("ion-button", { id: "clear-button", color: this.color, onClick: () => clearButtonClick() }, this.clearText)), showDefaultButtons && (h("ion-button", { id: "confirm-button", color: this.color, onClick: () => this.confirm(true) }, this.doneText)))))))));
1100
- }
1101
- /**
1102
- * Wheel picker render methods
1103
- */
1104
- renderWheelPicker(forcePresentation = this.presentation) {
1105
998
  /**
1106
- * If presentation="time-date" we switch the
1107
- * order of the render array here instead of
1108
- * manually reordering each date/time picker
1109
- * column with CSS. This allows for additional
1110
- * flexibility if we need to render subsets
1111
- * of the date/time data or do additional ordering
1112
- * within the child render functions.
999
+ * When the presentation is changed, all calendar content is recreated,
1000
+ * so we need to re-init behavior with the new elements.
1113
1001
  */
1114
- const renderArray = forcePresentation === 'time-date'
1115
- ? [this.renderTimePickerColumns(forcePresentation), this.renderDatePickerColumns(forcePresentation)]
1116
- : [this.renderDatePickerColumns(forcePresentation), this.renderTimePickerColumns(forcePresentation)];
1117
- return h("ion-picker-internal", null, renderArray);
1118
- }
1119
- renderDatePickerColumns(forcePresentation) {
1120
- return forcePresentation === 'date-time' || forcePresentation === 'time-date'
1121
- ? this.renderCombinedDatePickerColumn()
1122
- : this.renderIndividualDatePickerColumns(forcePresentation);
1123
- }
1124
- renderCombinedDatePickerColumn() {
1125
- const { defaultParts, workingParts, locale, minParts, maxParts, todayParts, isDateEnabled } = this;
1126
- const activePart = this.getActivePartsWithFallback();
1127
- /**
1128
- * By default, generate a range of 3 months:
1129
- * Previous month, current month, and next month
1130
- */
1131
- const monthsToRender = generateMonths(workingParts);
1132
- const lastMonth = monthsToRender[monthsToRender.length - 1];
1133
- /**
1134
- * Ensure that users can select the entire window of dates.
1135
- */
1136
- monthsToRender[0].day = 1;
1137
- lastMonth.day = getNumDaysInMonth(lastMonth.month, lastMonth.year);
1138
- /**
1139
- * Narrow the dates rendered based on min/max dates (if any).
1140
- * The `min` date is used if the min is after the generated min month.
1141
- * The `max` date is used if the max is before the generated max month.
1142
- * This ensures that the sliding window always stays at 3 months
1143
- * but still allows future dates to be lazily rendered based on any min/max
1144
- * constraints.
1145
- */
1146
- const min = minParts !== undefined && isAfter(minParts, monthsToRender[0]) ? minParts : monthsToRender[0];
1147
- const max = maxParts !== undefined && isBefore(maxParts, lastMonth) ? maxParts : lastMonth;
1148
- const result = getCombinedDateColumnData(locale, todayParts, min, max, this.parsedDayValues, this.parsedMonthValues);
1149
- let items = result.items;
1150
- const parts = result.parts;
1151
- if (isDateEnabled) {
1152
- items = items.map((itemObject, index) => {
1153
- const referenceParts = parts[index];
1154
- let disabled;
1155
- try {
1156
- /**
1157
- * The `isDateEnabled` implementation is try-catch wrapped
1158
- * to prevent exceptions in the user's function from
1159
- * interrupting the calendar rendering.
1160
- */
1161
- disabled = !isDateEnabled(convertDataToISO(referenceParts));
1002
+ componentDidRender() {
1003
+ const { presentation, prevPresentation, calendarBodyRef, minParts, preferWheel, forceRenderDate } = this;
1004
+ /**
1005
+ * TODO(FW-2165)
1006
+ * Remove this when https://bugs.webkit.org/show_bug.cgi?id=235960 is fixed.
1007
+ * When using `min`, we add `scroll-snap-align: none`
1008
+ * to the disabled month so that users cannot scroll to it.
1009
+ * This triggers a bug in WebKit where the scroll position is reset.
1010
+ * Since the month change logic is handled by a scroll listener,
1011
+ * this causes the month to change leading to `scroll-snap-align`
1012
+ * changing again, thus changing the scroll position again and causing
1013
+ * an infinite loop.
1014
+ * This issue only applies to the calendar grid, so we can disable
1015
+ * it if the calendar grid is not being used.
1016
+ */
1017
+ const hasCalendarGrid = !preferWheel && ['date-time', 'time-date', 'date'].includes(presentation);
1018
+ if (minParts !== undefined && hasCalendarGrid && calendarBodyRef) {
1019
+ const workingMonth = calendarBodyRef.querySelector('.calendar-month:nth-of-type(1)');
1020
+ /**
1021
+ * We need to make sure the datetime is not in the process
1022
+ * of scrolling to a new datetime value if the value
1023
+ * is updated programmatically.
1024
+ * Otherwise, the datetime will appear to not scroll at all because
1025
+ * we are resetting the scroll position to the center of the view.
1026
+ * Prior to the datetime's value being updated programmatically,
1027
+ * the calendarBodyRef is scrolled such that the middle month is centered
1028
+ * in the view. The below code updates the scroll position so the middle
1029
+ * month is also centered in the view. Since the scroll position did not change,
1030
+ * the scroll callback in this file does not fire,
1031
+ * and the resolveForceDateScrolling promise never resolves.
1032
+ */
1033
+ if (workingMonth && forceRenderDate === undefined) {
1034
+ calendarBodyRef.scrollLeft = workingMonth.clientWidth * (isRTL(this.el) ? -1 : 1);
1035
+ }
1162
1036
  }
1163
- catch (e) {
1164
- printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', e);
1037
+ if (prevPresentation === null) {
1038
+ this.prevPresentation = presentation;
1039
+ return;
1040
+ }
1041
+ if (presentation === prevPresentation) {
1042
+ return;
1165
1043
  }
1166
- return Object.assign(Object.assign({}, itemObject), { disabled });
1167
- });
1044
+ this.prevPresentation = presentation;
1045
+ this.destroyInteractionListeners();
1046
+ this.initializeListeners();
1047
+ /**
1048
+ * The month/year picker from the date interface
1049
+ * should be closed as it is not available in non-date
1050
+ * interfaces.
1051
+ */
1052
+ this.showMonthAndYear = false;
1053
+ raf(() => {
1054
+ this.ionRender.emit();
1055
+ });
1056
+ }
1057
+ componentWillLoad() {
1058
+ const { el, highlightedDates, multiple, presentation, preferWheel } = this;
1059
+ if (multiple) {
1060
+ if (presentation !== 'date') {
1061
+ printIonWarning('Multiple date selection is only supported for presentation="date".', el);
1062
+ }
1063
+ if (preferWheel) {
1064
+ printIonWarning('Multiple date selection is not supported with preferWheel="true".', el);
1065
+ }
1066
+ }
1067
+ if (highlightedDates !== undefined) {
1068
+ if (presentation !== 'date' && presentation !== 'date-time' && presentation !== 'time-date') {
1069
+ printIonWarning('The highlightedDates property is only supported with the date, date-time, and time-date presentations.', el);
1070
+ }
1071
+ if (preferWheel) {
1072
+ printIonWarning('The highlightedDates property is not supported with preferWheel="true".', el);
1073
+ }
1074
+ }
1075
+ const hourValues = (this.parsedHourValues = convertToArrayOfNumbers(this.hourValues));
1076
+ const minuteValues = (this.parsedMinuteValues = convertToArrayOfNumbers(this.minuteValues));
1077
+ const monthValues = (this.parsedMonthValues = convertToArrayOfNumbers(this.monthValues));
1078
+ const yearValues = (this.parsedYearValues = convertToArrayOfNumbers(this.yearValues));
1079
+ const dayValues = (this.parsedDayValues = convertToArrayOfNumbers(this.dayValues));
1080
+ const todayParts = (this.todayParts = parseDate(getToday()));
1081
+ this.defaultParts = getClosestValidDate(todayParts, monthValues, dayValues, yearValues, hourValues, minuteValues);
1082
+ this.processMinParts();
1083
+ this.processMaxParts();
1084
+ this.processValue(this.value);
1085
+ this.emitStyle();
1086
+ }
1087
+ emitStyle() {
1088
+ this.ionStyle.emit({
1089
+ interactive: true,
1090
+ datetime: true,
1091
+ 'interactive-disabled': this.disabled,
1092
+ });
1168
1093
  }
1169
1094
  /**
1170
- * If we have selected a day already, then default the column
1171
- * to that value. Otherwise, set it to the default date.
1095
+ * Universal render methods
1096
+ * These are pieces of datetime that
1097
+ * are rendered independently of presentation.
1172
1098
  */
1173
- const todayString = workingParts.day !== null
1174
- ? `${workingParts.year}-${workingParts.month}-${workingParts.day}`
1175
- : `${defaultParts.year}-${defaultParts.month}-${defaultParts.day}`;
1176
- return (h("ion-picker-column-internal", { class: "date-column", color: this.color, items: items, value: todayString, onIonChange: (ev) => {
1177
- // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1178
- // Due to a Safari 14 issue we need to destroy
1179
- // the scroll listener before we update state
1180
- // and trigger a re-render.
1181
- if (this.destroyCalendarListener) {
1182
- this.destroyCalendarListener();
1099
+ renderFooter() {
1100
+ const { disabled, readonly, showDefaultButtons, showClearButton } = this;
1101
+ /**
1102
+ * The cancel, clear, and confirm buttons
1103
+ * should not be interactive if the datetime
1104
+ * is disabled or readonly.
1105
+ */
1106
+ const isButtonDisabled = disabled || readonly;
1107
+ const hasSlottedButtons = this.el.querySelector('[slot="buttons"]') !== null;
1108
+ if (!hasSlottedButtons && !showDefaultButtons && !showClearButton) {
1109
+ return;
1183
1110
  }
1184
- const { value } = ev.detail;
1185
- const findPart = parts.find(({ month, day, year }) => value === `${year}-${month}-${day}`);
1186
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), findPart));
1187
- this.setActiveParts(Object.assign(Object.assign({}, activePart), findPart));
1188
- // We can re-attach the scroll listener after
1189
- // the working parts have been updated.
1190
- this.initializeCalendarListener();
1191
- ev.stopPropagation();
1192
- } }));
1193
- }
1194
- renderIndividualDatePickerColumns(forcePresentation) {
1195
- const { workingParts, isDateEnabled } = this;
1196
- const shouldRenderMonths = forcePresentation !== 'year' && forcePresentation !== 'time';
1197
- const months = shouldRenderMonths
1198
- ? getMonthColumnData(this.locale, workingParts, this.minParts, this.maxParts, this.parsedMonthValues)
1199
- : [];
1200
- const shouldRenderDays = forcePresentation === 'date';
1201
- let days = shouldRenderDays
1202
- ? getDayColumnData(this.locale, workingParts, this.minParts, this.maxParts, this.parsedDayValues)
1203
- : [];
1204
- if (isDateEnabled) {
1205
- days = days.map((dayObject) => {
1206
- const { value } = dayObject;
1207
- const valueNum = typeof value === 'string' ? parseInt(value) : value;
1208
- const referenceParts = {
1209
- month: workingParts.month,
1210
- day: valueNum,
1211
- year: workingParts.year,
1111
+ const clearButtonClick = () => {
1112
+ this.reset();
1113
+ this.setValue(undefined);
1212
1114
  };
1213
- let disabled;
1214
- try {
1215
- /**
1216
- * The `isDateEnabled` implementation is try-catch wrapped
1217
- * to prevent exceptions in the user's function from
1218
- * interrupting the calendar rendering.
1219
- */
1220
- disabled = !isDateEnabled(convertDataToISO(referenceParts));
1221
- }
1222
- catch (e) {
1223
- printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', e);
1224
- }
1225
- return Object.assign(Object.assign({}, dayObject), { disabled });
1226
- });
1115
+ /**
1116
+ * By default we render two buttons:
1117
+ * Cancel - Dismisses the datetime and
1118
+ * does not update the `value` prop.
1119
+ * OK - Dismisses the datetime and
1120
+ * updates the `value` prop.
1121
+ */
1122
+ return (h("div", { class: "datetime-footer" }, h("div", { class: "datetime-buttons" }, h("div", { class: {
1123
+ ['datetime-action-buttons']: true,
1124
+ ['has-clear-button']: this.showClearButton,
1125
+ } }, h("slot", { name: "buttons" }, h("ion-buttons", null, showDefaultButtons && (h("ion-button", { id: "cancel-button", color: this.color, onClick: () => this.cancel(true), disabled: isButtonDisabled }, this.cancelText)), h("div", { class: "datetime-action-buttons-container" }, showClearButton && (h("ion-button", { id: "clear-button", color: this.color, onClick: () => clearButtonClick(), disabled: isButtonDisabled }, this.clearText)), showDefaultButtons && (h("ion-button", { id: "confirm-button", color: this.color, onClick: () => this.confirm(true), disabled: isButtonDisabled }, this.doneText)))))))));
1227
1126
  }
1228
- const shouldRenderYears = forcePresentation !== 'month' && forcePresentation !== 'time';
1229
- const years = shouldRenderYears
1230
- ? getYearColumnData(this.locale, this.defaultParts, this.minParts, this.maxParts, this.parsedYearValues)
1231
- : [];
1232
1127
  /**
1233
- * Certain locales show the day before the month.
1128
+ * Wheel picker render methods
1234
1129
  */
1235
- const showMonthFirst = isMonthFirstLocale(this.locale, { month: 'numeric', day: 'numeric' });
1236
- let renderArray = [];
1237
- if (showMonthFirst) {
1238
- renderArray = [
1239
- this.renderMonthPickerColumn(months),
1240
- this.renderDayPickerColumn(days),
1241
- this.renderYearPickerColumn(years),
1242
- ];
1130
+ renderWheelPicker(forcePresentation = this.presentation) {
1131
+ /**
1132
+ * If presentation="time-date" we switch the
1133
+ * order of the render array here instead of
1134
+ * manually reordering each date/time picker
1135
+ * column with CSS. This allows for additional
1136
+ * flexibility if we need to render subsets
1137
+ * of the date/time data or do additional ordering
1138
+ * within the child render functions.
1139
+ */
1140
+ const renderArray = forcePresentation === 'time-date'
1141
+ ? [this.renderTimePickerColumns(forcePresentation), this.renderDatePickerColumns(forcePresentation)]
1142
+ : [this.renderDatePickerColumns(forcePresentation), this.renderTimePickerColumns(forcePresentation)];
1143
+ return h("ion-picker-internal", null, renderArray);
1243
1144
  }
1244
- else {
1245
- renderArray = [
1246
- this.renderDayPickerColumn(days),
1247
- this.renderMonthPickerColumn(months),
1248
- this.renderYearPickerColumn(years),
1249
- ];
1145
+ renderDatePickerColumns(forcePresentation) {
1146
+ return forcePresentation === 'date-time' || forcePresentation === 'time-date'
1147
+ ? this.renderCombinedDatePickerColumn()
1148
+ : this.renderIndividualDatePickerColumns(forcePresentation);
1250
1149
  }
1251
- return renderArray;
1252
- }
1253
- renderDayPickerColumn(days) {
1254
- var _a;
1255
- if (days.length === 0) {
1256
- return [];
1150
+ renderCombinedDatePickerColumn() {
1151
+ const { defaultParts, disabled, workingParts, locale, minParts, maxParts, todayParts, isDateEnabled } = this;
1152
+ const activePart = this.getActivePartsWithFallback();
1153
+ /**
1154
+ * By default, generate a range of 3 months:
1155
+ * Previous month, current month, and next month
1156
+ */
1157
+ const monthsToRender = generateMonths(workingParts);
1158
+ const lastMonth = monthsToRender[monthsToRender.length - 1];
1159
+ /**
1160
+ * Ensure that users can select the entire window of dates.
1161
+ */
1162
+ monthsToRender[0].day = 1;
1163
+ lastMonth.day = getNumDaysInMonth(lastMonth.month, lastMonth.year);
1164
+ /**
1165
+ * Narrow the dates rendered based on min/max dates (if any).
1166
+ * The `min` date is used if the min is after the generated min month.
1167
+ * The `max` date is used if the max is before the generated max month.
1168
+ * This ensures that the sliding window always stays at 3 months
1169
+ * but still allows future dates to be lazily rendered based on any min/max
1170
+ * constraints.
1171
+ */
1172
+ const min = minParts !== undefined && isAfter(minParts, monthsToRender[0]) ? minParts : monthsToRender[0];
1173
+ const max = maxParts !== undefined && isBefore(maxParts, lastMonth) ? maxParts : lastMonth;
1174
+ const result = getCombinedDateColumnData(locale, todayParts, min, max, this.parsedDayValues, this.parsedMonthValues);
1175
+ let items = result.items;
1176
+ const parts = result.parts;
1177
+ if (isDateEnabled) {
1178
+ items = items.map((itemObject, index) => {
1179
+ const referenceParts = parts[index];
1180
+ let disabled;
1181
+ try {
1182
+ /**
1183
+ * The `isDateEnabled` implementation is try-catch wrapped
1184
+ * to prevent exceptions in the user's function from
1185
+ * interrupting the calendar rendering.
1186
+ */
1187
+ disabled = !isDateEnabled(convertDataToISO(referenceParts));
1188
+ }
1189
+ catch (e) {
1190
+ printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', e);
1191
+ }
1192
+ return Object.assign(Object.assign({}, itemObject), { disabled });
1193
+ });
1194
+ }
1195
+ /**
1196
+ * If we have selected a day already, then default the column
1197
+ * to that value. Otherwise, set it to the default date.
1198
+ */
1199
+ const todayString = workingParts.day !== null
1200
+ ? `${workingParts.year}-${workingParts.month}-${workingParts.day}`
1201
+ : `${defaultParts.year}-${defaultParts.month}-${defaultParts.day}`;
1202
+ return (h("ion-picker-column-internal", { class: "date-column", color: this.color, disabled: disabled, items: items, value: todayString, onIonChange: (ev) => {
1203
+ // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1204
+ // Due to a Safari 14 issue we need to destroy
1205
+ // the scroll listener before we update state
1206
+ // and trigger a re-render.
1207
+ if (this.destroyCalendarListener) {
1208
+ this.destroyCalendarListener();
1209
+ }
1210
+ const { value } = ev.detail;
1211
+ const findPart = parts.find(({ month, day, year }) => value === `${year}-${month}-${day}`);
1212
+ this.setWorkingParts(Object.assign(Object.assign({}, workingParts), findPart));
1213
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), findPart));
1214
+ // We can re-attach the scroll listener after
1215
+ // the working parts have been updated.
1216
+ this.initializeCalendarListener();
1217
+ ev.stopPropagation();
1218
+ } }));
1257
1219
  }
1258
- const { workingParts } = this;
1259
- const activePart = this.getActivePartsWithFallback();
1260
- return (h("ion-picker-column-internal", { class: "day-column", color: this.color, items: days, value: (_a = (workingParts.day !== null ? workingParts.day : this.defaultParts.day)) !== null && _a !== void 0 ? _a : undefined, onIonChange: (ev) => {
1261
- // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1262
- // Due to a Safari 14 issue we need to destroy
1263
- // the scroll listener before we update state
1264
- // and trigger a re-render.
1265
- if (this.destroyCalendarListener) {
1266
- this.destroyCalendarListener();
1220
+ renderIndividualDatePickerColumns(forcePresentation) {
1221
+ const { workingParts, isDateEnabled } = this;
1222
+ const shouldRenderMonths = forcePresentation !== 'year' && forcePresentation !== 'time';
1223
+ const months = shouldRenderMonths
1224
+ ? getMonthColumnData(this.locale, workingParts, this.minParts, this.maxParts, this.parsedMonthValues)
1225
+ : [];
1226
+ const shouldRenderDays = forcePresentation === 'date';
1227
+ let days = shouldRenderDays
1228
+ ? getDayColumnData(this.locale, workingParts, this.minParts, this.maxParts, this.parsedDayValues)
1229
+ : [];
1230
+ if (isDateEnabled) {
1231
+ days = days.map((dayObject) => {
1232
+ const { value } = dayObject;
1233
+ const valueNum = typeof value === 'string' ? parseInt(value) : value;
1234
+ const referenceParts = {
1235
+ month: workingParts.month,
1236
+ day: valueNum,
1237
+ year: workingParts.year,
1238
+ };
1239
+ let disabled;
1240
+ try {
1241
+ /**
1242
+ * The `isDateEnabled` implementation is try-catch wrapped
1243
+ * to prevent exceptions in the user's function from
1244
+ * interrupting the calendar rendering.
1245
+ */
1246
+ disabled = !isDateEnabled(convertDataToISO(referenceParts));
1247
+ }
1248
+ catch (e) {
1249
+ printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', e);
1250
+ }
1251
+ return Object.assign(Object.assign({}, dayObject), { disabled });
1252
+ });
1267
1253
  }
1268
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { day: ev.detail.value }));
1269
- this.setActiveParts(Object.assign(Object.assign({}, activePart), { day: ev.detail.value }));
1270
- // We can re-attach the scroll listener after
1271
- // the working parts have been updated.
1272
- this.initializeCalendarListener();
1273
- ev.stopPropagation();
1274
- } }));
1275
- }
1276
- renderMonthPickerColumn(months) {
1277
- if (months.length === 0) {
1278
- return [];
1254
+ const shouldRenderYears = forcePresentation !== 'month' && forcePresentation !== 'time';
1255
+ const years = shouldRenderYears
1256
+ ? getYearColumnData(this.locale, this.defaultParts, this.minParts, this.maxParts, this.parsedYearValues)
1257
+ : [];
1258
+ /**
1259
+ * Certain locales show the day before the month.
1260
+ */
1261
+ const showMonthFirst = isMonthFirstLocale(this.locale, { month: 'numeric', day: 'numeric' });
1262
+ let renderArray = [];
1263
+ if (showMonthFirst) {
1264
+ renderArray = [
1265
+ this.renderMonthPickerColumn(months),
1266
+ this.renderDayPickerColumn(days),
1267
+ this.renderYearPickerColumn(years),
1268
+ ];
1269
+ }
1270
+ else {
1271
+ renderArray = [
1272
+ this.renderDayPickerColumn(days),
1273
+ this.renderMonthPickerColumn(months),
1274
+ this.renderYearPickerColumn(years),
1275
+ ];
1276
+ }
1277
+ return renderArray;
1279
1278
  }
1280
- const { workingParts } = this;
1281
- const activePart = this.getActivePartsWithFallback();
1282
- return (h("ion-picker-column-internal", { class: "month-column", color: this.color, items: months, value: workingParts.month, onIonChange: (ev) => {
1283
- // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1284
- // Due to a Safari 14 issue we need to destroy
1285
- // the scroll listener before we update state
1286
- // and trigger a re-render.
1287
- if (this.destroyCalendarListener) {
1288
- this.destroyCalendarListener();
1279
+ renderDayPickerColumn(days) {
1280
+ var _a;
1281
+ if (days.length === 0) {
1282
+ return [];
1289
1283
  }
1290
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { month: ev.detail.value }));
1291
- this.setActiveParts(Object.assign(Object.assign({}, activePart), { month: ev.detail.value }));
1292
- // We can re-attach the scroll listener after
1293
- // the working parts have been updated.
1294
- this.initializeCalendarListener();
1295
- ev.stopPropagation();
1296
- } }));
1297
- }
1298
- renderYearPickerColumn(years) {
1299
- if (years.length === 0) {
1300
- return [];
1284
+ const { disabled, workingParts } = this;
1285
+ const activePart = this.getActivePartsWithFallback();
1286
+ return (h("ion-picker-column-internal", { class: "day-column", color: this.color, disabled: disabled, items: days, value: (_a = (workingParts.day !== null ? workingParts.day : this.defaultParts.day)) !== null && _a !== void 0 ? _a : undefined, onIonChange: (ev) => {
1287
+ // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1288
+ // Due to a Safari 14 issue we need to destroy
1289
+ // the scroll listener before we update state
1290
+ // and trigger a re-render.
1291
+ if (this.destroyCalendarListener) {
1292
+ this.destroyCalendarListener();
1293
+ }
1294
+ this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { day: ev.detail.value }));
1295
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), { day: ev.detail.value }));
1296
+ // We can re-attach the scroll listener after
1297
+ // the working parts have been updated.
1298
+ this.initializeCalendarListener();
1299
+ ev.stopPropagation();
1300
+ } }));
1301
1301
  }
1302
- const { workingParts } = this;
1303
- const activePart = this.getActivePartsWithFallback();
1304
- return (h("ion-picker-column-internal", { class: "year-column", color: this.color, items: years, value: workingParts.year, onIonChange: (ev) => {
1305
- // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1306
- // Due to a Safari 14 issue we need to destroy
1307
- // the scroll listener before we update state
1308
- // and trigger a re-render.
1309
- if (this.destroyCalendarListener) {
1310
- this.destroyCalendarListener();
1302
+ renderMonthPickerColumn(months) {
1303
+ if (months.length === 0) {
1304
+ return [];
1311
1305
  }
1312
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { year: ev.detail.value }));
1313
- this.setActiveParts(Object.assign(Object.assign({}, activePart), { year: ev.detail.value }));
1314
- // We can re-attach the scroll listener after
1315
- // the working parts have been updated.
1316
- this.initializeCalendarListener();
1317
- ev.stopPropagation();
1318
- } }));
1319
- }
1320
- renderTimePickerColumns(forcePresentation) {
1321
- if (['date', 'month', 'month-year', 'year'].includes(forcePresentation)) {
1322
- return [];
1306
+ const { disabled, workingParts } = this;
1307
+ const activePart = this.getActivePartsWithFallback();
1308
+ return (h("ion-picker-column-internal", { class: "month-column", color: this.color, disabled: disabled, items: months, value: workingParts.month, onIonChange: (ev) => {
1309
+ // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1310
+ // Due to a Safari 14 issue we need to destroy
1311
+ // the scroll listener before we update state
1312
+ // and trigger a re-render.
1313
+ if (this.destroyCalendarListener) {
1314
+ this.destroyCalendarListener();
1315
+ }
1316
+ this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { month: ev.detail.value }));
1317
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), { month: ev.detail.value }));
1318
+ // We can re-attach the scroll listener after
1319
+ // the working parts have been updated.
1320
+ this.initializeCalendarListener();
1321
+ ev.stopPropagation();
1322
+ } }));
1323
1323
  }
1324
- /**
1325
- * If a user has not selected a date,
1326
- * then we should show all times. If the
1327
- * user has selected a date (even if it has
1328
- * not been confirmed yet), we should apply
1329
- * the max and min restrictions so that the
1330
- * time picker shows values that are
1331
- * appropriate for the selected date.
1332
- */
1333
- const activePart = this.getActivePart();
1334
- const userHasSelectedDate = activePart !== undefined;
1335
- const { hoursData, minutesData, dayPeriodData } = getTimeColumnsData(this.locale, this.workingParts, this.hourCycle, userHasSelectedDate ? this.minParts : undefined, userHasSelectedDate ? this.maxParts : undefined, this.parsedHourValues, this.parsedMinuteValues);
1336
- return [
1337
- this.renderHourPickerColumn(hoursData),
1338
- this.renderMinutePickerColumn(minutesData),
1339
- this.renderDayPeriodPickerColumn(dayPeriodData),
1340
- ];
1341
- }
1342
- renderHourPickerColumn(hoursData) {
1343
- const { workingParts } = this;
1344
- if (hoursData.length === 0)
1345
- return [];
1346
- const activePart = this.getActivePartsWithFallback();
1347
- return (h("ion-picker-column-internal", { color: this.color, value: activePart.hour, items: hoursData, numericInput: true, onIonChange: (ev) => {
1348
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { hour: ev.detail.value }));
1349
- this.setActiveParts(Object.assign(Object.assign({}, activePart), { hour: ev.detail.value }));
1350
- ev.stopPropagation();
1351
- } }));
1352
- }
1353
- renderMinutePickerColumn(minutesData) {
1354
- const { workingParts } = this;
1355
- if (minutesData.length === 0)
1356
- return [];
1357
- const activePart = this.getActivePartsWithFallback();
1358
- return (h("ion-picker-column-internal", { color: this.color, value: activePart.minute, items: minutesData, numericInput: true, onIonChange: (ev) => {
1359
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { minute: ev.detail.value }));
1360
- this.setActiveParts(Object.assign(Object.assign({}, activePart), { minute: ev.detail.value }));
1361
- ev.stopPropagation();
1362
- } }));
1363
- }
1364
- renderDayPeriodPickerColumn(dayPeriodData) {
1365
- const { workingParts } = this;
1366
- if (dayPeriodData.length === 0) {
1367
- return [];
1324
+ renderYearPickerColumn(years) {
1325
+ if (years.length === 0) {
1326
+ return [];
1327
+ }
1328
+ const { disabled, workingParts } = this;
1329
+ const activePart = this.getActivePartsWithFallback();
1330
+ return (h("ion-picker-column-internal", { class: "year-column", color: this.color, disabled: disabled, items: years, value: workingParts.year, onIonChange: (ev) => {
1331
+ // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1332
+ // Due to a Safari 14 issue we need to destroy
1333
+ // the scroll listener before we update state
1334
+ // and trigger a re-render.
1335
+ if (this.destroyCalendarListener) {
1336
+ this.destroyCalendarListener();
1337
+ }
1338
+ this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { year: ev.detail.value }));
1339
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), { year: ev.detail.value }));
1340
+ // We can re-attach the scroll listener after
1341
+ // the working parts have been updated.
1342
+ this.initializeCalendarListener();
1343
+ ev.stopPropagation();
1344
+ } }));
1368
1345
  }
1369
- const activePart = this.getActivePartsWithFallback();
1370
- const isDayPeriodRTL = isLocaleDayPeriodRTL(this.locale);
1371
- return (h("ion-picker-column-internal", { style: isDayPeriodRTL ? { order: '-1' } : {}, color: this.color, value: activePart.ampm, items: dayPeriodData, onIonChange: (ev) => {
1372
- const hour = calculateHourFromAMPM(workingParts, ev.detail.value);
1373
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { ampm: ev.detail.value, hour }));
1374
- this.setActiveParts(Object.assign(Object.assign({}, activePart), { ampm: ev.detail.value, hour }));
1375
- ev.stopPropagation();
1376
- } }));
1377
- }
1378
- renderWheelView(forcePresentation) {
1379
- const { locale } = this;
1380
- const showMonthFirst = isMonthFirstLocale(locale);
1381
- const columnOrder = showMonthFirst ? 'month-first' : 'year-first';
1382
- return (h("div", { class: {
1383
- [`wheel-order-${columnOrder}`]: true,
1384
- } }, this.renderWheelPicker(forcePresentation)));
1385
- }
1386
- /**
1387
- * Grid Render Methods
1388
- */
1389
- renderCalendarHeader(mode) {
1390
- const expandedIcon = mode === 'ios' ? chevronDown : caretUpSharp;
1391
- const collapsedIcon = mode === 'ios' ? chevronForward : caretDownSharp;
1392
- const prevMonthDisabled = isPrevMonthDisabled(this.workingParts, this.minParts, this.maxParts);
1393
- const nextMonthDisabled = isNextMonthDisabled(this.workingParts, this.maxParts);
1394
- // don't use the inheritAttributes util because it removes dir from the host, and we still need that
1395
- const hostDir = this.el.getAttribute('dir') || undefined;
1396
- return (h("div", { class: "calendar-header" }, h("div", { class: "calendar-action-buttons" }, h("div", { class: "calendar-month-year" }, h("ion-item", { part: "month-year-button", ref: (el) => (this.monthYearToggleItemRef = el), button: true, "aria-label": "Show year picker", detail: false, lines: "none", onClick: () => {
1397
- var _a;
1398
- this.toggleMonthAndYearView();
1346
+ renderTimePickerColumns(forcePresentation) {
1347
+ if (['date', 'month', 'month-year', 'year'].includes(forcePresentation)) {
1348
+ return [];
1349
+ }
1399
1350
  /**
1400
- * TODO: FW-3547
1401
- *
1402
- * Currently there is not a way to set the aria-label on the inner button
1403
- * on the `ion-item` and have it be reactive to changes. This is a workaround
1404
- * until we either refactor `ion-item` to a button or Stencil adds a way to
1405
- * have reactive props for built-in properties, such as `aria-label`.
1351
+ * If a user has not selected a date,
1352
+ * then we should show all times. If the
1353
+ * user has selected a date (even if it has
1354
+ * not been confirmed yet), we should apply
1355
+ * the max and min restrictions so that the
1356
+ * time picker shows values that are
1357
+ * appropriate for the selected date.
1406
1358
  */
1407
- const { monthYearToggleItemRef } = this;
1408
- if (monthYearToggleItemRef) {
1409
- const btn = (_a = monthYearToggleItemRef.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.item-native');
1410
- if (btn) {
1411
- const monthYearAriaLabel = this.showMonthAndYear ? 'Hide year picker' : 'Show year picker';
1412
- btn.setAttribute('aria-label', monthYearAriaLabel);
1413
- }
1414
- }
1415
- } }, h("ion-label", null, getMonthAndYear(this.locale, this.workingParts), h("ion-icon", { "aria-hidden": "true", icon: this.showMonthAndYear ? expandedIcon : collapsedIcon, lazy: false, flipRtl: true })))), h("div", { class: "calendar-next-prev" }, h("ion-buttons", null, h("ion-button", { "aria-label": "Previous month", disabled: prevMonthDisabled, onClick: () => this.prevMonth() }, h("ion-icon", { dir: hostDir, "aria-hidden": "true", slot: "icon-only", icon: chevronBack, lazy: false, flipRtl: true })), h("ion-button", { "aria-label": "Next month", disabled: nextMonthDisabled, onClick: () => this.nextMonth() }, h("ion-icon", { dir: hostDir, "aria-hidden": "true", slot: "icon-only", icon: chevronForward, lazy: false, flipRtl: true }))))), h("div", { class: "calendar-days-of-week", "aria-hidden": "true" }, getDaysOfWeek(this.locale, mode, this.firstDayOfWeek % 7).map((d) => {
1416
- return h("div", { class: "day-of-week" }, d);
1417
- }))));
1418
- }
1419
- renderMonth(month, year) {
1420
- const yearAllowed = this.parsedYearValues === undefined || this.parsedYearValues.includes(year);
1421
- const monthAllowed = this.parsedMonthValues === undefined || this.parsedMonthValues.includes(month);
1422
- const isCalMonthDisabled = !yearAllowed || !monthAllowed;
1423
- const swipeDisabled = isMonthDisabled({
1424
- month,
1425
- year,
1426
- day: null,
1427
- }, {
1428
- // The day is not used when checking if a month is disabled.
1429
- // Users should be able to access the min or max month, even if the
1430
- // min/max date is out of bounds (e.g. min is set to Feb 15, Feb should not be disabled).
1431
- minParts: Object.assign(Object.assign({}, this.minParts), { day: null }),
1432
- maxParts: Object.assign(Object.assign({}, this.maxParts), { day: null }),
1433
- });
1434
- // The working month should never have swipe disabled.
1435
- // Otherwise the CSS scroll snap will not work and the user
1436
- // can free-scroll the calendar.
1437
- const isWorkingMonth = this.workingParts.month === month && this.workingParts.year === year;
1438
- const activePart = this.getActivePartsWithFallback();
1439
- return (h("div", { "aria-hidden": !isWorkingMonth ? 'true' : null, class: {
1440
- 'calendar-month': true,
1441
- // Prevents scroll snap swipe gestures for months outside of the min/max bounds
1442
- 'calendar-month-disabled': !isWorkingMonth && swipeDisabled,
1443
- } }, h("div", { class: "calendar-month-grid" }, getDaysOfMonth(month, year, this.firstDayOfWeek % 7).map((dateObject, index) => {
1444
- const { day, dayOfWeek } = dateObject;
1445
- const { el, highlightedDates, isDateEnabled, multiple } = this;
1446
- const referenceParts = { month, day, year };
1447
- const isCalendarPadding = day === null;
1448
- const { isActive, isToday, ariaLabel, ariaSelected, disabled, text } = getCalendarDayState(this.locale, referenceParts, this.activeParts, this.todayParts, this.minParts, this.maxParts, this.parsedDayValues);
1449
- const dateIsoString = convertDataToISO(referenceParts);
1450
- let isCalDayDisabled = isCalMonthDisabled || disabled;
1451
- if (!isCalDayDisabled && isDateEnabled !== undefined) {
1452
- try {
1453
- /**
1454
- * The `isDateEnabled` implementation is try-catch wrapped
1455
- * to prevent exceptions in the user's function from
1456
- * interrupting the calendar rendering.
1457
- */
1458
- isCalDayDisabled = !isDateEnabled(dateIsoString);
1459
- }
1460
- catch (e) {
1461
- printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', el, e);
1359
+ const activePart = this.getActivePart();
1360
+ const userHasSelectedDate = activePart !== undefined;
1361
+ const { hoursData, minutesData, dayPeriodData } = getTimeColumnsData(this.locale, this.workingParts, this.hourCycle, userHasSelectedDate ? this.minParts : undefined, userHasSelectedDate ? this.maxParts : undefined, this.parsedHourValues, this.parsedMinuteValues);
1362
+ return [
1363
+ this.renderHourPickerColumn(hoursData),
1364
+ this.renderMinutePickerColumn(minutesData),
1365
+ this.renderDayPeriodPickerColumn(dayPeriodData),
1366
+ ];
1367
+ }
1368
+ renderHourPickerColumn(hoursData) {
1369
+ const { disabled, workingParts } = this;
1370
+ if (hoursData.length === 0)
1371
+ return [];
1372
+ const activePart = this.getActivePartsWithFallback();
1373
+ return (h("ion-picker-column-internal", { color: this.color, disabled: disabled, value: activePart.hour, items: hoursData, numericInput: true, onIonChange: (ev) => {
1374
+ this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { hour: ev.detail.value }));
1375
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), { hour: ev.detail.value }));
1376
+ ev.stopPropagation();
1377
+ } }));
1378
+ }
1379
+ renderMinutePickerColumn(minutesData) {
1380
+ const { disabled, workingParts } = this;
1381
+ if (minutesData.length === 0)
1382
+ return [];
1383
+ const activePart = this.getActivePartsWithFallback();
1384
+ return (h("ion-picker-column-internal", { color: this.color, disabled: disabled, value: activePart.minute, items: minutesData, numericInput: true, onIonChange: (ev) => {
1385
+ this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { minute: ev.detail.value }));
1386
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), { minute: ev.detail.value }));
1387
+ ev.stopPropagation();
1388
+ } }));
1389
+ }
1390
+ renderDayPeriodPickerColumn(dayPeriodData) {
1391
+ const { disabled, workingParts } = this;
1392
+ if (dayPeriodData.length === 0) {
1393
+ return [];
1462
1394
  }
1463
- }
1464
- let dateStyle = undefined;
1465
- /**
1466
- * Custom highlight styles should not override the style for selected dates,
1467
- * nor apply to "filler days" at the start of the grid.
1468
- */
1469
- if (highlightedDates !== undefined && !isActive && day !== null) {
1470
- dateStyle = getHighlightStyles(highlightedDates, dateIsoString, el);
1471
- }
1472
- let dateParts = undefined;
1473
- // "Filler days" at the beginning of the grid should not get the calendar day
1474
- // CSS parts added to them
1475
- if (!isCalendarPadding) {
1476
- dateParts = `calendar-day${isActive ? ' active' : ''}${isToday ? ' today' : ''}${isCalDayDisabled ? ' disabled' : ''}`;
1477
- }
1478
- return (h("div", { class: "calendar-day-wrapper" }, h("button", {
1479
- // We need to use !important for the inline styles here because
1480
- // otherwise the CSS shadow parts will override these styles.
1481
- // See https://github.com/WICG/webcomponents/issues/847
1482
- // Both the CSS shadow parts and highlightedDates styles are
1483
- // provided by the developer, but highlightedDates styles should
1484
- // always take priority.
1485
- ref: (el) => {
1486
- if (el) {
1487
- el.style.setProperty('color', `${dateStyle ? dateStyle.textColor : ''}`, 'important');
1488
- el.style.setProperty('background-color', `${dateStyle ? dateStyle.backgroundColor : ''}`, 'important');
1489
- }
1490
- }, tabindex: "-1", "data-day": day, "data-month": month, "data-year": year, "data-index": index, "data-day-of-week": dayOfWeek, disabled: isCalDayDisabled, class: {
1491
- 'calendar-day-padding': isCalendarPadding,
1492
- 'calendar-day': true,
1493
- 'calendar-day-active': isActive,
1494
- 'calendar-day-today': isToday,
1495
- }, part: dateParts, "aria-hidden": isCalendarPadding ? 'true' : null, "aria-selected": ariaSelected, "aria-label": ariaLabel, onClick: () => {
1496
- if (isCalendarPadding) {
1395
+ const activePart = this.getActivePartsWithFallback();
1396
+ const isDayPeriodRTL = isLocaleDayPeriodRTL(this.locale);
1397
+ return (h("ion-picker-column-internal", { style: isDayPeriodRTL ? { order: '-1' } : {}, color: this.color, disabled: disabled, value: activePart.ampm, items: dayPeriodData, onIonChange: (ev) => {
1398
+ const hour = calculateHourFromAMPM(workingParts, ev.detail.value);
1399
+ this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { ampm: ev.detail.value, hour }));
1400
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), { ampm: ev.detail.value, hour }));
1401
+ ev.stopPropagation();
1402
+ } }));
1403
+ }
1404
+ renderWheelView(forcePresentation) {
1405
+ const { locale } = this;
1406
+ const showMonthFirst = isMonthFirstLocale(locale);
1407
+ const columnOrder = showMonthFirst ? 'month-first' : 'year-first';
1408
+ return (h("div", { class: {
1409
+ [`wheel-order-${columnOrder}`]: true,
1410
+ } }, this.renderWheelPicker(forcePresentation)));
1411
+ }
1412
+ /**
1413
+ * Grid Render Methods
1414
+ */
1415
+ renderCalendarHeader(mode) {
1416
+ const { disabled } = this;
1417
+ const expandedIcon = mode === 'ios' ? chevronDown : caretUpSharp;
1418
+ const collapsedIcon = mode === 'ios' ? chevronForward : caretDownSharp;
1419
+ const prevMonthDisabled = disabled || isPrevMonthDisabled(this.workingParts, this.minParts, this.maxParts);
1420
+ const nextMonthDisabled = disabled || isNextMonthDisabled(this.workingParts, this.maxParts);
1421
+ // don't use the inheritAttributes util because it removes dir from the host, and we still need that
1422
+ const hostDir = this.el.getAttribute('dir') || undefined;
1423
+ return (h("div", { class: "calendar-header" }, h("div", { class: "calendar-action-buttons" }, h("div", { class: "calendar-month-year" }, h("ion-item", { part: "month-year-button", ref: (el) => (this.monthYearToggleItemRef = el), button: true, "aria-label": "Show year picker", detail: false, lines: "none", disabled: disabled, onClick: () => {
1424
+ var _a;
1425
+ this.toggleMonthAndYearView();
1426
+ /**
1427
+ * TODO: FW-3547
1428
+ *
1429
+ * Currently there is not a way to set the aria-label on the inner button
1430
+ * on the `ion-item` and have it be reactive to changes. This is a workaround
1431
+ * until we either refactor `ion-item` to a button or Stencil adds a way to
1432
+ * have reactive props for built-in properties, such as `aria-label`.
1433
+ */
1434
+ const { monthYearToggleItemRef } = this;
1435
+ if (monthYearToggleItemRef) {
1436
+ const btn = (_a = monthYearToggleItemRef.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.item-native');
1437
+ if (btn) {
1438
+ const monthYearAriaLabel = this.showMonthAndYear ? 'Hide year picker' : 'Show year picker';
1439
+ btn.setAttribute('aria-label', monthYearAriaLabel);
1440
+ }
1441
+ }
1442
+ } }, h("ion-label", null, getMonthAndYear(this.locale, this.workingParts), h("ion-icon", { "aria-hidden": "true", icon: this.showMonthAndYear ? expandedIcon : collapsedIcon, lazy: false, flipRtl: true })))), h("div", { class: "calendar-next-prev" }, h("ion-buttons", null, h("ion-button", { "aria-label": "Previous month", disabled: prevMonthDisabled, onClick: () => this.prevMonth() }, h("ion-icon", { dir: hostDir, "aria-hidden": "true", slot: "icon-only", icon: chevronBack, lazy: false, flipRtl: true })), h("ion-button", { "aria-label": "Next month", disabled: nextMonthDisabled, onClick: () => this.nextMonth() }, h("ion-icon", { dir: hostDir, "aria-hidden": "true", slot: "icon-only", icon: chevronForward, lazy: false, flipRtl: true }))))), h("div", { class: "calendar-days-of-week", "aria-hidden": "true" }, getDaysOfWeek(this.locale, mode, this.firstDayOfWeek % 7).map((d) => {
1443
+ return h("div", { class: "day-of-week" }, d);
1444
+ }))));
1445
+ }
1446
+ renderMonth(month, year) {
1447
+ const { disabled, readonly } = this;
1448
+ const yearAllowed = this.parsedYearValues === undefined || this.parsedYearValues.includes(year);
1449
+ const monthAllowed = this.parsedMonthValues === undefined || this.parsedMonthValues.includes(month);
1450
+ const isCalMonthDisabled = !yearAllowed || !monthAllowed;
1451
+ const isDatetimeDisabled = disabled || readonly;
1452
+ const swipeDisabled = disabled ||
1453
+ isMonthDisabled({
1454
+ month,
1455
+ year,
1456
+ day: null,
1457
+ }, {
1458
+ // The day is not used when checking if a month is disabled.
1459
+ // Users should be able to access the min or max month, even if the
1460
+ // min/max date is out of bounds (e.g. min is set to Feb 15, Feb should not be disabled).
1461
+ minParts: Object.assign(Object.assign({}, this.minParts), { day: null }),
1462
+ maxParts: Object.assign(Object.assign({}, this.maxParts), { day: null }),
1463
+ });
1464
+ // The working month should never have swipe disabled.
1465
+ // Otherwise the CSS scroll snap will not work and the user
1466
+ // can free-scroll the calendar.
1467
+ const isWorkingMonth = this.workingParts.month === month && this.workingParts.year === year;
1468
+ const activePart = this.getActivePartsWithFallback();
1469
+ return (h("div", { "aria-hidden": !isWorkingMonth ? 'true' : null, class: {
1470
+ 'calendar-month': true,
1471
+ // Prevents scroll snap swipe gestures for months outside of the min/max bounds
1472
+ 'calendar-month-disabled': !isWorkingMonth && swipeDisabled,
1473
+ } }, h("div", { class: "calendar-month-grid" }, getDaysOfMonth(month, year, this.firstDayOfWeek % 7).map((dateObject, index) => {
1474
+ const { day, dayOfWeek } = dateObject;
1475
+ const { el, highlightedDates, isDateEnabled, multiple } = this;
1476
+ const referenceParts = { month, day, year };
1477
+ const isCalendarPadding = day === null;
1478
+ const { isActive, isToday, ariaLabel, ariaSelected, disabled: isDayDisabled, text, } = getCalendarDayState(this.locale, referenceParts, this.activeParts, this.todayParts, this.minParts, this.maxParts, this.parsedDayValues);
1479
+ const dateIsoString = convertDataToISO(referenceParts);
1480
+ let isCalDayDisabled = isCalMonthDisabled || isDayDisabled;
1481
+ if (!isCalDayDisabled && isDateEnabled !== undefined) {
1482
+ try {
1483
+ /**
1484
+ * The `isDateEnabled` implementation is try-catch wrapped
1485
+ * to prevent exceptions in the user's function from
1486
+ * interrupting the calendar rendering.
1487
+ */
1488
+ isCalDayDisabled = !isDateEnabled(dateIsoString);
1489
+ }
1490
+ catch (e) {
1491
+ printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', el, e);
1492
+ }
1493
+ }
1494
+ /**
1495
+ * Some days are constrained through max & min or allowed dates
1496
+ * and also disabled because the component is readonly or disabled.
1497
+ * These need to be displayed differently.
1498
+ */
1499
+ const isCalDayConstrained = isCalDayDisabled && isDatetimeDisabled;
1500
+ const isButtonDisabled = isCalDayDisabled || isDatetimeDisabled;
1501
+ let dateStyle = undefined;
1502
+ /**
1503
+ * Custom highlight styles should not override the style for selected dates,
1504
+ * nor apply to "filler days" at the start of the grid.
1505
+ */
1506
+ if (highlightedDates !== undefined && !isActive && day !== null) {
1507
+ dateStyle = getHighlightStyles(highlightedDates, dateIsoString, el);
1508
+ }
1509
+ let dateParts = undefined;
1510
+ // "Filler days" at the beginning of the grid should not get the calendar day
1511
+ // CSS parts added to them
1512
+ if (!isCalendarPadding) {
1513
+ dateParts = `calendar-day${isActive ? ' active' : ''}${isToday ? ' today' : ''}${isCalDayDisabled ? ' disabled' : ''}`;
1514
+ }
1515
+ return (h("div", { class: "calendar-day-wrapper" }, h("button", {
1516
+ // We need to use !important for the inline styles here because
1517
+ // otherwise the CSS shadow parts will override these styles.
1518
+ // See https://github.com/WICG/webcomponents/issues/847
1519
+ // Both the CSS shadow parts and highlightedDates styles are
1520
+ // provided by the developer, but highlightedDates styles should
1521
+ // always take priority.
1522
+ ref: (el) => {
1523
+ if (el) {
1524
+ el.style.setProperty('color', `${dateStyle ? dateStyle.textColor : ''}`, 'important');
1525
+ el.style.setProperty('background-color', `${dateStyle ? dateStyle.backgroundColor : ''}`, 'important');
1526
+ }
1527
+ }, tabindex: "-1", "data-day": day, "data-month": month, "data-year": year, "data-index": index, "data-day-of-week": dayOfWeek, disabled: isButtonDisabled, class: {
1528
+ 'calendar-day-padding': isCalendarPadding,
1529
+ 'calendar-day': true,
1530
+ 'calendar-day-active': isActive,
1531
+ 'calendar-day-constrained': isCalDayConstrained,
1532
+ 'calendar-day-today': isToday,
1533
+ }, part: dateParts, "aria-hidden": isCalendarPadding ? 'true' : null, "aria-selected": ariaSelected, "aria-label": ariaLabel, onClick: () => {
1534
+ if (isCalendarPadding) {
1535
+ return;
1536
+ }
1537
+ this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), { month,
1538
+ day,
1539
+ year }));
1540
+ // multiple only needs date info, so we can wipe out other fields like time
1541
+ if (multiple) {
1542
+ this.setActiveParts({
1543
+ month,
1544
+ day,
1545
+ year,
1546
+ }, isActive);
1547
+ }
1548
+ else {
1549
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), { month,
1550
+ day,
1551
+ year }));
1552
+ }
1553
+ }
1554
+ }, text)));
1555
+ }))));
1556
+ }
1557
+ renderCalendarBody() {
1558
+ return (h("div", { class: "calendar-body ion-focusable", ref: (el) => (this.calendarBodyRef = el), tabindex: "0" }, generateMonths(this.workingParts, this.forceRenderDate).map(({ month, year }) => {
1559
+ return this.renderMonth(month, year);
1560
+ })));
1561
+ }
1562
+ renderCalendar(mode) {
1563
+ return (h("div", { class: "datetime-calendar", key: "datetime-calendar" }, this.renderCalendarHeader(mode), this.renderCalendarBody()));
1564
+ }
1565
+ renderTimeLabel() {
1566
+ const hasSlottedTimeLabel = this.el.querySelector('[slot="time-label"]') !== null;
1567
+ if (!hasSlottedTimeLabel && !this.showDefaultTimeLabel) {
1497
1568
  return;
1498
- }
1499
- this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), { month,
1500
- day,
1501
- year }));
1502
- // multiple only needs date info, so we can wipe out other fields like time
1503
- if (multiple) {
1504
- this.setActiveParts({
1505
- month,
1506
- day,
1507
- year,
1508
- }, isActive);
1509
- }
1510
- else {
1511
- this.setActiveParts(Object.assign(Object.assign({}, activePart), { month,
1512
- day,
1513
- year }));
1514
- }
1515
1569
  }
1516
- }, text)));
1517
- }))));
1518
- }
1519
- renderCalendarBody() {
1520
- return (h("div", { class: "calendar-body ion-focusable", ref: (el) => (this.calendarBodyRef = el), tabindex: "0" }, generateMonths(this.workingParts, this.forceRenderDate).map(({ month, year }) => {
1521
- return this.renderMonth(month, year);
1522
- })));
1523
- }
1524
- renderCalendar(mode) {
1525
- return (h("div", { class: "datetime-calendar", key: "datetime-calendar" }, this.renderCalendarHeader(mode), this.renderCalendarBody()));
1526
- }
1527
- renderTimeLabel() {
1528
- const hasSlottedTimeLabel = this.el.querySelector('[slot="time-label"]') !== null;
1529
- if (!hasSlottedTimeLabel && !this.showDefaultTimeLabel) {
1530
- return;
1570
+ return h("slot", { name: "time-label" }, "Time");
1531
1571
  }
1532
- return h("slot", { name: "time-label" }, "Time");
1533
- }
1534
- renderTimeOverlay() {
1535
- const { hourCycle, isTimePopoverOpen, locale } = this;
1536
- const computedHourCycle = getHourCycle(locale, hourCycle);
1537
- const activePart = this.getActivePartsWithFallback();
1538
- return [
1539
- h("div", { class: "time-header" }, this.renderTimeLabel()),
1540
- h("button", { class: {
1541
- 'time-body': true,
1542
- 'time-body-active': isTimePopoverOpen,
1543
- }, part: `time-button${isTimePopoverOpen ? ' active' : ''}`, "aria-expanded": "false", "aria-haspopup": "true", onClick: async (ev) => {
1544
- const { popoverRef } = this;
1545
- if (popoverRef) {
1546
- this.isTimePopoverOpen = true;
1547
- popoverRef.present(new CustomEvent('ionShadowTarget', {
1548
- detail: {
1549
- ionShadowTarget: ev.target,
1550
- },
1551
- }));
1552
- await popoverRef.onWillDismiss();
1553
- this.isTimePopoverOpen = false;
1554
- }
1555
- } }, getLocalizedTime(locale, activePart, computedHourCycle)),
1556
- h("ion-popover", { alignment: "center", translucent: true, overlayIndex: 1, arrow: false, onWillPresent: (ev) => {
1557
- /**
1558
- * Intersection Observers do not consistently fire between Blink and Webkit
1559
- * when toggling the visibility of the popover and trying to scroll the picker
1560
- * column to the correct time value.
1561
- *
1562
- * This will correctly scroll the element position to the correct time value,
1563
- * before the popover is fully presented.
1564
- */
1565
- const cols = ev.target.querySelectorAll('ion-picker-column-internal');
1566
- // TODO (FW-615): Potentially remove this when intersection observers are fixed in picker column
1567
- cols.forEach((col) => col.scrollActiveItemIntoView());
1568
- }, style: {
1569
- '--offset-y': '-10px',
1570
- '--min-width': 'fit-content',
1571
- },
1572
- // Allow native browser keyboard events to support up/down/home/end key
1573
- // navigation within the time picker.
1574
- keyboardEvents: true, ref: (el) => (this.popoverRef = el) }, this.renderWheelPicker('time')),
1575
- ];
1576
- }
1577
- getHeaderSelectedDateText() {
1578
- const { activeParts, multiple, titleSelectedDatesFormatter } = this;
1579
- const isArray = Array.isArray(activeParts);
1580
- let headerText;
1581
- if (multiple && isArray && activeParts.length !== 1) {
1582
- headerText = `${activeParts.length} days`; // default/fallback for multiple selection
1583
- if (titleSelectedDatesFormatter !== undefined) {
1584
- try {
1585
- headerText = titleSelectedDatesFormatter(convertDataToISO(activeParts));
1572
+ renderTimeOverlay() {
1573
+ const { disabled, hourCycle, isTimePopoverOpen, locale } = this;
1574
+ const computedHourCycle = getHourCycle(locale, hourCycle);
1575
+ const activePart = this.getActivePartsWithFallback();
1576
+ return [
1577
+ h("div", { class: "time-header" }, this.renderTimeLabel()),
1578
+ h("button", { class: {
1579
+ 'time-body': true,
1580
+ 'time-body-active': isTimePopoverOpen,
1581
+ }, part: `time-button${isTimePopoverOpen ? ' active' : ''}`, "aria-expanded": "false", "aria-haspopup": "true", disabled: disabled, onClick: async (ev) => {
1582
+ const { popoverRef } = this;
1583
+ if (popoverRef) {
1584
+ this.isTimePopoverOpen = true;
1585
+ popoverRef.present(new CustomEvent('ionShadowTarget', {
1586
+ detail: {
1587
+ ionShadowTarget: ev.target,
1588
+ },
1589
+ }));
1590
+ await popoverRef.onWillDismiss();
1591
+ this.isTimePopoverOpen = false;
1592
+ }
1593
+ } }, getLocalizedTime(locale, activePart, computedHourCycle)),
1594
+ h("ion-popover", { alignment: "center", translucent: true, overlayIndex: 1, arrow: false, onWillPresent: (ev) => {
1595
+ /**
1596
+ * Intersection Observers do not consistently fire between Blink and Webkit
1597
+ * when toggling the visibility of the popover and trying to scroll the picker
1598
+ * column to the correct time value.
1599
+ *
1600
+ * This will correctly scroll the element position to the correct time value,
1601
+ * before the popover is fully presented.
1602
+ */
1603
+ const cols = ev.target.querySelectorAll('ion-picker-column-internal');
1604
+ // TODO (FW-615): Potentially remove this when intersection observers are fixed in picker column
1605
+ cols.forEach((col) => col.scrollActiveItemIntoView());
1606
+ }, style: {
1607
+ '--offset-y': '-10px',
1608
+ '--min-width': 'fit-content',
1609
+ },
1610
+ // Allow native browser keyboard events to support up/down/home/end key
1611
+ // navigation within the time picker.
1612
+ keyboardEvents: true, ref: (el) => (this.popoverRef = el) }, this.renderWheelPicker('time')),
1613
+ ];
1614
+ }
1615
+ getHeaderSelectedDateText() {
1616
+ const { activeParts, multiple, titleSelectedDatesFormatter } = this;
1617
+ const isArray = Array.isArray(activeParts);
1618
+ let headerText;
1619
+ if (multiple && isArray && activeParts.length !== 1) {
1620
+ headerText = `${activeParts.length} days`; // default/fallback for multiple selection
1621
+ if (titleSelectedDatesFormatter !== undefined) {
1622
+ try {
1623
+ headerText = titleSelectedDatesFormatter(convertDataToISO(activeParts));
1624
+ }
1625
+ catch (e) {
1626
+ printIonError('Exception in provided `titleSelectedDatesFormatter`: ', e);
1627
+ }
1628
+ }
1586
1629
  }
1587
- catch (e) {
1588
- printIonError('Exception in provided `titleSelectedDatesFormatter`: ', e);
1630
+ else {
1631
+ // for exactly 1 day selected (multiple set or not), show a formatted version of that
1632
+ headerText = getMonthAndDay(this.locale, this.getActivePartsWithFallback());
1589
1633
  }
1590
- }
1634
+ return headerText;
1591
1635
  }
1592
- else {
1593
- // for exactly 1 day selected (multiple set or not), show a formatted version of that
1594
- headerText = getMonthAndDay(this.locale, this.getActivePartsWithFallback());
1636
+ renderHeader(showExpandedHeader = true) {
1637
+ const hasSlottedTitle = this.el.querySelector('[slot="title"]') !== null;
1638
+ if (!hasSlottedTitle && !this.showDefaultTitle) {
1639
+ return;
1640
+ }
1641
+ return (h("div", { class: "datetime-header" }, h("div", { class: "datetime-title" }, h("slot", { name: "title" }, "Select Date")), showExpandedHeader && h("div", { class: "datetime-selected-date" }, this.getHeaderSelectedDateText())));
1595
1642
  }
1596
- return headerText;
1597
- }
1598
- renderHeader(showExpandedHeader = true) {
1599
- const hasSlottedTitle = this.el.querySelector('[slot="title"]') !== null;
1600
- if (!hasSlottedTitle && !this.showDefaultTitle) {
1601
- return;
1643
+ /**
1644
+ * Render time picker inside of datetime.
1645
+ * Do not pass color prop to segment on
1646
+ * iOS mode. MD segment has been customized and
1647
+ * should take on the color prop, but iOS
1648
+ * should just be the default segment.
1649
+ */
1650
+ renderTime() {
1651
+ const { presentation } = this;
1652
+ const timeOnlyPresentation = presentation === 'time';
1653
+ return (h("div", { class: "datetime-time" }, timeOnlyPresentation ? this.renderWheelPicker() : this.renderTimeOverlay()));
1602
1654
  }
1603
- return (h("div", { class: "datetime-header" }, h("div", { class: "datetime-title" }, h("slot", { name: "title" }, "Select Date")), showExpandedHeader && h("div", { class: "datetime-selected-date" }, this.getHeaderSelectedDateText())));
1604
- }
1605
- /**
1606
- * Render time picker inside of datetime.
1607
- * Do not pass color prop to segment on
1608
- * iOS mode. MD segment has been customized and
1609
- * should take on the color prop, but iOS
1610
- * should just be the default segment.
1611
- */
1612
- renderTime() {
1613
- const { presentation } = this;
1614
- const timeOnlyPresentation = presentation === 'time';
1615
- return (h("div", { class: "datetime-time" }, timeOnlyPresentation ? this.renderWheelPicker() : this.renderTimeOverlay()));
1616
- }
1617
- /**
1618
- * Renders the month/year picker that is
1619
- * displayed on the calendar grid.
1620
- * The .datetime-year class has additional
1621
- * styles that let us show/hide the
1622
- * picker when the user clicks on the
1623
- * toggle in the calendar header.
1624
- */
1625
- renderCalendarViewMonthYearPicker() {
1626
- return h("div", { class: "datetime-year" }, this.renderWheelView('month-year'));
1627
- }
1628
- /**
1629
- * Render entry point
1630
- * All presentation types are rendered from here.
1631
- */
1632
- renderDatetime(mode) {
1633
- const { presentation, preferWheel } = this;
1634
1655
  /**
1635
- * Certain presentation types have separate grid and wheel displays.
1636
- * If preferWheel is true then we should show a wheel picker instead.
1656
+ * Renders the month/year picker that is
1657
+ * displayed on the calendar grid.
1658
+ * The .datetime-year class has additional
1659
+ * styles that let us show/hide the
1660
+ * picker when the user clicks on the
1661
+ * toggle in the calendar header.
1637
1662
  */
1638
- const hasWheelVariant = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
1639
- if (preferWheel && hasWheelVariant) {
1640
- return [this.renderHeader(false), this.renderWheelView(), this.renderFooter()];
1663
+ renderCalendarViewMonthYearPicker() {
1664
+ return h("div", { class: "datetime-year" }, this.renderWheelView('month-year'));
1641
1665
  }
1642
- switch (presentation) {
1643
- case 'date-time':
1644
- return [
1645
- this.renderHeader(),
1646
- this.renderCalendar(mode),
1647
- this.renderCalendarViewMonthYearPicker(),
1648
- this.renderTime(),
1649
- this.renderFooter(),
1650
- ];
1651
- case 'time-date':
1652
- return [
1653
- this.renderHeader(),
1654
- this.renderTime(),
1655
- this.renderCalendar(mode),
1656
- this.renderCalendarViewMonthYearPicker(),
1657
- this.renderFooter(),
1658
- ];
1659
- case 'time':
1660
- return [this.renderHeader(false), this.renderTime(), this.renderFooter()];
1661
- case 'month':
1662
- case 'month-year':
1663
- case 'year':
1664
- return [this.renderHeader(false), this.renderWheelView(), this.renderFooter()];
1665
- default:
1666
- return [
1667
- this.renderHeader(),
1668
- this.renderCalendar(mode),
1669
- this.renderCalendarViewMonthYearPicker(),
1670
- this.renderFooter(),
1671
- ];
1666
+ /**
1667
+ * Render entry point
1668
+ * All presentation types are rendered from here.
1669
+ */
1670
+ renderDatetime(mode) {
1671
+ const { presentation, preferWheel } = this;
1672
+ /**
1673
+ * Certain presentation types have separate grid and wheel displays.
1674
+ * If preferWheel is true then we should show a wheel picker instead.
1675
+ */
1676
+ const hasWheelVariant = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
1677
+ if (preferWheel && hasWheelVariant) {
1678
+ return [this.renderHeader(false), this.renderWheelView(), this.renderFooter()];
1679
+ }
1680
+ switch (presentation) {
1681
+ case 'date-time':
1682
+ return [
1683
+ this.renderHeader(),
1684
+ this.renderCalendar(mode),
1685
+ this.renderCalendarViewMonthYearPicker(),
1686
+ this.renderTime(),
1687
+ this.renderFooter(),
1688
+ ];
1689
+ case 'time-date':
1690
+ return [
1691
+ this.renderHeader(),
1692
+ this.renderTime(),
1693
+ this.renderCalendar(mode),
1694
+ this.renderCalendarViewMonthYearPicker(),
1695
+ this.renderFooter(),
1696
+ ];
1697
+ case 'time':
1698
+ return [this.renderHeader(false), this.renderTime(), this.renderFooter()];
1699
+ case 'month':
1700
+ case 'month-year':
1701
+ case 'year':
1702
+ return [this.renderHeader(false), this.renderWheelView(), this.renderFooter()];
1703
+ default:
1704
+ return [
1705
+ this.renderHeader(),
1706
+ this.renderCalendar(mode),
1707
+ this.renderCalendarViewMonthYearPicker(),
1708
+ this.renderFooter(),
1709
+ ];
1710
+ }
1672
1711
  }
1673
- }
1674
- render() {
1675
- const { name, value, disabled, el, color, readonly, showMonthAndYear, preferWheel, presentation, size, isGridStyle, } = this;
1676
- const mode = getIonMode(this);
1677
- const isMonthAndYearPresentation = presentation === 'year' || presentation === 'month' || presentation === 'month-year';
1678
- const shouldShowMonthAndYear = showMonthAndYear || isMonthAndYearPresentation;
1679
- const monthYearPickerOpen = showMonthAndYear && !isMonthAndYearPresentation;
1680
- const hasDatePresentation = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
1681
- const hasWheelVariant = hasDatePresentation && preferWheel;
1682
- renderHiddenInput(true, el, name, formatValue(value), disabled);
1683
- return (h(Host, { "aria-disabled": disabled ? 'true' : null, onFocus: this.onFocus, onBlur: this.onBlur, class: Object.assign({}, createColorClasses(color, {
1684
- [mode]: true,
1685
- ['datetime-readonly']: readonly,
1686
- ['datetime-disabled']: disabled,
1687
- 'show-month-and-year': shouldShowMonthAndYear,
1688
- 'month-year-picker-open': monthYearPickerOpen,
1689
- [`datetime-presentation-${presentation}`]: true,
1690
- [`datetime-size-${size}`]: true,
1691
- [`datetime-prefer-wheel`]: hasWheelVariant,
1692
- [`datetime-grid`]: isGridStyle,
1693
- })) }, this.renderDatetime(mode)));
1694
- }
1695
- get el() { return this; }
1696
- static get watchers() { return {
1697
- "disabled": ["disabledChanged"],
1698
- "min": ["minChanged"],
1699
- "max": ["maxChanged"],
1700
- "yearValues": ["yearValuesChanged"],
1701
- "monthValues": ["monthValuesChanged"],
1702
- "dayValues": ["dayValuesChanged"],
1703
- "hourValues": ["hourValuesChanged"],
1704
- "minuteValues": ["minuteValuesChanged"],
1705
- "value": ["valueChanged"]
1706
- }; }
1707
- static get style() { return {
1708
- ios: datetimeIosCss,
1709
- md: datetimeMdCss
1710
- }; }
1712
+ render() {
1713
+ const { name, value, disabled, el, color, readonly, showMonthAndYear, preferWheel, presentation, size, isGridStyle, } = this;
1714
+ const mode = getIonMode(this);
1715
+ const isMonthAndYearPresentation = presentation === 'year' || presentation === 'month' || presentation === 'month-year';
1716
+ const shouldShowMonthAndYear = showMonthAndYear || isMonthAndYearPresentation;
1717
+ const monthYearPickerOpen = showMonthAndYear && !isMonthAndYearPresentation;
1718
+ const hasDatePresentation = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
1719
+ const hasWheelVariant = hasDatePresentation && preferWheel;
1720
+ renderHiddenInput(true, el, name, formatValue(value), disabled);
1721
+ return (h(Host, { "aria-disabled": disabled ? 'true' : null, onFocus: this.onFocus, onBlur: this.onBlur, class: Object.assign({}, createColorClasses(color, {
1722
+ [mode]: true,
1723
+ ['datetime-readonly']: readonly,
1724
+ ['datetime-disabled']: disabled,
1725
+ 'show-month-and-year': shouldShowMonthAndYear,
1726
+ 'month-year-picker-open': monthYearPickerOpen,
1727
+ [`datetime-presentation-${presentation}`]: true,
1728
+ [`datetime-size-${size}`]: true,
1729
+ [`datetime-prefer-wheel`]: hasWheelVariant,
1730
+ [`datetime-grid`]: isGridStyle,
1731
+ })) }, this.renderDatetime(mode)));
1732
+ }
1733
+ get el() { return this; }
1734
+ static get watchers() { return {
1735
+ "disabled": ["disabledChanged"],
1736
+ "min": ["minChanged"],
1737
+ "max": ["maxChanged"],
1738
+ "yearValues": ["yearValuesChanged"],
1739
+ "monthValues": ["monthValuesChanged"],
1740
+ "dayValues": ["dayValuesChanged"],
1741
+ "hourValues": ["hourValuesChanged"],
1742
+ "minuteValues": ["minuteValuesChanged"],
1743
+ "value": ["valueChanged"]
1744
+ }; }
1745
+ static get style() { return {
1746
+ ios: datetimeIosCss,
1747
+ md: datetimeMdCss
1748
+ }; }
1711
1749
  }, [33, "ion-datetime", {
1712
- "color": [1],
1713
- "name": [1],
1714
- "disabled": [4],
1715
- "readonly": [4],
1716
- "isDateEnabled": [16],
1717
- "min": [1025],
1718
- "max": [1025],
1719
- "presentation": [1],
1720
- "cancelText": [1, "cancel-text"],
1721
- "doneText": [1, "done-text"],
1722
- "clearText": [1, "clear-text"],
1723
- "yearValues": [8, "year-values"],
1724
- "monthValues": [8, "month-values"],
1725
- "dayValues": [8, "day-values"],
1726
- "hourValues": [8, "hour-values"],
1727
- "minuteValues": [8, "minute-values"],
1728
- "locale": [1],
1729
- "firstDayOfWeek": [2, "first-day-of-week"],
1730
- "titleSelectedDatesFormatter": [16],
1731
- "multiple": [4],
1732
- "highlightedDates": [16],
1733
- "value": [1025],
1734
- "showDefaultTitle": [4, "show-default-title"],
1735
- "showDefaultButtons": [4, "show-default-buttons"],
1736
- "showClearButton": [4, "show-clear-button"],
1737
- "showDefaultTimeLabel": [4, "show-default-time-label"],
1738
- "hourCycle": [1, "hour-cycle"],
1739
- "size": [1],
1740
- "preferWheel": [4, "prefer-wheel"],
1741
- "showMonthAndYear": [32],
1742
- "activeParts": [32],
1743
- "workingParts": [32],
1744
- "isTimePopoverOpen": [32],
1745
- "forceRenderDate": [32],
1746
- "confirm": [64],
1747
- "reset": [64],
1748
- "cancel": [64]
1749
- }, undefined, {
1750
- "disabled": ["disabledChanged"],
1751
- "min": ["minChanged"],
1752
- "max": ["maxChanged"],
1753
- "yearValues": ["yearValuesChanged"],
1754
- "monthValues": ["monthValuesChanged"],
1755
- "dayValues": ["dayValuesChanged"],
1756
- "hourValues": ["hourValuesChanged"],
1757
- "minuteValues": ["minuteValuesChanged"],
1758
- "value": ["valueChanged"]
1759
- }]);
1750
+ "color": [1],
1751
+ "name": [1],
1752
+ "disabled": [4],
1753
+ "readonly": [4],
1754
+ "isDateEnabled": [16],
1755
+ "min": [1025],
1756
+ "max": [1025],
1757
+ "presentation": [1],
1758
+ "cancelText": [1, "cancel-text"],
1759
+ "doneText": [1, "done-text"],
1760
+ "clearText": [1, "clear-text"],
1761
+ "yearValues": [8, "year-values"],
1762
+ "monthValues": [8, "month-values"],
1763
+ "dayValues": [8, "day-values"],
1764
+ "hourValues": [8, "hour-values"],
1765
+ "minuteValues": [8, "minute-values"],
1766
+ "locale": [1],
1767
+ "firstDayOfWeek": [2, "first-day-of-week"],
1768
+ "titleSelectedDatesFormatter": [16],
1769
+ "multiple": [4],
1770
+ "highlightedDates": [16],
1771
+ "value": [1025],
1772
+ "showDefaultTitle": [4, "show-default-title"],
1773
+ "showDefaultButtons": [4, "show-default-buttons"],
1774
+ "showClearButton": [4, "show-clear-button"],
1775
+ "showDefaultTimeLabel": [4, "show-default-time-label"],
1776
+ "hourCycle": [1, "hour-cycle"],
1777
+ "size": [1],
1778
+ "preferWheel": [4, "prefer-wheel"],
1779
+ "showMonthAndYear": [32],
1780
+ "activeParts": [32],
1781
+ "workingParts": [32],
1782
+ "isTimePopoverOpen": [32],
1783
+ "forceRenderDate": [32],
1784
+ "confirm": [64],
1785
+ "reset": [64],
1786
+ "cancel": [64]
1787
+ }, undefined, {
1788
+ "disabled": ["disabledChanged"],
1789
+ "min": ["minChanged"],
1790
+ "max": ["maxChanged"],
1791
+ "yearValues": ["yearValuesChanged"],
1792
+ "monthValues": ["monthValuesChanged"],
1793
+ "dayValues": ["dayValuesChanged"],
1794
+ "hourValues": ["hourValuesChanged"],
1795
+ "minuteValues": ["minuteValuesChanged"],
1796
+ "value": ["valueChanged"]
1797
+ }]);
1760
1798
  let datetimeIds = 0;
1761
1799
  function defineCustomElement$1() {
1762
- if (typeof customElements === "undefined") {
1763
- return;
1764
- }
1765
- const components = ["ion-datetime", "ion-backdrop", "ion-button", "ion-buttons", "ion-icon", "ion-item", "ion-label", "ion-note", "ion-picker-column-internal", "ion-picker-internal", "ion-popover", "ion-ripple-effect"];
1766
- components.forEach(tagName => { switch (tagName) {
1767
- case "ion-datetime":
1768
- if (!customElements.get(tagName)) {
1769
- customElements.define(tagName, Datetime);
1770
- }
1771
- break;
1772
- case "ion-backdrop":
1773
- if (!customElements.get(tagName)) {
1774
- defineCustomElement$c();
1775
- }
1776
- break;
1777
- case "ion-button":
1778
- if (!customElements.get(tagName)) {
1779
- defineCustomElement$b();
1780
- }
1781
- break;
1782
- case "ion-buttons":
1783
- if (!customElements.get(tagName)) {
1784
- defineCustomElement$a();
1785
- }
1786
- break;
1787
- case "ion-icon":
1788
- if (!customElements.get(tagName)) {
1789
- defineCustomElement$9();
1790
- }
1791
- break;
1792
- case "ion-item":
1793
- if (!customElements.get(tagName)) {
1794
- defineCustomElement$8();
1795
- }
1796
- break;
1797
- case "ion-label":
1798
- if (!customElements.get(tagName)) {
1799
- defineCustomElement$7();
1800
- }
1801
- break;
1802
- case "ion-note":
1803
- if (!customElements.get(tagName)) {
1804
- defineCustomElement$6();
1805
- }
1806
- break;
1807
- case "ion-picker-column-internal":
1808
- if (!customElements.get(tagName)) {
1809
- defineCustomElement$5();
1810
- }
1811
- break;
1812
- case "ion-picker-internal":
1813
- if (!customElements.get(tagName)) {
1814
- defineCustomElement$4();
1815
- }
1816
- break;
1817
- case "ion-popover":
1818
- if (!customElements.get(tagName)) {
1819
- defineCustomElement$3();
1820
- }
1821
- break;
1822
- case "ion-ripple-effect":
1823
- if (!customElements.get(tagName)) {
1824
- defineCustomElement$2();
1825
- }
1826
- break;
1827
- } });
1800
+ if (typeof customElements === "undefined") {
1801
+ return;
1802
+ }
1803
+ const components = ["ion-datetime", "ion-backdrop", "ion-button", "ion-buttons", "ion-icon", "ion-item", "ion-label", "ion-note", "ion-picker-column-internal", "ion-picker-internal", "ion-popover", "ion-ripple-effect"];
1804
+ components.forEach(tagName => { switch (tagName) {
1805
+ case "ion-datetime":
1806
+ if (!customElements.get(tagName)) {
1807
+ customElements.define(tagName, Datetime);
1808
+ }
1809
+ break;
1810
+ case "ion-backdrop":
1811
+ if (!customElements.get(tagName)) {
1812
+ defineCustomElement$c();
1813
+ }
1814
+ break;
1815
+ case "ion-button":
1816
+ if (!customElements.get(tagName)) {
1817
+ defineCustomElement$b();
1818
+ }
1819
+ break;
1820
+ case "ion-buttons":
1821
+ if (!customElements.get(tagName)) {
1822
+ defineCustomElement$a();
1823
+ }
1824
+ break;
1825
+ case "ion-icon":
1826
+ if (!customElements.get(tagName)) {
1827
+ defineCustomElement$9();
1828
+ }
1829
+ break;
1830
+ case "ion-item":
1831
+ if (!customElements.get(tagName)) {
1832
+ defineCustomElement$8();
1833
+ }
1834
+ break;
1835
+ case "ion-label":
1836
+ if (!customElements.get(tagName)) {
1837
+ defineCustomElement$7();
1838
+ }
1839
+ break;
1840
+ case "ion-note":
1841
+ if (!customElements.get(tagName)) {
1842
+ defineCustomElement$6();
1843
+ }
1844
+ break;
1845
+ case "ion-picker-column-internal":
1846
+ if (!customElements.get(tagName)) {
1847
+ defineCustomElement$5();
1848
+ }
1849
+ break;
1850
+ case "ion-picker-internal":
1851
+ if (!customElements.get(tagName)) {
1852
+ defineCustomElement$4();
1853
+ }
1854
+ break;
1855
+ case "ion-popover":
1856
+ if (!customElements.get(tagName)) {
1857
+ defineCustomElement$3();
1858
+ }
1859
+ break;
1860
+ case "ion-ripple-effect":
1861
+ if (!customElements.get(tagName)) {
1862
+ defineCustomElement$2();
1863
+ }
1864
+ break;
1865
+ } });
1828
1866
  }
1829
1867
 
1830
1868
  const IonDatetime = Datetime;