voyager-ionic-core 7.7.3 → 8.0.0-beta.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1003) hide show
  1. package/components/action-sheet.js +6 -6
  2. package/components/alert.js +4 -4
  3. package/components/backdrop.js +1 -13
  4. package/components/button-active.js +1 -1
  5. package/components/button.js +4 -4
  6. package/components/buttons.js +3 -3
  7. package/components/checkbox.js +8 -80
  8. package/components/data.js +24 -39
  9. package/components/gesture-controller.js +1 -1
  10. package/components/hardware-back-button.js +3 -3
  11. package/components/helpers.js +2 -9
  12. package/components/index9.js +1 -1
  13. package/components/input-shims.js +8 -1
  14. package/components/input.utils.js +12 -0
  15. package/components/ion-accordion-group.js +1 -1
  16. package/components/ion-app.js +4 -4
  17. package/components/ion-avatar.js +1 -1
  18. package/components/ion-back-button.js +3 -3
  19. package/components/ion-badge.js +4 -4
  20. package/components/ion-breadcrumb.js +4 -4
  21. package/components/ion-breadcrumbs.js +2 -2
  22. package/components/ion-card-content.js +1 -1
  23. package/components/ion-card-header.js +2 -2
  24. package/components/ion-card-subtitle.js +4 -4
  25. package/components/ion-card-title.js +3 -3
  26. package/components/ion-card.js +3 -3
  27. package/components/ion-chip.js +2 -2
  28. package/components/ion-col.js +2 -2
  29. package/components/ion-content.js +5 -6
  30. package/components/ion-datetime-button.js +15 -14
  31. package/components/ion-datetime.js +109 -111
  32. package/components/ion-fab-button.js +4 -4
  33. package/components/ion-fab-list.js +3 -3
  34. package/components/ion-fab.js +2 -2
  35. package/components/ion-footer.js +3 -3
  36. package/components/ion-grid.js +2 -2
  37. package/components/ion-header.js +3 -3
  38. package/components/ion-img.js +1 -1
  39. package/components/ion-infinite-scroll-content.js +4 -4
  40. package/components/ion-infinite-scroll.js +1 -1
  41. package/components/ion-input.js +7 -93
  42. package/components/ion-item-divider.js +4 -4
  43. package/components/ion-item-group.js +1 -1
  44. package/components/ion-item-option.js +4 -4
  45. package/components/ion-item-options.js +4 -4
  46. package/components/ion-item-sliding.js +2 -2
  47. package/components/ion-loading.js +4 -4
  48. package/components/ion-menu-button.js +3 -3
  49. package/components/ion-menu-toggle.js +2 -2
  50. package/components/ion-menu.js +29 -44
  51. package/components/ion-modal.js +43 -28
  52. package/components/ion-nav-link.js +1 -1
  53. package/components/ion-nav.js +9 -5
  54. package/components/ion-note.js +43 -1
  55. package/components/ion-picker-column-option.d.ts +11 -0
  56. package/components/ion-picker-column-option.js +9 -0
  57. package/components/ion-picker-column.js +2 -2
  58. package/components/ion-picker-legacy-column.d.ts +11 -0
  59. package/components/ion-picker-legacy-column.js +9 -0
  60. package/components/{ion-picker-internal.d.ts → ion-picker-legacy.d.ts} +4 -4
  61. package/components/ion-picker-legacy.js +321 -0
  62. package/components/ion-picker.js +1 -315
  63. package/components/ion-progress-bar.js +7 -4
  64. package/components/ion-range.js +160 -109
  65. package/components/ion-refresher-content.js +1 -1
  66. package/components/ion-refresher.js +4 -4
  67. package/components/ion-reorder-group.js +1 -1
  68. package/components/ion-reorder.js +1 -1
  69. package/components/ion-router-link.js +3 -3
  70. package/components/ion-router-outlet.js +2 -2
  71. package/components/ion-router.js +1 -1
  72. package/components/ion-row.js +1 -1
  73. package/components/ion-searchbar.js +36 -7
  74. package/components/ion-segment-button.js +5 -5
  75. package/components/ion-segment.js +2 -2
  76. package/components/ion-select-option.js +1 -1
  77. package/components/ion-select.js +83 -183
  78. package/components/ion-skeleton-text.js +2 -2
  79. package/components/ion-split-pane.js +28 -17
  80. package/components/ion-tab-bar.js +4 -4
  81. package/components/ion-tab-button.js +4 -4
  82. package/components/ion-tab.js +2 -2
  83. package/components/ion-tabs.js +1 -1
  84. package/components/ion-text.js +2 -2
  85. package/components/ion-textarea.js +7 -70
  86. package/components/ion-thumbnail.js +1 -1
  87. package/components/ion-title.js +3 -3
  88. package/components/ion-toast.js +12 -6
  89. package/components/ion-toggle.js +7 -64
  90. package/components/ion-toolbar.js +4 -4
  91. package/components/item.js +29 -95
  92. package/components/label.js +5 -5
  93. package/components/list-header.js +4 -4
  94. package/components/list.js +2 -2
  95. package/components/overlays.js +151 -59
  96. package/components/picker-column-option.js +124 -0
  97. package/components/picker-column.js +367 -324
  98. package/components/picker-column2.js +381 -0
  99. package/components/{picker-internal.js → picker.js} +33 -26
  100. package/components/popover.js +6 -6
  101. package/components/radio-group.js +1 -1
  102. package/components/radio.js +8 -81
  103. package/components/refresher.utils.js +1 -1
  104. package/components/ripple-effect.js +1 -1
  105. package/components/select-popover.js +14 -20
  106. package/components/spinner.js +1 -1
  107. package/components/swipe-back.js +1 -1
  108. package/css/core.css +90 -27
  109. package/css/core.css.map +1 -1
  110. package/css/display.css.map +1 -1
  111. package/css/float-elements.css.map +1 -1
  112. package/css/global.bundle.css +1 -1
  113. package/css/global.bundle.css.map +1 -1
  114. package/css/ionic-swiper.css.map +1 -1
  115. package/css/ionic.bundle.css +1 -1
  116. package/css/ionic.bundle.css.map +1 -1
  117. package/css/padding.css.map +1 -1
  118. package/css/structure.css.map +1 -1
  119. package/css/text-alignment.css.map +1 -1
  120. package/css/text-transformation.css.map +1 -1
  121. package/css/themes/dark.always.css +160 -0
  122. package/css/themes/dark.always.css.map +1 -0
  123. package/css/themes/dark.class.css +160 -0
  124. package/css/themes/dark.class.css.map +1 -0
  125. package/css/themes/dark.css +3 -0
  126. package/css/themes/dark.css.map +1 -0
  127. package/css/themes/dark.system.css +162 -0
  128. package/css/themes/dark.system.css.map +1 -0
  129. package/css/themes/high-contrast-dark.always.css +180 -0
  130. package/css/themes/high-contrast-dark.always.css.map +1 -0
  131. package/css/themes/high-contrast-dark.class.css +180 -0
  132. package/css/themes/high-contrast-dark.class.css.map +1 -0
  133. package/css/themes/high-contrast-dark.css +3 -0
  134. package/css/themes/high-contrast-dark.css.map +1 -0
  135. package/css/themes/high-contrast-dark.system.css +182 -0
  136. package/css/themes/high-contrast-dark.system.css.map +1 -0
  137. package/css/themes/high-contrast.always.css +101 -0
  138. package/css/themes/high-contrast.always.css.map +1 -0
  139. package/css/themes/high-contrast.class.css +101 -0
  140. package/css/themes/high-contrast.class.css.map +1 -0
  141. package/css/themes/high-contrast.css +3 -0
  142. package/css/themes/high-contrast.css.map +1 -0
  143. package/css/themes/high-contrast.system.css +103 -0
  144. package/css/themes/high-contrast.system.css.map +1 -0
  145. package/css/typography.css +1 -1
  146. package/css/typography.css.map +1 -1
  147. package/css/utils.bundle.css.map +1 -1
  148. package/dist/cjs/{animation-c2840aea.js → animation-3e7bb91e.js} +1 -1
  149. package/dist/cjs/{app-globals-92ad1b3d.js → app-globals-e132c781.js} +1 -1
  150. package/dist/cjs/{button-active-2d6520ec.js → button-active-60ecf64d.js} +3 -3
  151. package/dist/cjs/{data-a5109f09.js → data-21dc0f81.js} +23 -40
  152. package/dist/cjs/{framework-delegate-e0e13baa.js → framework-delegate-0499d444.js} +1 -1
  153. package/dist/cjs/{gesture-controller-c40c045a.js → gesture-controller-9436f482.js} +1 -0
  154. package/dist/cjs/{hardware-back-button-2696acaf.js → hardware-back-button-1c67a5a2.js} +5 -5
  155. package/dist/cjs/{helpers-da4c0ed1.js → helpers-668b3d95.js} +1 -9
  156. package/dist/cjs/{index-62290fec.js → index-275cc12e.js} +1 -1
  157. package/dist/cjs/{index-0ffe376d.js → index-2d21d526.js} +443 -14
  158. package/dist/cjs/{index-4c96691f.js → index-ba7ba0af.js} +4 -4
  159. package/dist/cjs/{index-bef98850.js → index-c49cb371.js} +1 -1
  160. package/dist/cjs/{index-9bfcb6e8.js → index-e4b6c97e.js} +4 -4
  161. package/dist/cjs/{index-d1b59ffa.js → index-ee07ed59.js} +1 -1
  162. package/dist/cjs/index.cjs.js +13 -13
  163. package/dist/cjs/{input-shims-a9a85bb9.js → input-shims-b419f083.js} +10 -3
  164. package/dist/cjs/{input.utils-d7dca90f.js → input.utils-32c0a14a.js} +13 -1
  165. package/dist/cjs/ion-accordion_2.cjs.entry.js +4 -4
  166. package/dist/cjs/ion-action-sheet.cjs.entry.js +16 -16
  167. package/dist/cjs/ion-alert.cjs.entry.js +14 -14
  168. package/dist/cjs/ion-app_8.cjs.entry.js +33 -34
  169. package/dist/cjs/ion-avatar_3.cjs.entry.js +8 -8
  170. package/dist/cjs/ion-back-button.cjs.entry.js +6 -6
  171. package/dist/cjs/ion-backdrop.cjs.entry.js +3 -15
  172. package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +9 -9
  173. package/dist/cjs/ion-button_2.cjs.entry.js +7 -7
  174. package/dist/cjs/ion-card_5.cjs.entry.js +16 -16
  175. package/dist/cjs/ion-checkbox.cjs.entry.js +9 -77
  176. package/dist/cjs/ion-chip.cjs.entry.js +4 -4
  177. package/dist/cjs/ion-col_3.cjs.entry.js +7 -7
  178. package/dist/cjs/ion-datetime-button.cjs.entry.js +18 -17
  179. package/dist/cjs/ion-datetime_3.cjs.entry.js +120 -115
  180. package/dist/cjs/ion-fab_3.cjs.entry.js +12 -12
  181. package/dist/cjs/ion-img.cjs.entry.js +4 -4
  182. package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +9 -9
  183. package/dist/cjs/ion-input.cjs.entry.js +12 -92
  184. package/dist/cjs/ion-item-option_3.cjs.entry.js +13 -13
  185. package/dist/cjs/ion-item_8.cjs.entry.js +48 -102
  186. package/dist/cjs/ion-loading.cjs.entry.js +12 -11
  187. package/dist/cjs/ion-menu_3.cjs.entry.js +40 -56
  188. package/dist/cjs/ion-modal.cjs.entry.js +53 -38
  189. package/dist/cjs/ion-nav_2.cjs.entry.js +13 -10
  190. package/dist/cjs/ion-picker-column-option.cjs.entry.js +106 -0
  191. package/dist/cjs/{ion-picker-column-internal.cjs.entry.js → ion-picker-column.cjs.entry.js} +124 -93
  192. package/dist/cjs/{ion-picker-internal.cjs.entry.js → ion-picker.cjs.entry.js} +32 -25
  193. package/dist/cjs/ion-popover.cjs.entry.js +13 -12
  194. package/dist/cjs/ion-progress-bar.cjs.entry.js +9 -6
  195. package/dist/cjs/ion-radio_2.cjs.entry.js +10 -79
  196. package/dist/cjs/ion-range.cjs.entry.js +163 -111
  197. package/dist/cjs/ion-refresher_2.cjs.entry.js +12 -12
  198. package/dist/cjs/ion-reorder_2.cjs.entry.js +7 -7
  199. package/dist/cjs/ion-ripple-effect.cjs.entry.js +3 -3
  200. package/dist/cjs/ion-route_4.cjs.entry.js +6 -6
  201. package/dist/cjs/ion-searchbar.cjs.entry.js +33 -9
  202. package/dist/cjs/ion-segment_2.cjs.entry.js +11 -11
  203. package/dist/cjs/ion-select_3.cjs.entry.js +78 -169
  204. package/dist/cjs/ion-spinner.cjs.entry.js +3 -3
  205. package/dist/cjs/ion-split-pane.cjs.entry.js +28 -18
  206. package/dist/cjs/ion-tab-bar_2.cjs.entry.js +11 -11
  207. package/dist/cjs/ion-tab_2.cjs.entry.js +6 -6
  208. package/dist/cjs/ion-text.cjs.entry.js +4 -4
  209. package/dist/cjs/ion-textarea.cjs.entry.js +11 -71
  210. package/dist/cjs/ion-toast.cjs.entry.js +20 -14
  211. package/dist/cjs/ion-toggle.cjs.entry.js +10 -66
  212. package/dist/cjs/{ionic-global-59a10130.js → ionic-global-5762eca9.js} +1 -1
  213. package/dist/cjs/ionic.cjs.js +28 -5
  214. package/dist/cjs/{ios.transition-96679580.js → ios.transition-3e119901.js} +4 -4
  215. package/dist/cjs/loader.cjs.js +4 -4
  216. package/dist/cjs/{md.transition-d6c98822.js → md.transition-c1392f92.js} +4 -4
  217. package/dist/cjs/{notch-controller-bfbcbb7a.js → notch-controller-08a24f39.js} +1 -1
  218. package/dist/cjs/{overlays-db5d96f3.js → overlays-44b8d0e0.js} +153 -60
  219. package/dist/cjs/{status-tap-7ad5f0fb.js → status-tap-32430b3e.js} +3 -3
  220. package/dist/cjs/{swipe-back-dcd0d4a9.js → swipe-back-b8484483.js} +3 -3
  221. package/dist/collection/collection-manifest.json +8 -7
  222. package/dist/collection/components/accordion-group/accordion-group.md.css +4 -26
  223. package/dist/collection/components/action-sheet/action-sheet.ios.css +16 -9
  224. package/dist/collection/components/action-sheet/action-sheet.js +4 -4
  225. package/dist/collection/components/action-sheet/action-sheet.md.css +10 -3
  226. package/dist/collection/components/action-sheet/test/a11y/action-sheet.e2e.js +23 -14
  227. package/dist/collection/components/action-sheet/test/basic/action-sheet-rendering.e2e.js +19 -0
  228. package/dist/collection/components/action-sheet/test/basic/action-sheet.spec.js +22 -0
  229. package/dist/collection/components/alert/alert.ios.css +33 -80
  230. package/dist/collection/components/alert/alert.js +2 -2
  231. package/dist/collection/components/alert/alert.md.css +25 -121
  232. package/dist/collection/components/alert/test/a11y/alert.e2e.js +22 -9
  233. package/dist/collection/components/app/app.js +4 -4
  234. package/dist/collection/components/avatar/avatar.js +1 -1
  235. package/dist/collection/components/back-button/back-button.ios.css +1 -1
  236. package/dist/collection/components/back-button/back-button.js +2 -2
  237. package/dist/collection/components/back-button/test/a11y/back-button.e2e.js +21 -0
  238. package/dist/collection/components/backdrop/backdrop.js +1 -13
  239. package/dist/collection/components/badge/badge.ios.css +1 -1
  240. package/dist/collection/components/badge/badge.js +2 -2
  241. package/dist/collection/components/badge/badge.md.css +1 -1
  242. package/dist/collection/components/badge/test/a11y/badge.e2e.js +18 -0
  243. package/dist/collection/components/breadcrumb/breadcrumb.ios.css +9 -9
  244. package/dist/collection/components/breadcrumb/breadcrumb.js +2 -2
  245. package/dist/collection/components/breadcrumb/breadcrumb.md.css +9 -9
  246. package/dist/collection/components/breadcrumbs/breadcrumbs.js +2 -2
  247. package/dist/collection/components/button/button.ios.css +11 -11
  248. package/dist/collection/components/button/button.js +2 -2
  249. package/dist/collection/components/button/button.md.css +9 -9
  250. package/dist/collection/components/button/test/a11y/button.e2e.js +48 -0
  251. package/dist/collection/components/button/test/wrap/button.e2e.js +12 -24
  252. package/dist/collection/components/buttons/buttons.js +2 -2
  253. package/dist/collection/components/card/card.ios.css +1 -1
  254. package/dist/collection/components/card/card.js +1 -1
  255. package/dist/collection/components/card/card.md.css +1 -1
  256. package/dist/collection/components/card-content/card-content.js +1 -1
  257. package/dist/collection/components/card-header/card-header.js +2 -2
  258. package/dist/collection/components/card-subtitle/card-subtitle.ios.css +1 -1
  259. package/dist/collection/components/card-subtitle/card-subtitle.js +2 -2
  260. package/dist/collection/components/card-subtitle/card-subtitle.md.css +1 -1
  261. package/dist/collection/components/card-title/card-title.js +2 -2
  262. package/dist/collection/components/card-title/card-title.md.css +1 -1
  263. package/dist/collection/components/checkbox/checkbox.ios.css +10 -88
  264. package/dist/collection/components/checkbox/checkbox.js +5 -118
  265. package/dist/collection/components/checkbox/checkbox.md.css +7 -85
  266. package/dist/collection/components/checkbox/test/a11y/checkbox.e2e.js +11 -2
  267. package/dist/collection/components/checkbox/test/basic/checkbox.e2e.js +10 -0
  268. package/dist/collection/components/checkbox/test/checkbox.spec.js +12 -0
  269. package/dist/collection/components/chip/chip.js +2 -2
  270. package/dist/collection/components/col/col.js +2 -2
  271. package/dist/collection/components/content/content.css +0 -4
  272. package/dist/collection/components/content/content.js +3 -4
  273. package/dist/collection/components/datetime/datetime.ios.css +105 -117
  274. package/dist/collection/components/datetime/datetime.js +74 -83
  275. package/dist/collection/components/datetime/datetime.md.css +106 -114
  276. package/dist/collection/components/datetime/test/a11y/datetime.e2e.js +1 -1
  277. package/dist/collection/components/datetime/test/a11y/datetime.spec.js +6 -9
  278. package/dist/collection/components/datetime/test/basic/datetime.e2e.js +90 -1
  279. package/dist/collection/components/datetime/test/datetime.e2e.js +2 -2
  280. package/dist/collection/components/datetime/test/disabled/datetime.spec.js +4 -4
  281. package/dist/collection/components/datetime/test/format.spec.js +65 -15
  282. package/dist/collection/components/datetime/test/locale/datetime.e2e.js +2 -2
  283. package/dist/collection/components/datetime/test/minmax/datetime.e2e.js +6 -6
  284. package/dist/collection/components/datetime/test/month-year-picker/datetime.e2e.js +1 -1
  285. package/dist/collection/components/datetime/test/prefer-wheel/datetime.e2e.js +43 -41
  286. package/dist/collection/components/datetime/test/presentation/datetime.e2e.js +1 -1
  287. package/dist/collection/components/datetime/test/readonly/datetime.e2e.js +4 -4
  288. package/dist/collection/components/datetime/test/values/datetime.e2e.js +15 -12
  289. package/dist/collection/components/datetime/utils/data.js +1 -1
  290. package/dist/collection/components/datetime/utils/format.js +24 -37
  291. package/dist/collection/components/datetime/utils/validate.js +45 -0
  292. package/dist/collection/components/datetime-button/datetime-button.ios.css +107 -0
  293. package/dist/collection/components/datetime-button/datetime-button.js +15 -14
  294. package/dist/collection/components/datetime-button/{datetime-button.css → datetime-button.md.css} +10 -7
  295. package/dist/collection/components/datetime-button/test/basic/datetime-button.e2e.js +77 -0
  296. package/dist/collection/components/fab/fab.js +2 -2
  297. package/dist/collection/components/fab-button/fab-button.ios.css +7 -7
  298. package/dist/collection/components/fab-button/fab-button.js +2 -2
  299. package/dist/collection/components/fab-button/fab-button.md.css +1 -1
  300. package/dist/collection/components/fab-button/test/a11y/fab-button.e2e.js +50 -0
  301. package/dist/collection/components/fab-list/fab-list.css +4 -42
  302. package/dist/collection/components/fab-list/fab-list.js +2 -2
  303. package/dist/collection/components/footer/footer.js +2 -2
  304. package/dist/collection/components/grid/grid.js +2 -2
  305. package/dist/collection/components/header/header.js +2 -2
  306. package/dist/collection/components/img/img.js +1 -1
  307. package/dist/collection/components/infinite-scroll/infinite-scroll.js +1 -1
  308. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.ios.css +3 -3
  309. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +2 -2
  310. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.md.css +3 -3
  311. package/dist/collection/components/input/input.ios.css +13 -104
  312. package/dist/collection/components/input/input.js +6 -144
  313. package/dist/collection/components/input/input.md.css +39 -218
  314. package/dist/collection/components/input/test/a11y/input.e2e.js +41 -3
  315. package/dist/collection/components/input/test/highlight/input.e2e.js +144 -0
  316. package/dist/collection/components/input/test/item/input.e2e.js +21 -0
  317. package/dist/collection/components/item/item.ios.css +8 -224
  318. package/dist/collection/components/item/item.js +22 -169
  319. package/dist/collection/components/item/item.md.css +15 -451
  320. package/dist/collection/components/item/test/a11y/item.e2e.js +0 -40
  321. package/dist/collection/components/item/test/basic/item.e2e.js +0 -5
  322. package/dist/collection/components/item/test/item.spec.js +1 -1
  323. package/dist/collection/components/item-divider/item-divider.ios.css +3 -3
  324. package/dist/collection/components/item-divider/item-divider.js +2 -2
  325. package/dist/collection/components/item-divider/item-divider.md.css +7 -17
  326. package/dist/collection/components/item-group/item-group.js +1 -1
  327. package/dist/collection/components/item-option/item-option.ios.css +2 -2
  328. package/dist/collection/components/item-option/item-option.js +2 -2
  329. package/dist/collection/components/item-option/item-option.md.css +1 -1
  330. package/dist/collection/components/item-options/item-options.ios.css +1 -1
  331. package/dist/collection/components/item-options/item-options.js +1 -1
  332. package/dist/collection/components/item-options/item-options.md.css +1 -1
  333. package/dist/collection/components/item-sliding/item-sliding.js +1 -1
  334. package/dist/collection/components/item-sliding/test/a11y/item-sliding.e2e.js +28 -0
  335. package/dist/collection/components/label/label.ios.css +1 -6
  336. package/dist/collection/components/label/label.js +2 -2
  337. package/dist/collection/components/label/label.md.css +2 -77
  338. package/dist/collection/components/label/test/a11y/label.e2e.js +20 -0
  339. package/dist/collection/components/list/list.js +1 -1
  340. package/dist/collection/components/list/list.md.css +2 -26
  341. package/dist/collection/components/list-header/list-header.ios.css +2 -2
  342. package/dist/collection/components/list-header/list-header.js +2 -2
  343. package/dist/collection/components/list-header/list-header.md.css +1 -1
  344. package/dist/collection/components/loading/loading.ios.css +2 -2
  345. package/dist/collection/components/loading/loading.js +2 -2
  346. package/dist/collection/components/loading/loading.md.css +3 -3
  347. package/dist/collection/components/loading/test/a11y/loading.e2e.js +21 -5
  348. package/dist/collection/components/menu/menu.ios.css +72 -53
  349. package/dist/collection/components/menu/menu.js +35 -43
  350. package/dist/collection/components/menu/menu.md.css +72 -53
  351. package/dist/collection/components/menu-button/menu-button.ios.css +1 -1
  352. package/dist/collection/components/menu-button/menu-button.js +2 -2
  353. package/dist/collection/components/menu-button/test/a11y/menu-button.e2e.js +14 -0
  354. package/dist/collection/components/menu-toggle/menu-toggle.js +2 -2
  355. package/dist/collection/components/modal/gestures/swipe-to-close.js +1 -1
  356. package/dist/collection/components/modal/modal.ios.css +9 -38
  357. package/dist/collection/components/modal/modal.js +37 -5
  358. package/dist/collection/components/modal/modal.md.css +1 -1
  359. package/dist/collection/components/modal/test/modal-attributes.spec.js +32 -0
  360. package/dist/collection/components/modal/utils.js +2 -8
  361. package/dist/collection/components/nav/nav.js +23 -3
  362. package/dist/collection/components/nav/test/nav-controller.spec.js +36 -36
  363. package/dist/collection/components/nav-link/nav-link.js +1 -1
  364. package/dist/collection/components/note/note.ios.css +1 -1
  365. package/dist/collection/components/note/note.js +2 -2
  366. package/dist/collection/components/note/note.md.css +1 -1
  367. package/dist/collection/components/picker/picker.ios.css +97 -234
  368. package/dist/collection/components/picker/picker.js +488 -742
  369. package/dist/collection/components/picker/picker.md.css +98 -226
  370. package/dist/collection/components/{picker-internal/test/a11y/picker-internal.e2e.js → picker/test/a11y/picker.e2e.js} +2 -2
  371. package/dist/collection/components/picker/test/basic/picker.e2e.js +99 -13
  372. package/dist/collection/components/picker/test/custom/picker.e2e.js +85 -0
  373. package/dist/collection/components/{picker-internal/test/keyboard-entry/picker-internal.e2e.js → picker/test/keyboard-entry/picker.e2e.js} +79 -42
  374. package/dist/collection/components/{picker-column-internal/picker-column-internal.md.css → picker-column/picker-column.css} +96 -83
  375. package/dist/collection/components/picker-column/picker-column.js +514 -335
  376. package/dist/collection/components/{picker-column-internal/test/basic/picker-column-internal.e2e.js → picker-column/test/basic/picker-column.e2e.js} +8 -8
  377. package/dist/collection/components/picker-column/test/disabled/picker-column.e2e.js +91 -0
  378. package/dist/collection/components/picker-column/test/slots/picker-column.e2e.js +39 -0
  379. package/dist/collection/components/picker-column-option/picker-column-option.ios.css +87 -0
  380. package/dist/collection/components/picker-column-option/picker-column-option.js +173 -0
  381. package/dist/collection/components/{picker-column-internal/picker-column-internal.ios.css → picker-column-option/picker-column-option.md.css} +6 -53
  382. package/dist/collection/components/picker-column-option/test/a11y/picker-column-option.e2e.js +18 -0
  383. package/dist/collection/components/picker-column-option/test/basic/picker-column-option.e2e.js +37 -0
  384. package/dist/collection/components/picker-column-option/test/picker-column-option.spec.js +29 -0
  385. package/dist/collection/components/{picker-internal/picker-internal.ios.css → picker-legacy/picker.ios.css} +155 -117
  386. package/dist/collection/components/picker-legacy/picker.js +821 -0
  387. package/dist/collection/components/{picker-internal/picker-internal.md.css → picker-legacy/picker.md.css} +144 -115
  388. package/dist/collection/components/picker-legacy/test/basic/picker.e2e.js +25 -0
  389. package/dist/collection/components/{picker → picker-legacy}/test/is-open/picker.e2e.js +4 -4
  390. package/dist/collection/components/{picker → picker-legacy}/test/picker-id.spec.js +5 -5
  391. package/dist/collection/components/{picker → picker-legacy}/test/trigger/picker.e2e.js +1 -1
  392. package/dist/collection/components/{picker-column → picker-legacy-column}/picker-column.ios.css +2 -26
  393. package/dist/collection/components/picker-legacy-column/picker-column.js +419 -0
  394. package/dist/collection/components/{picker-column → picker-legacy-column}/picker-column.md.css +3 -27
  395. package/dist/collection/components/{picker-column → picker-legacy-column}/test/picker-column-aria.spec.js +3 -3
  396. package/dist/collection/components/{picker-column → picker-legacy-column}/test/picker-column-dynamic.spec.js +2 -2
  397. package/dist/collection/components/{picker-column → picker-legacy-column}/test/picker-column.spec.js +2 -2
  398. package/dist/collection/components/{picker-column → picker-legacy-column}/test/standalone/picker-column.e2e.js +3 -3
  399. package/dist/collection/components/popover/popover.ios.css +3 -27
  400. package/dist/collection/components/popover/popover.js +5 -4
  401. package/dist/collection/components/progress-bar/progress-bar.ios.css +17 -11
  402. package/dist/collection/components/progress-bar/progress-bar.js +4 -1
  403. package/dist/collection/components/progress-bar/progress-bar.md.css +8 -10
  404. package/dist/collection/components/progress-bar/test/a11y/progress-bar.e2e.js +24 -0
  405. package/dist/collection/components/radio/radio.ios.css +10 -101
  406. package/dist/collection/components/radio/radio.js +5 -119
  407. package/dist/collection/components/radio/radio.md.css +8 -105
  408. package/dist/collection/components/radio/test/a11y/radio.e2e.js +114 -81
  409. package/dist/collection/components/radio-group/radio-group.js +1 -1
  410. package/dist/collection/components/range/range.ios.css +12 -90
  411. package/dist/collection/components/range/range.js +156 -144
  412. package/dist/collection/components/range/range.md.css +22 -152
  413. package/dist/collection/components/range/test/a11y/range.e2e.js +20 -10
  414. package/dist/collection/components/range/test/range-events.e2e.js +28 -1
  415. package/dist/collection/components/range/test/range.spec.js +0 -12
  416. package/dist/collection/components/refresher/refresher.ios.css +4 -27
  417. package/dist/collection/components/refresher/refresher.js +1 -1
  418. package/dist/collection/components/refresher/refresher.md.css +7 -30
  419. package/dist/collection/components/refresher/test/a11y/refresher.e2e.js +26 -0
  420. package/dist/collection/components/refresher-content/refresher-content.js +1 -1
  421. package/dist/collection/components/reorder/reorder.js +1 -1
  422. package/dist/collection/components/reorder-group/reorder-group.js +1 -1
  423. package/dist/collection/components/ripple-effect/ripple-effect.js +1 -1
  424. package/dist/collection/components/router-link/router-link.css +1 -1
  425. package/dist/collection/components/router-link/router-link.js +2 -2
  426. package/dist/collection/components/router-link/test/a11y/router-link.e2e.js +23 -0
  427. package/dist/collection/components/router-outlet/router-outlet.js +1 -1
  428. package/dist/collection/components/row/row.js +1 -1
  429. package/dist/collection/components/searchbar/searchbar.ios.css +11 -59
  430. package/dist/collection/components/searchbar/searchbar.js +84 -5
  431. package/dist/collection/components/searchbar/searchbar.md.css +10 -82
  432. package/dist/collection/components/searchbar/test/searchbar.spec.js +20 -2
  433. package/dist/collection/components/segment/segment.js +2 -2
  434. package/dist/collection/components/segment/test/a11y/segment.e2e.js +23 -0
  435. package/dist/collection/components/segment-button/segment-button.ios.css +3 -3
  436. package/dist/collection/components/segment-button/segment-button.js +3 -3
  437. package/dist/collection/components/segment-button/segment-button.md.css +2 -2
  438. package/dist/collection/components/select/select.ios.css +13 -79
  439. package/dist/collection/components/select/select.js +64 -173
  440. package/dist/collection/components/select/select.md.css +42 -196
  441. package/dist/collection/components/select/test/a11y/select.e2e.js +68 -4
  442. package/dist/collection/components/select/test/highlight/select.e2e.js +88 -4
  443. package/dist/collection/components/select-option/select-option.js +1 -1
  444. package/dist/collection/components/select-popover/select-popover.js +1 -1
  445. package/dist/collection/components/select-popover/select-popover.md.css +4 -4
  446. package/dist/collection/components/select-popover/test/a11y/select-popover.e2e.js +32 -0
  447. package/dist/collection/components/skeleton-text/skeleton-text.js +2 -2
  448. package/dist/collection/components/spinner/spinner.js +1 -1
  449. package/dist/collection/components/split-pane/split-pane.ios.css +3 -55
  450. package/dist/collection/components/split-pane/split-pane.js +48 -14
  451. package/dist/collection/components/split-pane/split-pane.md.css +3 -55
  452. package/dist/collection/components/split-pane/test/wrapped-menu/split-pane.e2e.js +41 -0
  453. package/dist/collection/components/tab/tab.js +2 -2
  454. package/dist/collection/components/tab-bar/tab-bar.ios.css +4 -4
  455. package/dist/collection/components/tab-bar/tab-bar.js +2 -2
  456. package/dist/collection/components/tab-bar/tab-bar.md.css +3 -3
  457. package/dist/collection/components/tab-button/tab-button.ios.css +16 -94
  458. package/dist/collection/components/tab-button/tab-button.js +2 -2
  459. package/dist/collection/components/tab-button/tab-button.md.css +10 -93
  460. package/dist/collection/components/tabs/tabs.js +1 -1
  461. package/dist/collection/components/text/text.js +2 -2
  462. package/dist/collection/components/textarea/test/a11y/textarea.e2e.js +41 -3
  463. package/dist/collection/components/textarea/test/highlight/textarea.e2e.js +144 -0
  464. package/dist/collection/components/textarea/test/item/textarea.e2e.js +21 -0
  465. package/dist/collection/components/textarea/textarea.ios.css +15 -123
  466. package/dist/collection/components/textarea/textarea.js +5 -84
  467. package/dist/collection/components/textarea/textarea.md.css +41 -241
  468. package/dist/collection/components/thumbnail/thumbnail.js +1 -1
  469. package/dist/collection/components/title/title.ios.css +2 -21
  470. package/dist/collection/components/title/title.js +2 -2
  471. package/dist/collection/components/toast/test/a11y/toast.e2e.js +89 -24
  472. package/dist/collection/components/toast/toast.ios.css +8 -55
  473. package/dist/collection/components/toast/toast.js +9 -3
  474. package/dist/collection/components/toast/toast.md.css +10 -57
  475. package/dist/collection/components/toggle/test/a11y/toggle.e2e.js +8 -2
  476. package/dist/collection/components/toggle/toggle.ios.css +11 -90
  477. package/dist/collection/components/toggle/toggle.js +5 -101
  478. package/dist/collection/components/toggle/toggle.md.css +6 -91
  479. package/dist/collection/components/toolbar/toolbar.ios.css +2 -2
  480. package/dist/collection/components/toolbar/toolbar.js +2 -2
  481. package/dist/collection/components/toolbar/toolbar.md.css +1 -1
  482. package/dist/collection/css/test/a11y/typography.e2e.js +18 -0
  483. package/dist/collection/themes/test/colors/theme.e2e.js +170 -0
  484. package/dist/collection/utils/focus-trap.js +78 -0
  485. package/dist/collection/utils/forms/index.js +0 -1
  486. package/dist/collection/utils/gesture/button-active.js +1 -1
  487. package/dist/collection/utils/gesture/gesture-controller.js +1 -1
  488. package/dist/collection/utils/hardware-back-button.js +2 -2
  489. package/dist/collection/utils/helpers.js +1 -8
  490. package/dist/collection/utils/input-shims/input-shims.js +8 -1
  491. package/dist/collection/utils/native/status-bar.js +0 -11
  492. package/dist/collection/utils/overlays.js +75 -57
  493. package/dist/collection/utils/slot-mutation-controller.js +12 -0
  494. package/dist/collection/utils/test/aria.spec.js +2 -1
  495. package/dist/collection/utils/test/overlays/overlays-scroll-blocking.spec.js +65 -0
  496. package/dist/collection/utils/test/overlays/overlays.spec.js +53 -0
  497. package/dist/collection/utils/test/playwright/generator.js +1 -0
  498. package/dist/collection/utils/test/playwright/page/utils/set-content.js +1 -1
  499. package/dist/docs.json +688 -481
  500. package/dist/esm/{animation-6a0c5338.js → animation-9a23ed8d.js} +1 -1
  501. package/dist/esm/{app-globals-5cf6195b.js → app-globals-80842d68.js} +1 -1
  502. package/dist/esm/{button-active-47ac8092.js → button-active-c6e18fac.js} +3 -3
  503. package/dist/esm/{data-0f3ab200.js → data-ae11fd43.js} +24 -39
  504. package/dist/esm/{framework-delegate-ed4ba327.js → framework-delegate-3fd96df8.js} +1 -1
  505. package/dist/esm/{gesture-controller-1bf57181.js → gesture-controller-314a54f6.js} +1 -1
  506. package/dist/esm/{hardware-back-button-b410a047.js → hardware-back-button-fb295e3a.js} +5 -5
  507. package/dist/esm/{helpers-be245865.js → helpers-f51cf76f.js} +2 -9
  508. package/dist/esm/{index-020f5464.js → index-1262064c.js} +1 -1
  509. package/dist/esm/{index-2cf77112.js → index-39782642.js} +2 -2
  510. package/dist/esm/{index-4c30cddd.js → index-5d6a0317.js} +443 -15
  511. package/dist/esm/{index-348ed70a.js → index-6da05eef.js} +4 -4
  512. package/dist/esm/{index-f3946ac1.js → index-86688780.js} +1 -1
  513. package/dist/esm/{index-e1b622e3.js → index-9d7e5d3e.js} +4 -4
  514. package/dist/esm/index.js +13 -13
  515. package/dist/esm/{input-shims-5329bbe8.js → input-shims-2a4ad5a1.js} +10 -3
  516. package/dist/esm/{input.utils-a445f677.js → input.utils-d2dee48e.js} +13 -1
  517. package/dist/esm/ion-accordion_2.entry.js +4 -4
  518. package/dist/esm/ion-action-sheet.entry.js +16 -16
  519. package/dist/esm/ion-alert.entry.js +14 -14
  520. package/dist/esm/ion-app_8.entry.js +33 -34
  521. package/dist/esm/ion-avatar_3.entry.js +8 -8
  522. package/dist/esm/ion-back-button.entry.js +6 -6
  523. package/dist/esm/ion-backdrop.entry.js +3 -15
  524. package/dist/esm/ion-breadcrumb_2.entry.js +9 -9
  525. package/dist/esm/ion-button_2.entry.js +7 -7
  526. package/dist/esm/ion-card_5.entry.js +16 -16
  527. package/dist/esm/ion-checkbox.entry.js +9 -77
  528. package/dist/esm/ion-chip.entry.js +4 -4
  529. package/dist/esm/ion-col_3.entry.js +7 -7
  530. package/dist/esm/ion-datetime-button.entry.js +18 -17
  531. package/dist/esm/ion-datetime_3.entry.js +119 -114
  532. package/dist/esm/ion-fab_3.entry.js +12 -12
  533. package/dist/esm/ion-img.entry.js +4 -4
  534. package/dist/esm/ion-infinite-scroll_2.entry.js +9 -9
  535. package/dist/esm/ion-input.entry.js +12 -92
  536. package/dist/esm/ion-item-option_3.entry.js +13 -13
  537. package/dist/esm/ion-item_8.entry.js +48 -102
  538. package/dist/esm/ion-loading.entry.js +12 -11
  539. package/dist/esm/ion-menu_3.entry.js +41 -57
  540. package/dist/esm/ion-modal.entry.js +53 -38
  541. package/dist/esm/ion-nav_2.entry.js +13 -10
  542. package/dist/esm/ion-picker-column-option.entry.js +102 -0
  543. package/dist/esm/{ion-picker-column-internal.entry.js → ion-picker-column.entry.js} +124 -93
  544. package/dist/esm/{ion-picker-internal.entry.js → ion-picker.entry.js} +32 -25
  545. package/dist/esm/ion-popover.entry.js +13 -12
  546. package/dist/esm/ion-progress-bar.entry.js +9 -6
  547. package/dist/esm/ion-radio_2.entry.js +10 -79
  548. package/dist/esm/ion-range.entry.js +164 -112
  549. package/dist/esm/ion-refresher_2.entry.js +12 -12
  550. package/dist/esm/ion-reorder_2.entry.js +7 -7
  551. package/dist/esm/ion-ripple-effect.entry.js +3 -3
  552. package/dist/esm/ion-route_4.entry.js +6 -6
  553. package/dist/esm/ion-searchbar.entry.js +33 -9
  554. package/dist/esm/ion-segment_2.entry.js +11 -11
  555. package/dist/esm/ion-select_3.entry.js +76 -167
  556. package/dist/esm/ion-spinner.entry.js +3 -3
  557. package/dist/esm/ion-split-pane.entry.js +28 -18
  558. package/dist/esm/ion-tab-bar_2.entry.js +11 -11
  559. package/dist/esm/ion-tab_2.entry.js +6 -6
  560. package/dist/esm/ion-text.entry.js +4 -4
  561. package/dist/esm/ion-textarea.entry.js +12 -72
  562. package/dist/esm/ion-toast.entry.js +21 -15
  563. package/dist/esm/ion-toggle.entry.js +10 -66
  564. package/dist/esm/{ionic-global-ad9a1810.js → ionic-global-a589c12c.js} +1 -1
  565. package/dist/esm/ionic.js +29 -6
  566. package/dist/esm/{ios.transition-7459f819.js → ios.transition-fbde96b0.js} +4 -4
  567. package/dist/esm/loader.js +5 -5
  568. package/dist/esm/{md.transition-b8224313.js → md.transition-76e0020b.js} +4 -4
  569. package/dist/esm/{notch-controller-6bd3e0f9.js → notch-controller-00572cf8.js} +1 -1
  570. package/dist/esm/{overlays-19b26885.js → overlays-b1ac1c63.js} +153 -61
  571. package/dist/esm/{status-tap-b41ece3c.js → status-tap-84b41f36.js} +3 -3
  572. package/dist/esm/{swipe-back-c6d0e5d9.js → swipe-back-4f2e5d47.js} +3 -3
  573. package/dist/esm-es5/{animation-6a0c5338.js → animation-9a23ed8d.js} +1 -1
  574. package/dist/esm-es5/app-globals-80842d68.js +4 -0
  575. package/dist/esm-es5/button-active-c6e18fac.js +4 -0
  576. package/dist/esm-es5/data-ae11fd43.js +4 -0
  577. package/dist/esm-es5/{framework-delegate-ed4ba327.js → framework-delegate-3fd96df8.js} +1 -1
  578. package/dist/esm-es5/{gesture-controller-1bf57181.js → gesture-controller-314a54f6.js} +1 -1
  579. package/dist/esm-es5/hardware-back-button-fb295e3a.js +4 -0
  580. package/dist/esm-es5/helpers-f51cf76f.js +4 -0
  581. package/dist/esm-es5/index-1262064c.js +4 -0
  582. package/dist/esm-es5/{index-2cf77112.js → index-39782642.js} +1 -1
  583. package/dist/esm-es5/index-5d6a0317.js +5 -0
  584. package/dist/esm-es5/{index-348ed70a.js → index-6da05eef.js} +1 -1
  585. package/dist/esm-es5/{index-f3946ac1.js → index-86688780.js} +1 -1
  586. package/dist/esm-es5/{index-e1b622e3.js → index-9d7e5d3e.js} +1 -1
  587. package/dist/esm-es5/index.js +1 -1
  588. package/dist/esm-es5/{input-shims-5329bbe8.js → input-shims-2a4ad5a1.js} +1 -1
  589. package/dist/esm-es5/input.utils-d2dee48e.js +4 -0
  590. package/dist/esm-es5/ion-accordion_2.entry.js +1 -1
  591. package/dist/esm-es5/ion-action-sheet.entry.js +1 -1
  592. package/dist/esm-es5/ion-alert.entry.js +1 -1
  593. package/dist/esm-es5/ion-app_8.entry.js +1 -1
  594. package/dist/esm-es5/ion-avatar_3.entry.js +1 -1
  595. package/dist/esm-es5/ion-back-button.entry.js +1 -1
  596. package/dist/esm-es5/ion-backdrop.entry.js +1 -1
  597. package/dist/esm-es5/ion-breadcrumb_2.entry.js +1 -1
  598. package/dist/esm-es5/ion-button_2.entry.js +1 -1
  599. package/dist/esm-es5/ion-card_5.entry.js +1 -1
  600. package/dist/esm-es5/ion-checkbox.entry.js +1 -1
  601. package/dist/esm-es5/ion-chip.entry.js +1 -1
  602. package/dist/esm-es5/ion-col_3.entry.js +1 -1
  603. package/dist/esm-es5/ion-datetime-button.entry.js +1 -1
  604. package/dist/esm-es5/ion-datetime_3.entry.js +1 -1
  605. package/dist/esm-es5/ion-fab_3.entry.js +1 -1
  606. package/dist/esm-es5/ion-img.entry.js +1 -1
  607. package/dist/esm-es5/ion-infinite-scroll_2.entry.js +1 -1
  608. package/dist/esm-es5/ion-input.entry.js +1 -1
  609. package/dist/esm-es5/ion-item-option_3.entry.js +1 -1
  610. package/dist/esm-es5/ion-item_8.entry.js +1 -1
  611. package/dist/esm-es5/ion-loading.entry.js +1 -1
  612. package/dist/esm-es5/ion-menu_3.entry.js +1 -1
  613. package/dist/esm-es5/ion-modal.entry.js +1 -1
  614. package/dist/esm-es5/ion-nav_2.entry.js +1 -1
  615. package/dist/esm-es5/ion-picker-column-option.entry.js +4 -0
  616. package/dist/esm-es5/ion-picker-column.entry.js +4 -0
  617. package/dist/esm-es5/ion-picker.entry.js +4 -0
  618. package/dist/esm-es5/ion-popover.entry.js +1 -1
  619. package/dist/esm-es5/ion-progress-bar.entry.js +1 -1
  620. package/dist/esm-es5/ion-radio_2.entry.js +1 -1
  621. package/dist/esm-es5/ion-range.entry.js +1 -1
  622. package/dist/esm-es5/ion-refresher_2.entry.js +1 -1
  623. package/dist/esm-es5/ion-reorder_2.entry.js +1 -1
  624. package/dist/esm-es5/ion-ripple-effect.entry.js +1 -1
  625. package/dist/esm-es5/ion-route_4.entry.js +1 -1
  626. package/dist/esm-es5/ion-searchbar.entry.js +1 -1
  627. package/dist/esm-es5/ion-segment_2.entry.js +1 -1
  628. package/dist/esm-es5/ion-select_3.entry.js +1 -1
  629. package/dist/esm-es5/ion-spinner.entry.js +1 -1
  630. package/dist/esm-es5/ion-split-pane.entry.js +1 -1
  631. package/dist/esm-es5/ion-tab-bar_2.entry.js +1 -1
  632. package/dist/esm-es5/ion-tab_2.entry.js +1 -1
  633. package/dist/esm-es5/ion-text.entry.js +1 -1
  634. package/dist/esm-es5/ion-textarea.entry.js +1 -1
  635. package/dist/esm-es5/ion-toast.entry.js +1 -1
  636. package/dist/esm-es5/ion-toggle.entry.js +1 -1
  637. package/dist/esm-es5/{ionic-global-ad9a1810.js → ionic-global-a589c12c.js} +1 -1
  638. package/dist/esm-es5/ionic.js +1 -1
  639. package/dist/esm-es5/{ios.transition-7459f819.js → ios.transition-fbde96b0.js} +1 -1
  640. package/dist/esm-es5/loader.js +1 -1
  641. package/dist/esm-es5/md.transition-76e0020b.js +4 -0
  642. package/dist/esm-es5/{notch-controller-6bd3e0f9.js → notch-controller-00572cf8.js} +1 -1
  643. package/dist/esm-es5/overlays-b1ac1c63.js +4 -0
  644. package/dist/esm-es5/{status-tap-b41ece3c.js → status-tap-84b41f36.js} +1 -1
  645. package/dist/esm-es5/{swipe-back-c6d0e5d9.js → swipe-back-4f2e5d47.js} +1 -1
  646. package/dist/html.html-data.json +176 -63
  647. package/dist/ionic/index.esm.js +1 -1
  648. package/dist/ionic/ionic.esm.js +1 -1
  649. package/dist/ionic/ionic.js +1 -1
  650. package/dist/ionic/{p-cbcffe6e.system.js → p-01171ead.system.js} +1 -1
  651. package/dist/ionic/{p-5d7e32ce.js → p-031c5621.js} +1 -1
  652. package/dist/ionic/{p-1a680496.entry.js → p-03f3ebd2.entry.js} +1 -1
  653. package/dist/ionic/{p-f02c41af.system.js → p-04f9ce05.system.js} +1 -1
  654. package/dist/ionic/p-063c093d.system.entry.js +4 -0
  655. package/dist/ionic/p-06e951a9.entry.js +4 -0
  656. package/dist/ionic/{p-822730c4.entry.js → p-070cf7c3.entry.js} +1 -1
  657. package/dist/ionic/p-07a0190a.system.entry.js +4 -0
  658. package/dist/ionic/p-0afaf65b.system.entry.js +4 -0
  659. package/dist/ionic/p-0b175848.entry.js +4 -0
  660. package/dist/ionic/p-0da58e53.entry.js +4 -0
  661. package/dist/ionic/p-0eb381c3.system.js +4 -0
  662. package/dist/ionic/p-144ae947.js +4 -0
  663. package/dist/ionic/{p-a3df16b9.system.entry.js → p-15e2ff5f.system.entry.js} +1 -1
  664. package/dist/ionic/{p-d425b1de.entry.js → p-19243ae6.entry.js} +1 -1
  665. package/dist/ionic/p-1acaf641.entry.js +4 -0
  666. package/dist/ionic/{p-ce1c0a0e.system.entry.js → p-1d1394da.system.entry.js} +2 -2
  667. package/dist/ionic/p-1e5c0c49.js +4 -0
  668. package/dist/ionic/p-2028668d.system.entry.js +4 -0
  669. package/dist/ionic/p-2070f8d8.entry.js +4 -0
  670. package/dist/ionic/{p-c7c8429a.system.js → p-20d469d0.system.js} +1 -1
  671. package/dist/ionic/p-219c17cf.system.entry.js +4 -0
  672. package/dist/ionic/p-21e88629.entry.js +4 -0
  673. package/dist/ionic/p-234dc736.entry.js +4 -0
  674. package/dist/ionic/p-237b1791.system.entry.js +4 -0
  675. package/dist/ionic/{p-ceceac26.js → p-239906f1.js} +1 -1
  676. package/dist/ionic/p-25648922.system.entry.js +4 -0
  677. package/dist/ionic/{p-b727af6a.entry.js → p-29ecf879.entry.js} +1 -1
  678. package/dist/ionic/p-2c560619.system.entry.js +4 -0
  679. package/dist/ionic/p-2e2635b4.system.entry.js +4 -0
  680. package/dist/ionic/p-2f53f47a.entry.js +4 -0
  681. package/dist/ionic/p-30dfa360.system.js +4 -0
  682. package/dist/ionic/p-314ae72a.js +4 -0
  683. package/dist/ionic/{p-97ca0cb9.system.js → p-33e39575.system.js} +1 -1
  684. package/dist/ionic/p-355736ea.js +4 -0
  685. package/dist/ionic/p-373e757d.entry.js +4 -0
  686. package/dist/ionic/{p-bd313b73.system.js → p-3944820a.system.js} +1 -1
  687. package/dist/ionic/{p-02ad4bbe.js → p-39483fc9.js} +1 -1
  688. package/dist/ionic/p-39860681.entry.js +4 -0
  689. package/dist/ionic/{p-a6c0a380.js → p-3a572692.js} +1 -1
  690. package/dist/ionic/{p-31b2326e.system.js → p-3e1e14d9.system.js} +1 -1
  691. package/dist/ionic/p-42d9f81e.entry.js +4 -0
  692. package/dist/ionic/p-45a2b1ee.system.entry.js +4 -0
  693. package/dist/ionic/{p-779aede8.js → p-46a4e4e8.js} +1 -1
  694. package/dist/ionic/{p-7670acd8.entry.js → p-48fef2f1.entry.js} +1 -1
  695. package/dist/ionic/p-493bce1f.entry.js +4 -0
  696. package/dist/ionic/{p-bcd9cad8.system.js → p-4997d7dc.system.js} +1 -1
  697. package/dist/ionic/{p-fe320051.system.js → p-49a205d0.system.js} +1 -1
  698. package/dist/ionic/{p-12a8643e.js → p-4ba6d7d1.js} +1 -1
  699. package/dist/ionic/p-4d6ec139.entry.js +4 -0
  700. package/dist/ionic/p-4d7230bd.system.entry.js +4 -0
  701. package/dist/ionic/{p-2c118b1e.js → p-4da2ae44.js} +1 -1
  702. package/dist/ionic/p-5054b3db.entry.js +4 -0
  703. package/dist/ionic/p-50d19fc7.system.entry.js +4 -0
  704. package/dist/ionic/p-513abaf6.system.entry.js +4 -0
  705. package/dist/ionic/p-517b76cb.entry.js +4 -0
  706. package/dist/ionic/{p-942a9358.js → p-51b1a6be.js} +1 -1
  707. package/dist/ionic/p-53c592ec.system.js +4 -0
  708. package/dist/ionic/{p-abcedc15.system.entry.js → p-566818dd.system.entry.js} +1 -1
  709. package/dist/ionic/p-59e86adb.js +4 -0
  710. package/dist/ionic/p-5f9abba8.system.entry.js +4 -0
  711. package/dist/ionic/p-6042920d.system.entry.js +4 -0
  712. package/dist/ionic/{p-88e9052d.entry.js → p-65374504.entry.js} +1 -1
  713. package/dist/ionic/{p-b6279412.entry.js → p-66596659.entry.js} +1 -1
  714. package/dist/ionic/p-667290b0.system.js +4 -0
  715. package/dist/ionic/{p-337ac0f5.entry.js → p-66e50777.entry.js} +1 -1
  716. package/dist/ionic/{p-62b7320a.system.js → p-67dbcd3b.system.js} +1 -1
  717. package/dist/ionic/p-696db6f4.system.js +4 -0
  718. package/dist/ionic/p-69df28fd.entry.js +4 -0
  719. package/dist/ionic/p-6d0e7669.system.entry.js +4 -0
  720. package/dist/ionic/p-6d1f5de9.system.entry.js +4 -0
  721. package/dist/ionic/p-6d75fbe8.system.entry.js +4 -0
  722. package/dist/ionic/{p-9998cb62.system.entry.js → p-7162350a.system.entry.js} +1 -1
  723. package/dist/ionic/p-7200f2da.entry.js +4 -0
  724. package/dist/ionic/p-739f8b95.system.entry.js +4 -0
  725. package/dist/ionic/p-75addf49.entry.js +4 -0
  726. package/dist/ionic/{p-de55ec45.js → p-78b3da77.js} +1 -1
  727. package/dist/ionic/p-7c7e495d.system.js +4 -0
  728. package/dist/ionic/{p-1b3ffb2f.js → p-7d4f6f18.js} +1 -1
  729. package/dist/ionic/p-824d44c5.system.entry.js +4 -0
  730. package/dist/ionic/p-8c0b08db.entry.js +4 -0
  731. package/dist/ionic/p-8dfe436d.system.js +4 -0
  732. package/dist/ionic/{p-f5d2dc9b.js → p-8ededb41.js} +1 -1
  733. package/dist/ionic/{p-86813176.system.entry.js → p-91567c90.system.entry.js} +1 -1
  734. package/dist/ionic/{p-6e23d039.entry.js → p-95648db9.entry.js} +1 -1
  735. package/dist/ionic/{p-bb3615f7.js → p-9b97df10.js} +1 -1
  736. package/dist/ionic/p-9c970454.entry.js +4 -0
  737. package/dist/ionic/{p-6525a8cd.system.js → p-9e3177a5.system.js} +1 -1
  738. package/dist/ionic/p-a03c993e.entry.js +4 -0
  739. package/dist/ionic/{p-baf8eeac.system.entry.js → p-a37d4fe9.system.entry.js} +1 -1
  740. package/dist/ionic/{p-717e2526.system.entry.js → p-a43fbe0a.system.entry.js} +2 -2
  741. package/dist/ionic/{p-ebc86ce9.system.entry.js → p-a5c33d6b.system.entry.js} +1 -1
  742. package/dist/ionic/{p-079da3df.entry.js → p-a7f788ec.entry.js} +1 -1
  743. package/dist/ionic/p-acd64713.system.entry.js +4 -0
  744. package/dist/ionic/{p-89ca4c4b.system.js → p-af9256a0.system.js} +1 -1
  745. package/dist/ionic/p-b0850af6.system.entry.js +4 -0
  746. package/dist/ionic/p-b0d35de4.system.js +4 -0
  747. package/dist/ionic/p-b996756b.entry.js +4 -0
  748. package/dist/ionic/p-ba9120fe.system.entry.js +4 -0
  749. package/dist/ionic/p-bb78b64e.entry.js +4 -0
  750. package/dist/ionic/{p-2c4bfe1c.entry.js → p-bbc4f653.entry.js} +1 -1
  751. package/dist/ionic/p-c34d1515.js +4 -0
  752. package/dist/ionic/{p-a85d9047.system.entry.js → p-c4390f10.system.entry.js} +1 -1
  753. package/dist/ionic/p-c629d22b.system.js +5 -0
  754. package/dist/ionic/p-c834c535.system.entry.js +4 -0
  755. package/dist/ionic/p-c8675b7b.system.entry.js +4 -0
  756. package/dist/ionic/p-c8f7f923.entry.js +4 -0
  757. package/dist/ionic/p-c962e9ea.entry.js +4 -0
  758. package/dist/ionic/p-cada6331.entry.js +4 -0
  759. package/dist/ionic/p-cc19ecba.system.entry.js +4 -0
  760. package/dist/ionic/p-ce36d285.system.js +4 -0
  761. package/dist/ionic/p-d09c9468.system.entry.js +4 -0
  762. package/dist/ionic/p-d10bbab7.entry.js +4 -0
  763. package/dist/ionic/p-d268f7e2.system.entry.js +4 -0
  764. package/dist/ionic/p-d3c1c23f.entry.js +4 -0
  765. package/dist/ionic/{p-644d03d7.system.entry.js → p-d4be0d81.system.entry.js} +1 -1
  766. package/dist/ionic/p-d5ef3a0a.entry.js +4 -0
  767. package/dist/ionic/p-d60342e3.js +4 -0
  768. package/dist/ionic/{p-657ccdd6.entry.js → p-d85eebc3.entry.js} +1 -1
  769. package/dist/ionic/p-d9dfdbb5.system.entry.js +4 -0
  770. package/dist/ionic/p-da5bbd4f.entry.js +4 -0
  771. package/dist/ionic/p-dad515dc.js +4 -0
  772. package/dist/ionic/{p-3079950e.entry.js → p-de39f314.entry.js} +1 -1
  773. package/dist/ionic/p-de4c700f.entry.js +4 -0
  774. package/dist/ionic/{p-6afef6c1.system.js → p-e01ebeba.system.js} +1 -1
  775. package/dist/ionic/p-e222fdd1.entry.js +4 -0
  776. package/dist/ionic/p-e5e492d8.entry.js +4 -0
  777. package/dist/ionic/{p-4b8a620f.system.entry.js → p-e9412fe7.system.entry.js} +1 -1
  778. package/dist/ionic/{p-2c86025e.system.js → p-ea5173f9.system.js} +1 -1
  779. package/dist/ionic/p-eb546888.entry.js +4 -0
  780. package/dist/ionic/{p-05253db9.js → p-eee87ebb.js} +1 -1
  781. package/dist/ionic/p-f012e8f2.system.entry.js +4 -0
  782. package/dist/ionic/{p-18918a24.system.entry.js → p-f15b0bbc.system.entry.js} +1 -1
  783. package/dist/ionic/{p-288649db.system.entry.js → p-f15f8140.system.entry.js} +1 -1
  784. package/dist/ionic/{p-125f8cdd.system.js → p-f3e8c505.system.js} +1 -1
  785. package/dist/ionic/{p-56ee6d9a.js → p-f5cb9689.js} +1 -1
  786. package/dist/ionic/p-f687573e.system.js +4 -0
  787. package/dist/ionic/p-f6db2e96.system.entry.js +4 -0
  788. package/dist/ionic/p-f8502e85.js +5 -0
  789. package/dist/ionic/p-f8dfae89.system.entry.js +4 -0
  790. package/dist/ionic/p-fcec3b7a.system.entry.js +4 -0
  791. package/dist/ionic/{p-91f4e611.system.entry.js → p-ff740d68.system.entry.js} +2 -2
  792. package/dist/types/components/action-sheet/action-sheet-interface.d.ts +8 -0
  793. package/dist/types/components/backdrop/backdrop.d.ts +0 -3
  794. package/dist/types/components/checkbox/checkbox.d.ts +1 -24
  795. package/dist/types/components/datetime/datetime-interface.d.ts +10 -0
  796. package/dist/types/components/datetime/datetime.d.ts +9 -2
  797. package/dist/types/components/datetime/utils/data.d.ts +11 -7
  798. package/dist/types/components/datetime/utils/format.d.ts +7 -13
  799. package/dist/types/components/datetime/utils/validate.d.ts +8 -0
  800. package/dist/types/components/input/input.d.ts +0 -26
  801. package/dist/types/components/item/item.d.ts +0 -32
  802. package/dist/types/components/menu/menu-interface.d.ts +1 -0
  803. package/dist/types/components/menu/menu.d.ts +14 -6
  804. package/dist/types/components/modal/utils.d.ts +0 -4
  805. package/dist/types/components/nav/nav.d.ts +4 -1
  806. package/dist/types/components/picker/picker-interfaces.d.ts +8 -0
  807. package/dist/types/components/picker/picker.d.ts +75 -133
  808. package/dist/types/components/picker-column/picker-column-interfaces.d.ts +4 -0
  809. package/dist/types/components/picker-column/picker-column.d.ts +99 -39
  810. package/dist/types/components/picker-column-option/picker-column-option.d.ts +66 -0
  811. package/dist/types/components/picker-legacy/picker.d.ts +158 -0
  812. package/dist/types/components/picker-legacy-column/picker-column.d.ts +46 -0
  813. package/dist/types/components/radio/radio.d.ts +1 -24
  814. package/dist/types/components/range/range.d.ts +30 -21
  815. package/dist/types/components/searchbar/searchbar.d.ts +38 -0
  816. package/dist/types/components/select/select.d.ts +0 -15
  817. package/dist/types/components/split-pane/split-pane.d.ts +14 -2
  818. package/dist/types/components/textarea/textarea.d.ts +0 -17
  819. package/dist/types/components/toast/toast-interface.d.ts +0 -4
  820. package/dist/types/components/toggle/toggle.d.ts +1 -21
  821. package/dist/types/components.d.ts +198 -241
  822. package/dist/types/interface.d.ts +1 -1
  823. package/dist/types/utils/config.d.ts +2 -2
  824. package/dist/types/utils/focus-trap.d.ts +35 -0
  825. package/dist/types/utils/forms/index.d.ts +0 -1
  826. package/dist/types/utils/gesture/gesture-controller.d.ts +1 -0
  827. package/dist/types/utils/hardware-back-button.d.ts +1 -1
  828. package/dist/types/utils/helpers.d.ts +0 -1
  829. package/dist/types/utils/native/status-bar.d.ts +0 -1
  830. package/dist/types/utils/overlays.d.ts +5 -8
  831. package/dist/types/utils/test/playwright/generator.d.ts +3 -1
  832. package/hydrate/index.js +2404 -2603
  833. package/package.json +1 -2
  834. package/components/form-controller.js +0 -64
  835. package/components/ion-picker-column-internal.d.ts +0 -11
  836. package/components/ion-picker-column-internal.js +0 -9
  837. package/components/ion-picker-internal.js +0 -9
  838. package/components/note.js +0 -48
  839. package/components/picker-column-internal.js +0 -392
  840. package/dist/cjs/form-controller-c83330c0.js +0 -66
  841. package/dist/collection/components/checkbox/test/legacy/basic/checkbox.e2e.js +0 -68
  842. package/dist/collection/components/checkbox/test/legacy/indeterminate/checkbox.e2e.js +0 -14
  843. package/dist/collection/components/input/test/item/input.spec.js +0 -24
  844. package/dist/collection/components/input/test/legacy/a11y/input.e2e.js +0 -28
  845. package/dist/collection/components/input/test/legacy/basic/input.e2e.js +0 -181
  846. package/dist/collection/components/input/test/legacy/clear-on-edit/input.e2e.js +0 -55
  847. package/dist/collection/components/input/test/legacy/input-events.e2e.js +0 -71
  848. package/dist/collection/components/input/test/legacy/masking/input.e2e.js +0 -26
  849. package/dist/collection/components/input/test/legacy/spec/input.e2e.js +0 -16
  850. package/dist/collection/components/item/test/counter/item.e2e.js +0 -49
  851. package/dist/collection/components/item/test/highlight/item.e2e.js +0 -14
  852. package/dist/collection/components/item/test/legacy/alignment/item.e2e.js +0 -14
  853. package/dist/collection/components/item/test/legacy/disabled/item.e2e.js +0 -14
  854. package/dist/collection/components/item/test/legacy/fill/item.e2e.js +0 -14
  855. package/dist/collection/components/item/test/legacy/form/item.e2e.js +0 -14
  856. package/dist/collection/components/modal/test/a11y/modal.spec.js +0 -22
  857. package/dist/collection/components/picker-column-internal/picker-column-internal.js +0 -566
  858. package/dist/collection/components/picker-column-internal/test/disabled/picker-column-internal.e2e.js +0 -162
  859. package/dist/collection/components/picker-internal/picker-internal.js +0 -560
  860. package/dist/collection/components/picker-internal/test/basic/picker-internal.e2e.js +0 -118
  861. package/dist/collection/components/radio/test/legacy/a11y/radio.e2e.js +0 -53
  862. package/dist/collection/components/radio/test/legacy/basic/radio.e2e.js +0 -127
  863. package/dist/collection/components/radio-group/test/legacy/basic/radio-group.e2e.js +0 -122
  864. package/dist/collection/components/radio-group/test/legacy/form/radio-group.e2e.js +0 -30
  865. package/dist/collection/components/radio-group/test/legacy/search/radio-group.e2e.js +0 -38
  866. package/dist/collection/components/range/test/legacy/a11y/range.e2e.js +0 -49
  867. package/dist/collection/components/range/test/legacy/active-bar-start/range.e2e.js +0 -14
  868. package/dist/collection/components/range/test/legacy/basic/range.e2e.js +0 -75
  869. package/dist/collection/components/range/test/legacy/range-events.e2e.js +0 -90
  870. package/dist/collection/components/range/test/legacy/scroll-target/range.e2e.js +0 -32
  871. package/dist/collection/components/select/test/legacy/async/select.e2e.js +0 -19
  872. package/dist/collection/components/select/test/legacy/basic/select.e2e.js +0 -145
  873. package/dist/collection/components/select/test/legacy/compare-with/select.e2e.js +0 -67
  874. package/dist/collection/components/select/test/legacy/custom/custom.e2e.js +0 -13
  875. package/dist/collection/components/select/test/legacy/single-value/select.e2e.js +0 -16
  876. package/dist/collection/components/select/test/legacy/spec/select.e2e.js +0 -14
  877. package/dist/collection/components/select/test/legacy/standalone/select.e2e.js +0 -18
  878. package/dist/collection/components/select/test/legacy/wrapping/select.e2e.js +0 -39
  879. package/dist/collection/components/textarea/test/legacy/a11y/textarea.e2e.js +0 -31
  880. package/dist/collection/components/textarea/test/legacy/autogrow/textarea.e2e.js +0 -58
  881. package/dist/collection/components/textarea/test/legacy/basic/textarea.e2e.js +0 -43
  882. package/dist/collection/components/textarea/test/legacy/clear-on-edit/textarea.e2e.js +0 -25
  883. package/dist/collection/components/toggle/test/legacy/basic/toggle.e2e.js +0 -83
  884. package/dist/collection/components/toggle/test/legacy/enable-on-off-labels/toggle.e2e.js +0 -37
  885. package/dist/collection/components/toggle/test/legacy/sizes/power-outline.svg +0 -1
  886. package/dist/collection/components/toggle/test/legacy/sizes/toggle.e2e.js +0 -14
  887. package/dist/collection/utils/forms/form-controller.js +0 -61
  888. package/dist/esm/form-controller-21dd62b1.js +0 -64
  889. package/dist/esm-es5/app-globals-5cf6195b.js +0 -4
  890. package/dist/esm-es5/button-active-47ac8092.js +0 -4
  891. package/dist/esm-es5/data-0f3ab200.js +0 -4
  892. package/dist/esm-es5/form-controller-21dd62b1.js +0 -4
  893. package/dist/esm-es5/hardware-back-button-b410a047.js +0 -4
  894. package/dist/esm-es5/helpers-be245865.js +0 -4
  895. package/dist/esm-es5/index-020f5464.js +0 -4
  896. package/dist/esm-es5/index-4c30cddd.js +0 -5
  897. package/dist/esm-es5/input.utils-a445f677.js +0 -4
  898. package/dist/esm-es5/ion-picker-column-internal.entry.js +0 -4
  899. package/dist/esm-es5/ion-picker-internal.entry.js +0 -4
  900. package/dist/esm-es5/md.transition-b8224313.js +0 -4
  901. package/dist/esm-es5/overlays-19b26885.js +0 -4
  902. package/dist/ionic/p-021f9d72.entry.js +0 -4
  903. package/dist/ionic/p-02542247.system.entry.js +0 -4
  904. package/dist/ionic/p-0b34d3a7.system.js +0 -4
  905. package/dist/ionic/p-12527c4b.entry.js +0 -4
  906. package/dist/ionic/p-15a40a0b.system.entry.js +0 -4
  907. package/dist/ionic/p-1636923f.system.js +0 -4
  908. package/dist/ionic/p-16a61810.entry.js +0 -4
  909. package/dist/ionic/p-1846513c.js +0 -4
  910. package/dist/ionic/p-1bc9b5f5.system.js +0 -4
  911. package/dist/ionic/p-1f16d040.entry.js +0 -4
  912. package/dist/ionic/p-1f19958f.system.entry.js +0 -4
  913. package/dist/ionic/p-2178329b.entry.js +0 -4
  914. package/dist/ionic/p-257046d2.system.js +0 -4
  915. package/dist/ionic/p-262024fd.entry.js +0 -4
  916. package/dist/ionic/p-2765a571.system.entry.js +0 -4
  917. package/dist/ionic/p-2ea71956.system.entry.js +0 -4
  918. package/dist/ionic/p-2fd3c3dd.entry.js +0 -4
  919. package/dist/ionic/p-36be3332.js +0 -4
  920. package/dist/ionic/p-437f4d02.system.entry.js +0 -4
  921. package/dist/ionic/p-46bcc2f5.js +0 -4
  922. package/dist/ionic/p-4788693d.entry.js +0 -4
  923. package/dist/ionic/p-479f5926.system.entry.js +0 -4
  924. package/dist/ionic/p-482ea916.system.entry.js +0 -4
  925. package/dist/ionic/p-49f481cc.system.entry.js +0 -4
  926. package/dist/ionic/p-521b3971.entry.js +0 -4
  927. package/dist/ionic/p-5cb5f63d.system.entry.js +0 -4
  928. package/dist/ionic/p-5de920f4.system.entry.js +0 -4
  929. package/dist/ionic/p-5fc8d5ef.system.js +0 -4
  930. package/dist/ionic/p-6812d37d.js +0 -4
  931. package/dist/ionic/p-6b6ca3f5.system.entry.js +0 -4
  932. package/dist/ionic/p-6c45c617.js +0 -4
  933. package/dist/ionic/p-6f59cdbc.system.entry.js +0 -4
  934. package/dist/ionic/p-70fbf4e2.entry.js +0 -4
  935. package/dist/ionic/p-72fa96bf.system.js +0 -5
  936. package/dist/ionic/p-7330c044.system.js +0 -4
  937. package/dist/ionic/p-741a0f0d.system.entry.js +0 -4
  938. package/dist/ionic/p-76b8bcb8.system.entry.js +0 -4
  939. package/dist/ionic/p-7a615a5a.entry.js +0 -4
  940. package/dist/ionic/p-7e16220b.entry.js +0 -4
  941. package/dist/ionic/p-7e838f43.system.entry.js +0 -4
  942. package/dist/ionic/p-7f30ad48.entry.js +0 -4
  943. package/dist/ionic/p-80aed9fb.system.entry.js +0 -4
  944. package/dist/ionic/p-84b85535.entry.js +0 -4
  945. package/dist/ionic/p-85f66c3c.entry.js +0 -4
  946. package/dist/ionic/p-860e2539.system.entry.js +0 -4
  947. package/dist/ionic/p-8cc34120.entry.js +0 -4
  948. package/dist/ionic/p-8e651c29.entry.js +0 -4
  949. package/dist/ionic/p-9056778e.system.entry.js +0 -4
  950. package/dist/ionic/p-96084f36.entry.js +0 -4
  951. package/dist/ionic/p-973b4db3.entry.js +0 -4
  952. package/dist/ionic/p-98aa0553.entry.js +0 -4
  953. package/dist/ionic/p-9de75bac.system.entry.js +0 -4
  954. package/dist/ionic/p-a02ea777.entry.js +0 -4
  955. package/dist/ionic/p-a1036ce7.js +0 -4
  956. package/dist/ionic/p-a1222c24.entry.js +0 -4
  957. package/dist/ionic/p-a4aa6dd2.system.entry.js +0 -4
  958. package/dist/ionic/p-a667dd1f.system.js +0 -4
  959. package/dist/ionic/p-a8459bfb.entry.js +0 -4
  960. package/dist/ionic/p-ae2b3a7a.system.entry.js +0 -4
  961. package/dist/ionic/p-ae828bd9.system.entry.js +0 -4
  962. package/dist/ionic/p-b0aa3806.system.entry.js +0 -4
  963. package/dist/ionic/p-b27bba38.system.entry.js +0 -4
  964. package/dist/ionic/p-b4d2f43c.system.js +0 -4
  965. package/dist/ionic/p-b58686e0.entry.js +0 -4
  966. package/dist/ionic/p-ba0fbecc.entry.js +0 -4
  967. package/dist/ionic/p-bdca4784.js +0 -4
  968. package/dist/ionic/p-c1a871ff.system.entry.js +0 -4
  969. package/dist/ionic/p-c1c7309e.entry.js +0 -4
  970. package/dist/ionic/p-c7288e78.system.entry.js +0 -4
  971. package/dist/ionic/p-cb3065b8.entry.js +0 -4
  972. package/dist/ionic/p-cb9812f7.entry.js +0 -4
  973. package/dist/ionic/p-cfb4d7e0.js +0 -4
  974. package/dist/ionic/p-d143fefa.system.entry.js +0 -4
  975. package/dist/ionic/p-d6c6541b.system.entry.js +0 -4
  976. package/dist/ionic/p-df504a37.system.js +0 -4
  977. package/dist/ionic/p-dff97cfa.entry.js +0 -4
  978. package/dist/ionic/p-e1c52dc6.entry.js +0 -4
  979. package/dist/ionic/p-e4e74b5f.system.entry.js +0 -4
  980. package/dist/ionic/p-e626800f.system.entry.js +0 -4
  981. package/dist/ionic/p-e94c1402.entry.js +0 -4
  982. package/dist/ionic/p-ebc1ca90.system.js +0 -4
  983. package/dist/ionic/p-ed4760ef.entry.js +0 -4
  984. package/dist/ionic/p-ed7a529f.js +0 -5
  985. package/dist/ionic/p-f0e54781.system.entry.js +0 -4
  986. package/dist/ionic/p-f7dce541.js +0 -4
  987. package/dist/ionic/p-fa8d3b01.entry.js +0 -4
  988. package/dist/ionic/p-fbd01db3.system.js +0 -4
  989. package/dist/types/components/picker-column-internal/picker-column-internal-interfaces.d.ts +0 -5
  990. package/dist/types/components/picker-column-internal/picker-column-internal.d.ts +0 -102
  991. package/dist/types/components/picker-internal/picker-internal-interfaces.d.ts +0 -8
  992. package/dist/types/components/picker-internal/picker-internal.d.ts +0 -102
  993. package/dist/types/utils/forms/form-controller.d.ts +0 -15
  994. /package/dist/collection/components/{picker-internal/picker-internal-interfaces.js → picker/picker-interfaces.js} +0 -0
  995. /package/dist/collection/components/{picker-column-internal/picker-column-internal-interfaces.js → picker-column/picker-column-interfaces.js} +0 -0
  996. /package/dist/collection/components/{picker → picker-legacy}/animations/ios.enter.js +0 -0
  997. /package/dist/collection/components/{picker → picker-legacy}/animations/ios.leave.js +0 -0
  998. /package/dist/collection/components/{picker → picker-legacy}/picker-interface.js +0 -0
  999. /package/dist/collection/components/{picker-column → picker-legacy-column}/test/test.utils.js +0 -0
  1000. /package/dist/types/components/{picker → picker-legacy}/animations/ios.enter.d.ts +0 -0
  1001. /package/dist/types/components/{picker → picker-legacy}/animations/ios.leave.d.ts +0 -0
  1002. /package/dist/types/components/{picker → picker-legacy}/picker-interface.d.ts +0 -0
  1003. /package/dist/types/components/{picker-column → picker-legacy-column}/test/test.utils.d.ts +0 -0
