@ionic/core 8.8.6-dev.11777572994.1147595d → 8.8.6-dev.11777668103.132817bd

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 (1110) hide show
  1. package/components/index.js +1 -1
  2. package/components/ion-accordion-group.js +1 -1
  3. package/components/ion-accordion.js +1 -1
  4. package/components/ion-action-sheet.js +1 -1
  5. package/components/ion-alert.js +1 -1
  6. package/components/ion-app.js +1 -1
  7. package/components/ion-avatar.js +1 -1
  8. package/components/ion-back-button.js +1 -1
  9. package/components/ion-backdrop.js +1 -1
  10. package/components/ion-badge.js +1 -1
  11. package/components/ion-breadcrumb.js +1 -1
  12. package/components/ion-breadcrumbs.js +1 -1
  13. package/components/ion-button.js +1 -1
  14. package/components/ion-buttons.js +1 -1
  15. package/components/ion-card-content.js +1 -1
  16. package/components/ion-card-header.js +1 -1
  17. package/components/ion-card-subtitle.js +1 -1
  18. package/components/ion-card-title.js +1 -1
  19. package/components/ion-card.js +1 -1
  20. package/components/ion-checkbox.js +1 -1
  21. package/components/ion-chip.js +1 -1
  22. package/components/ion-col.js +1 -1
  23. package/components/ion-content.js +1 -1
  24. package/components/ion-datetime-button.js +1 -1
  25. package/components/ion-datetime.js +1 -1
  26. package/components/ion-divider.d.ts +11 -0
  27. package/components/ion-divider.js +4 -0
  28. package/components/ion-fab-button.js +1 -1
  29. package/components/ion-fab-list.js +1 -1
  30. package/components/ion-fab.js +1 -1
  31. package/components/ion-footer.js +1 -1
  32. package/components/ion-gallery.d.ts +11 -0
  33. package/components/ion-gallery.js +4 -0
  34. package/components/ion-grid.js +1 -1
  35. package/components/ion-header.js +1 -1
  36. package/components/ion-icon.js +1 -1
  37. package/components/ion-img.js +1 -1
  38. package/components/ion-infinite-scroll-content.js +1 -1
  39. package/components/ion-infinite-scroll.js +1 -1
  40. package/components/ion-input-otp.js +1 -1
  41. package/components/ion-input-password-toggle.js +1 -1
  42. package/components/ion-input.js +1 -1
  43. package/components/ion-item-divider.js +1 -1
  44. package/components/ion-item-group.js +1 -1
  45. package/components/ion-item-option.js +1 -1
  46. package/components/ion-item-options.js +1 -1
  47. package/components/ion-item-sliding.js +1 -1
  48. package/components/ion-item.js +1 -1
  49. package/components/ion-label.js +1 -1
  50. package/components/ion-list-header.js +1 -1
  51. package/components/ion-list.js +1 -1
  52. package/components/ion-loading.js +1 -1
  53. package/components/ion-menu-button.js +1 -1
  54. package/components/ion-menu-toggle.js +1 -1
  55. package/components/ion-menu.js +1 -1
  56. package/components/ion-modal.js +1 -1
  57. package/components/ion-nav-link.js +1 -1
  58. package/components/ion-nav.js +1 -1
  59. package/components/ion-note.js +1 -1
  60. package/components/ion-picker-column-option.js +1 -1
  61. package/components/ion-picker-column.js +1 -1
  62. package/components/ion-picker-legacy-column.d.ts +11 -0
  63. package/components/ion-picker-legacy-column.js +4 -0
  64. package/components/ion-picker-legacy.d.ts +11 -0
  65. package/components/ion-picker-legacy.js +4 -0
  66. package/components/ion-picker.js +1 -1
  67. package/components/ion-popover.js +1 -1
  68. package/components/ion-progress-bar.js +1 -1
  69. package/components/ion-radio-group.js +1 -1
  70. package/components/ion-radio.js +1 -1
  71. package/components/ion-range.js +1 -1
  72. package/components/ion-refresher-content.js +1 -1
  73. package/components/ion-refresher.js +1 -1
  74. package/components/ion-reorder-group.js +1 -1
  75. package/components/ion-reorder.js +1 -1
  76. package/components/ion-ripple-effect.js +1 -1
  77. package/components/ion-route-redirect.js +1 -1
  78. package/components/ion-route.js +1 -1
  79. package/components/ion-router-link.js +1 -1
  80. package/components/ion-router-outlet.js +1 -1
  81. package/components/ion-router.js +1 -1
  82. package/components/ion-row.js +1 -1
  83. package/components/ion-searchbar.js +1 -1
  84. package/components/ion-segment-button.js +1 -1
  85. package/components/ion-segment-content.js +1 -1
  86. package/components/ion-segment-view.js +1 -1
  87. package/components/ion-segment.js +1 -1
  88. package/components/ion-select-modal.js +1 -1
  89. package/components/ion-select-option.js +1 -1
  90. package/components/ion-select-popover.js +1 -1
  91. package/components/ion-select.js +1 -1
  92. package/components/ion-skeleton-text.js +1 -1
  93. package/components/ion-spinner.js +1 -1
  94. package/components/ion-split-pane.js +1 -1
  95. package/components/ion-tab-bar.js +1 -1
  96. package/components/ion-tab-button.js +1 -1
  97. package/components/ion-tab.js +1 -1
  98. package/components/ion-tabs.js +1 -1
  99. package/components/ion-text.js +1 -1
  100. package/components/ion-textarea.js +1 -1
  101. package/components/ion-thumbnail.js +1 -1
  102. package/components/ion-title.js +1 -1
  103. package/components/ion-toast.js +1 -1
  104. package/components/ion-toggle.js +1 -1
  105. package/components/ion-toolbar.js +1 -1
  106. package/components/p-0sa2JgYA.js +4 -0
  107. package/components/p-3Ni1Z654.js +4 -0
  108. package/{dist/ionic/p-D13Eaw-8.js → components/p-9gxM3tAr.js} +1 -1
  109. package/components/p-B2rpt1JV.js +4 -0
  110. package/components/{p-ak_d-z48.js → p-B636tzQ7.js} +1 -1
  111. package/components/p-B6zr9RZN.js +4 -0
  112. package/components/p-B71c6yUH.js +4 -0
  113. package/components/p-B8Oa6a_k.js +4 -0
  114. package/components/p-BCDEEm9n.js +4 -0
  115. package/components/p-BCFZKMI6.js +4 -0
  116. package/components/p-BDndEqui.js +4 -0
  117. package/components/p-BDqjX7Z_.js +4 -0
  118. package/components/p-BErKjY03.js +4 -0
  119. package/components/p-BFCM_1oE.js +4 -0
  120. package/components/p-BFbsici0.js +4 -0
  121. package/components/p-BLCuPAtN.js +4 -0
  122. package/components/{p-cyNmxje6.js → p-BLysWQA1.js} +1 -1
  123. package/components/p-BO4aickU.js +4 -0
  124. package/components/p-BRWWcnBq.js +4 -0
  125. package/components/p-BXcCGjEc.js +4 -0
  126. package/components/p-BYSs-jZz.js +4 -0
  127. package/components/p-BaPtaYEC.js +4 -0
  128. package/components/p-BbQGmZyu.js +4 -0
  129. package/components/p-BcbmT6b3.js +4 -0
  130. package/components/p-BeVlsaLA.js +4 -0
  131. package/components/p-BjW8SOqw.js +4 -0
  132. package/components/p-Bp__mr16.js +4 -0
  133. package/components/p-BqDiJgC_.js +4 -0
  134. package/components/p-BqImG3uk.js +4 -0
  135. package/components/p-BwKpO3Is.js +4 -0
  136. package/components/p-C00Y_WJv.js +4 -0
  137. package/components/p-C0U8YqYW.js +4 -0
  138. package/components/p-C8ktKu9j.js +4 -0
  139. package/components/p-CIoAIKEr.js +4 -0
  140. package/components/p-CKfNwyAb.js +4 -0
  141. package/components/p-CN-WzkJE.js +4 -0
  142. package/components/p-CVBkx7m1.js +4 -0
  143. package/components/p-Cb9imMZh.js +4 -0
  144. package/components/p-Cf9-xP7P.js +4 -0
  145. package/components/{p-Cwv-vmkN.js → p-CjSx8W-k.js} +1 -1
  146. package/components/p-Cmql_g3_.js +4 -0
  147. package/components/p-CoFqDNc5.js +4 -0
  148. package/components/p-CtiqM786.js +4 -0
  149. package/components/p-D1t981Ih.js +4 -0
  150. package/components/p-DAv9P_LE.js +4 -0
  151. package/components/p-DDw-NYxz.js +4 -0
  152. package/components/p-DH_9VCbD.js +4 -0
  153. package/components/p-DTtRWhIZ.js +4 -0
  154. package/components/p-DVcs-2q3.js +4 -0
  155. package/components/p-DXUyXgVL.js +4 -0
  156. package/components/p-DaJxRxSQ.js +4 -0
  157. package/components/p-Dhi5xtNS.js +4 -0
  158. package/components/p-Di5rHO3q.js +4 -0
  159. package/components/p-IMXp2Inn.js +4 -0
  160. package/components/p-TR4ubkPu.js +4 -0
  161. package/components/p-XegQjlzJ.js +4 -0
  162. package/components/p-fIOYmaqA.js +4 -0
  163. package/components/p-lIOqnNXn.js +4 -0
  164. package/{dist/ionic/p-BvFYtOdE.js → components/p-oF-CwZ0b.js} +1 -1
  165. package/components/p-sK-FK9CT.js +4 -0
  166. package/components/p-t98_NeNv.js +4 -0
  167. package/components/p-vCpF32Z7.js +4 -0
  168. package/components/p-vXpMhGrs.js +4 -0
  169. package/components/p-wCDzv5Q8.js +4 -0
  170. package/components/{p-YLXPWgVj.js → p-zWP0sUV_.js} +1 -1
  171. package/css/core.css +1 -1
  172. package/css/core.css.map +1 -1
  173. package/css/display.css +1 -1
  174. package/css/display.css.map +1 -1
  175. package/css/flex-utils.css +1 -1
  176. package/css/flex-utils.css.map +1 -1
  177. package/css/float-elements.css.map +1 -1
  178. package/css/global.bundle.css.map +1 -1
  179. package/css/ionic/bundle.ionic.css +1 -0
  180. package/css/ionic/bundle.ionic.css.map +1 -0
  181. package/css/ionic/core.ionic.css +1 -0
  182. package/css/ionic/core.ionic.css.map +1 -0
  183. package/css/ionic/global.bundle.ionic.css +1 -0
  184. package/css/ionic/global.bundle.ionic.css.map +1 -0
  185. package/css/ionic/ionic-swiper.ionic.css +1 -0
  186. package/css/ionic/ionic-swiper.ionic.css.map +1 -0
  187. package/css/ionic/link.ionic.css +1 -0
  188. package/css/ionic/link.ionic.css.map +1 -0
  189. package/css/ionic/structure.ionic.css +1 -0
  190. package/css/ionic/structure.ionic.css.map +1 -0
  191. package/css/ionic/typography.ionic.css +1 -0
  192. package/css/ionic/typography.ionic.css.map +1 -0
  193. package/css/ionic/utils.bundle.ionic.css +1 -0
  194. package/css/ionic/utils.bundle.ionic.css.map +1 -0
  195. package/css/ionic-swiper.css +1 -1
  196. package/css/ionic-swiper.css.map +1 -1
  197. package/css/ionic.bundle.css +1 -1
  198. package/css/ionic.bundle.css.map +1 -1
  199. package/css/normalize.css.map +1 -1
  200. package/css/padding.css.map +1 -1
  201. package/css/palettes/dark.always.css.map +1 -1
  202. package/css/palettes/dark.class.css.map +1 -1
  203. package/css/palettes/dark.system.css.map +1 -1
  204. package/css/palettes/high-contrast-dark.always.css.map +1 -1
  205. package/css/palettes/high-contrast-dark.class.css.map +1 -1
  206. package/css/palettes/high-contrast-dark.system.css.map +1 -1
  207. package/css/palettes/high-contrast.always.css.map +1 -1
  208. package/css/palettes/high-contrast.class.css.map +1 -1
  209. package/css/palettes/high-contrast.system.css.map +1 -1
  210. package/css/structure.css.map +1 -1
  211. package/css/text-alignment.css.map +1 -1
  212. package/css/text-transformation.css.map +1 -1
  213. package/css/typography.css.map +1 -1
  214. package/css/utils.bundle.css +1 -1
  215. package/css/utils.bundle.css.map +1 -1
  216. package/dist/cjs/{animation-Dg4yiuR2.js → animation-DknMeJ3x.js} +3 -3
  217. package/dist/cjs/{app-globals-CLI8xCmk.js → app-globals-DtAeky3x.js} +1 -1
  218. package/dist/cjs/{button-active-FscMI17-.js → button-active-JoIWyYri.js} +2 -2
  219. package/dist/cjs/{capacitor-DmA66EwP.js → capacitor-BnRBm_ys.js} +3 -3
  220. package/dist/cjs/caret-down-vtVgfXIs.js +8 -0
  221. package/dist/cjs/caret-left-CxZXLRv5.js +8 -0
  222. package/dist/cjs/caret-right-CRCgv98E.js +8 -0
  223. package/dist/cjs/config-DWdFbSNK.js +35 -0
  224. package/dist/cjs/{data-BYlBjkMU.js → data-DuOuKG7I.js} +6 -6
  225. package/dist/cjs/{focus-visible-CCvKiLh3.js → focus-visible-BIj-I3-C.js} +24 -0
  226. package/dist/cjs/{framework-delegate-CRgp8o_p.js → framework-delegate-Dx9FrqAC.js} +4 -2
  227. package/dist/cjs/{haptic-ClPPQ_PS.js → haptic-D3Ay9mmg.js} +1 -1
  228. package/dist/cjs/{helpers-CxTYJdbT.js → helpers-DJYxKN5U.js} +57 -4
  229. package/dist/cjs/{config-BukYi_pW.js → index-BJlwOs11.js} +1 -31
  230. package/dist/cjs/{index-MbaBbWXk.js → index-BJrpF9T3.js} +2 -2
  231. package/dist/cjs/{index-CFUwM5x_.js → index-Cer2Qy4I.js} +15 -15
  232. package/dist/cjs/{index-DqmRDbxg.js → index-CgAbCW6L.js} +2 -0
  233. package/dist/cjs/{index-CqT-2gKy.js → index-CzcLEdQ5.js} +41 -4
  234. package/dist/cjs/{index-YcSftOMz.js → index-DMJjUhXH.js} +9 -8
  235. package/dist/cjs/{index-C845Ti6K.js → index-D_mPAIqF.js} +4 -4
  236. package/dist/cjs/index.cjs.js +17 -16
  237. package/dist/cjs/{input-shims-Dl5cnc_e.js → input-shims-Dn33gFln.js} +18 -17
  238. package/dist/cjs/{input.utils-DmeJ8dmo.js → input.utils-DnVnhWEF.js} +5 -5
  239. package/dist/cjs/ion-accordion_2.cjs.entry.js +61 -29
  240. package/dist/cjs/ion-action-sheet.cjs.entry.js +41 -26
  241. package/dist/cjs/ion-alert.cjs.entry.js +62 -45
  242. package/dist/cjs/ion-app_8.cjs.entry.js +296 -175
  243. package/dist/cjs/ion-avatar_3.cjs.entry.js +125 -13
  244. package/dist/cjs/ion-back-button.cjs.entry.js +31 -22
  245. package/dist/cjs/ion-backdrop.cjs.entry.js +10 -7
  246. package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +54 -18
  247. package/dist/cjs/ion-button_2.cjs.entry.js +59 -22
  248. package/dist/cjs/ion-card_5.cjs.entry.js +55 -33
  249. package/dist/cjs/ion-checkbox.cjs.entry.js +34 -16
  250. package/dist/cjs/ion-chip.cjs.entry.js +50 -9
  251. package/dist/cjs/ion-col_3.cjs.entry.js +56 -57
  252. package/dist/cjs/ion-datetime-button.cjs.entry.js +13 -9
  253. package/dist/cjs/{ion-datetime.cjs.entry.js → ion-datetime_3.cjs.entry.js} +742 -29
  254. package/dist/cjs/ion-divider.cjs.entry.js +51 -0
  255. package/dist/cjs/ion-fab_3.cjs.entry.js +44 -28
  256. package/dist/cjs/ion-gallery.cjs.entry.js +348 -0
  257. package/dist/cjs/ion-img.cjs.entry.js +8 -4
  258. package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +93 -17
  259. package/dist/cjs/ion-input-otp.cjs.entry.js +74 -9
  260. package/dist/cjs/ion-input-password-toggle.cjs.entry.js +53 -15
  261. package/dist/cjs/ion-input.cjs.entry.js +124 -34
  262. package/dist/cjs/ion-item-option_3.cjs.entry.js +186 -21
  263. package/dist/cjs/ion-item_8.cjs.entry.js +116 -49
  264. package/dist/cjs/ion-loading.cjs.entry.js +22 -23
  265. package/dist/cjs/ion-menu_3.cjs.entry.js +47 -29
  266. package/dist/cjs/ion-modal.cjs.entry.js +262 -142
  267. package/dist/cjs/ion-nav_2.cjs.entry.js +14 -11
  268. package/dist/cjs/ion-picker-column-option.cjs.entry.js +12 -8
  269. package/dist/cjs/ion-picker-column.cjs.entry.js +14 -14
  270. package/dist/cjs/ion-picker.cjs.entry.js +10 -6
  271. package/dist/cjs/ion-popover.cjs.entry.js +21 -23
  272. package/dist/cjs/ion-progress-bar.cjs.entry.js +27 -9
  273. package/dist/cjs/ion-radio_2.cjs.entry.js +35 -17
  274. package/dist/cjs/ion-range.cjs.entry.js +20 -13
  275. package/dist/cjs/ion-refresher_2.cjs.entry.js +42 -23
  276. package/dist/cjs/ion-reorder_2.cjs.entry.js +38 -14
  277. package/dist/cjs/ion-ripple-effect.cjs.entry.js +15 -7
  278. package/dist/cjs/ion-route_4.cjs.entry.js +10 -9
  279. package/dist/cjs/ion-searchbar.cjs.entry.js +137 -24
  280. package/dist/cjs/ion-segment-content.cjs.entry.js +2 -2
  281. package/dist/cjs/ion-segment-view.cjs.entry.js +6 -3
  282. package/dist/cjs/ion-segment_2.cjs.entry.js +23 -16
  283. package/dist/cjs/ion-select-modal.cjs.entry.js +97 -40
  284. package/dist/cjs/ion-select_3.cjs.entry.js +453 -84
  285. package/dist/cjs/ion-spinner.cjs.entry.js +30 -8
  286. package/dist/cjs/ion-split-pane.cjs.entry.js +13 -9
  287. package/dist/cjs/ion-tab-bar_2.cjs.entry.js +147 -23
  288. package/dist/cjs/ion-tab_2.cjs.entry.js +8 -7
  289. package/dist/cjs/ion-text.cjs.entry.js +7 -7
  290. package/dist/cjs/ion-textarea.cjs.entry.js +137 -23
  291. package/dist/cjs/ion-toast.cjs.entry.js +70 -46
  292. package/dist/cjs/ion-toggle.cjs.entry.js +82 -25
  293. package/dist/cjs/ionic-global-CSEbHD_F.js +519 -0
  294. package/dist/cjs/ionic.cjs.js +4 -4
  295. package/dist/cjs/{ios.transition-trBiC95R.js → ios.transition-UCjoxA3D.js} +7 -5
  296. package/dist/cjs/{keyboard-hHzlEQpk.js → keyboard-Bhav6x-R.js} +4 -3
  297. package/dist/cjs/{keyboard-UuAS4D_9.js → keyboard-Dsczf-iT.js} +1 -1
  298. package/dist/cjs/{keyboard-controller-GXBiBRKS.js → keyboard-controller-tqGDP9SU.js} +11 -9
  299. package/dist/cjs/list-a-7GSA6K.js +8 -0
  300. package/dist/cjs/loader.cjs.js +4 -4
  301. package/dist/cjs/{md.transition-CUQECuvD.js → md.transition-CNwlchQn.js} +6 -5
  302. package/dist/cjs/{notch-controller-sD-lTpdc.js → notch-controller-CgtkBzy0.js} +4 -4
  303. package/dist/cjs/{overlays-DIfHxkst.js → overlays-Hci_7vw_.js} +117 -42
  304. package/dist/cjs/select-option-render-C7klBX2H.js +81 -0
  305. package/dist/cjs/{status-tap-CCJk5VgT.js → status-tap-CTY2dMsZ.js} +4 -3
  306. package/dist/cjs/{swipe-back-BGhTQ1CU.js → swipe-back-jJFi5KCB.js} +3 -2
  307. package/dist/cjs/{theme-CeDs6Hcv.js → theme-IlOsGAz7.js} +25 -1
  308. package/dist/cjs/validity-QmuwEptc.js +51 -0
  309. package/dist/cjs/x-BTF99yFH.js +8 -0
  310. package/dist/collection/collection-manifest.json +12 -1
  311. package/dist/collection/components/accordion/accordion.ionic.css +201 -0
  312. package/dist/collection/components/accordion/accordion.ios.css +73 -58
  313. package/dist/collection/components/accordion/accordion.js +41 -27
  314. package/dist/collection/components/accordion/accordion.md.css +67 -59
  315. package/dist/collection/components/accordion-group/accordion-group.ionic.css +93 -0
  316. package/dist/collection/components/accordion-group/accordion-group.ios.css +16 -4
  317. package/dist/collection/components/accordion-group/accordion-group.js +44 -8
  318. package/dist/collection/components/accordion-group/accordion-group.md.css +22 -4
  319. package/dist/collection/components/action-sheet/action-sheet.ionic.css +834 -0
  320. package/dist/collection/components/action-sheet/action-sheet.ios.css +102 -6
  321. package/dist/collection/components/action-sheet/action-sheet.js +33 -18
  322. package/dist/collection/components/action-sheet/action-sheet.md.css +101 -5
  323. package/dist/collection/components/alert/alert.ionic.css +1165 -0
  324. package/dist/collection/components/alert/alert.ios.css +102 -1
  325. package/dist/collection/components/alert/alert.js +52 -35
  326. package/dist/collection/components/alert/alert.md.css +102 -1
  327. package/dist/collection/components/app/app.js +15 -83
  328. package/dist/collection/components/avatar/avatar.ionic.css +391 -0
  329. package/dist/collection/components/avatar/avatar.ios.css +7 -33
  330. package/dist/collection/components/avatar/avatar.js +120 -4
  331. package/dist/collection/components/avatar/avatar.md.css +51 -0
  332. package/dist/collection/components/back-button/back-button.ios.css +60 -48
  333. package/dist/collection/components/back-button/back-button.js +27 -19
  334. package/dist/collection/components/back-button/back-button.md.css +60 -48
  335. package/dist/collection/components/backdrop/backdrop.ionic.css +109 -0
  336. package/dist/collection/components/backdrop/backdrop.ios.css +56 -19
  337. package/dist/collection/components/backdrop/backdrop.js +12 -6
  338. package/dist/collection/components/backdrop/backdrop.md.css +56 -19
  339. package/dist/collection/components/badge/badge.ionic.css +275 -0
  340. package/dist/collection/components/badge/badge.ios.css +139 -12
  341. package/dist/collection/components/badge/badge.js +145 -9
  342. package/dist/collection/components/badge/badge.md.css +123 -12
  343. package/dist/collection/components/breadcrumb/breadcrumb.ios.css +20 -8
  344. package/dist/collection/components/breadcrumb/breadcrumb.js +43 -11
  345. package/dist/collection/components/breadcrumb/breadcrumb.md.css +20 -8
  346. package/dist/collection/components/breadcrumbs/breadcrumbs.ios.css +6 -0
  347. package/dist/collection/components/breadcrumbs/breadcrumbs.js +11 -9
  348. package/dist/collection/components/breadcrumbs/breadcrumbs.md.css +6 -0
  349. package/dist/collection/components/button/button.ionic.css +646 -0
  350. package/dist/collection/components/button/button.ios.css +154 -46
  351. package/dist/collection/components/button/button.js +63 -27
  352. package/dist/collection/components/button/button.md.css +150 -50
  353. package/dist/collection/components/buttons/buttons.ionic.css +97 -0
  354. package/dist/collection/components/buttons/buttons.ios.css +59 -7
  355. package/dist/collection/components/buttons/buttons.js +15 -9
  356. package/dist/collection/components/buttons/buttons.md.css +55 -3
  357. package/dist/collection/components/card/card.ionic.css +144 -0
  358. package/dist/collection/components/card/card.ios.css +65 -14
  359. package/dist/collection/components/card/card.js +41 -10
  360. package/dist/collection/components/card/card.md.css +65 -14
  361. package/dist/collection/components/card-content/card-content.ionic.css +89 -0
  362. package/dist/collection/components/card-content/card-content.ios.css +20 -35
  363. package/dist/collection/components/card-content/card-content.js +12 -10
  364. package/dist/collection/components/card-content/card-content.md.css +20 -35
  365. package/dist/collection/components/card-header/card-header.ionic.css +85 -0
  366. package/dist/collection/components/card-header/card-header.ios.css +27 -15
  367. package/dist/collection/components/card-header/card-header.js +13 -10
  368. package/dist/collection/components/card-header/card-header.md.css +27 -15
  369. package/dist/collection/components/card-subtitle/card-subtitle.ionic.css +144 -0
  370. package/dist/collection/components/card-subtitle/card-subtitle.ios.css +12 -0
  371. package/dist/collection/components/card-subtitle/card-subtitle.js +11 -8
  372. package/dist/collection/components/card-subtitle/card-subtitle.md.css +12 -0
  373. package/dist/collection/components/card-title/card-title.ios.css +73 -0
  374. package/dist/collection/components/card-title/card-title.js +11 -8
  375. package/dist/collection/components/card-title/card-title.md.css +73 -0
  376. package/dist/collection/components/checkbox/checkbox.ionic.css +539 -0
  377. package/dist/collection/components/checkbox/checkbox.ios.css +161 -101
  378. package/dist/collection/components/checkbox/checkbox.js +70 -14
  379. package/dist/collection/components/checkbox/checkbox.md.css +162 -102
  380. package/dist/collection/components/chip/chip.ionic.css +217 -0
  381. package/dist/collection/components/chip/chip.ios.css +67 -14
  382. package/dist/collection/components/chip/chip.js +108 -8
  383. package/dist/collection/components/chip/chip.md.css +67 -14
  384. package/dist/collection/components/col/col.css +192 -4
  385. package/dist/collection/components/col/col.js +211 -61
  386. package/dist/collection/components/content/content.css +8 -2
  387. package/dist/collection/components/content/content.js +16 -11
  388. package/dist/collection/components/datetime/datetime.ionic.css +703 -0
  389. package/dist/collection/components/datetime/datetime.ios.css +302 -106
  390. package/dist/collection/components/datetime/datetime.js +98 -20
  391. package/dist/collection/components/datetime/datetime.md.css +293 -96
  392. package/dist/collection/components/datetime/utils/data.js +5 -5
  393. package/dist/collection/components/datetime-button/datetime-button.ios.css +6 -0
  394. package/dist/collection/components/datetime-button/datetime-button.js +11 -8
  395. package/dist/collection/components/datetime-button/datetime-button.md.css +6 -0
  396. package/dist/collection/components/divider/divider.ionic.css +148 -0
  397. package/dist/collection/components/divider/divider.ios.css +87 -0
  398. package/dist/collection/components/divider/divider.js +94 -0
  399. package/dist/collection/components/divider/divider.md.css +87 -0
  400. package/dist/collection/components/fab/fab.css +25 -1
  401. package/dist/collection/components/fab/fab.js +9 -5
  402. package/dist/collection/components/fab-button/fab-button.ios.css +18 -6
  403. package/dist/collection/components/fab-button/fab-button.js +36 -21
  404. package/dist/collection/components/fab-button/fab-button.md.css +20 -8
  405. package/dist/collection/components/fab-list/fab-list.css +12 -0
  406. package/dist/collection/components/fab-list/fab-list.js +9 -5
  407. package/dist/collection/components/footer/footer.ios.css +14 -2
  408. package/dist/collection/components/footer/footer.js +21 -16
  409. package/dist/collection/components/footer/footer.md.css +12 -0
  410. package/dist/collection/components/gallery/gallery-interface.js +1 -0
  411. package/dist/collection/components/gallery/gallery.css +103 -0
  412. package/dist/collection/components/gallery/gallery.js +439 -0
  413. package/dist/collection/components/gallery/test/utils.js +100 -0
  414. package/dist/collection/components/grid/grid.css +12 -0
  415. package/dist/collection/components/grid/grid.js +9 -5
  416. package/dist/collection/components/header/header.ionic.css +97 -0
  417. package/dist/collection/components/header/header.ios.css +25 -10
  418. package/dist/collection/components/header/header.js +50 -19
  419. package/dist/collection/components/header/header.md.css +23 -8
  420. package/dist/collection/components/header/header.utils.js +5 -5
  421. package/dist/collection/components/img/img.js +8 -2
  422. package/dist/collection/components/infinite-scroll/infinite-scroll.js +100 -5
  423. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.ios.css +12 -0
  424. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +16 -10
  425. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.md.css +12 -0
  426. package/dist/collection/components/input/input.ionic.css +889 -0
  427. package/dist/collection/components/input/input.ios.css +223 -135
  428. package/dist/collection/components/input/input.js +148 -37
  429. package/dist/collection/components/input/input.md.css +193 -207
  430. package/dist/collection/components/input-otp/input-otp.ionic.css +371 -0
  431. package/dist/collection/components/input-otp/input-otp.ios.css +105 -60
  432. package/dist/collection/components/input-otp/input-otp.js +73 -6
  433. package/dist/collection/components/input-otp/input-otp.md.css +105 -60
  434. package/dist/collection/components/input-password-toggle/input-password-toggle.ionic.css +78 -0
  435. package/dist/collection/components/input-password-toggle/input-password-toggle.js +48 -12
  436. package/dist/collection/components/input-password-toggle/input-password-toggle.native.css +61 -0
  437. package/dist/collection/components/item/item.ionic.css +508 -0
  438. package/dist/collection/components/item/item.ios.css +109 -69
  439. package/dist/collection/components/item/item.js +51 -20
  440. package/dist/collection/components/item/item.md.css +120 -68
  441. package/dist/collection/components/item-divider/item-divider.ios.css +18 -0
  442. package/dist/collection/components/item-divider/item-divider.js +11 -8
  443. package/dist/collection/components/item-divider/item-divider.md.css +18 -0
  444. package/dist/collection/components/item-group/item-group.ios.css +12 -0
  445. package/dist/collection/components/item-group/item-group.js +13 -7
  446. package/dist/collection/components/item-group/item-group.md.css +12 -0
  447. package/dist/collection/components/item-option/item-option.ionic.css +278 -0
  448. package/dist/collection/components/item-option/item-option.ios.css +136 -29
  449. package/dist/collection/components/item-option/item-option.js +73 -9
  450. package/dist/collection/components/item-option/item-option.md.css +136 -29
  451. package/dist/collection/components/item-options/item-options.ionic.css +221 -0
  452. package/dist/collection/components/item-options/item-options.ios.css +77 -34
  453. package/dist/collection/components/item-options/item-options.js +13 -7
  454. package/dist/collection/components/item-options/item-options.md.css +77 -34
  455. package/dist/collection/components/item-sliding/item-sliding.css +6 -0
  456. package/dist/collection/components/item-sliding/item-sliding.js +144 -4
  457. package/dist/collection/components/item-sliding/test/test.utils.js +13 -0
  458. package/dist/collection/components/label/label.ios.css +18 -0
  459. package/dist/collection/components/label/label.js +11 -8
  460. package/dist/collection/components/label/label.md.css +18 -0
  461. package/dist/collection/components/list/list.ionic.css +212 -0
  462. package/dist/collection/components/list/list.ios.css +54 -14
  463. package/dist/collection/components/list/list.js +48 -9
  464. package/dist/collection/components/list/list.md.css +56 -16
  465. package/dist/collection/components/list-header/list-header.ionic.css +190 -0
  466. package/dist/collection/components/list-header/list-header.ios.css +82 -38
  467. package/dist/collection/components/list-header/list-header.js +11 -8
  468. package/dist/collection/components/list-header/list-header.md.css +82 -38
  469. package/dist/collection/components/loading/loading.ios.css +13 -1
  470. package/dist/collection/components/loading/loading.js +15 -16
  471. package/dist/collection/components/loading/loading.md.css +13 -1
  472. package/dist/collection/components/menu/menu.ios.css +15 -3
  473. package/dist/collection/components/menu/menu.js +12 -7
  474. package/dist/collection/components/menu/menu.md.css +15 -3
  475. package/dist/collection/components/menu-button/menu-button.ionic.css +236 -0
  476. package/dist/collection/components/menu-button/menu-button.ios.css +48 -14
  477. package/dist/collection/components/menu-button/menu-button.js +26 -10
  478. package/dist/collection/components/menu-button/menu-button.md.css +49 -15
  479. package/dist/collection/components/menu-toggle/menu-toggle.js +8 -5
  480. package/dist/collection/components/modal/animations/ionic.enter.js +40 -0
  481. package/dist/collection/components/modal/animations/ionic.leave.js +28 -0
  482. package/dist/collection/components/modal/animations/sheet.js +8 -2
  483. package/dist/collection/components/modal/gestures/sheet.js +76 -10
  484. package/dist/collection/components/modal/modal.ionic.css +247 -0
  485. package/dist/collection/components/modal/modal.ios.css +178 -70
  486. package/dist/collection/components/modal/modal.js +51 -17
  487. package/dist/collection/components/modal/modal.md.css +178 -70
  488. package/dist/collection/components/nav/nav.css +7 -1
  489. package/dist/collection/components/nav/nav.js +11 -5
  490. package/dist/collection/components/nav-link/nav-link.js +5 -1
  491. package/dist/collection/components/note/note.ios.css +12 -0
  492. package/dist/collection/components/note/note.js +11 -8
  493. package/dist/collection/components/note/note.md.css +12 -0
  494. package/dist/collection/components/picker/picker.ios.css +15 -3
  495. package/dist/collection/components/picker/picker.js +8 -5
  496. package/dist/collection/components/picker/picker.md.css +15 -3
  497. package/dist/collection/components/picker-column/picker-column.css +9 -2
  498. package/dist/collection/components/picker-column/picker-column.js +8 -7
  499. package/dist/collection/components/picker-column-option/picker-column-option.ios.css +6 -0
  500. package/dist/collection/components/picker-column-option/picker-column-option.js +13 -7
  501. package/dist/collection/components/picker-column-option/picker-column-option.md.css +6 -0
  502. package/dist/collection/components/picker-legacy/animations/ios.enter.js +27 -0
  503. package/dist/collection/components/picker-legacy/animations/ios.leave.js +23 -0
  504. package/dist/collection/components/picker-legacy/picker-interface.js +1 -0
  505. package/dist/collection/components/picker-legacy/picker.ios.css +312 -0
  506. package/dist/collection/components/picker-legacy/picker.js +891 -0
  507. package/dist/collection/components/picker-legacy/picker.md.css +299 -0
  508. package/dist/collection/components/picker-legacy-column/picker-column.ios.css +243 -0
  509. package/dist/collection/components/picker-legacy-column/picker-column.js +422 -0
  510. package/dist/collection/components/picker-legacy-column/picker-column.md.css +234 -0
  511. package/dist/collection/components/picker-legacy-column/test/test.utils.js +43 -0
  512. package/dist/collection/components/popover/popover.ionic.css +290 -0
  513. package/dist/collection/components/popover/popover.ios.css +29 -1
  514. package/dist/collection/components/popover/popover.js +19 -20
  515. package/dist/collection/components/popover/popover.md.css +29 -1
  516. package/dist/collection/components/progress-bar/progress-bar.ionic.css +287 -0
  517. package/dist/collection/components/progress-bar/progress-bar.ios.css +48 -17
  518. package/dist/collection/components/progress-bar/progress-bar.js +43 -7
  519. package/dist/collection/components/progress-bar/progress-bar.md.css +48 -17
  520. package/dist/collection/components/radio/radio.ionic.css +422 -0
  521. package/dist/collection/components/radio/radio.ios.css +134 -91
  522. package/dist/collection/components/radio/radio.js +15 -10
  523. package/dist/collection/components/radio/radio.md.css +134 -91
  524. package/dist/collection/components/radio-group/radio-group.ionic.css +119 -0
  525. package/dist/collection/components/radio-group/radio-group.ios.css +43 -19
  526. package/dist/collection/components/radio-group/radio-group.js +48 -7
  527. package/dist/collection/components/radio-group/radio-group.md.css +43 -19
  528. package/dist/collection/components/range/range.ionic.css +567 -0
  529. package/dist/collection/components/range/range.ios.css +128 -85
  530. package/dist/collection/components/range/range.js +16 -10
  531. package/dist/collection/components/range/range.md.css +128 -85
  532. package/dist/collection/components/refresher/refresher.ios.css +14 -1
  533. package/dist/collection/components/refresher/refresher.js +11 -8
  534. package/dist/collection/components/refresher/refresher.md.css +15 -2
  535. package/dist/collection/components/refresher-content/refresher-content.js +28 -7
  536. package/dist/collection/components/reorder/reorder.ios.css +6 -0
  537. package/dist/collection/components/reorder/reorder.js +33 -6
  538. package/dist/collection/components/reorder/reorder.md.css +6 -0
  539. package/dist/collection/components/reorder-group/reorder-group.css +6 -0
  540. package/dist/collection/components/reorder-group/reorder-group.js +8 -4
  541. package/dist/collection/components/ripple-effect/{ripple-effect.css → ripple-effect.common.css} +7 -1
  542. package/dist/collection/components/ripple-effect/ripple-effect.ionic.css +215 -0
  543. package/dist/collection/components/ripple-effect/ripple-effect.js +14 -6
  544. package/dist/collection/components/route/route.js +4 -0
  545. package/dist/collection/components/router/router.js +4 -0
  546. package/dist/collection/components/router-link/router-link.css +8 -2
  547. package/dist/collection/components/router-link/router-link.js +9 -5
  548. package/dist/collection/components/router-outlet/router-outlet.css +7 -1
  549. package/dist/collection/components/router-outlet/router-outlet.js +10 -40
  550. package/dist/collection/components/row/row.css +16 -0
  551. package/dist/collection/components/row/row.js +9 -2
  552. package/dist/collection/components/searchbar/searchbar.ionic.css +626 -0
  553. package/dist/collection/components/searchbar/searchbar.ios.css +56 -18
  554. package/dist/collection/components/searchbar/searchbar.js +180 -33
  555. package/dist/collection/components/searchbar/searchbar.md.css +56 -18
  556. package/dist/collection/components/segment/segment.ionic.css +115 -0
  557. package/dist/collection/components/segment/segment.ios.css +45 -2
  558. package/dist/collection/components/segment/segment.js +11 -8
  559. package/dist/collection/components/segment/segment.md.css +45 -2
  560. package/dist/collection/components/segment-button/segment-button.ionic.css +353 -0
  561. package/dist/collection/components/segment-button/segment-button.ios.css +146 -105
  562. package/dist/collection/components/segment-button/segment-button.js +11 -8
  563. package/dist/collection/components/segment-button/segment-button.md.css +148 -107
  564. package/dist/collection/components/segment-content/segment-content.js +1 -1
  565. package/dist/collection/components/segment-view/segment-view.ios.css +6 -0
  566. package/dist/collection/components/segment-view/segment-view.js +6 -4
  567. package/dist/collection/components/segment-view/segment-view.md.css +6 -0
  568. package/dist/collection/components/select/select.ionic.css +810 -0
  569. package/dist/collection/components/select/select.ios.css +348 -176
  570. package/dist/collection/components/select/select.js +434 -66
  571. package/dist/collection/components/select/select.md.css +364 -178
  572. package/dist/collection/components/select-modal/select-modal.ionic.css +154 -0
  573. package/dist/collection/components/select-modal/select-modal.ios.css +95 -0
  574. package/dist/collection/components/select-modal/select-modal.js +109 -32
  575. package/dist/collection/components/select-modal/select-modal.md.css +83 -0
  576. package/dist/collection/components/select-option/select-option.js +32 -2
  577. package/dist/collection/components/select-popover/select-popover.ionic.css +499 -0
  578. package/dist/collection/components/select-popover/select-popover.ios.css +100 -0
  579. package/dist/collection/components/select-popover/select-popover.js +72 -31
  580. package/dist/collection/components/select-popover/select-popover.md.css +100 -0
  581. package/dist/collection/components/skeleton-text/skeleton-text.css +6 -0
  582. package/dist/collection/components/skeleton-text/skeleton-text.js +9 -5
  583. package/dist/collection/components/spinner/{spinner.css → spinner.ionic.css} +78 -10
  584. package/dist/collection/components/spinner/spinner.js +47 -6
  585. package/dist/collection/components/spinner/spinner.native.css +199 -0
  586. package/dist/collection/components/split-pane/split-pane.ios.css +20 -2
  587. package/dist/collection/components/split-pane/split-pane.js +15 -8
  588. package/dist/collection/components/split-pane/split-pane.md.css +20 -2
  589. package/dist/collection/components/tab/tab.js +6 -2
  590. package/dist/collection/components/tab-bar/tab-bar.ionic.css +227 -0
  591. package/dist/collection/components/tab-bar/tab-bar.ios.css +71 -43
  592. package/dist/collection/components/tab-bar/tab-bar.js +171 -13
  593. package/dist/collection/components/tab-bar/tab-bar.md.css +71 -43
  594. package/dist/collection/components/tab-button/tab-button.ionic.css +348 -0
  595. package/dist/collection/components/tab-button/tab-button.ios.css +171 -95
  596. package/dist/collection/components/tab-button/tab-button.js +54 -9
  597. package/dist/collection/components/tab-button/tab-button.md.css +137 -93
  598. package/dist/collection/components/tabs/tabs.css +7 -1
  599. package/dist/collection/components/tabs/tabs.js +4 -1
  600. package/dist/collection/components/text/text.css +6 -0
  601. package/dist/collection/components/text/text.js +7 -6
  602. package/dist/collection/components/textarea/textarea.ionic.css +898 -0
  603. package/dist/collection/components/textarea/textarea.ios.css +298 -158
  604. package/dist/collection/components/textarea/textarea.js +162 -24
  605. package/dist/collection/components/textarea/textarea.md.css +312 -159
  606. package/dist/collection/components/thumbnail/thumbnail.css +6 -0
  607. package/dist/collection/components/thumbnail/thumbnail.js +9 -2
  608. package/dist/collection/components/title/title.ionic.css +127 -0
  609. package/dist/collection/components/title/title.ios.css +32 -4
  610. package/dist/collection/components/title/title.js +13 -7
  611. package/dist/collection/components/title/title.md.css +32 -4
  612. package/dist/collection/components/toast/animations/utils.js +1 -1
  613. package/dist/collection/components/toast/toast.ionic.css +394 -0
  614. package/dist/collection/components/toast/toast.ios.css +84 -45
  615. package/dist/collection/components/toast/toast.js +76 -13
  616. package/dist/collection/components/toast/toast.md.css +84 -45
  617. package/dist/collection/components/toggle/toggle.ionic.css +508 -0
  618. package/dist/collection/components/toggle/toggle.ios.css +247 -131
  619. package/dist/collection/components/toggle/toggle.js +73 -18
  620. package/dist/collection/components/toggle/toggle.md.css +244 -131
  621. package/dist/collection/components/toolbar/test/image.svg +1 -0
  622. package/dist/collection/components/toolbar/toolbar.ionic.css +249 -0
  623. package/dist/collection/components/toolbar/toolbar.ios.css +90 -47
  624. package/dist/collection/components/toolbar/toolbar.js +218 -13
  625. package/dist/collection/components/toolbar/toolbar.md.css +90 -47
  626. package/dist/collection/global/ionic-global.js +241 -13
  627. package/dist/collection/index.js +1 -1
  628. package/dist/collection/utils/focus-trap.js +13 -2
  629. package/dist/collection/utils/focus-visible.js +22 -0
  630. package/dist/collection/utils/forms/validity.js +31 -0
  631. package/dist/collection/utils/framework-delegate.js +3 -1
  632. package/dist/collection/utils/hardware-back-button.js +15 -0
  633. package/dist/collection/utils/helpers.js +57 -3
  634. package/dist/collection/utils/keyboard/keyboard-controller.js +3 -1
  635. package/dist/collection/utils/media.js +1 -0
  636. package/dist/collection/utils/menu-controller/animations/overlay.js +3 -3
  637. package/dist/collection/utils/menu-controller/animations/push.js +2 -1
  638. package/dist/collection/utils/menu-controller/animations/reveal.js +2 -1
  639. package/dist/collection/utils/overlays.js +97 -31
  640. package/dist/collection/utils/select-option-render.js +76 -0
  641. package/dist/collection/utils/test/playwright/drag-element.js +32 -9
  642. package/dist/collection/utils/test/playwright/generator.js +48 -23
  643. package/dist/collection/utils/test/playwright/page/utils/goto.js +14 -5
  644. package/dist/collection/utils/test/playwright/page/utils/set-content.js +26 -3
  645. package/dist/collection/utils/theme.js +25 -1
  646. package/dist/collection/utils/transition/ios.transition.js +1 -0
  647. package/dist/docs.json +10080 -669
  648. package/dist/esm/{animation-CnGMT4ji.js → animation-Cqe2x-Pt.js} +2 -2
  649. package/dist/esm/{app-globals-DhZjtldk.js → app-globals-Dk1rB3aE.js} +1 -1
  650. package/dist/esm/{button-active-BBx21brx.js → button-active-g6ZnZzDZ.js} +2 -2
  651. package/dist/esm/{capacitor-CFERIeaU.js → capacitor-C4lYa1nV.js} +1 -1
  652. package/dist/esm/caret-down-D1t981Ih.js +6 -0
  653. package/dist/esm/caret-left-fIOYmaqA.js +6 -0
  654. package/dist/esm/caret-right-BYSs-jZz.js +6 -0
  655. package/dist/esm/config-BwKpO3Is.js +31 -0
  656. package/dist/esm/{data-B9iGR5YO.js → data-BNKYavC3.js} +6 -6
  657. package/dist/esm/{focus-visible-BmVRXR1y.js → focus-visible-vXpMhGrs.js} +23 -1
  658. package/dist/esm/{framework-delegate-CyxE1S_P.js → framework-delegate-CjVwn_KZ.js} +4 -2
  659. package/dist/esm/{haptic-DzAMWJuk.js → haptic-_88k1V5U.js} +1 -1
  660. package/dist/esm/{helpers-Tl8jw6S2.js → helpers-Do7zwvM1.js} +58 -5
  661. package/dist/esm/{index-hW6eNZ3o.js → index-BmkLokUL.js} +2 -2
  662. package/dist/esm/{index-BtUdxPjv.js → index-C5t9-ciC.js} +4 -3
  663. package/dist/esm/{index-B-hkiOUh.js → index-CGthURny.js} +4 -4
  664. package/dist/esm/{index-AlrZKoWR.js → index-D2tu5BUg.js} +2 -1
  665. package/dist/esm/{config-TO1rZH52.js → index-D4ugF_sT.js} +2 -29
  666. package/dist/esm/{index-IGIE5vDm.js → index-Omi_TcwW.js} +41 -4
  667. package/dist/esm/{index-B2KwgBLx.js → index-hpH08p5s.js} +11 -11
  668. package/dist/esm/index.js +14 -14
  669. package/dist/esm/{input-shims-AaDhOpKN.js → input-shims-vDjCsx95.js} +7 -6
  670. package/dist/esm/{input.utils-Bxa_DQ7-.js → input.utils-B9Q5xHp6.js} +3 -3
  671. package/dist/esm/ion-accordion_2.entry.js +61 -29
  672. package/dist/esm/ion-action-sheet.entry.js +41 -26
  673. package/dist/esm/ion-alert.entry.js +61 -44
  674. package/dist/esm/ion-app_8.entry.js +296 -175
  675. package/dist/esm/ion-avatar_3.entry.js +125 -13
  676. package/dist/esm/ion-back-button.entry.js +31 -22
  677. package/dist/esm/ion-backdrop.entry.js +10 -7
  678. package/dist/esm/ion-breadcrumb_2.entry.js +54 -18
  679. package/dist/esm/ion-button_2.entry.js +59 -22
  680. package/dist/esm/ion-card_5.entry.js +55 -33
  681. package/dist/esm/ion-checkbox.entry.js +34 -16
  682. package/dist/esm/ion-chip.entry.js +50 -9
  683. package/dist/esm/ion-col_3.entry.js +56 -57
  684. package/dist/esm/ion-datetime-button.entry.js +13 -9
  685. package/dist/esm/{ion-datetime.entry.js → ion-datetime_3.entry.js} +741 -30
  686. package/dist/esm/ion-divider.entry.js +49 -0
  687. package/dist/esm/ion-fab_3.entry.js +44 -28
  688. package/dist/esm/ion-gallery.entry.js +346 -0
  689. package/dist/esm/ion-img.entry.js +8 -4
  690. package/dist/esm/ion-infinite-scroll_2.entry.js +92 -16
  691. package/dist/esm/ion-input-otp.entry.js +74 -9
  692. package/dist/esm/ion-input-password-toggle.entry.js +53 -15
  693. package/dist/esm/ion-input.entry.js +124 -34
  694. package/dist/esm/ion-item-option_3.entry.js +186 -21
  695. package/dist/esm/ion-item_8.entry.js +116 -49
  696. package/dist/esm/ion-loading.entry.js +21 -22
  697. package/dist/esm/ion-menu_3.entry.js +47 -29
  698. package/dist/esm/ion-modal.entry.js +215 -95
  699. package/dist/esm/ion-nav_2.entry.js +14 -11
  700. package/dist/esm/ion-picker-column-option.entry.js +12 -8
  701. package/dist/esm/ion-picker-column.entry.js +13 -13
  702. package/dist/esm/ion-picker.entry.js +10 -6
  703. package/dist/esm/ion-popover.entry.js +21 -23
  704. package/dist/esm/ion-progress-bar.entry.js +27 -9
  705. package/dist/esm/ion-radio_2.entry.js +35 -17
  706. package/dist/esm/ion-range.entry.js +20 -13
  707. package/dist/esm/ion-refresher_2.entry.js +40 -21
  708. package/dist/esm/ion-reorder_2.entry.js +38 -14
  709. package/dist/esm/ion-ripple-effect.entry.js +15 -7
  710. package/dist/esm/ion-route_4.entry.js +10 -9
  711. package/dist/esm/ion-searchbar.entry.js +137 -24
  712. package/dist/esm/ion-segment-content.entry.js +2 -2
  713. package/dist/esm/ion-segment-view.entry.js +6 -3
  714. package/dist/esm/ion-segment_2.entry.js +23 -16
  715. package/dist/esm/ion-select-modal.entry.js +97 -40
  716. package/dist/esm/ion-select_3.entry.js +453 -84
  717. package/dist/esm/ion-spinner.entry.js +30 -8
  718. package/dist/esm/ion-split-pane.entry.js +13 -9
  719. package/dist/esm/ion-tab-bar_2.entry.js +147 -23
  720. package/dist/esm/ion-tab_2.entry.js +8 -7
  721. package/dist/esm/ion-text.entry.js +7 -7
  722. package/dist/esm/ion-textarea.entry.js +137 -23
  723. package/dist/esm/ion-toast.entry.js +45 -21
  724. package/dist/esm/ion-toggle.entry.js +82 -25
  725. package/dist/esm/ionic-global-CAZb-5i-.js +508 -0
  726. package/dist/esm/ionic.js +5 -5
  727. package/dist/esm/{ios.transition--aMF-pDH.js → ios.transition-CzSncKQg.js} +7 -5
  728. package/dist/esm/{keyboard-CUw4ekVy.js → keyboard-Cpw6xVLJ.js} +1 -1
  729. package/dist/esm/{keyboard-ywgs5efA.js → keyboard-DJpS2IGK.js} +4 -3
  730. package/dist/esm/{keyboard-controller-BaaVITYt.js → keyboard-controller-CAc33ylR.js} +5 -3
  731. package/dist/esm/list-Dhi5xtNS.js +6 -0
  732. package/dist/esm/loader.js +5 -5
  733. package/dist/esm/{md.transition-BEVbfm8j.js → md.transition-DIsWqYBZ.js} +6 -5
  734. package/dist/esm/{notch-controller-DAcvKU57.js → notch-controller-DiBq57w8.js} +2 -2
  735. package/dist/esm/{overlays-BDGzTP3L.js → overlays-rwDDzEs4.js} +114 -39
  736. package/dist/esm/select-option-render-B2qc5ZP7.js +79 -0
  737. package/dist/esm/{status-tap-BfJqFSLF.js → status-tap-fYFdZg6z.js} +4 -3
  738. package/dist/esm/{swipe-back-BZBFwTQV.js → swipe-back-BzGqTrrq.js} +3 -2
  739. package/dist/esm/{theme-DiVJyqlX.js → theme-DaJxRxSQ.js} +25 -1
  740. package/dist/esm/validity-BjW8SOqw.js +48 -0
  741. package/dist/esm/x-BDqjX7Z_.js +6 -0
  742. package/dist/html.html-data.json +2589 -100
  743. package/dist/ionic/index.esm.js +1 -1
  744. package/dist/ionic/ionic.esm.js +1 -1
  745. package/dist/ionic/p-00c0bd38.entry.js +4 -0
  746. package/dist/ionic/p-05a30032.entry.js +4 -0
  747. package/dist/ionic/p-07d3388f.entry.js +4 -0
  748. package/dist/ionic/p-11nqcMM3.js +4 -0
  749. package/dist/ionic/p-139d02eb.entry.js +4 -0
  750. package/dist/ionic/p-15e3e8f5.entry.js +4 -0
  751. package/dist/ionic/p-1709b0aa.entry.js +4 -0
  752. package/dist/ionic/p-1c2c1869.entry.js +4 -0
  753. package/dist/ionic/p-1c4de46b.entry.js +4 -0
  754. package/dist/ionic/p-1e1c8d61.entry.js +4 -0
  755. package/dist/ionic/p-2311e660.entry.js +4 -0
  756. package/dist/ionic/p-2aa7567e.entry.js +4 -0
  757. package/dist/ionic/p-2ad79c23.entry.js +4 -0
  758. package/dist/ionic/p-2f0073af.entry.js +4 -0
  759. package/dist/ionic/p-37ccbee4.entry.js +4 -0
  760. package/dist/ionic/p-3aba19e2.entry.js +4 -0
  761. package/dist/ionic/p-3f79f594.entry.js +4 -0
  762. package/dist/ionic/p-4079cee3.entry.js +4 -0
  763. package/dist/ionic/p-45825c2c.entry.js +4 -0
  764. package/dist/ionic/p-48026d15.entry.js +4 -0
  765. package/dist/ionic/p-488992b6.entry.js +4 -0
  766. package/dist/ionic/p-4a0260e6.entry.js +4 -0
  767. package/dist/ionic/p-50b61fab.entry.js +4 -0
  768. package/dist/ionic/p-50cd2d57.entry.js +4 -0
  769. package/dist/ionic/p-5274f999.entry.js +4 -0
  770. package/dist/ionic/p-586d4270.entry.js +4 -0
  771. package/dist/ionic/p-68c21b2a.entry.js +4 -0
  772. package/dist/ionic/p-6fbead83.entry.js +4 -0
  773. package/dist/ionic/p-7194f6fa.entry.js +4 -0
  774. package/dist/ionic/p-71b6014c.entry.js +4 -0
  775. package/dist/ionic/p-72491468.entry.js +4 -0
  776. package/dist/ionic/p-7d267dc6.entry.js +4 -0
  777. package/dist/ionic/p-7d5057c4.entry.js +4 -0
  778. package/dist/ionic/p-83c693c4.entry.js +4 -0
  779. package/dist/ionic/p-8537b2fb.entry.js +4 -0
  780. package/dist/ionic/p-8f127a9c.entry.js +4 -0
  781. package/dist/ionic/p-8uDL7fql.js +4 -0
  782. package/dist/ionic/p-9d789053.entry.js +4 -0
  783. package/dist/ionic/p-BDqjX7Z_.js +4 -0
  784. package/dist/ionic/p-BYSs-jZz.js +4 -0
  785. package/dist/ionic/p-BjW8SOqw.js +4 -0
  786. package/{components/p-9VcRUwdB.js → dist/ionic/p-BsfuYVMP.js} +1 -1
  787. package/dist/ionic/p-BwKpO3Is.js +4 -0
  788. package/dist/ionic/p-Bx0bt2Ar.js +4 -0
  789. package/dist/ionic/p-C2mpVKI1.js +4 -0
  790. package/dist/ionic/p-C4uUM9DM.js +4 -0
  791. package/dist/ionic/p-C5zxLmJ_.js +4 -0
  792. package/{components/p-BS1TtEiJ.js → dist/ionic/p-C8IHbcuP.js} +1 -1
  793. package/dist/ionic/p-CBV-BGvD.js +4 -0
  794. package/dist/ionic/p-CDn0uNJA.js +4 -0
  795. package/dist/ionic/p-CFjI63GE.js +4 -0
  796. package/dist/ionic/p-CHE1xWbg.js +4 -0
  797. package/dist/ionic/p-CIk5QtPm.js +4 -0
  798. package/dist/ionic/p-CQKe4n56.js +4 -0
  799. package/dist/ionic/p-CVp2D--1.js +4 -0
  800. package/dist/ionic/p-CWJdc8f_.js +4 -0
  801. package/dist/ionic/p-CXqdKf1K.js +4 -0
  802. package/dist/ionic/p-Cb-0O4h8.js +4 -0
  803. package/dist/ionic/{p-CKvCXMs9.js → p-CbkICFBN.js} +1 -1
  804. package/dist/ionic/p-D1t981Ih.js +4 -0
  805. package/dist/ionic/p-D2tu5BUg.js +4 -0
  806. package/dist/ionic/{p-B8xlpH8p.js → p-DKWXAwlR.js} +1 -1
  807. package/dist/ionic/p-DaJxRxSQ.js +4 -0
  808. package/dist/ionic/p-Dhi5xtNS.js +4 -0
  809. package/dist/ionic/p-DoyDJ2X5.js +4 -0
  810. package/dist/ionic/p-FvDKM4Ax.js +4 -0
  811. package/dist/ionic/p-Omi_TcwW.js +5 -0
  812. package/{components/p-D13Eaw-8.js → dist/ionic/p-SJmaFQ0H.js} +1 -1
  813. package/dist/ionic/p-SOASChNu.js +4 -0
  814. package/dist/ionic/{p-DjriolRs.js → p-ZqkJDyhe.js} +1 -1
  815. package/dist/ionic/p-a9fb086b.entry.js +4 -0
  816. package/dist/ionic/p-acdc21a6.entry.js +4 -0
  817. package/dist/ionic/p-ae667493.entry.js +4 -0
  818. package/dist/ionic/p-b2fe6c1c.entry.js +4 -0
  819. package/dist/ionic/p-b3c9f19c.entry.js +4 -0
  820. package/dist/ionic/p-b653f4c2.entry.js +4 -0
  821. package/dist/ionic/p-bd71a4a7.entry.js +4 -0
  822. package/dist/ionic/p-bf972309.entry.js +4 -0
  823. package/dist/ionic/p-c10fa162.entry.js +4 -0
  824. package/dist/ionic/p-cdb5fc03.entry.js +4 -0
  825. package/dist/ionic/p-d4ed5710.entry.js +4 -0
  826. package/dist/ionic/p-d6299c37.entry.js +4 -0
  827. package/dist/ionic/p-d976e777.entry.js +4 -0
  828. package/dist/ionic/p-e18d3fdb.entry.js +4 -0
  829. package/dist/ionic/p-e3abffbe.entry.js +4 -0
  830. package/dist/ionic/p-f02ba305.entry.js +4 -0
  831. package/dist/ionic/p-f85942f8.entry.js +4 -0
  832. package/dist/ionic/p-fIOYmaqA.js +4 -0
  833. package/dist/ionic/p-fad05840.entry.js +4 -0
  834. package/dist/ionic/p-qETiT38a.js +4 -0
  835. package/dist/ionic/p-vXpMhGrs.js +4 -0
  836. package/dist/types/components/accordion/accordion.d.ts +6 -3
  837. package/dist/types/components/accordion-group/accordion-group.d.ts +12 -1
  838. package/dist/types/components/action-sheet/action-sheet-interface.d.ts +3 -7
  839. package/dist/types/components/action-sheet/action-sheet.d.ts +3 -2
  840. package/dist/types/components/alert/alert-interface.d.ts +3 -7
  841. package/dist/types/components/alert/alert.d.ts +3 -2
  842. package/dist/types/components/app/app.d.ts +4 -5
  843. package/dist/types/components/avatar/avatar.d.ts +32 -0
  844. package/dist/types/components/back-button/back-button.d.ts +2 -1
  845. package/dist/types/components/backdrop/backdrop.d.ts +4 -0
  846. package/dist/types/components/badge/badge.d.ts +34 -1
  847. package/dist/types/components/breadcrumb/breadcrumb.d.ts +4 -1
  848. package/dist/types/components/breadcrumbs/breadcrumbs.d.ts +2 -2
  849. package/dist/types/components/button/button.d.ts +23 -8
  850. package/dist/types/components/buttons/buttons.d.ts +5 -1
  851. package/dist/types/components/card/card.d.ts +8 -1
  852. package/dist/types/components/card-content/card-content.d.ts +2 -1
  853. package/dist/types/components/card-header/card-header.d.ts +3 -2
  854. package/dist/types/components/card-subtitle/card-subtitle.d.ts +2 -1
  855. package/dist/types/components/card-title/card-title.d.ts +2 -1
  856. package/dist/types/components/checkbox/checkbox.d.ts +14 -4
  857. package/dist/types/components/chip/chip.d.ts +26 -1
  858. package/dist/types/components/col/col.d.ts +52 -5
  859. package/dist/types/components/content/content.d.ts +3 -0
  860. package/dist/types/components/datetime/datetime.d.ts +26 -1
  861. package/dist/types/components/datetime/utils/data.d.ts +5 -5
  862. package/dist/types/components/datetime-button/datetime-button.d.ts +2 -1
  863. package/dist/types/components/divider/divider.d.ts +20 -0
  864. package/dist/types/components/fab/fab.d.ts +4 -0
  865. package/dist/types/components/fab-button/fab-button.d.ts +5 -3
  866. package/dist/types/components/fab-list/fab-list.d.ts +4 -0
  867. package/dist/types/components/footer/footer.d.ts +4 -3
  868. package/dist/types/components/gallery/gallery-interface.d.ts +9 -0
  869. package/dist/types/components/gallery/gallery.d.ts +125 -0
  870. package/dist/types/components/gallery/test/utils.d.ts +2 -0
  871. package/dist/types/components/grid/grid.d.ts +4 -0
  872. package/dist/types/components/header/header.d.ts +9 -3
  873. package/dist/types/components/header/header.utils.d.ts +3 -3
  874. package/dist/types/components/img/img.d.ts +3 -0
  875. package/dist/types/components/infinite-scroll/infinite-scroll.d.ts +21 -0
  876. package/dist/types/components/infinite-scroll-content/infinite-scroll-content.d.ts +4 -0
  877. package/dist/types/components/input/input.d.ts +31 -5
  878. package/dist/types/components/input-otp/input-otp.d.ts +37 -0
  879. package/dist/types/components/input-password-toggle/input-password-toggle.d.ts +2 -0
  880. package/dist/types/components/item/item.d.ts +11 -4
  881. package/dist/types/components/item-divider/item-divider.d.ts +2 -1
  882. package/dist/types/components/item-group/item-group.d.ts +4 -0
  883. package/dist/types/components/item-option/item-option.d.ts +18 -1
  884. package/dist/types/components/item-options/item-options.d.ts +4 -0
  885. package/dist/types/components/item-sliding/item-sliding.d.ts +32 -1
  886. package/dist/types/components/item-sliding/test/test.utils.d.ts +13 -0
  887. package/dist/types/components/label/label.d.ts +2 -1
  888. package/dist/types/components/list/list.d.ts +15 -1
  889. package/dist/types/components/list-header/list-header.d.ts +2 -1
  890. package/dist/types/components/loading/loading-interface.d.ts +2 -7
  891. package/dist/types/components/loading/loading.d.ts +3 -2
  892. package/dist/types/components/menu/menu.d.ts +3 -0
  893. package/dist/types/components/menu-button/menu-button.d.ts +3 -1
  894. package/dist/types/components/menu-toggle/menu-toggle.d.ts +3 -0
  895. package/dist/types/components/modal/animations/ionic.enter.d.ts +6 -0
  896. package/dist/types/components/modal/animations/ionic.leave.d.ts +6 -0
  897. package/dist/types/components/modal/gestures/sheet.d.ts +1 -1
  898. package/dist/types/components/modal/modal-interface.d.ts +4 -7
  899. package/dist/types/components/modal/modal.d.ts +11 -1
  900. package/dist/types/components/nav/nav-interface.d.ts +9 -1
  901. package/dist/types/components/nav/nav.d.ts +5 -1
  902. package/dist/types/components/nav-link/nav-link.d.ts +4 -0
  903. package/dist/types/components/note/note.d.ts +2 -1
  904. package/dist/types/components/picker/picker.d.ts +2 -1
  905. package/dist/types/components/picker-column/picker-column.d.ts +2 -1
  906. package/dist/types/components/picker-column-option/picker-column-option.d.ts +4 -0
  907. package/dist/types/components/picker-legacy/animations/ios.enter.d.ts +5 -0
  908. package/dist/types/components/picker-legacy/animations/ios.leave.d.ts +5 -0
  909. package/dist/types/components/picker-legacy/picker-interface.d.ts +52 -0
  910. package/dist/types/components/picker-legacy/picker.d.ts +159 -0
  911. package/dist/types/components/picker-legacy-column/picker-column.d.ts +46 -0
  912. package/dist/types/components/picker-legacy-column/test/test.utils.d.ts +9 -0
  913. package/dist/types/components/popover/popover-interface.d.ts +3 -6
  914. package/dist/types/components/popover/popover.d.ts +6 -5
  915. package/dist/types/components/progress-bar/progress-bar.d.ts +10 -1
  916. package/dist/types/components/radio/radio.d.ts +2 -1
  917. package/dist/types/components/radio-group/radio-group.d.ts +12 -0
  918. package/dist/types/components/range/range.d.ts +2 -1
  919. package/dist/types/components/refresher/refresher.d.ts +2 -1
  920. package/dist/types/components/refresher-content/refresher-content.d.ts +4 -0
  921. package/dist/types/components/reorder/reorder.d.ts +9 -0
  922. package/dist/types/components/reorder-group/reorder-group.d.ts +4 -0
  923. package/dist/types/components/ripple-effect/ripple-effect.d.ts +4 -0
  924. package/dist/types/components/route/route.d.ts +4 -0
  925. package/dist/types/components/router/router.d.ts +4 -0
  926. package/dist/types/components/router-link/router-link.d.ts +4 -0
  927. package/dist/types/components/router-outlet/router-outlet.d.ts +4 -8
  928. package/dist/types/components/row/row.d.ts +4 -0
  929. package/dist/types/components/searchbar/searchbar.d.ts +51 -9
  930. package/dist/types/components/segment/segment.d.ts +2 -1
  931. package/dist/types/components/segment-button/segment-button.d.ts +2 -1
  932. package/dist/types/components/select/select-interface.d.ts +23 -0
  933. package/dist/types/components/select/select.d.ts +66 -13
  934. package/dist/types/components/select-modal/select-modal.d.ts +8 -0
  935. package/dist/types/components/select-option/select-option.d.ts +12 -0
  936. package/dist/types/components/select-popover/select-popover.d.ts +3 -0
  937. package/dist/types/components/skeleton-text/skeleton-text.d.ts +4 -0
  938. package/dist/types/components/spinner/spinner.d.ts +15 -0
  939. package/dist/types/components/split-pane/split-pane.d.ts +4 -0
  940. package/dist/types/components/tab/tab.d.ts +4 -0
  941. package/dist/types/components/tab-bar/tab-bar.d.ts +37 -2
  942. package/dist/types/components/tab-button/tab-button.d.ts +12 -1
  943. package/dist/types/components/tabs/tabs.d.ts +3 -0
  944. package/dist/types/components/text/text.d.ts +2 -1
  945. package/dist/types/components/textarea/textarea.d.ts +53 -4
  946. package/dist/types/components/thumbnail/thumbnail.d.ts +4 -0
  947. package/dist/types/components/title/title.d.ts +4 -0
  948. package/dist/types/components/toast/animations/utils.d.ts +2 -2
  949. package/dist/types/components/toast/toast-interface.d.ts +3 -7
  950. package/dist/types/components/toast/toast.d.ts +19 -2
  951. package/dist/types/components/toggle/toggle.d.ts +15 -1
  952. package/dist/types/components/toolbar/toolbar.d.ts +43 -3
  953. package/dist/types/components.d.ts +2102 -252
  954. package/dist/types/global/ionic-global.d.ts +28 -2
  955. package/dist/types/index.d.ts +1 -1
  956. package/dist/types/interface.d.ts +4 -0
  957. package/dist/types/utils/config.d.ts +114 -2
  958. package/dist/types/utils/focus-trap.d.ts +1 -1
  959. package/dist/types/utils/focus-visible.d.ts +13 -0
  960. package/dist/types/utils/forms/validity.d.ts +7 -0
  961. package/dist/types/utils/helpers.d.ts +11 -0
  962. package/dist/types/utils/overlays-interface.d.ts +31 -1
  963. package/dist/types/utils/overlays.d.ts +10 -12
  964. package/dist/types/utils/select-option-render.d.ts +22 -0
  965. package/dist/types/utils/test/playwright/drag-element.d.ts +16 -3
  966. package/dist/types/utils/test/playwright/generator.d.ts +31 -2
  967. package/dist/types/utils/theme.d.ts +9 -0
  968. package/hydrate/index.js +5403 -1380
  969. package/hydrate/index.mjs +5403 -1380
  970. package/package.json +10 -6
  971. package/components/p-B6FQ0cKR.js +0 -4
  972. package/components/p-B6HaBl3o.js +0 -4
  973. package/components/p-B8b1Ukl9.js +0 -4
  974. package/components/p-BGHGpkPX.js +0 -4
  975. package/components/p-BHlzkIpO.js +0 -4
  976. package/components/p-BJoMtgfR.js +0 -4
  977. package/components/p-BNAG-aVv.js +0 -4
  978. package/components/p-BR3tZJmu.js +0 -4
  979. package/components/p-BUbsoBOV.js +0 -4
  980. package/components/p-BYDc3hSE.js +0 -4
  981. package/components/p-BagjAGC0.js +0 -4
  982. package/components/p-BeL7B3Bb.js +0 -4
  983. package/components/p-Bg7NsGS9.js +0 -4
  984. package/components/p-BgwEQWW6.js +0 -4
  985. package/components/p-BmVRXR1y.js +0 -4
  986. package/components/p-BxwWvu-b.js +0 -4
  987. package/components/p-C4jPsTQa.js +0 -4
  988. package/components/p-C59ryAuS.js +0 -4
  989. package/components/p-CBzELu-H.js +0 -4
  990. package/components/p-CDXBV7oG.js +0 -4
  991. package/components/p-CDfQnFrd.js +0 -4
  992. package/components/p-CIGNaXM1.js +0 -4
  993. package/components/p-CO7fmmxt.js +0 -4
  994. package/components/p-CU1SSH8_.js +0 -4
  995. package/components/p-CWpbvhwY.js +0 -4
  996. package/components/p-CgqKJg96.js +0 -4
  997. package/components/p-CneGxKsZ.js +0 -4
  998. package/components/p-CoA-aqGF.js +0 -4
  999. package/components/p-Csw8xuz4.js +0 -4
  1000. package/components/p-Ct3FLpwo.js +0 -4
  1001. package/components/p-CtWGkNnJ.js +0 -4
  1002. package/components/p-Cy5XSfIk.js +0 -4
  1003. package/components/p-Cz5nLPGT.js +0 -4
  1004. package/components/p-D6NJwNJN.js +0 -4
  1005. package/components/p-D6Ynv7Xh.js +0 -4
  1006. package/components/p-DBHdZu4y.js +0 -4
  1007. package/components/p-DJztqcrH.js +0 -4
  1008. package/components/p-DL2W2mt3.js +0 -4
  1009. package/components/p-DPdqO7R6.js +0 -4
  1010. package/components/p-DYdpXONG.js +0 -4
  1011. package/components/p-DbISMmiI.js +0 -4
  1012. package/components/p-DgbT0exM.js +0 -4
  1013. package/components/p-DiVJyqlX.js +0 -4
  1014. package/components/p-DrIm1s9R.js +0 -4
  1015. package/components/p-DvOO1fxp.js +0 -4
  1016. package/components/p-DxXmSp9Y.js +0 -4
  1017. package/components/p-FBcnjE5W.js +0 -4
  1018. package/components/p-OOMJP0jy.js +0 -4
  1019. package/components/p-SBseW5KJ.js +0 -4
  1020. package/components/p-ZjP4CjeZ.js +0 -4
  1021. package/components/p-nPoOPlPt.js +0 -4
  1022. package/components/p-vEbVo2hO.js +0 -4
  1023. package/dist/cjs/hardware-back-button-C4rMJ5uI.js +0 -121
  1024. package/dist/cjs/index-DkNv4J_i.js +0 -10
  1025. package/dist/cjs/ionic-global-Bc3kJi1Z.js +0 -151
  1026. package/dist/cjs/validity-BpS37YFM.js +0 -19
  1027. package/dist/esm/hardware-back-button-CTe4XmL7.js +0 -115
  1028. package/dist/esm/index-ZjP4CjeZ.js +0 -7
  1029. package/dist/esm/ionic-global-DfbeLwcV.js +0 -146
  1030. package/dist/esm/validity-DJztqcrH.js +0 -17
  1031. package/dist/ionic/p-045a6a42.entry.js +0 -4
  1032. package/dist/ionic/p-078037da.entry.js +0 -4
  1033. package/dist/ionic/p-18b5d5ff.entry.js +0 -4
  1034. package/dist/ionic/p-19adf785.entry.js +0 -4
  1035. package/dist/ionic/p-1d2163ad.entry.js +0 -4
  1036. package/dist/ionic/p-2089f9cb.entry.js +0 -4
  1037. package/dist/ionic/p-23ec35e4.entry.js +0 -4
  1038. package/dist/ionic/p-30f5ad9e.entry.js +0 -4
  1039. package/dist/ionic/p-34b3a309.entry.js +0 -4
  1040. package/dist/ionic/p-370a60ee.entry.js +0 -4
  1041. package/dist/ionic/p-3b58996c.entry.js +0 -4
  1042. package/dist/ionic/p-460fbe5b.entry.js +0 -4
  1043. package/dist/ionic/p-4c8d8c55.entry.js +0 -4
  1044. package/dist/ionic/p-4ea520a4.entry.js +0 -4
  1045. package/dist/ionic/p-4ed63122.entry.js +0 -4
  1046. package/dist/ionic/p-4f3a8ccf.entry.js +0 -4
  1047. package/dist/ionic/p-506038d3.entry.js +0 -4
  1048. package/dist/ionic/p-528d4c1d.entry.js +0 -4
  1049. package/dist/ionic/p-5430ae94.entry.js +0 -4
  1050. package/dist/ionic/p-5c2cc090.entry.js +0 -4
  1051. package/dist/ionic/p-6406d5a9.entry.js +0 -4
  1052. package/dist/ionic/p-66494f9b.entry.js +0 -4
  1053. package/dist/ionic/p-6af16209.entry.js +0 -4
  1054. package/dist/ionic/p-6b97f2a3.entry.js +0 -4
  1055. package/dist/ionic/p-6da572e7.entry.js +0 -4
  1056. package/dist/ionic/p-6e99ae8d.entry.js +0 -4
  1057. package/dist/ionic/p-7f269aff.entry.js +0 -4
  1058. package/dist/ionic/p-7f9db51b.entry.js +0 -4
  1059. package/dist/ionic/p-7fe42b71.entry.js +0 -4
  1060. package/dist/ionic/p-87125490.entry.js +0 -4
  1061. package/dist/ionic/p-898f9d11.entry.js +0 -4
  1062. package/dist/ionic/p-8a3a936b.entry.js +0 -4
  1063. package/dist/ionic/p-9833cf63.entry.js +0 -4
  1064. package/dist/ionic/p-9eeaBrnk.js +0 -4
  1065. package/dist/ionic/p-AlrZKoWR.js +0 -4
  1066. package/dist/ionic/p-BAt5H1ac.js +0 -4
  1067. package/dist/ionic/p-BW_TRJm8.js +0 -4
  1068. package/dist/ionic/p-BmVRXR1y.js +0 -4
  1069. package/dist/ionic/p-Bum7H1fw.js +0 -4
  1070. package/dist/ionic/p-BxIcPWoV.js +0 -4
  1071. package/dist/ionic/p-C0JvVFMv.js +0 -4
  1072. package/dist/ionic/p-CGmVTdWh.js +0 -4
  1073. package/dist/ionic/p-CIGNaXM1.js +0 -4
  1074. package/dist/ionic/p-CYbRmDdy.js +0 -4
  1075. package/dist/ionic/p-CYvM5g3q.js +0 -4
  1076. package/dist/ionic/p-CmFz1Mjc.js +0 -4
  1077. package/dist/ionic/p-Csx_Ej2k.js +0 -4
  1078. package/dist/ionic/p-CtA-yJYy.js +0 -4
  1079. package/dist/ionic/p-CtWGkNnJ.js +0 -4
  1080. package/dist/ionic/p-D8HJQ1qq.js +0 -4
  1081. package/dist/ionic/p-DB_iPQC-.js +0 -4
  1082. package/dist/ionic/p-DJztqcrH.js +0 -4
  1083. package/dist/ionic/p-DLbbmF9h.js +0 -4
  1084. package/dist/ionic/p-DiVJyqlX.js +0 -4
  1085. package/dist/ionic/p-DtVZDHlS.js +0 -4
  1086. package/dist/ionic/p-IGIE5vDm.js +0 -5
  1087. package/dist/ionic/p-NFFyoJ4Q.js +0 -4
  1088. package/dist/ionic/p-ZjP4CjeZ.js +0 -4
  1089. package/dist/ionic/p-a39db980.entry.js +0 -4
  1090. package/dist/ionic/p-a805674e.entry.js +0 -4
  1091. package/dist/ionic/p-b553828c.entry.js +0 -4
  1092. package/dist/ionic/p-b5e3e1f7.entry.js +0 -4
  1093. package/dist/ionic/p-b6e0ff03.entry.js +0 -4
  1094. package/dist/ionic/p-b6f16f18.entry.js +0 -4
  1095. package/dist/ionic/p-b8f4a31c.entry.js +0 -4
  1096. package/dist/ionic/p-ca31010f.entry.js +0 -4
  1097. package/dist/ionic/p-cce0cd26.entry.js +0 -4
  1098. package/dist/ionic/p-d92ba088.entry.js +0 -4
  1099. package/dist/ionic/p-dc198c3a.entry.js +0 -4
  1100. package/dist/ionic/p-e663bc5a.entry.js +0 -4
  1101. package/dist/ionic/p-e6cedcd7.entry.js +0 -4
  1102. package/dist/ionic/p-e9dd191b.entry.js +0 -4
  1103. package/dist/ionic/p-ede28b71.entry.js +0 -4
  1104. package/dist/ionic/p-f17d05e3.entry.js +0 -4
  1105. package/dist/ionic/p-f5dfb9a3.entry.js +0 -4
  1106. package/dist/ionic/p-f7762013.entry.js +0 -4
  1107. package/dist/ionic/p-fed27c64.entry.js +0 -4
  1108. package/dist/ionic/p-gbVXD275.js +0 -4
  1109. package/dist/ionic/p-hNN3VvaC.js +0 -4
  1110. /package/dist/collection/components/{input-password-toggle/input-password-toggle.css → refresher-content/refresher-content.css} +0 -0
