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
@@ -1,32 +1,32 @@
1
1
  /*!
2
2
  * (C) Ionic http://ionicframework.com - MIT License
3
3
  */
4
- import { r as registerInstance, d as createEvent, w as writeTask, h, H as Host, f as getElement } from './index-b49b173c.js';
5
- import { startFocusVisible } from './focus-visible-85493433.js';
6
- import { r as raf, d as renderHiddenInput, g as getElementRoot, l as clamp } from './helpers-3379ba19.js';
7
- import { a as printIonError, p as printIonWarning } from './index-595d62c9.js';
8
- import { i as isRTL } from './dir-912e3e13.js';
9
- import { c as createColorClasses, g as getClassMap } from './theme-17531cdf.js';
4
+ import { r as registerInstance, d as createEvent, w as writeTask, h, H as Host, f as getElement } from './index-08d686eb.js';
5
+ import { startFocusVisible } from './focus-visible-dd40d69f.js';
6
+ import { r as raf, d as renderHiddenInput, g as getElementRoot, l as clamp } from './helpers-ae653409.js';
7
+ import { a as printIonError, p as printIonWarning } from './index-9b0d46f4.js';
8
+ import { i as isRTL } from './dir-babeabeb.js';
9
+ import { c as createColorClasses, g as getClassMap } from './theme-01f3f29c.js';
10
10
  import { c as chevronBack, o as chevronForward, l as chevronDown, p as caretUpSharp, q as caretDownSharp } from './index-c132c5f1.js';
11
- import { b as getIonMode } from './ionic-global-246ca78f.js';
12
- import { g as generateDayAriaLabel, a as getDay, i as isBefore, b as isAfter, c as isSameDay, d as getPreviousMonth, e as getNextMonth, v as validateParts, f as getPartsFromCalendarDay, h as getEndOfWeek, j as getStartOfWeek, k as getPreviousDay, l as getNextDay, m as getPreviousWeek, n as getNextWeek, p as parseMinParts, o as parseMaxParts, q as parseDate, w as warnIfValueOutOfBounds, r as convertToArrayOfNumbers, s as convertDataToISO, t as getToday, u as getClosestValidDate, x as getNumDaysInMonth, y as getCombinedDateColumnData, z as getMonthColumnData, A as getDayColumnData, B as getYearColumnData, C as isMonthFirstLocale, D as getTimeColumnsData, E as isLocaleDayPeriodRTL, F as getDaysOfWeek, G as getMonthAndYear, H as getDaysOfMonth, I as generateMonths, J as getHourCycle, K as getLocalizedTime, L as getMonthAndDay, M as formatValue, N as getNextYear, O as getPreviousYear, P as clampDate, Q as parseAmPm, R as calculateHourFromAMPM } from './data-44d9e816.js';
13
- import { c as createLockController } from './lock-controller-e8c6c051.js';
14
- import { d as createDelegateController, e as createTriggerController, B as BACKDROP, i as isCancel, j as prepareOverlay, k as setOverlayId, f as present, g as dismiss, h as eventMethod, s as safeCall } from './overlays-cec6bac8.js';
15
- import { c as createAnimation } from './animation-92066c62.js';
16
- import { b as hapticSelectionChanged, h as hapticSelectionEnd, a as hapticSelectionStart } from './haptic-1243b917.js';
17
- import './index-7a14ecec.js';
18
- import './framework-delegate-aa433dea.js';
19
- import './hardware-back-button-39299f84.js';
20
- import './capacitor-b4979570.js';
11
+ import { b as getIonMode } from './ionic-global-c0cda98e.js';
12
+ import { g as generateDayAriaLabel, a as getDay, i as isBefore, b as isAfter, c as isSameDay, d as getPreviousMonth, e as getNextMonth, v as validateParts, f as getPartsFromCalendarDay, h as getEndOfWeek, j as getStartOfWeek, k as getPreviousDay, l as getNextDay, m as getPreviousWeek, n as getNextWeek, p as parseMinParts, o as parseMaxParts, q as parseDate, w as warnIfValueOutOfBounds, r as convertToArrayOfNumbers, s as convertDataToISO, t as getToday, u as getClosestValidDate, x as getNumDaysInMonth, y as getCombinedDateColumnData, z as getMonthColumnData, A as getDayColumnData, B as getYearColumnData, C as isMonthFirstLocale, D as getTimeColumnsData, E as isLocaleDayPeriodRTL, F as getDaysOfWeek, G as getMonthAndYear, H as getDaysOfMonth, I as generateMonths, J as getHourCycle, K as getLocalizedTime, L as getMonthAndDay, M as formatValue, N as getNextYear, O as getPreviousYear, P as clampDate, Q as parseAmPm, R as calculateHourFromAMPM } from './data-f5c75b4e.js';
13
+ import { c as createLockController } from './lock-controller-316928be.js';
14
+ import { d as createDelegateController, e as createTriggerController, B as BACKDROP, i as isCancel, j as prepareOverlay, k as setOverlayId, f as present, g as dismiss, h as eventMethod, s as safeCall } from './overlays-32ef481d.js';
15
+ import { c as createAnimation } from './animation-dde8cc0d.js';
16
+ import { b as hapticSelectionChanged, h as hapticSelectionEnd, a as hapticSelectionStart } from './haptic-554688a5.js';
17
+ import './index-a5d50daf.js';
18
+ import './framework-delegate-bc1fd82a.js';
19
+ import './hardware-back-button-b2bc76db.js';
20
+ import './capacitor-59395cbd.js';
21
21
 
22
22
  const isYearDisabled = (refYear, minParts, maxParts) => {
23
- if (minParts && minParts.year > refYear) {
24
- return true;
25
- }
26
- if (maxParts && maxParts.year < refYear) {
27
- return true;
28
- }
29
- return false;
23
+ if (minParts && minParts.year > refYear) {
24
+ return true;
25
+ }
26
+ if (maxParts && maxParts.year < refYear) {
27
+ return true;
28
+ }
29
+ return false;
30
30
  };
31
31
  /**
32
32
  * Returns true if a given day should
@@ -34,104 +34,104 @@ const isYearDisabled = (refYear, minParts, maxParts) => {
34
34
  * or the max/min dates.
35
35
  */
36
36
  const isDayDisabled = (refParts, minParts, maxParts, dayValues) => {
37
- /**
38
- * If this is a filler date (i.e. padding)
39
- * then the date is disabled.
40
- */
41
- if (refParts.day === null) {
42
- return true;
43
- }
44
- /**
45
- * If user passed in a list of acceptable day values
46
- * check to make sure that the date we are looking
47
- * at is in this array.
48
- */
49
- if (dayValues !== undefined && !dayValues.includes(refParts.day)) {
50
- return true;
51
- }
52
- /**
53
- * Given a min date, perform the following
54
- * checks. If any of them are true, then the
55
- * day should be disabled:
56
- * 1. Is the current year < the min allowed year?
57
- * 2. Is the current year === min allowed year,
58
- * but the current month < the min allowed month?
59
- * 3. Is the current year === min allowed year, the
60
- * current month === min allow month, but the current
61
- * day < the min allowed day?
62
- */
63
- if (minParts && isBefore(refParts, minParts)) {
64
- return true;
65
- }
66
- /**
67
- * Given a max date, perform the following
68
- * checks. If any of them are true, then the
69
- * day should be disabled:
70
- * 1. Is the current year > the max allowed year?
71
- * 2. Is the current year === max allowed year,
72
- * but the current month > the max allowed month?
73
- * 3. Is the current year === max allowed year, the
74
- * current month === max allow month, but the current
75
- * day > the max allowed day?
76
- */
77
- if (maxParts && isAfter(refParts, maxParts)) {
78
- return true;
79
- }
80
- /**
81
- * If none of these checks
82
- * passed then the date should
83
- * be interactive.
84
- */
85
- return false;
37
+ /**
38
+ * If this is a filler date (i.e. padding)
39
+ * then the date is disabled.
40
+ */
41
+ if (refParts.day === null) {
42
+ return true;
43
+ }
44
+ /**
45
+ * If user passed in a list of acceptable day values
46
+ * check to make sure that the date we are looking
47
+ * at is in this array.
48
+ */
49
+ if (dayValues !== undefined && !dayValues.includes(refParts.day)) {
50
+ return true;
51
+ }
52
+ /**
53
+ * Given a min date, perform the following
54
+ * checks. If any of them are true, then the
55
+ * day should be disabled:
56
+ * 1. Is the current year < the min allowed year?
57
+ * 2. Is the current year === min allowed year,
58
+ * but the current month < the min allowed month?
59
+ * 3. Is the current year === min allowed year, the
60
+ * current month === min allow month, but the current
61
+ * day < the min allowed day?
62
+ */
63
+ if (minParts && isBefore(refParts, minParts)) {
64
+ return true;
65
+ }
66
+ /**
67
+ * Given a max date, perform the following
68
+ * checks. If any of them are true, then the
69
+ * day should be disabled:
70
+ * 1. Is the current year > the max allowed year?
71
+ * 2. Is the current year === max allowed year,
72
+ * but the current month > the max allowed month?
73
+ * 3. Is the current year === max allowed year, the
74
+ * current month === max allow month, but the current
75
+ * day > the max allowed day?
76
+ */
77
+ if (maxParts && isAfter(refParts, maxParts)) {
78
+ return true;
79
+ }
80
+ /**
81
+ * If none of these checks
82
+ * passed then the date should
83
+ * be interactive.
84
+ */
85
+ return false;
86
86
  };
87
87
  /**
88
88
  * Given a locale, a date, the selected date(s), and today's date,
89
89
  * generate the state for a given calendar day button.
90
90
  */
91
91
  const getCalendarDayState = (locale, refParts, activeParts, todayParts, minParts, maxParts, dayValues) => {
92
- /**
93
- * activeParts signals what day(s) are currently selected in the datetime.
94
- * If multiple="true", this will be an array, but the logic in this util
95
- * is the same whether we have one selected day or many because we're only
96
- * calculating the state for one button. So, we treat a single activeParts value
97
- * the same as an array of length one.
98
- */
99
- const activePartsArray = Array.isArray(activeParts) ? activeParts : [activeParts];
100
- /**
101
- * The day button is active if it is selected, or in other words, if refParts
102
- * matches at least one selected date.
103
- */
104
- const isActive = activePartsArray.find((parts) => isSameDay(refParts, parts)) !== undefined;
105
- const isToday = isSameDay(refParts, todayParts);
106
- const disabled = isDayDisabled(refParts, minParts, maxParts, dayValues);
107
- /**
108
- * Note that we always return one object regardless of whether activeParts
109
- * was an array, since we pare down to one value for isActive.
110
- */
111
- return {
112
- disabled,
113
- isActive,
114
- isToday,
115
- ariaSelected: isActive ? 'true' : null,
116
- ariaLabel: generateDayAriaLabel(locale, isToday, refParts),
117
- text: refParts.day != null ? getDay(locale, refParts) : null,
118
- };
92
+ /**
93
+ * activeParts signals what day(s) are currently selected in the datetime.
94
+ * If multiple="true", this will be an array, but the logic in this util
95
+ * is the same whether we have one selected day or many because we're only
96
+ * calculating the state for one button. So, we treat a single activeParts value
97
+ * the same as an array of length one.
98
+ */
99
+ const activePartsArray = Array.isArray(activeParts) ? activeParts : [activeParts];
100
+ /**
101
+ * The day button is active if it is selected, or in other words, if refParts
102
+ * matches at least one selected date.
103
+ */
104
+ const isActive = activePartsArray.find((parts) => isSameDay(refParts, parts)) !== undefined;
105
+ const isToday = isSameDay(refParts, todayParts);
106
+ const disabled = isDayDisabled(refParts, minParts, maxParts, dayValues);
107
+ /**
108
+ * Note that we always return one object regardless of whether activeParts
109
+ * was an array, since we pare down to one value for isActive.
110
+ */
111
+ return {
112
+ disabled,
113
+ isActive,
114
+ isToday,
115
+ ariaSelected: isActive ? 'true' : null,
116
+ ariaLabel: generateDayAriaLabel(locale, isToday, refParts),
117
+ text: refParts.day != null ? getDay(locale, refParts) : null,
118
+ };
119
119
  };
120
120
  /**
121
121
  * Returns `true` if the month is disabled given the
122
122
  * current date value and min/max date constraints.
123
123
  */
124
124
  const isMonthDisabled = (refParts, { minParts, maxParts, }) => {
125
- // If the year is disabled then the month is disabled.
126
- if (isYearDisabled(refParts.year, minParts, maxParts)) {
127
- return true;
128
- }
129
- // If the date value is before the min date, then the month is disabled.
130
- // If the date value is after the max date, then the month is disabled.
131
- if ((minParts && isBefore(refParts, minParts)) || (maxParts && isAfter(refParts, maxParts))) {
132
- return true;
133
- }
134
- return false;
125
+ // If the year is disabled then the month is disabled.
126
+ if (isYearDisabled(refParts.year, minParts, maxParts)) {
127
+ return true;
128
+ }
129
+ // If the date value is before the min date, then the month is disabled.
130
+ // If the date value is after the max date, then the month is disabled.
131
+ if ((minParts && isBefore(refParts, minParts)) || (maxParts && isAfter(refParts, maxParts))) {
132
+ return true;
133
+ }
134
+ return false;
135
135
  };
136
136
  /**
137
137
  * Given a working date, an optional minimum date range,
@@ -139,21 +139,21 @@ const isMonthDisabled = (refParts, { minParts, maxParts, }) => {
139
139
  * previous navigation button is disabled.
140
140
  */
141
141
  const isPrevMonthDisabled = (refParts, minParts, maxParts) => {
142
- const prevMonth = Object.assign(Object.assign({}, getPreviousMonth(refParts)), { day: null });
143
- return isMonthDisabled(prevMonth, {
144
- minParts,
145
- maxParts,
146
- });
142
+ const prevMonth = Object.assign(Object.assign({}, getPreviousMonth(refParts)), { day: null });
143
+ return isMonthDisabled(prevMonth, {
144
+ minParts,
145
+ maxParts,
146
+ });
147
147
  };
148
148
  /**
149
149
  * Given a working date and a maximum date range,
150
150
  * determine if the next navigation button is disabled.
151
151
  */
152
152
  const isNextMonthDisabled = (refParts, maxParts) => {
153
- const nextMonth = Object.assign(Object.assign({}, getNextMonth(refParts)), { day: null });
154
- return isMonthDisabled(nextMonth, {
155
- maxParts,
156
- });
153
+ const nextMonth = Object.assign(Object.assign({}, getNextMonth(refParts)), { day: null });
154
+ return isMonthDisabled(nextMonth, {
155
+ maxParts,
156
+ });
157
157
  };
158
158
  /**
159
159
  * Given the value of the highlightedDates property
@@ -161,1593 +161,1631 @@ const isNextMonthDisabled = (refParts, maxParts) => {
161
161
  * that date, or undefined if none are found.
162
162
  */
163
163
  const getHighlightStyles = (highlightedDates, dateIsoString, el) => {
164
- if (Array.isArray(highlightedDates)) {
165
- const dateStringWithoutTime = dateIsoString.split('T')[0];
166
- const matchingHighlight = highlightedDates.find((hd) => hd.date === dateStringWithoutTime);
167
- if (matchingHighlight) {
168
- return {
169
- textColor: matchingHighlight.textColor,
170
- backgroundColor: matchingHighlight.backgroundColor,
171
- };
172
- }
173
- }
174
- else {
175
- /**
176
- * Wrap in a try-catch to prevent exceptions in the user's function
177
- * from interrupting the calendar's rendering.
178
- */
179
- try {
180
- return highlightedDates(dateIsoString);
164
+ if (Array.isArray(highlightedDates)) {
165
+ const dateStringWithoutTime = dateIsoString.split('T')[0];
166
+ const matchingHighlight = highlightedDates.find((hd) => hd.date === dateStringWithoutTime);
167
+ if (matchingHighlight) {
168
+ return {
169
+ textColor: matchingHighlight.textColor,
170
+ backgroundColor: matchingHighlight.backgroundColor,
171
+ };
172
+ }
181
173
  }
182
- catch (e) {
183
- printIonError('Exception thrown from provided `highlightedDates` callback. Please check your function and try again.', el, e);
174
+ else {
175
+ /**
176
+ * Wrap in a try-catch to prevent exceptions in the user's function
177
+ * from interrupting the calendar's rendering.
178
+ */
179
+ try {
180
+ return highlightedDates(dateIsoString);
181
+ }
182
+ catch (e) {
183
+ printIonError('Exception thrown from provided `highlightedDates` callback. Please check your function and try again.', el, e);
184
+ }
184
185
  }
185
- }
186
- return undefined;
186
+ return undefined;
187
187
  };
188
188
 
189
- 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%}";
189
+ 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%}";
190
190
 
191
- 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)}";
191
+ 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}";
192
192
 