@@ -60,7 +60,7 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
60
60
  <ion-datetime presentation="date" prefer-wheel="true" min="2019-05-05" max="2023-10-01" value="2019-05-30"></ion-datetime>
61
61
  `, config);
62
62
  await page.locator('.datetime-ready').waitFor();
63
- const dayValues = page.locator('ion-datetime .day-column .picker-item[data-value]');
63
+ const dayValues = page.locator('ion-datetime .day-column ion-picker-column-option');
64
64
  expect(await dayValues.count()).toEqual(27);
65
65
  });
66
66
  test('should respect the max bounds', async ({ page }) => {
@@ -68,7 +68,7 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
68
68
  <ion-datetime presentation="date" prefer-wheel="true" min="2019-05-05" max="2023-10-01" value="2023-10-01"></ion-datetime>
69
69
  `, config);
70
70
  await page.locator('.datetime-ready').waitFor();
71
- const dayValues = page.locator('ion-datetime .day-column .picker-item[data-value]');
71
+ const dayValues = page.locator('ion-datetime .day-column ion-picker-column-option');
72
72
  expect(await dayValues.count()).toEqual(1);
73
73
  });
74
74
  test('should respect isDateEnabled preference', async ({ page }) => {
@@ -86,9 +86,9 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
86
86
  </script>
87
87
  `, config);
88
88
  await page.locator('.datetime-ready').waitFor();
89
- const disabledMonths = page.locator('.month-column .picker-item[disabled]');
90
- const disabledYears = page.locator('.year-column .picker-item[disabled]');
91
- const disabledDays = page.locator('.day-column .picker-item[disabled]');
89
+ const disabledMonths = page.locator('.month-column ion-picker-column-option.option-disabled');
90
+ const disabledYears = page.locator('.year-column ion-picker-column-option.option-disabled');
91
+ const disabledDays = page.locator('.day-column ion-picker-column-option.option-disabled');
92
92
  expect(await disabledMonths.count()).toBe(0);
93
93
  expect(await disabledYears.count()).toBe(0);
94
94
  expect(await disabledDays.count()).toBe(15);
@@ -105,9 +105,9 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
105
105
  ></ion-datetime>
106
106
  `, config);
107
107
  await page.locator('.datetime-ready').waitFor();
108
- const monthValues = page.locator('.month-column .picker-item:not(.picker-item-empty)');
109
- const yearValues = page.locator('.year-column .picker-item:not(.picker-item-empty)');
110
- const dayValues = page.locator('.day-column .picker-item:not(.picker-item-empty)');
108
+ const monthValues = page.locator('.month-column ion-picker-column-option');
109
+ const yearValues = page.locator('.year-column ion-picker-column-option');
110
+ const dayValues = page.locator('.day-column ion-picker-column-option');
111
111
  expect(await monthValues.count()).toBe(2);
112
112
  expect(await yearValues.count()).toBe(3);
113
113
  expect(await dayValues.count()).toBe(5);
@@ -134,7 +134,7 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
134
134
  `, config);
135
135
  await page.locator('.datetime-ready').waitFor();
136
136
  const ionChange = await page.spyOnEvent('ionChange');
137
- const monthValues = page.locator('.month-column .picker-item:not(.picker-item-empty)');
137
+ const monthValues = page.locator('.month-column ion-picker-column-option');
138
138
  // Change month value
139
139
  await monthValues.nth(0).click();
140
140
  await ionChange.next();
@@ -161,7 +161,7 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
161
161
  `, config);
