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

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 (939) hide show
  1. package/components/action-sheet.js +4 -4
  2. package/components/alert.js +2 -2
  3. package/components/backdrop.js +1 -13
  4. package/components/button-active.js +1 -1
  5. package/components/button.js +2 -2
  6. package/components/checkbox.js +8 -80
  7. package/components/data.js +1 -1
  8. package/components/gesture-controller.js +1 -1
  9. package/components/helpers.js +1 -1
  10. package/components/index9.js +1 -1
  11. package/components/input-shims.js +8 -1
  12. package/components/ion-accordion-group.js +1 -1
  13. package/components/ion-back-button.js +1 -1
  14. package/components/ion-badge.js +2 -2
  15. package/components/ion-breadcrumb.js +2 -2
  16. package/components/ion-card-subtitle.js +2 -2
  17. package/components/ion-card-title.js +1 -1
  18. package/components/ion-card.js +2 -2
  19. package/components/ion-chip.js +2 -2
  20. package/components/ion-col.js +2 -2
  21. package/components/ion-content.js +5 -6
  22. package/components/ion-datetime-button.js +5 -5
  23. package/components/ion-datetime.js +41 -105
  24. package/components/ion-fab-button.js +4 -4
  25. package/components/ion-fab-list.js +3 -3
  26. package/components/ion-fab.js +2 -2
  27. package/components/ion-footer.js +3 -3
  28. package/components/ion-grid.js +2 -2
  29. package/components/ion-header.js +3 -3
  30. package/components/ion-img.js +1 -1
  31. package/components/ion-infinite-scroll-content.js +4 -4
  32. package/components/ion-infinite-scroll.js +1 -1
  33. package/components/ion-input.js +7 -93
  34. package/components/ion-item-divider.js +4 -4
  35. package/components/ion-item-group.js +1 -1
  36. package/components/ion-item-option.js +4 -4
  37. package/components/ion-item-options.js +4 -4
  38. package/components/ion-item-sliding.js +2 -2
  39. package/components/ion-loading.js +4 -4
  40. package/components/ion-menu-button.js +3 -3
  41. package/components/ion-menu-toggle.js +2 -2
  42. package/components/ion-menu.js +28 -43
  43. package/components/ion-modal.js +43 -28
  44. package/components/ion-nav-link.js +1 -1
  45. package/components/ion-nav.js +9 -5
  46. package/components/ion-picker-column-option.d.ts +11 -0
  47. package/components/ion-picker-column-option.js +9 -0
  48. package/components/ion-picker-column.js +2 -2
  49. package/components/ion-picker-legacy-column.d.ts +11 -0
  50. package/components/ion-picker-legacy-column.js +9 -0
  51. package/components/{ion-picker-internal.d.ts → ion-picker-legacy.d.ts} +4 -4
  52. package/components/ion-picker-legacy.js +321 -0
  53. package/components/ion-picker.js +1 -315
  54. package/components/ion-progress-bar.js +7 -4
  55. package/components/ion-range.js +34 -88
  56. package/components/ion-refresher-content.js +1 -1
  57. package/components/ion-refresher.js +4 -4
  58. package/components/ion-reorder-group.js +1 -1
  59. package/components/ion-reorder.js +1 -1
  60. package/components/ion-router-link.js +3 -3
  61. package/components/ion-router-outlet.js +2 -2
  62. package/components/ion-router.js +1 -1
  63. package/components/ion-row.js +1 -1
  64. package/components/ion-searchbar.js +7 -7
  65. package/components/ion-segment-button.js +5 -5
  66. package/components/ion-segment.js +2 -2
  67. package/components/ion-select-option.js +1 -1
  68. package/components/ion-select.js +65 -159
  69. package/components/ion-skeleton-text.js +2 -2
  70. package/components/ion-split-pane.js +28 -17
  71. package/components/ion-tab-bar.js +4 -4
  72. package/components/ion-tab-button.js +4 -4
  73. package/components/ion-tab.js +2 -2
  74. package/components/ion-tabs.js +1 -1
  75. package/components/ion-text.js +2 -2
  76. package/components/ion-textarea.js +7 -70
  77. package/components/ion-thumbnail.js +1 -1
  78. package/components/ion-title.js +3 -3
  79. package/components/ion-toast.js +12 -6
  80. package/components/ion-toggle.js +7 -64
  81. package/components/ion-toolbar.js +4 -4
  82. package/components/item.js +22 -7
  83. package/components/label.js +3 -3
  84. package/components/list-header.js +4 -4
  85. package/components/list.js +2 -2
  86. package/components/note.js +4 -4
  87. package/components/overlays.js +90 -40
  88. package/components/picker-column-option.js +124 -0
  89. package/components/picker-column.js +367 -324
  90. package/components/picker-column2.js +381 -0
  91. package/components/{picker-internal.js → picker.js} +33 -26
  92. package/components/popover.js +6 -6
  93. package/components/radio-group.js +1 -1
  94. package/components/radio.js +8 -81
  95. package/components/refresher.utils.js +1 -1
  96. package/components/ripple-effect.js +1 -1
  97. package/components/select-popover.js +2 -2
  98. package/components/spinner.js +1 -1
  99. package/components/swipe-back.js +1 -1
  100. package/css/core.css +90 -27
  101. package/css/core.css.map +1 -1
  102. package/css/display.css.map +1 -1
  103. package/css/float-elements.css.map +1 -1
  104. package/css/global.bundle.css +1 -1
  105. package/css/global.bundle.css.map +1 -1
  106. package/css/ionic-swiper.css.map +1 -1
  107. package/css/ionic.bundle.css +1 -1
  108. package/css/ionic.bundle.css.map +1 -1
  109. package/css/padding.css.map +1 -1
  110. package/css/structure.css.map +1 -1
  111. package/css/text-alignment.css.map +1 -1
  112. package/css/text-transformation.css.map +1 -1
  113. package/css/themes/dark.always.css +160 -0
  114. package/css/themes/dark.always.css.map +1 -0
  115. package/css/themes/dark.class.css +160 -0
  116. package/css/themes/dark.class.css.map +1 -0
  117. package/css/themes/dark.css +3 -0
  118. package/css/themes/dark.css.map +1 -0
  119. package/css/themes/dark.system.css +162 -0
  120. package/css/themes/dark.system.css.map +1 -0
  121. package/css/themes/high-contrast-dark.always.css +180 -0
  122. package/css/themes/high-contrast-dark.always.css.map +1 -0
  123. package/css/themes/high-contrast-dark.class.css +180 -0
  124. package/css/themes/high-contrast-dark.class.css.map +1 -0
  125. package/css/themes/high-contrast-dark.css +3 -0
  126. package/css/themes/high-contrast-dark.css.map +1 -0
  127. package/css/themes/high-contrast-dark.system.css +182 -0
  128. package/css/themes/high-contrast-dark.system.css.map +1 -0
  129. package/css/themes/high-contrast.always.css +101 -0
  130. package/css/themes/high-contrast.always.css.map +1 -0
  131. package/css/themes/high-contrast.class.css +101 -0
  132. package/css/themes/high-contrast.class.css.map +1 -0
  133. package/css/themes/high-contrast.css +3 -0
  134. package/css/themes/high-contrast.css.map +1 -0
  135. package/css/themes/high-contrast.system.css +103 -0
  136. package/css/themes/high-contrast.system.css.map +1 -0
  137. package/css/typography.css +1 -1
  138. package/css/typography.css.map +1 -1
  139. package/css/utils.bundle.css.map +1 -1
  140. package/dist/cjs/{animation-c2840aea.js → animation-4ad55058.js} +1 -1
  141. package/dist/cjs/{app-globals-92ad1b3d.js → app-globals-4d26cb5a.js} +1 -1
  142. package/dist/cjs/{button-active-2d6520ec.js → button-active-e447f58b.js} +3 -3
  143. package/dist/cjs/{data-a5109f09.js → data-e2bf21de.js} +1 -1
  144. package/dist/cjs/{framework-delegate-e0e13baa.js → framework-delegate-53817ef1.js} +1 -1
  145. package/dist/cjs/{gesture-controller-c40c045a.js → gesture-controller-9436f482.js} +1 -0
  146. package/dist/cjs/{hardware-back-button-2696acaf.js → hardware-back-button-4cb049f1.js} +2 -2
  147. package/dist/cjs/{helpers-da4c0ed1.js → helpers-b71ca811.js} +0 -1
  148. package/dist/cjs/{index-bef98850.js → index-347883f6.js} +1 -1
  149. package/dist/cjs/{index-62290fec.js → index-7574e3d2.js} +1 -1
  150. package/dist/cjs/{index-9bfcb6e8.js → index-92bb95d6.js} +4 -4
  151. package/dist/cjs/{index-4c96691f.js → index-bbc5b1f7.js} +4 -4
  152. package/dist/cjs/{index-0ffe376d.js → index-ea266398.js} +2 -2
  153. package/dist/cjs/{index-d1b59ffa.js → index-ee07ed59.js} +1 -1
  154. package/dist/cjs/index.cjs.js +13 -13
  155. package/dist/cjs/{input-shims-a9a85bb9.js → input-shims-679d87bc.js} +10 -3
  156. package/dist/cjs/{input.utils-d7dca90f.js → input.utils-5175aea1.js} +1 -1
  157. package/dist/cjs/ion-accordion_2.cjs.entry.js +4 -4
  158. package/dist/cjs/ion-action-sheet.cjs.entry.js +14 -14
  159. package/dist/cjs/ion-alert.cjs.entry.js +12 -12
  160. package/dist/cjs/ion-app_8.cjs.entry.js +28 -29
  161. package/dist/cjs/ion-avatar_3.cjs.entry.js +5 -5
  162. package/dist/cjs/ion-back-button.cjs.entry.js +4 -4
  163. package/dist/cjs/ion-backdrop.cjs.entry.js +3 -15
  164. package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +5 -5
  165. package/dist/cjs/ion-button_2.cjs.entry.js +5 -5
  166. package/dist/cjs/ion-card_5.cjs.entry.js +8 -8
  167. package/dist/cjs/ion-checkbox.cjs.entry.js +9 -77
  168. package/dist/cjs/ion-chip.cjs.entry.js +4 -4
  169. package/dist/cjs/ion-col_3.cjs.entry.js +7 -7
  170. package/dist/cjs/ion-datetime-button.cjs.entry.js +9 -9
  171. package/dist/cjs/ion-datetime_3.cjs.entry.js +56 -110
  172. package/dist/cjs/ion-fab_3.cjs.entry.js +12 -12
  173. package/dist/cjs/ion-img.cjs.entry.js +4 -4
  174. package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +9 -9
  175. package/dist/cjs/ion-input.cjs.entry.js +12 -92
  176. package/dist/cjs/ion-item-option_3.cjs.entry.js +13 -13
  177. package/dist/cjs/ion-item_8.cjs.entry.js +45 -30
  178. package/dist/cjs/ion-loading.cjs.entry.js +12 -11
  179. package/dist/cjs/ion-menu_3.cjs.entry.js +40 -56
  180. package/dist/cjs/ion-modal.cjs.entry.js +53 -38
  181. package/dist/cjs/ion-nav_2.cjs.entry.js +13 -10
  182. package/dist/cjs/ion-picker-column-option.cjs.entry.js +106 -0
  183. package/dist/cjs/{ion-picker-column-internal.cjs.entry.js → ion-picker-column.cjs.entry.js} +124 -93
  184. package/dist/cjs/{ion-picker-internal.cjs.entry.js → ion-picker.cjs.entry.js} +32 -25
  185. package/dist/cjs/ion-popover.cjs.entry.js +13 -12
  186. package/dist/cjs/ion-progress-bar.cjs.entry.js +9 -6
  187. package/dist/cjs/ion-radio_2.cjs.entry.js +10 -79
  188. package/dist/cjs/ion-range.cjs.entry.js +37 -90
  189. package/dist/cjs/ion-refresher_2.cjs.entry.js +12 -12
  190. package/dist/cjs/ion-reorder_2.cjs.entry.js +7 -7
  191. package/dist/cjs/ion-ripple-effect.cjs.entry.js +3 -3
  192. package/dist/cjs/ion-route_4.cjs.entry.js +6 -6
  193. package/dist/cjs/ion-searchbar.cjs.entry.js +9 -9
  194. package/dist/cjs/ion-segment_2.cjs.entry.js +11 -11
  195. package/dist/cjs/ion-select_3.cjs.entry.js +78 -169
  196. package/dist/cjs/ion-spinner.cjs.entry.js +3 -3
  197. package/dist/cjs/ion-split-pane.cjs.entry.js +28 -18
  198. package/dist/cjs/ion-tab-bar_2.cjs.entry.js +11 -11
  199. package/dist/cjs/ion-tab_2.cjs.entry.js +6 -6
  200. package/dist/cjs/ion-text.cjs.entry.js +4 -4
  201. package/dist/cjs/ion-textarea.cjs.entry.js +11 -71
  202. package/dist/cjs/ion-toast.cjs.entry.js +20 -14
  203. package/dist/cjs/ion-toggle.cjs.entry.js +10 -66
  204. package/dist/cjs/{ionic-global-59a10130.js → ionic-global-59aa7eb7.js} +1 -1
  205. package/dist/cjs/ionic.cjs.js +5 -5
  206. package/dist/cjs/{ios.transition-96679580.js → ios.transition-997fe325.js} +4 -4
  207. package/dist/cjs/loader.cjs.js +4 -4
  208. package/dist/cjs/{md.transition-d6c98822.js → md.transition-2b76c2c6.js} +4 -4
  209. package/dist/cjs/{notch-controller-bfbcbb7a.js → notch-controller-8e0ae870.js} +1 -1
  210. package/dist/cjs/{overlays-db5d96f3.js → overlays-3d02b54f.js} +93 -42
  211. package/dist/cjs/{status-tap-7ad5f0fb.js → status-tap-3761c2d4.js} +3 -3
  212. package/dist/cjs/{swipe-back-dcd0d4a9.js → swipe-back-5b71fc62.js} +3 -3
  213. package/dist/collection/collection-manifest.json +8 -7
  214. package/dist/collection/components/accordion-group/accordion-group.md.css +4 -26
  215. package/dist/collection/components/action-sheet/action-sheet.ios.css +16 -9
  216. package/dist/collection/components/action-sheet/action-sheet.js +2 -2
  217. package/dist/collection/components/action-sheet/action-sheet.md.css +10 -3
  218. package/dist/collection/components/action-sheet/test/a11y/action-sheet.e2e.js +23 -14
  219. package/dist/collection/components/action-sheet/test/basic/action-sheet-rendering.e2e.js +19 -0
  220. package/dist/collection/components/action-sheet/test/basic/action-sheet.spec.js +22 -0
  221. package/dist/collection/components/alert/alert.ios.css +33 -80
  222. package/dist/collection/components/alert/alert.md.css +25 -121
  223. package/dist/collection/components/alert/test/a11y/alert.e2e.js +22 -9
  224. package/dist/collection/components/back-button/back-button.ios.css +1 -1
  225. package/dist/collection/components/back-button/test/a11y/back-button.e2e.js +21 -0
  226. package/dist/collection/components/backdrop/backdrop.js +1 -13
  227. package/dist/collection/components/badge/badge.ios.css +1 -1
  228. package/dist/collection/components/badge/badge.md.css +1 -1
  229. package/dist/collection/components/badge/test/a11y/badge.e2e.js +18 -0
  230. package/dist/collection/components/breadcrumb/breadcrumb.ios.css +9 -9
  231. package/dist/collection/components/breadcrumb/breadcrumb.md.css +9 -9
  232. package/dist/collection/components/button/button.ios.css +11 -11
  233. package/dist/collection/components/button/button.md.css +9 -9
  234. package/dist/collection/components/button/test/a11y/button.e2e.js +48 -0
  235. package/dist/collection/components/button/test/wrap/button.e2e.js +12 -24
  236. package/dist/collection/components/card/card.ios.css +1 -1
  237. package/dist/collection/components/card/card.md.css +1 -1
  238. package/dist/collection/components/card-subtitle/card-subtitle.ios.css +1 -1
  239. package/dist/collection/components/card-subtitle/card-subtitle.md.css +1 -1
  240. package/dist/collection/components/card-title/card-title.md.css +1 -1
  241. package/dist/collection/components/checkbox/checkbox.ios.css +10 -88
  242. package/dist/collection/components/checkbox/checkbox.js +5 -118
  243. package/dist/collection/components/checkbox/checkbox.md.css +7 -85
  244. package/dist/collection/components/checkbox/test/a11y/checkbox.e2e.js +11 -2
  245. package/dist/collection/components/checkbox/test/basic/checkbox.e2e.js +10 -0
  246. package/dist/collection/components/chip/chip.js +2 -2
  247. package/dist/collection/components/col/col.js +2 -2
  248. package/dist/collection/components/content/content.css +0 -4
  249. package/dist/collection/components/content/content.js +3 -4
  250. package/dist/collection/components/datetime/datetime.ios.css +105 -117
  251. package/dist/collection/components/datetime/datetime.js +25 -77
  252. package/dist/collection/components/datetime/datetime.md.css +106 -114
  253. package/dist/collection/components/datetime/test/a11y/datetime.e2e.js +1 -1
  254. package/dist/collection/components/datetime/test/a11y/datetime.spec.js +6 -9
  255. package/dist/collection/components/datetime/test/basic/datetime.e2e.js +13 -1
  256. package/dist/collection/components/datetime/test/datetime.e2e.js +2 -2
  257. package/dist/collection/components/datetime/test/disabled/datetime.spec.js +4 -4
  258. package/dist/collection/components/datetime/test/locale/datetime.e2e.js +2 -2
  259. package/dist/collection/components/datetime/test/minmax/datetime.e2e.js +6 -6
  260. package/dist/collection/components/datetime/test/month-year-picker/datetime.e2e.js +1 -1
  261. package/dist/collection/components/datetime/test/prefer-wheel/datetime.e2e.js +43 -41
  262. package/dist/collection/components/datetime/test/presentation/datetime.e2e.js +1 -1
  263. package/dist/collection/components/datetime/test/readonly/datetime.e2e.js +4 -4
  264. package/dist/collection/components/datetime/test/values/datetime.e2e.js +15 -12
  265. package/dist/collection/components/datetime/utils/data.js +1 -1
  266. package/dist/collection/components/datetime-button/datetime-button.ios.css +107 -0
  267. package/dist/collection/components/datetime-button/datetime-button.js +5 -5
  268. package/dist/collection/components/datetime-button/{datetime-button.css → datetime-button.md.css} +10 -7
  269. package/dist/collection/components/datetime-button/test/basic/datetime-button.e2e.js +12 -0
  270. package/dist/collection/components/fab/fab.js +2 -2
  271. package/dist/collection/components/fab-button/fab-button.ios.css +7 -7
  272. package/dist/collection/components/fab-button/fab-button.js +2 -2
  273. package/dist/collection/components/fab-button/fab-button.md.css +1 -1
  274. package/dist/collection/components/fab-button/test/a11y/fab-button.e2e.js +50 -0
  275. package/dist/collection/components/fab-list/fab-list.css +4 -42
  276. package/dist/collection/components/fab-list/fab-list.js +2 -2
  277. package/dist/collection/components/footer/footer.js +2 -2
  278. package/dist/collection/components/grid/grid.js +2 -2
  279. package/dist/collection/components/header/header.js +2 -2
  280. package/dist/collection/components/img/img.js +1 -1
  281. package/dist/collection/components/infinite-scroll/infinite-scroll.js +1 -1
  282. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.ios.css +3 -3
  283. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +2 -2
  284. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.md.css +3 -3
  285. package/dist/collection/components/input/input.ios.css +11 -104
  286. package/dist/collection/components/input/input.js +6 -144
  287. package/dist/collection/components/input/input.md.css +35 -216
  288. package/dist/collection/components/input/test/a11y/input.e2e.js +41 -3
  289. package/dist/collection/components/input/test/item/input.e2e.js +21 -0
  290. package/dist/collection/components/item/item.ios.css +7 -31
  291. package/dist/collection/components/item/item.js +20 -5
  292. package/dist/collection/components/item/item.md.css +29 -112
  293. package/dist/collection/components/item/test/a11y/item.e2e.js +0 -40
  294. package/dist/collection/components/item-divider/item-divider.ios.css +3 -3
  295. package/dist/collection/components/item-divider/item-divider.js +2 -2
  296. package/dist/collection/components/item-divider/item-divider.md.css +7 -17
  297. package/dist/collection/components/item-group/item-group.js +1 -1
  298. package/dist/collection/components/item-option/item-option.ios.css +2 -2
  299. package/dist/collection/components/item-option/item-option.js +2 -2
  300. package/dist/collection/components/item-option/item-option.md.css +1 -1
  301. package/dist/collection/components/item-options/item-options.ios.css +1 -1
  302. package/dist/collection/components/item-options/item-options.js +1 -1
  303. package/dist/collection/components/item-options/item-options.md.css +1 -1
  304. package/dist/collection/components/item-sliding/item-sliding.js +1 -1
  305. package/dist/collection/components/item-sliding/test/a11y/item-sliding.e2e.js +28 -0
  306. package/dist/collection/components/label/label.ios.css +1 -1
  307. package/dist/collection/components/label/label.js +1 -1
  308. package/dist/collection/components/label/label.md.css +2 -2
  309. package/dist/collection/components/label/test/a11y/label.e2e.js +20 -0
  310. package/dist/collection/components/list/list.js +1 -1
  311. package/dist/collection/components/list/list.md.css +2 -26
  312. package/dist/collection/components/list-header/list-header.ios.css +2 -2
  313. package/dist/collection/components/list-header/list-header.js +2 -2
  314. package/dist/collection/components/list-header/list-header.md.css +1 -1
  315. package/dist/collection/components/loading/loading.ios.css +2 -2
  316. package/dist/collection/components/loading/loading.js +2 -2
  317. package/dist/collection/components/loading/loading.md.css +3 -3
  318. package/dist/collection/components/loading/test/a11y/loading.e2e.js +21 -5
  319. package/dist/collection/components/menu/menu.ios.css +72 -53
  320. package/dist/collection/components/menu/menu.js +25 -39
  321. package/dist/collection/components/menu/menu.md.css +72 -53
  322. package/dist/collection/components/menu-button/menu-button.ios.css +1 -1
  323. package/dist/collection/components/menu-button/menu-button.js +2 -2
  324. package/dist/collection/components/menu-button/test/a11y/menu-button.e2e.js +14 -0
  325. package/dist/collection/components/menu-toggle/menu-toggle.js +2 -2
  326. package/dist/collection/components/modal/gestures/swipe-to-close.js +1 -1
  327. package/dist/collection/components/modal/modal.ios.css +9 -38
  328. package/dist/collection/components/modal/modal.js +37 -5
  329. package/dist/collection/components/modal/modal.md.css +1 -1
  330. package/dist/collection/components/modal/test/modal-attributes.spec.js +32 -0
  331. package/dist/collection/components/modal/utils.js +2 -8
  332. package/dist/collection/components/nav/nav.js +23 -3
  333. package/dist/collection/components/nav/test/nav-controller.spec.js +36 -36
  334. package/dist/collection/components/nav-link/nav-link.js +1 -1
  335. package/dist/collection/components/note/note.ios.css +1 -1
  336. package/dist/collection/components/note/note.js +2 -2
  337. package/dist/collection/components/note/note.md.css +1 -1
  338. package/dist/collection/components/picker/picker.ios.css +97 -234
  339. package/dist/collection/components/picker/picker.js +488 -742
  340. package/dist/collection/components/picker/picker.md.css +98 -226
  341. package/dist/collection/components/{picker-internal/test/a11y/picker-internal.e2e.js → picker/test/a11y/picker.e2e.js} +2 -2
  342. package/dist/collection/components/picker/test/basic/picker.e2e.js +99 -13
  343. package/dist/collection/components/picker/test/custom/picker.e2e.js +85 -0
  344. package/dist/collection/components/{picker-internal/test/keyboard-entry/picker-internal.e2e.js → picker/test/keyboard-entry/picker.e2e.js} +79 -42
  345. package/dist/collection/components/{picker-column-internal/picker-column-internal.md.css → picker-column/picker-column.css} +96 -83
  346. package/dist/collection/components/picker-column/picker-column.js +514 -335
  347. package/dist/collection/components/{picker-column-internal/test/basic/picker-column-internal.e2e.js → picker-column/test/basic/picker-column.e2e.js} +8 -8
  348. package/dist/collection/components/picker-column/test/disabled/picker-column.e2e.js +91 -0
  349. package/dist/collection/components/picker-column/test/slots/picker-column.e2e.js +39 -0
  350. package/dist/collection/components/picker-column-option/picker-column-option.ios.css +87 -0
  351. package/dist/collection/components/picker-column-option/picker-column-option.js +173 -0
  352. package/dist/collection/components/{picker-column-internal/picker-column-internal.ios.css → picker-column-option/picker-column-option.md.css} +6 -53
  353. package/dist/collection/components/picker-column-option/test/a11y/picker-column-option.e2e.js +18 -0
  354. package/dist/collection/components/picker-column-option/test/basic/picker-column-option.e2e.js +37 -0
  355. package/dist/collection/components/picker-column-option/test/picker-column-option.spec.js +29 -0
  356. package/dist/collection/components/{picker-internal/picker-internal.ios.css → picker-legacy/picker.ios.css} +155 -117
  357. package/dist/collection/components/picker-legacy/picker.js +821 -0
  358. package/dist/collection/components/{picker-internal/picker-internal.md.css → picker-legacy/picker.md.css} +144 -115
  359. package/dist/collection/components/picker-legacy/test/basic/picker.e2e.js +25 -0
  360. package/dist/collection/components/{picker → picker-legacy}/test/is-open/picker.e2e.js +4 -4
  361. package/dist/collection/components/{picker → picker-legacy}/test/picker-id.spec.js +5 -5
  362. package/dist/collection/components/{picker → picker-legacy}/test/trigger/picker.e2e.js +1 -1
  363. package/dist/collection/components/{picker-column → picker-legacy-column}/picker-column.ios.css +2 -26
  364. package/dist/collection/components/picker-legacy-column/picker-column.js +419 -0
  365. package/dist/collection/components/{picker-column → picker-legacy-column}/picker-column.md.css +3 -27
  366. package/dist/collection/components/{picker-column → picker-legacy-column}/test/picker-column-aria.spec.js +3 -3
  367. package/dist/collection/components/{picker-column → picker-legacy-column}/test/picker-column-dynamic.spec.js +2 -2
  368. package/dist/collection/components/{picker-column → picker-legacy-column}/test/picker-column.spec.js +2 -2
  369. package/dist/collection/components/{picker-column → picker-legacy-column}/test/standalone/picker-column.e2e.js +3 -3
  370. package/dist/collection/components/popover/popover.ios.css +3 -27
  371. package/dist/collection/components/popover/popover.js +5 -4
  372. package/dist/collection/components/progress-bar/progress-bar.ios.css +17 -11
  373. package/dist/collection/components/progress-bar/progress-bar.js +4 -1
  374. package/dist/collection/components/progress-bar/progress-bar.md.css +8 -10
  375. package/dist/collection/components/progress-bar/test/a11y/progress-bar.e2e.js +24 -0
  376. package/dist/collection/components/radio/radio.ios.css +10 -101
  377. package/dist/collection/components/radio/radio.js +5 -119
  378. package/dist/collection/components/radio/radio.md.css +8 -105
  379. package/dist/collection/components/radio/test/a11y/radio.e2e.js +114 -81
  380. package/dist/collection/components/radio-group/radio-group.js +1 -1
  381. package/dist/collection/components/range/range.ios.css +12 -90
  382. package/dist/collection/components/range/range.js +30 -123
  383. package/dist/collection/components/range/range.md.css +22 -152
  384. package/dist/collection/components/range/test/a11y/range.e2e.js +20 -10
  385. package/dist/collection/components/range/test/range-events.e2e.js +1 -1
  386. package/dist/collection/components/range/test/range.spec.js +0 -12
  387. package/dist/collection/components/refresher/refresher.ios.css +4 -27
  388. package/dist/collection/components/refresher/refresher.js +1 -1
  389. package/dist/collection/components/refresher/refresher.md.css +7 -30
  390. package/dist/collection/components/refresher/test/a11y/refresher.e2e.js +26 -0
  391. package/dist/collection/components/refresher-content/refresher-content.js +1 -1
  392. package/dist/collection/components/reorder/reorder.js +1 -1
  393. package/dist/collection/components/reorder-group/reorder-group.js +1 -1
  394. package/dist/collection/components/ripple-effect/ripple-effect.js +1 -1
  395. package/dist/collection/components/router-link/router-link.css +1 -1
  396. package/dist/collection/components/router-link/router-link.js +2 -2
  397. package/dist/collection/components/router-link/test/a11y/router-link.e2e.js +23 -0
  398. package/dist/collection/components/router-outlet/router-outlet.js +1 -1
  399. package/dist/collection/components/row/row.js +1 -1
  400. package/dist/collection/components/searchbar/searchbar.ios.css +11 -59
  401. package/dist/collection/components/searchbar/searchbar.js +4 -4
  402. package/dist/collection/components/searchbar/searchbar.md.css +10 -82
  403. package/dist/collection/components/segment/segment.js +2 -2
  404. package/dist/collection/components/segment/test/a11y/segment.e2e.js +23 -0
  405. package/dist/collection/components/segment-button/segment-button.ios.css +3 -3
  406. package/dist/collection/components/segment-button/segment-button.js +3 -3
  407. package/dist/collection/components/segment-button/segment-button.md.css +2 -2
  408. package/dist/collection/components/select/select.ios.css +10 -81
  409. package/dist/collection/components/select/select.js +64 -173
  410. package/dist/collection/components/select/select.md.css +38 -169
  411. package/dist/collection/components/select/test/a11y/select.e2e.js +68 -4
  412. package/dist/collection/components/select-option/select-option.js +1 -1
  413. package/dist/collection/components/select-popover/select-popover.js +1 -1
  414. package/dist/collection/components/select-popover/select-popover.md.css +4 -4
  415. package/dist/collection/components/select-popover/test/a11y/select-popover.e2e.js +32 -0
  416. package/dist/collection/components/skeleton-text/skeleton-text.js +2 -2
  417. package/dist/collection/components/spinner/spinner.js +1 -1
  418. package/dist/collection/components/split-pane/split-pane.ios.css +3 -55
  419. package/dist/collection/components/split-pane/split-pane.js +48 -14
  420. package/dist/collection/components/split-pane/split-pane.md.css +3 -55
  421. package/dist/collection/components/split-pane/test/wrapped-menu/split-pane.e2e.js +41 -0
  422. package/dist/collection/components/tab/tab.js +2 -2
  423. package/dist/collection/components/tab-bar/tab-bar.ios.css +4 -4
  424. package/dist/collection/components/tab-bar/tab-bar.js +2 -2
  425. package/dist/collection/components/tab-bar/tab-bar.md.css +3 -3
  426. package/dist/collection/components/tab-button/tab-button.ios.css +16 -94
  427. package/dist/collection/components/tab-button/tab-button.js +2 -2
  428. package/dist/collection/components/tab-button/tab-button.md.css +10 -93
  429. package/dist/collection/components/tabs/tabs.js +1 -1
  430. package/dist/collection/components/text/text.js +2 -2
  431. package/dist/collection/components/textarea/test/a11y/textarea.e2e.js +41 -3
  432. package/dist/collection/components/textarea/test/item/textarea.e2e.js +21 -0
  433. package/dist/collection/components/textarea/textarea.ios.css +13 -103
  434. package/dist/collection/components/textarea/textarea.js +5 -84
  435. package/dist/collection/components/textarea/textarea.md.css +37 -226
  436. package/dist/collection/components/thumbnail/thumbnail.js +1 -1
  437. package/dist/collection/components/title/title.ios.css +2 -21
  438. package/dist/collection/components/title/title.js +2 -2
  439. package/dist/collection/components/toast/test/a11y/toast.e2e.js +89 -24
  440. package/dist/collection/components/toast/toast.ios.css +8 -55
  441. package/dist/collection/components/toast/toast.js +9 -3
  442. package/dist/collection/components/toast/toast.md.css +10 -57
  443. package/dist/collection/components/toggle/test/a11y/toggle.e2e.js +8 -2
  444. package/dist/collection/components/toggle/toggle.ios.css +11 -90
  445. package/dist/collection/components/toggle/toggle.js +5 -101
  446. package/dist/collection/components/toggle/toggle.md.css +6 -91
  447. package/dist/collection/components/toolbar/toolbar.ios.css +2 -2
  448. package/dist/collection/components/toolbar/toolbar.js +2 -2
  449. package/dist/collection/components/toolbar/toolbar.md.css +1 -1
  450. package/dist/collection/css/test/a11y/typography.e2e.js +18 -0
  451. package/dist/collection/themes/test/colors/theme.e2e.js +170 -0
  452. package/dist/collection/utils/focus-trap.js +78 -0
  453. package/dist/collection/utils/gesture/button-active.js +1 -1
  454. package/dist/collection/utils/gesture/gesture-controller.js +1 -1
  455. package/dist/collection/utils/input-shims/input-shims.js +8 -1
  456. package/dist/collection/utils/native/status-bar.js +0 -11
  457. package/dist/collection/utils/overlays.js +14 -38
  458. package/dist/collection/utils/test/aria.spec.js +2 -1
  459. package/dist/collection/utils/test/overlays/overlays-scroll-blocking.spec.js +65 -0
  460. package/dist/collection/utils/test/playwright/generator.js +1 -0
  461. package/dist/collection/utils/test/playwright/page/utils/set-content.js +1 -1
  462. package/dist/docs.json +569 -331
  463. package/dist/esm/{animation-6a0c5338.js → animation-a4acf150.js} +1 -1
  464. package/dist/esm/{app-globals-5cf6195b.js → app-globals-cfb6787b.js} +1 -1
  465. package/dist/esm/{button-active-47ac8092.js → button-active-454e5c57.js} +3 -3
  466. package/dist/esm/{data-0f3ab200.js → data-691286f1.js} +1 -1
  467. package/dist/esm/{framework-delegate-ed4ba327.js → framework-delegate-1eb3236c.js} +1 -1
  468. package/dist/esm/{gesture-controller-1bf57181.js → gesture-controller-314a54f6.js} +1 -1
  469. package/dist/esm/{hardware-back-button-b410a047.js → hardware-back-button-3a14f99e.js} +2 -2
  470. package/dist/esm/{helpers-be245865.js → helpers-ae74b3c9.js} +1 -1
  471. package/dist/esm/{index-e1b622e3.js → index-03086279.js} +4 -4
  472. package/dist/esm/{index-020f5464.js → index-1f563746.js} +1 -1
  473. package/dist/esm/{index-2cf77112.js → index-39782642.js} +2 -2
  474. package/dist/esm/{index-348ed70a.js → index-5847f4a9.js} +4 -4
  475. package/dist/esm/{index-f3946ac1.js → index-66871a1d.js} +1 -1
  476. package/dist/esm/{index-4c30cddd.js → index-9b6d6df3.js} +2 -2
  477. package/dist/esm/index.js +13 -13
  478. package/dist/esm/{input-shims-5329bbe8.js → input-shims-56c1f603.js} +10 -3
  479. package/dist/esm/{input.utils-a445f677.js → input.utils-482fc893.js} +1 -1
  480. package/dist/esm/ion-accordion_2.entry.js +4 -4
  481. package/dist/esm/ion-action-sheet.entry.js +14 -14
  482. package/dist/esm/ion-alert.entry.js +12 -12
  483. package/dist/esm/ion-app_8.entry.js +28 -29
  484. package/dist/esm/ion-avatar_3.entry.js +5 -5
  485. package/dist/esm/ion-back-button.entry.js +4 -4
  486. package/dist/esm/ion-backdrop.entry.js +3 -15
  487. package/dist/esm/ion-breadcrumb_2.entry.js +5 -5
  488. package/dist/esm/ion-button_2.entry.js +5 -5
  489. package/dist/esm/ion-card_5.entry.js +8 -8
  490. package/dist/esm/ion-checkbox.entry.js +9 -77
  491. package/dist/esm/ion-chip.entry.js +4 -4
  492. package/dist/esm/ion-col_3.entry.js +7 -7
  493. package/dist/esm/ion-datetime-button.entry.js +9 -9
  494. package/dist/esm/ion-datetime_3.entry.js +55 -109
  495. package/dist/esm/ion-fab_3.entry.js +12 -12
  496. package/dist/esm/ion-img.entry.js +4 -4
  497. package/dist/esm/ion-infinite-scroll_2.entry.js +9 -9
  498. package/dist/esm/ion-input.entry.js +12 -92
  499. package/dist/esm/ion-item-option_3.entry.js +13 -13
  500. package/dist/esm/ion-item_8.entry.js +45 -30
  501. package/dist/esm/ion-loading.entry.js +12 -11
  502. package/dist/esm/ion-menu_3.entry.js +41 -57
  503. package/dist/esm/ion-modal.entry.js +53 -38
  504. package/dist/esm/ion-nav_2.entry.js +13 -10
  505. package/dist/esm/ion-picker-column-option.entry.js +102 -0
  506. package/dist/esm/{ion-picker-column-internal.entry.js → ion-picker-column.entry.js} +124 -93
  507. package/dist/esm/{ion-picker-internal.entry.js → ion-picker.entry.js} +32 -25
  508. package/dist/esm/ion-popover.entry.js +13 -12
  509. package/dist/esm/ion-progress-bar.entry.js +9 -6
  510. package/dist/esm/ion-radio_2.entry.js +10 -79
  511. package/dist/esm/ion-range.entry.js +38 -91
  512. package/dist/esm/ion-refresher_2.entry.js +12 -12
  513. package/dist/esm/ion-reorder_2.entry.js +7 -7
  514. package/dist/esm/ion-ripple-effect.entry.js +3 -3
  515. package/dist/esm/ion-route_4.entry.js +6 -6
  516. package/dist/esm/ion-searchbar.entry.js +9 -9
  517. package/dist/esm/ion-segment_2.entry.js +11 -11
  518. package/dist/esm/ion-select_3.entry.js +76 -167
  519. package/dist/esm/ion-spinner.entry.js +3 -3
  520. package/dist/esm/ion-split-pane.entry.js +28 -18
  521. package/dist/esm/ion-tab-bar_2.entry.js +11 -11
  522. package/dist/esm/ion-tab_2.entry.js +6 -6
  523. package/dist/esm/ion-text.entry.js +4 -4
  524. package/dist/esm/ion-textarea.entry.js +12 -72
  525. package/dist/esm/ion-toast.entry.js +21 -15
  526. package/dist/esm/ion-toggle.entry.js +10 -66
  527. package/dist/esm/{ionic-global-ad9a1810.js → ionic-global-c976d684.js} +1 -1
  528. package/dist/esm/ionic.js +6 -6
  529. package/dist/esm/{ios.transition-7459f819.js → ios.transition-a097dbf5.js} +4 -4
  530. package/dist/esm/loader.js +5 -5
  531. package/dist/esm/{md.transition-b8224313.js → md.transition-b4170ef7.js} +4 -4
  532. package/dist/esm/{notch-controller-6bd3e0f9.js → notch-controller-18bf9f76.js} +1 -1
  533. package/dist/esm/{overlays-19b26885.js → overlays-4ba3b255.js} +93 -43
  534. package/dist/esm/{status-tap-b41ece3c.js → status-tap-7a12f017.js} +3 -3
  535. package/dist/esm/{swipe-back-c6d0e5d9.js → swipe-back-ae14449a.js} +3 -3
  536. package/dist/esm-es5/{animation-6a0c5338.js → animation-a4acf150.js} +1 -1
  537. package/dist/esm-es5/app-globals-cfb6787b.js +4 -0
  538. package/dist/esm-es5/button-active-454e5c57.js +4 -0
  539. package/dist/esm-es5/{framework-delegate-ed4ba327.js → framework-delegate-1eb3236c.js} +1 -1
  540. package/dist/esm-es5/{gesture-controller-1bf57181.js → gesture-controller-314a54f6.js} +1 -1
  541. package/dist/esm-es5/{hardware-back-button-b410a047.js → hardware-back-button-3a14f99e.js} +1 -1
  542. package/dist/esm-es5/{helpers-be245865.js → helpers-ae74b3c9.js} +1 -1
  543. package/dist/esm-es5/{index-e1b622e3.js → index-03086279.js} +1 -1
  544. package/dist/esm-es5/{index-020f5464.js → index-1f563746.js} +1 -1
  545. package/dist/esm-es5/{index-2cf77112.js → index-39782642.js} +1 -1
  546. package/dist/esm-es5/{index-348ed70a.js → index-5847f4a9.js} +1 -1
  547. package/dist/esm-es5/{index-f3946ac1.js → index-66871a1d.js} +1 -1
  548. package/dist/esm-es5/{index-4c30cddd.js → index-9b6d6df3.js} +1 -1
  549. package/dist/esm-es5/index.js +1 -1
  550. package/dist/esm-es5/{input-shims-5329bbe8.js → input-shims-56c1f603.js} +1 -1
  551. package/dist/esm-es5/{input.utils-a445f677.js → input.utils-482fc893.js} +1 -1
  552. package/dist/esm-es5/ion-accordion_2.entry.js +1 -1
  553. package/dist/esm-es5/ion-action-sheet.entry.js +1 -1
  554. package/dist/esm-es5/ion-alert.entry.js +1 -1
  555. package/dist/esm-es5/ion-app_8.entry.js +1 -1
  556. package/dist/esm-es5/ion-avatar_3.entry.js +1 -1
  557. package/dist/esm-es5/ion-back-button.entry.js +1 -1
  558. package/dist/esm-es5/ion-backdrop.entry.js +1 -1
  559. package/dist/esm-es5/ion-breadcrumb_2.entry.js +1 -1
  560. package/dist/esm-es5/ion-button_2.entry.js +1 -1
  561. package/dist/esm-es5/ion-card_5.entry.js +1 -1
  562. package/dist/esm-es5/ion-checkbox.entry.js +1 -1
  563. package/dist/esm-es5/ion-chip.entry.js +1 -1
  564. package/dist/esm-es5/ion-col_3.entry.js +1 -1
  565. package/dist/esm-es5/ion-datetime-button.entry.js +1 -1
  566. package/dist/esm-es5/ion-datetime_3.entry.js +1 -1
  567. package/dist/esm-es5/ion-fab_3.entry.js +1 -1
  568. package/dist/esm-es5/ion-img.entry.js +1 -1
  569. package/dist/esm-es5/ion-infinite-scroll_2.entry.js +1 -1
  570. package/dist/esm-es5/ion-input.entry.js +1 -1
  571. package/dist/esm-es5/ion-item-option_3.entry.js +1 -1
  572. package/dist/esm-es5/ion-item_8.entry.js +1 -1
  573. package/dist/esm-es5/ion-loading.entry.js +1 -1
  574. package/dist/esm-es5/ion-menu_3.entry.js +1 -1
  575. package/dist/esm-es5/ion-modal.entry.js +1 -1
  576. package/dist/esm-es5/ion-nav_2.entry.js +1 -1
  577. package/dist/esm-es5/ion-picker-column-option.entry.js +4 -0
  578. package/dist/esm-es5/ion-picker-column.entry.js +4 -0
  579. package/dist/esm-es5/ion-picker.entry.js +4 -0
  580. package/dist/esm-es5/ion-popover.entry.js +1 -1
  581. package/dist/esm-es5/ion-progress-bar.entry.js +1 -1
  582. package/dist/esm-es5/ion-radio_2.entry.js +1 -1
  583. package/dist/esm-es5/ion-range.entry.js +1 -1
  584. package/dist/esm-es5/ion-refresher_2.entry.js +1 -1
  585. package/dist/esm-es5/ion-reorder_2.entry.js +1 -1
  586. package/dist/esm-es5/ion-ripple-effect.entry.js +1 -1
  587. package/dist/esm-es5/ion-route_4.entry.js +1 -1
  588. package/dist/esm-es5/ion-searchbar.entry.js +1 -1
  589. package/dist/esm-es5/ion-segment_2.entry.js +1 -1
  590. package/dist/esm-es5/ion-select_3.entry.js +1 -1
  591. package/dist/esm-es5/ion-spinner.entry.js +1 -1
  592. package/dist/esm-es5/ion-split-pane.entry.js +1 -1
  593. package/dist/esm-es5/ion-tab-bar_2.entry.js +1 -1
  594. package/dist/esm-es5/ion-tab_2.entry.js +1 -1
  595. package/dist/esm-es5/ion-text.entry.js +1 -1
  596. package/dist/esm-es5/ion-textarea.entry.js +1 -1
  597. package/dist/esm-es5/ion-toast.entry.js +1 -1
  598. package/dist/esm-es5/ion-toggle.entry.js +1 -1
  599. package/dist/esm-es5/{ionic-global-ad9a1810.js → ionic-global-c976d684.js} +1 -1
  600. package/dist/esm-es5/ionic.js +1 -1
  601. package/dist/esm-es5/{ios.transition-7459f819.js → ios.transition-a097dbf5.js} +1 -1
  602. package/dist/esm-es5/loader.js +1 -1
  603. package/dist/esm-es5/md.transition-b4170ef7.js +4 -0
  604. package/dist/esm-es5/{notch-controller-6bd3e0f9.js → notch-controller-18bf9f76.js} +1 -1
  605. package/dist/esm-es5/overlays-4ba3b255.js +4 -0
  606. package/dist/esm-es5/{status-tap-b41ece3c.js → status-tap-7a12f017.js} +1 -1
  607. package/dist/esm-es5/{swipe-back-c6d0e5d9.js → swipe-back-ae14449a.js} +1 -1
  608. package/dist/html.html-data.json +152 -37
  609. package/dist/ionic/index.esm.js +1 -1
  610. package/dist/ionic/ionic.esm.js +1 -1
  611. package/dist/ionic/ionic.js +1 -1
  612. package/dist/ionic/p-03f63663.system.js +4 -0
  613. package/dist/ionic/p-060fdc03.entry.js +4 -0
  614. package/dist/ionic/{p-1bc9b5f5.system.js → p-069388dd.system.js} +1 -1
  615. package/dist/ionic/p-06fccad7.entry.js +4 -0
  616. package/dist/ionic/p-09872ec8.system.entry.js +4 -0
  617. package/dist/ionic/p-0ca35c1d.system.entry.js +4 -0
  618. package/dist/ionic/p-134d4936.system.js +4 -0
  619. package/dist/ionic/{p-779aede8.js → p-15708968.js} +1 -1
  620. package/dist/ionic/p-1600d68c.system.entry.js +4 -0
  621. package/dist/ionic/p-19e79fe8.entry.js +4 -0
  622. package/dist/ionic/{p-6afef6c1.system.js → p-19f6ac6c.system.js} +1 -1
  623. package/dist/ionic/{p-ebc86ce9.system.entry.js → p-1a5ed3fe.system.entry.js} +1 -1
  624. package/dist/ionic/p-1a68de09.entry.js +4 -0
  625. package/dist/ionic/p-1bca443b.system.entry.js +4 -0
  626. package/dist/ionic/p-1c436e95.system.entry.js +4 -0
  627. package/dist/ionic/{p-657ccdd6.entry.js → p-1ce172db.entry.js} +1 -1
  628. package/dist/ionic/p-1e0a18a1.system.entry.js +4 -0
  629. package/dist/ionic/p-1ea88de9.system.js +4 -0
  630. package/dist/ionic/p-1ed99eba.system.entry.js +4 -0
  631. package/dist/ionic/{p-de55ec45.js → p-1fa738c4.js} +1 -1
  632. package/dist/ionic/{p-c7c8429a.system.js → p-20d469d0.system.js} +1 -1
  633. package/dist/ionic/p-22d2a891.js +4 -0
  634. package/dist/ionic/p-239262e4.system.entry.js +4 -0
  635. package/dist/ionic/p-25850474.entry.js +4 -0
  636. package/dist/ionic/{p-ceceac26.js → p-27594fc2.js} +1 -1
  637. package/dist/ionic/{p-288649db.system.entry.js → p-2b3e0d99.system.entry.js} +1 -1
  638. package/dist/ionic/p-300b2cf1.entry.js +4 -0
  639. package/dist/ionic/{p-6525a8cd.system.js → p-30892e0c.system.js} +1 -1
  640. package/dist/ionic/p-32bd7ed7.entry.js +4 -0
  641. package/dist/ionic/{p-2c86025e.system.js → p-3410a9cb.system.js} +1 -1
  642. package/dist/ionic/{p-717e2526.system.entry.js → p-3bac30bf.system.entry.js} +2 -2
  643. package/dist/ionic/{p-31b2326e.system.js → p-3e1e14d9.system.js} +1 -1
  644. package/dist/ionic/p-41970e75.entry.js +4 -0
  645. package/dist/ionic/p-43322b14.js +4 -0
  646. package/dist/ionic/p-4523be60.entry.js +4 -0
  647. package/dist/ionic/p-454b36f7.system.entry.js +4 -0
  648. package/dist/ionic/p-466bdeae.entry.js +4 -0
  649. package/dist/ionic/p-4825e380.entry.js +4 -0
  650. package/dist/ionic/{p-62b7320a.system.js → p-4a8f173c.system.js} +1 -1
  651. package/dist/ionic/p-4ad02639.entry.js +4 -0
  652. package/dist/ionic/p-4c2cac66.entry.js +4 -0
  653. package/dist/ionic/{p-6e23d039.entry.js → p-5a055df4.entry.js} +1 -1
  654. package/dist/ionic/{p-5d7e32ce.js → p-5aa60929.js} +1 -1
  655. package/dist/ionic/p-5afb6e48.entry.js +4 -0
  656. package/dist/ionic/p-5c3991e3.system.entry.js +4 -0
  657. package/dist/ionic/p-602494c6.entry.js +4 -0
  658. package/dist/ionic/{p-ed7a529f.js → p-60efe117.js} +1 -1
  659. package/dist/ionic/p-62f15daf.system.entry.js +4 -0
  660. package/dist/ionic/{p-05253db9.js → p-65d3f0e9.js} +1 -1
  661. package/dist/ionic/p-6657681b.system.entry.js +4 -0
  662. package/dist/ionic/p-6d95943d.system.js +4 -0
  663. package/dist/ionic/p-6e1fa025.js +4 -0
  664. package/dist/ionic/{p-84b85535.entry.js → p-6e5eeb35.entry.js} +1 -1
  665. package/dist/ionic/p-6ef5f4da.entry.js +4 -0
  666. package/dist/ionic/{p-e1c52dc6.entry.js → p-6f6d56f1.entry.js} +1 -1
  667. package/dist/ionic/{p-a6c0a380.js → p-6fd26009.js} +1 -1
  668. package/dist/ionic/p-70218e28.system.entry.js +4 -0
  669. package/dist/ionic/p-72bc2484.system.entry.js +4 -0
  670. package/dist/ionic/p-7541ca9f.system.entry.js +4 -0
  671. package/dist/ionic/{p-56ee6d9a.js → p-760dbd5e.js} +1 -1
  672. package/dist/ionic/p-7665bbbc.system.entry.js +4 -0
  673. package/dist/ionic/{p-822730c4.entry.js → p-77982637.entry.js} +1 -1
  674. package/dist/ionic/{p-644d03d7.system.entry.js → p-780ff3b5.system.entry.js} +1 -1
  675. package/dist/ionic/p-7a3fa32c.entry.js +4 -0
  676. package/dist/ionic/{p-88e9052d.entry.js → p-7b44b443.entry.js} +1 -1
  677. package/dist/ionic/p-7b795aee.system.entry.js +4 -0
  678. package/dist/ionic/p-7cc01684.js +4 -0
  679. package/dist/ionic/{p-97ca0cb9.system.js → p-816476b0.system.js} +1 -1
  680. package/dist/ionic/p-81869a97.system.entry.js +4 -0
  681. package/dist/ionic/p-82d459c1.js +4 -0
  682. package/dist/ionic/{p-a85d9047.system.entry.js → p-82f5375e.system.entry.js} +1 -1
  683. package/dist/ionic/p-842777af.js +4 -0
  684. package/dist/ionic/p-85464e28.system.entry.js +4 -0
  685. package/dist/ionic/{p-d425b1de.entry.js → p-85cb4733.entry.js} +1 -1
  686. package/dist/ionic/{p-4b8a620f.system.entry.js → p-874510e9.system.entry.js} +1 -1
  687. package/dist/ionic/{p-bd313b73.system.js → p-8a50f8d6.system.js} +1 -1
  688. package/dist/ionic/{p-1b3ffb2f.js → p-8ab308e9.js} +1 -1
  689. package/dist/ionic/{p-baf8eeac.system.entry.js → p-8aeed464.system.entry.js} +1 -1
  690. package/dist/ionic/p-8ba5912c.entry.js +4 -0
  691. package/dist/ionic/{p-2c118b1e.js → p-8d4d902b.js} +1 -1
  692. package/dist/ionic/p-8d50220b.system.js +4 -0
  693. package/dist/ionic/{p-72fa96bf.system.js → p-8d602214.system.js} +1 -1
  694. package/dist/ionic/p-8e3ee444.system.entry.js +4 -0
  695. package/dist/ionic/{p-ce1c0a0e.system.entry.js → p-8e83b7f1.system.entry.js} +2 -2
  696. package/dist/ionic/{p-f5d2dc9b.js → p-8ededb41.js} +1 -1
  697. package/dist/ionic/p-91a72ad6.system.entry.js +4 -0
  698. package/dist/ionic/p-9382ebab.entry.js +4 -0
  699. package/dist/ionic/p-942c19cb.entry.js +4 -0
  700. package/dist/ionic/p-95e14c7b.system.js +4 -0
  701. package/dist/ionic/p-96391c0e.entry.js +4 -0
  702. package/dist/ionic/{p-2c4bfe1c.entry.js → p-97135baa.entry.js} +1 -1
  703. package/dist/ionic/{p-bb3615f7.js → p-9b97df10.js} +1 -1
  704. package/dist/ionic/{p-a1036ce7.js → p-9d6f351e.js} +1 -1
  705. package/dist/ionic/{p-5fc8d5ef.system.js → p-9e3b3f15.system.js} +1 -1
  706. package/dist/ionic/{p-f02c41af.system.js → p-a06af32c.system.js} +1 -1
  707. package/dist/ionic/p-a375c9f6.system.entry.js +4 -0
  708. package/dist/ionic/p-a58ec401.js +4 -0
  709. package/dist/ionic/p-a5b7a286.entry.js +4 -0
  710. package/dist/ionic/{p-942a9358.js → p-a6cc38d4.js} +1 -1
  711. package/dist/ionic/{p-125f8cdd.system.js → p-a71dc777.system.js} +1 -1
  712. package/dist/ionic/{p-cbcffe6e.system.js → p-a8cc0027.system.js} +1 -1
  713. package/dist/ionic/{p-18918a24.system.entry.js → p-aaca8dd4.system.entry.js} +1 -1
  714. package/dist/ionic/p-ad2b216a.system.entry.js +4 -0
  715. package/dist/ionic/p-add93c7a.entry.js +4 -0
  716. package/dist/ionic/{p-3079950e.entry.js → p-afcd4f49.entry.js} +1 -1
  717. package/dist/ionic/p-b1a9e85a.system.entry.js +4 -0
  718. package/dist/ionic/p-b4bb9cd0.system.entry.js +4 -0
  719. package/dist/ionic/p-baa409f1.system.entry.js +4 -0
  720. package/dist/ionic/p-bcb58446.entry.js +4 -0
  721. package/dist/ionic/p-c2336a9e.system.entry.js +4 -0
  722. package/dist/ionic/{p-bcd9cad8.system.js → p-c38c5dfc.system.js} +1 -1
  723. package/dist/ionic/{p-337ac0f5.entry.js → p-c3a2e5cc.entry.js} +1 -1
  724. package/dist/ionic/{p-a3df16b9.system.entry.js → p-c5b77291.system.entry.js} +1 -1
  725. package/dist/ionic/{p-12a8643e.js → p-c880c809.js} +1 -1
  726. package/dist/ionic/{p-91f4e611.system.entry.js → p-cb0e4100.system.entry.js} +2 -2
  727. package/dist/ionic/{p-fe320051.system.js → p-cb944b1a.system.js} +1 -1
  728. package/dist/ionic/p-cbc3840e.entry.js +4 -0
  729. package/dist/ionic/p-cd366840.system.entry.js +4 -0
  730. package/dist/ionic/p-cf852615.system.entry.js +4 -0
  731. package/dist/ionic/{p-9998cb62.system.entry.js → p-d4d0538c.system.entry.js} +1 -1
  732. package/dist/ionic/{p-1a680496.entry.js → p-d504bc71.entry.js} +1 -1
  733. package/dist/ionic/{p-86813176.system.entry.js → p-da83d833.system.entry.js} +1 -1
  734. package/dist/ionic/p-dcfc297d.system.entry.js +4 -0
  735. package/dist/ionic/p-ddc4e717.entry.js +4 -0
  736. package/dist/ionic/p-ded27993.entry.js +4 -0
  737. package/dist/ionic/p-e15eda82.system.js +4 -0
  738. package/dist/ionic/{p-b727af6a.entry.js → p-e38b3c29.entry.js} +1 -1
  739. package/dist/ionic/p-e470466e.entry.js +4 -0
  740. package/dist/ionic/p-e64277c4.entry.js +4 -0
  741. package/dist/ionic/{p-abcedc15.system.entry.js → p-ebe0be94.system.entry.js} +1 -1
  742. package/dist/ionic/{p-89ca4c4b.system.js → p-eec92f77.system.js} +1 -1
  743. package/dist/ionic/{p-cb9812f7.entry.js → p-ef99a759.entry.js} +1 -1
  744. package/dist/ionic/{p-7670acd8.entry.js → p-f16bfd53.entry.js} +1 -1
  745. package/dist/ionic/{p-b6279412.entry.js → p-f3d6085c.entry.js} +1 -1
  746. package/dist/ionic/p-f6a6b7ef.system.entry.js +4 -0
  747. package/dist/ionic/p-f71082f7.entry.js +4 -0
  748. package/dist/ionic/p-f7ed6a44.system.entry.js +4 -0
  749. package/dist/ionic/p-fc5ddbf6.entry.js +4 -0
  750. package/dist/ionic/p-fd94dd20.system.entry.js +4 -0
  751. package/dist/ionic/p-feb66f6f.entry.js +4 -0
  752. package/dist/types/components/action-sheet/action-sheet-interface.d.ts +8 -0
  753. package/dist/types/components/backdrop/backdrop.d.ts +0 -3
  754. package/dist/types/components/checkbox/checkbox.d.ts +1 -24
  755. package/dist/types/components/datetime/datetime.d.ts +0 -1
  756. package/dist/types/components/datetime/utils/data.d.ts +11 -7
  757. package/dist/types/components/input/input.d.ts +0 -26
  758. package/dist/types/components/menu/menu.d.ts +12 -4
  759. package/dist/types/components/modal/utils.d.ts +0 -4
  760. package/dist/types/components/nav/nav.d.ts +4 -1
  761. package/dist/types/components/picker/picker-interfaces.d.ts +8 -0
  762. package/dist/types/components/picker/picker.d.ts +75 -133
  763. package/dist/types/components/picker-column/picker-column-interfaces.d.ts +4 -0
  764. package/dist/types/components/picker-column/picker-column.d.ts +99 -39
  765. package/dist/types/components/picker-column-option/picker-column-option.d.ts +66 -0
  766. package/dist/types/components/picker-legacy/picker.d.ts +158 -0
  767. package/dist/types/components/picker-legacy-column/picker-column.d.ts +46 -0
  768. package/dist/types/components/radio/radio.d.ts +1 -24
  769. package/dist/types/components/range/range.d.ts +1 -21
  770. package/dist/types/components/select/select.d.ts +0 -15
  771. package/dist/types/components/split-pane/split-pane.d.ts +14 -2
  772. package/dist/types/components/textarea/textarea.d.ts +0 -17
  773. package/dist/types/components/toast/toast-interface.d.ts +0 -4
  774. package/dist/types/components/toggle/toggle.d.ts +1 -21
  775. package/dist/types/components.d.ts +160 -195
  776. package/dist/types/interface.d.ts +1 -1
  777. package/dist/types/utils/config.d.ts +2 -2
  778. package/dist/types/utils/focus-trap.d.ts +35 -0
  779. package/dist/types/utils/gesture/gesture-controller.d.ts +1 -0
  780. package/dist/types/utils/native/status-bar.d.ts +0 -1
  781. package/dist/types/utils/overlays.d.ts +5 -8
  782. package/dist/types/utils/test/playwright/generator.d.ts +3 -1
  783. package/hydrate/index.js +2044 -2393
  784. package/package.json +1 -2
  785. package/components/form-controller.js +0 -64
  786. package/components/ion-picker-column-internal.d.ts +0 -11
  787. package/components/ion-picker-column-internal.js +0 -9
  788. package/components/ion-picker-internal.js +0 -9
  789. package/components/picker-column-internal.js +0 -392
  790. package/dist/cjs/form-controller-c83330c0.js +0 -66
  791. package/dist/collection/components/checkbox/test/legacy/basic/checkbox.e2e.js +0 -68
  792. package/dist/collection/components/checkbox/test/legacy/indeterminate/checkbox.e2e.js +0 -14
  793. package/dist/collection/components/input/test/item/input.spec.js +0 -24
  794. package/dist/collection/components/input/test/legacy/a11y/input.e2e.js +0 -28
  795. package/dist/collection/components/input/test/legacy/basic/input.e2e.js +0 -181
  796. package/dist/collection/components/input/test/legacy/clear-on-edit/input.e2e.js +0 -55
  797. package/dist/collection/components/input/test/legacy/input-events.e2e.js +0 -71
  798. package/dist/collection/components/input/test/legacy/masking/input.e2e.js +0 -26
  799. package/dist/collection/components/input/test/legacy/spec/input.e2e.js +0 -16
  800. package/dist/collection/components/item/test/counter/item.e2e.js +0 -49
  801. package/dist/collection/components/item/test/highlight/item.e2e.js +0 -14
  802. package/dist/collection/components/item/test/legacy/alignment/item.e2e.js +0 -14
  803. package/dist/collection/components/item/test/legacy/fill/item.e2e.js +0 -14
  804. package/dist/collection/components/item/test/legacy/form/item.e2e.js +0 -14
  805. package/dist/collection/components/modal/test/a11y/modal.spec.js +0 -22
  806. package/dist/collection/components/picker-column-internal/picker-column-internal.js +0 -566
  807. package/dist/collection/components/picker-column-internal/test/disabled/picker-column-internal.e2e.js +0 -162
  808. package/dist/collection/components/picker-internal/picker-internal.js +0 -560
  809. package/dist/collection/components/picker-internal/test/basic/picker-internal.e2e.js +0 -118
  810. package/dist/collection/components/radio/test/legacy/a11y/radio.e2e.js +0 -53
  811. package/dist/collection/components/radio/test/legacy/basic/radio.e2e.js +0 -127
  812. package/dist/collection/components/radio-group/test/legacy/basic/radio-group.e2e.js +0 -122
  813. package/dist/collection/components/radio-group/test/legacy/form/radio-group.e2e.js +0 -30
  814. package/dist/collection/components/radio-group/test/legacy/search/radio-group.e2e.js +0 -38
  815. package/dist/collection/components/range/test/legacy/a11y/range.e2e.js +0 -49
  816. package/dist/collection/components/range/test/legacy/active-bar-start/range.e2e.js +0 -14
  817. package/dist/collection/components/range/test/legacy/basic/range.e2e.js +0 -75
  818. package/dist/collection/components/range/test/legacy/range-events.e2e.js +0 -90
  819. package/dist/collection/components/range/test/legacy/scroll-target/range.e2e.js +0 -32
  820. package/dist/collection/components/select/test/legacy/async/select.e2e.js +0 -19
  821. package/dist/collection/components/select/test/legacy/basic/select.e2e.js +0 -145
  822. package/dist/collection/components/select/test/legacy/compare-with/select.e2e.js +0 -67
  823. package/dist/collection/components/select/test/legacy/custom/custom.e2e.js +0 -13
  824. package/dist/collection/components/select/test/legacy/single-value/select.e2e.js +0 -16
  825. package/dist/collection/components/select/test/legacy/spec/select.e2e.js +0 -14
  826. package/dist/collection/components/select/test/legacy/standalone/select.e2e.js +0 -18
  827. package/dist/collection/components/select/test/legacy/wrapping/select.e2e.js +0 -39
  828. package/dist/collection/components/textarea/test/legacy/a11y/textarea.e2e.js +0 -31
  829. package/dist/collection/components/textarea/test/legacy/autogrow/textarea.e2e.js +0 -58
  830. package/dist/collection/components/textarea/test/legacy/basic/textarea.e2e.js +0 -43
  831. package/dist/collection/components/textarea/test/legacy/clear-on-edit/textarea.e2e.js +0 -25
  832. package/dist/collection/components/toggle/test/legacy/basic/toggle.e2e.js +0 -83
  833. package/dist/collection/components/toggle/test/legacy/enable-on-off-labels/toggle.e2e.js +0 -37
  834. package/dist/collection/components/toggle/test/legacy/sizes/power-outline.svg +0 -1
  835. package/dist/collection/components/toggle/test/legacy/sizes/toggle.e2e.js +0 -14
  836. package/dist/esm/form-controller-21dd62b1.js +0 -64
  837. package/dist/esm-es5/app-globals-5cf6195b.js +0 -4
  838. package/dist/esm-es5/button-active-47ac8092.js +0 -4
  839. package/dist/esm-es5/form-controller-21dd62b1.js +0 -4
  840. package/dist/esm-es5/ion-picker-column-internal.entry.js +0 -4
  841. package/dist/esm-es5/ion-picker-internal.entry.js +0 -4
  842. package/dist/esm-es5/md.transition-b8224313.js +0 -4
  843. package/dist/esm-es5/overlays-19b26885.js +0 -4
  844. package/dist/ionic/p-021f9d72.entry.js +0 -4
  845. package/dist/ionic/p-02542247.system.entry.js +0 -4
  846. package/dist/ionic/p-02ad4bbe.js +0 -4
  847. package/dist/ionic/p-079da3df.entry.js +0 -4
  848. package/dist/ionic/p-0b34d3a7.system.js +0 -4
  849. package/dist/ionic/p-12527c4b.entry.js +0 -4
  850. package/dist/ionic/p-15a40a0b.system.entry.js +0 -4
  851. package/dist/ionic/p-1636923f.system.js +0 -4
  852. package/dist/ionic/p-16a61810.entry.js +0 -4
  853. package/dist/ionic/p-1846513c.js +0 -4
  854. package/dist/ionic/p-1f16d040.entry.js +0 -4
  855. package/dist/ionic/p-1f19958f.system.entry.js +0 -4
  856. package/dist/ionic/p-2178329b.entry.js +0 -4
  857. package/dist/ionic/p-257046d2.system.js +0 -4
  858. package/dist/ionic/p-262024fd.entry.js +0 -4
  859. package/dist/ionic/p-2765a571.system.entry.js +0 -4
  860. package/dist/ionic/p-2ea71956.system.entry.js +0 -4
  861. package/dist/ionic/p-2fd3c3dd.entry.js +0 -4
  862. package/dist/ionic/p-36be3332.js +0 -4
  863. package/dist/ionic/p-437f4d02.system.entry.js +0 -4
  864. package/dist/ionic/p-46bcc2f5.js +0 -4
  865. package/dist/ionic/p-4788693d.entry.js +0 -4
  866. package/dist/ionic/p-479f5926.system.entry.js +0 -4
  867. package/dist/ionic/p-482ea916.system.entry.js +0 -4
  868. package/dist/ionic/p-49f481cc.system.entry.js +0 -4
  869. package/dist/ionic/p-521b3971.entry.js +0 -4
  870. package/dist/ionic/p-5cb5f63d.system.entry.js +0 -4
  871. package/dist/ionic/p-5de920f4.system.entry.js +0 -4
  872. package/dist/ionic/p-6812d37d.js +0 -4
  873. package/dist/ionic/p-6b6ca3f5.system.entry.js +0 -4
  874. package/dist/ionic/p-6c45c617.js +0 -4
  875. package/dist/ionic/p-6f59cdbc.system.entry.js +0 -4
  876. package/dist/ionic/p-70fbf4e2.entry.js +0 -4
  877. package/dist/ionic/p-741a0f0d.system.entry.js +0 -4
  878. package/dist/ionic/p-76b8bcb8.system.entry.js +0 -4
  879. package/dist/ionic/p-7a615a5a.entry.js +0 -4
  880. package/dist/ionic/p-7e16220b.entry.js +0 -4
  881. package/dist/ionic/p-7e838f43.system.entry.js +0 -4
  882. package/dist/ionic/p-7f30ad48.entry.js +0 -4
  883. package/dist/ionic/p-80aed9fb.system.entry.js +0 -4
  884. package/dist/ionic/p-85f66c3c.entry.js +0 -4
  885. package/dist/ionic/p-860e2539.system.entry.js +0 -4
  886. package/dist/ionic/p-8cc34120.entry.js +0 -4
  887. package/dist/ionic/p-8e651c29.entry.js +0 -4
  888. package/dist/ionic/p-9056778e.system.entry.js +0 -4
  889. package/dist/ionic/p-96084f36.entry.js +0 -4
  890. package/dist/ionic/p-973b4db3.entry.js +0 -4
  891. package/dist/ionic/p-98aa0553.entry.js +0 -4
  892. package/dist/ionic/p-9de75bac.system.entry.js +0 -4
  893. package/dist/ionic/p-a02ea777.entry.js +0 -4
  894. package/dist/ionic/p-a1222c24.entry.js +0 -4
  895. package/dist/ionic/p-a4aa6dd2.system.entry.js +0 -4
  896. package/dist/ionic/p-a667dd1f.system.js +0 -4
  897. package/dist/ionic/p-a8459bfb.entry.js +0 -4
  898. package/dist/ionic/p-ae2b3a7a.system.entry.js +0 -4
  899. package/dist/ionic/p-ae828bd9.system.entry.js +0 -4
  900. package/dist/ionic/p-b0aa3806.system.entry.js +0 -4
  901. package/dist/ionic/p-b27bba38.system.entry.js +0 -4
  902. package/dist/ionic/p-b4d2f43c.system.js +0 -4
  903. package/dist/ionic/p-b58686e0.entry.js +0 -4
  904. package/dist/ionic/p-ba0fbecc.entry.js +0 -4
  905. package/dist/ionic/p-bdca4784.js +0 -4
  906. package/dist/ionic/p-c1a871ff.system.entry.js +0 -4
  907. package/dist/ionic/p-c1c7309e.entry.js +0 -4
  908. package/dist/ionic/p-c7288e78.system.entry.js +0 -4
  909. package/dist/ionic/p-cb3065b8.entry.js +0 -4
  910. package/dist/ionic/p-cfb4d7e0.js +0 -4
  911. package/dist/ionic/p-d143fefa.system.entry.js +0 -4
  912. package/dist/ionic/p-d6c6541b.system.entry.js +0 -4
  913. package/dist/ionic/p-df504a37.system.js +0 -4
  914. package/dist/ionic/p-dff97cfa.entry.js +0 -4
  915. package/dist/ionic/p-e4e74b5f.system.entry.js +0 -4
  916. package/dist/ionic/p-e626800f.system.entry.js +0 -4
  917. package/dist/ionic/p-e94c1402.entry.js +0 -4
  918. package/dist/ionic/p-ebc1ca90.system.js +0 -4
  919. package/dist/ionic/p-ed4760ef.entry.js +0 -4
  920. package/dist/ionic/p-f0e54781.system.entry.js +0 -4
  921. package/dist/ionic/p-fa8d3b01.entry.js +0 -4
  922. package/dist/ionic/p-fbd01db3.system.js +0 -4
  923. package/dist/types/components/picker-column-internal/picker-column-internal-interfaces.d.ts +0 -5
  924. package/dist/types/components/picker-column-internal/picker-column-internal.d.ts +0 -102
  925. package/dist/types/components/picker-internal/picker-internal-interfaces.d.ts +0 -8
  926. package/dist/types/components/picker-internal/picker-internal.d.ts +0 -102
  927. /package/dist/collection/components/{picker-internal/picker-internal-interfaces.js → picker/picker-interfaces.js} +0 -0
  928. /package/dist/collection/components/{picker-column-internal/picker-column-internal-interfaces.js → picker-column/picker-column-interfaces.js} +0 -0
  929. /package/dist/collection/components/{picker → picker-legacy}/animations/ios.enter.js +0 -0
  930. /package/dist/collection/components/{picker → picker-legacy}/animations/ios.leave.js +0 -0
  931. /package/dist/collection/components/{picker → picker-legacy}/picker-interface.js +0 -0
  932. /package/dist/collection/components/{picker-column → picker-legacy-column}/test/test.utils.js +0 -0
  933. /package/dist/esm-es5/{data-0f3ab200.js → data-691286f1.js} +0 -0
  934. /package/dist/ionic/{p-f7dce541.js → p-5289aade.js} +0 -0
  935. /package/dist/ionic/{p-7330c044.system.js → p-66e6860f.system.js} +0 -0
  936. /package/dist/types/components/{picker → picker-legacy}/animations/ios.enter.d.ts +0 -0
  937. /package/dist/types/components/{picker → picker-legacy}/animations/ios.leave.d.ts +0 -0
  938. /package/dist/types/components/{picker → picker-legacy}/picker-interface.d.ts +0 -0
  939. /package/dist/types/components/{picker-column → picker-legacy-column}/test/test.utils.d.ts +0 -0