193
193
  const Datetime = class {
194
- constructor(hostRef) {
195
- registerInstance(this, hostRef);
196
- this.ionCancel = createEvent(this, "ionCancel", 7);
197
- this.ionChange = createEvent(this, "ionChange", 7);
198
- this.ionValueChange = createEvent(this, "ionValueChange", 7);
199
- this.ionFocus = createEvent(this, "ionFocus", 7);
200
- this.ionBlur = createEvent(this, "ionBlur", 7);
201
- this.ionStyle = createEvent(this, "ionStyle", 7);
202
- this.ionRender = createEvent(this, "ionRender", 7);
203
- this.inputId = `ion-dt-${datetimeIds++}`;
204
- this.prevPresentation = null;
205
- this.warnIfIncorrectValueUsage = () => {
206
- const { multiple, value } = this;
207
- if (!multiple && Array.isArray(value)) {
208
- /**
209
- * We do some processing on the `value` array so
210
- * that it looks more like an array when logged to
211
- * the console.
212
- * Example given ['a', 'b']
213
- * Default toString() behavior: a,b
214
- * Custom behavior: ['a', 'b']
215
- */
216
- 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".
194
+ constructor(hostRef) {
195
+ registerInstance(this, hostRef);
196
+ this.ionCancel = createEvent(this, "ionCancel", 7);
197
+ this.ionChange = createEvent(this, "ionChange", 7);
198
+ this.ionValueChange = createEvent(this, "ionValueChange", 7);
199
+ this.ionFocus = createEvent(this, "ionFocus", 7);
200
+ this.ionBlur = createEvent(this, "ionBlur", 7);
201
+ this.ionStyle = createEvent(this, "ionStyle", 7);
202
+ this.ionRender = createEvent(this, "ionRender", 7);
203
+ this.inputId = `ion-dt-${datetimeIds++}`;
204
+ this.prevPresentation = null;
205
+ this.warnIfIncorrectValueUsage = () => {
206
+ const { multiple, value } = this;
207
+ if (!multiple && Array.isArray(value)) {
208
+ /**
209
+ * We do some processing on the `value` array so
210
+ * that it looks more like an array when logged to
211
+ * the console.
212
+ * Example given ['a', 'b']
213
+ * Default toString() behavior: a,b
214
+ * Custom behavior: ['a', 'b']
215
+ */
216
+ 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".
217
217
 
218
218
  Value Passed: [${value.map((v) => `'${v}'`).join(', ')}]
219
219
  `, this.el);
220
- }
221
- };
222
- this.setValue = (value) => {
223
- this.value = value;
224
- this.ionChange.emit({ value });
225
- };
220
+ }
221
+ };
222
+ this.setValue = (value) => {
223
+ this.value = value;
224
+ this.ionChange.emit({ value });
225
+ };
226
+ /**
227
+ * Returns the DatetimePart interface
228
+ * to use when rendering an initial set of
229
+ * data. This should be used when rendering an
230
+ * interface in an environment where the `value`
231
+ * may not be set. This function works
232
+ * by returning the first selected date and then
233
+ * falling back to defaultParts if no active date
234
+ * is selected.
235
+ */
236
+ this.getActivePartsWithFallback = () => {
237
+ var _a;
238
+ const { defaultParts } = this;
239
+ return (_a = this.getActivePart()) !== null && _a !== void 0 ? _a : defaultParts;
240
+ };
241
+ this.getActivePart = () => {
242
+ const { activeParts } = this;
243
+ return Array.isArray(activeParts) ? activeParts[0] : activeParts;
244
+ };
245
+ this.closeParentOverlay = () => {
246
+ const popoverOrModal = this.el.closest('ion-modal, ion-popover');
247
+ if (popoverOrModal) {
248
+ popoverOrModal.dismiss();
249
+ }
250
+ };
251
+ this.setWorkingParts = (parts) => {
252
+ this.workingParts = Object.assign({}, parts);
253
+ };
254
+ this.setActiveParts = (parts, removeDate = false) => {
255
+ /** if the datetime component is in readonly mode,
256
+ * allow browsing of the calendar without changing
257
+ * the set value
258
+ */
259
+ if (this.readonly) {
260
+ return;
261
+ }
262
+ const { multiple, minParts, maxParts, activeParts } = this;
263
+ /**
264
+ * When setting the active parts, it is possible
265
+ * to set invalid data. For example,
266
+ * when updating January 31 to February,
267
+ * February 31 does not exist. As a result
268
+ * we need to validate the active parts and
269
+ * ensure that we are only setting valid dates.
270
+ * Additionally, we need to update the working parts
271
+ * too in the event that the validated parts are different.
272
+ */
273
+ const validatedParts = validateParts(parts, minParts, maxParts);
274
+ this.setWorkingParts(validatedParts);
275
+ if (multiple) {
276
+ const activePartsArray = Array.isArray(activeParts) ? activeParts : [activeParts];
277
+ if (removeDate) {
278
+ this.activeParts = activePartsArray.filter((p) => !isSameDay(p, validatedParts));
279
+ }
280
+ else {
281
+ this.activeParts = [...activePartsArray, validatedParts];
282
+ }
283
+ }
284
+ else {
285
+ this.activeParts = Object.assign({}, validatedParts);
286
+ }
287
+ const hasSlottedButtons = this.el.querySelector('[slot="buttons"]') !== null;
288
+ if (hasSlottedButtons || this.showDefaultButtons) {
289
+ return;
290
+ }
291
+ this.confirm();
292
+ };
293
+ this.initializeKeyboardListeners = () => {
294
+ const calendarBodyRef = this.calendarBodyRef;
295
+ if (!calendarBodyRef) {
296
+ return;
297
+ }
298
+ const root = this.el.shadowRoot;
299
+ /**
300
+ * Get a reference to the month
301
+ * element we are currently viewing.
302
+ */
303
+ const currentMonth = calendarBodyRef.querySelector('.calendar-month:nth-of-type(2)');
304
+ /**
305
+ * When focusing the calendar body, we want to pass focus
306
+ * to the working day, but other days should
307
+ * only be accessible using the arrow keys. Pressing
308
+ * Tab should jump between bodies of selectable content.
309
+ */
310
+ const checkCalendarBodyFocus = (ev) => {
311
+ var _a;
312
+ const record = ev[0];
313
+ /**
314
+ * If calendar body was already focused
315
+ * when this fired or if the calendar body
316
+ * if not currently focused, we should not re-focus
317
+ * the inner day.
318
+ */
319
+ if (((_a = record.oldValue) === null || _a === void 0 ? void 0 : _a.includes('ion-focused')) || !calendarBodyRef.classList.contains('ion-focused')) {
320
+ return;
321
+ }
322
+ this.focusWorkingDay(currentMonth);
323
+ };
324
+ const mo = new MutationObserver(checkCalendarBodyFocus);
325
+ mo.observe(calendarBodyRef, { attributeFilter: ['class'], attributeOldValue: true });
326
+ this.destroyKeyboardMO = () => {
327
+ mo === null || mo === void 0 ? void 0 : mo.disconnect();
328
+ };
329
+ /**
330
+ * We must use keydown not keyup as we want
331
+ * to prevent scrolling when using the arrow keys.
332
+ */
333
+ calendarBodyRef.addEventListener('keydown', (ev) => {
334
+ const activeElement = root.activeElement;
335
+ if (!activeElement || !activeElement.classList.contains('calendar-day')) {
336
+ return;
337
+ }
338
+ const parts = getPartsFromCalendarDay(activeElement);
339
+ let partsToFocus;
340
+ switch (ev.key) {
341
+ case 'ArrowDown':
342
+ ev.preventDefault();
343
+ partsToFocus = getNextWeek(parts);
344
+ break;
345
+ case 'ArrowUp':
346
+ ev.preventDefault();
347
+ partsToFocus = getPreviousWeek(parts);
348
+ break;
349
+ case 'ArrowRight':
350
+ ev.preventDefault();
351
+ partsToFocus = getNextDay(parts);
352
+ break;
353
+ case 'ArrowLeft':
354
+ ev.preventDefault();
355
+ partsToFocus = getPreviousDay(parts);
356
+ break;
357
+ case 'Home':
358
+ ev.preventDefault();
359
+ partsToFocus = getStartOfWeek(parts);
360
+ break;
361
+ case 'End':
362
+ ev.preventDefault();
363
+ partsToFocus = getEndOfWeek(parts);
364
+ break;
365
+ case 'PageUp':
366
+ ev.preventDefault();
367
+ partsToFocus = ev.shiftKey ? getPreviousYear(parts) : getPreviousMonth(parts);
368
+ break;
369
+ case 'PageDown':
370
+ ev.preventDefault();
371
+ partsToFocus = ev.shiftKey ? getNextYear(parts) : getNextMonth(parts);
372
+ break;
373
+ /**
374
+ * Do not preventDefault here
375
+ * as we do not want to override other
376
+ * browser defaults such as pressing Enter/Space
377
+ * to select a day.
378
+ */
379
+ default:
380
+ return;
381
+ }
382
+ /**
383
+ * If the day we want to move focus to is
384
+ * disabled, do not do anything.
385
+ */
386
+ if (isDayDisabled(partsToFocus, this.minParts, this.maxParts)) {
387
+ return;
388
+ }
389
+ this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), partsToFocus));
390
+ /**
391
+ * Give view a chance to re-render
392
+ * then move focus to the new working day
393
+ */
394
+ requestAnimationFrame(() => this.focusWorkingDay(currentMonth));
395
+ });
396
+ };
397
+ this.focusWorkingDay = (currentMonth) => {
398
+ /**
399
+ * Get the number of padding days so
400
+ * we know how much to offset our next selector by
401
+ * to grab the correct calendar-day element.
402
+ */
403
+ const padding = currentMonth.querySelectorAll('.calendar-day-padding');
404
+ const { day } = this.workingParts;
405
+ if (day === null) {
406
+ return;
407
+ }
408
+ /**
409
+ * Get the calendar day element
410
+ * and focus it.
411
+ */
412
+ const dayEl = currentMonth.querySelector(`.calendar-day-wrapper:nth-of-type(${padding.length + day}) .calendar-day`);
413
+ if (dayEl) {
414
+ dayEl.focus();
415
+ }
416
+ };
417
+ this.processMinParts = () => {
418
+ const { min, defaultParts } = this;
419
+ if (min === undefined) {
420
+ this.minParts = undefined;
421
+ return;
422
+ }
423
+ this.minParts = parseMinParts(min, defaultParts);
424
+ };
425
+ this.processMaxParts = () => {
426
+ const { max, defaultParts } = this;
427
+ if (max === undefined) {
428
+ this.maxParts = undefined;
429
+ return;
430
+ }
431
+ this.maxParts = parseMaxParts(max, defaultParts);
432
+ };
433
+ this.initializeCalendarListener = () => {
434
+ const calendarBodyRef = this.calendarBodyRef;
435
+ if (!calendarBodyRef) {
436
+ return;
437
+ }
438
+ /**
439
+ * For performance reasons, we only render 3
440
+ * months at a time: The current month, the previous
441
+ * month, and the next month. We have a scroll listener
442
+ * on the calendar body to append/prepend new months.
443
+ *
444
+ * We can do this because Stencil is smart enough to not
445
+ * re-create the .calendar-month containers, but rather
446
+ * update the content within those containers.
447
+ *
448
+ * As an added bonus, WebKit has some troubles with
449
+ * scroll-snap-stop: always, so not rendering all of
450
+ * the months in a row allows us to mostly sidestep
451
+ * that issue.
452
+ */
453
+ const months = calendarBodyRef.querySelectorAll('.calendar-month');
454
+ const startMonth = months[0];
455
+ const workingMonth = months[1];
456
+ const endMonth = months[2];
457
+ const mode = getIonMode(this);
458
+ const needsiOSRubberBandFix = mode === 'ios' && typeof navigator !== 'undefined' && navigator.maxTouchPoints > 1;
459
+ /**
460
+ * Before setting up the scroll listener,
461
+ * scroll the middle month into view.
462
+ * scrollIntoView() will scroll entire page
463
+ * if element is not in viewport. Use scrollLeft instead.
464
+ */
465
+ writeTask(() => {
466
+ calendarBodyRef.scrollLeft = startMonth.clientWidth * (isRTL(this.el) ? -1 : 1);
467
+ const getChangedMonth = (parts) => {
468
+ const box = calendarBodyRef.getBoundingClientRect();
469
+ /**
470
+ * If the current scroll position is all the way to the left
471
+ * then we have scrolled to the previous month.
472
+ * Otherwise, assume that we have scrolled to the next
473
+ * month. We have a tolerance of 2px to account for
474
+ * sub pixel rendering.
475
+ *
476
+ * Check below the next line ensures that we did not
477
+ * swipe and abort (i.e. we swiped but we are still on the current month).
478
+ */
479
+ const month = calendarBodyRef.scrollLeft <= 2 ? startMonth : endMonth;
480
+ /**
481
+ * The edge of the month must be lined up with
482
+ * the edge of the calendar body in order for
483
+ * the component to update. Otherwise, it
484
+ * may be the case that the user has paused their
485
+ * swipe or the browser has not finished snapping yet.
486
+ * Rather than check if the x values are equal,
487
+ * we give it a tolerance of 2px to account for
488
+ * sub pixel rendering.
489
+ */
490
+ const monthBox = month.getBoundingClientRect();
491
+ if (Math.abs(monthBox.x - box.x) > 2)
492
+ return;
493
+ /**
494
+ * If we're force-rendering a month, assume we've
495
+ * scrolled to that and return it.
496
+ *
497
+ * If forceRenderDate is ever used in a context where the
498
+ * forced month is not immediately auto-scrolled to, this
499
+ * should be updated to also check whether `month` has the
500
+ * same month and year as the forced date.
501
+ */
502
+ const { forceRenderDate } = this;
503
+ if (forceRenderDate !== undefined) {
504
+ return { month: forceRenderDate.month, year: forceRenderDate.year, day: forceRenderDate.day };
505
+ }
506
+ /**
507
+ * From here, we can determine if the start
508
+ * month or the end month was scrolled into view.
509
+ * If no month was changed, then we can return from
510
+ * the scroll callback early.
511
+ */
512
+ if (month === startMonth) {
513
+ return getPreviousMonth(parts);
514
+ }
515
+ else if (month === endMonth) {
516
+ return getNextMonth(parts);
517
+ }
518
+ else {
519
+ return;
520
+ }
521
+ };
522
+ const updateActiveMonth = () => {
523
+ if (needsiOSRubberBandFix) {
524
+ calendarBodyRef.style.removeProperty('pointer-events');
525
+ appliediOSRubberBandFix = false;
526
+ }
527
+ /**
528
+ * If the month did not change
529
+ * then we can return early.
530
+ */
531
+ const newDate = getChangedMonth(this.workingParts);
532
+ if (!newDate)
533
+ return;
534
+ const { month, day, year } = newDate;
535
+ if (isMonthDisabled({ month, year, day: null }, {
536
+ minParts: Object.assign(Object.assign({}, this.minParts), { day: null }),
537
+ maxParts: Object.assign(Object.assign({}, this.maxParts), { day: null }),
538
+ })) {
539
+ return;
540
+ }
541
+ /**
542
+ * Prevent scrolling for other browsers
543
+ * to give the DOM time to update and the container
544
+ * time to properly snap.
545
+ */
546
+ calendarBodyRef.style.setProperty('overflow', 'hidden');
547
+ /**
548
+ * Use a writeTask here to ensure
549
+ * that the state is updated and the
550
+ * correct month is scrolled into view
551
+ * in the same frame. This is not
552
+ * typically a problem on newer devices
553
+ * but older/slower device may have a flicker
554
+ * if we did not do this.
555
+ */
556
+ writeTask(() => {
557
+ this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), { month, day: day, year }));
558
+ calendarBodyRef.scrollLeft = workingMonth.clientWidth * (isRTL(this.el) ? -1 : 1);
559
+ calendarBodyRef.style.removeProperty('overflow');
560
+ if (this.resolveForceDateScrolling) {
561
+ this.resolveForceDateScrolling();
562
+ }
563
+ });
564
+ };
565
+ /**
566
+ * When the container finishes scrolling we
567
+ * need to update the DOM with the selected month.
568
+ */
569
+ let scrollTimeout;
570
+ /**
571
+ * We do not want to attempt to set pointer-events
572
+ * multiple times within a single swipe gesture as
573
+ * that adds unnecessary work to the main thread.
574
+ */
575
+ let appliediOSRubberBandFix = false;
576
+ const scrollCallback = () => {
577
+ if (scrollTimeout) {
578
+ clearTimeout(scrollTimeout);
579
+ }
580
+ /**
581
+ * On iOS it is possible to quickly rubber band
582
+ * the scroll area before the scroll timeout has fired.
583
+ * This results in users reaching the end of the scrollable
584
+ * container before the DOM has updated.
585
+ * By setting `pointer-events: none` we can ensure that
586
+ * subsequent swipes do not happen while the container
587
+ * is snapping.
588
+ */
589
+ if (!appliediOSRubberBandFix && needsiOSRubberBandFix) {
590
+ calendarBodyRef.style.setProperty('pointer-events', 'none');
591
+ appliediOSRubberBandFix = true;
592
+ }
593
+ // Wait ~3 frames
594
+ scrollTimeout = setTimeout(updateActiveMonth, 50);
595
+ };
596
+ calendarBodyRef.addEventListener('scroll', scrollCallback);
597
+ this.destroyCalendarListener = () => {
598
+ calendarBodyRef.removeEventListener('scroll', scrollCallback);
599
+ };
600
+ });
601
+ };
602
+ /**
603
+ * Clean up all listeners except for the overlay
604
+ * listener. This is so that we can re-create the listeners
605
+ * if the datetime has been hidden/presented by a modal or popover.
606
+ */
607
+ this.destroyInteractionListeners = () => {
608
+ const { destroyCalendarListener, destroyKeyboardMO } = this;
609
+ if (destroyCalendarListener !== undefined) {
610
+ destroyCalendarListener();
611
+ }
612
+ if (destroyKeyboardMO !== undefined) {
613
+ destroyKeyboardMO();
614
+ }
615
+ };
616
+ this.processValue = (value) => {
617
+ const hasValue = value !== null && value !== undefined && (!Array.isArray(value) || value.length > 0);
618
+ const valueToProcess = hasValue ? parseDate(value) : this.defaultParts;
619
+ const { minParts, maxParts, workingParts, el } = this;
620
+ this.warnIfIncorrectValueUsage();
621
+ /**
622
+ * Return early if the value wasn't parsed correctly, such as
623
+ * if an improperly formatted date string was provided.
624
+ */
625
+ if (!valueToProcess) {
626
+ return;
627
+ }
628
+ /**
629
+ * Datetime should only warn of out of bounds values
630
+ * if set by the user. If the `value` is undefined,
631
+ * we will default to today's date which may be out
632
+ * of bounds. In this case, the warning makes it look
633
+ * like the developer did something wrong which is
634
+ * not true.
635
+ */
636
+ if (hasValue) {
637
+ warnIfValueOutOfBounds(valueToProcess, minParts, maxParts);
638
+ }
639
+ /**
640
+ * If there are multiple values, pick an arbitrary one to clamp to. This way,
641
+ * if the values are across months, we always show at least one of them. Note
642
+ * that the values don't necessarily have to be in order.
643
+ */
644
+ const singleValue = Array.isArray(valueToProcess) ? valueToProcess[0] : valueToProcess;
645
+ const targetValue = clampDate(singleValue, minParts, maxParts);
646
+ const { month, day, year, hour, minute } = targetValue;
647
+ const ampm = parseAmPm(hour);
648
+ /**
649
+ * Since `activeParts` indicates a value that
650
+ * been explicitly selected either by the
651
+ * user or the app, only update `activeParts`
652
+ * if the `value` property is set.
653
+ */
654
+ if (hasValue) {
655
+ if (Array.isArray(valueToProcess)) {
656
+ this.activeParts = [...valueToProcess];
657
+ }
658
+ else {
659
+ this.activeParts = {
660
+ month,
661
+ day,
662
+ year,
663
+ hour,
664
+ minute,
665
+ ampm,
666
+ };
667
+ }
668
+ }
669
+ else {
670
+ /**
671
+ * Reset the active parts if the value is not set.
672
+ * This will clear the selected calendar day when
673
+ * performing a clear action or using the reset() method.
674
+ */
675
+ this.activeParts = [];
676
+ }
677
+ /**
678
+ * Only animate if:
679
+ * 1. We're using grid style (wheel style pickers should just jump to new value)
680
+ * 2. The month and/or year actually changed, and both are defined (otherwise there's nothing to animate to)
681
+ * 3. The calendar body is visible (prevents animation when in collapsed datetime-button, for example)
682
+ * 4. The month/year picker is not open (since you wouldn't see the animation anyway)
683
+ */
684
+ const didChangeMonth = (month !== undefined && month !== workingParts.month) || (year !== undefined && year !== workingParts.year);
685
+ const bodyIsVisible = el.classList.contains('datetime-ready');
686
+ const { isGridStyle, showMonthAndYear } = this;
687
+ if (isGridStyle && didChangeMonth && bodyIsVisible && !showMonthAndYear) {
688
+ this.animateToDate(targetValue);
689
+ }
690
+ else {
691
+ /**
692
+ * We only need to do this if we didn't just animate to a new month,
693
+ * since that calls prevMonth/nextMonth which calls setWorkingParts for us.
694
+ */
695
+ this.setWorkingParts({
696
+ month,
697
+ day,
698
+ year,
699
+ hour,
700
+ minute,
701
+ ampm,
702
+ });
703
+ }
704
+ };
705
+ this.animateToDate = async (targetValue) => {
706
+ const { workingParts } = this;
707
+ /**
708
+ * Tell other render functions that we need to force the
709
+ * target month to appear in place of the actual next/prev month.
710
+ * Because this is a State variable, a rerender will be triggered
711
+ * automatically, updating the rendered months.
712
+ */
713
+ this.forceRenderDate = targetValue;
714
+ /**
715
+ * Flag that we've started scrolling to the forced date.
716
+ * The resolve function will be called by the datetime's
717
+ * scroll listener when it's done updating everything.
718
+ * This is a replacement for making prev/nextMonth async,
719
+ * since the logic we're waiting on is in a listener.
720
+ */
721
+ const forceDateScrollingPromise = new Promise((resolve) => {
722
+ this.resolveForceDateScrolling = resolve;
723
+ });
724
+ /**
725
+ * Animate smoothly to the forced month. This will also update
726
+ * workingParts and correct the surrounding months for us.
727
+ */
728
+ const targetMonthIsBefore = isBefore(targetValue, workingParts);
729
+ targetMonthIsBefore ? this.prevMonth() : this.nextMonth();
730
+ await forceDateScrollingPromise;
731
+ this.resolveForceDateScrolling = undefined;
732
+ this.forceRenderDate = undefined;
733
+ };
734
+ this.onFocus = () => {
735
+ this.ionFocus.emit();
736
+ };
737
+ this.onBlur = () => {
738
+ this.ionBlur.emit();
739
+ };
740
+ this.hasValue = () => {
741
+ return this.value != null;
742
+ };
743
+ this.nextMonth = () => {
744
+ const calendarBodyRef = this.calendarBodyRef;
745
+ if (!calendarBodyRef) {
746
+ return;
747
+ }
748
+ const nextMonth = calendarBodyRef.querySelector('.calendar-month:last-of-type');
749
+ if (!nextMonth) {
750
+ return;
751
+ }
752
+ const left = nextMonth.offsetWidth * 2;
753
+ calendarBodyRef.scrollTo({
754
+ top: 0,
755
+ left: left * (isRTL(this.el) ? -1 : 1),
756
+ behavior: 'smooth',
757
+ });
758
+ };
759
+ this.prevMonth = () => {
760
+ const calendarBodyRef = this.calendarBodyRef;
761
+ if (!calendarBodyRef) {
762
+ return;
763
+ }
764
+ const prevMonth = calendarBodyRef.querySelector('.calendar-month:first-of-type');
765
+ if (!prevMonth) {
766
+ return;
767
+ }
768
+ calendarBodyRef.scrollTo({
769
+ top: 0,
770
+ left: 0,
771
+ behavior: 'smooth',
772
+ });
773
+ };
774
+ this.toggleMonthAndYearView = () => {
775
+ this.showMonthAndYear = !this.showMonthAndYear;
776
+ };
777
+ this.showMonthAndYear = false;
778
+ this.activeParts = [];
779
+ this.workingParts = {
780
+ month: 5,
781
+ day: 28,
782
+ year: 2021,
783
+ hour: 13,
784
+ minute: 52,
785
+ ampm: 'pm',
786
+ };
787
+ this.isTimePopoverOpen = false;
788
+ this.forceRenderDate = undefined;
789
+ this.color = 'primary';
790
+ this.name = this.inputId;
791
+ this.disabled = false;
792
+ this.readonly = false;
793
+ this.isDateEnabled = undefined;
794
+ this.min = undefined;
795
+ this.max = undefined;
796
+ this.presentation = 'date-time';
797
+ this.cancelText = 'Cancel';
798
+ this.doneText = 'Done';
799
+ this.clearText = 'Clear';
800
+ this.yearValues = undefined;
801
+ this.monthValues = undefined;
802
+ this.dayValues = undefined;
803
+ this.hourValues = undefined;
804
+ this.minuteValues = undefined;
805
+ this.locale = 'default';
806
+ this.firstDayOfWeek = 0;
807
+ this.titleSelectedDatesFormatter = undefined;
808
+ this.multiple = false;
809
+ this.highlightedDates = undefined;
810
+ this.value = undefined;
811
+ this.showDefaultTitle = false;
812
+ this.showDefaultButtons = false;
813
+ this.showClearButton = false;
814
+ this.showDefaultTimeLabel = true;
815
+ this.hourCycle = undefined;
816
+ this.size = 'fixed';
817
+ this.preferWheel = false;
818
+ }
819
+ disabledChanged() {
820
+ this.emitStyle();
821
+ }
822
+ minChanged() {
823
+ this.processMinParts();
824
+ }
825
+ maxChanged() {
826
+ this.processMaxParts();
827
+ }
828
+ get isGridStyle() {
829
+ const { presentation, preferWheel } = this;
830
+ const hasDatePresentation = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
831
+ return hasDatePresentation && !preferWheel;
832
+ }
833
+ yearValuesChanged() {
834
+ this.parsedYearValues = convertToArrayOfNumbers(this.yearValues);
835
+ }
836
+ monthValuesChanged() {
837
+ this.parsedMonthValues = convertToArrayOfNumbers(this.monthValues);
838
+ }
839
+ dayValuesChanged() {
840
+ this.parsedDayValues = convertToArrayOfNumbers(this.dayValues);
841
+ }
842
+ hourValuesChanged() {
843
+ this.parsedHourValues = convertToArrayOfNumbers(this.hourValues);
844
+ }
845
+ minuteValuesChanged() {
846
+ this.parsedMinuteValues = convertToArrayOfNumbers(this.minuteValues);
847
+ }
226
848
  /**
227
- * Returns the DatetimePart interface
228
- * to use when rendering an initial set of
229
- * data. This should be used when rendering an
230
- * interface in an environment where the `value`
231
- * may not be set. This function works
232
- * by returning the first selected date and then
233
- * falling back to defaultParts if no active date
234
- * is selected.
849
+ * Update the datetime value when the value changes
235
850
  */
236
- this.getActivePartsWithFallback = () => {
237
- var _a;
238
- const { defaultParts } = this;
239
- return (_a = this.getActivePart()) !== null && _a !== void 0 ? _a : defaultParts;
240
- };
241
- this.getActivePart = () => {
242
- const { activeParts } = this;
243
- return Array.isArray(activeParts) ? activeParts[0] : activeParts;
244
- };
245
- this.closeParentOverlay = () => {
246
- const popoverOrModal = this.el.closest('ion-modal, ion-popover');
247
- if (popoverOrModal) {
248
- popoverOrModal.dismiss();
249
- }
250
- };
251
- this.setWorkingParts = (parts) => {
252
- this.workingParts = Object.assign({}, parts);
253
- };
254
- this.setActiveParts = (parts, removeDate = false) => {
255
- const { multiple, minParts, maxParts, activeParts } = this;
256
- /**
257
- * When setting the active parts, it is possible
258
- * to set invalid data. For example,
259
- * when updating January 31 to February,
260
- * February 31 does not exist. As a result
261
- * we need to validate the active parts and
262
- * ensure that we are only setting valid dates.
263
- * Additionally, we need to update the working parts
264
- * too in the event that the validated parts are different.
265
- */
266
- const validatedParts = validateParts(parts, minParts, maxParts);
267
- this.setWorkingParts(validatedParts);
268
- if (multiple) {
269
- const activePartsArray = Array.isArray(activeParts) ? activeParts : [activeParts];
270
- if (removeDate) {
271
- this.activeParts = activePartsArray.filter((p) => !isSameDay(p, validatedParts));
851
+ async valueChanged() {
852
+ const { value } = this;
853
+ if (this.hasValue()) {
854
+ this.processValue(value);
272
855
  }
273
- else {
274
- this.activeParts = [...activePartsArray, validatedParts];
275
- }
276
- }
277
- else {
278
- this.activeParts = Object.assign({}, validatedParts);
279
- }
280
- const hasSlottedButtons = this.el.querySelector('[slot="buttons"]') !== null;
281
- if (hasSlottedButtons || this.showDefaultButtons) {
282
- return;
283
- }
284
- this.confirm();
285
- };
286
- this.initializeKeyboardListeners = () => {
287
- const calendarBodyRef = this.calendarBodyRef;
288
- if (!calendarBodyRef) {
289
- return;
290
- }
291
- const root = this.el.shadowRoot;
292
- /**
293
- * Get a reference to the month
294
- * element we are currently viewing.
295
- */
296
- const currentMonth = calendarBodyRef.querySelector('.calendar-month:nth-of-type(2)');
297
- /**
298
- * When focusing the calendar body, we want to pass focus
299
- * to the working day, but other days should
300
- * only be accessible using the arrow keys. Pressing
301
- * Tab should jump between bodies of selectable content.
302
- */
303
- const checkCalendarBodyFocus = (ev) => {
304
- var _a;
305
- const record = ev[0];
856
+ this.emitStyle();
857
+ this.ionValueChange.emit({ value });
858
+ }
859
+ /**
860
+ * Confirms the selected datetime value, updates the
861
+ * `value` property, and optionally closes the popover
862
+ * or modal that the datetime was presented in.
863
+ */
864
+ async confirm(closeOverlay = false) {
865
+ const { isCalendarPicker, activeParts } = this;
306
866
  /**
307
- * If calendar body was already focused
308
- * when this fired or if the calendar body
309
- * if not currently focused, we should not re-focus
310
- * the inner day.
867
+ * We only update the value if the presentation is not a calendar picker.
311
868
  */
312
- if (((_a = record.oldValue) === null || _a === void 0 ? void 0 : _a.includes('ion-focused')) || !calendarBodyRef.classList.contains('ion-focused')) {
313
- return;
869
+ if (activeParts !== undefined || !isCalendarPicker) {
870
+ const activePartsIsArray = Array.isArray(activeParts);
871
+ if (activePartsIsArray && activeParts.length === 0) {
872
+ this.setValue(undefined);
873
+ }
874
+ else {
875
+ this.setValue(convertDataToISO(activeParts));
876
+ }
314
877
  }
315
- this.focusWorkingDay(currentMonth);
316
- };
317
- const mo = new MutationObserver(checkCalendarBodyFocus);
318
- mo.observe(calendarBodyRef, { attributeFilter: ['class'], attributeOldValue: true });
319
- this.destroyKeyboardMO = () => {
320
- mo === null || mo === void 0 ? void 0 : mo.disconnect();
321
- };
322
- /**
323
- * We must use keydown not keyup as we want
324
- * to prevent scrolling when using the arrow keys.
325
- */
326
- calendarBodyRef.addEventListener('keydown', (ev) => {
327
- const activeElement = root.activeElement;
328
- if (!activeElement || !activeElement.classList.contains('calendar-day')) {
329
- return;
878
+ if (closeOverlay) {
879
+ this.closeParentOverlay();
330
880
  }
331
- const parts = getPartsFromCalendarDay(activeElement);
332
- let partsToFocus;
333
- switch (ev.key) {
334
- case 'ArrowDown':
335
- ev.preventDefault();
336
- partsToFocus = getNextWeek(parts);
337
- break;
338
- case 'ArrowUp':
339
- ev.preventDefault();
340
- partsToFocus = getPreviousWeek(parts);
341
- break;
342
- case 'ArrowRight':
343
- ev.preventDefault();
344
- partsToFocus = getNextDay(parts);
345
- break;
346
- case 'ArrowLeft':
347
- ev.preventDefault();
348
- partsToFocus = getPreviousDay(parts);
349
- break;
350
- case 'Home':
351
- ev.preventDefault();
352
- partsToFocus = getStartOfWeek(parts);
353
- break;
354
- case 'End':
355
- ev.preventDefault();
356
- partsToFocus = getEndOfWeek(parts);
357
- break;
358
- case 'PageUp':
359
- ev.preventDefault();
360
- partsToFocus = ev.shiftKey ? getPreviousYear(parts) : getPreviousMonth(parts);
361
- break;
362
- case 'PageDown':
363
- ev.preventDefault();
364
- partsToFocus = ev.shiftKey ? getNextYear(parts) : getNextMonth(parts);
365
- break;
366
- /**
367
- * Do not preventDefault here
368
- * as we do not want to override other
369
- * browser defaults such as pressing Enter/Space
370
- * to select a day.
371
- */
372
- default:
373
- return;
881
+ }
882
+ /**
883
+ * Resets the internal state of the datetime but does not update the value.
884
+ * Passing a valid ISO-8601 string will reset the state of the component to the provided date.
885
+ * If no value is provided, the internal state will be reset to the clamped value of the min, max and today.
886
+ */
887
+ async reset(startDate) {
888
+ this.processValue(startDate);
889
+ }
890
+ /**
891
+ * Emits the ionCancel event and
892
+ * optionally closes the popover
893
+ * or modal that the datetime was
894
+ * presented in.
895
+ */
896
+ async cancel(closeOverlay = false) {
897
+ this.ionCancel.emit();
898
+ if (closeOverlay) {
899
+ this.closeParentOverlay();
374
900
  }
375
- /**
376
- * If the day we want to move focus to is
377
- * disabled, do not do anything.
378
- */
379
- if (isDayDisabled(partsToFocus, this.minParts, this.maxParts)) {
380
- return;
901
+ }
902
+ get isCalendarPicker() {
903
+ const { presentation } = this;
904
+ return presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
905
+ }
906
+ connectedCallback() {
907
+ this.clearFocusVisible = startFocusVisible(this.el).destroy;
908
+ }
909
+ disconnectedCallback() {
910
+ if (this.clearFocusVisible) {
911
+ this.clearFocusVisible();
912
+ this.clearFocusVisible = undefined;
381
913
  }
382
- this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), partsToFocus));
914
+ }
915
+ initializeListeners() {
916
+ this.initializeCalendarListener();
917
+ this.initializeKeyboardListeners();
918
+ }
919
+ componentDidLoad() {
383
920
  /**
384
- * Give view a chance to re-render
385
- * then move focus to the new working day
921
+ * If a scrollable element is hidden using `display: none`,
922
+ * it will not have a scroll height meaning we cannot scroll elements
923
+ * into view. As a result, we will need to wait for the datetime to become
924
+ * visible if used inside of a modal or a popover otherwise the scrollable
925
+ * areas will not have the correct values snapped into place.
386
926
  */
387
- requestAnimationFrame(() => this.focusWorkingDay(currentMonth));
388
- });
389
- };
390
- this.focusWorkingDay = (currentMonth) => {
391
- /**
392
- * Get the number of padding days so
393
- * we know how much to offset our next selector by
394
- * to grab the correct calendar-day element.
395
- */
396
- const padding = currentMonth.querySelectorAll('.calendar-day-padding');
397
- const { day } = this.workingParts;
398
- if (day === null) {
399
- return;
400
- }
401
- /**
402
- * Get the calendar day element
403
- * and focus it.
404
- */
405
- const dayEl = currentMonth.querySelector(`.calendar-day-wrapper:nth-of-type(${padding.length + day}) .calendar-day`);
406
- if (dayEl) {
407
- dayEl.focus();
408
- }
409
- };
410
- this.processMinParts = () => {
411
- const { min, defaultParts } = this;
412
- if (min === undefined) {
413
- this.minParts = undefined;
414
- return;
415
- }
416
- this.minParts = parseMinParts(min, defaultParts);
417
- };
418
- this.processMaxParts = () => {
419
- const { max, defaultParts } = this;
420
- if (max === undefined) {
421
- this.maxParts = undefined;
422
- return;
423
- }
424
- this.maxParts = parseMaxParts(max, defaultParts);
425
- };
426
- this.initializeCalendarListener = () => {
427
- const calendarBodyRef = this.calendarBodyRef;
428
- if (!calendarBodyRef) {
429
- return;
430
- }
431
- /**
432
- * For performance reasons, we only render 3
433
- * months at a time: The current month, the previous
434
- * month, and the next month. We have a scroll listener
435
- * on the calendar body to append/prepend new months.
436
- *
437
- * We can do this because Stencil is smart enough to not
438
- * re-create the .calendar-month containers, but rather
439
- * update the content within those containers.
440
- *
441
- * As an added bonus, WebKit has some troubles with
442
- * scroll-snap-stop: always, so not rendering all of
443
- * the months in a row allows us to mostly sidestep
444
- * that issue.
445
- */
446
- const months = calendarBodyRef.querySelectorAll('.calendar-month');
447
- const startMonth = months[0];
448
- const workingMonth = months[1];
449
- const endMonth = months[2];
450
- const mode = getIonMode(this);
451
- const needsiOSRubberBandFix = mode === 'ios' && typeof navigator !== 'undefined' && navigator.maxTouchPoints > 1;
452
- /**
453
- * Before setting up the scroll listener,
454
- * scroll the middle month into view.
455
- * scrollIntoView() will scroll entire page
456
- * if element is not in viewport. Use scrollLeft instead.
457
- */
458
- writeTask(() => {
459
- calendarBodyRef.scrollLeft = startMonth.clientWidth * (isRTL(this.el) ? -1 : 1);
460
- const getChangedMonth = (parts) => {
461
- const box = calendarBodyRef.getBoundingClientRect();
462
- /**
463
- * If the current scroll position is all the way to the left
464
- * then we have scrolled to the previous month.
465
- * Otherwise, assume that we have scrolled to the next
466
- * month. We have a tolerance of 2px to account for
467
- * sub pixel rendering.
468
- *
469
- * Check below the next line ensures that we did not
470
- * swipe and abort (i.e. we swiped but we are still on the current month).
471
- */
472
- const month = calendarBodyRef.scrollLeft <= 2 ? startMonth : endMonth;
473
- /**
474
- * The edge of the month must be lined up with
475
- * the edge of the calendar body in order for
476
- * the component to update. Otherwise, it
477
- * may be the case that the user has paused their
478
- * swipe or the browser has not finished snapping yet.
479
- * Rather than check if the x values are equal,
480
- * we give it a tolerance of 2px to account for
481
- * sub pixel rendering.
482
- */
483
- const monthBox = month.getBoundingClientRect();
484
- if (Math.abs(monthBox.x - box.x) > 2)
485
- return;
486
- /**
487
- * If we're force-rendering a month, assume we've
488
- * scrolled to that and return it.
489
- *
490
- * If forceRenderDate is ever used in a context where the
491
- * forced month is not immediately auto-scrolled to, this
492
- * should be updated to also check whether `month` has the
493
- * same month and year as the forced date.
494
- */
495
- const { forceRenderDate } = this;
496
- if (forceRenderDate !== undefined) {
497
- return { month: forceRenderDate.month, year: forceRenderDate.year, day: forceRenderDate.day };
498
- }
499
- /**
500
- * From here, we can determine if the start
501
- * month or the end month was scrolled into view.
502
- * If no month was changed, then we can return from
503
- * the scroll callback early.
504
- */
505
- if (month === startMonth) {
506
- return getPreviousMonth(parts);
507
- }
508
- else if (month === endMonth) {
509
- return getNextMonth(parts);
510
- }
511
- else {
512
- return;
513
- }
514
- };
515
- const updateActiveMonth = () => {
516
- if (needsiOSRubberBandFix) {
517
- calendarBodyRef.style.removeProperty('pointer-events');
518
- appliediOSRubberBandFix = false;
519
- }
520
- /**
521
- * If the month did not change
522
- * then we can return early.
523
- */
524
- const newDate = getChangedMonth(this.workingParts);
525
- if (!newDate)
526
- return;
527
- const { month, day, year } = newDate;
528
- if (isMonthDisabled({ month, year, day: null }, {
529
- minParts: Object.assign(Object.assign({}, this.minParts), { day: null }),
530
- maxParts: Object.assign(Object.assign({}, this.maxParts), { day: null }),
531
- })) {
532
- return;
533
- }
534
- /**
535
- * Prevent scrolling for other browsers
536
- * to give the DOM time to update and the container
537
- * time to properly snap.
538
- */
539
- calendarBodyRef.style.setProperty('overflow', 'hidden');
540
- /**
541
- * Use a writeTask here to ensure
542
- * that the state is updated and the
543
- * correct month is scrolled into view
544
- * in the same frame. This is not
545
- * typically a problem on newer devices
546
- * but older/slower device may have a flicker
547
- * if we did not do this.
548
- */
549
- writeTask(() => {
550
- this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), { month, day: day, year }));
551
- calendarBodyRef.scrollLeft = workingMonth.clientWidth * (isRTL(this.el) ? -1 : 1);
552
- calendarBodyRef.style.removeProperty('overflow');
553
- if (this.resolveForceDateScrolling) {
554
- this.resolveForceDateScrolling();
927
+ const visibleCallback = (entries) => {
928
+ const ev = entries[0];
929
+ if (!ev.isIntersecting) {
930
+ return;
555
931
  }
556
- });
932
+ this.initializeListeners();
933
+ /**
934
+ * TODO FW-2793: Datetime needs a frame to ensure that it
935
+ * can properly scroll contents into view. As a result
936
+ * we hide the scrollable content until after that frame
937
+ * so users do not see the content quickly shifting. The downside
938
+ * is that the content will pop into view a frame after. Maybe there
939
+ * is a better way to handle this?
940
+ */
941
+ writeTask(() => {
942
+ this.el.classList.add('datetime-ready');
943
+ });
557
944
  };
945
+ const visibleIO = new IntersectionObserver(visibleCallback, { threshold: 0.01 });
558
946
  /**
559
- * When the container finishes scrolling we
560
- * need to update the DOM with the selected month.
947
+ * Use raf to avoid a race condition between the component loading and
948
+ * its display animation starting (such as when shown in a modal). This
949
+ * could cause the datetime to start at a visibility of 0, erroneously
950
+ * triggering the `hiddenIO` observer below.
561
951
  */
562
- let scrollTimeout;
952
+ raf(() => visibleIO === null || visibleIO === void 0 ? void 0 : visibleIO.observe(this.el));
563
953
  /**
564
- * We do not want to attempt to set pointer-events
565
- * multiple times within a single swipe gesture as
566
- * that adds unnecessary work to the main thread.
954
+ * We need to clean up listeners when the datetime is hidden
955
+ * in a popover/modal so that we can properly scroll containers
956
+ * back into view if they are re-presented. When the datetime is hidden
957
+ * the scroll areas have scroll widths/heights of 0px, so any snapping
958
+ * we did originally has been lost.
567
959
  */
568
- let appliediOSRubberBandFix = false;
569
- const scrollCallback = () => {
570
- if (scrollTimeout) {
571
- clearTimeout(scrollTimeout);
572
- }
573
- /**
574
- * On iOS it is possible to quickly rubber band
575
- * the scroll area before the scroll timeout has fired.
576
- * This results in users reaching the end of the scrollable
577
- * container before the DOM has updated.
578
- * By setting `pointer-events: none` we can ensure that
579
- * subsequent swipes do not happen while the container
580
- * is snapping.
581
- */
582
- if (!appliediOSRubberBandFix && needsiOSRubberBandFix) {
583
- calendarBodyRef.style.setProperty('pointer-events', 'none');
584
- appliediOSRubberBandFix = true;
585
- }
586
- // Wait ~3 frames
587
- scrollTimeout = setTimeout(updateActiveMonth, 50);
588
- };
589
- calendarBodyRef.addEventListener('scroll', scrollCallback);
590
- this.destroyCalendarListener = () => {
591
- calendarBodyRef.removeEventListener('scroll', scrollCallback);
960
+ const hiddenCallback = (entries) => {
961
+ const ev = entries[0];
962
+ if (ev.isIntersecting) {
963
+ return;
964
+ }
965
+ this.destroyInteractionListeners();
966
+ /**
967
+ * When datetime is hidden, we need to make sure that
968
+ * the month/year picker is closed. Otherwise,
969
+ * it will be open when the datetime re-appears
970
+ * and the scroll area of the calendar grid will be 0.
971
+ * As a result, the wrong month will be shown.
972
+ */
973
+ this.showMonthAndYear = false;
974
+ writeTask(() => {
975
+ this.el.classList.remove('datetime-ready');
976
+ });
592
977
  };
593
- });
594
- };
978
+ const hiddenIO = new IntersectionObserver(hiddenCallback, { threshold: 0 });
979
+ raf(() => hiddenIO === null || hiddenIO === void 0 ? void 0 : hiddenIO.observe(this.el));
980
+ /**
981
+ * Datetime uses Ionic components that emit
982
+ * ionFocus and ionBlur. These events are
983
+ * composed meaning they will cross
984
+ * the shadow dom boundary. We need to
985
+ * stop propagation on these events otherwise
986
+ * developers will see 2 ionFocus or 2 ionBlur
987
+ * events at a time.
988
+ */
989
+ const root = getElementRoot(this.el);
990
+ root.addEventListener('ionFocus', (ev) => ev.stopPropagation());
991
+ root.addEventListener('ionBlur', (ev) => ev.stopPropagation());
992
+ }
595
993
  /**
596
- * Clean up all listeners except for the overlay
597
- * listener. This is so that we can re-create the listeners
598
- * if the datetime has been hidden/presented by a modal or popover.
994
+ * When the presentation is changed, all calendar content is recreated,
995
+ * so we need to re-init behavior with the new elements.
599
996
  */
600
- this.destroyInteractionListeners = () => {
601
- const { destroyCalendarListener, destroyKeyboardMO } = this;
602
- if (destroyCalendarListener !== undefined) {
603
- destroyCalendarListener();
604
- }
605
- if (destroyKeyboardMO !== undefined) {
606
- destroyKeyboardMO();
607
- }
608
- };
609
- this.processValue = (value) => {
610
- const hasValue = value !== null && value !== undefined && (!Array.isArray(value) || value.length > 0);
611
- const valueToProcess = hasValue ? parseDate(value) : this.defaultParts;
612
- const { minParts, maxParts, workingParts, el } = this;
613
- this.warnIfIncorrectValueUsage();
614
- /**
615
- * Return early if the value wasn't parsed correctly, such as
616
- * if an improperly formatted date string was provided.
617
- */
618
- if (!valueToProcess) {
619
- return;
620
- }
621
- /**
622
- * Datetime should only warn of out of bounds values
623
- * if set by the user. If the `value` is undefined,
624
- * we will default to today's date which may be out
625
- * of bounds. In this case, the warning makes it look
626
- * like the developer did something wrong which is
627
- * not true.
628
- */
629
- if (hasValue) {
630
- warnIfValueOutOfBounds(valueToProcess, minParts, maxParts);
631
- }
632
- /**
633
- * If there are multiple values, pick an arbitrary one to clamp to. This way,
634
- * if the values are across months, we always show at least one of them. Note
635
- * that the values don't necessarily have to be in order.
636
- */
637
- const singleValue = Array.isArray(valueToProcess) ? valueToProcess[0] : valueToProcess;
638
- const targetValue = clampDate(singleValue, minParts, maxParts);
639
- const { month, day, year, hour, minute } = targetValue;
640
- const ampm = parseAmPm(hour);
641
- /**
642
- * Since `activeParts` indicates a value that
643
- * been explicitly selected either by the
644
- * user or the app, only update `activeParts`
645
- * if the `value` property is set.
646
- */
647
- if (hasValue) {
648
- if (Array.isArray(valueToProcess)) {
649
- this.activeParts = [...valueToProcess];
650
- }
651
- else {
652
- this.activeParts = {
653
- month,
654
- day,
655
- year,
656
- hour,
657
- minute,
658
- ampm,
659
- };
660
- }
661
- }
662
- else {
997
+ componentDidRender() {
998
+ const { presentation, prevPresentation, calendarBodyRef, minParts, preferWheel, forceRenderDate } = this;
663
999
  /**
664
- * Reset the active parts if the value is not set.
665
- * This will clear the selected calendar day when
666
- * performing a clear action or using the reset() method.
1000
+ * TODO(FW-2165)
1001
+ * Remove this when https://bugs.webkit.org/show_bug.cgi?id=235960 is fixed.
1002
+ * When using `min`, we add `scroll-snap-align: none`
1003
+ * to the disabled month so that users cannot scroll to it.
1004
+ * This triggers a bug in WebKit where the scroll position is reset.
1005
+ * Since the month change logic is handled by a scroll listener,
1006
+ * this causes the month to change leading to `scroll-snap-align`
1007
+ * changing again, thus changing the scroll position again and causing
1008
+ * an infinite loop.
1009
+ * This issue only applies to the calendar grid, so we can disable
1010
+ * it if the calendar grid is not being used.
667
1011
  */
668
- this.activeParts = [];
669
- }
670
- /**
671
- * Only animate if:
672
- * 1. We're using grid style (wheel style pickers should just jump to new value)
673
- * 2. The month and/or year actually changed, and both are defined (otherwise there's nothing to animate to)
674
- * 3. The calendar body is visible (prevents animation when in collapsed datetime-button, for example)
675
- * 4. The month/year picker is not open (since you wouldn't see the animation anyway)
676
- */
677
- const didChangeMonth = (month !== undefined && month !== workingParts.month) || (year !== undefined && year !== workingParts.year);
678
- const bodyIsVisible = el.classList.contains('datetime-ready');
679
- const { isGridStyle, showMonthAndYear } = this;
680
- if (isGridStyle && didChangeMonth && bodyIsVisible && !showMonthAndYear) {
681
- this.animateToDate(targetValue);
682
- }
683
- else {
1012
+ const hasCalendarGrid = !preferWheel && ['date-time', 'time-date', 'date'].includes(presentation);
1013
+ if (minParts !== undefined && hasCalendarGrid && calendarBodyRef) {
1014
+ const workingMonth = calendarBodyRef.querySelector('.calendar-month:nth-of-type(1)');
1015
+ /**
1016
+ * We need to make sure the datetime is not in the process
1017
+ * of scrolling to a new datetime value if the value
1018
+ * is updated programmatically.
1019
+ * Otherwise, the datetime will appear to not scroll at all because
1020
+ * we are resetting the scroll position to the center of the view.
1021
+ * Prior to the datetime's value being updated programmatically,
1022
+ * the calendarBodyRef is scrolled such that the middle month is centered
1023
+ * in the view. The below code updates the scroll position so the middle
1024
+ * month is also centered in the view. Since the scroll position did not change,
1025
+ * the scroll callback in this file does not fire,
1026
+ * and the resolveForceDateScrolling promise never resolves.
1027
+ */
1028
+ if (workingMonth && forceRenderDate === undefined) {
1029
+ calendarBodyRef.scrollLeft = workingMonth.clientWidth * (isRTL(this.el) ? -1 : 1);
1030
+ }
1031
+ }
1032
+ if (prevPresentation === null) {
1033
+ this.prevPresentation = presentation;
1034
+ return;
1035
+ }
1036
+ if (presentation === prevPresentation) {
1037
+ return;
1038
+ }
1039
+ this.prevPresentation = presentation;
1040
+ this.destroyInteractionListeners();
1041
+ this.initializeListeners();
684
1042
  /**
685
- * We only need to do this if we didn't just animate to a new month,
686
- * since that calls prevMonth/nextMonth which calls setWorkingParts for us.
1043
+ * The month/year picker from the date interface
1044
+ * should be closed as it is not available in non-date
1045
+ * interfaces.
687
1046
  */
688
- this.setWorkingParts({
689
- month,
690
- day,
691
- year,
692
- hour,
693
- minute,
694
- ampm,
1047
+ this.showMonthAndYear = false;
1048
+ raf(() => {
1049
+ this.ionRender.emit();
695
1050
  });
696
- }
697
- };
698
- this.animateToDate = async (targetValue) => {
699
- const { workingParts } = this;
700
- /**
701
- * Tell other render functions that we need to force the
702
- * target month to appear in place of the actual next/prev month.
703
- * Because this is a State variable, a rerender will be triggered
704
- * automatically, updating the rendered months.
705
- */
706
- this.forceRenderDate = targetValue;
707
- /**
708
- * Flag that we've started scrolling to the forced date.
709
- * The resolve function will be called by the datetime's
710
- * scroll listener when it's done updating everything.
711
- * This is a replacement for making prev/nextMonth async,
712
- * since the logic we're waiting on is in a listener.
713
- */
714
- const forceDateScrollingPromise = new Promise((resolve) => {
715
- this.resolveForceDateScrolling = resolve;
716
- });
717
- /**
718
- * Animate smoothly to the forced month. This will also update
719
- * workingParts and correct the surrounding months for us.
720
- */
721
- const targetMonthIsBefore = isBefore(targetValue, workingParts);
722
- targetMonthIsBefore ? this.prevMonth() : this.nextMonth();
723
- await forceDateScrollingPromise;
724
- this.resolveForceDateScrolling = undefined;
725
- this.forceRenderDate = undefined;
726
- };
727
- this.onFocus = () => {
728
- this.ionFocus.emit();
729
- };
730
- this.onBlur = () => {
731
- this.ionBlur.emit();
732
- };
733
- this.hasValue = () => {
734
- return this.value != null;
735
- };
736
- this.nextMonth = () => {
737
- const calendarBodyRef = this.calendarBodyRef;
738
- if (!calendarBodyRef) {
739
- return;
740
- }
741
- const nextMonth = calendarBodyRef.querySelector('.calendar-month:last-of-type');
742
- if (!nextMonth) {
743
- return;
744
- }
745
- const left = nextMonth.offsetWidth * 2;
746
- calendarBodyRef.scrollTo({
747
- top: 0,
748
- left: left * (isRTL(this.el) ? -1 : 1),
749
- behavior: 'smooth',
750
- });
751
- };
752
- this.prevMonth = () => {
753
- const calendarBodyRef = this.calendarBodyRef;
754
- if (!calendarBodyRef) {
755
- return;
756
- }
757
- const prevMonth = calendarBodyRef.querySelector('.calendar-month:first-of-type');
758
- if (!prevMonth) {
759
- return;
760
- }
761
- calendarBodyRef.scrollTo({
762
- top: 0,
763
- left: 0,
764
- behavior: 'smooth',
765
- });
766
- };
767
- this.toggleMonthAndYearView = () => {
768
- this.showMonthAndYear = !this.showMonthAndYear;
769
- };
770
- this.showMonthAndYear = false;
771
- this.activeParts = [];
772
- this.workingParts = {
773
- month: 5,
774
- day: 28,
775
- year: 2021,
776
- hour: 13,
777
- minute: 52,
778
- ampm: 'pm',
779
- };
780
- this.isTimePopoverOpen = false;
781
- this.forceRenderDate = undefined;
782
- this.color = 'primary';
783
- this.name = this.inputId;
784
- this.disabled = false;
785
- this.readonly = false;
786
- this.isDateEnabled = undefined;
787
- this.min = undefined;
788
- this.max = undefined;
789
- this.presentation = 'date-time';
790
- this.cancelText = 'Cancel';
791
- this.doneText = 'Done';
792
- this.clearText = 'Clear';
793
- this.yearValues = undefined;
794
- this.monthValues = undefined;
795
- this.dayValues = undefined;
796
- this.hourValues = undefined;
797
- this.minuteValues = undefined;
798
- this.locale = 'default';
799
- this.firstDayOfWeek = 0;
800
- this.titleSelectedDatesFormatter = undefined;
801
- this.multiple = false;
802
- this.highlightedDates = undefined;
803
- this.value = undefined;
804
- this.showDefaultTitle = false;
805
- this.showDefaultButtons = false;
806
- this.showClearButton = false;
807
- this.showDefaultTimeLabel = true;
808
- this.hourCycle = undefined;
809
- this.size = 'fixed';
810
- this.preferWheel = false;
811
- }
812
- disabledChanged() {
813
- this.emitStyle();
814
- }
815
- minChanged() {
816
- this.processMinParts();
817
- }
818
- maxChanged() {
819
- this.processMaxParts();
820
- }
821
- get isGridStyle() {
822
- const { presentation, preferWheel } = this;
823
- const hasDatePresentation = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
824
- return hasDatePresentation && !preferWheel;
825
- }
826
- yearValuesChanged() {
827
- this.parsedYearValues = convertToArrayOfNumbers(this.yearValues);
828
- }
829
- monthValuesChanged() {
830
- this.parsedMonthValues = convertToArrayOfNumbers(this.monthValues);
831
- }
832
- dayValuesChanged() {
833
- this.parsedDayValues = convertToArrayOfNumbers(this.dayValues);
834
- }
835
- hourValuesChanged() {
836
- this.parsedHourValues = convertToArrayOfNumbers(this.hourValues);
837
- }
838
- minuteValuesChanged() {
839
- this.parsedMinuteValues = convertToArrayOfNumbers(this.minuteValues);
840
- }
841
- /**
842
- * Update the datetime value when the value changes
843
- */
844
- async valueChanged() {
845
- const { value } = this;
846
- if (this.hasValue()) {
847
- this.processValue(value);
848
- }
849
- this.emitStyle();
850
- this.ionValueChange.emit({ value });
851
- }
852
- /**
853
- * Confirms the selected datetime value, updates the
854
- * `value` property, and optionally closes the popover
855
- * or modal that the datetime was presented in.
856
- */
857
- async confirm(closeOverlay = false) {
858
- const { isCalendarPicker, activeParts } = this;
859
- /**
860
- * We only update the value if the presentation is not a calendar picker.
861
- */
862
- if (activeParts !== undefined || !isCalendarPicker) {
863
- const activePartsIsArray = Array.isArray(activeParts);
864
- if (activePartsIsArray && activeParts.length === 0) {
865
- this.setValue(undefined);
866
- }
867
- else {
868
- this.setValue(convertDataToISO(activeParts));
869
- }
870
- }
871
- if (closeOverlay) {
872
- this.closeParentOverlay();
873
- }
874
- }
875
- /**
876
- * Resets the internal state of the datetime but does not update the value.
877
- * Passing a valid ISO-8601 string will reset the state of the component to the provided date.
878
- * If no value is provided, the internal state will be reset to the clamped value of the min, max and today.
879
- */
880
- async reset(startDate) {
881
- this.processValue(startDate);
882
- }
883
- /**
884
- * Emits the ionCancel event and
885
- * optionally closes the popover
886
- * or modal that the datetime was
887
- * presented in.
888
- */
889
- async cancel(closeOverlay = false) {
890
- this.ionCancel.emit();
891
- if (closeOverlay) {
892
- this.closeParentOverlay();
893
- }
894
- }
895
- get isCalendarPicker() {
896
- const { presentation } = this;
897
- return presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
898
- }
899
- connectedCallback() {
900
- this.clearFocusVisible = startFocusVisible(this.el).destroy;
901
- }
902
- disconnectedCallback() {
903
- if (this.clearFocusVisible) {
904
- this.clearFocusVisible();
905
- this.clearFocusVisible = undefined;
906
- }
907
- }
908
- initializeListeners() {
909
- this.initializeCalendarListener();
910
- this.initializeKeyboardListeners();
911
- }
912
- componentDidLoad() {
913
- /**
914
- * If a scrollable element is hidden using `display: none`,
915
- * it will not have a scroll height meaning we cannot scroll elements
916
- * into view. As a result, we will need to wait for the datetime to become
917
- * visible if used inside of a modal or a popover otherwise the scrollable
918
- * areas will not have the correct values snapped into place.
919
- */
920
- const visibleCallback = (entries) => {
921
- const ev = entries[0];
922
- if (!ev.isIntersecting) {
923
- return;
924
- }
925
- this.initializeListeners();
926
- /**
927
- * TODO FW-2793: Datetime needs a frame to ensure that it
928
- * can properly scroll contents into view. As a result
929
- * we hide the scrollable content until after that frame
930
- * so users do not see the content quickly shifting. The downside
931
- * is that the content will pop into view a frame after. Maybe there
932
- * is a better way to handle this?
933
- */
934
- writeTask(() => {
935
- this.el.classList.add('datetime-ready');
936
- });
937
- };
938
- const visibleIO = new IntersectionObserver(visibleCallback, { threshold: 0.01 });
939
- /**
940
- * Use raf to avoid a race condition between the component loading and
941
- * its display animation starting (such as when shown in a modal). This
942
- * could cause the datetime to start at a visibility of 0, erroneously
943
- * triggering the `hiddenIO` observer below.
944
- */
945
- raf(() => visibleIO === null || visibleIO === void 0 ? void 0 : visibleIO.observe(this.el));
946
- /**
947
- * We need to clean up listeners when the datetime is hidden
948
- * in a popover/modal so that we can properly scroll containers
949
- * back into view if they are re-presented. When the datetime is hidden
950
- * the scroll areas have scroll widths/heights of 0px, so any snapping
951
- * we did originally has been lost.
952
- */
953
- const hiddenCallback = (entries) => {
954
- const ev = entries[0];
955
- if (ev.isIntersecting) {
956
- return;
957
- }
958
- this.destroyInteractionListeners();
959
- /**
960
- * When datetime is hidden, we need to make sure that
961
- * the month/year picker is closed. Otherwise,
962
- * it will be open when the datetime re-appears
963
- * and the scroll area of the calendar grid will be 0.
964
- * As a result, the wrong month will be shown.
965
- */
966
- this.showMonthAndYear = false;
967
- writeTask(() => {
968
- this.el.classList.remove('datetime-ready');
969
- });
970
- };
971
- const hiddenIO = new IntersectionObserver(hiddenCallback, { threshold: 0 });
972
- raf(() => hiddenIO === null || hiddenIO === void 0 ? void 0 : hiddenIO.observe(this.el));
973
- /**
974
- * Datetime uses Ionic components that emit
975
- * ionFocus and ionBlur. These events are
976
- * composed meaning they will cross
977
- * the shadow dom boundary. We need to
978
- * stop propagation on these events otherwise
979
- * developers will see 2 ionFocus or 2 ionBlur
980
- * events at a time.
981
- */
982
- const root = getElementRoot(this.el);
983
- root.addEventListener('ionFocus', (ev) => ev.stopPropagation());
984
- root.addEventListener('ionBlur', (ev) => ev.stopPropagation());
985
- }
986
- /**
987
- * When the presentation is changed, all calendar content is recreated,
988
- * so we need to re-init behavior with the new elements.
989
- */
990
- componentDidRender() {
991
- const { presentation, prevPresentation, calendarBodyRef, minParts, preferWheel } = this;
992
- /**
993
- * TODO(FW-2165)
994
- * Remove this when https://bugs.webkit.org/show_bug.cgi?id=235960 is fixed.
995
- * When using `min`, we add `scroll-snap-align: none`
996
- * to the disabled month so that users cannot scroll to it.
997
- * This triggers a bug in WebKit where the scroll position is reset.
998
- * Since the month change logic is handled by a scroll listener,
999
- * this causes the month to change leading to `scroll-snap-align`
1000
- * changing again, thus changing the scroll position again and causing
1001
- * an infinite loop.
1002
- * This issue only applies to the calendar grid, so we can disable
1003
- * it if the calendar grid is not being used.
1004
- */
1005
- const hasCalendarGrid = !preferWheel && ['date-time', 'time-date', 'date'].includes(presentation);
1006
- if (minParts !== undefined && hasCalendarGrid && calendarBodyRef) {
1007
- const workingMonth = calendarBodyRef.querySelector('.calendar-month:nth-of-type(1)');
1008
- if (workingMonth) {
1009
- calendarBodyRef.scrollLeft = workingMonth.clientWidth * (isRTL(this.el) ? -1 : 1);
1010
- }
1011
- }
1012
- if (prevPresentation === null) {
1013
- this.prevPresentation = presentation;
1014
- return;
1015
- }
1016
- if (presentation === prevPresentation) {
1017
- return;
1018
- }
1019
- this.prevPresentation = presentation;
1020
- this.destroyInteractionListeners();
1021
- this.initializeListeners();
1022
- /**
1023
- * The month/year picker from the date interface
1024
- * should be closed as it is not available in non-date
1025
- * interfaces.
1026
- */
1027
- this.showMonthAndYear = false;
1028
- raf(() => {
1029
- this.ionRender.emit();
1030
- });
1031
- }
1032
- componentWillLoad() {
1033
- const { el, highlightedDates, multiple, presentation, preferWheel } = this;
1034
- if (multiple) {
1035
- if (presentation !== 'date') {
1036
- printIonWarning('Multiple date selection is only supported for presentation="date".', el);
1037
- }
1038
- if (preferWheel) {
1039
- printIonWarning('Multiple date selection is not supported with preferWheel="true".', el);
1040
- }
1041
- }
1042
- if (highlightedDates !== undefined) {
1043
- if (presentation !== 'date' && presentation !== 'date-time' && presentation !== 'time-date') {
1044
- printIonWarning('The highlightedDates property is only supported with the date, date-time, and time-date presentations.', el);
1045
- }
1046
- if (preferWheel) {
1047
- printIonWarning('The highlightedDates property is not supported with preferWheel="true".', el);
1048
- }
1049
- }
1050
- const hourValues = (this.parsedHourValues = convertToArrayOfNumbers(this.hourValues));
1051
- const minuteValues = (this.parsedMinuteValues = convertToArrayOfNumbers(this.minuteValues));
1052
- const monthValues = (this.parsedMonthValues = convertToArrayOfNumbers(this.monthValues));
1053
- const yearValues = (this.parsedYearValues = convertToArrayOfNumbers(this.yearValues));
1054
- const dayValues = (this.parsedDayValues = convertToArrayOfNumbers(this.dayValues));
1055
- const todayParts = (this.todayParts = parseDate(getToday()));
1056
- this.defaultParts = getClosestValidDate(todayParts, monthValues, dayValues, yearValues, hourValues, minuteValues);
1057
- this.processMinParts();
1058
- this.processMaxParts();
1059
- this.processValue(this.value);
1060
- this.emitStyle();
1061
- }
1062
- emitStyle() {
1063
- this.ionStyle.emit({
1064
- interactive: true,
1065
- datetime: true,
1066
- 'interactive-disabled': this.disabled,
1067
- });
1068
- }
1069
- /**
1070
- * Universal render methods
1071
- * These are pieces of datetime that
1072
- * are rendered independently of presentation.
1073
- */
1074
- renderFooter() {
1075
- const { showDefaultButtons, showClearButton } = this;
1076
- const hasSlottedButtons = this.el.querySelector('[slot="buttons"]') !== null;
1077
- if (!hasSlottedButtons && !showDefaultButtons && !showClearButton) {
1078
- return;
1079
- }
1080
- const clearButtonClick = () => {
1081
- this.reset();
1082
- this.setValue(undefined);
1083
- };
1084
- /**
1085
- * By default we render two buttons:
1086
- * Cancel - Dismisses the datetime and
1087
- * does not update the `value` prop.
1088
- * OK - Dismisses the datetime and
1089
- * updates the `value` prop.
1090
- */
1091
- return (h("div", { class: "datetime-footer" }, h("div", { class: "datetime-buttons" }, h("div", { class: {
1092
- ['datetime-action-buttons']: true,
1093
- ['has-clear-button']: this.showClearButton,
1094
- } }, 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)))))))));
1095
- }
1096
- /**
1097
- * Wheel picker render methods
1098
- */
1099
- renderWheelPicker(forcePresentation = this.presentation) {
1100
- /**
1101
- * If presentation="time-date" we switch the
1102
- * order of the render array here instead of
1103
- * manually reordering each date/time picker
1104
- * column with CSS. This allows for additional
1105
- * flexibility if we need to render subsets
1106
- * of the date/time data or do additional ordering
1107
- * within the child render functions.
1108
- */
1109
- const renderArray = forcePresentation === 'time-date'
1110
- ? [this.renderTimePickerColumns(forcePresentation), this.renderDatePickerColumns(forcePresentation)]
1111
- : [this.renderDatePickerColumns(forcePresentation), this.renderTimePickerColumns(forcePresentation)];
1112
- return h("ion-picker-internal", null, renderArray);
1113
- }
1114
- renderDatePickerColumns(forcePresentation) {
1115
- return forcePresentation === 'date-time' || forcePresentation === 'time-date'
1116
- ? this.renderCombinedDatePickerColumn()
1117
- : this.renderIndividualDatePickerColumns(forcePresentation);
1118
- }
1119
- renderCombinedDatePickerColumn() {
1120
- const { defaultParts, workingParts, locale, minParts, maxParts, todayParts, isDateEnabled } = this;
1121
- const activePart = this.getActivePartsWithFallback();
1122
- /**
1123
- * By default, generate a range of 3 months:
1124
- * Previous month, current month, and next month
1125
- */
1126
- const monthsToRender = generateMonths(workingParts);
1127
- const lastMonth = monthsToRender[monthsToRender.length - 1];
1128
- /**
1129
- * Ensure that users can select the entire window of dates.
1130
- */
1131
- monthsToRender[0].day = 1;
1132
- lastMonth.day = getNumDaysInMonth(lastMonth.month, lastMonth.year);
1133
- /**
1134
- * Narrow the dates rendered based on min/max dates (if any).
1135
- * The `min` date is used if the min is after the generated min month.
1136
- * The `max` date is used if the max is before the generated max month.
1137
- * This ensures that the sliding window always stays at 3 months
1138
- * but still allows future dates to be lazily rendered based on any min/max
1139
- * constraints.
1140
- */
1141
- const min = minParts !== undefined && isAfter(minParts, monthsToRender[0]) ? minParts : monthsToRender[0];
1142
- const max = maxParts !== undefined && isBefore(maxParts, lastMonth) ? maxParts : lastMonth;
1143
- const result = getCombinedDateColumnData(locale, todayParts, min, max, this.parsedDayValues, this.parsedMonthValues);
1144
- let items = result.items;
1145
- const parts = result.parts;
1146
- if (isDateEnabled) {
1147
- items = items.map((itemObject, index) => {
1148
- const referenceParts = parts[index];
1149
- let disabled;
1150
- try {
1151
- /**
1152
- * The `isDateEnabled` implementation is try-catch wrapped
1153
- * to prevent exceptions in the user's function from
1154
- * interrupting the calendar rendering.
1155
- */
1156
- disabled = !isDateEnabled(convertDataToISO(referenceParts));
1051
+ }
1052
+ componentWillLoad() {
1053
+ const { el, highlightedDates, multiple, presentation, preferWheel } = this;
1054
+ if (multiple) {
1055
+ if (presentation !== 'date') {
1056
+ printIonWarning('Multiple date selection is only supported for presentation="date".', el);
1057
+ }
1058
+ if (preferWheel) {
1059
+ printIonWarning('Multiple date selection is not supported with preferWheel="true".', el);
1060
+ }
1157
1061
  }
1158
- catch (e) {
1159
- printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', e);
1062
+ if (highlightedDates !== undefined) {
1063
+ if (presentation !== 'date' && presentation !== 'date-time' && presentation !== 'time-date') {
1064
+ printIonWarning('The highlightedDates property is only supported with the date, date-time, and time-date presentations.', el);
1065
+ }
1066
+ if (preferWheel) {
1067
+ printIonWarning('The highlightedDates property is not supported with preferWheel="true".', el);
1068
+ }
1160
1069
  }
1161
- return Object.assign(Object.assign({}, itemObject), { disabled });
1162
- });
1070
+ const hourValues = (this.parsedHourValues = convertToArrayOfNumbers(this.hourValues));
1071
+ const minuteValues = (this.parsedMinuteValues = convertToArrayOfNumbers(this.minuteValues));
1072
+ const monthValues = (this.parsedMonthValues = convertToArrayOfNumbers(this.monthValues));
1073
+ const yearValues = (this.parsedYearValues = convertToArrayOfNumbers(this.yearValues));
1074
+ const dayValues = (this.parsedDayValues = convertToArrayOfNumbers(this.dayValues));
1075
+ const todayParts = (this.todayParts = parseDate(getToday()));
1076
+ this.defaultParts = getClosestValidDate(todayParts, monthValues, dayValues, yearValues, hourValues, minuteValues);
1077
+ this.processMinParts();
1078
+ this.processMaxParts();
1079
+ this.processValue(this.value);
1080
+ this.emitStyle();
1081
+ }
1082
+ emitStyle() {
1083
+ this.ionStyle.emit({
1084
+ interactive: true,
1085
+ datetime: true,
1086
+ 'interactive-disabled': this.disabled,
1087
+ });
1163
1088
  }
1164
1089
  /**
1165
- * If we have selected a day already, then default the column
1166
- * to that value. Otherwise, set it to the default date.
1090
+ * Universal render methods
1091
+ * These are pieces of datetime that
1092
+ * are rendered independently of presentation.
1167
1093
  */
1168
- const todayString = workingParts.day !== null
1169
- ? `${workingParts.year}-${workingParts.month}-${workingParts.day}`
1170
- : `${defaultParts.year}-${defaultParts.month}-${defaultParts.day}`;
1171
- return (h("ion-picker-column-internal", { class: "date-column", color: this.color, items: items, value: todayString, onIonChange: (ev) => {
1172
- // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1173
- // Due to a Safari 14 issue we need to destroy
1174
- // the scroll listener before we update state
1175
- // and trigger a re-render.
1176
- if (this.destroyCalendarListener) {
1177
- this.destroyCalendarListener();
1094
+ renderFooter() {
1095
+ const { disabled, readonly, showDefaultButtons, showClearButton } = this;
1096
+ /**
1097
+ * The cancel, clear, and confirm buttons
1098
+ * should not be interactive if the datetime
1099
+ * is disabled or readonly.
1100
+ */
1101
+ const isButtonDisabled = disabled || readonly;
1102
+ const hasSlottedButtons = this.el.querySelector('[slot="buttons"]') !== null;
1103
+ if (!hasSlottedButtons && !showDefaultButtons && !showClearButton) {
1104
+ return;
1178
1105
  }
1179
- const { value } = ev.detail;
1180
- const findPart = parts.find(({ month, day, year }) => value === `${year}-${month}-${day}`);
1181
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), findPart));
1182
- this.setActiveParts(Object.assign(Object.assign({}, activePart), findPart));
1183
- // We can re-attach the scroll listener after
1184
- // the working parts have been updated.
1185
- this.initializeCalendarListener();
1186
- ev.stopPropagation();
1187
- } }));
1188
- }
1189
- renderIndividualDatePickerColumns(forcePresentation) {
1190
- const { workingParts, isDateEnabled } = this;
1191
- const shouldRenderMonths = forcePresentation !== 'year' && forcePresentation !== 'time';
1192
- const months = shouldRenderMonths
1193
- ? getMonthColumnData(this.locale, workingParts, this.minParts, this.maxParts, this.parsedMonthValues)
1194
- : [];
1195
- const shouldRenderDays = forcePresentation === 'date';
1196
- let days = shouldRenderDays
1197
- ? getDayColumnData(this.locale, workingParts, this.minParts, this.maxParts, this.parsedDayValues)
1198
- : [];
1199
- if (isDateEnabled) {
1200
- days = days.map((dayObject) => {
1201
- const { value } = dayObject;
1202
- const valueNum = typeof value === 'string' ? parseInt(value) : value;
1203
- const referenceParts = {
1204
- month: workingParts.month,
1205
- day: valueNum,
1206
- year: workingParts.year,
1106
+ const clearButtonClick = () => {
1107
+ this.reset();
1108
+ this.setValue(undefined);
1207
1109
  };
1208
- let disabled;
1209
- try {
1210
- /**
1211
- * The `isDateEnabled` implementation is try-catch wrapped
1212
- * to prevent exceptions in the user's function from
1213
- * interrupting the calendar rendering.
1214
- */
1215
- disabled = !isDateEnabled(convertDataToISO(referenceParts));
1216
- }
1217
- catch (e) {
1218
- printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', e);
1219
- }
1220
- return Object.assign(Object.assign({}, dayObject), { disabled });
1221
- });
1110
+ /**
1111
+ * By default we render two buttons:
1112
+ * Cancel - Dismisses the datetime and
1113
+ * does not update the `value` prop.
1114
+ * OK - Dismisses the datetime and
1115
+ * updates the `value` prop.
1116
+ */
1117
+ return (h("div", { class: "datetime-footer" }, h("div", { class: "datetime-buttons" }, h("div", { class: {
1118
+ ['datetime-action-buttons']: true,
1119
+ ['has-clear-button']: this.showClearButton,
1120
+ } }, 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)))))))));
1222
1121
  }
1223
- const shouldRenderYears = forcePresentation !== 'month' && forcePresentation !== 'time';
1224
- const years = shouldRenderYears
1225
- ? getYearColumnData(this.locale, this.defaultParts, this.minParts, this.maxParts, this.parsedYearValues)
1226
- : [];
1227
1122
  /**
1228
- * Certain locales show the day before the month.
1123
+ * Wheel picker render methods
1229
1124
  */
1230
- const showMonthFirst = isMonthFirstLocale(this.locale, { month: 'numeric', day: 'numeric' });
1231
- let renderArray = [];
1232
- if (showMonthFirst) {
1233
- renderArray = [
1234
- this.renderMonthPickerColumn(months),
1235
- this.renderDayPickerColumn(days),
1236
- this.renderYearPickerColumn(years),
1237
- ];
1125
+ renderWheelPicker(forcePresentation = this.presentation) {
1126
+ /**
1127
+ * If presentation="time-date" we switch the
1128
+ * order of the render array here instead of
1129
+ * manually reordering each date/time picker
1130
+ * column with CSS. This allows for additional
1131
+ * flexibility if we need to render subsets
1132
+ * of the date/time data or do additional ordering
1133
+ * within the child render functions.
1134
+ */
1135
+ const renderArray = forcePresentation === 'time-date'
1136
+ ? [this.renderTimePickerColumns(forcePresentation), this.renderDatePickerColumns(forcePresentation)]
1137
+ : [this.renderDatePickerColumns(forcePresentation), this.renderTimePickerColumns(forcePresentation)];
1138
+ return h("ion-picker-internal", null, renderArray);
1238
1139
  }
1239
- else {
1240
- renderArray = [
1241
- this.renderDayPickerColumn(days),
1242
- this.renderMonthPickerColumn(months),
1243
- this.renderYearPickerColumn(years),
1244
- ];
1245
- }
1246
- return renderArray;
1247
- }
1248
- renderDayPickerColumn(days) {
1249
- var _a;
1250
- if (days.length === 0) {
1251
- return [];
1252
- }
1253
- const { workingParts } = this;
1254
- const activePart = this.getActivePartsWithFallback();
1255
- 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) => {
1256
- // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1257
- // Due to a Safari 14 issue we need to destroy
1258
- // the scroll listener before we update state
1259
- // and trigger a re-render.
1260
- if (this.destroyCalendarListener) {
1261
- this.destroyCalendarListener();
1262
- }
1263
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { day: ev.detail.value }));
1264
- this.setActiveParts(Object.assign(Object.assign({}, activePart), { day: ev.detail.value }));
1265
- // We can re-attach the scroll listener after
1266
- // the working parts have been updated.
1267
- this.initializeCalendarListener();
1268
- ev.stopPropagation();
1269
- } }));
1270
- }
1271
- renderMonthPickerColumn(months) {
1272
- if (months.length === 0) {
1273
- return [];
1274
- }
1275
- const { workingParts } = this;
1276
- const activePart = this.getActivePartsWithFallback();
1277
- return (h("ion-picker-column-internal", { class: "month-column", color: this.color, items: months, value: workingParts.month, onIonChange: (ev) => {
1278
- // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1279
- // Due to a Safari 14 issue we need to destroy
1280
- // the scroll listener before we update state
1281
- // and trigger a re-render.
1282
- if (this.destroyCalendarListener) {
1283
- this.destroyCalendarListener();
1284
- }
1285
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { month: ev.detail.value }));
1286
- this.setActiveParts(Object.assign(Object.assign({}, activePart), { month: ev.detail.value }));
1287
- // We can re-attach the scroll listener after
1288
- // the working parts have been updated.
1289
- this.initializeCalendarListener();
1290
- ev.stopPropagation();
1291
- } }));
1292
- }
1293
- renderYearPickerColumn(years) {
1294
- if (years.length === 0) {
1295
- return [];
1296
- }
1297
- const { workingParts } = this;
1298
- const activePart = this.getActivePartsWithFallback();
1299
- return (h("ion-picker-column-internal", { class: "year-column", color: this.color, items: years, value: workingParts.year, onIonChange: (ev) => {
1300
- // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1301
- // Due to a Safari 14 issue we need to destroy
1302
- // the scroll listener before we update state
1303
- // and trigger a re-render.
1304
- if (this.destroyCalendarListener) {
1305
- this.destroyCalendarListener();
1140
+ renderDatePickerColumns(forcePresentation) {
1141
+ return forcePresentation === 'date-time' || forcePresentation === 'time-date'
1142
+ ? this.renderCombinedDatePickerColumn()
1143
+ : this.renderIndividualDatePickerColumns(forcePresentation);
1144
+ }
1145
+ renderCombinedDatePickerColumn() {
1146
+ const { defaultParts, disabled, workingParts, locale, minParts, maxParts, todayParts, isDateEnabled } = this;
1147
+ const activePart = this.getActivePartsWithFallback();
1148
+ /**
1149
+ * By default, generate a range of 3 months:
1150
+ * Previous month, current month, and next month
1151
+ */
1152
+ const monthsToRender = generateMonths(workingParts);
1153
+ const lastMonth = monthsToRender[monthsToRender.length - 1];
1154
+ /**
1155
+ * Ensure that users can select the entire window of dates.
1156
+ */
1157
+ monthsToRender[0].day = 1;
1158
+ lastMonth.day = getNumDaysInMonth(lastMonth.month, lastMonth.year);
1159
+ /**
1160
+ * Narrow the dates rendered based on min/max dates (if any).
1161
+ * The `min` date is used if the min is after the generated min month.
1162
+ * The `max` date is used if the max is before the generated max month.
1163
+ * This ensures that the sliding window always stays at 3 months
1164
+ * but still allows future dates to be lazily rendered based on any min/max
1165
+ * constraints.
1166
+ */
1167
+ const min = minParts !== undefined && isAfter(minParts, monthsToRender[0]) ? minParts : monthsToRender[0];
1168
+ const max = maxParts !== undefined && isBefore(maxParts, lastMonth) ? maxParts : lastMonth;
1169
+ const result = getCombinedDateColumnData(locale, todayParts, min, max, this.parsedDayValues, this.parsedMonthValues);
1170
+ let items = result.items;
1171
+ const parts = result.parts;
1172
+ if (isDateEnabled) {
1173
+ items = items.map((itemObject, index) => {
1174
+ const referenceParts = parts[index];
1175
+ let disabled;
1176
+ try {
1177
+ /**
1178
+ * The `isDateEnabled` implementation is try-catch wrapped
1179
+ * to prevent exceptions in the user's function from
1180
+ * interrupting the calendar rendering.
1181
+ */
1182
+ disabled = !isDateEnabled(convertDataToISO(referenceParts));
1183
+ }
1184
+ catch (e) {
1185
+ printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', e);
1186
+ }
1187
+ return Object.assign(Object.assign({}, itemObject), { disabled });
1188
+ });
1306
1189
  }
1307
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { year: ev.detail.value }));
1308
- this.setActiveParts(Object.assign(Object.assign({}, activePart), { year: ev.detail.value }));
1309
- // We can re-attach the scroll listener after
1310
- // the working parts have been updated.
1311
- this.initializeCalendarListener();
1312
- ev.stopPropagation();
1313
- } }));
1314
- }
1315
- renderTimePickerColumns(forcePresentation) {
1316
- if (['date', 'month', 'month-year', 'year'].includes(forcePresentation)) {
1317
- return [];
1190
+ /**
1191
+ * If we have selected a day already, then default the column
1192
+ * to that value. Otherwise, set it to the default date.
1193
+ */
1194
+ const todayString = workingParts.day !== null
1195
+ ? `${workingParts.year}-${workingParts.month}-${workingParts.day}`
1196
+ : `${defaultParts.year}-${defaultParts.month}-${defaultParts.day}`;
1197
+ return (h("ion-picker-column-internal", { class: "date-column", color: this.color, disabled: disabled, items: items, value: todayString, onIonChange: (ev) => {
1198
+ // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1199
+ // Due to a Safari 14 issue we need to destroy
1200
+ // the scroll listener before we update state
1201
+ // and trigger a re-render.
1202
+ if (this.destroyCalendarListener) {
1203
+ this.destroyCalendarListener();
1204
+ }
1205
+ const { value } = ev.detail;
1206
+ const findPart = parts.find(({ month, day, year }) => value === `${year}-${month}-${day}`);
1207
+ this.setWorkingParts(Object.assign(Object.assign({}, workingParts), findPart));
1208
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), findPart));
1209
+ // We can re-attach the scroll listener after
1210
+ // the working parts have been updated.
1211
+ this.initializeCalendarListener();
1212
+ ev.stopPropagation();
1213
+ } }));
1318
1214
  }
1319
- /**
1320
- * If a user has not selected a date,
1321
- * then we should show all times. If the
1322
- * user has selected a date (even if it has
1323
- * not been confirmed yet), we should apply
1324
- * the max and min restrictions so that the
1325
- * time picker shows values that are
1326
- * appropriate for the selected date.
1327
- */
1328
- const activePart = this.getActivePart();
1329
- const userHasSelectedDate = activePart !== undefined;
1330
- const { hoursData, minutesData, dayPeriodData } = getTimeColumnsData(this.locale, this.workingParts, this.hourCycle, userHasSelectedDate ? this.minParts : undefined, userHasSelectedDate ? this.maxParts : undefined, this.parsedHourValues, this.parsedMinuteValues);
1331
- return [
1332
- this.renderHourPickerColumn(hoursData),
1333
- this.renderMinutePickerColumn(minutesData),
1334
- this.renderDayPeriodPickerColumn(dayPeriodData),
1335
- ];
1336
- }
1337
- renderHourPickerColumn(hoursData) {
1338
- const { workingParts } = this;
1339
- if (hoursData.length === 0)
1340
- return [];
1341
- const activePart = this.getActivePartsWithFallback();
1342
- return (h("ion-picker-column-internal", { color: this.color, value: activePart.hour, items: hoursData, numericInput: true, onIonChange: (ev) => {
1343
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { hour: ev.detail.value }));
1344
- this.setActiveParts(Object.assign(Object.assign({}, activePart), { hour: ev.detail.value }));
1345
- ev.stopPropagation();
1346
- } }));
1347
- }
1348
- renderMinutePickerColumn(minutesData) {
1349
- const { workingParts } = this;
1350
- if (minutesData.length === 0)
1351
- return [];
1352
- const activePart = this.getActivePartsWithFallback();
1353
- return (h("ion-picker-column-internal", { color: this.color, value: activePart.minute, items: minutesData, numericInput: true, onIonChange: (ev) => {
1354
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { minute: ev.detail.value }));
1355
- this.setActiveParts(Object.assign(Object.assign({}, activePart), { minute: ev.detail.value }));
1356
- ev.stopPropagation();
1357
- } }));
1358
- }
1359
- renderDayPeriodPickerColumn(dayPeriodData) {
1360
- const { workingParts } = this;
1361
- if (dayPeriodData.length === 0) {
1362
- return [];
1363
- }
1364
- const activePart = this.getActivePartsWithFallback();
1365
- const isDayPeriodRTL = isLocaleDayPeriodRTL(this.locale);
1366
- return (h("ion-picker-column-internal", { style: isDayPeriodRTL ? { order: '-1' } : {}, color: this.color, value: activePart.ampm, items: dayPeriodData, onIonChange: (ev) => {
1367
- const hour = calculateHourFromAMPM(workingParts, ev.detail.value);
1368
- this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { ampm: ev.detail.value, hour }));
1369
- this.setActiveParts(Object.assign(Object.assign({}, activePart), { ampm: ev.detail.value, hour }));
1370
- ev.stopPropagation();
1371
- } }));
1372
- }
1373
- renderWheelView(forcePresentation) {
1374
- const { locale } = this;
1375
- const showMonthFirst = isMonthFirstLocale(locale);
1376
- const columnOrder = showMonthFirst ? 'month-first' : 'year-first';
1377
- return (h("div", { class: {
1378
- [`wheel-order-${columnOrder}`]: true,
1379
- } }, this.renderWheelPicker(forcePresentation)));
1380
- }
1381
- /**
1382
- * Grid Render Methods
1383
- */
1384
- renderCalendarHeader(mode) {
1385
- const expandedIcon = mode === 'ios' ? chevronDown : caretUpSharp;
1386
- const collapsedIcon = mode === 'ios' ? chevronForward : caretDownSharp;
1387
- const prevMonthDisabled = isPrevMonthDisabled(this.workingParts, this.minParts, this.maxParts);
1388
- const nextMonthDisabled = isNextMonthDisabled(this.workingParts, this.maxParts);
1389
- // don't use the inheritAttributes util because it removes dir from the host, and we still need that
1390
- const hostDir = this.el.getAttribute('dir') || undefined;
1391
- 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: () => {
1392
- var _a;
1393
- this.toggleMonthAndYearView();
1215
+ renderIndividualDatePickerColumns(forcePresentation) {
1216
+ const { workingParts, isDateEnabled } = this;
1217
+ const shouldRenderMonths = forcePresentation !== 'year' && forcePresentation !== 'time';
1218
+ const months = shouldRenderMonths
1219
+ ? getMonthColumnData(this.locale, workingParts, this.minParts, this.maxParts, this.parsedMonthValues)
1220
+ : [];
1221
+ const shouldRenderDays = forcePresentation === 'date';
1222
+ let days = shouldRenderDays
1223
+ ? getDayColumnData(this.locale, workingParts, this.minParts, this.maxParts, this.parsedDayValues)
1224
+ : [];
1225
+ if (isDateEnabled) {
1226
+ days = days.map((dayObject) => {
1227
+ const { value } = dayObject;
1228
+ const valueNum = typeof value === 'string' ? parseInt(value) : value;
1229
+ const referenceParts = {
1230
+ month: workingParts.month,
1231
+ day: valueNum,
1232
+ year: workingParts.year,
1233
+ };
1234
+ let disabled;
1235
+ try {
1236
+ /**
1237
+ * The `isDateEnabled` implementation is try-catch wrapped
1238
+ * to prevent exceptions in the user's function from
1239
+ * interrupting the calendar rendering.
1240
+ */
1241
+ disabled = !isDateEnabled(convertDataToISO(referenceParts));
1242
+ }
1243
+ catch (e) {
1244
+ printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', e);
1245
+ }
1246
+ return Object.assign(Object.assign({}, dayObject), { disabled });
1247
+ });
1248
+ }
1249
+ const shouldRenderYears = forcePresentation !== 'month' && forcePresentation !== 'time';
1250
+ const years = shouldRenderYears
1251
+ ? getYearColumnData(this.locale, this.defaultParts, this.minParts, this.maxParts, this.parsedYearValues)
1252
+ : [];
1394
1253
  /**
1395
- * TODO: FW-3547
1396
- *
1397
- * Currently there is not a way to set the aria-label on the inner button
1398
- * on the `ion-item` and have it be reactive to changes. This is a workaround
1399
- * until we either refactor `ion-item` to a button or Stencil adds a way to
1400
- * have reactive props for built-in properties, such as `aria-label`.
1254
+ * Certain locales show the day before the month.
1401
1255
  */
1402
- const { monthYearToggleItemRef } = this;
1403
- if (monthYearToggleItemRef) {
1404
- const btn = (_a = monthYearToggleItemRef.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.item-native');
1405
- if (btn) {
1406
- const monthYearAriaLabel = this.showMonthAndYear ? 'Hide year picker' : 'Show year picker';
1407
- btn.setAttribute('aria-label', monthYearAriaLabel);
1408
- }
1256
+ const showMonthFirst = isMonthFirstLocale(this.locale, { month: 'numeric', day: 'numeric' });
1257
+ let renderArray = [];
1258
+ if (showMonthFirst) {
1259
+ renderArray = [
1260
+ this.renderMonthPickerColumn(months),
1261
+ this.renderDayPickerColumn(days),
1262
+ this.renderYearPickerColumn(years),
1263
+ ];
1409
1264
  }
1410
- } }, 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) => {
1411
- return h("div", { class: "day-of-week" }, d);
1412
- }))));
1413
- }
1414
- renderMonth(month, year) {
1415
- const yearAllowed = this.parsedYearValues === undefined || this.parsedYearValues.includes(year);
1416
- const monthAllowed = this.parsedMonthValues === undefined || this.parsedMonthValues.includes(month);
1417
- const isCalMonthDisabled = !yearAllowed || !monthAllowed;
1418
- const swipeDisabled = isMonthDisabled({
1419
- month,
1420
- year,
1421
- day: null,
1422
- }, {
1423
- // The day is not used when checking if a month is disabled.
1424
- // Users should be able to access the min or max month, even if the
1425
- // min/max date is out of bounds (e.g. min is set to Feb 15, Feb should not be disabled).
1426
- minParts: Object.assign(Object.assign({}, this.minParts), { day: null }),
1427
- maxParts: Object.assign(Object.assign({}, this.maxParts), { day: null }),
1428
- });
1429
- // The working month should never have swipe disabled.
1430
- // Otherwise the CSS scroll snap will not work and the user
1431
- // can free-scroll the calendar.
1432
- const isWorkingMonth = this.workingParts.month === month && this.workingParts.year === year;
1433
- const activePart = this.getActivePartsWithFallback();
1434
- return (h("div", { "aria-hidden": !isWorkingMonth ? 'true' : null, class: {
1435
- 'calendar-month': true,
1436
- // Prevents scroll snap swipe gestures for months outside of the min/max bounds
1437
- 'calendar-month-disabled': !isWorkingMonth && swipeDisabled,
1438
- } }, h("div", { class: "calendar-month-grid" }, getDaysOfMonth(month, year, this.firstDayOfWeek % 7).map((dateObject, index) => {
1439
- const { day, dayOfWeek } = dateObject;
1440
- const { el, highlightedDates, isDateEnabled, multiple } = this;
1441
- const referenceParts = { month, day, year };
1442
- const isCalendarPadding = day === null;
1443
- const { isActive, isToday, ariaLabel, ariaSelected, disabled, text } = getCalendarDayState(this.locale, referenceParts, this.activeParts, this.todayParts, this.minParts, this.maxParts, this.parsedDayValues);
1444
- const dateIsoString = convertDataToISO(referenceParts);
1445
- let isCalDayDisabled = isCalMonthDisabled || disabled;
1446
- if (!isCalDayDisabled && isDateEnabled !== undefined) {
1447
- try {
1448
- /**
1449
- * The `isDateEnabled` implementation is try-catch wrapped
1450
- * to prevent exceptions in the user's function from
1451
- * interrupting the calendar rendering.
1452
- */
1453
- isCalDayDisabled = !isDateEnabled(dateIsoString);
1265
+ else {
1266
+ renderArray = [
1267
+ this.renderDayPickerColumn(days),
1268
+ this.renderMonthPickerColumn(months),
1269
+ this.renderYearPickerColumn(years),
1270
+ ];
1454
1271
  }
1455
- catch (e) {
1456
- printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', el, e);
1272
+ return renderArray;
1273
+ }
1274
+ renderDayPickerColumn(days) {
1275
+ var _a;
1276
+ if (days.length === 0) {
1277
+ return [];
1457
1278
  }
1458
- }
1459
- let dateStyle = undefined;
1460
- /**
1461
- * Custom highlight styles should not override the style for selected dates,
1462
- * nor apply to "filler days" at the start of the grid.
1463
- */
1464
- if (highlightedDates !== undefined && !isActive && day !== null) {
1465
- dateStyle = getHighlightStyles(highlightedDates, dateIsoString, el);
1466
- }
1467
- let dateParts = undefined;
1468
- // "Filler days" at the beginning of the grid should not get the calendar day
1469
- // CSS parts added to them
1470
- if (!isCalendarPadding) {
1471
- dateParts = `calendar-day${isActive ? ' active' : ''}${isToday ? ' today' : ''}${isCalDayDisabled ? ' disabled' : ''}`;
1472
- }
1473
- return (h("div", { class: "calendar-day-wrapper" }, h("button", {
1474
- // We need to use !important for the inline styles here because
1475
- // otherwise the CSS shadow parts will override these styles.
1476
- // See https://github.com/WICG/webcomponents/issues/847
1477
- // Both the CSS shadow parts and highlightedDates styles are
1478
- // provided by the developer, but highlightedDates styles should
1479
- // always take priority.
1480
- ref: (el) => {
1481
- if (el) {
1482
- el.style.setProperty('color', `${dateStyle ? dateStyle.textColor : ''}`, 'important');
1483
- el.style.setProperty('background-color', `${dateStyle ? dateStyle.backgroundColor : ''}`, 'important');
1484
- }
1485
- }, tabindex: "-1", "data-day": day, "data-month": month, "data-year": year, "data-index": index, "data-day-of-week": dayOfWeek, disabled: isCalDayDisabled, class: {
1486
- 'calendar-day-padding': isCalendarPadding,
1487
- 'calendar-day': true,
1488
- 'calendar-day-active': isActive,
1489
- 'calendar-day-today': isToday,
1490
- }, part: dateParts, "aria-hidden": isCalendarPadding ? 'true' : null, "aria-selected": ariaSelected, "aria-label": ariaLabel, onClick: () => {
1491
- if (isCalendarPadding) {
1492
- return;
1493
- }
1494
- this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), { month,
1495
- day,
1496
- year }));
1497
- // multiple only needs date info, so we can wipe out other fields like time
1498
- if (multiple) {
1499
- this.setActiveParts({
1500
- month,
1501
- day,
1502
- year,
1503
- }, isActive);
1504
- }
1505
- else {
1506
- this.setActiveParts(Object.assign(Object.assign({}, activePart), { month,
1507
- day,
1508
- year }));
1509
- }
1279
+ const { disabled, workingParts } = this;
1280
+ const activePart = this.getActivePartsWithFallback();
1281
+ 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) => {
1282
+ // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1283
+ // Due to a Safari 14 issue we need to destroy
1284
+ // the scroll listener before we update state
1285
+ // and trigger a re-render.
1286
+ if (this.destroyCalendarListener) {
1287
+ this.destroyCalendarListener();
1288
+ }
1289
+ this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { day: ev.detail.value }));
1290
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), { day: ev.detail.value }));
1291
+ // We can re-attach the scroll listener after
1292
+ // the working parts have been updated.
1293
+ this.initializeCalendarListener();
1294
+ ev.stopPropagation();
1295
+ } }));
1296
+ }
1297
+ renderMonthPickerColumn(months) {
1298
+ if (months.length === 0) {
1299
+ return [];
1510
1300
  }
1511
- }, text)));
1512
- }))));
1513
- }
1514
- renderCalendarBody() {
1515
- return (h("div", { class: "calendar-body ion-focusable", ref: (el) => (this.calendarBodyRef = el), tabindex: "0" }, generateMonths(this.workingParts, this.forceRenderDate).map(({ month, year }) => {
1516
- return this.renderMonth(month, year);
1517
- })));
1518
- }
1519
- renderCalendar(mode) {
1520
- return (h("div", { class: "datetime-calendar", key: "datetime-calendar" }, this.renderCalendarHeader(mode), this.renderCalendarBody()));
1521
- }
1522
- renderTimeLabel() {
1523
- const hasSlottedTimeLabel = this.el.querySelector('[slot="time-label"]') !== null;
1524
- if (!hasSlottedTimeLabel && !this.showDefaultTimeLabel) {
1525
- return;
1526
- }
1527
- return h("slot", { name: "time-label" }, "Time");
1528
- }
1529
- renderTimeOverlay() {
1530
- const { hourCycle, isTimePopoverOpen, locale } = this;
1531
- const computedHourCycle = getHourCycle(locale, hourCycle);
1532
- const activePart = this.getActivePartsWithFallback();
1533
- return [
1534
- h("div", { class: "time-header" }, this.renderTimeLabel()),
1535
- h("button", { class: {
1536
- 'time-body': true,
1537
- 'time-body-active': isTimePopoverOpen,
1538
- }, part: `time-button${isTimePopoverOpen ? ' active' : ''}`, "aria-expanded": "false", "aria-haspopup": "true", onClick: async (ev) => {
1539
- const { popoverRef } = this;
1540
- if (popoverRef) {
1541
- this.isTimePopoverOpen = true;
1542
- popoverRef.present(new CustomEvent('ionShadowTarget', {
1543
- detail: {
1544
- ionShadowTarget: ev.target,
1545
- },
1546
- }));
1547
- await popoverRef.onWillDismiss();
1548
- this.isTimePopoverOpen = false;
1549
- }
1550
- } }, getLocalizedTime(locale, activePart, computedHourCycle)),
1551
- h("ion-popover", { alignment: "center", translucent: true, overlayIndex: 1, arrow: false, onWillPresent: (ev) => {
1552
- /**
1553
- * Intersection Observers do not consistently fire between Blink and Webkit
1554
- * when toggling the visibility of the popover and trying to scroll the picker
1555
- * column to the correct time value.
1556
- *
1557
- * This will correctly scroll the element position to the correct time value,
1558
- * before the popover is fully presented.
1559
- */
1560
- const cols = ev.target.querySelectorAll('ion-picker-column-internal');
1561
- // TODO (FW-615): Potentially remove this when intersection observers are fixed in picker column
1562
- cols.forEach((col) => col.scrollActiveItemIntoView());
1563
- }, style: {
1564
- '--offset-y': '-10px',
1565
- '--min-width': 'fit-content',
1566
- },
1567
- // Allow native browser keyboard events to support up/down/home/end key
1568
- // navigation within the time picker.
1569
- keyboardEvents: true, ref: (el) => (this.popoverRef = el) }, this.renderWheelPicker('time')),
1570
- ];
1571
- }
1572
- getHeaderSelectedDateText() {
1573
- const { activeParts, multiple, titleSelectedDatesFormatter } = this;
1574
- const isArray = Array.isArray(activeParts);
1575
- let headerText;
1576
- if (multiple && isArray && activeParts.length !== 1) {
1577
- headerText = `${activeParts.length} days`; // default/fallback for multiple selection
1578
- if (titleSelectedDatesFormatter !== undefined) {
1579
- try {
1580
- headerText = titleSelectedDatesFormatter(convertDataToISO(activeParts));
1301
+ const { disabled, workingParts } = this;
1302
+ const activePart = this.getActivePartsWithFallback();
1303
+ return (h("ion-picker-column-internal", { class: "month-column", color: this.color, disabled: disabled, items: months, value: workingParts.month, onIonChange: (ev) => {
1304
+ // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1305
+ // Due to a Safari 14 issue we need to destroy
1306
+ // the scroll listener before we update state
1307
+ // and trigger a re-render.
1308
+ if (this.destroyCalendarListener) {
1309
+ this.destroyCalendarListener();
1310
+ }
1311
+ this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { month: ev.detail.value }));
1312
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), { month: ev.detail.value }));
1313
+ // We can re-attach the scroll listener after
1314
+ // the working parts have been updated.
1315
+ this.initializeCalendarListener();
1316
+ ev.stopPropagation();
1317
+ } }));
1318
+ }
1319
+ renderYearPickerColumn(years) {
1320
+ if (years.length === 0) {
1321
+ return [];
1581
1322
  }
1582
- catch (e) {
1583
- printIonError('Exception in provided `titleSelectedDatesFormatter`: ', e);
1323
+ const { disabled, workingParts } = this;
1324
+ const activePart = this.getActivePartsWithFallback();
1325
+ return (h("ion-picker-column-internal", { class: "year-column", color: this.color, disabled: disabled, items: years, value: workingParts.year, onIonChange: (ev) => {
1326
+ // TODO(FW-1823) Remove this when iOS 14 support is dropped.
1327
+ // Due to a Safari 14 issue we need to destroy
1328
+ // the scroll listener before we update state
1329
+ // and trigger a re-render.
1330
+ if (this.destroyCalendarListener) {
1331
+ this.destroyCalendarListener();
1332
+ }
1333
+ this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { year: ev.detail.value }));
1334
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), { year: ev.detail.value }));
1335
+ // We can re-attach the scroll listener after
1336
+ // the working parts have been updated.
1337
+ this.initializeCalendarListener();
1338
+ ev.stopPropagation();
1339
+ } }));
1340
+ }
1341
+ renderTimePickerColumns(forcePresentation) {
1342
+ if (['date', 'month', 'month-year', 'year'].includes(forcePresentation)) {
1343
+ return [];
1584
1344
  }
1585
- }
1345
+ /**
1346
+ * If a user has not selected a date,
1347
+ * then we should show all times. If the
1348
+ * user has selected a date (even if it has
1349
+ * not been confirmed yet), we should apply
1350
+ * the max and min restrictions so that the
1351
+ * time picker shows values that are
1352
+ * appropriate for the selected date.
1353
+ */
1354
+ const activePart = this.getActivePart();
1355
+ const userHasSelectedDate = activePart !== undefined;
1356
+ const { hoursData, minutesData, dayPeriodData } = getTimeColumnsData(this.locale, this.workingParts, this.hourCycle, userHasSelectedDate ? this.minParts : undefined, userHasSelectedDate ? this.maxParts : undefined, this.parsedHourValues, this.parsedMinuteValues);
1357
+ return [
1358
+ this.renderHourPickerColumn(hoursData),
1359
+ this.renderMinutePickerColumn(minutesData),
1360
+ this.renderDayPeriodPickerColumn(dayPeriodData),
1361
+ ];
1362
+ }
1363
+ renderHourPickerColumn(hoursData) {
1364
+ const { disabled, workingParts } = this;
1365
+ if (hoursData.length === 0)
1366
+ return [];
1367
+ const activePart = this.getActivePartsWithFallback();
1368
+ return (h("ion-picker-column-internal", { color: this.color, disabled: disabled, value: activePart.hour, items: hoursData, numericInput: true, onIonChange: (ev) => {
1369
+ this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { hour: ev.detail.value }));
1370
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), { hour: ev.detail.value }));
1371
+ ev.stopPropagation();
1372
+ } }));
1373
+ }
1374
+ renderMinutePickerColumn(minutesData) {
1375
+ const { disabled, workingParts } = this;
1376
+ if (minutesData.length === 0)
1377
+ return [];
1378
+ const activePart = this.getActivePartsWithFallback();
1379
+ return (h("ion-picker-column-internal", { color: this.color, disabled: disabled, value: activePart.minute, items: minutesData, numericInput: true, onIonChange: (ev) => {
1380
+ this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { minute: ev.detail.value }));
1381
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), { minute: ev.detail.value }));
1382
+ ev.stopPropagation();
1383
+ } }));
1384
+ }
1385
+ renderDayPeriodPickerColumn(dayPeriodData) {
1386
+ const { disabled, workingParts } = this;
1387
+ if (dayPeriodData.length === 0) {
1388
+ return [];
1389
+ }
1390
+ const activePart = this.getActivePartsWithFallback();
1391
+ const isDayPeriodRTL = isLocaleDayPeriodRTL(this.locale);
1392
+ return (h("ion-picker-column-internal", { style: isDayPeriodRTL ? { order: '-1' } : {}, color: this.color, disabled: disabled, value: activePart.ampm, items: dayPeriodData, onIonChange: (ev) => {
1393
+ const hour = calculateHourFromAMPM(workingParts, ev.detail.value);
1394
+ this.setWorkingParts(Object.assign(Object.assign({}, workingParts), { ampm: ev.detail.value, hour }));
1395
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), { ampm: ev.detail.value, hour }));
1396
+ ev.stopPropagation();
1397
+ } }));
1398
+ }
1399
+ renderWheelView(forcePresentation) {
1400
+ const { locale } = this;
1401
+ const showMonthFirst = isMonthFirstLocale(locale);
1402
+ const columnOrder = showMonthFirst ? 'month-first' : 'year-first';
1403
+ return (h("div", { class: {
1404
+ [`wheel-order-${columnOrder}`]: true,
1405
+ } }, this.renderWheelPicker(forcePresentation)));
1586
1406
  }
1587
- else {
1588
- // for exactly 1 day selected (multiple set or not), show a formatted version of that
1589
- headerText = getMonthAndDay(this.locale, this.getActivePartsWithFallback());
1590
- }
1591
- return headerText;
1592
- }
1593
- renderHeader(showExpandedHeader = true) {
1594
- const hasSlottedTitle = this.el.querySelector('[slot="title"]') !== null;
1595
- if (!hasSlottedTitle && !this.showDefaultTitle) {
1596
- return;
1597
- }
1598
- 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())));
1599
- }
1600
- /**
1601
- * Render time picker inside of datetime.
1602
- * Do not pass color prop to segment on
1603
- * iOS mode. MD segment has been customized and
1604
- * should take on the color prop, but iOS
1605
- * should just be the default segment.
1606
- */
1607
- renderTime() {
1608
- const { presentation } = this;
1609
- const timeOnlyPresentation = presentation === 'time';
1610
- return (h("div", { class: "datetime-time" }, timeOnlyPresentation ? this.renderWheelPicker() : this.renderTimeOverlay()));
1611
- }
1612
- /**
1613
- * Renders the month/year picker that is
1614
- * displayed on the calendar grid.
1615
- * The .datetime-year class has additional
1616
- * styles that let us show/hide the
1617
- * picker when the user clicks on the
1618
- * toggle in the calendar header.
1619
- */
1620
- renderCalendarViewMonthYearPicker() {
1621
- return h("div", { class: "datetime-year" }, this.renderWheelView('month-year'));
1622
- }
1623
- /**
1624
- * Render entry point
1625
- * All presentation types are rendered from here.
1626
- */
1627
- renderDatetime(mode) {
1628
- const { presentation, preferWheel } = this;
1629
1407
  /**
1630
- * Certain presentation types have separate grid and wheel displays.
1631
- * If preferWheel is true then we should show a wheel picker instead.
1408
+ * Grid Render Methods
1632
1409
  */
1633
- const hasWheelVariant = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
1634
- if (preferWheel && hasWheelVariant) {
1635
- return [this.renderHeader(false), this.renderWheelView(), this.renderFooter()];
1410
+ renderCalendarHeader(mode) {
1411
+ const { disabled } = this;
1412
+ const expandedIcon = mode === 'ios' ? chevronDown : caretUpSharp;
1413
+ const collapsedIcon = mode === 'ios' ? chevronForward : caretDownSharp;
1414
+ const prevMonthDisabled = disabled || isPrevMonthDisabled(this.workingParts, this.minParts, this.maxParts);
1415
+ const nextMonthDisabled = disabled || isNextMonthDisabled(this.workingParts, this.maxParts);
1416
+ // don't use the inheritAttributes util because it removes dir from the host, and we still need that
1417
+ const hostDir = this.el.getAttribute('dir') || undefined;
1418
+ 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: () => {
1419
+ var _a;
1420
+ this.toggleMonthAndYearView();
1421
+ /**
1422
+ * TODO: FW-3547
1423
+ *
1424
+ * Currently there is not a way to set the aria-label on the inner button
1425
+ * on the `ion-item` and have it be reactive to changes. This is a workaround
1426
+ * until we either refactor `ion-item` to a button or Stencil adds a way to
1427
+ * have reactive props for built-in properties, such as `aria-label`.
1428
+ */
1429
+ const { monthYearToggleItemRef } = this;
1430
+ if (monthYearToggleItemRef) {
1431
+ const btn = (_a = monthYearToggleItemRef.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector('.item-native');
1432
+ if (btn) {
1433
+ const monthYearAriaLabel = this.showMonthAndYear ? 'Hide year picker' : 'Show year picker';
1434
+ btn.setAttribute('aria-label', monthYearAriaLabel);
1435
+ }
1436
+ }
1437
+ } }, 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) => {
1438
+ return h("div", { class: "day-of-week" }, d);
1439
+ }))));
1636
1440
  }
1637
- switch (presentation) {
1638
- case 'date-time':
1639
- return [
1640
- this.renderHeader(),
1641
- this.renderCalendar(mode),
1642
- this.renderCalendarViewMonthYearPicker(),
1643
- this.renderTime(),
1644
- this.renderFooter(),
1645
- ];
1646
- case 'time-date':
1647
- return [
1648
- this.renderHeader(),
1649
- this.renderTime(),
1650
- this.renderCalendar(mode),
1651
- this.renderCalendarViewMonthYearPicker(),
1652
- this.renderFooter(),
1653
- ];
1654
- case 'time':
1655
- return [this.renderHeader(false), this.renderTime(), this.renderFooter()];
1656
- case 'month':
1657
- case 'month-year':
1658
- case 'year':
1659
- return [this.renderHeader(false), this.renderWheelView(), this.renderFooter()];
1660
- default:
1441
+ renderMonth(month, year) {
1442
+ const { disabled, readonly } = this;
1443
+ const yearAllowed = this.parsedYearValues === undefined || this.parsedYearValues.includes(year);
1444
+ const monthAllowed = this.parsedMonthValues === undefined || this.parsedMonthValues.includes(month);
1445
+ const isCalMonthDisabled = !yearAllowed || !monthAllowed;
1446
+ const isDatetimeDisabled = disabled || readonly;
1447
+ const swipeDisabled = disabled ||
1448
+ isMonthDisabled({
1449
+ month,
1450
+ year,
1451
+ day: null,
1452
+ }, {
1453
+ // The day is not used when checking if a month is disabled.
1454
+ // Users should be able to access the min or max month, even if the
1455
+ // min/max date is out of bounds (e.g. min is set to Feb 15, Feb should not be disabled).
1456
+ minParts: Object.assign(Object.assign({}, this.minParts), { day: null }),
1457
+ maxParts: Object.assign(Object.assign({}, this.maxParts), { day: null }),
1458
+ });
1459
+ // The working month should never have swipe disabled.
1460
+ // Otherwise the CSS scroll snap will not work and the user
1461
+ // can free-scroll the calendar.
1462
+ const isWorkingMonth = this.workingParts.month === month && this.workingParts.year === year;
1463
+ const activePart = this.getActivePartsWithFallback();
1464
+ return (h("div", { "aria-hidden": !isWorkingMonth ? 'true' : null, class: {
1465
+ 'calendar-month': true,
1466
+ // Prevents scroll snap swipe gestures for months outside of the min/max bounds
1467
+ 'calendar-month-disabled': !isWorkingMonth && swipeDisabled,
1468
+ } }, h("div", { class: "calendar-month-grid" }, getDaysOfMonth(month, year, this.firstDayOfWeek % 7).map((dateObject, index) => {
1469
+ const { day, dayOfWeek } = dateObject;
1470
+ const { el, highlightedDates, isDateEnabled, multiple } = this;
1471
+ const referenceParts = { month, day, year };
1472
+ const isCalendarPadding = day === null;
1473
+ const { isActive, isToday, ariaLabel, ariaSelected, disabled: isDayDisabled, text, } = getCalendarDayState(this.locale, referenceParts, this.activeParts, this.todayParts, this.minParts, this.maxParts, this.parsedDayValues);
1474
+ const dateIsoString = convertDataToISO(referenceParts);
1475
+ let isCalDayDisabled = isCalMonthDisabled || isDayDisabled;
1476
+ if (!isCalDayDisabled && isDateEnabled !== undefined) {
1477
+ try {
1478
+ /**
1479
+ * The `isDateEnabled` implementation is try-catch wrapped
1480
+ * to prevent exceptions in the user's function from
1481
+ * interrupting the calendar rendering.
1482
+ */
1483
+ isCalDayDisabled = !isDateEnabled(dateIsoString);
1484
+ }
1485
+ catch (e) {
1486
+ printIonError('Exception thrown from provided `isDateEnabled` function. Please check your function and try again.', el, e);
1487
+ }
1488
+ }
1489
+ /**
1490
+ * Some days are constrained through max & min or allowed dates
1491
+ * and also disabled because the component is readonly or disabled.
1492
+ * These need to be displayed differently.
1493
+ */
1494
+ const isCalDayConstrained = isCalDayDisabled && isDatetimeDisabled;
1495
+ const isButtonDisabled = isCalDayDisabled || isDatetimeDisabled;
1496
+ let dateStyle = undefined;
1497
+ /**
1498
+ * Custom highlight styles should not override the style for selected dates,
1499
+ * nor apply to "filler days" at the start of the grid.
1500
+ */
1501
+ if (highlightedDates !== undefined && !isActive && day !== null) {
1502
+ dateStyle = getHighlightStyles(highlightedDates, dateIsoString, el);
1503
+ }
1504
+ let dateParts = undefined;
1505
+ // "Filler days" at the beginning of the grid should not get the calendar day
1506
+ // CSS parts added to them
1507
+ if (!isCalendarPadding) {
1508
+ dateParts = `calendar-day${isActive ? ' active' : ''}${isToday ? ' today' : ''}${isCalDayDisabled ? ' disabled' : ''}`;
1509
+ }
1510
+ return (h("div", { class: "calendar-day-wrapper" }, h("button", {
1511
+ // We need to use !important for the inline styles here because
1512
+ // otherwise the CSS shadow parts will override these styles.
1513
+ // See https://github.com/WICG/webcomponents/issues/847
1514
+ // Both the CSS shadow parts and highlightedDates styles are
1515
+ // provided by the developer, but highlightedDates styles should
1516
+ // always take priority.
1517
+ ref: (el) => {
1518
+ if (el) {
1519
+ el.style.setProperty('color', `${dateStyle ? dateStyle.textColor : ''}`, 'important');
1520
+ el.style.setProperty('background-color', `${dateStyle ? dateStyle.backgroundColor : ''}`, 'important');
1521
+ }
1522
+ }, tabindex: "-1", "data-day": day, "data-month": month, "data-year": year, "data-index": index, "data-day-of-week": dayOfWeek, disabled: isButtonDisabled, class: {
1523
+ 'calendar-day-padding': isCalendarPadding,
1524
+ 'calendar-day': true,
1525
+ 'calendar-day-active': isActive,
1526
+ 'calendar-day-constrained': isCalDayConstrained,
1527
+ 'calendar-day-today': isToday,
1528
+ }, part: dateParts, "aria-hidden": isCalendarPadding ? 'true' : null, "aria-selected": ariaSelected, "aria-label": ariaLabel, onClick: () => {
1529
+ if (isCalendarPadding) {
1530
+ return;
1531
+ }
1532
+ this.setWorkingParts(Object.assign(Object.assign({}, this.workingParts), { month,
1533
+ day,
1534
+ year }));
1535
+ // multiple only needs date info, so we can wipe out other fields like time
1536
+ if (multiple) {
1537
+ this.setActiveParts({
1538
+ month,
1539
+ day,
1540
+ year,
1541
+ }, isActive);
1542
+ }
1543
+ else {
1544
+ this.setActiveParts(Object.assign(Object.assign({}, activePart), { month,
1545
+ day,
1546
+ year }));
1547
+ }
1548
+ }
1549
+ }, text)));
1550
+ }))));
1551
+ }
1552
+ renderCalendarBody() {
1553
+ return (h("div", { class: "calendar-body ion-focusable", ref: (el) => (this.calendarBodyRef = el), tabindex: "0" }, generateMonths(this.workingParts, this.forceRenderDate).map(({ month, year }) => {
1554
+ return this.renderMonth(month, year);
1555
+ })));
1556
+ }
1557
+ renderCalendar(mode) {
1558
+ return (h("div", { class: "datetime-calendar", key: "datetime-calendar" }, this.renderCalendarHeader(mode), this.renderCalendarBody()));
1559
+ }
1560
+ renderTimeLabel() {
1561
+ const hasSlottedTimeLabel = this.el.querySelector('[slot="time-label"]') !== null;
1562
+ if (!hasSlottedTimeLabel && !this.showDefaultTimeLabel) {
1563
+ return;
1564
+ }
1565
+ return h("slot", { name: "time-label" }, "Time");
1566
+ }
1567
+ renderTimeOverlay() {
1568
+ const { disabled, hourCycle, isTimePopoverOpen, locale } = this;
1569
+ const computedHourCycle = getHourCycle(locale, hourCycle);
1570
+ const activePart = this.getActivePartsWithFallback();
1661
1571
  return [
1662
- this.renderHeader(),
1663
- this.renderCalendar(mode),
1664
- this.renderCalendarViewMonthYearPicker(),
1665
- this.renderFooter(),
1572
+ h("div", { class: "time-header" }, this.renderTimeLabel()),
1573
+ h("button", { class: {
1574
+ 'time-body': true,
1575
+ 'time-body-active': isTimePopoverOpen,
1576
+ }, part: `time-button${isTimePopoverOpen ? ' active' : ''}`, "aria-expanded": "false", "aria-haspopup": "true", disabled: disabled, onClick: async (ev) => {
1577
+ const { popoverRef } = this;
1578
+ if (popoverRef) {
1579
+ this.isTimePopoverOpen = true;
1580
+ popoverRef.present(new CustomEvent('ionShadowTarget', {
1581
+ detail: {
1582
+ ionShadowTarget: ev.target,
1583
+ },
1584
+ }));
1585
+ await popoverRef.onWillDismiss();
1586
+ this.isTimePopoverOpen = false;
1587
+ }
1588
+ } }, getLocalizedTime(locale, activePart, computedHourCycle)),
1589
+ h("ion-popover", { alignment: "center", translucent: true, overlayIndex: 1, arrow: false, onWillPresent: (ev) => {
1590
+ /**
1591
+ * Intersection Observers do not consistently fire between Blink and Webkit
1592
+ * when toggling the visibility of the popover and trying to scroll the picker
1593
+ * column to the correct time value.
1594
+ *
1595
+ * This will correctly scroll the element position to the correct time value,
1596
+ * before the popover is fully presented.
1597
+ */
1598
+ const cols = ev.target.querySelectorAll('ion-picker-column-internal');
1599
+ // TODO (FW-615): Potentially remove this when intersection observers are fixed in picker column
1600
+ cols.forEach((col) => col.scrollActiveItemIntoView());
1601
+ }, style: {
1602
+ '--offset-y': '-10px',
1603
+ '--min-width': 'fit-content',
1604
+ },
1605
+ // Allow native browser keyboard events to support up/down/home/end key
1606
+ // navigation within the time picker.
1607
+ keyboardEvents: true, ref: (el) => (this.popoverRef = el) }, this.renderWheelPicker('time')),
1666
1608
  ];
1667
1609
  }
1668
- }
1669
- render() {
1670
- const { name, value, disabled, el, color, readonly, showMonthAndYear, preferWheel, presentation, size, isGridStyle, } = this;
1671
- const mode = getIonMode(this);
1672
- const isMonthAndYearPresentation = presentation === 'year' || presentation === 'month' || presentation === 'month-year';
1673
- const shouldShowMonthAndYear = showMonthAndYear || isMonthAndYearPresentation;
1674
- const monthYearPickerOpen = showMonthAndYear && !isMonthAndYearPresentation;
1675
- const hasDatePresentation = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
1676
- const hasWheelVariant = hasDatePresentation && preferWheel;
1677
- renderHiddenInput(true, el, name, formatValue(value), disabled);
1678
- return (h(Host, { "aria-disabled": disabled ? 'true' : null, onFocus: this.onFocus, onBlur: this.onBlur, class: Object.assign({}, createColorClasses(color, {
1679
- [mode]: true,
1680
- ['datetime-readonly']: readonly,
1681
- ['datetime-disabled']: disabled,
1682
- 'show-month-and-year': shouldShowMonthAndYear,
1683
- 'month-year-picker-open': monthYearPickerOpen,
1684
- [`datetime-presentation-${presentation}`]: true,
1685
- [`datetime-size-${size}`]: true,
1686
- [`datetime-prefer-wheel`]: hasWheelVariant,
1687
- [`datetime-grid`]: isGridStyle,
1688
- })) }, this.renderDatetime(mode)));
1689
- }
1690
- get el() { return getElement(this); }
1691
- static get watchers() { return {
1692
- "disabled": ["disabledChanged"],
1693
- "min": ["minChanged"],
1694
- "max": ["maxChanged"],
1695
- "yearValues": ["yearValuesChanged"],
1696
- "monthValues": ["monthValuesChanged"],
1697
- "dayValues": ["dayValuesChanged"],
1698
- "hourValues": ["hourValuesChanged"],
1699
- "minuteValues": ["minuteValuesChanged"],
1700
- "value": ["valueChanged"]
1701
- }; }
1610
+ getHeaderSelectedDateText() {
1611
+ const { activeParts, multiple, titleSelectedDatesFormatter } = this;
1612
+ const isArray = Array.isArray(activeParts);
1613
+ let headerText;
1614
+ if (multiple && isArray && activeParts.length !== 1) {
1615
+ headerText = `${activeParts.length} days`; // default/fallback for multiple selection
1616
+ if (titleSelectedDatesFormatter !== undefined) {
1617
+ try {
1618
+ headerText = titleSelectedDatesFormatter(convertDataToISO(activeParts));
1619
+ }
1620
+ catch (e) {
1621
+ printIonError('Exception in provided `titleSelectedDatesFormatter`: ', e);
1622
+ }
1623
+ }
1624
+ }
1625
+ else {
1626
+ // for exactly 1 day selected (multiple set or not), show a formatted version of that
1627
+ headerText = getMonthAndDay(this.locale, this.getActivePartsWithFallback());
1628
+ }
1629
+ return headerText;
1630
+ }
1631
+ renderHeader(showExpandedHeader = true) {
1632
+ const hasSlottedTitle = this.el.querySelector('[slot="title"]') !== null;
1633
+ if (!hasSlottedTitle && !this.showDefaultTitle) {
1634
+ return;
1635
+ }
1636
+ 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())));
1637
+ }
1638
+ /**
1639
+ * Render time picker inside of datetime.
1640
+ * Do not pass color prop to segment on
1641
+ * iOS mode. MD segment has been customized and
1642
+ * should take on the color prop, but iOS
1643
+ * should just be the default segment.
1644
+ */
1645
+ renderTime() {
1646
+ const { presentation } = this;
1647
+ const timeOnlyPresentation = presentation === 'time';
1648
+ return (h("div", { class: "datetime-time" }, timeOnlyPresentation ? this.renderWheelPicker() : this.renderTimeOverlay()));
1649
+ }
1650
+ /**
1651
+ * Renders the month/year picker that is
1652
+ * displayed on the calendar grid.
1653
+ * The .datetime-year class has additional
1654
+ * styles that let us show/hide the
1655
+ * picker when the user clicks on the
1656
+ * toggle in the calendar header.
1657
+ */
1658
+ renderCalendarViewMonthYearPicker() {
1659
+ return h("div", { class: "datetime-year" }, this.renderWheelView('month-year'));
1660
+ }
1661
+ /**
1662
+ * Render entry point
1663
+ * All presentation types are rendered from here.
1664
+ */
1665
+ renderDatetime(mode) {
1666
+ const { presentation, preferWheel } = this;
1667
+ /**
1668
+ * Certain presentation types have separate grid and wheel displays.
1669
+ * If preferWheel is true then we should show a wheel picker instead.
1670
+ */
1671
+ const hasWheelVariant = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
1672
+ if (preferWheel && hasWheelVariant) {
1673
+ return [this.renderHeader(false), this.renderWheelView(), this.renderFooter()];
1674
+ }
1675
+ switch (presentation) {
1676
+ case 'date-time':
1677
+ return [
1678
+ this.renderHeader(),
1679
+ this.renderCalendar(mode),
1680
+ this.renderCalendarViewMonthYearPicker(),
1681
+ this.renderTime(),
1682
+ this.renderFooter(),
1683
+ ];
1684
+ case 'time-date':
1685
+ return [
1686
+ this.renderHeader(),
1687
+ this.renderTime(),
1688
+ this.renderCalendar(mode),
1689
+ this.renderCalendarViewMonthYearPicker(),
1690
+ this.renderFooter(),
1691
+ ];
1692
+ case 'time':
1693
+ return [this.renderHeader(false), this.renderTime(), this.renderFooter()];
1694
+ case 'month':
1695
+ case 'month-year':
1696
+ case 'year':
1697
+ return [this.renderHeader(false), this.renderWheelView(), this.renderFooter()];
1698
+ default:
1699
+ return [
1700
+ this.renderHeader(),
1701
+ this.renderCalendar(mode),
1702
+ this.renderCalendarViewMonthYearPicker(),
1703
+ this.renderFooter(),
1704
+ ];
1705
+ }
1706
+ }
1707
+ render() {
1708
+ const { name, value, disabled, el, color, readonly, showMonthAndYear, preferWheel, presentation, size, isGridStyle, } = this;
1709
+ const mode = getIonMode(this);
1710
+ const isMonthAndYearPresentation = presentation === 'year' || presentation === 'month' || presentation === 'month-year';
1711
+ const shouldShowMonthAndYear = showMonthAndYear || isMonthAndYearPresentation;
1712
+ const monthYearPickerOpen = showMonthAndYear && !isMonthAndYearPresentation;
1713
+ const hasDatePresentation = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
1714
+ const hasWheelVariant = hasDatePresentation && preferWheel;
1715
+ renderHiddenInput(true, el, name, formatValue(value), disabled);
1716
+ return (h(Host, { "aria-disabled": disabled ? 'true' : null, onFocus: this.onFocus, onBlur: this.onBlur, class: Object.assign({}, createColorClasses(color, {
1717
+ [mode]: true,
1718
+ ['datetime-readonly']: readonly,
1719
+ ['datetime-disabled']: disabled,
1720
+ 'show-month-and-year': shouldShowMonthAndYear,
1721
+ 'month-year-picker-open': monthYearPickerOpen,
1722
+ [`datetime-presentation-${presentation}`]: true,
1723
+ [`datetime-size-${size}`]: true,
1724
+ [`datetime-prefer-wheel`]: hasWheelVariant,
1725
+ [`datetime-grid`]: isGridStyle,
1726
+ })) }, this.renderDatetime(mode)));
1727
+ }
1728
+ get el() { return getElement(this); }
1729
+ static get watchers() { return {
1730
+ "disabled": ["disabledChanged"],
1731
+ "min": ["minChanged"],
1732
+ "max": ["maxChanged"],
1733
+ "yearValues": ["yearValuesChanged"],
1734
+ "monthValues": ["monthValuesChanged"],
1735
+ "dayValues": ["dayValuesChanged"],
1736
+ "hourValues": ["hourValuesChanged"],
1737
+ "minuteValues": ["minuteValuesChanged"],
1738
+ "value": ["valueChanged"]
1739
+ }; }
1702
1740
  };
1703
1741
  let datetimeIds = 0;
1704
1742
  Datetime.style = {
1705
- ios: datetimeIosCss,
1706
- md: datetimeMdCss
1743
+ ios: datetimeIosCss,
1744
+ md: datetimeMdCss
1707
1745
  };
1708
1746
 
1709
1747
  /**
1710
1748
  * iOS Picker Enter Animation
1711
1749
  */
1712
1750
  const iosEnterAnimation = (baseEl) => {
1713
- const baseAnimation = createAnimation();
1714
- const backdropAnimation = createAnimation();
1715
- const wrapperAnimation = createAnimation();
1716
- backdropAnimation
1717
- .addElement(baseEl.querySelector('ion-backdrop'))
1718
- .fromTo('opacity', 0.01, 'var(--backdrop-opacity)')
1719
- .beforeStyles({
1720
- 'pointer-events': 'none',
1721
- })
1722
- .afterClearStyles(['pointer-events']);
1723
- wrapperAnimation
1724
- .addElement(baseEl.querySelector('.picker-wrapper'))
1725
- .fromTo('transform', 'translateY(100%)', 'translateY(0%)');
1726
- return baseAnimation
1727
- .addElement(baseEl)
1728
- .easing('cubic-bezier(.36,.66,.04,1)')
1729
- .duration(400)
1730
- .addAnimation([backdropAnimation, wrapperAnimation]);
1751
+ const baseAnimation = createAnimation();
1752
+ const backdropAnimation = createAnimation();
1753
+ const wrapperAnimation = createAnimation();
1754
+ backdropAnimation
1755
+ .addElement(baseEl.querySelector('ion-backdrop'))
1756
+ .fromTo('opacity', 0.01, 'var(--backdrop-opacity)')
1757
+ .beforeStyles({
1758
+ 'pointer-events': 'none',
1759
+ })
1760
+ .afterClearStyles(['pointer-events']);
1761
+ wrapperAnimation
1762
+ .addElement(baseEl.querySelector('.picker-wrapper'))
1763
+ .fromTo('transform', 'translateY(100%)', 'translateY(0%)');
1764
+ return baseAnimation
1765
+ .addElement(baseEl)
1766
+ .easing('cubic-bezier(.36,.66,.04,1)')
1767
+ .duration(400)
1768
+ .addAnimation([backdropAnimation, wrapperAnimation]);
1731
1769
  };
1732
1770
 
1733
1771
  /**
1734
1772
  * iOS Picker Leave Animation
1735
1773
  */
1736
1774
  const iosLeaveAnimation = (baseEl) => {
1737
- const baseAnimation = createAnimation();
1738
- const backdropAnimation = createAnimation();
1739
- const wrapperAnimation = createAnimation();
1740
- backdropAnimation
1741
- .addElement(baseEl.querySelector('ion-backdrop'))
1742
- .fromTo('opacity', 'var(--backdrop-opacity)', 0.01);
1743
- wrapperAnimation
1744
- .addElement(baseEl.querySelector('.picker-wrapper'))
1745
- .fromTo('transform', 'translateY(0%)', 'translateY(100%)');
1746
- return baseAnimation
1747
- .addElement(baseEl)
1748
- .easing('cubic-bezier(.36,.66,.04,1)')
1749
- .duration(400)
1750
- .addAnimation([backdropAnimation, wrapperAnimation]);
1775
+ const baseAnimation = createAnimation();
1776
+ const backdropAnimation = createAnimation();
1777
+ const wrapperAnimation = createAnimation();
1778
+ backdropAnimation
1779
+ .addElement(baseEl.querySelector('ion-backdrop'))
1780
+ .fromTo('opacity', 'var(--backdrop-opacity)', 0.01);
1781
+ wrapperAnimation
1782
+ .addElement(baseEl.querySelector('.picker-wrapper'))
1783
+ .fromTo('transform', 'translateY(0%)', 'translateY(100%)');
1784
+ return baseAnimation
1785
+ .addElement(baseEl)
1786
+ .easing('cubic-bezier(.36,.66,.04,1)')
1787
+ .duration(400)
1788
+ .addAnimation([backdropAnimation, wrapperAnimation]);
1751
1789
  };
1752
1790
 
1753
1791
  const pickerIosCss = ".sc-ion-picker-ios-h{--border-radius:0;--border-style:solid;--min-width:auto;--width:100%;--max-width:500px;--min-height:auto;--max-height:auto;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;top:0;display:block;position:absolute;width:100%;height:100%;outline:none;font-family:var(--ion-font-family, inherit);contain:strict;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;z-index:1001}@supports (inset-inline-start: 0){.sc-ion-picker-ios-h{inset-inline-start:0}}@supports not (inset-inline-start: 0){.sc-ion-picker-ios-h{left:0}[dir=rtl].sc-ion-picker-ios-h,[dir=rtl] .sc-ion-picker-ios-h{left:unset;right:unset;right:0}@supports selector(:dir(rtl)){.sc-ion-picker-ios-h:dir(rtl){left:unset;right:unset;right:0}}}.overlay-hidden.sc-ion-picker-ios-h{display:none}.picker-wrapper.sc-ion-picker-ios{border-radius:var(--border-radius);left:0;right:0;bottom:0;-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto;margin-top:auto;margin-bottom:auto;-webkit-transform:translate3d(0, 100%, 0);transform:translate3d(0, 100%, 0);display:-ms-flexbox;display:flex;position:absolute;-ms-flex-direction:column;flex-direction:column;width:var(--width);min-width:var(--min-width);max-width:var(--max-width);height:var(--height);min-height:var(--min-height);max-height:var(--max-height);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);background:var(--background);contain:strict;overflow:hidden;z-index:10}.picker-toolbar.sc-ion-picker-ios{width:100%;background:transparent;contain:strict;z-index:1}.picker-button.sc-ion-picker-ios{border:0;font-family:inherit}.picker-button.sc-ion-picker-ios:active,.picker-button.sc-ion-picker-ios:focus{outline:none}.picker-columns.sc-ion-picker-ios{display:-ms-flexbox;display:flex;position:relative;-ms-flex-pack:center;justify-content:center;margin-bottom:var(--ion-safe-area-bottom, 0);contain:strict;overflow:hidden}.picker-above-highlight.sc-ion-picker-ios,.picker-below-highlight.sc-ion-picker-ios{display:none;pointer-events:none}.sc-ion-picker-ios-h{--background:var(--ion-background-color, #fff);--border-width:1px 0 0;--border-color:var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-250, #c8c7cc)));--height:260px;--backdrop-opacity:var(--ion-backdrop-opacity, 0.26);color:var(--ion-item-color, var(--ion-text-color, #000))}.picker-toolbar.sc-ion-picker-ios{display:-ms-flexbox;display:flex;height:44px;border-bottom:0.55px solid var(--border-color)}.picker-toolbar-button.sc-ion-picker-ios{-ms-flex:1;flex:1;text-align:end}.picker-toolbar-button.sc-ion-picker-ios:last-child .picker-button.sc-ion-picker-ios{font-weight:600}.picker-toolbar-button.sc-ion-picker-ios:first-child{font-weight:normal;text-align:start}.picker-button.sc-ion-picker-ios,.picker-button.ion-activated.sc-ion-picker-ios{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;-webkit-padding-start:1em;padding-inline-start:1em;-webkit-padding-end:1em;padding-inline-end:1em;padding-top:0;padding-bottom:0;height:44px;background:transparent;color:var(--ion-color-primary, #3880ff);font-size:16px}.picker-columns.sc-ion-picker-ios{height:215px;-webkit-perspective:1000px;perspective:1000px}.picker-above-highlight.sc-ion-picker-ios{top:0;-webkit-transform:translate3d(0, 0, 90px);transform:translate3d(0, 0, 90px);display:block;position:absolute;width:100%;height:81px;border-bottom:1px solid var(--border-color);background:-webkit-gradient(linear, left top, left bottom, color-stop(20%, var(--background, var(--ion-background-color, #fff))), to(rgba(var(--background-rgb, var(--ion-background-color-rgb, 255, 255, 255)), 0.8)));background:linear-gradient(to bottom, var(--background, var(--ion-background-color, #fff)) 20%, rgba(var(--background-rgb, var(--ion-background-color-rgb, 255, 255, 255)), 0.8) 100%);z-index:10}@supports (inset-inline-start: 0){.picker-above-highlight.sc-ion-picker-ios{inset-inline-start:0}}@supports not (inset-inline-start: 0){.picker-above-highlight.sc-ion-picker-ios{left:0}[dir=rtl].sc-ion-picker-ios-h .picker-above-highlight.sc-ion-picker-ios,[dir=rtl] .sc-ion-picker-ios-h .picker-above-highlight.sc-ion-picker-ios{left:unset;right:unset;right:0}[dir=rtl].sc-ion-picker-ios .picker-above-highlight.sc-ion-picker-ios{left:unset;right:unset;right:0}@supports selector(:dir(rtl)){.picker-above-highlight.sc-ion-picker-ios:dir(rtl){left:unset;right:unset;right:0}}}.picker-below-highlight.sc-ion-picker-ios{top:115px;-webkit-transform:translate3d(0, 0, 90px);transform:translate3d(0, 0, 90px);display:block;position:absolute;width:100%;height:119px;border-top:1px solid var(--border-color);background:-webkit-gradient(linear, left bottom, left top, color-stop(30%, var(--background, var(--ion-background-color, #fff))), to(rgba(var(--background-rgb, var(--ion-background-color-rgb, 255, 255, 255)), 0.8)));background:linear-gradient(to top, var(--background, var(--ion-background-color, #fff)) 30%, rgba(var(--background-rgb, var(--ion-background-color-rgb, 255, 255, 255)), 0.8) 100%);z-index:11}@supports (inset-inline-start: 0){.picker-below-highlight.sc-ion-picker-ios{inset-inline-start:0}}@supports not (inset-inline-start: 0){.picker-below-highlight.sc-ion-picker-ios{left:0}[dir=rtl].sc-ion-picker-ios-h .picker-below-highlight.sc-ion-picker-ios,[dir=rtl] .sc-ion-picker-ios-h .picker-below-highlight.sc-ion-picker-ios{left:unset;right:unset;right:0}[dir=rtl].sc-ion-picker-ios .picker-below-highlight.sc-ion-picker-ios{left:unset;right:unset;right:0}@supports selector(:dir(rtl)){.picker-below-highlight.sc-ion-picker-ios:dir(rtl){left:unset;right:unset;right:0}}}";
@@ -1755,195 +1793,205 @@ const pickerIosCss = ".sc-ion-picker-ios-h{--border-radius:0;--border-style:soli
1755
1793
  const pickerMdCss = ".sc-ion-picker-md-h{--border-radius:0;--border-style:solid;--min-width:auto;--width:100%;--max-width:500px;--min-height:auto;--max-height:auto;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;top:0;display:block;position:absolute;width:100%;height:100%;outline:none;font-family:var(--ion-font-family, inherit);contain:strict;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;z-index:1001}@supports (inset-inline-start: 0){.sc-ion-picker-md-h{inset-inline-start:0}}@supports not (inset-inline-start: 0){.sc-ion-picker-md-h{left:0}[dir=rtl].sc-ion-picker-md-h,[dir=rtl] .sc-ion-picker-md-h{left:unset;right:unset;right:0}@supports selector(:dir(rtl)){.sc-ion-picker-md-h:dir(rtl){left:unset;right:unset;right:0}}}.overlay-hidden.sc-ion-picker-md-h{display:none}.picker-wrapper.sc-ion-picker-md{border-radius:var(--border-radius);left:0;right:0;bottom:0;-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto;margin-top:auto;margin-bottom:auto;-webkit-transform:translate3d(0, 100%, 0);transform:translate3d(0, 100%, 0);display:-ms-flexbox;display:flex;position:absolute;-ms-flex-direction:column;flex-direction:column;width:var(--width);min-width:var(--min-width);max-width:var(--max-width);height:var(--height);min-height:var(--min-height);max-height:var(--max-height);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);background:var(--background);contain:strict;overflow:hidden;z-index:10}.picker-toolbar.sc-ion-picker-md{width:100%;background:transparent;contain:strict;z-index:1}.picker-button.sc-ion-picker-md{border:0;font-family:inherit}.picker-button.sc-ion-picker-md:active,.picker-button.sc-ion-picker-md:focus{outline:none}.picker-columns.sc-ion-picker-md{display:-ms-flexbox;display:flex;position:relative;-ms-flex-pack:center;justify-content:center;margin-bottom:var(--ion-safe-area-bottom, 0);contain:strict;overflow:hidden}.picker-above-highlight.sc-ion-picker-md,.picker-below-highlight.sc-ion-picker-md{display:none;pointer-events:none}.sc-ion-picker-md-h{--background:var(--ion-background-color, #fff);--border-width:0.55px 0 0;--border-color:var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-150, rgba(0, 0, 0, 0.13))));--height:260px;--backdrop-opacity:var(--ion-backdrop-opacity, 0.26);color:var(--ion-item-color, var(--ion-text-color, #000))}.picker-toolbar.sc-ion-picker-md{display:-ms-flexbox;display:flex;-ms-flex-pack:end;justify-content:flex-end;height:44px}.picker-button.sc-ion-picker-md,.picker-button.ion-activated.sc-ion-picker-md{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;-webkit-padding-start:1.1em;padding-inline-start:1.1em;-webkit-padding-end:1.1em;padding-inline-end:1.1em;padding-top:0;padding-bottom:0;height:44px;background:transparent;color:var(--ion-color-primary, #3880ff);font-size:14px;font-weight:500;text-transform:uppercase;-webkit-box-shadow:none;box-shadow:none}.picker-columns.sc-ion-picker-md{height:216px;-webkit-perspective:1800px;perspective:1800px}.picker-above-highlight.sc-ion-picker-md{top:0;-webkit-transform:translate3d(0, 0, 90px);transform:translate3d(0, 0, 90px);position:absolute;width:100%;height:81px;border-bottom:1px solid var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-150, rgba(0, 0, 0, 0.13))));background:-webkit-gradient(linear, left top, left bottom, color-stop(20%, var(--ion-background-color, #fff)), to(rgba(var(--ion-background-color-rgb, 255, 255, 255), 0.8)));background:linear-gradient(to bottom, var(--ion-background-color, #fff) 20%, rgba(var(--ion-background-color-rgb, 255, 255, 255), 0.8) 100%);z-index:10}@supports (inset-inline-start: 0){.picker-above-highlight.sc-ion-picker-md{inset-inline-start:0}}@supports not (inset-inline-start: 0){.picker-above-highlight.sc-ion-picker-md{left:0}[dir=rtl].sc-ion-picker-md-h .picker-above-highlight.sc-ion-picker-md,[dir=rtl] .sc-ion-picker-md-h .picker-above-highlight.sc-ion-picker-md{left:unset;right:unset;right:0}[dir=rtl].sc-ion-picker-md .picker-above-highlight.sc-ion-picker-md{left:unset;right:unset;right:0}@supports selector(:dir(rtl)){.picker-above-highlight.sc-ion-picker-md:dir(rtl){left:unset;right:unset;right:0}}}.picker-below-highlight.sc-ion-picker-md{top:115px;-webkit-transform:translate3d(0, 0, 90px);transform:translate3d(0, 0, 90px);position:absolute;width:100%;height:119px;border-top:1px solid var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-150, rgba(0, 0, 0, 0.13))));background:-webkit-gradient(linear, left bottom, left top, color-stop(30%, var(--ion-background-color, #fff)), to(rgba(var(--ion-background-color-rgb, 255, 255, 255), 0.8)));background:linear-gradient(to top, var(--ion-background-color, #fff) 30%, rgba(var(--ion-background-color-rgb, 255, 255, 255), 0.8) 100%);z-index:11}@supports (inset-inline-start: 0){.picker-below-highlight.sc-ion-picker-md{inset-inline-start:0}}@supports not (inset-inline-start: 0){.picker-below-highlight.sc-ion-picker-md{left:0}[dir=rtl].sc-ion-picker-md-h .picker-below-highlight.sc-ion-picker-md,[dir=rtl] .sc-ion-picker-md-h .picker-below-highlight.sc-ion-picker-md{left:unset;right:unset;right:0}[dir=rtl].sc-ion-picker-md .picker-below-highlight.sc-ion-picker-md{left:unset;right:unset;right:0}@supports selector(:dir(rtl)){.picker-below-highlight.sc-ion-picker-md:dir(rtl){left:unset;right:unset;right:0}}}";
1756
1794
 
1757
1795
  const Picker = class {
1758
- constructor(hostRef) {
1759
- registerInstance(this, hostRef);
1760
- this.didPresent = createEvent(this, "ionPickerDidPresent", 7);
1761
- this.willPresent = createEvent(this, "ionPickerWillPresent", 7);
1762
- this.willDismiss = createEvent(this, "ionPickerWillDismiss", 7);
1763
- this.didDismiss = createEvent(this, "ionPickerDidDismiss", 7);
1764
- this.didPresentShorthand = createEvent(this, "didPresent", 7);
1765
- this.willPresentShorthand = createEvent(this, "willPresent", 7);
1766
- this.willDismissShorthand = createEvent(this, "willDismiss", 7);
1767
- this.didDismissShorthand = createEvent(this, "didDismiss", 7);
1768
- this.delegateController = createDelegateController(this);
1769
- this.lockController = createLockController();
1770
- this.triggerController = createTriggerController();
1771
- this.onBackdropTap = () => {
1772
- this.dismiss(undefined, BACKDROP);
1773
- };
1774
- this.dispatchCancelHandler = (ev) => {
1775
- const role = ev.detail.role;
1776
- if (isCancel(role)) {
1777
- const cancelButton = this.buttons.find((b) => b.role === 'cancel');
1778
- this.callButtonHandler(cancelButton);
1779
- }
1780
- };
1781
- this.presented = false;
1782
- this.overlayIndex = undefined;
1783
- this.delegate = undefined;
1784
- this.hasController = false;
1785
- this.keyboardClose = true;
1786
- this.enterAnimation = undefined;
1787
- this.leaveAnimation = undefined;
1788
- this.buttons = [];
1789
- this.columns = [];
1790
- this.cssClass = undefined;
1791
- this.duration = 0;
1792
- this.showBackdrop = true;
1793
- this.backdropDismiss = true;
1794
- this.animated = true;
1795
- this.htmlAttributes = undefined;
1796
- this.isOpen = false;
1797
- this.trigger = undefined;
1798
- }
1799
- onIsOpenChange(newValue, oldValue) {
1800
- if (newValue === true && oldValue === false) {
1801
- this.present();
1802
- }
1803
- else if (newValue === false && oldValue === true) {
1804
- this.dismiss();
1805
- }
1806
- }
1807
- triggerChanged() {
1808
- const { trigger, el, triggerController } = this;
1809
- if (trigger) {
1810
- triggerController.addClickListener(el, trigger);
1811
- }
1812
- }
1813
- connectedCallback() {
1814
- prepareOverlay(this.el);
1815
- this.triggerChanged();
1816
- }
1817
- disconnectedCallback() {
1818
- this.triggerController.removeClickListener();
1819
- }
1820
- componentWillLoad() {
1821
- setOverlayId(this.el);
1822
- }
1823
- componentDidLoad() {
1796
+ constructor(hostRef) {
1797
+ registerInstance(this, hostRef);
1798
+ this.didPresent = createEvent(this, "ionPickerDidPresent", 7);
1799
+ this.willPresent = createEvent(this, "ionPickerWillPresent", 7);
1800
+ this.willDismiss = createEvent(this, "ionPickerWillDismiss", 7);
1801
+ this.didDismiss = createEvent(this, "ionPickerDidDismiss", 7);
1802
+ this.didPresentShorthand = createEvent(this, "didPresent", 7);
1803
+ this.willPresentShorthand = createEvent(this, "willPresent", 7);
1804
+ this.willDismissShorthand = createEvent(this, "willDismiss", 7);
1805
+ this.didDismissShorthand = createEvent(this, "didDismiss", 7);
1806
+ this.delegateController = createDelegateController(this);
1807
+ this.lockController = createLockController();
1808
+ this.triggerController = createTriggerController();
1809
+ this.onBackdropTap = () => {
1810
+ this.dismiss(undefined, BACKDROP);
1811
+ };
1812
+ this.dispatchCancelHandler = (ev) => {
1813
+ const role = ev.detail.role;
1814
+ if (isCancel(role)) {
1815
+ const cancelButton = this.buttons.find((b) => b.role === 'cancel');
1816
+ this.callButtonHandler(cancelButton);
1817
+ }
1818
+ };
1819
+ this.presented = false;
1820
+ this.overlayIndex = undefined;
1821
+ this.delegate = undefined;
1822
+ this.hasController = false;
1823
+ this.keyboardClose = true;
1824
+ this.enterAnimation = undefined;
1825
+ this.leaveAnimation = undefined;
1826
+ this.buttons = [];
1827
+ this.columns = [];
1828
+ this.cssClass = undefined;
1829
+ this.duration = 0;
1830
+ this.showBackdrop = true;
1831
+ this.backdropDismiss = true;
1832
+ this.animated = true;
1833
+ this.htmlAttributes = undefined;
1834
+ this.isOpen = false;
1835
+ this.trigger = undefined;
1836
+ }
1837
+ onIsOpenChange(newValue, oldValue) {
1838
+ if (newValue === true && oldValue === false) {
1839
+ this.present();
1840
+ }
1841
+ else if (newValue === false && oldValue === true) {
1842
+ this.dismiss();
1843
+ }
1844
+ }
1845
+ triggerChanged() {
1846
+ const { trigger, el, triggerController } = this;
1847
+ if (trigger) {
1848
+ triggerController.addClickListener(el, trigger);
1849
+ }
1850
+ }
1851
+ connectedCallback() {
1852
+ prepareOverlay(this.el);
1853
+ this.triggerChanged();
1854
+ }
1855
+ disconnectedCallback() {
1856
+ this.triggerController.removeClickListener();
1857
+ }
1858
+ componentWillLoad() {
1859
+ setOverlayId(this.el);
1860
+ }
1861
+ componentDidLoad() {
1862
+ /**
1863
+ * If picker was rendered with isOpen="true"
1864
+ * then we should open picker immediately.
1865
+ */
1866
+ if (this.isOpen === true) {
1867
+ raf(() => this.present());
1868
+ }
1869
+ /**
1870
+ * When binding values in frameworks such as Angular
1871
+ * it is possible for the value to be set after the Web Component
1872
+ * initializes but before the value watcher is set up in Stencil.
1873
+ * As a result, the watcher callback may not be fired.
1874
+ * We work around this by manually calling the watcher
1875
+ * callback when the component has loaded and the watcher
1876
+ * is configured.
1877
+ */
1878
+ this.triggerChanged();
1879
+ }
1824
1880
  /**
1825
- * If picker was rendered with isOpen="true"
1826
- * then we should open picker immediately.
1881
+ * Present the picker overlay after it has been created.
1827
1882
  */
1828
- if (this.isOpen === true) {
1829
- raf(() => this.present());
1830
- }
1831
- }
1832
- /**
1833
- * Present the picker overlay after it has been created.
1834
- */
1835
- async present() {
1836
- const unlock = await this.lockController.lock();
1837
- await this.delegateController.attachViewToDom();
1838
- await present(this, 'pickerEnter', iosEnterAnimation, iosEnterAnimation, undefined);
1839
- if (this.duration > 0) {
1840
- this.durationTimeout = setTimeout(() => this.dismiss(), this.duration);
1841
- }
1842
- unlock();
1843
- }
1844
- /**
1845
- * Dismiss the picker overlay after it has been presented.
1846
- *
1847
- * @param data Any data to emit in the dismiss events.
1848
- * @param role The role of the element that is dismissing the picker.
1849
- * This can be useful in a button handler for determining which button was
1850
- * clicked to dismiss the picker.
1851
- * Some examples include: ``"cancel"`, `"destructive"`, "selected"`, and `"backdrop"`.
1852
- */
1853
- async dismiss(data, role) {
1854
- const unlock = await this.lockController.lock();
1855
- if (this.durationTimeout) {
1856
- clearTimeout(this.durationTimeout);
1857
- }
1858
- const dismissed = await dismiss(this, data, role, 'pickerLeave', iosLeaveAnimation, iosLeaveAnimation);
1859
- if (dismissed) {
1860
- this.delegateController.removeViewFromDom();
1861
- }
1862
- unlock();
1863
- return dismissed;
1864
- }
1865
- /**
1866
- * Returns a promise that resolves when the picker did dismiss.
1867
- */
1868
- onDidDismiss() {
1869
- return eventMethod(this.el, 'ionPickerDidDismiss');
1870
- }
1871
- /**
1872
- * Returns a promise that resolves when the picker will dismiss.
1873
- */
1874
- onWillDismiss() {
1875
- return eventMethod(this.el, 'ionPickerWillDismiss');
1876
- }
1877
- /**
1878
- * Get the column that matches the specified name.
1879
- *
1880
- * @param name The name of the column.
1881
- */
1882
- getColumn(name) {
1883
- return Promise.resolve(this.columns.find((column) => column.name === name));
1884
- }
1885
- async buttonClick(button) {
1886
- const role = button.role;
1887
- if (isCancel(role)) {
1888
- return this.dismiss(undefined, role);
1889
- }
1890
- const shouldDismiss = await this.callButtonHandler(button);
1891
- if (shouldDismiss) {
1892
- return this.dismiss(this.getSelected(), button.role);
1893
- }
1894
- return Promise.resolve();
1895
- }
1896
- async callButtonHandler(button) {
1897
- if (button) {
1898
- // a handler has been provided, execute it
1899
- // pass the handler the values from the inputs
1900
- const rtn = await safeCall(button.handler, this.getSelected());
1901
- if (rtn === false) {
1902
- // if the return value of the handler is false then do not dismiss
1903
- return false;
1904
- }
1905
- }
1906
- return true;
1907
- }
1908
- getSelected() {
1909
- const selected = {};
1910
- this.columns.forEach((col, index) => {
1911
- const selectedColumn = col.selectedIndex !== undefined ? col.options[col.selectedIndex] : undefined;
1912
- selected[col.name] = {
1913
- text: selectedColumn ? selectedColumn.text : undefined,
1914
- value: selectedColumn ? selectedColumn.value : undefined,
1915
- columnIndex: index,
1916
- };
1917
- });
1918
- return selected;
1919
- }
1920
- render() {
1921
- const { htmlAttributes } = this;
1922
- const mode = getIonMode(this);
1923
- return (h(Host, Object.assign({ "aria-modal": "true", tabindex: "-1" }, htmlAttributes, { style: {
1924
- zIndex: `${20000 + this.overlayIndex}`,
1925
- }, class: Object.assign({ [mode]: true,
1926
- // Used internally for styling
1927
- [`picker-${mode}`]: true, 'overlay-hidden': true }, getClassMap(this.cssClass)), onIonBackdropTap: this.onBackdropTap, onIonPickerWillDismiss: this.dispatchCancelHandler }), h("ion-backdrop", { visible: this.showBackdrop, tappable: this.backdropDismiss }), h("div", { tabindex: "0" }), h("div", { class: "picker-wrapper ion-overlay-wrapper", role: "dialog" }, h("div", { class: "picker-toolbar" }, this.buttons.map((b) => (h("div", { class: buttonWrapperClass(b) }, h("button", { type: "button", onClick: () => this.buttonClick(b), class: buttonClass(b) }, b.text))))), h("div", { class: "picker-columns" }, h("div", { class: "picker-above-highlight" }), this.presented && this.columns.map((c) => h("ion-picker-column", { col: c })), h("div", { class: "picker-below-highlight" }))), h("div", { tabindex: "0" })));
1928
- }
1929
- get el() { return getElement(this); }
1930
- static get watchers() { return {
1931
- "isOpen": ["onIsOpenChange"],
1932
- "trigger": ["triggerChanged"]
1933
- }; }
1883
+ async present() {
1884
+ const unlock = await this.lockController.lock();
1885
+ await this.delegateController.attachViewToDom();
1886
+ await present(this, 'pickerEnter', iosEnterAnimation, iosEnterAnimation, undefined);
1887
+ if (this.duration > 0) {
1888
+ this.durationTimeout = setTimeout(() => this.dismiss(), this.duration);
1889
+ }
1890
+ unlock();
1891
+ }
1892
+ /**
1893
+ * Dismiss the picker overlay after it has been presented.
1894
+ *
1895
+ * @param data Any data to emit in the dismiss events.
1896
+ * @param role The role of the element that is dismissing the picker.
1897
+ * This can be useful in a button handler for determining which button was
1898
+ * clicked to dismiss the picker.
1899
+ * Some examples include: ``"cancel"`, `"destructive"`, "selected"`, and `"backdrop"`.
1900
+ */
1901
+ async dismiss(data, role) {
1902
+ const unlock = await this.lockController.lock();
1903
+ if (this.durationTimeout) {
1904
+ clearTimeout(this.durationTimeout);
1905
+ }
1906
+ const dismissed = await dismiss(this, data, role, 'pickerLeave', iosLeaveAnimation, iosLeaveAnimation);
1907
+ if (dismissed) {
1908
+ this.delegateController.removeViewFromDom();
1909
+ }
1910
+ unlock();
1911
+ return dismissed;
1912
+ }
1913
+ /**
1914
+ * Returns a promise that resolves when the picker did dismiss.
1915
+ */
1916
+ onDidDismiss() {
1917
+ return eventMethod(this.el, 'ionPickerDidDismiss');
1918
+ }
1919
+ /**
1920
+ * Returns a promise that resolves when the picker will dismiss.
1921
+ */
1922
+ onWillDismiss() {
1923
+ return eventMethod(this.el, 'ionPickerWillDismiss');
1924
+ }
1925
+ /**
1926
+ * Get the column that matches the specified name.
1927
+ *
1928
+ * @param name The name of the column.
1929
+ */
1930
+ getColumn(name) {
1931
+ return Promise.resolve(this.columns.find((column) => column.name === name));
1932
+ }
1933
+ async buttonClick(button) {
1934
+ const role = button.role;
1935
+ if (isCancel(role)) {
1936
+ return this.dismiss(undefined, role);
1937
+ }
1938
+ const shouldDismiss = await this.callButtonHandler(button);
1939
+ if (shouldDismiss) {
1940
+ return this.dismiss(this.getSelected(), button.role);
1941
+ }
1942
+ return Promise.resolve();
1943
+ }
1944
+ async callButtonHandler(button) {
1945
+ if (button) {
1946
+ // a handler has been provided, execute it
1947
+ // pass the handler the values from the inputs
1948
+ const rtn = await safeCall(button.handler, this.getSelected());
1949
+ if (rtn === false) {
1950
+ // if the return value of the handler is false then do not dismiss
1951
+ return false;
1952
+ }
1953
+ }
1954
+ return true;
1955
+ }
1956
+ getSelected() {
1957
+ const selected = {};
1958
+ this.columns.forEach((col, index) => {
1959
+ const selectedColumn = col.selectedIndex !== undefined ? col.options[col.selectedIndex] : undefined;
1960
+ selected[col.name] = {
1961
+ text: selectedColumn ? selectedColumn.text : undefined,
1962
+ value: selectedColumn ? selectedColumn.value : undefined,
1963
+ columnIndex: index,
1964
+ };
1965
+ });
1966
+ return selected;
1967
+ }
1968
+ render() {
1969
+ const { htmlAttributes } = this;
1970
+ const mode = getIonMode(this);
1971
+ return (h(Host, Object.assign({ "aria-modal": "true", tabindex: "-1" }, htmlAttributes, { style: {
1972
+ zIndex: `${20000 + this.overlayIndex}`,
1973
+ }, class: Object.assign({ [mode]: true,
1974
+ // Used internally for styling
1975
+ [`picker-${mode}`]: true, 'overlay-hidden': true }, getClassMap(this.cssClass)), onIonBackdropTap: this.onBackdropTap, onIonPickerWillDismiss: this.dispatchCancelHandler }), h("ion-backdrop", { visible: this.showBackdrop, tappable: this.backdropDismiss }), h("div", { tabindex: "0" }), h("div", { class: "picker-wrapper ion-overlay-wrapper", role: "dialog" }, h("div", { class: "picker-toolbar" }, this.buttons.map((b) => (h("div", { class: buttonWrapperClass(b) }, h("button", { type: "button", onClick: () => this.buttonClick(b), class: buttonClass(b) }, b.text))))), h("div", { class: "picker-columns" }, h("div", { class: "picker-above-highlight" }), this.presented && this.columns.map((c) => h("ion-picker-column", { col: c })), h("div", { class: "picker-below-highlight" }))), h("div", { tabindex: "0" })));
1976
+ }
1977
+ get el() { return getElement(this); }
1978
+ static get watchers() { return {
1979
+ "isOpen": ["onIsOpenChange"],
1980
+ "trigger": ["triggerChanged"]
1981
+ }; }
1934
1982
  };
1935
1983
  const buttonWrapperClass = (button) => {
1936
- return {
1937
- [`picker-toolbar-${button.role}`]: button.role !== undefined,
1938
- 'picker-toolbar-button': true,
1939
- };
1984
+ return {
1985
+ [`picker-toolbar-${button.role}`]: button.role !== undefined,
1986
+ 'picker-toolbar-button': true,
1987
+ };
1940
1988
  };
1941
1989
  const buttonClass = (button) => {
1942
- return Object.assign({ 'picker-button': true, 'ion-activatable': true }, getClassMap(button.cssClass));
1990
+ return Object.assign({ 'picker-button': true, 'ion-activatable': true }, getClassMap(button.cssClass));
1943
1991
  };
1944
1992
  Picker.style = {
1945
- ios: pickerIosCss,
1946
- md: pickerMdCss
1993
+ ios: pickerIosCss,
1994
+ md: pickerMdCss
1947
1995
  };
1948
1996
 
1949
1997
  const pickerColumnIosCss = ".picker-col{display:-ms-flexbox;display:flex;position:relative;-ms-flex:1;flex:1;-ms-flex-pack:center;justify-content:center;height:100%;-webkit-box-sizing:content-box;box-sizing:content-box;contain:content}.picker-opts{position:relative;-ms-flex:1;flex:1;max-width:100%}.picker-opt{top:0;display:block;position:absolute;width:100%;border:0;text-align:center;text-overflow:ellipsis;white-space:nowrap;contain:strict;overflow:hidden;will-change:transform}@supports (inset-inline-start: 0){.picker-opt{inset-inline-start:0}}@supports not (inset-inline-start: 0){.picker-opt{left:0}:host-context([dir=rtl]) .picker-opt{left:unset;right:unset;right:0}[dir=rtl] .picker-opt{left:unset;right:unset;right:0}@supports selector(:dir(rtl)){.picker-opt:dir(rtl){left:unset;right:unset;right:0}}}.picker-opt.picker-opt-disabled{pointer-events:none}.picker-opt-disabled{opacity:0}.picker-opts-left{-ms-flex-pack:start;justify-content:flex-start}.picker-opts-right{-ms-flex-pack:end;justify-content:flex-end}.picker-opt:active,.picker-opt:focus{outline:none}.picker-prefix{position:relative;-ms-flex:1;flex:1;text-align:end;white-space:nowrap}.picker-suffix{position:relative;-ms-flex:1;flex:1;text-align:start;white-space:nowrap}.picker-col{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:4px;padding-inline-end:4px;padding-top:0;padding-bottom:0;-webkit-transform-style:preserve-3d;transform-style:preserve-3d}.picker-prefix,.picker-suffix,.picker-opts{top:77px;-webkit-transform-style:preserve-3d;transform-style:preserve-3d;color:inherit;font-size:20px;line-height:42px;pointer-events:none}.picker-opt{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;-webkit-transform-origin:center center;transform-origin:center center;height:46px;-webkit-transform-style:preserve-3d;transform-style:preserve-3d;-webkit-transition-timing-function:ease-out;transition-timing-function:ease-out;background:transparent;color:inherit;font-size:20px;line-height:42px;-webkit-backface-visibility:hidden;backface-visibility:hidden;pointer-events:auto}:host-context([dir=rtl]) .picker-opt{-webkit-transform-origin:calc(100% - center) center;transform-origin:calc(100% - center) center}[dir=rtl] .picker-opt{-webkit-transform-origin:calc(100% - center) center;transform-origin:calc(100% - center) center}@supports selector(:dir(rtl)){.picker-opt:dir(rtl){-webkit-transform-origin:calc(100% - center) center;transform-origin:calc(100% - center) center}}";
@@ -1951,350 +1999,350 @@ const pickerColumnIosCss = ".picker-col{display:-ms-flexbox;display:flex;positio
1951
1999
  const pickerColumnMdCss = ".picker-col{display:-ms-flexbox;display:flex;position:relative;-ms-flex:1;flex:1;-ms-flex-pack:center;justify-content:center;height:100%;-webkit-box-sizing:content-box;box-sizing:content-box;contain:content}.picker-opts{position:relative;-ms-flex:1;flex:1;max-width:100%}.picker-opt{top:0;display:block;position:absolute;width:100%;border:0;text-align:center;text-overflow:ellipsis;white-space:nowrap;contain:strict;overflow:hidden;will-change:transform}@supports (inset-inline-start: 0){.picker-opt{inset-inline-start:0}}@supports not (inset-inline-start: 0){.picker-opt{left:0}:host-context([dir=rtl]) .picker-opt{left:unset;right:unset;right:0}[dir=rtl] .picker-opt{left:unset;right:unset;right:0}@supports selector(:dir(rtl)){.picker-opt:dir(rtl){left:unset;right:unset;right:0}}}.picker-opt.picker-opt-disabled{pointer-events:none}.picker-opt-disabled{opacity:0}.picker-opts-left{-ms-flex-pack:start;justify-content:flex-start}.picker-opts-right{-ms-flex-pack:end;justify-content:flex-end}.picker-opt:active,.picker-opt:focus{outline:none}.picker-prefix{position:relative;-ms-flex:1;flex:1;text-align:end;white-space:nowrap}.picker-suffix{position:relative;-ms-flex:1;flex:1;text-align:start;white-space:nowrap}.picker-col{-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px;padding-top:0;padding-bottom:0;-webkit-transform-style:preserve-3d;transform-style:preserve-3d}.picker-prefix,.picker-suffix,.picker-opts{top:77px;-webkit-transform-style:preserve-3d;transform-style:preserve-3d;color:inherit;font-size:22px;line-height:42px;pointer-events:none}.picker-opt{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;height:43px;-webkit-transition-timing-function:ease-out;transition-timing-function:ease-out;background:transparent;color:inherit;font-size:22px;line-height:42px;-webkit-backface-visibility:hidden;backface-visibility:hidden;pointer-events:auto}.picker-prefix,.picker-suffix,.picker-opt.picker-opt-selected{color:var(--ion-color-primary, #3880ff)}";
1952
2000
 
1953
2001
  const PickerColumnCmp = class {
1954
- constructor(hostRef) {
1955
- registerInstance(this, hostRef);
1956
- this.ionPickerColChange = createEvent(this, "ionPickerColChange", 7);
1957
- this.optHeight = 0;
1958
- this.rotateFactor = 0;
1959
- this.scaleFactor = 1;
1960
- this.velocity = 0;
1961
- this.y = 0;
1962
- this.noAnimate = true;
1963
- // `colDidChange` is a flag that gets set when the column is changed
1964
- // dynamically. When this flag is set, the column will refresh
1965
- // after the component re-renders to incorporate the new column data.
1966
- // This is necessary because `this.refresh` queries for the option elements,
1967
- // so it needs to wait for the latest elements to be available in the DOM.
1968
- // Ex: column is created with 3 options. User updates the column data
1969
- // to have 5 options. The column will still think it only has 3 options.
1970
- this.colDidChange = false;
1971
- this.col = undefined;
1972
- }
1973
- colChanged() {
1974
- this.colDidChange = true;
1975
- }
1976
- async connectedCallback() {
1977
- let pickerRotateFactor = 0;
1978
- let pickerScaleFactor = 0.81;
1979
- const mode = getIonMode(this);
1980
- if (mode === 'ios') {
1981
- pickerRotateFactor = -0.46;
1982
- pickerScaleFactor = 1;
1983
- }
1984
- this.rotateFactor = pickerRotateFactor;
1985
- this.scaleFactor = pickerScaleFactor;
1986
- this.gesture = (await import('./index-ff313b19.js')).createGesture({
1987
- el: this.el,
1988
- gestureName: 'picker-swipe',
1989
- gesturePriority: 100,
1990
- threshold: 0,
1991
- passive: false,
1992
- onStart: (ev) => this.onStart(ev),
1993
- onMove: (ev) => this.onMove(ev),
1994
- onEnd: (ev) => this.onEnd(ev),
1995
- });
1996
- this.gesture.enable();
1997
- // Options have not been initialized yet
1998
- // Animation must be disabled through the `noAnimate` flag
1999
- // Otherwise, the options will render
2000
- // at the top of the column and transition down
2001
- this.tmrId = setTimeout(() => {
2002
- this.noAnimate = false;
2003
- // After initialization, `refresh()` will be called
2004
- // At this point, animation will be enabled. The options will
2005
- // animate as they are being selected.
2006
- this.refresh(true);
2007
- }, 250);
2008
- }
2009
- componentDidLoad() {
2010
- this.onDomChange();
2011
- }
2012
- componentDidUpdate() {
2013
- // Options may have changed since last update.
2014
- if (this.colDidChange) {
2015
- // Animation must be disabled through the `onDomChange` parameter.
2016
- // Otherwise, the recently added options will render
2017
- // at the top of the column and transition down
2018
- this.onDomChange(true, false);
2019
- this.colDidChange = false;
2020
- }
2021
- }
2022
- disconnectedCallback() {
2023
- if (this.rafId !== undefined)
2024
- cancelAnimationFrame(this.rafId);
2025
- if (this.tmrId)
2026
- clearTimeout(this.tmrId);
2027
- if (this.gesture) {
2028
- this.gesture.destroy();
2029
- this.gesture = undefined;
2030
- }
2031
- }
2032
- emitColChange() {
2033
- this.ionPickerColChange.emit(this.col);
2034
- }
2035
- setSelected(selectedIndex, duration) {
2036
- // if there is a selected index, then figure out it's y position
2037
- // if there isn't a selected index, then just use the top y position
2038
- const y = selectedIndex > -1 ? -(selectedIndex * this.optHeight) : 0;
2039
- this.velocity = 0;
2040
- // set what y position we're at
2041
- if (this.rafId !== undefined)
2042
- cancelAnimationFrame(this.rafId);
2043
- this.update(y, duration, true);
2044
- this.emitColChange();
2045
- }
2046
- update(y, duration, saveY) {
2047
- if (!this.optsEl) {
2048
- return;
2049
- }
2050
- // ensure we've got a good round number :)
2051
- let translateY = 0;
2052
- let translateZ = 0;
2053
- const { col, rotateFactor } = this;
2054
- const prevSelected = col.selectedIndex;
2055
- const selectedIndex = (col.selectedIndex = this.indexForY(-y));
2056
- const durationStr = duration === 0 ? '' : duration + 'ms';
2057
- const scaleStr = `scale(${this.scaleFactor})`;
2058
- const children = this.optsEl.children;
2059
- for (let i = 0; i < children.length; i++) {
2060
- const button = children[i];
2061
- const opt = col.options[i];
2062
- const optOffset = i * this.optHeight + y;
2063
- let transform = '';
2064
- if (rotateFactor !== 0) {
2065
- const rotateX = optOffset * rotateFactor;
2066
- if (Math.abs(rotateX) <= 90) {
2067
- translateY = 0;
2068
- translateZ = 90;
2069
- transform = `rotateX(${rotateX}deg) `;
2002
+ constructor(hostRef) {
2003
+ registerInstance(this, hostRef);
2004
+ this.ionPickerColChange = createEvent(this, "ionPickerColChange", 7);
2005
+ this.optHeight = 0;
2006
+ this.rotateFactor = 0;
2007
+ this.scaleFactor = 1;
2008
+ this.velocity = 0;
2009
+ this.y = 0;
2010
+ this.noAnimate = true;
2011
+ // `colDidChange` is a flag that gets set when the column is changed
2012
+ // dynamically. When this flag is set, the column will refresh
2013
+ // after the component re-renders to incorporate the new column data.
2014
+ // This is necessary because `this.refresh` queries for the option elements,
2015
+ // so it needs to wait for the latest elements to be available in the DOM.
2016
+ // Ex: column is created with 3 options. User updates the column data
2017
+ // to have 5 options. The column will still think it only has 3 options.
2018
+ this.colDidChange = false;
2019
+ this.col = undefined;
2020
+ }
2021
+ colChanged() {
2022
+ this.colDidChange = true;
2023
+ }
2024
+ async connectedCallback() {
2025
+ let pickerRotateFactor = 0;
2026
+ let pickerScaleFactor = 0.81;
2027
+ const mode = getIonMode(this);
2028
+ if (mode === 'ios') {
2029
+ pickerRotateFactor = -0.46;
2030
+ pickerScaleFactor = 1;
2070
2031
  }
2071
- else {
2072
- translateY = -9999;
2032
+ this.rotateFactor = pickerRotateFactor;
2033
+ this.scaleFactor = pickerScaleFactor;
2034
+ this.gesture = (await import('./index-2cf77112.js')).createGesture({
2035
+ el: this.el,
2036
+ gestureName: 'picker-swipe',
2037
+ gesturePriority: 100,
2038
+ threshold: 0,
2039
+ passive: false,
2040
+ onStart: (ev) => this.onStart(ev),
2041
+ onMove: (ev) => this.onMove(ev),
2042
+ onEnd: (ev) => this.onEnd(ev),
2043
+ });
2044
+ this.gesture.enable();
2045
+ // Options have not been initialized yet
2046
+ // Animation must be disabled through the `noAnimate` flag
2047
+ // Otherwise, the options will render
2048
+ // at the top of the column and transition down
2049
+ this.tmrId = setTimeout(() => {
2050
+ this.noAnimate = false;
2051
+ // After initialization, `refresh()` will be called
2052
+ // At this point, animation will be enabled. The options will
2053
+ // animate as they are being selected.
2054
+ this.refresh(true);
2055
+ }, 250);
2056
+ }
2057
+ componentDidLoad() {
2058
+ this.onDomChange();
2059
+ }
2060
+ componentDidUpdate() {
2061
+ // Options may have changed since last update.
2062
+ if (this.colDidChange) {
2063
+ // Animation must be disabled through the `onDomChange` parameter.
2064
+ // Otherwise, the recently added options will render
2065
+ // at the top of the column and transition down
2066
+ this.onDomChange(true, false);
2067
+ this.colDidChange = false;
2073
2068
  }
2074
- }
2075
- else {
2076
- translateZ = 0;
2077
- translateY = optOffset;
2078
- }
2079
- const selected = selectedIndex === i;
2080
- transform += `translate3d(0px,${translateY}px,${translateZ}px) `;
2081
- if (this.scaleFactor !== 1 && !selected) {
2082
- transform += scaleStr;
2083
- }
2084
- // Update transition duration
2085
- if (this.noAnimate) {
2086
- opt.duration = 0;
2087
- button.style.transitionDuration = '';
2088
- }
2089
- else if (duration !== opt.duration) {
2090
- opt.duration = duration;
2091
- button.style.transitionDuration = durationStr;
2092
- }
2093
- // Update transform
2094
- if (transform !== opt.transform) {
2095
- opt.transform = transform;
2096
- }
2097
- button.style.transform = transform;
2098
- /**
2099
- * Ensure that the select column
2100
- * item has the selected class
2101
- */
2102
- opt.selected = selected;
2103
- if (selected) {
2104
- button.classList.add(PICKER_OPT_SELECTED);
2105
- }
2106
- else {
2107
- button.classList.remove(PICKER_OPT_SELECTED);
2108
- }
2109
- }
2110
- this.col.prevSelected = prevSelected;
2111
- if (saveY) {
2112
- this.y = y;
2113
- }
2114
- if (this.lastIndex !== selectedIndex) {
2115
- // have not set a last index yet
2116
- hapticSelectionChanged();
2117
- this.lastIndex = selectedIndex;
2118
- }
2119
- }
2120
- decelerate() {
2121
- if (this.velocity !== 0) {
2122
- // still decelerating
2123
- this.velocity *= DECELERATION_FRICTION;
2124
- // do not let it go slower than a velocity of 1
2125
- this.velocity = this.velocity > 0 ? Math.max(this.velocity, 1) : Math.min(this.velocity, -1);
2126
- let y = this.y + this.velocity;
2127
- if (y > this.minY) {
2128
- // whoops, it's trying to scroll up farther than the options we have!
2129
- y = this.minY;
2130
- this.velocity = 0;
2131
- }
2132
- else if (y < this.maxY) {
2133
- // gahh, it's trying to scroll down farther than we can!
2134
- y = this.maxY;
2135
- this.velocity = 0;
2136
- }
2137
- this.update(y, 0, true);
2138
- const notLockedIn = Math.round(y) % this.optHeight !== 0 || Math.abs(this.velocity) > 1;
2139
- if (notLockedIn) {
2140
- // isn't locked in yet, keep decelerating until it is
2141
- this.rafId = requestAnimationFrame(() => this.decelerate());
2142
- }
2143
- else {
2069
+ }
2070
+ disconnectedCallback() {
2071
+ if (this.rafId !== undefined)
2072
+ cancelAnimationFrame(this.rafId);
2073
+ if (this.tmrId)
2074
+ clearTimeout(this.tmrId);
2075
+ if (this.gesture) {
2076
+ this.gesture.destroy();
2077
+ this.gesture = undefined;
2078
+ }
2079
+ }
2080
+ emitColChange() {
2081
+ this.ionPickerColChange.emit(this.col);
2082
+ }
2083
+ setSelected(selectedIndex, duration) {
2084
+ // if there is a selected index, then figure out it's y position
2085
+ // if there isn't a selected index, then just use the top y position
2086
+ const y = selectedIndex > -1 ? -(selectedIndex * this.optHeight) : 0;
2144
2087
  this.velocity = 0;
2088
+ // set what y position we're at
2089
+ if (this.rafId !== undefined)
2090
+ cancelAnimationFrame(this.rafId);
2091
+ this.update(y, duration, true);
2145
2092
  this.emitColChange();
2146
- hapticSelectionEnd();
2147
- }
2148
- }
2149
- else if (this.y % this.optHeight !== 0) {
2150
- // needs to still get locked into a position so options line up
2151
- const currentPos = Math.abs(this.y % this.optHeight);
2152
- // create a velocity in the direction it needs to scroll
2153
- this.velocity = currentPos > this.optHeight / 2 ? 1 : -1;
2154
- this.decelerate();
2155
- }
2156
- }
2157
- indexForY(y) {
2158
- return Math.min(Math.max(Math.abs(Math.round(y / this.optHeight)), 0), this.col.options.length - 1);
2159
- }
2160
- onStart(detail) {
2161
- // We have to prevent default in order to block scrolling under the picker
2162
- // but we DO NOT have to stop propagation, since we still want
2163
- // some "click" events to capture
2164
- if (detail.event.cancelable) {
2165
- detail.event.preventDefault();
2166
- }
2167
- detail.event.stopPropagation();
2168
- hapticSelectionStart();
2169
- // reset everything
2170
- if (this.rafId !== undefined)
2171
- cancelAnimationFrame(this.rafId);
2172
- const options = this.col.options;
2173
- let minY = options.length - 1;
2174
- let maxY = 0;
2175
- for (let i = 0; i < options.length; i++) {
2176
- if (!options[i].disabled) {
2177
- minY = Math.min(minY, i);
2178
- maxY = Math.max(maxY, i);
2179
- }
2180
- }
2181
- this.minY = -(minY * this.optHeight);
2182
- this.maxY = -(maxY * this.optHeight);
2183
- }
2184
- onMove(detail) {
2185
- if (detail.event.cancelable) {
2186
- detail.event.preventDefault();
2187
- }
2188
- detail.event.stopPropagation();
2189
- // update the scroll position relative to pointer start position
2190
- let y = this.y + detail.deltaY;
2191
- if (y > this.minY) {
2192
- // scrolling up higher than scroll area
2193
- y = Math.pow(y, 0.8);
2194
- this.bounceFrom = y;
2195
- }
2196
- else if (y < this.maxY) {
2197
- // scrolling down below scroll area
2198
- y += Math.pow(this.maxY - y, 0.9);
2199
- this.bounceFrom = y;
2200
2093
  }
2201
- else {
2202
- this.bounceFrom = 0;
2203
- }
2204
- this.update(y, 0, false);
2205
- }
2206
- onEnd(detail) {
2207
- if (this.bounceFrom > 0) {
2208
- // bounce back up
2209
- this.update(this.minY, 100, true);
2210
- this.emitColChange();
2211
- return;
2212
- }
2213
- else if (this.bounceFrom < 0) {
2214
- // bounce back down
2215
- this.update(this.maxY, 100, true);
2216
- this.emitColChange();
2217
- return;
2218
- }
2219
- this.velocity = clamp(-MAX_PICKER_SPEED, detail.velocityY * 23, MAX_PICKER_SPEED);
2220
- if (this.velocity === 0 && detail.deltaY === 0) {
2221
- const opt = detail.event.target.closest('.picker-opt');
2222
- if (opt === null || opt === void 0 ? void 0 : opt.hasAttribute('opt-index')) {
2223
- this.setSelected(parseInt(opt.getAttribute('opt-index'), 10), TRANSITION_DURATION);
2224
- }
2094
+ update(y, duration, saveY) {
2095
+ if (!this.optsEl) {
2096
+ return;
2097
+ }
2098
+ // ensure we've got a good round number :)
2099
+ let translateY = 0;
2100
+ let translateZ = 0;
2101
+ const { col, rotateFactor } = this;
2102
+ const prevSelected = col.selectedIndex;
2103
+ const selectedIndex = (col.selectedIndex = this.indexForY(-y));
2104
+ const durationStr = duration === 0 ? '' : duration + 'ms';
2105
+ const scaleStr = `scale(${this.scaleFactor})`;
2106
+ const children = this.optsEl.children;
2107
+ for (let i = 0; i < children.length; i++) {
2108
+ const button = children[i];
2109
+ const opt = col.options[i];
2110
+ const optOffset = i * this.optHeight + y;
2111
+ let transform = '';
2112
+ if (rotateFactor !== 0) {
2113
+ const rotateX = optOffset * rotateFactor;
2114
+ if (Math.abs(rotateX) <= 90) {
2115
+ translateY = 0;
2116
+ translateZ = 90;
2117
+ transform = `rotateX(${rotateX}deg) `;
2118
+ }
2119
+ else {
2120
+ translateY = -9999;
2121
+ }
2122
+ }
2123
+ else {
2124
+ translateZ = 0;
2125
+ translateY = optOffset;
2126
+ }
2127
+ const selected = selectedIndex === i;
2128
+ transform += `translate3d(0px,${translateY}px,${translateZ}px) `;
2129
+ if (this.scaleFactor !== 1 && !selected) {
2130
+ transform += scaleStr;
2131
+ }
2132
+ // Update transition duration
2133
+ if (this.noAnimate) {
2134
+ opt.duration = 0;
2135
+ button.style.transitionDuration = '';
2136
+ }
2137
+ else if (duration !== opt.duration) {
2138
+ opt.duration = duration;
2139
+ button.style.transitionDuration = durationStr;
2140
+ }
2141
+ // Update transform
2142
+ if (transform !== opt.transform) {
2143
+ opt.transform = transform;
2144
+ }
2145
+ button.style.transform = transform;
2146
+ /**
2147
+ * Ensure that the select column
2148
+ * item has the selected class
2149
+ */
2150
+ opt.selected = selected;
2151
+ if (selected) {
2152
+ button.classList.add(PICKER_OPT_SELECTED);
2153
+ }
2154
+ else {
2155
+ button.classList.remove(PICKER_OPT_SELECTED);
2156
+ }
2157
+ }
2158
+ this.col.prevSelected = prevSelected;
2159
+ if (saveY) {
2160
+ this.y = y;
2161
+ }
2162
+ if (this.lastIndex !== selectedIndex) {
2163
+ // have not set a last index yet
2164
+ hapticSelectionChanged();
2165
+ this.lastIndex = selectedIndex;
2166
+ }
2225
2167
  }
2226
- else {
2227
- this.y += detail.deltaY;
2228
- if (Math.abs(detail.velocityY) < 0.05) {
2229
- const isScrollingUp = detail.deltaY > 0;
2230
- const optHeightFraction = (Math.abs(this.y) % this.optHeight) / this.optHeight;
2231
- if (isScrollingUp && optHeightFraction > 0.5) {
2232
- this.velocity = Math.abs(this.velocity) * -1;
2168
+ decelerate() {
2169
+ if (this.velocity !== 0) {
2170
+ // still decelerating
2171
+ this.velocity *= DECELERATION_FRICTION;
2172
+ // do not let it go slower than a velocity of 1
2173
+ this.velocity = this.velocity > 0 ? Math.max(this.velocity, 1) : Math.min(this.velocity, -1);
2174
+ let y = this.y + this.velocity;
2175
+ if (y > this.minY) {
2176
+ // whoops, it's trying to scroll up farther than the options we have!
2177
+ y = this.minY;
2178
+ this.velocity = 0;
2179
+ }
2180
+ else if (y < this.maxY) {
2181
+ // gahh, it's trying to scroll down farther than we can!
2182
+ y = this.maxY;
2183
+ this.velocity = 0;
2184
+ }
2185
+ this.update(y, 0, true);
2186
+ const notLockedIn = Math.round(y) % this.optHeight !== 0 || Math.abs(this.velocity) > 1;
2187
+ if (notLockedIn) {
2188
+ // isn't locked in yet, keep decelerating until it is
2189
+ this.rafId = requestAnimationFrame(() => this.decelerate());
2190
+ }
2191
+ else {
2192
+ this.velocity = 0;
2193
+ this.emitColChange();
2194
+ hapticSelectionEnd();
2195
+ }
2233
2196
  }
2234
- else if (!isScrollingUp && optHeightFraction <= 0.5) {
2235
- this.velocity = Math.abs(this.velocity);
2197
+ else if (this.y % this.optHeight !== 0) {
2198
+ // needs to still get locked into a position so options line up
2199
+ const currentPos = Math.abs(this.y % this.optHeight);
2200
+ // create a velocity in the direction it needs to scroll
2201
+ this.velocity = currentPos > this.optHeight / 2 ? 1 : -1;
2202
+ this.decelerate();
2236
2203
  }
2237
- }
2238
- this.decelerate();
2239
- }
2240
- }
2241
- refresh(forceRefresh, animated) {
2242
- var _a;
2243
- let min = this.col.options.length - 1;
2244
- let max = 0;
2245
- const options = this.col.options;
2246
- for (let i = 0; i < options.length; i++) {
2247
- if (!options[i].disabled) {
2248
- min = Math.min(min, i);
2249
- max = Math.max(max, i);
2250
- }
2251
2204
  }
2252
- /**
2253
- * Only update selected value if column has a
2254
- * velocity of 0. If it does not, then the
2255
- * column is animating might land on
2256
- * a value different than the value at
2257
- * selectedIndex
2258
- */
2259
- if (this.velocity !== 0) {
2260
- return;
2261
- }
2262
- const selectedIndex = clamp(min, (_a = this.col.selectedIndex) !== null && _a !== void 0 ? _a : 0, max);
2263
- if (this.col.prevSelected !== selectedIndex || forceRefresh) {
2264
- const y = selectedIndex * this.optHeight * -1;
2265
- const duration = animated ? TRANSITION_DURATION : 0;
2266
- this.velocity = 0;
2267
- this.update(y, duration, true);
2268
- }
2269
- }
2270
- onDomChange(forceRefresh, animated) {
2271
- const colEl = this.optsEl;
2272
- if (colEl) {
2273
- // DOM READ
2274
- // We perfom a DOM read over a rendered item, this needs to happen after the first render or after the the column has changed
2275
- this.optHeight = colEl.firstElementChild ? colEl.firstElementChild.clientHeight : 0;
2276
- }
2277
- this.refresh(forceRefresh, animated);
2278
- }
2279
- render() {
2280
- const col = this.col;
2281
- const mode = getIonMode(this);
2282
- return (h(Host, { class: Object.assign({ [mode]: true, 'picker-col': true, 'picker-opts-left': this.col.align === 'left', 'picker-opts-right': this.col.align === 'right' }, getClassMap(col.cssClass)), style: {
2283
- 'max-width': this.col.columnWidth,
2284
- } }, col.prefix && (h("div", { class: "picker-prefix", style: { width: col.prefixWidth } }, col.prefix)), h("div", { class: "picker-opts", style: { maxWidth: col.optionsWidth }, ref: (el) => (this.optsEl = el) }, col.options.map((o, index) => (h("button", { "aria-label": o.ariaLabel, class: { 'picker-opt': true, 'picker-opt-disabled': !!o.disabled }, "opt-index": index }, o.text)))), col.suffix && (h("div", { class: "picker-suffix", style: { width: col.suffixWidth } }, col.suffix))));
2285
- }
2286
- get el() { return getElement(this); }
2287
- static get watchers() { return {
2288
- "col": ["colChanged"]
2289
- }; }
2205
+ indexForY(y) {
2206
+ return Math.min(Math.max(Math.abs(Math.round(y / this.optHeight)), 0), this.col.options.length - 1);
2207
+ }
2208
+ onStart(detail) {
2209
+ // We have to prevent default in order to block scrolling under the picker
2210
+ // but we DO NOT have to stop propagation, since we still want
2211
+ // some "click" events to capture
2212
+ if (detail.event.cancelable) {
2213
+ detail.event.preventDefault();
2214
+ }
2215
+ detail.event.stopPropagation();
2216
+ hapticSelectionStart();
2217
+ // reset everything
2218
+ if (this.rafId !== undefined)
2219
+ cancelAnimationFrame(this.rafId);
2220
+ const options = this.col.options;
2221
+ let minY = options.length - 1;
2222
+ let maxY = 0;
2223
+ for (let i = 0; i < options.length; i++) {
2224
+ if (!options[i].disabled) {
2225
+ minY = Math.min(minY, i);
2226
+ maxY = Math.max(maxY, i);
2227
+ }
2228
+ }
2229
+ this.minY = -(minY * this.optHeight);
2230
+ this.maxY = -(maxY * this.optHeight);
2231
+ }
2232
+ onMove(detail) {
2233
+ if (detail.event.cancelable) {
2234
+ detail.event.preventDefault();
2235
+ }
2236
+ detail.event.stopPropagation();
2237
+ // update the scroll position relative to pointer start position
2238
+ let y = this.y + detail.deltaY;
2239
+ if (y > this.minY) {
2240
+ // scrolling up higher than scroll area
2241
+ y = Math.pow(y, 0.8);
2242
+ this.bounceFrom = y;
2243
+ }
2244
+ else if (y < this.maxY) {
2245
+ // scrolling down below scroll area
2246
+ y += Math.pow(this.maxY - y, 0.9);
2247
+ this.bounceFrom = y;
2248
+ }
2249
+ else {
2250
+ this.bounceFrom = 0;
2251
+ }
2252
+ this.update(y, 0, false);
2253
+ }
2254
+ onEnd(detail) {
2255
+ if (this.bounceFrom > 0) {
2256
+ // bounce back up
2257
+ this.update(this.minY, 100, true);
2258
+ this.emitColChange();
2259
+ return;
2260
+ }
2261
+ else if (this.bounceFrom < 0) {
2262
+ // bounce back down
2263
+ this.update(this.maxY, 100, true);
2264
+ this.emitColChange();
2265
+ return;
2266
+ }
2267
+ this.velocity = clamp(-MAX_PICKER_SPEED, detail.velocityY * 23, MAX_PICKER_SPEED);
2268
+ if (this.velocity === 0 && detail.deltaY === 0) {
2269
+ const opt = detail.event.target.closest('.picker-opt');
2270
+ if (opt === null || opt === void 0 ? void 0 : opt.hasAttribute('opt-index')) {
2271
+ this.setSelected(parseInt(opt.getAttribute('opt-index'), 10), TRANSITION_DURATION);
2272
+ }
2273
+ }
2274
+ else {
2275
+ this.y += detail.deltaY;
2276
+ if (Math.abs(detail.velocityY) < 0.05) {
2277
+ const isScrollingUp = detail.deltaY > 0;
2278
+ const optHeightFraction = (Math.abs(this.y) % this.optHeight) / this.optHeight;
2279
+ if (isScrollingUp && optHeightFraction > 0.5) {
2280
+ this.velocity = Math.abs(this.velocity) * -1;
2281
+ }
2282
+ else if (!isScrollingUp && optHeightFraction <= 0.5) {
2283
+ this.velocity = Math.abs(this.velocity);
2284
+ }
2285
+ }
2286
+ this.decelerate();
2287
+ }
2288
+ }
2289
+ refresh(forceRefresh, animated) {
2290
+ var _a;
2291
+ let min = this.col.options.length - 1;
2292
+ let max = 0;
2293
+ const options = this.col.options;
2294
+ for (let i = 0; i < options.length; i++) {
2295
+ if (!options[i].disabled) {
2296
+ min = Math.min(min, i);
2297
+ max = Math.max(max, i);
2298
+ }
2299
+ }
2300
+ /**
2301
+ * Only update selected value if column has a
2302
+ * velocity of 0. If it does not, then the
2303
+ * column is animating might land on
2304
+ * a value different than the value at
2305
+ * selectedIndex
2306
+ */
2307
+ if (this.velocity !== 0) {
2308
+ return;
2309
+ }
2310
+ const selectedIndex = clamp(min, (_a = this.col.selectedIndex) !== null && _a !== void 0 ? _a : 0, max);
2311
+ if (this.col.prevSelected !== selectedIndex || forceRefresh) {
2312
+ const y = selectedIndex * this.optHeight * -1;
2313
+ const duration = animated ? TRANSITION_DURATION : 0;
2314
+ this.velocity = 0;
2315
+ this.update(y, duration, true);
2316
+ }
2317
+ }
2318
+ onDomChange(forceRefresh, animated) {
2319
+ const colEl = this.optsEl;
2320
+ if (colEl) {
2321
+ // DOM READ
2322
+ // We perfom a DOM read over a rendered item, this needs to happen after the first render or after the the column has changed
2323
+ this.optHeight = colEl.firstElementChild ? colEl.firstElementChild.clientHeight : 0;
2324
+ }
2325
+ this.refresh(forceRefresh, animated);
2326
+ }
2327
+ render() {
2328
+ const col = this.col;
2329
+ const mode = getIonMode(this);
2330
+ return (h(Host, { class: Object.assign({ [mode]: true, 'picker-col': true, 'picker-opts-left': this.col.align === 'left', 'picker-opts-right': this.col.align === 'right' }, getClassMap(col.cssClass)), style: {
2331
+ 'max-width': this.col.columnWidth,
2332
+ } }, col.prefix && (h("div", { class: "picker-prefix", style: { width: col.prefixWidth } }, col.prefix)), h("div", { class: "picker-opts", style: { maxWidth: col.optionsWidth }, ref: (el) => (this.optsEl = el) }, col.options.map((o, index) => (h("button", { "aria-label": o.ariaLabel, class: { 'picker-opt': true, 'picker-opt-disabled': !!o.disabled }, "opt-index": index }, o.text)))), col.suffix && (h("div", { class: "picker-suffix", style: { width: col.suffixWidth } }, col.suffix))));
2333
+ }
2334
+ get el() { return getElement(this); }
2335
+ static get watchers() { return {
2336
+ "col": ["colChanged"]
2337
+ }; }
2290
2338
  };
2291
2339
  const PICKER_OPT_SELECTED = 'picker-opt-selected';
2292
2340
  const DECELERATION_FRICTION = 0.97;
2293
2341
  const MAX_PICKER_SPEED = 90;
2294
2342
  const TRANSITION_DURATION = 150;
2295
2343
  PickerColumnCmp.style = {
2296
- ios: pickerColumnIosCss,
2297
- md: pickerColumnMdCss
2344
+ ios: pickerColumnIosCss,
2345
+ md: pickerColumnMdCss
2298
2346
  };
2299
2347
 
2300
2348
  export { Datetime as ion_datetime, Picker as ion_picker, PickerColumnCmp as ion_picker_column };