162
162
  await page.locator('.datetime-ready').waitFor();
163
163
  const ionChange = await page.spyOnEvent('ionChange');
164
- const dayValues = page.locator('.day-column .picker-item:not(.picker-item-empty)');
164
+ const dayValues = page.locator('.day-column ion-picker-column-option');
165
165
  // Change day value
166
166
  await dayValues.nth(0).click();
167
167
  await ionChange.next();
@@ -175,7 +175,7 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
175
175
  `, config);
176
176
  await page.locator('.datetime-ready').waitFor();
177
177
  const ionChange = await page.spyOnEvent('ionChange');
178
- const yearValues = page.locator('.year-column .picker-item:not(.picker-item-empty)');
178
+ const yearValues = page.locator('.year-column ion-picker-column-option');
179
179
  /**
180
180
  * Change year value
181
181
  * The 0th index is the current
@@ -192,9 +192,9 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
192
192
  const datetime = page.locator('ion-datetime');
193
193
  await datetime.evaluate((el) => (el.value = '2021-05-25T12:40:00.000Z'));
194
194
  await page.waitForChanges();
195
- const selectedMonth = datetime.locator('.month-column .picker-item-active');
196
- const selectedDay = datetime.locator('.day-column .picker-item-active');
197
- const selectedYear = datetime.locator('.year-column .picker-item-active');
195
+ const selectedMonth = datetime.locator('.month-column ion-picker-column-option.option-active');
196
+ const selectedDay = datetime.locator('.day-column ion-picker-column-option.option-active');
197
+ const selectedYear = datetime.locator('.year-column ion-picker-column-option.option-active');
198
198
  await expect(selectedMonth).toHaveText(/May/);
199
199
  await expect(selectedDay).toHaveText(/25/);
200
200
  await expect(selectedYear).toHaveText(/2021/);
@@ -213,8 +213,8 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
213
213
  ></ion-datetime>
214
214
  `, config);