@@ -3,19 +3,23 @@
3
3
  */
4
4
  'use strict';
5
5
 
6
- var index = require('./index-CqT-2gKy.js');
7
- var focusVisible = require('./focus-visible-CCvKiLh3.js');
8
- var helpers = require('./helpers-CxTYJdbT.js');
9
- var overlays = require('./overlays-DIfHxkst.js');
6
+ var index = require('./index-CzcLEdQ5.js');
7
+ var caretLeft = require('./caret-left-CxZXLRv5.js');
8
+ var caretRight = require('./caret-right-CRCgv98E.js');
9
+ var focusVisible = require('./focus-visible-BIj-I3-C.js');
10
+ var helpers = require('./helpers-DJYxKN5U.js');
11
+ var overlays = require('./overlays-Hci_7vw_.js');
10
12
  var dir = require('./dir-Cn0z1rJH.js');
11
- var theme = require('./theme-CeDs6Hcv.js');
12
- var index$1 = require('./index-DqmRDbxg.js');
13
- var ionicGlobal = require('./ionic-global-Bc3kJi1Z.js');
14
- var data = require('./data-BYlBjkMU.js');
15
- require('./index-DkNv4J_i.js');
16
- require('./hardware-back-button-C4rMJ5uI.js');
17
- require('./framework-delegate-CRgp8o_p.js');
13
+ var theme = require('./theme-IlOsGAz7.js');
14
+ var index$1 = require('./index-CgAbCW6L.js');
15
+ var ionicGlobal = require('./ionic-global-CSEbHD_F.js');
16
+ var data = require('./data-DuOuKG7I.js');
17
+ var lockController = require('./lock-controller-aDB9wrEf.js');
18
+ var animation = require('./animation-DknMeJ3x.js');
19
+ var haptic = require('./haptic-D3Ay9mmg.js');
20
+ require('./framework-delegate-Dx9FrqAC.js');
18
21
  require('./gesture-controller-dtqlP_q4.js');
