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