215
215
  await page.locator('.datetime-ready').waitFor();
216
- const monthValues = page.locator('.month-column .picker-item:not(.picker-item-empty)');
217
- const dayValues = page.locator('.day-column .picker-item:not(.picker-item-empty)');
216
+ const monthValues = page.locator('.month-column ion-picker-column-option');
217
+ const dayValues = page.locator('.day-column ion-picker-column-option');
218
218
  await expect(monthValues).toHaveText(['1月', '2月', '3月']);
219
219
  await expect(dayValues).toHaveText(['1日', '2日', '3日']);
220
220
  });
@@ -228,7 +228,7 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
228
228
  ></ion-datetime>
229
229
  `, config);
230
230
  await page.locator('.datetime-ready').waitFor();
231
- const columns = page.locator('ion-picker-column-internal');
231
+ const columns = page.locator('ion-picker-column');
232
232
  await expect(columns.nth(0)).toHaveClass(/month-column/);
233
233
  await expect(columns.nth(1)).toHaveClass(/day-column/);
234
234
  await expect(columns.nth(2)).toHaveClass(/year-column/);
@@ -243,7 +243,7 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
243
243
  ></ion-datetime>
244
244
  `, config);
245
245
  await page.locator('.datetime-ready').waitFor();
246
- const columns = page.locator('ion-picker-column-internal');
246
+ const columns = page.locator('ion-picker-column');
247
247
  await expect(columns.nth(0)).toHaveClass(/day-column/);