22
+ require('./capacitor-BnRBm_ys.js');
19
23
 
20
24
  const isYearDisabled = (refYear, minParts, maxParts) => {
21
25
  if (minParts && minParts.year > refYear) {
@@ -227,9 +231,11 @@ const checkForPresentationFormatMismatch = (el, presentation, formatOptions) =>
227
231
  }
228
232
  };
229
233
 
230
- const datetimeIosCss = () => `:host{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;background:var(--background);overflow:hidden}: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}: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-button{--background:transparent}: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:not(.calendar-day-adjacent-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, var(--ion-background-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 .calendar-month-year-toggle{color:var(--ion-color-base)}.calendar-month-year{min-width:0}.calendar-month-year-toggle{font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;text-align:inherit;white-space:inherit;color:inherit;position:relative;border:0;outline:none;background:transparent;cursor:pointer;z-index:1}.calendar-month-year-toggle::after{left:0;right:0;top:0;bottom:0;position:absolute;content:"";opacity:0;-webkit-transition:opacity 15ms linear, background-color 15ms linear;transition:opacity 15ms linear, background-color 15ms linear;z-index:-1}.calendar-month-year-toggle.ion-focused::after{background:currentColor}.calendar-month-year-toggle:disabled{opacity:0.3;pointer-events:none}.calendar-month-year-toggle ion-icon{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:0;padding-inline-end:0;padding-top:0;padding-bottom:0;-ms-flex-negative:0;flex-shrink:0}.calendar-month-year-toggle #toggle-wrapper{display:-ms-inline-flexbox;display:inline-flex;-ms-flex-align:center;align-items:center}ion-picker{--highlight-background:var(--wheel-highlight-background);--highlight-border-radius:var(--wheel-highlight-border-radius);--fade-background-rgb:var(--wheel-fade-background-rgb)}:host{--background:var(--ion-color-light, #f4f5f8);--background-rgb:var(--ion-color-light-rgb, 244, 245, 248);--title-color:var(--ion-color-step-600, var(--ion-text-color-step-400, #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, var(--ion-background-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}.calendar-month-year-toggle{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:0px;padding-bottom:0px;min-height:44px;font-size:min(1rem, 25.6px);font-weight:600}.calendar-month-year-toggle.ion-focused::after{opacity:0.15}.calendar-month-year-toggle #toggle-wrapper{-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:8px;margin-inline-end:8px;margin-top:10px;margin-bottom:10px}:host .calendar-action-buttons .calendar-month-year-toggle ion-icon,:host .calendar-action-buttons ion-buttons ion-button{color:var(--ion-color-base)}:host .calendar-action-buttons ion-buttons{-ms-flex-align:stretch;align-items:stretch;height:100%}: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, var(--ion-text-color-step-700, #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);font-size:min(1.375rem, 35.2px)}:host .calendar-day.calendar-day-today{color:var(--ion-color-base)}:host .calendar-day.calendar-day-active,:host .calendar-day.calendar-day-adjacent-day.calendar-day-active{color:var(--ion-color-base);font-weight:600}:host .calendar-day.calendar-day-today.calendar-day-active{background:var(--ion-color-base);color:var(--ion-color-contrast)}:host .calendar-day.calendar-day-adjacent-day{color:var(--ion-color-step-300, var(--ion-text-color-step-700, #b3b3b3))}: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, var(--ion-background-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%}`;
234
+ const datetimeIonicCss = () => `:host{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;background:var(--background);overflow:hidden}:host(.datetime-size-fixed){width:auto;height:auto}:host(.datetime-size-cover){width:100%}:host(:not(.datetime-ready)) .datetime-year{position:absolute;pointer-events:none}:host(.datetime-ready) .datetime-year{display:none}: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}: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,::slotted([slot=buttons]),.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-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{-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;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;z-index:0}.calendar-day[disabled]{pointer-events:none}:host .datetime-time{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host .time-header{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}:host .time-body{display:-ms-flexbox;display:flex;border:none;font-family:inherit;font-size:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}:host(.in-item){position:static}.calendar-month-year{min-width:0}.calendar-month-year-toggle{color:inherit;font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-align:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;white-space:inherit;position:relative;border:0;outline:none;background:transparent;cursor:pointer;z-index:1}.calendar-month-year-toggle ion-icon{-ms-flex-negative:0;flex-shrink:0}.calendar-month-year-toggle #toggle-wrapper{display:-ms-inline-flexbox;display:inline-flex;-ms-flex-align:center;align-items:center}:host{--background:var(--token-bg-surface-default, var(--token-primitives-base-white, #ffffff));--focus-ring-color:var(--token-border-focus-default, var(--token-primitives-blue-400, #b5c0f7));--focus-ring-width:var(--token-border-radius-025, var(--token-scale-050, 2px));--body-opacity:0;--year-opacity:0}:host .calendar-body{opacity:var(--body-opacity)}:host .datetime-year{opacity:var(--year-opacity)}:host(.datetime-ready) .calendar-body{--body-opacity:1}:host(.datetime-ready) .datetime-year{--year-opacity:1}:host .datetime-header{-webkit-padding-start:var(--token-space-400, var(--token-scale-400, 16px));padding-inline-start:var(--token-space-400, var(--token-scale-400, 16px));-webkit-padding-end:var(--token-space-400, var(--token-scale-400, 16px));padding-inline-end:var(--token-space-400, var(--token-scale-400, 16px));padding-top:var(--token-space-200, var(--token-scale-200, 8px));padding-bottom:var(--token-space-400, var(--token-scale-400, 16px));display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;-ms-flex-align:start;align-items:start;-ms-flex-pack:justify;justify-content:space-between;height:var(--token-scale-1400, 56px);margin-bottom:var(--token-space-200, var(--token-scale-200, 8px));border-bottom:var(--token-border-style-solid, solid) var(--token-border-size-025, var(--token-scale-025, 1px)) var(--token-primitives-neutral-400, #d5d5d5)}:host .datetime-header .datetime-title{font-size:var(--token-font-size-450, 1.125rem);font-weight:var(--token-font-weight-medium, 500);letter-spacing:var(--token-font-letter-spacing-0, 0%);line-height:var(--token-font-line-height-700, var(--token-scale-700, 28px));text-decoration:none;text-transform:none;color:var(--token-primitives-neutral-800, #626262)}:host .datetime-header .datetime-selected-date{font-size:var(--token-font-size-350, 0.875rem);font-weight:var(--token-font-weight-regular, 400);letter-spacing:var(--token-font-letter-spacing-0, 0%);line-height:var(--token-font-line-height-600, var(--token-scale-600, 24px));text-decoration:none;text-transform:none;color:var(--token-primitives-neutral-1000, #3b3b3b)}.calendar-action-buttons{padding-top:var(--token-space-200, var(--token-scale-200, 8px));padding-bottom:var(--token-space-200, var(--token-scale-200, 8px));-ms-flex-align:center;align-items:center;height:var(--token-scale-1400, 56px);-webkit-box-sizing:border-box;box-sizing:border-box}.calendar-month-year{-ms-flex:1 0 0px;flex:1 0 0}.calendar-month-year-toggle{border-radius:var(--token-border-radius-full, 999px);font-size:var(--token-font-size-400, 1rem);font-weight:var(--token-font-weight-medium, 500);letter-spacing:var(--token-font-letter-spacing-1, 1%);line-height:var(--token-font-line-height-600, var(--token-scale-600, 24px));text-decoration:none;text-transform:none;-webkit-padding-start:var(--token-space-400, var(--token-scale-400, 16px));padding-inline-start:var(--token-space-400, var(--token-scale-400, 16px));-webkit-padding-end:var(--token-space-400, var(--token-scale-400, 16px));padding-inline-end:var(--token-space-400, var(--token-scale-400, 16px));padding-top:var(--token-space-200, var(--token-scale-200, 8px));padding-bottom:var(--token-space-200, var(--token-scale-200, 8px));min-width:var(--token-scale-1600, 64px);min-height:var(--token-scale-1000, 40px);border:var(--focus-ring-width) var(--token-border-style-solid, solid) transparent;color:var(--token-semantics-primary-base, var(--token-semantics-primary-700, var(--token-primitives-blue-700, #105cef)))}@media (any-hover: hover){.calendar-month-year-toggle:hover{background:var(--token-primitives-neutral-200, #eae9e9)}}.calendar-month-year-toggle.ion-focused{border-color:var(--focus-ring-color)}.calendar-month-year-toggle.ion-activated{background:var(--token-primitives-neutral-200, #eae9e9)}.calendar-next-prev ion-button.button-has-icon-only{--color:var(--token-primitives-neutral-1000, #3b3b3b);--background-activated:var(--token-primitives-neutral-200, #eae9e9);--background-hover:var(--token-primitives-neutral-200, #eae9e9);--background-hover-opacity:1;min-height:var(--token-scale-1000, 40px)}.calendar-next-prev ion-button.button-has-icon-only.ion-focused::part(native){border:var(--token-border-size-050, var(--token-scale-050, 2px)) var(--token-border-style-solid, solid) var(--token-border-focus-default, var(--token-primitives-blue-400, #b5c0f7));outline:none}.calendar-days-of-week{font-size:var(--token-font-size-300, 0.75rem);font-weight:var(--token-font-weight-medium, 500);letter-spacing:var(--token-font-letter-spacing-2, 1.5%);line-height:var(--token-font-line-height-500, var(--token-scale-500, 20px));text-decoration:none;text-transform:uppercase;-ms-flex-line-pack:center;align-content:center;height:var(--token-scale-1200, 48px);color:var(--token-primitives-neutral-800, #626262)}.calendar-day{border-radius:var(--token-border-radius-full, 999px);-webkit-padding-start:var(--token-space-100, var(--token-scale-100, 4px));padding-inline-start:var(--token-space-100, var(--token-scale-100, 4px));-webkit-padding-end:var(--token-space-100, var(--token-scale-100, 4px));padding-inline-end:var(--token-space-100, var(--token-scale-100, 4px));padding-top:var(--token-space-100, var(--token-scale-100, 4px));padding-bottom:var(--token-space-100, var(--token-scale-100, 4px));font-size:var(--token-font-size-350, 0.875rem);font-weight:var(--token-font-weight-medium, 500);letter-spacing:var(--token-font-letter-spacing-1, 1%);line-height:var(--token-font-line-height-500, var(--token-scale-500, 20px));text-decoration:none;text-transform:none;width:var(--token-scale-1200, 48px);min-width:var(--token-scale-1200, 48px);height:var(--token-scale-1200, 48px);color:var(--token-text-default, var(--token-primitives-neutral-1200, #242424))}.calendar-day[disabled]:not(.calendar-day-constrained){color:var(--token-primitives-neutral-500, #a2a2a2)}.calendar-day.calendar-day-today{color:var(--token-semantics-primary-base, var(--token-semantics-primary-700, var(--token-primitives-blue-700, #105cef)))}.calendar-day.calendar-day-active,.calendar-day.calendar-day-active.calendar-day-adjacent-day{background:var(--token-semantics-primary-100, var(--token-primitives-blue-100, #e9ecfc))}.calendar-day:focus-visible{border:var(--focus-ring-width) var(--token-border-style-solid, solid) var(--focus-ring-color)}@media (any-hover: hover){.calendar-day:not([disabled]):not(:active):hover{background:var(--token-semantics-primary-200, var(--token-primitives-blue-200, #e4e8ff))}}.calendar-day:active,.calendar-day.calendar-day-adjacent-day:active{background:var(--token-bg-primary-subtle-press, var(--token-semantics-primary-300, var(--token-primitives-blue-300, #d0d7fa)))}.calendar-day.calendar-day-adjacent-day{color:var(--token-text-subtlest, var(--token-primitives-neutral-800, #626262))}.calendar-day.calendar-day-active.calendar-day-adjacent-day{color:var(--token-text-default, var(--token-primitives-neutral-1200, #242424))}:host .datetime-time{-webkit-padding-start:var(--token-space-400, var(--token-scale-400, 16px));padding-inline-start:var(--token-space-400, var(--token-scale-400, 16px));-webkit-padding-end:var(--token-space-400, var(--token-scale-400, 16px));padding-inline-end:var(--token-space-400, var(--token-scale-400, 16px));padding-top:var(--token-space-100, var(--token-scale-100, 4px));padding-bottom:var(--token-space-100, var(--token-scale-100, 4px))}:host .datetime-time .time-header{font-size:var(--token-font-size-400, 1rem);font-weight:var(--token-font-weight-medium, 500);letter-spacing:var(--token-font-letter-spacing-1, 1%);line-height:var(--token-font-line-height-600, var(--token-scale-600, 24px));text-decoration:none;text-transform:none;color:var(--token-primitives-neutral-800, #626262)}:host .datetime-time button{-webkit-padding-start:var(--token-space-200, var(--token-scale-200, 8px));padding-inline-start:var(--token-space-200, var(--token-scale-200, 8px));-webkit-padding-end:var(--token-space-200, var(--token-scale-200, 8px));padding-inline-end:var(--token-space-200, var(--token-scale-200, 8px));padding-top:var(--token-space-0, var(--token-scale-0, 0px));padding-bottom:var(--token-space-0, var(--token-scale-0, 0px));font-size:var(--token-font-size-350, 0.875rem);font-weight:var(--token-font-weight-medium, 500);letter-spacing:var(--token-font-letter-spacing-0, 0%);line-height:var(--token-font-line-height-600, var(--token-scale-600, 24px));text-decoration:none;text-transform:none;border-radius:var(--token-border-radius-full, 999px);display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;height:var(--token-scale-800, 32px);background-color:var(--token-primitives-neutral-100, #f3f3f3);color:var(--token-text-default, var(--token-primitives-neutral-1200, #242424))}:host .datetime-footer{padding-left:0;padding-right:0;padding-top:var(--token-space-200, var(--token-scale-200, 8px));padding-bottom:0;margin-left:0;margin-right:0;margin-top:var(--token-space-200, var(--token-scale-200, 8px));margin-bottom:0;border-left:0;border-right:0;border-top:var(--token-border-style-solid, solid) var(--token-border-size-025, var(--token-scale-025, 1px)) var(--token-primitives-neutral-400, #d5d5d5);border-bottom:0}:host .datetime-buttons .datetime-action-buttons,.datetime-action-buttons .datetime-action-buttons-container,::slotted([slot=buttons]){-ms-flex-flow:column;flex-flow:column;-ms-flex-align:stretch;align-items:stretch;gap:var(--token-space-200, var(--token-scale-200, 8px))}`;
231
235
 