@@ -2,196 +2,497 @@
2
2
  * (C) Ionic http://ionicframework.com - MIT License
3
3
  */
4
4
  import { Host, h } from "@stencil/core";
5
- import { raf } from "../../utils/helpers";
6
- import { createLockController } from "../../utils/lock-controller";
7
- import { createDelegateController, createTriggerController, BACKDROP, dismiss, eventMethod, isCancel, prepareOverlay, present, safeCall, setOverlayId, } from "../../utils/overlays";
8
- import { getClassMap } from "../../utils/theme";
9
- import { getIonMode } from "../../global/ionic-global";
10
- import { iosEnterAnimation } from "./animations/ios.enter";
11
- import { iosLeaveAnimation } from "./animations/ios.leave";
12
- // TODO(FW-2832): types
5
+ import { getElementRoot } from "../../utils/helpers";
13
6
  /**
14
7
  * @virtualProp {"ios" | "md"} mode - The mode determines which platform styles to use.
15
8
  */
16
9
  export class Picker {
17
10
  constructor() {
18
- this.delegateController = createDelegateController(this);
19
- this.lockController = createLockController();
20
- this.triggerController = createTriggerController();
21
- this.onBackdropTap = () => {
22
- this.dismiss(undefined, BACKDROP);
11
+ this.useInputMode = false;
12
+ this.isInHighlightBounds = (ev) => {
13
+ const { highlightEl } = this;
14
+ if (!highlightEl) {
15
+ return false;
16
+ }
17
+ const bbox = highlightEl.getBoundingClientRect();
18
+ /**
19
+ * Check to see if the user clicked
20
+ * outside the bounds of the highlight.
21
+ */
22
+ const outsideX = ev.clientX < bbox.left || ev.clientX > bbox.right;
23
+ const outsideY = ev.clientY < bbox.top || ev.clientY > bbox.bottom;
24
+ if (outsideX || outsideY) {
25
+ return false;
26
+ }
27
+ return true;
23
28
  };
24
- this.dispatchCancelHandler = (ev) => {
25
- const role = ev.detail.role;
26
- if (isCancel(role)) {
27
- const cancelButton = this.buttons.find((b) => b.role === 'cancel');
28
- this.callButtonHandler(cancelButton);
29
+ /**
30
+ * If we are no longer focused
31
+ * on a picker column, then we should
32
+ * exit input mode. An exception is made
33
+ * for the input in the picker since having
34
+ * that focused means we are still in input mode.
35
+ */
36
+ this.onFocusOut = (ev) => {
37
+ // TODO(FW-2832): type
38
+ const { relatedTarget } = ev;
39
+ if (!relatedTarget || (relatedTarget.tagName !== 'ION-PICKER-COLUMN' && relatedTarget !== this.inputEl)) {
40
+ this.exitInputMode();
29
41
  }
30
42
  };
31
- this.presented = false;
32
- this.overlayIndex = undefined;
33
- this.delegate = undefined;
34
- this.hasController = false;
35
- this.keyboardClose = true;
36
- this.enterAnimation = undefined;
37
- this.leaveAnimation = undefined;
38
- this.buttons = [];
39
- this.columns = [];
40
- this.cssClass = undefined;
41
- this.duration = 0;
42
- this.showBackdrop = true;
43
- this.backdropDismiss = true;
44
- this.animated = true;
45
- this.htmlAttributes = undefined;
46
- this.isOpen = false;
47
- this.trigger = undefined;
48
- }
49
- onIsOpenChange(newValue, oldValue) {
50
- if (newValue === true && oldValue === false) {
51
- this.present();
52
- }
53
- else if (newValue === false && oldValue === true) {
54
- this.dismiss();
55
- }
56
- }
57
- triggerChanged() {
58
- const { trigger, el, triggerController } = this;
59
- if (trigger) {
60
- triggerController.addClickListener(el, trigger);
61
- }
62
- }
63
- connectedCallback() {
64
- prepareOverlay(this.el);
65
- this.triggerChanged();
66
- }
67
- disconnectedCallback() {
68
- this.triggerController.removeClickListener();
69
- }
70
- componentWillLoad() {
71
- setOverlayId(this.el);
72
- }
73
- componentDidLoad() {
74
43
  /**
75
- * If picker was rendered with isOpen="true"
76
- * then we should open picker immediately.
44
+ * When picker columns receive focus
45
+ * the parent picker needs to determine
46
+ * whether to enter/exit input mode.
77
47
  */
78
- if (this.isOpen === true) {
79
- raf(() => this.present());
80
- }
48
+ this.onFocusIn = (ev) => {
49
+ // TODO(FW-2832): type
50
+ const { target } = ev;
51
+ /**
52
+ * Due to browser differences in how/when focus
53
+ * is dispatched on certain elements, we need to
54
+ * make sure that this function only ever runs when
55
+ * focusing a picker column.
56
+ */
57
+ if (target.tagName !== 'ION-PICKER-COLUMN') {
58
+ return;
59
+ }
60
+ /**
61
+ * If we have actionOnClick
62
+ * then this means the user focused
63
+ * a picker column via mouse or
64
+ * touch (i.e. a PointerEvent). As a result,
65
+ * we should not enter/exit input mode
66
+ * until the click event has fired, which happens
67
+ * after the `focusin` event.
68
+ *
69
+ * Otherwise, the user likely focused
70
+ * the column using their keyboard and
71
+ * we should enter/exit input mode automatically.
72
+ */
73
+ if (!this.actionOnClick) {
74
+ const columnEl = target;
75
+ const allowInput = columnEl.numericInput;
76
+ if (allowInput) {
77
+ this.enterInputMode(columnEl, false);
78
+ }
79
+ else {
80
+ this.exitInputMode();
81
+ }
82
+ }
83
+ };
81
84
  /**
82
- * When binding values in frameworks such as Angular
83
- * it is possible for the value to be set after the Web Component
84
- * initializes but before the value watcher is set up in Stencil.
85
- * As a result, the watcher callback may not be fired.
86
- * We work around this by manually calling the watcher
87
- * callback when the component has loaded and the watcher
88
- * is configured.
85
+ * On click we need to run an actionOnClick
86
+ * function that has been set in onPointerDown
87
+ * so that we enter/exit input mode correctly.
89
88
  */
90
- this.triggerChanged();
91
- }
92
- /**
93
- * Present the picker overlay after it has been created.
94
- */
95
- async present() {
96
- const unlock = await this.lockController.lock();
97
- await this.delegateController.attachViewToDom();
98
- await present(this, 'pickerEnter', iosEnterAnimation, iosEnterAnimation, undefined);
99
- if (this.duration > 0) {
100
- this.durationTimeout = setTimeout(() => this.dismiss(), this.duration);
101
- }
102
- unlock();
103
- }
104
- /**
105
- * Dismiss the picker overlay after it has been presented.
106
- *
107
- * @param data Any data to emit in the dismiss events.
108
- * @param role The role of the element that is dismissing the picker.
109
- * This can be useful in a button handler for determining which button was
110
- * clicked to dismiss the picker.
111
- * Some examples include: ``"cancel"`, `"destructive"`, "selected"`, and `"backdrop"`.
112
- *
113
- * This is a no-op if the overlay has not been presented yet. If you want
114
- * to remove an overlay from the DOM that was never presented, use the
115
- * [remove](https://developer.mozilla.org/en-US/docs/Web/API/Element/remove) method.
116
- */
117
- async dismiss(data, role) {
118
- const unlock = await this.lockController.lock();
119
- if (this.durationTimeout) {
120
- clearTimeout(this.durationTimeout);
121
- }
122
- const dismissed = await dismiss(this, data, role, 'pickerLeave', iosLeaveAnimation, iosLeaveAnimation);
123
- if (dismissed) {
124
- this.delegateController.removeViewFromDom();
125
- }
126
- unlock();
127
- return dismissed;
89
+ this.onClick = () => {
90
+ const { actionOnClick } = this;
91
+ if (actionOnClick) {
92
+ actionOnClick();
93
+ this.actionOnClick = undefined;
94
+ }
95
+ };
96
+ /**
97
+ * Clicking a column also focuses the column on
98
+ * certain browsers, so we use onPointerDown
99
+ * to tell the onFocusIn function that users
100
+ * are trying to click the column rather than
101
+ * focus the column using the keyboard. When the
102
+ * user completes the click, the onClick function
103
+ * runs and runs the actionOnClick callback.
104
+ */
105
+ this.onPointerDown = (ev) => {
106
+ const { useInputMode, inputModeColumn, el } = this;
107
+ if (this.isInHighlightBounds(ev)) {
108
+ /**
109
+ * If we were already in
110
+ * input mode, then we should determine
111
+ * if we tapped a particular column and
112
+ * should switch to input mode for
113
+ * that specific column.
114
+ */
115
+ if (useInputMode) {
116
+ /**
117
+ * If we tapped a picker column
118
+ * then we should either switch to input
119
+ * mode for that column or all columns.
120
+ * Otherwise we should exit input mode
121
+ * since we just tapped the highlight and
122
+ * not a column.
123
+ */
124
+ if (ev.target.tagName === 'ION-PICKER-COLUMN') {
125
+ /**
126
+ * If user taps 2 different columns
127
+ * then we should just switch to input mode
128
+ * for the new column rather than switching to
129
+ * input mode for all columns.
130
+ */
131
+ if (inputModeColumn && inputModeColumn === ev.target) {
132
+ this.actionOnClick = () => {
133
+ this.enterInputMode();
134
+ };
135
+ }
136
+ else {
137
+ this.actionOnClick = () => {
138
+ this.enterInputMode(ev.target);
139
+ };
140
+ }
141
+ }
142
+ else {
143
+ this.actionOnClick = () => {
144
+ this.exitInputMode();
145
+ };
146
+ }
147
+ /**
148
+ * If we were not already in
149
+ * input mode, then we should
150
+ * enter input mode for all columns.
151
+ */
152
+ }
153
+ else {
154
+ /**
155
+ * If there is only 1 numeric input column
156
+ * then we should skip multi column input.
157
+ */
158
+ const columns = el.querySelectorAll('ion-picker-column.picker-column-numeric-input');
159
+ const columnEl = columns.length === 1 ? ev.target : undefined;
160
+ this.actionOnClick = () => {
161
+ this.enterInputMode(columnEl);
162
+ };
163
+ }
164
+ return;
165
+ }
166
+ this.actionOnClick = () => {
167
+ this.exitInputMode();
168
+ };
169
+ };
170
+ /**
171
+ * Enters input mode to allow
172
+ * for text entry of numeric values.
173
+ * If on mobile, we focus a hidden input
174
+ * field so that the on screen keyboard
175
+ * is brought up. When tabbing using a
176
+ * keyboard, picker columns receive an outline
177
+ * to indicate they are focused. As a result,
178
+ * we should not focus the hidden input as it
179
+ * would cause the outline to go away, preventing
180
+ * users from having any visual indication of which
181
+ * column is focused.
182
+ */
183
+ this.enterInputMode = (columnEl, focusInput = true) => {
184
+ const { inputEl, el } = this;
185
+ if (!inputEl) {
186
+ return;
187
+ }
188
+ /**
189
+ * Only active input mode if there is at
190
+ * least one column that accepts numeric input.
191
+ */
192
+ const hasInputColumn = el.querySelector('ion-picker-column.picker-column-numeric-input');
193
+ if (!hasInputColumn) {
194
+ return;
195
+ }
196
+ /**
197
+ * If columnEl is undefined then
198
+ * it is assumed that all numeric pickers
199
+ * are eligible for text entry.
200
+ * (i.e. hour and minute columns)
201
+ */
202
+ this.useInputMode = true;
203
+ this.inputModeColumn = columnEl;
204
+ /**
205
+ * Users with a keyboard and mouse can
206
+ * activate input mode where the input is
207
+ * focused as well as when it is not focused,
208
+ * so we need to make sure we clean up any
209
+ * old listeners.
210
+ */
211
+ if (focusInput) {
212
+ if (this.destroyKeypressListener) {
213
+ this.destroyKeypressListener();
214
+ this.destroyKeypressListener = undefined;
215
+ }
216
+ inputEl.focus();
217
+ }
218
+ else {
219
+ // TODO FW-5900 Use keydown instead
220
+ el.addEventListener('keypress', this.onKeyPress);
221
+ this.destroyKeypressListener = () => {
222
+ el.removeEventListener('keypress', this.onKeyPress);
223
+ };
224
+ }
225
+ this.emitInputModeChange();
226
+ };
227
+ this.onKeyPress = (ev) => {
228
+ const { inputEl } = this;
229
+ if (!inputEl) {
230
+ return;
231
+ }
232
+ const parsedValue = parseInt(ev.key, 10);
233
+ /**
234
+ * Only numbers should be allowed
235
+ */
236
+ if (!Number.isNaN(parsedValue)) {
237
+ inputEl.value += ev.key;
238
+ this.onInputChange();
239
+ }
240
+ };
241
+ this.selectSingleColumn = () => {
242
+ const { inputEl, inputModeColumn, singleColumnSearchTimeout } = this;
243
+ if (!inputEl || !inputModeColumn) {
244
+ return;
245
+ }
246
+ const options = Array.from(inputModeColumn.querySelectorAll('ion-picker-column-option')).filter((el) => el.disabled !== true);
247
+ /**
248
+ * If users pause for a bit, the search
249
+ * value should be reset similar to how a
250
+ * <select> behaves. So typing "34", waiting,
251
+ * then typing "5" should select "05".
252
+ */
253
+ if (singleColumnSearchTimeout) {
254
+ clearTimeout(singleColumnSearchTimeout);
255
+ }
256
+ this.singleColumnSearchTimeout = setTimeout(() => {
257
+ inputEl.value = '';
258
+ this.singleColumnSearchTimeout = undefined;
259
+ }, 1000);
260
+ /**
261
+ * For values that are longer than 2 digits long
262
+ * we should shift the value over 1 character
263
+ * to the left. So typing "456" would result in "56".
264
+ * TODO: If we want to support more than just
265
+ * time entry, we should update this value to be
266
+ * the max length of all of the picker items.
267
+ */
268
+ if (inputEl.value.length >= 3) {
269
+ const startIndex = inputEl.value.length - 2;
270
+ const newString = inputEl.value.substring(startIndex);
271
+ inputEl.value = newString;
272
+ this.selectSingleColumn();
273
+ return;
274
+ }
275
+ /**
276
+ * Checking the value of the input gets priority
277
+ * first. For example, if the value of the input
278
+ * is "1" and we entered "2", then the complete value
279
+ * is "12" and we should select hour 12.
280
+ *
281
+ * Regex removes any leading zeros from values like "02",
282
+ * but it keeps a single zero if there are only zeros in the string.
283
+ * 0+(?=[1-9]) --> Match 1 or more zeros that are followed by 1-9
284
+ * 0+(?=0$) --> Match 1 or more zeros that must be followed by one 0 and end.
285
+ */
286
+ const findItemFromCompleteValue = options.find(({ textContent }) => {
287
+ /**
288
+ * Keyboard entry is currently only used inside of Datetime
289
+ * where we guarantee textContent is set.
290
+ * If we end up exposing this feature publicly we should revisit this assumption.
291
+ */
292
+ const parsedText = textContent.replace(/^0+(?=[1-9])|0+(?=0$)/, '');
293
+ return parsedText === inputEl.value;
294
+ });
295
+ if (findItemFromCompleteValue) {
296
+ inputModeColumn.setValue(findItemFromCompleteValue.value);
297
+ return;
298
+ }
299
+ /**
300
+ * If we typed "56" to get minute 56, then typed "7",
301
+ * we should select "07" as "567" is not a valid minute.
302
+ */
303
+ if (inputEl.value.length === 2) {
304
+ const changedCharacter = inputEl.value.substring(inputEl.value.length - 1);
305
+ inputEl.value = changedCharacter;
306
+ this.selectSingleColumn();
307
+ }
308
+ };
309
+ /**
310
+ * Searches a list of column items for a particular
311
+ * value. This is currently used for numeric values.
312
+ * The zeroBehavior can be set to account for leading
313
+ * or trailing zeros when looking at the item text.
314
+ */
315
+ this.searchColumn = (colEl, value, zeroBehavior = 'start') => {
316
+ const behavior = zeroBehavior === 'start' ? /^0+/ : /0$/;
317
+ const option = Array.from(colEl.querySelectorAll('ion-picker-column-option')).find((el) => {
318
+ return el.disabled !== true && el.textContent.replace(behavior, '') === value;
319
+ });
320
+ if (option) {
321
+ colEl.setValue(option.value);
322
+ }
323
+ };
324
+ this.selectMultiColumn = () => {
325
+ const { inputEl, el } = this;
326
+ if (!inputEl) {
327
+ return;
328
+ }
329
+ const numericPickers = Array.from(el.querySelectorAll('ion-picker-column')).filter((col) => col.numericInput);
330
+ const firstColumn = numericPickers[0];
331
+ const lastColumn = numericPickers[1];
332
+ let value = inputEl.value;
333
+ let minuteValue;
334
+ switch (value.length) {
335
+ case 1:
336
+ this.searchColumn(firstColumn, value);
337
+ break;
338
+ case 2:
339
+ /**
340
+ * If the first character is `0` or `1` it is
341
+ * possible that users are trying to type `09`
342
+ * or `11` into the hour field, so we should look
343
+ * at that first.
344
+ */
345
+ const firstCharacter = inputEl.value.substring(0, 1);
346
+ value = firstCharacter === '0' || firstCharacter === '1' ? inputEl.value : firstCharacter;
347
+ this.searchColumn(firstColumn, value);
348
+ /**
349
+ * If only checked the first value,
350
+ * we can check the second value
351
+ * for a match in the minutes column
352
+ */
353
+ if (value.length === 1) {
354
+ minuteValue = inputEl.value.substring(inputEl.value.length - 1);
355
+ this.searchColumn(lastColumn, minuteValue, 'end');
356
+ }
357
+ break;
358
+ case 3:
359
+ /**
360
+ * If the first character is `0` or `1` it is
361
+ * possible that users are trying to type `09`
362
+ * or `11` into the hour field, so we should look
363
+ * at that first.
364
+ */
365
+ const firstCharacterAgain = inputEl.value.substring(0, 1);
366
+ value =
367
+ firstCharacterAgain === '0' || firstCharacterAgain === '1'
368
+ ? inputEl.value.substring(0, 2)
369
+ : firstCharacterAgain;
370
+ this.searchColumn(firstColumn, value);
371
+ /**
372
+ * If only checked the first value,
373
+ * we can check the second value
374
+ * for a match in the minutes column
375
+ */
376
+ minuteValue = value.length === 1 ? inputEl.value.substring(1) : inputEl.value.substring(2);
377
+ this.searchColumn(lastColumn, minuteValue, 'end');
378
+ break;
379
+ case 4:
380
+ /**
381
+ * If the first character is `0` or `1` it is
382
+ * possible that users are trying to type `09`
383
+ * or `11` into the hour field, so we should look
384
+ * at that first.
385
+ */
386
+ const firstCharacterAgainAgain = inputEl.value.substring(0, 1);
387
+ value =
388
+ firstCharacterAgainAgain === '0' || firstCharacterAgainAgain === '1'
389
+ ? inputEl.value.substring(0, 2)
390
+ : firstCharacterAgainAgain;
391
+ this.searchColumn(firstColumn, value);
392
+ /**
393
+ * If only checked the first value,
394
+ * we can check the second value
395
+ * for a match in the minutes column
396
+ */
397
+ const minuteValueAgain = value.length === 1
398
+ ? inputEl.value.substring(1, inputEl.value.length)
399
+ : inputEl.value.substring(2, inputEl.value.length);
400
+ this.searchColumn(lastColumn, minuteValueAgain, 'end');
401
+ break;
402
+ default:
403
+ const startIndex = inputEl.value.length - 4;
404
+ const newString = inputEl.value.substring(startIndex);
405
+ inputEl.value = newString;
406
+ this.selectMultiColumn();
407
+ break;
408
+ }
409
+ };
410
+ /**
411
+ * Searches the value of the active column
412
+ * to determine which value users are trying
413
+ * to select
414
+ */
415
+ this.onInputChange = () => {
416
+ const { useInputMode, inputEl, inputModeColumn } = this;
417
+ if (!useInputMode || !inputEl) {
418
+ return;
419
+ }
420
+ if (inputModeColumn) {
421
+ this.selectSingleColumn();
422
+ }
423
+ else {
424
+ this.selectMultiColumn();
425
+ }
426
+ };
427
+ /**
428
+ * Emit ionInputModeChange. Picker columns
429
+ * listen for this event to determine whether
430
+ * or not their column is "active" for text input.
431
+ */
432
+ this.emitInputModeChange = () => {
433
+ const { useInputMode, inputModeColumn } = this;
434
+ this.ionInputModeChange.emit({
435
+ useInputMode,
436
+ inputModeColumn,
437
+ });
438
+ };
128
439
  }
129
440
  /**
130
- * Returns a promise that resolves when the picker did dismiss.
441
+ * When the picker is interacted with
442
+ * we need to prevent touchstart so other
443
+ * gestures do not fire. For example,
444
+ * scrolling on the wheel picker
445
+ * in ion-datetime should not cause
446
+ * a card modal to swipe to close.
131
447
  */
132
- onDidDismiss() {
133
- return eventMethod(this.el, 'ionPickerDidDismiss');
448
+ preventTouchStartPropagation(ev) {
449
+ ev.stopPropagation();
134
450
  }
135
- /**
136
- * Returns a promise that resolves when the picker will dismiss.
137
- */
138
- onWillDismiss() {
139
- return eventMethod(this.el, 'ionPickerWillDismiss');
451
+ componentWillLoad() {
452
+ getElementRoot(this.el).addEventListener('focusin', this.onFocusIn);
453
+ getElementRoot(this.el).addEventListener('focusout', this.onFocusOut);
140
454
  }
141
455
  /**
142
- * Get the column that matches the specified name.
143
- *
144
- * @param name The name of the column.
456
+ * @internal
457
+ * Exits text entry mode for the picker
458
+ * This method blurs the hidden input
459
+ * and cause the keyboard to dismiss.
145
460
  */
146
- getColumn(name) {
147
- return Promise.resolve(this.columns.find((column) => column.name === name));
148
- }
149
- async buttonClick(button) {
150
- const role = button.role;
151
- if (isCancel(role)) {
152
- return this.dismiss(undefined, role);
461
+ async exitInputMode() {
462
+ const { inputEl, useInputMode } = this;
463
+ if (!useInputMode || !inputEl) {
464
+ return;
153
465
  }
154
- const shouldDismiss = await this.callButtonHandler(button);
155
- if (shouldDismiss) {
156
- return this.dismiss(this.getSelected(), button.role);
157
- }
158
- return Promise.resolve();
159
- }
160
- async callButtonHandler(button) {
161
- if (button) {
162
- // a handler has been provided, execute it
163
- // pass the handler the values from the inputs
164
- const rtn = await safeCall(button.handler, this.getSelected());
165
- if (rtn === false) {
166
- // if the return value of the handler is false then do not dismiss
167
- return false;
168
- }
466
+ this.useInputMode = false;
467
+ this.inputModeColumn = undefined;
468
+ inputEl.blur();
469
+ inputEl.value = '';
470
+ if (this.destroyKeypressListener) {
471
+ this.destroyKeypressListener();
472
+ this.destroyKeypressListener = undefined;
169
473
  }
170
- return true;
171
- }
172
- getSelected() {
173
- const selected = {};
174
- this.columns.forEach((col, index) => {
175
- const selectedColumn = col.selectedIndex !== undefined ? col.options[col.selectedIndex] : undefined;
176
- selected[col.name] = {
177
- text: selectedColumn ? selectedColumn.text : undefined,
178
- value: selectedColumn ? selectedColumn.value : undefined,
179
- columnIndex: index,
180
- };
181
- });
182
- return selected;
474
+ this.emitInputModeChange();
183
475
  }
184
476
  render() {
185
- const { htmlAttributes } = this;
186
- const mode = getIonMode(this);
187
- return (h(Host, Object.assign({ key: 'c266cc072afaba2da22f70d8b62dc4bc6756d188', "aria-modal": "true", tabindex: "-1" }, htmlAttributes, { style: {
188
- zIndex: `${20000 + this.overlayIndex}`,
189
- }, class: Object.assign({ [mode]: true,
190
- // Used internally for styling
191
- [`picker-${mode}`]: true, 'overlay-hidden': true }, getClassMap(this.cssClass)), onIonBackdropTap: this.onBackdropTap, onIonPickerWillDismiss: this.dispatchCancelHandler }), h("ion-backdrop", { key: '35ee3e5028028835580e28ac2c8db65a924d5d6a', visible: this.showBackdrop, tappable: this.backdropDismiss }), h("div", { key: '8b454e6edbcfc45c57d3d8baf7c14b7905921a6e', tabindex: "0" }), h("div", { key: 'e0fee78ec6d097bf0963190f748e5daad602e0f7', class: "picker-wrapper ion-overlay-wrapper", role: "dialog" }, h("div", { key: 'ce66bca18fc3e982ad7d6660f27cb1a03fb8247b', class: "picker-toolbar" }, this.buttons.map((b) => (h("div", { class: buttonWrapperClass(b) }, h("button", { type: "button", onClick: () => this.buttonClick(b), class: buttonClass(b) }, b.text))))), h("div", { key: 'a58b9523fe16f109dd6de0610717c5077fed964b', class: "picker-columns" }, h("div", { key: 'acd54c0314cff51e8513a08dd9755c4b847c0617', class: "picker-above-highlight" }), this.presented && this.columns.map((c) => h("ion-picker-column", { col: c })), h("div", { key: '604730bd87582d048d850c6e0a0f29ba33258918', class: "picker-below-highlight" }))), h("div", { key: '93baf5e6e57aec5f084d7d5b24af14e7d8126b5a', tabindex: "0" })));
477
+ return (h(Host, { key: '56b1421dee69c5aa7521b70199f047f4033c0a94', onPointerDown: (ev) => this.onPointerDown(ev), onClick: () => this.onClick() }, h("input", { key: '6956b6ee5debbad88e90d8b307833a4c112cabfb', "aria-hidden": "true", tabindex: -1, inputmode: "numeric", type: "number", onKeyDown: (ev) => {
478
+ var _a;
479
+ /**
480
+ * The "Enter" key represents
481
+ * the user submitting their time
482
+ * selection, so we should blur the
483
+ * input (and therefore close the keyboard)
484
+ *
485
+ * Updating the picker's state to no longer
486
+ * be in input mode is handled in the onBlur
487
+ * callback below.
488
+ */
489
+ if (ev.key === 'Enter') {
490
+ (_a = this.inputEl) === null || _a === void 0 ? void 0 : _a.blur();
491
+ }
492
+ }, ref: (el) => (this.inputEl = el), onInput: () => this.onInputChange(), onBlur: () => this.exitInputMode() }), h("div", { key: 'b6acaac9ed883ab1db90a09f7ef3c15feb8fa38b', class: "picker-before" }), h("div", { key: '76a49ca1b135f5fdd31a6230053af1f58d0d7dd1', class: "picker-after" }), h("div", { key: '1e265527d12ffd6dc005133ac7fcfc2a1e02c7c3', class: "picker-highlight", ref: (el) => (this.highlightEl = el) }), h("slot", { key: '828077cb8f6a8061d3509aca018d7b06d3e98130' })));
192
493
  }
193
494
  static get is() { return "ion-picker"; }
194
- static get encapsulation() { return "scoped"; }
495
+ static get encapsulation() { return "shadow"; }
195
496
  static get originalStyleUrls() {
196
497
  return {
197
498
  "ios": ["picker.ios.scss"],
@@ -204,465 +505,28 @@ export class Picker {
204
505
  "md": ["picker.md.css"]
205
506
  };
206
507
  }
207
- static get properties() {
208
- return {
209
- "overlayIndex": {
210
- "type": "number",
211
- "mutable": false,
212
- "complexType": {
213
- "original": "number",
214
- "resolved": "number",
215
- "references": {}
216
- },
217
- "required": true,
218
- "optional": false,
219
- "docs": {
220
- "tags": [{
221
- "name": "internal",
222
- "text": undefined
223
- }],
224
- "text": ""
225
- },
226
- "attribute": "overlay-index",
227
- "reflect": false
228
- },
229
- "delegate": {
230
- "type": "unknown",
231
- "mutable": false,
232
- "complexType": {
233
- "original": "FrameworkDelegate",
234
- "resolved": "FrameworkDelegate | undefined",
235
- "references": {
236
- "FrameworkDelegate": {
237
- "location": "import",
238
- "path": "../../interface",
239
- "id": "src/interface.d.ts::FrameworkDelegate"
240
- }
241
- }
242
- },
243
- "required": false,
244
- "optional": true,
245
- "docs": {
246
- "tags": [{
247
- "name": "internal",
248
- "text": undefined
249
- }],
250
- "text": ""
251
- }
252
- },
253
- "hasController": {
254
- "type": "boolean",
255
- "mutable": false,
256
- "complexType": {
257
- "original": "boolean",
258
- "resolved": "boolean",
259
- "references": {}
260
- },
261
- "required": false,
262
- "optional": false,
263
- "docs": {
264
- "tags": [{
265
- "name": "internal",
266
- "text": undefined
267
- }],
268
- "text": ""
269
- },
270
- "attribute": "has-controller",
271
- "reflect": false,
272
- "defaultValue": "false"
273
- },
274
- "keyboardClose": {
275
- "type": "boolean",
276
- "mutable": false,
277
- "complexType": {
278
- "original": "boolean",
279
- "resolved": "boolean",
280
- "references": {}
281
- },
282
- "required": false,
283
- "optional": false,
284
- "docs": {
285
- "tags": [],
286
- "text": "If `true`, the keyboard will be automatically dismissed when the overlay is presented."
287
- },
288
- "attribute": "keyboard-close",
289
- "reflect": false,
290
- "defaultValue": "true"
291
- },
292
- "enterAnimation": {
293
- "type": "unknown",
294
- "mutable": false,
295
- "complexType": {
296
- "original": "AnimationBuilder",
297
- "resolved": "((baseEl: any, opts?: any) => Animation) | undefined",
298
- "references": {
299
- "AnimationBuilder": {
300
- "location": "import",
301
- "path": "../../interface",
302
- "id": "src/interface.d.ts::AnimationBuilder"
303
- }
304
- }
305
- },
306
- "required": false,
307
- "optional": true,
308
- "docs": {
309
- "tags": [],
310
- "text": "Animation to use when the picker is presented."
311
- }
312
- },
313
- "leaveAnimation": {
314
- "type": "unknown",
315
- "mutable": false,
316
- "complexType": {
317
- "original": "AnimationBuilder",
318
- "resolved": "((baseEl: any, opts?: any) => Animation) | undefined",
319
- "references": {
320
- "AnimationBuilder": {
321
- "location": "import",
322
- "path": "../../interface",
323
- "id": "src/interface.d.ts::AnimationBuilder"
324
- }
325
- }
326
- },
327
- "required": false,
328
- "optional": true,
329
- "docs": {
330
- "tags": [],
331
- "text": "Animation to use when the picker is dismissed."
332
- }
333
- },
334
- "buttons": {
335
- "type": "unknown",
336
- "mutable": false,
337
- "complexType": {
338
- "original": "PickerButton[]",
339
- "resolved": "PickerButton[]",
340
- "references": {
341
- "PickerButton": {
342
- "location": "import",
343
- "path": "./picker-interface",
344
- "id": "src/components/picker/picker-interface.ts::PickerButton"
345
- }
346
- }
347
- },
348
- "required": false,
349
- "optional": false,
350
- "docs": {
351
- "tags": [],
352
- "text": "Array of buttons to be displayed at the top of the picker."
353
- },
354
- "defaultValue": "[]"
355
- },
356
- "columns": {
357
- "type": "unknown",
358
- "mutable": false,
359
- "complexType": {
360
- "original": "PickerColumn[]",
361
- "resolved": "PickerColumn[]",
362
- "references": {
363
- "PickerColumn": {
364
- "location": "import",
365
- "path": "./picker-interface",
366
- "id": "src/components/picker/picker-interface.ts::PickerColumn"
367
- }
368
- }
369
- },
370
- "required": false,
371
- "optional": false,
372
- "docs": {
373
- "tags": [],
374
- "text": "Array of columns to be displayed in the picker."
375
- },
376
- "defaultValue": "[]"
377
- },
378
- "cssClass": {
379
- "type": "string",
380
- "mutable": false,
381
- "complexType": {
382
- "original": "string | string[]",
383
- "resolved": "string | string[] | undefined",
384
- "references": {}
385
- },
386
- "required": false,
387
- "optional": true,
388
- "docs": {
389
- "tags": [],
390
- "text": "Additional classes to apply for custom CSS. If multiple classes are\nprovided they should be separated by spaces."
391
- },
392
- "attribute": "css-class",
393
- "reflect": false
394
- },
395
- "duration": {
396
- "type": "number",
397
- "mutable": false,
398
- "complexType": {
399
- "original": "number",
400
- "resolved": "number",
401
- "references": {}
402
- },
403
- "required": false,
404
- "optional": false,
405
- "docs": {
406
- "tags": [],
407
- "text": "Number of milliseconds to wait before dismissing the picker."
408
- },
409
- "attribute": "duration",
410
- "reflect": false,
411
- "defaultValue": "0"
412
- },
413
- "showBackdrop": {
414
- "type": "boolean",
415
- "mutable": false,
416
- "complexType": {
417
- "original": "boolean",
418
- "resolved": "boolean",
419
- "references": {}
420
- },
421
- "required": false,
422
- "optional": false,
423
- "docs": {
424
- "tags": [],
425
- "text": "If `true`, a backdrop will be displayed behind the picker."
426
- },
427
- "attribute": "show-backdrop",
428
- "reflect": false,
429
- "defaultValue": "true"
430
- },
431
- "backdropDismiss": {
432
- "type": "boolean",
433
- "mutable": false,
434
- "complexType": {
435
- "original": "boolean",
436
- "resolved": "boolean",
437
- "references": {}
438
- },
439
- "required": false,
440
- "optional": false,
441
- "docs": {
442
- "tags": [],
443
- "text": "If `true`, the picker will be dismissed when the backdrop is clicked."
444
- },
445
- "attribute": "backdrop-dismiss",
446
- "reflect": false,
447
- "defaultValue": "true"
448
- },
449
- "animated": {
450
- "type": "boolean",
451
- "mutable": false,
452
- "complexType": {
453
- "original": "boolean",
454
- "resolved": "boolean",
455
- "references": {}
456
- },
457
- "required": false,
458
- "optional": false,
459
- "docs": {
460
- "tags": [],
461
- "text": "If `true`, the picker will animate."
462
- },
463
- "attribute": "animated",
464
- "reflect": false,
465
- "defaultValue": "true"
466
- },
467
- "htmlAttributes": {
468
- "type": "unknown",
469
- "mutable": false,
470
- "complexType": {
471
- "original": "{ [key: string]: any }",
472
- "resolved": "undefined | { [key: string]: any; }",
473
- "references": {}
474
- },
475
- "required": false,
476
- "optional": true,
477
- "docs": {
478
- "tags": [],
479
- "text": "Additional attributes to pass to the picker."
480
- }
481
- },
482
- "isOpen": {
483
- "type": "boolean",
484
- "mutable": false,
485
- "complexType": {
486
- "original": "boolean",
487
- "resolved": "boolean",
488
- "references": {}
489
- },
490
- "required": false,
491
- "optional": false,
492
- "docs": {
493
- "tags": [],
494
- "text": "If `true`, the picker will open. If `false`, the picker will close.\nUse this if you need finer grained control over presentation, otherwise\njust use the pickerController or the `trigger` property.\nNote: `isOpen` will not automatically be set back to `false` when\nthe picker dismisses. You will need to do that in your code."
495
- },
496
- "attribute": "is-open",
497
- "reflect": false,
498
- "defaultValue": "false"
499
- },
500
- "trigger": {
501
- "type": "string",
502
- "mutable": false,
503
- "complexType": {
504
- "original": "string | undefined",
505
- "resolved": "string | undefined",
506
- "references": {}
507
- },
508
- "required": false,
509
- "optional": false,
510
- "docs": {
511
- "tags": [],
512
- "text": "An ID corresponding to the trigger element that\ncauses the picker to open when clicked."
513
- },
514
- "attribute": "trigger",
515
- "reflect": false
516
- }
517
- };
518
- }
519
- static get states() {
520
- return {
521
- "presented": {}
522
- };
523
- }
524
508
  static get events() {
525
509
  return [{
526
- "method": "didPresent",
527
- "name": "ionPickerDidPresent",
528
- "bubbles": true,
529
- "cancelable": true,
530
- "composed": true,
531
- "docs": {
532
- "tags": [],
533
- "text": "Emitted after the picker has presented."
534
- },
535
- "complexType": {
536
- "original": "void",
537
- "resolved": "void",
538
- "references": {}
539
- }
540
- }, {
541
- "method": "willPresent",
542
- "name": "ionPickerWillPresent",
543
- "bubbles": true,
544
- "cancelable": true,
545
- "composed": true,
546
- "docs": {
547
- "tags": [],
548
- "text": "Emitted before the picker has presented."
549
- },
550
- "complexType": {
551
- "original": "void",
552
- "resolved": "void",
553
- "references": {}
554
- }
555
- }, {
556
- "method": "willDismiss",
557
- "name": "ionPickerWillDismiss",
558
- "bubbles": true,
559
- "cancelable": true,
560
- "composed": true,
561
- "docs": {
562
- "tags": [],
563
- "text": "Emitted before the picker has dismissed."
564
- },
565
- "complexType": {
566
- "original": "OverlayEventDetail",
567
- "resolved": "OverlayEventDetail<any>",
568
- "references": {
569
- "OverlayEventDetail": {
570
- "location": "import",
571
- "path": "../../utils/overlays-interface",
572
- "id": "src/utils/overlays-interface.ts::OverlayEventDetail"
573
- }
574
- }
575
- }
576
- }, {
577
- "method": "didDismiss",
578
- "name": "ionPickerDidDismiss",
579
- "bubbles": true,
580
- "cancelable": true,
581
- "composed": true,
582
- "docs": {
583
- "tags": [],
584
- "text": "Emitted after the picker has dismissed."
585
- },
586
- "complexType": {
587
- "original": "OverlayEventDetail",
588
- "resolved": "OverlayEventDetail<any>",
589
- "references": {
590
- "OverlayEventDetail": {
591
- "location": "import",
592
- "path": "../../utils/overlays-interface",
593
- "id": "src/utils/overlays-interface.ts::OverlayEventDetail"
594
- }
595
- }
596
- }
597
- }, {
598
- "method": "didPresentShorthand",
599
- "name": "didPresent",
600
- "bubbles": true,
601
- "cancelable": true,
602
- "composed": true,
603
- "docs": {
604
- "tags": [],
605
- "text": "Emitted after the picker has presented.\nShorthand for ionPickerWillDismiss."
606
- },
607
- "complexType": {
608
- "original": "void",
609
- "resolved": "void",
610
- "references": {}
611
- }
612
- }, {
613
- "method": "willPresentShorthand",
614
- "name": "willPresent",
615
- "bubbles": true,
616
- "cancelable": true,
617
- "composed": true,
618
- "docs": {
619
- "tags": [],
620
- "text": "Emitted before the picker has presented.\nShorthand for ionPickerWillPresent."
621
- },
622
- "complexType": {
623
- "original": "void",
624
- "resolved": "void",
625
- "references": {}
626
- }
627
- }, {
628
- "method": "willDismissShorthand",
629
- "name": "willDismiss",
510
+ "method": "ionInputModeChange",
511
+ "name": "ionInputModeChange",
630
512
  "bubbles": true,
631
513
  "cancelable": true,
632
514
  "composed": true,
633
515
  "docs": {
634
- "tags": [],
635
- "text": "Emitted before the picker has dismissed.\nShorthand for ionPickerWillDismiss."
636
- },
637
- "complexType": {
638
- "original": "OverlayEventDetail",
639
- "resolved": "OverlayEventDetail<any>",
640
- "references": {
641
- "OverlayEventDetail": {
642
- "location": "import",
643
- "path": "../../utils/overlays-interface",
644
- "id": "src/utils/overlays-interface.ts::OverlayEventDetail"
645
- }
646
- }
647
- }
648
- }, {
649
- "method": "didDismissShorthand",
650
- "name": "didDismiss",
651
- "bubbles": true,
652
- "cancelable": true,
653
- "composed": true,
654
- "docs": {
655
- "tags": [],
656
- "text": "Emitted after the picker has dismissed.\nShorthand for ionPickerDidDismiss."
516
+ "tags": [{
517
+ "name": "internal",
518
+ "text": undefined
519
+ }],
520
+ "text": ""
657
521
  },
658
522
  "complexType": {
659
- "original": "OverlayEventDetail",
660
- "resolved": "OverlayEventDetail<any>",
523
+ "original": "PickerChangeEventDetail",
524
+ "resolved": "PickerChangeEventDetail",
661
525
  "references": {
662
- "OverlayEventDetail": {
526
+ "PickerChangeEventDetail": {
663
527
  "location": "import",
664
- "path": "../../utils/overlays-interface",
665
- "id": "src/utils/overlays-interface.ts::OverlayEventDetail"
528
+ "path": "./picker-interfaces",
529
+ "id": "src/components/picker/picker-interfaces.ts::PickerChangeEventDetail"
666
530
  }
667
531
  }
668
532
  }
@@ -670,7 +534,7 @@ export class Picker {
670
534
  }
671
535
  static get methods() {
672
536
  return {
673
- "present": {
537
+ "exitInputMode": {
674
538
  "complexType": {
675
539
  "signature": "() => Promise<void>",
676
540
  "parameters": [],
@@ -683,141 +547,23 @@ export class Picker {
683
547
  "return": "Promise<void>"
684
548
  },
685
549
  "docs": {
686
- "text": "Present the picker overlay after it has been created.",
687
- "tags": []
688
- }
689
- },
690
- "dismiss": {
691
- "complexType": {
692
- "signature": "(data?: any, role?: string) => Promise<boolean>",
693
- "parameters": [{
694
- "name": "data",
695
- "type": "any",
696
- "docs": "Any data to emit in the dismiss events."
697
- }, {
698
- "name": "role",
699
- "type": "string | undefined",
700
- "docs": "The role of the element that is dismissing the picker.\nThis can be useful in a button handler for determining which button was\nclicked to dismiss the picker.\nSome examples include: ``\"cancel\"`, `\"destructive\"`, \"selected\"`, and `\"backdrop\"`.\n\nThis is a no-op if the overlay has not been presented yet. If you want\nto remove an overlay from the DOM that was never presented, use the\n[remove](https://developer.mozilla.org/en-US/docs/Web/API/Element/remove) method."
701
- }],
702
- "references": {
703
- "Promise": {
704
- "location": "global",
705
- "id": "global::Promise"
706
- }
707
- },
708
- "return": "Promise<boolean>"
709
- },
710
- "docs": {
711
- "text": "Dismiss the picker overlay after it has been presented.",
712
- "tags": [{
713
- "name": "param",
714
- "text": "data Any data to emit in the dismiss events."
715
- }, {
716
- "name": "param",
717
- "text": "role The role of the element that is dismissing the picker.\nThis can be useful in a button handler for determining which button was\nclicked to dismiss the picker.\nSome examples include: ``\"cancel\"`, `\"destructive\"`, \"selected\"`, and `\"backdrop\"`.\n\nThis is a no-op if the overlay has not been presented yet. If you want\nto remove an overlay from the DOM that was never presented, use the\n[remove](https://developer.mozilla.org/en-US/docs/Web/API/Element/remove) method."
718
- }]
719
- }
720
- },
721
- "onDidDismiss": {
722
- "complexType": {
723
- "signature": "<T = any>() => Promise<OverlayEventDetail<T>>",
724
- "parameters": [],
725
- "references": {
726
- "Promise": {
727
- "location": "global",
728
- "id": "global::Promise"
729
- },
730
- "OverlayEventDetail": {
731
- "location": "import",
732
- "path": "../../utils/overlays-interface",
733
- "id": "src/utils/overlays-interface.ts::OverlayEventDetail"
734
- },
735
- "T": {
736
- "location": "global",
737
- "id": "global::T"
738
- }
739
- },
740
- "return": "Promise<OverlayEventDetail<T>>"
741
- },
742
- "docs": {
743
- "text": "Returns a promise that resolves when the picker did dismiss.",
744
- "tags": []
745
- }
746
- },
747
- "onWillDismiss": {
748
- "complexType": {
749
- "signature": "<T = any>() => Promise<OverlayEventDetail<T>>",
750
- "parameters": [],
751
- "references": {
752
- "Promise": {
753
- "location": "global",
754
- "id": "global::Promise"
755
- },
756
- "OverlayEventDetail": {
757
- "location": "import",
758
- "path": "../../utils/overlays-interface",
759
- "id": "src/utils/overlays-interface.ts::OverlayEventDetail"
760
- },
761
- "T": {
762
- "location": "global",
763
- "id": "global::T"
764
- }
765
- },
766
- "return": "Promise<OverlayEventDetail<T>>"
767
- },
768
- "docs": {
769
- "text": "Returns a promise that resolves when the picker will dismiss.",
770
- "tags": []
771
- }
772
- },
773
- "getColumn": {
774
- "complexType": {
775
- "signature": "(name: string) => Promise<PickerColumn | undefined>",
776
- "parameters": [{
777
- "name": "name",
778
- "type": "string",
779
- "docs": "The name of the column."
780
- }],
781
- "references": {
782
- "Promise": {
783
- "location": "global",
784
- "id": "global::Promise"
785
- },
786
- "PickerColumn": {
787
- "location": "import",
788
- "path": "./picker-interface",
789
- "id": "src/components/picker/picker-interface.ts::PickerColumn"
790
- }
791
- },
792
- "return": "Promise<PickerColumn | undefined>"
793
- },
794
- "docs": {
795
- "text": "Get the column that matches the specified name.",
550
+ "text": "",
796
551
  "tags": [{
797
- "name": "param",
798
- "text": "name The name of the column."
552
+ "name": "internal",
553
+ "text": "Exits text entry mode for the picker\nThis method blurs the hidden input\nand cause the keyboard to dismiss."
799
554
  }]
800
555
  }
801
556
  }
802
557
  };
803
558
  }
804
559
  static get elementRef() { return "el"; }
805
- static get watchers() {
560
+ static get listeners() {
806
561
  return [{
807
- "propName": "isOpen",
808
- "methodName": "onIsOpenChange"
809
- }, {
810
- "propName": "trigger",
811
- "methodName": "triggerChanged"
562
+ "name": "touchstart",
563
+ "method": "preventTouchStartPropagation",
564
+ "target": undefined,
565
+ "capture": false,
566
+ "passive": true
812
567
  }];
813
568
  }
814
569
  }
815
- const buttonWrapperClass = (button) => {
816
- return {
817
- [`picker-toolbar-${button.role}`]: button.role !== undefined,
818
- 'picker-toolbar-button': true,
819
- };
820
- };
821
- const buttonClass = (button) => {
822
- return Object.assign({ 'picker-button': true, 'ion-activatable': true }, getClassMap(button.cssClass));
823
- };