248
248
  await expect(columns.nth(1)).toHaveClass(/month-column/);
249
249
  await expect(columns.nth(2)).toHaveClass(/year-column/);
@@ -256,7 +256,7 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
256
256
  <ion-datetime presentation="date-time" prefer-wheel="true" min="2019-05-05" value="2019-05-10T16:30:00"></ion-datetime>
257
257
  `, config);
258
258
  await page.locator('.datetime-ready').waitFor();
259
- const dayValues = page.locator('ion-datetime .date-column .picker-item[data-value]');
259
+ const dayValues = page.locator('ion-datetime .date-column ion-picker-column-option');
260
260
  expect(await dayValues.count()).toEqual(57);
261
261
  });
262
262
  test('should respect the max bounds', async ({ page }) => {
@@ -264,7 +264,7 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
264
264
  <ion-datetime presentation="date-time" prefer-wheel="true" max="2023-06-10" value="2023-06-05T16:30:00"></ion-datetime>
265
265
  `, config);
266
266
  await page.locator('.datetime-ready').waitFor();
267
- const dayValues = page.locator('ion-datetime .date-column .picker-item[data-value]');
267
+ const dayValues = page.locator('ion-datetime .date-column ion-picker-column-option');
268
268
  expect(await dayValues.count()).toEqual(41);