232
- const datetimeMdCss = () => `:host{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;background:var(--background);overflow:hidden}: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}: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-button{--background:transparent}: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:not(.calendar-day-adjacent-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, var(--ion-background-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 .calendar-month-year-toggle{color:var(--ion-color-base)}.calendar-month-year{min-width:0}.calendar-month-year-toggle{font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;text-align:inherit;white-space:inherit;color:inherit;position:relative;border:0;outline:none;background:transparent;cursor:pointer;z-index:1}.calendar-month-year-toggle::after{left:0;right:0;top:0;bottom:0;position:absolute;content:"";opacity:0;-webkit-transition:opacity 15ms linear, background-color 15ms linear;transition:opacity 15ms linear, background-color 15ms linear;z-index:-1}.calendar-month-year-toggle.ion-focused::after{background:currentColor}.calendar-month-year-toggle:disabled{opacity:0.3;pointer-events:none}.calendar-month-year-toggle ion-icon{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:0;padding-inline-end:0;padding-top:0;padding-bottom:0;-ms-flex-negative:0;flex-shrink:0}.calendar-month-year-toggle #toggle-wrapper{display:-ms-inline-flexbox;display:inline-flex;-ms-flex-align:center;align-items:center}ion-picker{--highlight-background:var(--wheel-highlight-background);--highlight-border-radius:var(--wheel-highlight-border-radius);--fade-background-rgb:var(--wheel-fade-background-rgb)}:host{--background:var(--ion-color-step-100, var(--ion-background-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 .calendar-action-buttons ion-button{--color:var(--ion-color-step-650, var(--ion-text-color-step-350, #595959))}.calendar-month-year-toggle{-webkit-padding-start:20px;padding-inline-start:20px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:12px;padding-bottom:12px;min-height:48px;background:transparent;color:var(--ion-color-step-650, var(--ion-text-color-step-350, #595959));z-index:1}.calendar-month-year-toggle.ion-focused::after{opacity:0.04}.calendar-month-year-toggle ion-ripple-effect{color:currentColor}@media (any-hover: hover){.calendar-month-year-toggle.ion-activatable:not(.ion-focused):hover::after{background:currentColor;opacity:0.04}}: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, var(--ion-text-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,:host .calendar-day.calendar-day-adjacent-day.calendar-day-active{color:var(--ion-color-contrast)}.calendar-day.calendar-day-active,.calendar-day.calendar-day-active:focus{border:1px solid var(--ion-color-base);background:var(--ion-color-base)}:host .calendar-day.calendar-day-adjacent-day{color:var(--ion-color-step-500, var(--ion-text-color-step-500, gray))}: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, var(--ion-text-color-step-350, #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}`;
236
+ const datetimeIosCss = () => `:host{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;background:var(--background);overflow:hidden}:host(.datetime-size-fixed){width:auto;height:auto}:host(.datetime-size-cover){width:100%}:host(:not(.datetime-ready)) .datetime-year{position:absolute;pointer-events:none}:host(.datetime-ready) .datetime-year{display:none}: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}: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,::slotted([slot=buttons]),.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-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{-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;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;z-index:0}.calendar-day[disabled]{pointer-events:none}:host .datetime-time{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host .time-header{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}:host .time-body{display:-ms-flexbox;display:flex;border:none;font-family:inherit;font-size:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}:host(.in-item){position:static}.calendar-month-year{min-width:0}.calendar-month-year-toggle{color:inherit;font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-align:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;white-space:inherit;position:relative;border:0;outline:none;background:transparent;cursor:pointer;z-index:1}.calendar-month-year-toggle ion-icon{-ms-flex-negative:0;flex-shrink:0}.calendar-month-year-toggle #toggle-wrapper{display:-ms-inline-flexbox;display:inline-flex;-ms-flex-align:center;align-items:center}:host{}:host(.datetime-size-fixed:not(.datetime-prefer-wheel)){max-width:350px}:host .calendar-body,:host .datetime-year{opacity:0}:host(.datetime-ready) .calendar-body,:host(.datetime-ready) .datetime-year{opacity:1}: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 .calendar-action-buttons ion-button{--background:transparent}.calendar-day{border-radius:50%;font-family:var(--ion-font-family, inherit)}:host .calendar-day[disabled]{opacity:0.4}.calendar-day:not(.calendar-day-adjacent-day):focus{background:current-color(base, 0.2);-webkit-box-shadow:0px 0px 0px 4px current-color(base, 0.2);box-shadow:0px 0px 0px 4px current-color(base, 0.2)}.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 .calendar-next-prev{display:-ms-flexbox;display:flex;-ms-flex-align:start;align-items:start}.calendar-next-prev ion-button ion-icon[slot=icon-only]{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}: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-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;background:var(--ion-color-step-300, var(--ion-background-color-step-300, #edeef0));color:var(--ion-text-color, #000)}:host .time-body-active{color:var(--ion-color-base)}:host(.show-month-and-year) .calendar-action-buttons .calendar-month-year-toggle{color:var(--ion-color-base)}.calendar-month-year-toggle::after{right:0;left:0;top:0;bottom:0;position:absolute;content:"";opacity:0;-webkit-transition:opacity 15ms linear, background-color 15ms linear;transition:opacity 15ms linear, background-color 15ms linear;z-index:-1}.calendar-month-year-toggle.ion-focused::after{background:currentColor}.calendar-month-year-toggle:disabled{opacity:0.3;pointer-events:none}.calendar-month-year-toggle ion-icon{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:0;padding-inline-end:0;padding-top:0;padding-bottom:0}ion-picker{--highlight-background:var(--wheel-highlight-background);--highlight-border-radius:var(--wheel-highlight-border-radius);--fade-background-rgb:var(--wheel-fade-background-rgb)}:host .datetime-action-buttons{-ms-flex-pack:justify;justify-content:space-between}:host{--background:var(--ion-color-light, #f4f5f8);--background-rgb:var(--ion-color-light-rgb, 244, 245, 248);--title-color:var(--ion-color-step-600, var(--ion-text-color-step-400, #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, var(--ion-background-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}.calendar-month-year-toggle{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:0px;padding-bottom:0px;min-height:44px;font-size:min(1rem, 25.6px);font-weight:600}.calendar-month-year-toggle.ion-focused::after{opacity:0.15}.calendar-month-year-toggle #toggle-wrapper{-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:8px;margin-inline-end:8px;margin-top:10px;margin-bottom:10px}:host .calendar-action-buttons .calendar-month-year-toggle ion-icon,:host .calendar-action-buttons ion-button{color:var(--ion-color-base)}:host .calendar-action-buttons ion-button{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}:host .calendar-action-buttons .calendar-next-prev{-ms-flex-align:stretch;align-items:stretch}.calendar-next-prev ion-button{--padding-top:0;--padding-bottom:0;--padding-start:5px;--padding-end:5px;-webkit-margin-start:2px;margin-inline-start:2px;-webkit-margin-end:2px;margin-inline-end:2px;min-height:32px}.calendar-next-prev ion-button ion-icon[slot=icon-only]{font-size:1.65em;line-height:0.67}: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, var(--ion-text-color-step-700, #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);font-size:min(1.375rem, 35.2px)}:host .calendar-day.calendar-day-today{color:var(--ion-color-base)}:host .calendar-day.calendar-day-active,:host .calendar-day.calendar-day-adjacent-day.calendar-day-active{color:var(--ion-color-base);font-weight:600}:host .calendar-day.calendar-day-today.calendar-day-active{background:var(--ion-color-base);color:var(--ion-color-contrast)}:host .calendar-day.calendar-day-adjacent-day{color:var(--ion-color-step-300, var(--ion-text-color-step-700, #b3b3b3))}: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, var(--ion-background-color-step-200, #cccccc))}:host .datetime-buttons,::slotted([slot=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,::slotted([slot=buttons]){width:100%}`;
237
+
238
+ const datetimeMdCss = () => `:host{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;background:var(--background);overflow:hidden}:host(.datetime-size-fixed){width:auto;height:auto}:host(.datetime-size-cover){width:100%}:host(:not(.datetime-ready)) .datetime-year{position:absolute;pointer-events:none}:host(.datetime-ready) .datetime-year{display:none}: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}: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,::slotted([slot=buttons]),.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-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{-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;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;z-index:0}.calendar-day[disabled]{pointer-events:none}:host .datetime-time{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host .time-header{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}:host .time-body{display:-ms-flexbox;display:flex;border:none;font-family:inherit;font-size:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}:host(.in-item){position:static}.calendar-month-year{min-width:0}.calendar-month-year-toggle{color:inherit;font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-align:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;white-space:inherit;position:relative;border:0;outline:none;background:transparent;cursor:pointer;z-index:1}.calendar-month-year-toggle ion-icon{-ms-flex-negative:0;flex-shrink:0}.calendar-month-year-toggle #toggle-wrapper{display:-ms-inline-flexbox;display:inline-flex;-ms-flex-align:center;align-items:center}:host{}:host(.datetime-size-fixed:not(.datetime-prefer-wheel)){max-width:350px}:host .calendar-body,:host .datetime-year{opacity:0}:host(.datetime-ready) .calendar-body,:host(.datetime-ready) .datetime-year{opacity:1}: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 .calendar-action-buttons ion-button{--background:transparent}.calendar-day{border-radius:50%;font-family:var(--ion-font-family, inherit)}:host .calendar-day[disabled]{opacity:0.4}.calendar-day:not(.calendar-day-adjacent-day):focus{background:current-color(base, 0.2);-webkit-box-shadow:0px 0px 0px 4px current-color(base, 0.2);box-shadow:0px 0px 0px 4px current-color(base, 0.2)}.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 .calendar-next-prev{display:-ms-flexbox;display:flex;-ms-flex-align:start;align-items:start}.calendar-next-prev ion-button ion-icon[slot=icon-only]{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}: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-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;background:var(--ion-color-step-300, var(--ion-background-color-step-300, #edeef0));color:var(--ion-text-color, #000)}:host .time-body-active{color:var(--ion-color-base)}:host(.show-month-and-year) .calendar-action-buttons .calendar-month-year-toggle{color:var(--ion-color-base)}.calendar-month-year-toggle::after{right:0;left:0;top:0;bottom:0;position:absolute;content:"";opacity:0;-webkit-transition:opacity 15ms linear, background-color 15ms linear;transition:opacity 15ms linear, background-color 15ms linear;z-index:-1}.calendar-month-year-toggle.ion-focused::after{background:currentColor}.calendar-month-year-toggle:disabled{opacity:0.3;pointer-events:none}.calendar-month-year-toggle ion-icon{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:0;padding-inline-end:0;padding-top:0;padding-bottom:0}ion-picker{--highlight-background:var(--wheel-highlight-background);--highlight-border-radius:var(--wheel-highlight-border-radius);--fade-background-rgb:var(--wheel-fade-background-rgb)}:host .datetime-action-buttons{-ms-flex-pack:justify;justify-content:space-between}:host{--background:var(--ion-color-step-100, var(--ion-background-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 .calendar-action-buttons ion-button{--color:var(--ion-color-step-650, var(--ion-text-color-step-350, #595959))}.calendar-next-prev ion-button{--padding-top:12px;--padding-end:12px;--padding-bottom:12px;--padding-start:12px;--border-radius:50%;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;width:3rem;height:3rem}.calendar-next-prev ion-button ion-icon[slot=icon-only]{font-size:1.8em}.calendar-month-year-toggle{-webkit-padding-start:20px;padding-inline-start:20px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:12px;padding-bottom:12px;min-height:48px;background:transparent;color:var(--ion-color-step-650, var(--ion-text-color-step-350, #595959));z-index:1}.calendar-month-year-toggle.ion-focused::after{opacity:0.04}.calendar-month-year-toggle ion-ripple-effect{color:currentColor}@media (any-hover: hover){.calendar-month-year-toggle.ion-activatable:not(.ion-focused):hover::after{background:currentColor;opacity:0.04}}: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, var(--ion-text-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,:host .calendar-day.calendar-day-adjacent-day.calendar-day-active{color:var(--ion-color-contrast)}.calendar-day.calendar-day-active,.calendar-day.calendar-day-active:focus{border:1px solid var(--ion-color-base);background:var(--ion-color-base)}:host .calendar-day.calendar-day-adjacent-day{color:var(--ion-color-step-500, var(--ion-text-color-step-500, gray))}: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, var(--ion-text-color-step-350, #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}`;
233
239
 