269
269
  });
270
270
  test('should respect isDateEnabled preference', async ({ page }) => {
@@ -282,7 +282,7 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
282
282
  </script>
283
283
  `, config);
284
284
  await page.locator('.datetime-ready').waitFor();
285
- const disabledDates = page.locator('.date-column .picker-item[disabled]');
285
+ const disabledDates = page.locator('.date-column ion-picker-column-option.option-disabled');
286
286
  expect(await disabledDates.count()).toBe(44);
287
287
  });
288
288
  test('should respect month, day, and year preferences', async ({ page }) => {
@@ -297,7 +297,7 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
297
297
  ></ion-datetime>
298
298
  `, config);
299
299
  await page.locator('.datetime-ready').waitFor();
300
- const dateValues = page.locator('.date-column .picker-item:not(.picker-item-empty)');
300
+ const dateValues = page.locator('.date-column ion-picker-column-option');
301
301
  expect(await dateValues.count()).toBe(5);
302
302
  });
303
303
  test('should correctly localize the date data', async ({ page }) => {
@@ -312,7 +312,7 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
312
312
  ></ion-datetime>
313
313
  `, config);
314
314
  await page.locator('.datetime-ready').waitFor();
315
- const dateValues = page.locator('.date-column .picker-item:not(.picker-item-empty)');
315
+ const dateValues = page.locator('.date-column ion-picker-column-option');
316
316
  await expect(dateValues).toHaveText(['2月1日(火)', '2月2日(水)', '2月3日(木)']);
317
317
  });
318
318
  test('should respect min and max bounds even across years', async ({ page }) => {
@@ -327,15 +327,16 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
327
327
  `, config);
328
328
  await page.locator('.datetime-ready').waitFor();
329
329
  const dateColumn = page.locator('.date-column');
330
- const dateValues = dateColumn.locator('.picker-item:not(.picker-item-empty)');
330
+ const dateColumnScrollEl = dateColumn.locator('.picker-opts');
331
+ const dateValues = dateColumn.locator('ion-picker-column-option');
331
332
  expect(await dateValues.count()).toBe(90);
332
333
  /**
333
334
  * Select 1st item to change the dates rendered
334
335
  */
335
- await expect(dateValues.nth(0)).toHaveAttribute('data-value', '2022-1-1');
336
- await dateColumn.evaluate((el) => (el.scrollTop = 0));
336
+ await expect(dateValues.nth(0)).toHaveJSProperty('value', '2022-1-1');
337
+ await dateColumnScrollEl.evaluate((el) => (el.scrollTop = 0));
337
338
  await page.waitForChanges();
338
- await expect(dateValues.nth(0)).toHaveAttribute('data-value', '2021-12-1');
339
+ await expect(dateValues.nth(0)).toHaveJSProperty('value', '2021-12-1');
339
340
  });
340
341
  test('should keep sliding window if default window is within min and max constraints', async ({ page }) => {
341
342
  await page.setContent(`
@@ -348,7 +349,7 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
348
349
  ></ion-datetime>
349
350
  `, config);
350
351
  await page.locator('.datetime-ready').waitFor();
351
- const dayValues = page.locator('.date-column .picker-item:not(.picker-item-empty)');
352
+ const dayValues = page.locator('.date-column ion-picker-column-option');
352
353
  expect(await dayValues.count()).toBe(92);
353
354
  });
354
355
  test('should narrow sliding window if default window is not within min and max constraints', async ({ page }) => {
@@ -362,7 +363,7 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
362
363
  ></ion-datetime>
363
364
  `, config);
364
365
  await page.locator('.datetime-ready').waitFor();
365
- const dayValues = page.locator('.date-column .picker-item:not(.picker-item-empty)');
366
+ const dayValues = page.locator('.date-column ion-picker-column-option');
366
367
  expect(await dayValues.count()).toBe(15);
367
368
  });
368
369
  test('selecting date should update value when no value is set', async ({ page }) => {
@@ -374,7 +375,7 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
374
375
  `, config);
375
376
  await page.locator('.datetime-ready').waitFor();
376
377
  const ionChange = await page.spyOnEvent('ionChange');
377
- const dayValues = page.locator('.date-column .picker-item:not(.picker-item-empty)');
378
+ const dayValues = page.locator('.date-column ion-picker-column-option');
378
379
  // Change day/month value
379
380
  await dayValues.nth(0).click();
380
381
  await ionChange.next();
@@ -386,7 +387,7 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
386
387
  <ion-datetime presentation="time-date" prefer-wheel="true" min="2019-05-05" value="2019-05-10T16:30:00"></ion-datetime>
387
388
  `, config);
388
389
  await page.locator('.datetime-ready').waitFor();
389
- const dayValues = page.locator('ion-datetime .date-column .picker-item[data-value]');
390
+ const dayValues = page.locator('ion-datetime .date-column ion-picker-column-option');
390
391
  expect(await dayValues.count()).toEqual(57);
391
392
  });
392
393
  test('should respect the max bounds', async ({ page }) => {
@@ -394,7 +395,7 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
394
395
  <ion-datetime presentation="time-date" prefer-wheel="true" max="2023-06-10" value="2023-06-05T16:30:00"></ion-datetime>
395
396
  `, config);
396
397
  await page.locator('.datetime-ready').waitFor();
397
- const dayValues = page.locator('ion-datetime .date-column .picker-item[data-value]');
398
+ const dayValues = page.locator('ion-datetime .date-column ion-picker-column-option');
398
399
  expect(await dayValues.count()).toEqual(41);
399
400
  });
400
401
  test('should respect isDateEnabled preference', async ({ page }) => {
@@ -412,7 +413,7 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
412
413
  </script>
413
414
  `, config);
414
415
  await page.locator('.datetime-ready').waitFor();
415
- const disabledDates = page.locator('.date-column .picker-item[disabled]');
416
+ const disabledDates = page.locator('.date-column ion-picker-column-option.option-disabled');
416
417
  expect(await disabledDates.count()).toBe(44);
417
418
  });
418
419
  test('should respect month, day, and year preferences', async ({ page }) => {
@@ -427,7 +428,7 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
427
428
  ></ion-datetime>
428
429
  `, config);
429
430
  await page.locator('.datetime-ready').waitFor();
430
- const dateValues = page.locator('.date-column .picker-item:not(.picker-item-empty)');
431
+ const dateValues = page.locator('.date-column ion-picker-column-option');
431
432
  expect(await dateValues.count()).toBe(5);
432
433
  });
433
434
  test('should correctly localize the date data', async ({ page }) => {
@@ -442,7 +443,7 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
442
443
  ></ion-datetime>
443
444
  `, config);
444
445
  await page.locator('.datetime-ready').waitFor();
445
- const dateValues = page.locator('.date-column .picker-item:not(.picker-item-empty)');
446
+ const dateValues = page.locator('.date-column ion-picker-column-option');
446
447
  await expect(dateValues).toHaveText(['2月1日(火)', '2月2日(水)', '2月3日(木)']);
447
448
  });
448
449
  test('should respect min and max bounds even across years', async ({ page }) => {
@@ -457,15 +458,16 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
457
458
  `, config);
458
459
  await page.locator('.datetime-ready').waitFor();
459
460
  const dateColumn = page.locator('.date-column');
460
- const dateValues = dateColumn.locator('.picker-item:not(.picker-item-empty)');
461
+ const dateColumnScrollEl = dateColumn.locator('.picker-opts');
462
+ const dateValues = dateColumn.locator('ion-picker-column-option');
461
463
  expect(await dateValues.count()).toBe(90);
462
464
  /**
463
465
  * Select 1st item to change the dates rendered
464
466
  */
465
- await expect(dateValues.nth(0)).toHaveAttribute('data-value', '2022-1-1');
466
- await dateColumn.evaluate((el) => (el.scrollTop = 0));
467
+ await expect(dateValues.nth(0)).toHaveJSProperty('value', '2022-1-1');
468
+ await dateColumnScrollEl.evaluate((el) => (el.scrollTop = 0));
467
469
  await page.waitForChanges();
468
- await expect(dateValues.nth(0)).toHaveAttribute('data-value', '2021-12-1');
470
+ await expect(dateValues.nth(0)).toHaveJSProperty('value', '2021-12-1');
469
471
  });
470
472
  test('should keep sliding window if default window is within min and max constraints', async ({ page }) => {
471
473
  await page.setContent(`
@@ -478,7 +480,7 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
478
480
  ></ion-datetime>
479
481
  `, config);
480
482
  await page.locator('.datetime-ready').waitFor();
481
- const dayValues = page.locator('.date-column .picker-item:not(.picker-item-empty)');
483
+ const dayValues = page.locator('.date-column ion-picker-column-option');
482
484
  expect(await dayValues.count()).toBe(92);
483
485
  });