234
240
  const Datetime = class {
235
241
  constructor(hostRef) {
@@ -1306,6 +1312,7 @@ const Datetime = class {
1306
1312
  * are rendered independently of presentation.
1307
1313
  */
1308
1314
  renderFooter() {
1315
+ const theme = ionicGlobal.getIonTheme(this);
1309
1316
  const { disabled, readonly, showDefaultButtons, showClearButton } = this;
1310
1317
  /**
1311
1318
  * The cancel, clear, and confirm buttons
@@ -1313,6 +1320,7 @@ const Datetime = class {
1313
1320
  * is disabled or readonly.
1314
1321
  */
1315
1322
  const isButtonDisabled = disabled || readonly;
1323
+ const confirmFill = theme === 'ionic' ? 'solid' : undefined;
1316
1324
  const hasSlottedButtons = this.el.querySelector('[slot="buttons"]') !== null;
1317
1325
  if (!hasSlottedButtons && !showDefaultButtons && !showClearButton) {
1318
1326
  return;
@@ -1331,7 +1339,7 @@ const Datetime = class {
1331
1339
  return (index.h("div", { class: "datetime-footer" }, index.h("div", { class: "datetime-buttons" }, index.h("div", { class: {
1332
1340
  ['datetime-action-buttons']: true,
1333
1341
  ['has-clear-button']: this.showClearButton,
1334
- } }, index.h("slot", { name: "buttons" }, index.h("ion-buttons", null, showDefaultButtons && (index.h("ion-button", { id: "cancel-button", color: this.color, onClick: () => this.cancel(true), disabled: isButtonDisabled }, this.cancelText)), index.h("div", { class: "datetime-action-buttons-container" }, showClearButton && (index.h("ion-button", { id: "clear-button", color: this.color, onClick: () => clearButtonClick(), disabled: isButtonDisabled }, this.clearText)), showDefaultButtons && (index.h("ion-button", { id: "confirm-button", color: this.color, onClick: () => this.confirm(true), disabled: isButtonDisabled }, this.doneText)))))))));
1342
+ } }, index.h("slot", { name: "buttons" }, showDefaultButtons && (index.h("ion-button", { id: "cancel-button", color: this.color, onClick: () => this.cancel(true), disabled: isButtonDisabled }, this.cancelText)), index.h("div", { class: "datetime-action-buttons-container" }, showClearButton && (index.h("ion-button", { id: "clear-button", color: this.color, onClick: () => clearButtonClick(), disabled: isButtonDisabled }, this.clearText)), showDefaultButtons && (index.h("ion-button", { id: "confirm-button", fill: confirmFill, color: this.color, onClick: () => this.confirm(true), disabled: isButtonDisabled }, this.doneText))))))));
1335
1343
  }
1336
1344
  /**
1337
1345
  * Wheel picker render methods
@@ -1582,10 +1590,8 @@ const Datetime = class {
1582
1590
  /**
1583
1591
  * Grid Render Methods
1584
1592
  */
1585
- renderCalendarHeader(mode) {
1586
- const { disabled } = this;
1587
- const expandedIcon = mode === 'ios' ? index$1.chevronDown : index$1.caretUpSharp;
1588
- const collapsedIcon = mode === 'ios' ? index$1.chevronForward : index$1.caretDownSharp;
1593
+ renderCalendarHeader(theme) {
1594
+ const { disabled, datetimeNextIcon, datetimePreviousIcon, datetimeCollapsedIcon, datetimeExpandedIcon } = this;
1589
1595
  const prevMonthDisabled = disabled || isPrevMonthDisabled(this.workingParts, this.minParts, this.maxParts);
1590
1596
  const nextMonthDisabled = disabled || isNextMonthDisabled(this.workingParts, this.maxParts);
1591
1597
  // don't use the inheritAttributes util because it removes dir from the host, and we still need that
@@ -1594,7 +1600,7 @@ const Datetime = class {
1594
1600
  'calendar-month-year-toggle': true,
1595
1601
  'ion-activatable': true,
1596
1602
  'ion-focusable': true,
1597
- }, part: "month-year-button", disabled: disabled, "aria-label": this.showMonthAndYear ? 'Hide year picker' : 'Show year picker', onClick: () => this.toggleMonthAndYearView() }, index.h("span", { id: "toggle-wrapper" }, data.getMonthAndYear(this.locale, this.workingParts), index.h("ion-icon", { "aria-hidden": "true", icon: this.showMonthAndYear ? expandedIcon : collapsedIcon, lazy: false, flipRtl: true })), mode === 'md' && index.h("ion-ripple-effect", null))), index.h("div", { class: "calendar-next-prev" }, index.h("ion-buttons", null, index.h("ion-button", { "aria-label": "Previous month", disabled: prevMonthDisabled, onClick: () => this.prevMonth(), part: "navigation-button previous-button" }, index.h("ion-icon", { dir: hostDir, "aria-hidden": "true", slot: "icon-only", icon: index$1.chevronBack, lazy: false, flipRtl: true })), index.h("ion-button", { "aria-label": "Next month", disabled: nextMonthDisabled, onClick: () => this.nextMonth(), part: "navigation-button next-button" }, index.h("ion-icon", { dir: hostDir, "aria-hidden": "true", slot: "icon-only", icon: index$1.chevronForward, lazy: false, flipRtl: true }))))), index.h("div", { class: "calendar-days-of-week", "aria-hidden": "true", part: "calendar-days-of-week" }, data.getDaysOfWeek(this.locale, mode, this.firstDayOfWeek % 7).map((d) => {
1603
+ }, part: "month-year-button", disabled: disabled, "aria-label": this.showMonthAndYear ? 'Hide year picker' : 'Show year picker', onClick: () => this.toggleMonthAndYearView() }, index.h("span", { id: "toggle-wrapper" }, data.getMonthAndYear(this.locale, this.workingParts), theme !== 'ionic' && (index.h("ion-icon", { "aria-hidden": "true", icon: this.showMonthAndYear ? datetimeExpandedIcon : datetimeCollapsedIcon, lazy: false, flipRtl: true }))), theme === 'md' && index.h("ion-ripple-effect", null))), index.h("div", { class: "calendar-next-prev" }, index.h("ion-button", { "aria-label": "Previous month", disabled: prevMonthDisabled, onClick: () => this.prevMonth(), part: "navigation-button previous-button" }, index.h("ion-icon", { dir: hostDir, "aria-hidden": "true", slot: "icon-only", icon: datetimePreviousIcon, lazy: false, flipRtl: true })), index.h("ion-button", { "aria-label": "Next month", disabled: nextMonthDisabled, onClick: () => this.nextMonth(), part: "navigation-button next-button" }, index.h("ion-icon", { dir: hostDir, "aria-hidden": "true", slot: "icon-only", icon: datetimeNextIcon, lazy: false, flipRtl: true })))), index.h("div", { class: "calendar-days-of-week", "aria-hidden": "true", part: "calendar-days-of-week" }, data.getDaysOfWeek(this.locale, theme, this.firstDayOfWeek % 7).map((d) => {
1598
1604
  return index.h("div", { class: "day-of-week" }, d);
1599
1605
  }))));
1600
1606
  }
@@ -1746,8 +1752,8 @@ const Datetime = class {
1746
1752
  return this.renderMonth(month, year);
1747
1753
  })));
1748
1754
  }