484
486
  test('should narrow sliding window if default window is not within min and max constraints', async ({ page }) => {
@@ -492,7 +494,7 @@ configs({ modes: ['md'], directions: ['ltr'] }).forEach(({ title, config }) => {
492
494
  ></ion-datetime>
493
495
  `, config);
494
496
  await page.locator('.datetime-ready').waitFor();
495
- const dayValues = page.locator('.date-column .picker-item:not(.picker-item-empty)');
497
+ const dayValues = page.locator('.date-column ion-picker-column-option');
496
498
  expect(await dayValues.count()).toBe(15);
497
499
  });
498
500
  });
@@ -161,7 +161,7 @@ class TimePickerFixture {
161
161
  await this.page.waitForChanges();
162
162
  }
163
163
  async expectTime(hour, minute, ampm) {
164
- const pickerColumns = this.timePicker.locator('ion-picker-column-internal');
164
+ const pickerColumns = this.timePicker.locator('ion-picker-column');
165
165
  await expect(pickerColumns.nth(0)).toHaveJSProperty('value', hour);
166
166
  await expect(pickerColumns.nth(1)).toHaveJSProperty('value', minute);
167
167
  await expect(pickerColumns.nth(2)).toHaveJSProperty('value', ampm);
@@ -34,7 +34,7 @@ configs({ modes: ['ios'], directions: ['ltr'] }).forEach(({ title, config, scree
34
34
  await expect(calendarMonthYear).toHaveText('February 2022');
35
35
  await calendarMonthYear.click();
36
36
  await page.waitForChanges();
37
- await page.locator('.month-column .picker-item[data-value="3"]').click();
37
+ await page.locator('.month-column ion-picker-column-option').nth(2).click();
38
38
  await page.waitForChanges();
39
39
  await expect(calendarMonthYear).toHaveText('March 2022');
40
40
  await expect(ionChange).not.toHaveReceivedEvent();
@@ -46,14 +46,14 @@ configs({ modes: ['ios'], directions: ['ltr'] }).forEach(({ title, config, scree
46
46
  const tabKey = browserName === 'webkit' ? 'Alt+Tab' : 'Tab';
47
47
  await page.locator('.datetime-ready').waitFor();
48
48
  const calendarMonthYear = page.locator('ion-datetime .calendar-month-year');
49
- const monthYearButton = page.locator('.calendar-month-year ion-item');
49
+ const monthYearButton = page.locator('.calendar-month-year-toggle');
50
50
  await expect(calendarMonthYear).toHaveText('February 2022');
51
51
  await page.keyboard.press(tabKey);
52
52
  await expect(monthYearButton).toBeFocused();
53
53
  await page.waitForChanges();
54
54
  await page.keyboard.press('Enter');
55
55
  await page.waitForChanges();
56
- const marchPickerItem = page.locator('.month-column .picker-item[data-value="3"]');
56
+ const marchPickerItem = page.locator('.month-column ion-picker-column-option').nth(2);
57
57
  await expect(marchPickerItem).toBeVisible();
58
58
  });
59
59
  test('should view next month via next button', async ({ page }) => {
@@ -75,7 +75,7 @@ configs({ modes: ['ios'], directions: ['ltr'] }).forEach(({ title, config, scree
75
75
  `, config);
76
76
  const tabKey = browserName === 'webkit' ? 'Alt+Tab' : 'Tab';
77
77
  const datetime = page.locator('ion-datetime');
78
- const monthYearButton = page.locator('.calendar-month-year ion-item');
78
+ const monthYearButton = page.locator('.calendar-month-year-toggle');
79
79
  const prevButton = page.locator('.calendar-next-prev ion-button:nth-child(1)');
80
80
  const nextButton = page.locator('.calendar-next-prev ion-button:nth-child(2)');
81
81
  const calendarMonthYear = page.locator('ion-datetime .calendar-month-year');
@@ -22,28 +22,28 @@ configs({ modes: ['ios'], directions: ['ltr'] }).forEach(({ title, config }) =>
22
22
  await page.setContent(`
23
23
  <ion-datetime locale="en-US" presentation="month-year" month-values="5,6,10"></ion-datetime>
24
24
  `, config);
25
- const items = page.locator('.month-column .picker-item:not(.picker-item-empty)');
25
+ const items = page.locator('.month-column ion-picker-column-option');
26
26
  await expect(items).toHaveText(['May', 'June', 'October']);
27
27
  });
28
28
  test('should render correct years', async ({ page }) => {
29
29
  await page.setContent(`
30
30
  <ion-datetime locale="en-US" presentation="month-year" year-values="2022,2021,2020"></ion-datetime>
31
31
  `, config);
32
- const items = page.locator('.year-column .picker-item:not(.picker-item-empty)');
32
+ const items = page.locator('.year-column ion-picker-column-option');
33
33
  await expect(items).toHaveText(['2022', '2021', '2020']);
34
34
  });
35
35
  test('should render correct hours', async ({ page }) => {
36
36
  await page.setContent(`
37
37
  <ion-datetime locale="en-US" presentation="time" hour-values="1,2,3"></ion-datetime>
38
38
  `, config);
39
- const items = page.locator('ion-picker-column-internal:first-of-type .picker-item:not(.picker-item-empty)');
39
+ const items = page.locator('ion-picker-column:first-of-type ion-picker-column-option');
40
40
  await expect(items).toHaveText(['1', '2', '3']);
41
41
  });
42
42
  test('should render correct minutes', async ({ page }) => {
43
43
  await page.setContent(`
44
44
  <ion-datetime locale="en-US" presentation="time" minute-values="1,2,3"></ion-datetime>
45
45
  `, config);
46
- const items = page.locator('ion-picker-column-internal:nth-of-type(2) .picker-item:not(.picker-item-empty)');
46
+ const items = page.locator('ion-picker-column:nth-of-type(2) ion-picker-column-option');
47
47
  await expect(items).toHaveText(['01', '02', '03']);
48
48
  });
49
49
  test('should adjust default parts for allowed hour and minute values', async ({ page }) => {
@@ -69,19 +69,22 @@ configs({ modes: ['ios'], directions: ['ltr'] }).forEach(({ title, config }) =>
69
69
  </script>
70
70
  `, config);
71
71
  await page.locator('.datetime-ready').waitFor();
72
- const minuteItems = page.locator('ion-picker-column-internal:nth-of-type(2) .picker-item:not(.picker-item-empty)');
72
+ const minuteColumn = page.locator('ion-picker-column').nth(1);
73
+ const minuteItems = minuteColumn.locator('ion-picker-column-option');
73
74
  await expect(minuteItems).toHaveText(['00', '15', '30', '45']);
74
- await expect(minuteItems.nth(1)).toHaveClass(/picker-item-active/);
75
- const hourItems = page.locator('ion-picker-column-internal:nth-of-type(1) .picker-item:not(.picker-item-empty)');
75
+ await expect(minuteColumn).toHaveJSProperty('value', 15);
76
+ const hourColumn = page.locator('ion-picker-column').nth(0);
77
+ const hourItems = hourColumn.locator('ion-picker-column-option');
76
78
  await expect(hourItems).toHaveText(['2']);
77
- await expect(hourItems.nth(0)).toHaveClass(/picker-item-active/);
79
+ await expect(hourColumn).toHaveJSProperty('value', 2);
78
80
  /**
79
81
  * Since the allowed hour is 2AM, the time period
80
82
  * should switch from PM to AM.
81
83
  */
82
- const ampmItems = page.locator('ion-picker-column-internal:nth-of-type(3) .picker-item:not(.picker-item-empty)');
84
+ const ampmColumn = page.locator('ion-picker-column').nth(2);
85
+ const ampmItems = ampmColumn.locator('ion-picker-column-option');
83
86
  await expect(ampmItems).toHaveText(['AM', 'PM']);
84
- await expect(ampmItems.nth(0)).toHaveClass(/picker-item-active/);
87
+ await expect(ampmColumn).toHaveJSProperty('value', 'am');
85
88
  });
86
89
  test('should adjust default parts month for allowed month values', async ({ page }) => {
87
90
  /**
@@ -106,9 +109,9 @@ configs({ modes: ['ios'], directions: ['ltr'] }).forEach(({ title, config }) =>
106
109
  </script>
107
110
  `, config);
108
111
  await page.locator('.datetime-ready').waitFor();
109
- const monthItems = page.locator('.month-column .picker-item:not(.picker-item-empty)');
112
+ const monthItems = page.locator('.month-column ion-picker-column-option');
110
113
  await expect(monthItems).toHaveText(['January']);
111
- await expect(monthItems.nth(0)).toHaveClass(/picker-item-active/);
114
+ await expect(monthItems.nth(0)).toHaveClass(/option-active/);
112
115
  });
113
116
  test('today date highlight should persist even if disallowed from dayValues', async ({ page }) => {
114
117
  /**
@@ -323,7 +323,7 @@ export const getMonthColumnData = (locale, refParts, minParts, maxParts, monthVa
323
323
  * @param minParts The minimum bound on the date that can be returned
324
324
  * @param maxParts The maximum bound on the date that can be returned
325
325
  * @param dayValues The allowed date values
326
- * @returns Date data to be used in ion-picker-column-internal
326
+ * @returns Date data to be used in ion-picker-column
327
327
  */
328
328
  export const getDayColumnData = (locale, refParts, minParts, maxParts, dayValues, formatOptions = {
329
329
  day: 'numeric',
@@ -9,7 +9,26 @@ const getFormattedDayPeriod = (dayPeriod) => {
9
9
  }
10
10
  return dayPeriod.toUpperCase();
11
11
  };
12
- export const getLocalizedTime = (locale, refParts, hourCycle) => {
12
+ /**
13
+ * Including time zone options may lead to the rendered text showing a
14
+ * different time from what was selected in the Datetime, which could cause
15
+ * confusion.
16
+ */
17
+ export const stripTimeZone = (formatOptions) => {
18
+ return Object.assign(Object.assign({}, formatOptions), {
19
+ /**
20
+ * Setting the time zone to UTC ensures that the value shown is always the
21
+ * same as what was selected and safeguards against older Safari bugs with
22
+ * Intl.DateTimeFormat.
23
+ */
24
+ timeZone: 'UTC',
25
+ /**
26
+ * We do not want to display the time zone name
27
+ */
28
+ timeZoneName: undefined
29
+ });
30
+ };
31
+ export const getLocalizedTime = (locale, refParts, hourCycle, formatOptions = { hour: 'numeric', minute: 'numeric' }) => {
13
32
  const timeParts = {
14
33
  hour: refParts.hour,
15
34
  minute: refParts.minute,
@@ -17,28 +36,13 @@ export const getLocalizedTime = (locale, refParts, hourCycle) => {
17
36
  if (timeParts.hour === undefined || timeParts.minute === undefined) {
18
37
  return 'Invalid Time';
19
38
  }
20
- return new Intl.DateTimeFormat(locale, {
21
- hour: 'numeric',
22
- minute: 'numeric',
23
- /**
24
- * Setting the timeZone to UTC prevents
25
- * new Intl.DatetimeFormat from subtracting
26
- * the user's current timezone offset
27
- * when formatting the time.
28
- */
29
- timeZone: 'UTC',
39
+ return new Intl.DateTimeFormat(locale, Object.assign(Object.assign({}, stripTimeZone(formatOptions)), {
30
40
  /**
31
41
  * We use hourCycle here instead of hour12 due to:
32
42
  * https://bugs.chromium.org/p/chromium/issues/detail?id=1347316&q=hour12&can=2
33
43
  */
34
- hourCycle,
35
- /**
36
- * Setting Z at the end indicates that this
37
- * date string is in the UTC time zone. This
38
- * prevents new Date from adding the time zone
39
- * offset when getting the ISO string.
40
- */
41
- }).format(new Date(convertDataToISO(Object.assign({
44
+ hourCycle
45
+ })).format(new Date(convertDataToISO(Object.assign({
42
46
  /**
43
47
  * JS uses a simplified ISO 8601 format which allows for
44
48
  * date-only formats and date-time formats, but not
@@ -125,14 +129,6 @@ export const generateDayAriaLabel = (locale, today, refParts) => {
125
129
  */
126
130
  return today ? `Today, ${labelString}` : labelString;
127
131
  };
128
- /**
129
- * Gets the day of the week, month, and day
130
- * Used for the header in MD mode.
131
- */
132
- export const getMonthAndDay = (locale, refParts) => {
133
- const date = getNormalizedDate(refParts);
134
- return new Intl.DateTimeFormat(locale, { weekday: 'short', month: 'short', day: 'numeric', timeZone: 'UTC' }).format(date);
135
- };
136
132
  /**
137
133
  * Given a locale and a date object,
138
134
  * return a formatted string that includes
@@ -143,15 +139,6 @@ export const getMonthAndYear = (locale, refParts) => {
143
139
  const date = getNormalizedDate(refParts);
144
140
  return new Intl.DateTimeFormat(locale, { month: 'long', year: 'numeric', timeZone: 'UTC' }).format(date);
145
141
  };
146
- /**
147
- * Given a locale and a date object,
148
- * return a formatted string that includes
149
- * the short month, numeric day, and full year.
150
- * Example: Apr 22, 2021
151
- */
152
- export const getMonthDayAndYear = (locale, refParts) => {
153
- return getLocalizedDateTime(locale, refParts, { month: 'short', day: 'numeric', year: 'numeric' });
154
- };
155
142
  /**
156
143
  * Given a locale and a date object,
157
144
  * return a formatted string that includes
@@ -201,7 +188,7 @@ export const getNormalizedDate = (refParts) => {
201
188
  */
202
189
  export const getLocalizedDateTime = (locale, refParts, options) => {
203
190
  const date = getNormalizedDate(refParts);
204
- return getDateTimeFormat(locale, options).format(date);
191
+ return getDateTimeFormat(locale, stripTimeZone(options)).format(date);
205
192
  };
206
193
  /**
207
194
  * Given a locale, DatetimeParts, and options
@@ -0,0 +1,45 @@
1
+ /*!
2
+ * (C) Ionic http://ionicframework.com - MIT License
3
+ */
4
+ import { printIonWarning } from "../../../utils/logging/index";
5
+ /**
6
+ * If a time zone is provided in the format options, the rendered text could
7
+ * differ from what was selected in the Datetime, which could cause
8
+ * confusion.
9
+ */
10
+ export const warnIfTimeZoneProvided = (el, formatOptions) => {
11
+ var _a, _b, _c, _d;
12
+ if (((_a = formatOptions === null || formatOptions === void 0 ? void 0 : formatOptions.date) === null || _a === void 0 ? void 0 : _a.timeZone) ||
13
+ ((_b = formatOptions === null || formatOptions === void 0 ? void 0 : formatOptions.date) === null || _b === void 0 ? void 0 : _b.timeZoneName) ||
14
+ ((_c = formatOptions === null || formatOptions === void 0 ? void 0 : formatOptions.time) === null || _c === void 0 ? void 0 : _c.timeZone) ||
15
+ ((_d = formatOptions === null || formatOptions === void 0 ? void 0 : formatOptions.time) === null || _d === void 0 ? void 0 : _d.timeZoneName)) {
16
+ printIonWarning('Datetime: "timeZone" and "timeZoneName" are not supported in "formatOptions".', el);
17
+ }
18
+ };
19
+ export const checkForPresentationFormatMismatch = (el, presentation, formatOptions) => {
20
+ // formatOptions is not required
21
+ if (!formatOptions)
22
+ return;
23
+ // If formatOptions is provided, the date and/or time objects are required, depending on the presentation
24
+ switch (presentation) {
25
+ case 'date':
26
+ case 'month-year':
27
+ case 'month':
28
+ case 'year':
29
+ if (formatOptions.date === undefined) {
30
+ printIonWarning(`Datetime: The '${presentation}' presentation requires a date object in formatOptions.`, el);
31
+ }
32
+ break;
33
+ case 'time':
34
+ if (formatOptions.time === undefined) {
35
+ printIonWarning(`Datetime: The 'time' presentation requires a time object in formatOptions.`, el);
36
+ }
37
+ break;
38
+ case 'date-time':
39
+ case 'time-date':
40
+ if (formatOptions.date === undefined && formatOptions.time === undefined) {
41
+ printIonWarning(`Datetime: The '${presentation}' presentation requires either a date or time object (or both) in formatOptions.`, el);
42
+ }
43
+ break;
44
+ }
45
+ };