1749
- renderCalendar(mode) {
1750
- return (index.h("div", { class: "datetime-calendar", key: "datetime-calendar" }, this.renderCalendarHeader(mode), this.renderCalendarBody()));
1755
+ renderCalendar(theme) {
1756
+ return (index.h("div", { class: "datetime-calendar", key: "datetime-calendar" }, this.renderCalendarHeader(theme), this.renderCalendarBody()));
1751
1757
  }
1752
1758
  renderTimeLabel() {
1753
1759
  const hasSlottedTimeLabel = this.el.querySelector('[slot="time-label"]') !== null;
@@ -1855,7 +1861,7 @@ const Datetime = class {
1855
1861
  * Render entry point
1856
1862
  * All presentation types are rendered from here.
1857
1863
  */
1858
- renderDatetime(mode) {
1864
+ renderDatetime(theme) {
1859
1865
  const { presentation, preferWheel } = this;
1860
1866
  /**
1861
1867
  * Certain presentation types have separate grid and wheel displays.
@@ -1869,7 +1875,7 @@ const Datetime = class {
1869
1875
  case 'date-time':
1870
1876
  return [
1871
1877
  this.renderHeader(),
1872
- this.renderCalendar(mode),
1878
+ this.renderCalendar(theme),
1873
1879
  this.renderCalendarViewMonthYearPicker(),
1874
1880
  this.renderTime(),
1875
1881
  this.renderFooter(),
@@ -1878,7 +1884,7 @@ const Datetime = class {
1878
1884
  return [
1879
1885
  this.renderHeader(),
1880
1886
  this.renderTime(),
1881
- this.renderCalendar(mode),
1887
+ this.renderCalendar(theme),
1882
1888
  this.renderCalendarViewMonthYearPicker(),
1883
1889
  this.renderFooter(),
1884
1890
  ];
@@ -1891,23 +1897,95 @@ const Datetime = class {
1891
1897
  default:
1892
1898
  return [
1893
1899
  this.renderHeader(),
1894
- this.renderCalendar(mode),
1900
+ this.renderCalendar(theme),
1895
1901
  this.renderCalendarViewMonthYearPicker(),
1896
1902
  this.renderFooter(),
1897
1903
  ];
1898
1904
  }
1899
1905
  }
1906
+ /**
1907
+ * Get the icon to use for the next icon.
1908
+ * Otherwise, use the icon set in the config.
1909
+ * If no icon is set in the config, use the default icon.
1910
+ */
1911
+ get datetimeNextIcon() {
1912
+ // Determine the theme and map to default icons
1913
+ const theme = ionicGlobal.getIonTheme(this);
1914
+ const defaultIcons = {
1915
+ ios: index$1.chevronForward,
1916
+ ionic: caretRight.caretRightSvg,
1917
+ md: index$1.chevronForward,
1918
+ };
1919
+ // Get the default icon based on the theme, falling back to 'md' icon if necessary
1920
+ const defaultIcon = defaultIcons[theme] || defaultIcons.md;
1921
+ // Return the configured datetime next icon or the default icon
1922
+ return index.config.get('datetimeNextIcon', defaultIcon);
1923
+ }
1924
+ /**
1925
+ * Get the icon to use for the previous icon.
1926
+ * Otherwise, use the icon set in the config.
1927
+ * If no icon is set in the config, use the default icon.
1928
+ */
1929
+ get datetimePreviousIcon() {
1930
+ // Determine the theme and map to default icons
1931
+ const theme = ionicGlobal.getIonTheme(this);
1932
+ const defaultIcons = {
1933
+ ios: index$1.chevronBack,
1934
+ ionic: caretLeft.caretLeftSvg,
1935
+ md: index$1.chevronBack,
1936
+ };
1937
+ // Get the default icon based on the theme, falling back to 'md' icon if necessary
1938
+ const defaultIcon = defaultIcons[theme] || defaultIcons.md;
1939
+ // Return the configured datetime previous icon or the default icon
1940
+ return index.config.get('datetimePreviousIcon', defaultIcon);
1941
+ }
1942
+ /**
1943
+ * Get the icon to use for the show month and year icon.
1944
+ * Otherwise, use the icon set in the config.
1945
+ * If no icon is set in the config, use the default icon.
1946
+ */
1947
+ get datetimeCollapsedIcon() {
1948
+ // Determine the theme and map to default icons
1949
+ const theme = ionicGlobal.getIonTheme(this);
1950
+ const defaultIcons = {
1951
+ ios: index$1.chevronForward,
1952
+ ionic: undefined,
1953
+ md: index$1.caretDownSharp,
1954
+ };
1955
+ // Get the default icon based on the theme, falling back to 'md' icon if necessary
1956
+ const defaultIcon = defaultIcons[theme] || defaultIcons.md;
1957
+ // Return the configured datetime show month and year icon or the default icon
1958
+ return index.config.get('datetimeCollapsedIcon', defaultIcon);
1959
+ }
1960
+ /**
1961
+ * Get the icon to use for the hide month and year icon.
1962
+ * Otherwise, use the icon set in the config.
1963
+ * If no icon is set in the config, use the default icon.
1964
+ */
1965
+ get datetimeExpandedIcon() {
1966
+ // Determine the theme and map to default icons
1967
+ const theme = ionicGlobal.getIonTheme(this);
1968
+ const defaultIcons = {
1969
+ ios: index$1.chevronDown,
1970
+ ionic: undefined,
1971
+ md: index$1.caretUpSharp,
1972
+ };
1973
+ // Get the default icon based on the theme, falling back to 'md' icon if necessary
1974
+ const defaultIcon = defaultIcons[theme] || defaultIcons.md;
1975
+ // Return the configured datetime hide month and year icon or the default icon
1976
+ return index.config.get('datetimeExpandedIcon', defaultIcon);
1977
+ }
1900
1978
  render() {
1901
1979
  const { name, value, disabled, el, color, readonly, showMonthAndYear, preferWheel, presentation, size, isGridStyle, } = this;
1902
- const mode = ionicGlobal.getIonMode(this);
1980
+ const theme$1 = ionicGlobal.getIonTheme(this);
1903
1981
  const isMonthAndYearPresentation = presentation === 'year' || presentation === 'month' || presentation === 'month-year';
1904
1982
  const shouldShowMonthAndYear = showMonthAndYear || isMonthAndYearPresentation;
1905
1983
  const monthYearPickerOpen = showMonthAndYear && !isMonthAndYearPresentation;
1906
1984
  const hasDatePresentation = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
1907
1985
  const hasWheelVariant = hasDatePresentation && preferWheel;
1908
1986
  helpers.renderHiddenInput(true, el, name, data.formatValue(value), disabled);
1909
- return (index.h(index.Host, { key: '59e0811aa273e88dfb8e4b703e6824088a457380', "aria-disabled": disabled ? 'true' : null, onFocus: this.onFocus, onBlur: this.onBlur, class: Object.assign({}, theme.createColorClasses(color, {
1910
- [mode]: true,
1987
+ return (index.h(index.Host, { key: 'c90187ed4b2fee08c43a974573d2c99403ce3f86', "aria-disabled": disabled ? 'true' : null, onFocus: this.onFocus, onBlur: this.onBlur, class: Object.assign({}, theme.createColorClasses(color, {
1988
+ [theme$1]: true,
1911
1989
  ['datetime-readonly']: readonly,
1912
1990
  ['datetime-disabled']: disabled,
1913
1991
  'show-month-and-year': shouldShowMonthAndYear,
@@ -1916,7 +1994,7 @@ const Datetime = class {
1916
1994
  [`datetime-size-${size}`]: true,
1917
1995
  [`datetime-prefer-wheel`]: hasWheelVariant,
1918
1996
  [`datetime-grid`]: isGridStyle,
1919
- })) }, index.h("div", { key: '3753ff3dde3085070916c3de83687a219a49e553', class: "intersection-tracker", ref: (el) => (this.intersectionTrackerRef = el) }), this.renderDatetime(mode)));
1997
+ })) }, index.h("div", { key: '8f3c1012906ba19de0c765636307dcdd59e61868', class: "intersection-tracker", ref: (el) => (this.intersectionTrackerRef = el) }), this.renderDatetime(theme$1)));
1920
1998
  }
1921
1999
  get el() { return index.getElement(this); }
1922
2000
  static get watchers() { return {
@@ -1962,8 +2040,643 @@ const WHEEL_PART = 'wheel';
1962
2040
  const WHEEL_ITEM_PART = 'wheel-item';
1963
2041
  const WHEEL_ITEM_ACTIVE_PART = `active`;
1964
2042
  Datetime.style = {
2043
+ ionic: datetimeIonicCss(),
1965
2044
  ios: datetimeIosCss(),
1966
2045
  md: datetimeMdCss()
1967
2046
  };
1968
2047
 
2048
+ /**
2049
+ * iOS Picker Enter Animation
2050
+ */
2051
+ const iosEnterAnimation = (baseEl) => {
2052
+ const baseAnimation = animation.createAnimation();
2053
+ const backdropAnimation = animation.createAnimation();
2054
+ const wrapperAnimation = animation.createAnimation();
2055
+ backdropAnimation
2056
+ .addElement(baseEl.querySelector('ion-backdrop'))
2057
+ .fromTo('opacity', 0.01, 'var(--backdrop-opacity)')
2058
+ .beforeStyles({
2059
+ 'pointer-events': 'none',
2060
+ })
2061
+ .afterClearStyles(['pointer-events']);
2062
+ wrapperAnimation
2063
+ .addElement(baseEl.querySelector('.picker-wrapper'))
2064
+ .fromTo('transform', 'translateY(100%)', 'translateY(0%)');
2065
+ return baseAnimation
2066
+ .addElement(baseEl)
2067
+ .easing('cubic-bezier(.36,.66,.04,1)')
2068
+ .duration(400)
2069
+ .addAnimation([backdropAnimation, wrapperAnimation]);
2070
+ };
2071
+
2072
+ /**
2073
+ * iOS Picker Leave Animation
2074
+ */
2075
+ const iosLeaveAnimation = (baseEl) => {
2076
+ const baseAnimation = animation.createAnimation();
2077
+ const backdropAnimation = animation.createAnimation();
2078
+ const wrapperAnimation = animation.createAnimation();
2079
+ backdropAnimation
2080
+ .addElement(baseEl.querySelector('ion-backdrop'))
2081
+ .fromTo('opacity', 'var(--backdrop-opacity)', 0.01);
2082
+ wrapperAnimation
2083
+ .addElement(baseEl.querySelector('.picker-wrapper'))
2084
+ .fromTo('transform', 'translateY(0%)', 'translateY(100%)');
2085
+ return baseAnimation
2086
+ .addElement(baseEl)
2087
+ .easing('cubic-bezier(.36,.66,.04,1)')
2088
+ .duration(400)
2089
+ .addAnimation([backdropAnimation, wrapperAnimation]);
2090
+ };
2091
+
2092
+ const pickerIosCss = () => `.sc-ion-picker-legacy-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}.sc-ion-picker-legacy-ios-h{inset-inline-start:0}.overlay-hidden.sc-ion-picker-legacy-ios-h{display:none}.picker-wrapper.sc-ion-picker-legacy-ios{border-radius:var(--border-radius);right:0;left: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-legacy-ios{width:100%;background:transparent;contain:strict;z-index:1}.picker-button.sc-ion-picker-legacy-ios{border:0;font-family:inherit}.picker-button.sc-ion-picker-legacy-ios:active,.picker-button.sc-ion-picker-legacy-ios:focus{outline:none}.picker-columns.sc-ion-picker-legacy-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-legacy-ios,.picker-below-highlight.sc-ion-picker-legacy-ios{display:none;pointer-events:none}.sc-ion-picker-legacy-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, var(--ion-background-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-legacy-ios{display:-ms-flexbox;display:flex;height:44px;border-bottom:0.55px solid var(--border-color)}.picker-toolbar-button.sc-ion-picker-legacy-ios{-ms-flex:1;flex:1;text-align:end}.picker-toolbar-button.sc-ion-picker-legacy-ios:last-child .picker-button.sc-ion-picker-legacy-ios{font-weight:600}.picker-toolbar-button.sc-ion-picker-legacy-ios:first-child{font-weight:normal;text-align:start}.picker-button.sc-ion-picker-legacy-ios,.picker-button.ion-activated.sc-ion-picker-legacy-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, #0054e9);font-size:16px}.picker-columns.sc-ion-picker-legacy-ios{height:215px;-webkit-perspective:1000px;perspective:1000px}.picker-above-highlight.sc-ion-picker-legacy-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}.picker-above-highlight.sc-ion-picker-legacy-ios{inset-inline-start:0}.picker-below-highlight.sc-ion-picker-legacy-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}.picker-below-highlight.sc-ion-picker-legacy-ios{inset-inline-start:0}`;
2093
+
2094
+ const pickerMdCss = () => `.sc-ion-picker-legacy-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}.sc-ion-picker-legacy-md-h{inset-inline-start:0}.overlay-hidden.sc-ion-picker-legacy-md-h{display:none}.picker-wrapper.sc-ion-picker-legacy-md{border-radius:var(--border-radius);right:0;left: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-legacy-md{width:100%;background:transparent;contain:strict;z-index:1}.picker-button.sc-ion-picker-legacy-md{border:0;font-family:inherit}.picker-button.sc-ion-picker-legacy-md:active,.picker-button.sc-ion-picker-legacy-md:focus{outline:none}.picker-columns.sc-ion-picker-legacy-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-legacy-md,.picker-below-highlight.sc-ion-picker-legacy-md{display:none;pointer-events:none}.sc-ion-picker-legacy-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, var(--ion-background-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-legacy-md{display:-ms-flexbox;display:flex;-ms-flex-pack:end;justify-content:flex-end;height:44px}.picker-button.sc-ion-picker-legacy-md,.picker-button.ion-activated.sc-ion-picker-legacy-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, #0054e9);font-size:14px;font-weight:500;text-transform:uppercase;-webkit-box-shadow:none;box-shadow:none}.picker-columns.sc-ion-picker-legacy-md{height:216px;-webkit-perspective:1800px;perspective:1800px}.picker-above-highlight.sc-ion-picker-legacy-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, var(--ion-background-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}.picker-above-highlight.sc-ion-picker-legacy-md{inset-inline-start:0}.picker-below-highlight.sc-ion-picker-legacy-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, var(--ion-background-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}.picker-below-highlight.sc-ion-picker-legacy-md{inset-inline-start:0}`;
2095
+
2096
+ const Picker = class {
2097
+ constructor(hostRef) {
2098
+ index.registerInstance(this, hostRef);
2099
+ this.didPresent = index.createEvent(this, "ionPickerDidPresent", 7);
2100
+ this.willPresent = index.createEvent(this, "ionPickerWillPresent", 7);
2101
+ this.willDismiss = index.createEvent(this, "ionPickerWillDismiss", 7);
2102
+ this.didDismiss = index.createEvent(this, "ionPickerDidDismiss", 7);
2103
+ this.didPresentShorthand = index.createEvent(this, "didPresent", 7);
2104
+ this.willPresentShorthand = index.createEvent(this, "willPresent", 7);
2105
+ this.willDismissShorthand = index.createEvent(this, "willDismiss", 7);
2106
+ this.didDismissShorthand = index.createEvent(this, "didDismiss", 7);
2107
+ this.delegateController = overlays.createDelegateController(this);
2108
+ this.lockController = lockController.createLockController();
2109
+ this.triggerController = overlays.createTriggerController();
2110
+ this.presented = false;
2111
+ /** @internal */
2112
+ this.hasController = false;
2113
+ /**
2114
+ * If `true`, the keyboard will be automatically dismissed when the overlay is presented.
2115
+ */
2116
+ this.keyboardClose = true;
2117
+ /**
2118
+ * Array of buttons to be displayed at the top of the picker.
2119
+ */
2120
+ this.buttons = [];
2121
+ /**
2122
+ * Array of columns to be displayed in the picker.
2123
+ */
2124
+ this.columns = [];
2125
+ /**
2126
+ * Number of milliseconds to wait before dismissing the picker.
2127
+ */
2128
+ this.duration = 0;
2129
+ /**
2130
+ * If `true`, a backdrop will be displayed behind the picker.
2131
+ */
2132
+ this.showBackdrop = true;
2133
+ /**
2134
+ * If `true`, the picker will be dismissed when the backdrop is clicked.
2135
+ */
2136
+ this.backdropDismiss = true;
2137
+ /**
2138
+ * If `true`, the picker will animate.
2139
+ */
2140
+ this.animated = true;
2141
+ /**
2142
+ * If `true`, the picker will open. If `false`, the picker will close.
2143
+ * Use this if you need finer grained control over presentation, otherwise
2144
+ * just use the pickerController or the `trigger` property.
2145
+ * Note: `isOpen` will not automatically be set back to `false` when
2146
+ * the picker dismisses. You will need to do that in your code.
2147
+ */
2148
+ this.isOpen = false;
2149
+ this.onBackdropTap = () => {
2150
+ this.dismiss(undefined, overlays.BACKDROP);
2151
+ };
2152
+ this.dispatchCancelHandler = (ev) => {
2153
+ const role = ev.detail.role;
2154
+ if (overlays.isCancel(role)) {
2155
+ const cancelButton = this.buttons.find((b) => b.role === 'cancel');
2156
+ this.callButtonHandler(cancelButton);
2157
+ }
2158
+ };
2159
+ }
2160
+ onIsOpenChange(newValue, oldValue) {
2161
+ if (newValue === true && oldValue === false) {
2162
+ this.present();
2163
+ }
2164
+ else if (newValue === false && oldValue === true) {
2165
+ this.dismiss();
2166
+ }
2167
+ }
2168
+ triggerChanged() {
2169
+ const { trigger, el, triggerController } = this;
2170
+ if (trigger) {
2171
+ triggerController.addClickListener(el, trigger);
2172
+ }
2173
+ }
2174
+ connectedCallback() {
2175
+ overlays.prepareOverlay(this.el);
2176
+ this.triggerChanged();
2177
+ }
2178
+ disconnectedCallback() {
2179
+ this.triggerController.removeClickListener();
2180
+ }
2181
+ componentWillLoad() {
2182
+ var _a;
2183
+ if (!((_a = this.htmlAttributes) === null || _a === void 0 ? void 0 : _a.id)) {
2184
+ overlays.setOverlayId(this.el);
2185
+ }
2186
+ }
2187
+ componentDidLoad() {
2188
+ index.printIonWarning('[ion-picker-legacy] - ion-picker-legacy and ion-picker-legacy-column have been deprecated in favor of new versions of the ion-picker and ion-picker-column components. These new components display inline with your page content allowing for more presentation flexibility than before.', this.el);
2189
+ /**
2190
+ * If picker was rendered with isOpen="true"
2191
+ * then we should open picker immediately.
2192
+ */
2193
+ if (this.isOpen === true) {
2194
+ helpers.raf(() => this.present());
2195
+ }
2196
+ /**
2197
+ * When binding values in frameworks such as Angular
2198
+ * it is possible for the value to be set after the Web Component
2199
+ * initializes but before the value watcher is set up in Stencil.
2200
+ * As a result, the watcher callback may not be fired.
2201
+ * We work around this by manually calling the watcher
2202
+ * callback when the component has loaded and the watcher
2203
+ * is configured.
2204
+ */
2205
+ this.triggerChanged();
2206
+ }
2207
+ /**
2208
+ * Present the picker overlay after it has been created.
2209
+ */
2210
+ async present() {
2211
+ const unlock = await this.lockController.lock();
2212
+ await this.delegateController.attachViewToDom();
2213
+ await overlays.present(this, 'pickerEnter', iosEnterAnimation, iosEnterAnimation, undefined);
2214
+ if (this.duration > 0) {
2215
+ this.durationTimeout = setTimeout(() => this.dismiss(), this.duration);
2216
+ }
2217
+ unlock();
2218
+ }
2219
+ /**
2220
+ * Dismiss the picker overlay after it has been presented.
2221
+ *
2222
+ * @param data Any data to emit in the dismiss events.
2223
+ * @param role The role of the element that is dismissing the picker.
2224
+ * This can be useful in a button handler for determining which button was
2225
+ * clicked to dismiss the picker.
2226
+ * Some examples include: ``"cancel"`, `"destructive"`, "selected"`, and `"backdrop"`.
2227
+ */
2228
+ async dismiss(data, role) {
2229
+ const unlock = await this.lockController.lock();
2230
+ if (this.durationTimeout) {
2231
+ clearTimeout(this.durationTimeout);
2232
+ }
2233
+ const dismissed = await overlays.dismiss(this, data, role, 'pickerLeave', iosLeaveAnimation, iosLeaveAnimation);
2234
+ if (dismissed) {
2235
+ this.delegateController.removeViewFromDom();
2236
+ }
2237
+ unlock();
2238
+ return dismissed;
2239
+ }
2240
+ /**
2241
+ * Returns a promise that resolves when the picker did dismiss.
2242
+ */
2243
+ onDidDismiss() {
2244
+ return overlays.eventMethod(this.el, 'ionPickerDidDismiss');
2245
+ }
2246
+ /**
2247
+ * Returns a promise that resolves when the picker will dismiss.
2248
+ */
2249
+ onWillDismiss() {
2250
+ return overlays.eventMethod(this.el, 'ionPickerWillDismiss');
2251
+ }
2252
+ /**
2253
+ * Get the column that matches the specified name.
2254
+ *
2255
+ * @param name The name of the column.
2256
+ */
2257
+ getColumn(name) {
2258
+ return Promise.resolve(this.columns.find((column) => column.name === name));
2259
+ }
2260
+ async buttonClick(button) {
2261
+ const role = button.role;
2262
+ if (overlays.isCancel(role)) {
2263
+ return this.dismiss(undefined, role);
2264
+ }
2265
+ const shouldDismiss = await this.callButtonHandler(button);
2266
+ if (shouldDismiss) {
2267
+ return this.dismiss(this.getSelected(), button.role);
2268
+ }
2269
+ return Promise.resolve();
2270
+ }
2271
+ async callButtonHandler(button) {
2272
+ if (button) {
2273
+ // a handler has been provided, execute it
2274
+ // pass the handler the values from the inputs
2275
+ const rtn = await overlays.safeCall(button.handler, this.getSelected());
2276
+ if (rtn === false) {
2277
+ // if the return value of the handler is false then do not dismiss
2278
+ return false;
2279
+ }
2280
+ }
2281
+ return true;
2282
+ }
2283
+ getSelected() {
2284
+ const selected = {};
2285
+ this.columns.forEach((col, index) => {
2286
+ const selectedColumn = col.selectedIndex !== undefined ? col.options[col.selectedIndex] : undefined;
2287
+ selected[col.name] = {
2288
+ text: selectedColumn ? selectedColumn.text : undefined,
2289
+ value: selectedColumn ? selectedColumn.value : undefined,
2290
+ columnIndex: index,
2291
+ };
2292
+ });
2293
+ return selected;
2294
+ }
2295
+ render() {
2296
+ const { htmlAttributes } = this;
2297
+ const theme$1 = ionicGlobal.getIonTheme(this);
2298
+ return (index.h(index.Host, Object.assign({ key: 'b0c1fc8eee284f03c696f0c8aaa29f4a6d7be0be', "aria-modal": "true", tabindex: "-1" }, htmlAttributes, { style: {
2299
+ zIndex: `${20000 + this.overlayIndex}`,
2300
+ }, class: Object.assign({ [theme$1]: true,
2301
+ // Used internally for styling
2302
+ [`picker-${theme$1}`]: true, 'overlay-hidden': true }, theme.getClassMap(this.cssClass)), onIonBackdropTap: this.onBackdropTap, onIonPickerWillDismiss: this.dispatchCancelHandler }), index.h("ion-backdrop", { key: 'b56a9f94c7a95efc047d7be95e76ba3a2284801d', visible: this.showBackdrop, tappable: this.backdropDismiss }), index.h("div", { key: 'f134d49a3afcfd2a809147b55949cea43fc34462', tabindex: "0", "aria-hidden": "true" }), index.h("div", { key: '9ae98dc10164e182a13eaef2105894a717a03cc4', class: "picker-wrapper ion-overlay-wrapper", role: "dialog" }, index.h("div", { key: '96acad60c1214e13098282182fa855b19f0a386c', class: "picker-toolbar" }, this.buttons.map((b) => (index.h("div", { class: buttonWrapperClass(b) }, index.h("button", { type: "button", onClick: () => this.buttonClick(b), class: buttonClass(b) }, b.text))))), index.h("div", { key: 'af26cd644ed9bb50c22f06624da3726e7e60426f', class: "picker-columns" }, index.h("div", { key: 'c0d8bf724f7dc081c314bef61fa08894a75c657b', class: "picker-above-highlight" }), this.presented && this.columns.map((c) => index.h("ion-picker-legacy-column", { col: c })), index.h("div", { key: '7315333742b5b0c9533f30e5ce3dfc6ec9112dc1', class: "picker-below-highlight" }))), index.h("div", { key: '454546aaf27319ae7973e74063c0a026cfc88834', tabindex: "0", "aria-hidden": "true" })));
2303
+ }
2304
+ get el() { return index.getElement(this); }
2305
+ static get watchers() { return {
2306
+ "isOpen": [{
2307
+ "onIsOpenChange": 0
2308
+ }],
2309
+ "trigger": [{
2310
+ "triggerChanged": 0
2311
+ }]
2312
+ }; }
2313
+ };
2314
+ const buttonWrapperClass = (button) => {
2315
+ return {
2316
+ [`picker-toolbar-${button.role}`]: button.role !== undefined,
2317
+ 'picker-toolbar-button': true,
2318
+ };
2319
+ };
2320
+ const buttonClass = (button) => {
2321
+ return Object.assign({ 'picker-button': true, 'ion-activatable': true }, theme.getClassMap(button.cssClass));
2322
+ };
2323
+ Picker.style = {
2324
+ ios: pickerIosCss(),
2325
+ md: pickerMdCss()
2326
+ };
2327
+
2328
+ 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}.picker-opt{inset-inline-start: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}}`;
2329
+
2330
+ 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}.picker-opt{inset-inline-start: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, #0054e9)}`;
2331
+
2332
+ const PickerColumnCmp = class {
2333
+ constructor(hostRef) {
2334
+ index.registerInstance(this, hostRef);
2335
+ this.ionPickerColChange = index.createEvent(this, "ionPickerColChange", 7);
2336
+ this.optHeight = 0;
2337
+ this.rotateFactor = 0;
2338
+ this.scaleFactor = 1;
2339
+ this.velocity = 0;
2340
+ this.y = 0;
2341
+ this.noAnimate = true;
2342
+ // `colDidChange` is a flag that gets set when the column is changed
2343
+ // dynamically. When this flag is set, the column will refresh
2344
+ // after the component re-renders to incorporate the new column data.
2345
+ // This is necessary because `this.refresh` queries for the option elements,
2346
+ // so it needs to wait for the latest elements to be available in the DOM.
2347
+ // Ex: column is created with 3 options. User updates the column data
2348
+ // to have 5 options. The column will still think it only has 3 options.
2349
+ this.colDidChange = false;
2350
+ }
2351
+ colChanged() {
2352
+ this.colDidChange = true;
2353
+ }
2354
+ async connectedCallback() {
2355
+ let pickerRotateFactor = 0;
2356
+ let pickerScaleFactor = 0.81;
2357
+ const mode = ionicGlobal.getIonMode(this);
2358
+ if (mode === 'ios') {
2359
+ pickerRotateFactor = -0.46;
2360
+ pickerScaleFactor = 1;
2361
+ }
2362
+ this.rotateFactor = pickerRotateFactor;
2363
+ this.scaleFactor = pickerScaleFactor;
2364
+ this.gesture = (await Promise.resolve().then(function () { return require('./index-CAvQ7Tka.js'); })).createGesture({
2365
+ el: this.el,
2366
+ gestureName: 'picker-swipe',
2367
+ gesturePriority: 100,
2368
+ threshold: 0,
2369
+ passive: false,
2370
+ onStart: (ev) => this.onStart(ev),
2371
+ onMove: (ev) => this.onMove(ev),
2372
+ onEnd: (ev) => this.onEnd(ev),
2373
+ });
2374
+ this.gesture.enable();
2375
+ // Options have not been initialized yet
2376
+ // Animation must be disabled through the `noAnimate` flag
2377
+ // Otherwise, the options will render
2378
+ // at the top of the column and transition down
2379
+ this.tmrId = setTimeout(() => {
2380
+ this.noAnimate = false;
2381
+ // After initialization, `refresh()` will be called
2382
+ // At this point, animation will be enabled. The options will
2383
+ // animate as they are being selected.
2384
+ this.refresh(true);
2385
+ }, 250);
2386
+ }
2387
+ componentDidLoad() {
2388
+ this.onDomChange();
2389
+ }
2390
+ componentDidUpdate() {
2391
+ // Options may have changed since last update.
2392
+ if (this.colDidChange) {
2393
+ // Animation must be disabled through the `onDomChange` parameter.
2394
+ // Otherwise, the recently added options will render
2395
+ // at the top of the column and transition down
2396
+ this.onDomChange(true, false);
2397
+ this.colDidChange = false;
2398
+ }
2399
+ }
2400
+ disconnectedCallback() {
2401
+ if (this.rafId !== undefined)
2402
+ cancelAnimationFrame(this.rafId);
2403
+ if (this.tmrId)
2404
+ clearTimeout(this.tmrId);
2405
+ if (this.gesture) {
2406
+ this.gesture.destroy();
2407
+ this.gesture = undefined;
2408
+ }
2409
+ }
2410
+ emitColChange() {
2411
+ this.ionPickerColChange.emit(this.col);
2412
+ }
2413
+ setSelected(selectedIndex, duration) {
2414
+ // if there is a selected index, then figure out it's y position
2415
+ // if there isn't a selected index, then just use the top y position
2416
+ const y = selectedIndex > -1 ? -(selectedIndex * this.optHeight) : 0;
2417
+ this.velocity = 0;
2418
+ // set what y position we're at
2419
+ if (this.rafId !== undefined)
2420
+ cancelAnimationFrame(this.rafId);
2421
+ this.update(y, duration, true);
2422
+ this.emitColChange();
2423
+ }
2424
+ update(y, duration, saveY) {
2425
+ if (!this.optsEl) {
2426
+ return;
2427
+ }
2428
+ // ensure we've got a good round number :)
2429
+ let translateY = 0;
2430
+ let translateZ = 0;
2431
+ const { col, rotateFactor } = this;
2432
+ const prevSelected = col.selectedIndex;
2433
+ const selectedIndex = (col.selectedIndex = this.indexForY(-y));
2434
+ const durationStr = duration === 0 ? '' : duration + 'ms';
2435
+ const scaleStr = `scale(${this.scaleFactor})`;
2436
+ const children = this.optsEl.children;
2437
+ for (let i = 0; i < children.length; i++) {
2438
+ const button = children[i];
2439
+ const opt = col.options[i];
2440
+ const optOffset = i * this.optHeight + y;
2441
+ let transform = '';
2442
+ if (rotateFactor !== 0) {
2443
+ const rotateX = optOffset * rotateFactor;
2444
+ if (Math.abs(rotateX) <= 90) {
2445
+ translateY = 0;
2446
+ translateZ = 90;
2447
+ transform = `rotateX(${rotateX}deg) `;
2448
+ }
2449
+ else {
2450
+ translateY = -9999;
2451
+ }
2452
+ }
2453
+ else {
2454
+ translateZ = 0;
2455
+ translateY = optOffset;
2456
+ }
2457
+ const selected = selectedIndex === i;
2458
+ transform += `translate3d(0px,${translateY}px,${translateZ}px) `;
2459
+ if (this.scaleFactor !== 1 && !selected) {
2460
+ transform += scaleStr;
2461
+ }
2462
+ // Update transition duration
2463
+ if (this.noAnimate) {
2464
+ opt.duration = 0;
2465
+ button.style.transitionDuration = '';
2466
+ }
2467
+ else if (duration !== opt.duration) {
2468
+ opt.duration = duration;
2469
+ button.style.transitionDuration = durationStr;
2470
+ }
2471
+ // Update transform
2472
+ if (transform !== opt.transform) {
2473
+ opt.transform = transform;
2474
+ }
2475
+ button.style.transform = transform;
2476
+ /**
2477
+ * Ensure that the select column
2478
+ * item has the selected class
2479
+ */
2480
+ opt.selected = selected;
2481
+ if (selected) {
2482
+ button.classList.add(PICKER_OPT_SELECTED);
2483
+ }
2484
+ else {
2485
+ button.classList.remove(PICKER_OPT_SELECTED);
2486
+ }
2487
+ }
2488
+ this.col.prevSelected = prevSelected;
2489
+ if (saveY) {
2490
+ this.y = y;
2491
+ }
2492
+ if (this.lastIndex !== selectedIndex) {
2493
+ // have not set a last index yet
2494
+ haptic.hapticSelectionChanged();
2495
+ this.lastIndex = selectedIndex;
2496
+ }
2497
+ }
2498
+ decelerate() {
2499
+ if (this.velocity !== 0) {
2500
+ // still decelerating
2501
+ this.velocity *= DECELERATION_FRICTION;
2502
+ // do not let it go slower than a velocity of 1
2503
+ this.velocity = this.velocity > 0 ? Math.max(this.velocity, 1) : Math.min(this.velocity, -1);
2504
+ let y = this.y + this.velocity;
2505
+ if (y > this.minY) {
2506
+ // whoops, it's trying to scroll up farther than the options we have!
2507
+ y = this.minY;
2508
+ this.velocity = 0;
2509
+ }
2510
+ else if (y < this.maxY) {
2511
+ // gahh, it's trying to scroll down farther than we can!
2512
+ y = this.maxY;
2513
+ this.velocity = 0;
2514
+ }
2515
+ this.update(y, 0, true);
2516
+ const notLockedIn = Math.round(y) % this.optHeight !== 0 || Math.abs(this.velocity) > 1;
2517
+ if (notLockedIn) {
2518
+ // isn't locked in yet, keep decelerating until it is
2519
+ this.rafId = requestAnimationFrame(() => this.decelerate());
2520
+ }
2521
+ else {
2522
+ this.velocity = 0;
2523
+ this.emitColChange();
2524
+ haptic.hapticSelectionEnd();
2525
+ }
2526
+ }
2527
+ else if (this.y % this.optHeight !== 0) {
2528
+ // needs to still get locked into a position so options line up
2529
+ const currentPos = Math.abs(this.y % this.optHeight);
2530
+ // create a velocity in the direction it needs to scroll
2531
+ this.velocity = currentPos > this.optHeight / 2 ? 1 : -1;
2532
+ this.decelerate();
2533
+ }
2534
+ }
2535
+ indexForY(y) {
2536
+ return Math.min(Math.max(Math.abs(Math.round(y / this.optHeight)), 0), this.col.options.length - 1);
2537
+ }
2538
+ onStart(detail) {
2539
+ // We have to prevent default in order to block scrolling under the picker
2540
+ // but we DO NOT have to stop propagation, since we still want
2541
+ // some "click" events to capture
2542
+ if (detail.event.cancelable) {
2543
+ detail.event.preventDefault();
2544
+ }
2545
+ detail.event.stopPropagation();
2546
+ haptic.hapticSelectionStart();
2547
+ // reset everything
2548
+ if (this.rafId !== undefined)
2549
+ cancelAnimationFrame(this.rafId);
2550
+ const options = this.col.options;
2551
+ let minY = options.length - 1;
2552
+ let maxY = 0;
2553
+ for (let i = 0; i < options.length; i++) {
2554
+ if (!options[i].disabled) {
2555
+ minY = Math.min(minY, i);
2556
+ maxY = Math.max(maxY, i);
2557
+ }
2558
+ }
2559
+ this.minY = -(minY * this.optHeight);
2560
+ this.maxY = -(maxY * this.optHeight);
2561
+ }
2562
+ onMove(detail) {
2563
+ if (detail.event.cancelable) {
2564
+ detail.event.preventDefault();
2565
+ }
2566
+ detail.event.stopPropagation();
2567
+ // update the scroll position relative to pointer start position
2568
+ let y = this.y + detail.deltaY;
2569
+ if (y > this.minY) {
2570
+ // scrolling up higher than scroll area
2571
+ y = Math.pow(y, 0.8);
2572
+ this.bounceFrom = y;
2573
+ }
2574
+ else if (y < this.maxY) {
2575
+ // scrolling down below scroll area
2576
+ y += Math.pow(this.maxY - y, 0.9);
2577
+ this.bounceFrom = y;
2578
+ }
2579
+ else {
2580
+ this.bounceFrom = 0;
2581
+ }
2582
+ this.update(y, 0, false);
2583
+ }
2584
+ onEnd(detail) {
2585
+ if (this.bounceFrom > 0) {
2586
+ // bounce back up
2587
+ this.update(this.minY, 100, true);
2588
+ this.emitColChange();
2589
+ return;
2590
+ }
2591
+ else if (this.bounceFrom < 0) {
2592
+ // bounce back down
2593
+ this.update(this.maxY, 100, true);
2594
+ this.emitColChange();
2595
+ return;
2596
+ }
2597
+ this.velocity = helpers.clamp(-90, detail.velocityY * 23, MAX_PICKER_SPEED);
2598
+ if (this.velocity === 0 && detail.deltaY === 0) {
2599
+ const opt = detail.event.target.closest('.picker-opt');
2600
+ if (opt === null || opt === void 0 ? void 0 : opt.hasAttribute('opt-index')) {
2601
+ this.setSelected(parseInt(opt.getAttribute('opt-index'), 10), TRANSITION_DURATION);
2602
+ }
2603
+ }
2604
+ else {
2605
+ this.y += detail.deltaY;
2606
+ if (Math.abs(detail.velocityY) < 0.05) {
2607
+ const isScrollingUp = detail.deltaY > 0;
2608
+ const optHeightFraction = (Math.abs(this.y) % this.optHeight) / this.optHeight;
2609
+ if (isScrollingUp && optHeightFraction > 0.5) {
2610
+ this.velocity = Math.abs(this.velocity) * -1;
2611
+ }
2612
+ else if (!isScrollingUp && optHeightFraction <= 0.5) {
2613
+ this.velocity = Math.abs(this.velocity);
2614
+ }
2615
+ }
2616
+ this.decelerate();
2617
+ }
2618
+ }
2619
+ refresh(forceRefresh, animated) {
2620
+ var _a;
2621
+ let min = this.col.options.length - 1;
2622
+ let max = 0;
2623
+ const options = this.col.options;
2624
+ for (let i = 0; i < options.length; i++) {
2625
+ if (!options[i].disabled) {
2626
+ min = Math.min(min, i);
2627
+ max = Math.max(max, i);
2628
+ }
2629
+ }
2630
+ /**
2631
+ * Only update selected value if column has a
2632
+ * velocity of 0. If it does not, then the
2633
+ * column is animating might land on
2634
+ * a value different than the value at
2635
+ * selectedIndex
2636
+ */
2637
+ if (this.velocity !== 0) {
2638
+ return;
2639
+ }
2640
+ const selectedIndex = helpers.clamp(min, (_a = this.col.selectedIndex) !== null && _a !== void 0 ? _a : 0, max);
2641
+ if (this.col.prevSelected !== selectedIndex || forceRefresh) {
2642
+ const y = selectedIndex * this.optHeight * -1;
2643
+ const duration = animated ? TRANSITION_DURATION : 0;
2644
+ this.velocity = 0;
2645
+ this.update(y, duration, true);
2646
+ }
2647
+ }
2648
+ onDomChange(forceRefresh, animated) {
2649
+ const colEl = this.optsEl;
2650
+ if (colEl) {
2651
+ // DOM READ
2652
+ // We perfom a DOM read over a rendered item, this needs to happen after the first render or after the column has changed
2653
+ this.optHeight = colEl.firstElementChild ? colEl.firstElementChild.clientHeight : 0;
2654
+ }
2655
+ this.refresh(forceRefresh, animated);
2656
+ }
2657
+ render() {
2658
+ const col = this.col;
2659
+ const theme$1 = ionicGlobal.getIonTheme(this);
2660
+ return (index.h(index.Host, { key: '5751788e3b7ecd2fe269c096db883b0681646270', class: Object.assign({ [theme$1]: true, 'picker-col': true, 'picker-opts-left': this.col.align === 'left', 'picker-opts-right': this.col.align === 'right' }, theme.getClassMap(col.cssClass)), style: {
2661
+ 'max-width': this.col.columnWidth,
2662
+ } }, col.prefix && (index.h("div", { key: '833f3309c8c77e1faa773f7eaa066516dfd51067', class: "picker-prefix", style: { width: col.prefixWidth } }, col.prefix)), index.h("div", { key: 'a39f38e60938e70425e4d7674f5e481885b6b548', class: "picker-opts", style: { maxWidth: col.optionsWidth }, ref: (el) => (this.optsEl = el) }, col.options.map((o, index$1) => (index.h("button", { "aria-label": o.ariaLabel, class: { 'picker-opt': true, 'picker-opt-disabled': !!o.disabled }, "opt-index": index$1 }, o.text)))), col.suffix && (index.h("div", { key: 'a2f1e0eab834c85e84cee0a716eb1083aa6c7741', class: "picker-suffix", style: { width: col.suffixWidth } }, col.suffix))));
2663
+ }
2664
+ get el() { return index.getElement(this); }
2665
+ static get watchers() { return {
2666
+ "col": [{
2667
+ "colChanged": 0
2668
+ }]
2669
+ }; }
2670
+ };
2671
+ const PICKER_OPT_SELECTED = 'picker-opt-selected';
2672
+ const DECELERATION_FRICTION = 0.97;
2673
+ const MAX_PICKER_SPEED = 90;
2674
+ const TRANSITION_DURATION = 150;
2675
+ PickerColumnCmp.style = {
2676
+ ios: pickerColumnIosCss(),
2677
+ md: pickerColumnMdCss()
2678
+ };
2679
+
1969
2680
  exports.ion_datetime = Datetime;
2681
+ exports.ion_picker_legacy = Picker;
2682
+ exports.ion_picker_legacy_column = PickerColumnCmp;