voyager-ionic-core 8.0.0-beta.2 → 8.0.0-rc.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (678) hide show
  1. package/components/animation.js +9 -250
  2. package/components/button.js +18 -5
  3. package/components/haptic.js +6 -54
  4. package/components/helpers.js +1 -50
  5. package/components/index7.js +3 -1
  6. package/components/index9.js +5 -34
  7. package/components/ion-datetime-button.js +1 -1
  8. package/components/ion-datetime.js +7 -6
  9. package/components/ion-fab-button.js +2 -2
  10. package/components/ion-fab-list.js +2 -2
  11. package/components/ion-fab.js +2 -2
  12. package/components/ion-footer.js +2 -2
  13. package/components/ion-grid.js +2 -2
  14. package/components/ion-header.js +3 -3
  15. package/components/ion-img.js +1 -1
  16. package/components/ion-infinite-scroll-content.js +2 -2
  17. package/components/ion-infinite-scroll.js +1 -1
  18. package/components/ion-input-password-toggle.d.ts +11 -0
  19. package/components/ion-input-password-toggle.js +132 -0
  20. package/components/ion-input.js +27 -8
  21. package/components/ion-item-divider.js +2 -2
  22. package/components/ion-item-group.js +1 -1
  23. package/components/ion-item-option.js +2 -2
  24. package/components/ion-item-options.js +1 -1
  25. package/components/ion-item-sliding.js +1 -1
  26. package/components/ion-loading.js +2 -2
  27. package/components/ion-menu-button.js +3 -3
  28. package/components/ion-menu-toggle.js +2 -2
  29. package/components/ion-menu.js +2 -2
  30. package/components/ion-modal.js +3 -3
  31. package/components/ion-nav-link.js +1 -1
  32. package/components/ion-nav.js +1 -1
  33. package/components/ion-note.js +2 -2
  34. package/components/ion-picker-legacy.js +2 -2
  35. package/components/ion-progress-bar.js +1 -1
  36. package/components/ion-range.js +11 -24
  37. package/components/ion-refresher-content.js +2 -2
  38. package/components/ion-refresher.js +1 -1
  39. package/components/ion-reorder-group.js +1 -1
  40. package/components/ion-reorder.js +2 -2
  41. package/components/ion-router-link.js +2 -2
  42. package/components/ion-router-outlet.js +1 -1
  43. package/components/ion-router.js +1 -1
  44. package/components/ion-row.js +1 -1
  45. package/components/ion-searchbar.js +7 -7
  46. package/components/ion-segment-button.js +3 -3
  47. package/components/ion-segment.js +2 -2
  48. package/components/ion-select-option.js +1 -1
  49. package/components/ion-select.js +10 -10
  50. package/components/ion-skeleton-text.js +2 -2
  51. package/components/ion-split-pane.js +2 -2
  52. package/components/ion-tab-bar.js +2 -2
  53. package/components/ion-tab-button.js +2 -2
  54. package/components/ion-tab.js +2 -2
  55. package/components/ion-tabs.js +1 -1
  56. package/components/ion-text.js +2 -2
  57. package/components/ion-textarea.js +4 -5
  58. package/components/ion-thumbnail.js +1 -1
  59. package/components/ion-title.js +2 -2
  60. package/components/ion-toast.js +2 -2
  61. package/components/ion-toggle.js +4 -4
  62. package/components/ion-toolbar.js +2 -2
  63. package/components/label.js +2 -2
  64. package/components/list-header.js +2 -2
  65. package/components/list.js +1 -1
  66. package/components/picker-column-option.js +2 -2
  67. package/components/picker-column.js +8 -4
  68. package/components/picker-column2.js +2 -2
  69. package/components/picker.js +2 -2
  70. package/components/popover.js +2 -2
  71. package/components/radio-group.js +1 -1
  72. package/components/radio.js +3 -3
  73. package/components/ripple-effect.js +1 -1
  74. package/components/select-popover.js +1 -1
  75. package/components/spinner.js +1 -1
  76. package/css/palettes/dark.always.css.map +1 -0
  77. package/css/{themes → palettes}/dark.class.css +4 -4
  78. package/css/palettes/dark.class.css.map +1 -0
  79. package/css/palettes/dark.system.css.map +1 -0
  80. package/css/palettes/high-contrast-dark.always.css.map +1 -0
  81. package/css/{themes → palettes}/high-contrast-dark.class.css +10 -10
  82. package/css/palettes/high-contrast-dark.class.css.map +1 -0
  83. package/css/palettes/high-contrast-dark.system.css.map +1 -0
  84. package/css/palettes/high-contrast.always.css.map +1 -0
  85. package/css/{themes → palettes}/high-contrast.class.css +31 -31
  86. package/css/palettes/high-contrast.class.css.map +1 -0
  87. package/css/palettes/high-contrast.system.css.map +1 -0
  88. package/dist/cjs/{animation-3e7bb91e.js → animation-b4fdf128.js} +9 -250
  89. package/dist/cjs/{app-globals-e132c781.js → app-globals-63aebf89.js} +1 -1
  90. package/dist/cjs/{button-active-60ecf64d.js → button-active-bd13859e.js} +2 -2
  91. package/dist/cjs/{framework-delegate-0499d444.js → framework-delegate-55f5683a.js} +1 -1
  92. package/dist/cjs/{haptic-b882e0bb.js → haptic-f6b37aa3.js} +6 -54
  93. package/dist/cjs/{hardware-back-button-1c67a5a2.js → hardware-back-button-ad9299b4.js} +2 -2
  94. package/dist/cjs/{helpers-668b3d95.js → helpers-afaa9001.js} +0 -51
  95. package/dist/cjs/{index-f52c6d38.js → index-073c7cdc.js} +4 -0
  96. package/dist/cjs/{index-c49cb371.js → index-5b6a7459.js} +1 -1
  97. package/dist/cjs/{index-ba7ba0af.js → index-5cf05f94.js} +4 -4
  98. package/dist/cjs/{index-275cc12e.js → index-9509ecad.js} +5 -34
  99. package/dist/cjs/{index-2d21d526.js → index-af6d0fbb.js} +16 -4
  100. package/dist/cjs/{index-e4b6c97e.js → index-ff66cc7c.js} +4 -4
  101. package/dist/cjs/index.cjs.js +11 -11
  102. package/dist/cjs/{input-shims-b419f083.js → input-shims-20d639e6.js} +2 -2
  103. package/dist/cjs/{input.utils-32c0a14a.js → input.utils-611cde0b.js} +1 -1
  104. package/dist/cjs/ion-accordion_2.cjs.entry.js +4 -4
  105. package/dist/cjs/ion-action-sheet.cjs.entry.js +9 -9
  106. package/dist/cjs/ion-alert.cjs.entry.js +9 -9
  107. package/dist/cjs/ion-app_8.cjs.entry.js +22 -22
  108. package/dist/cjs/ion-avatar_3.cjs.entry.js +3 -3
  109. package/dist/cjs/ion-back-button.cjs.entry.js +4 -4
  110. package/dist/cjs/ion-backdrop.cjs.entry.js +2 -2
  111. package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +4 -4
  112. package/dist/cjs/ion-button_2.cjs.entry.js +19 -7
  113. package/dist/cjs/ion-card_5.cjs.entry.js +3 -3
  114. package/dist/cjs/ion-checkbox.cjs.entry.js +3 -3
  115. package/dist/cjs/ion-chip.cjs.entry.js +2 -2
  116. package/dist/cjs/ion-col_3.cjs.entry.js +5 -5
  117. package/dist/cjs/ion-datetime-button.cjs.entry.js +4 -4
  118. package/dist/cjs/ion-datetime_3.cjs.entry.js +20 -19
  119. package/dist/cjs/ion-fab_3.cjs.entry.js +10 -10
  120. package/dist/cjs/ion-img.cjs.entry.js +4 -4
  121. package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +7 -7
  122. package/dist/cjs/ion-input-password-toggle.cjs.entry.js +93 -0
  123. package/dist/cjs/ion-input.cjs.entry.js +30 -12
  124. package/dist/cjs/ion-item-option_3.cjs.entry.js +8 -8
  125. package/dist/cjs/ion-item_8.cjs.entry.js +16 -16
  126. package/dist/cjs/ion-loading.cjs.entry.js +9 -9
  127. package/dist/cjs/ion-menu_3.cjs.entry.js +15 -15
  128. package/dist/cjs/ion-modal.cjs.entry.js +12 -12
  129. package/dist/cjs/ion-nav_2.cjs.entry.js +8 -8
  130. package/dist/cjs/ion-picker-column-option.cjs.entry.js +5 -5
  131. package/dist/cjs/ion-picker-column.cjs.entry.js +12 -8
  132. package/dist/cjs/ion-picker.cjs.entry.js +4 -4
  133. package/dist/cjs/ion-popover.cjs.entry.js +10 -10
  134. package/dist/cjs/ion-progress-bar.cjs.entry.js +4 -4
  135. package/dist/cjs/ion-radio_2.cjs.entry.js +7 -7
  136. package/dist/cjs/ion-range.cjs.entry.js +14 -27
  137. package/dist/cjs/ion-refresher_2.cjs.entry.js +9 -9
  138. package/dist/cjs/ion-reorder_2.cjs.entry.js +8 -8
  139. package/dist/cjs/ion-ripple-effect.cjs.entry.js +3 -3
  140. package/dist/cjs/ion-route_4.cjs.entry.js +5 -5
  141. package/dist/cjs/ion-searchbar.cjs.entry.js +10 -10
  142. package/dist/cjs/ion-segment_2.cjs.entry.js +8 -8
  143. package/dist/cjs/ion-select_3.cjs.entry.js +18 -18
  144. package/dist/cjs/ion-spinner.cjs.entry.js +3 -3
  145. package/dist/cjs/ion-split-pane.cjs.entry.js +4 -4
  146. package/dist/cjs/ion-tab-bar_2.cjs.entry.js +7 -7
  147. package/dist/cjs/ion-tab_2.cjs.entry.js +6 -6
  148. package/dist/cjs/ion-text.cjs.entry.js +4 -4
  149. package/dist/cjs/ion-textarea.cjs.entry.js +9 -10
  150. package/dist/cjs/ion-toast.cjs.entry.js +9 -9
  151. package/dist/cjs/ion-toggle.cjs.entry.js +8 -8
  152. package/dist/cjs/{ionic-global-5762eca9.js → ionic-global-1adf9bc4.js} +1 -1
  153. package/dist/cjs/ionic.cjs.js +5 -5
  154. package/dist/cjs/{ios.transition-3e119901.js → ios.transition-06673f18.js} +4 -4
  155. package/dist/cjs/loader.cjs.js +4 -4
  156. package/dist/cjs/{md.transition-c1392f92.js → md.transition-4d7bb4b1.js} +4 -4
  157. package/dist/cjs/{notch-controller-08a24f39.js → notch-controller-d69150f5.js} +1 -1
  158. package/dist/cjs/{overlays-44b8d0e0.js → overlays-6487955a.js} +4 -4
  159. package/dist/cjs/{status-tap-32430b3e.js → status-tap-0be20572.js} +3 -3
  160. package/dist/cjs/{swipe-back-b8484483.js → swipe-back-f38a434a.js} +1 -1
  161. package/dist/collection/collection-manifest.json +3 -2
  162. package/dist/collection/components/action-sheet/test/a11y/action-sheet.e2e.js +1 -1
  163. package/dist/collection/components/alert/test/a11y/alert.e2e.js +5 -1
  164. package/dist/collection/components/alert/test/basic/alert.e2e.js +1 -1
  165. package/dist/collection/components/back-button/test/a11y/back-button.e2e.js +1 -1
  166. package/dist/collection/components/badge/test/a11y/badge.e2e.js +1 -1
  167. package/dist/collection/components/button/button.ios.css +32 -10
  168. package/dist/collection/components/button/button.js +19 -2
  169. package/dist/collection/components/button/button.md.css +28 -13
  170. package/dist/collection/components/button/test/a11y/button.e2e.js +2 -2
  171. package/dist/collection/components/button/test/round/button.e2e.js +39 -4
  172. package/dist/collection/components/checkbox/test/a11y/checkbox.e2e.js +1 -1
  173. package/dist/collection/components/datetime/datetime.js +7 -6
  174. package/dist/collection/components/datetime-button/datetime-button.js +1 -1
  175. package/dist/collection/components/fab/fab.js +2 -2
  176. package/dist/collection/components/fab-button/fab-button.js +2 -2
  177. package/dist/collection/components/fab-button/test/a11y/fab-button.e2e.js +1 -1
  178. package/dist/collection/components/fab-list/fab-list.js +2 -2
  179. package/dist/collection/components/footer/footer.js +2 -2
  180. package/dist/collection/components/grid/grid.js +2 -2
  181. package/dist/collection/components/header/header.ios.css +5 -2
  182. package/dist/collection/components/header/header.js +2 -2
  183. package/dist/collection/components/header/test/basic/header.e2e.js +77 -0
  184. package/dist/collection/components/img/img.js +1 -1
  185. package/dist/collection/components/infinite-scroll/infinite-scroll.js +1 -1
  186. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +2 -2
  187. package/dist/collection/components/input/input.ios.css +11 -2
  188. package/dist/collection/components/input/input.js +27 -30
  189. package/dist/collection/components/input/input.md.css +11 -2
  190. package/dist/collection/components/input/test/a11y/input.e2e.js +1 -1
  191. package/dist/collection/components/input/test/slot/input.e2e.js +8 -0
  192. package/dist/collection/components/input-password-toggle/input-password-toggle.css +0 -0
  193. package/dist/collection/components/input-password-toggle/input-password-toggle.js +183 -0
  194. package/dist/collection/components/input-password-toggle/test/a11y/input-password-toggle.e2e.js +21 -0
  195. package/dist/collection/components/input-password-toggle/test/basic/input-password-toggle.e2e.js +38 -0
  196. package/dist/collection/components/input-password-toggle/test/input-password-toggle.spec.js +76 -0
  197. package/dist/collection/components/item/test/buttons/item.e2e.js +20 -4
  198. package/dist/collection/components/item-divider/item-divider.js +2 -2
  199. package/dist/collection/components/item-group/item-group.js +1 -1
  200. package/dist/collection/components/item-option/item-option.js +2 -2
  201. package/dist/collection/components/item-options/item-options.js +1 -1
  202. package/dist/collection/components/item-sliding/item-sliding.js +1 -1
  203. package/dist/collection/components/item-sliding/test/a11y/item-sliding.e2e.js +1 -1
  204. package/dist/collection/components/label/label.js +2 -2
  205. package/dist/collection/components/label/test/a11y/label.e2e.js +1 -1
  206. package/dist/collection/components/list/list.js +1 -1
  207. package/dist/collection/components/list-header/list-header.js +2 -2
  208. package/dist/collection/components/loading/loading.js +2 -2
  209. package/dist/collection/components/loading/test/a11y/loading.e2e.js +1 -1
  210. package/dist/collection/components/menu/menu.js +2 -2
  211. package/dist/collection/components/menu-button/menu-button.js +2 -2
  212. package/dist/collection/components/menu-button/test/a11y/menu-button.e2e.js +1 -1
  213. package/dist/collection/components/menu-toggle/menu-toggle.js +2 -2
  214. package/dist/collection/components/modal/modal.js +3 -3
  215. package/dist/collection/components/nav/nav.js +1 -1
  216. package/dist/collection/components/nav-link/nav-link.js +1 -1
  217. package/dist/collection/components/note/note.js +2 -2
  218. package/dist/collection/components/picker/picker.js +2 -2
  219. package/dist/collection/components/picker-column/picker-column.js +8 -4
  220. package/dist/collection/components/picker-column-option/picker-column-option.js +2 -2
  221. package/dist/collection/components/picker-legacy/picker.js +2 -2
  222. package/dist/collection/components/picker-legacy-column/picker-column.js +2 -2
  223. package/dist/collection/components/popover/popover.js +2 -2
  224. package/dist/collection/components/progress-bar/progress-bar.js +1 -1
  225. package/dist/collection/components/progress-bar/test/a11y/progress-bar.e2e.js +1 -1
  226. package/dist/collection/components/radio/radio.js +3 -3
  227. package/dist/collection/components/radio/test/a11y/radio.e2e.js +1 -1
  228. package/dist/collection/components/radio-group/radio-group.js +1 -1
  229. package/dist/collection/components/range/range.js +11 -24
  230. package/dist/collection/components/range/test/a11y/range.e2e.js +1 -1
  231. package/dist/collection/components/range/test/label/range.spec.js +24 -0
  232. package/dist/collection/components/refresher/refresher.js +1 -1
  233. package/dist/collection/components/refresher/test/a11y/refresher.e2e.js +1 -1
  234. package/dist/collection/components/refresher-content/refresher-content.js +1 -1
  235. package/dist/collection/components/reorder/reorder.js +1 -1
  236. package/dist/collection/components/reorder-group/reorder-group.js +1 -1
  237. package/dist/collection/components/ripple-effect/ripple-effect.js +1 -1
  238. package/dist/collection/components/router-link/router-link.js +2 -2
  239. package/dist/collection/components/router-link/test/a11y/router-link.e2e.js +1 -1
  240. package/dist/collection/components/router-outlet/router-outlet.js +1 -1
  241. package/dist/collection/components/row/row.js +1 -1
  242. package/dist/collection/components/searchbar/searchbar.js +10 -9
  243. package/dist/collection/components/segment/segment.js +2 -2
  244. package/dist/collection/components/segment/test/a11y/segment.e2e.js +1 -1
  245. package/dist/collection/components/segment-button/segment-button.js +3 -3
  246. package/dist/collection/components/select/select.ios.css +2 -2
  247. package/dist/collection/components/select/select.js +7 -7
  248. package/dist/collection/components/select/select.md.css +2 -2
  249. package/dist/collection/components/select/test/a11y/select.e2e.js +1 -1
  250. package/dist/collection/components/select/test/select.spec.js +22 -0
  251. package/dist/collection/components/select/test/slot/select.e2e.js +8 -0
  252. package/dist/collection/components/select-option/select-option.js +1 -1
  253. package/dist/collection/components/select-popover/select-popover.js +1 -1
  254. package/dist/collection/components/select-popover/test/a11y/select-popover.e2e.js +1 -1
  255. package/dist/collection/components/skeleton-text/skeleton-text.js +2 -2
  256. package/dist/collection/components/spinner/spinner.js +1 -1
  257. package/dist/collection/components/split-pane/split-pane.js +2 -2
  258. package/dist/collection/components/tab/tab.js +2 -2
  259. package/dist/collection/components/tab-bar/tab-bar.js +2 -2
  260. package/dist/collection/components/tab-button/tab-button.js +2 -2
  261. package/dist/collection/components/tabs/tabs.js +1 -1
  262. package/dist/collection/components/text/text.js +2 -2
  263. package/dist/collection/components/textarea/test/a11y/textarea.e2e.js +1 -1
  264. package/dist/collection/components/textarea/test/slot/textarea.e2e.js +8 -0
  265. package/dist/collection/components/textarea/textarea.ios.css +2 -2
  266. package/dist/collection/components/textarea/textarea.js +2 -26
  267. package/dist/collection/components/textarea/textarea.md.css +2 -2
  268. package/dist/collection/components/thumbnail/thumbnail.js +1 -1
  269. package/dist/collection/components/title/title.js +2 -2
  270. package/dist/collection/components/toast/test/a11y/toast.e2e.js +2 -2
  271. package/dist/collection/components/toast/toast.js +2 -2
  272. package/dist/collection/components/toggle/test/a11y/toggle.e2e.js +1 -1
  273. package/dist/collection/components/toggle/toggle.js +4 -4
  274. package/dist/collection/components/toolbar/toolbar.js +2 -2
  275. package/dist/collection/css/test/a11y/typography.e2e.js +1 -1
  276. package/dist/collection/themes/test/colors/theme.e2e.js +2 -2
  277. package/dist/collection/utils/animation/animation-utils.js +0 -102
  278. package/dist/collection/utils/animation/animation.js +10 -141
  279. package/dist/collection/utils/animation/test/animation.spec.js +0 -89
  280. package/dist/collection/utils/animation/test/animationbuilder/animation.e2e.js +0 -4
  281. package/dist/collection/utils/animation/test/basic/animation.e2e.js +0 -4
  282. package/dist/collection/utils/animation/test/display/animation.e2e.js +0 -4
  283. package/dist/collection/utils/animation/test/hooks/animation.e2e.js +0 -4
  284. package/dist/collection/utils/animation/test/multiple/animation.e2e.js +0 -7
  285. package/dist/collection/utils/helpers.js +0 -46
  286. package/dist/collection/utils/native/haptic.js +6 -54
  287. package/dist/collection/utils/tap-click/index.js +5 -34
  288. package/dist/collection/utils/test/playwright/generator.js +17 -17
  289. package/dist/collection/utils/test/playwright/page/utils/set-content.js +6 -6
  290. package/dist/docs.json +211 -36
  291. package/dist/esm/{animation-9a23ed8d.js → animation-eab5a4ca.js} +9 -250
  292. package/dist/esm/{app-globals-80842d68.js → app-globals-b8e5e7fa.js} +1 -1
  293. package/dist/esm/{button-active-c6e18fac.js → button-active-a411da52.js} +2 -2
  294. package/dist/esm/{framework-delegate-3fd96df8.js → framework-delegate-63d1a679.js} +1 -1
  295. package/dist/esm/{haptic-554688a5.js → haptic-ac164e4c.js} +6 -54
  296. package/dist/esm/{hardware-back-button-fb295e3a.js → hardware-back-button-329c81fd.js} +2 -2
  297. package/dist/esm/{helpers-f51cf76f.js → helpers-da915de8.js} +1 -50
  298. package/dist/esm/{index-9d7e5d3e.js → index-10916999.js} +4 -4
  299. package/dist/esm/{index-86688780.js → index-5cc724f3.js} +1 -1
  300. package/dist/esm/{index-5d6a0317.js → index-6e4709ff.js} +16 -4
  301. package/dist/esm/{index-1262064c.js → index-79b30591.js} +5 -34
  302. package/dist/esm/{index-f7dc70ba.js → index-e2cf2ceb.js} +3 -1
  303. package/dist/esm/{index-6da05eef.js → index-f1f5de26.js} +4 -4
  304. package/dist/esm/index.js +11 -11
  305. package/dist/esm/{input-shims-2a4ad5a1.js → input-shims-4530285e.js} +2 -2
  306. package/dist/esm/{input.utils-d2dee48e.js → input.utils-09c71bc7.js} +1 -1
  307. package/dist/esm/ion-accordion_2.entry.js +4 -4
  308. package/dist/esm/ion-action-sheet.entry.js +9 -9
  309. package/dist/esm/ion-alert.entry.js +9 -9
  310. package/dist/esm/ion-app_8.entry.js +22 -22
  311. package/dist/esm/ion-avatar_3.entry.js +3 -3
  312. package/dist/esm/ion-back-button.entry.js +4 -4
  313. package/dist/esm/ion-backdrop.entry.js +2 -2
  314. package/dist/esm/ion-breadcrumb_2.entry.js +4 -4
  315. package/dist/esm/ion-button_2.entry.js +19 -7
  316. package/dist/esm/ion-card_5.entry.js +3 -3
  317. package/dist/esm/ion-checkbox.entry.js +3 -3
  318. package/dist/esm/ion-chip.entry.js +2 -2
  319. package/dist/esm/ion-col_3.entry.js +5 -5
  320. package/dist/esm/ion-datetime-button.entry.js +4 -4
  321. package/dist/esm/ion-datetime_3.entry.js +20 -19
  322. package/dist/esm/ion-fab_3.entry.js +10 -10
  323. package/dist/esm/ion-img.entry.js +4 -4
  324. package/dist/esm/ion-infinite-scroll_2.entry.js +7 -7
  325. package/dist/esm/ion-input-password-toggle.entry.js +89 -0
  326. package/dist/esm/ion-input.entry.js +30 -12
  327. package/dist/esm/ion-item-option_3.entry.js +8 -8
  328. package/dist/esm/ion-item_8.entry.js +16 -16
  329. package/dist/esm/ion-loading.entry.js +9 -9
  330. package/dist/esm/ion-menu_3.entry.js +15 -15
  331. package/dist/esm/ion-modal.entry.js +12 -12
  332. package/dist/esm/ion-nav_2.entry.js +8 -8
  333. package/dist/esm/ion-picker-column-option.entry.js +5 -5
  334. package/dist/esm/ion-picker-column.entry.js +12 -8
  335. package/dist/esm/ion-picker.entry.js +4 -4
  336. package/dist/esm/ion-popover.entry.js +10 -10
  337. package/dist/esm/ion-progress-bar.entry.js +4 -4
  338. package/dist/esm/ion-radio_2.entry.js +7 -7
  339. package/dist/esm/ion-range.entry.js +14 -27
  340. package/dist/esm/ion-refresher_2.entry.js +9 -9
  341. package/dist/esm/ion-reorder_2.entry.js +8 -8
  342. package/dist/esm/ion-ripple-effect.entry.js +3 -3
  343. package/dist/esm/ion-route_4.entry.js +5 -5
  344. package/dist/esm/ion-searchbar.entry.js +10 -10
  345. package/dist/esm/ion-segment_2.entry.js +8 -8
  346. package/dist/esm/ion-select_3.entry.js +18 -18
  347. package/dist/esm/ion-spinner.entry.js +3 -3
  348. package/dist/esm/ion-split-pane.entry.js +4 -4
  349. package/dist/esm/ion-tab-bar_2.entry.js +7 -7
  350. package/dist/esm/ion-tab_2.entry.js +6 -6
  351. package/dist/esm/ion-text.entry.js +4 -4
  352. package/dist/esm/ion-textarea.entry.js +9 -10
  353. package/dist/esm/ion-toast.entry.js +9 -9
  354. package/dist/esm/ion-toggle.entry.js +8 -8
  355. package/dist/esm/{ionic-global-a589c12c.js → ionic-global-c4e0c089.js} +1 -1
  356. package/dist/esm/ionic.js +6 -6
  357. package/dist/esm/{ios.transition-fbde96b0.js → ios.transition-8e181a7e.js} +4 -4
  358. package/dist/esm/loader.js +5 -5
  359. package/dist/esm/{md.transition-76e0020b.js → md.transition-f1c3c737.js} +4 -4
  360. package/dist/esm/{notch-controller-00572cf8.js → notch-controller-55b09e11.js} +1 -1
  361. package/dist/esm/{overlays-b1ac1c63.js → overlays-9472c98b.js} +4 -4
  362. package/dist/esm/{status-tap-84b41f36.js → status-tap-39da9160.js} +3 -3
  363. package/dist/esm/{swipe-back-4f2e5d47.js → swipe-back-b613d7db.js} +1 -1
  364. package/dist/esm-es5/animation-eab5a4ca.js +4 -0
  365. package/dist/esm-es5/app-globals-b8e5e7fa.js +4 -0
  366. package/dist/esm-es5/{button-active-c6e18fac.js → button-active-a411da52.js} +1 -1
  367. package/dist/esm-es5/framework-delegate-63d1a679.js +4 -0
  368. package/dist/esm-es5/haptic-ac164e4c.js +4 -0
  369. package/dist/esm-es5/{hardware-back-button-fb295e3a.js → hardware-back-button-329c81fd.js} +1 -1
  370. package/dist/esm-es5/helpers-da915de8.js +4 -0
  371. package/dist/esm-es5/index-10916999.js +4 -0
  372. package/dist/esm-es5/{index-86688780.js → index-5cc724f3.js} +1 -1
  373. package/dist/esm-es5/index-6e4709ff.js +5 -0
  374. package/dist/esm-es5/index-79b30591.js +4 -0
  375. package/dist/esm-es5/{index-f7dc70ba.js → index-e2cf2ceb.js} +1 -1
  376. package/dist/esm-es5/{index-6da05eef.js → index-f1f5de26.js} +1 -1
  377. package/dist/esm-es5/index.js +1 -1
  378. package/dist/esm-es5/input-shims-4530285e.js +4 -0
  379. package/dist/esm-es5/{input.utils-d2dee48e.js → input.utils-09c71bc7.js} +1 -1
  380. package/dist/esm-es5/ion-accordion_2.entry.js +1 -1
  381. package/dist/esm-es5/ion-action-sheet.entry.js +1 -1
  382. package/dist/esm-es5/ion-alert.entry.js +1 -1
  383. package/dist/esm-es5/ion-app_8.entry.js +1 -1
  384. package/dist/esm-es5/ion-avatar_3.entry.js +1 -1
  385. package/dist/esm-es5/ion-back-button.entry.js +1 -1
  386. package/dist/esm-es5/ion-backdrop.entry.js +1 -1
  387. package/dist/esm-es5/ion-breadcrumb_2.entry.js +1 -1
  388. package/dist/esm-es5/ion-button_2.entry.js +1 -1
  389. package/dist/esm-es5/ion-card_5.entry.js +1 -1
  390. package/dist/esm-es5/ion-checkbox.entry.js +1 -1
  391. package/dist/esm-es5/ion-chip.entry.js +1 -1
  392. package/dist/esm-es5/ion-col_3.entry.js +1 -1
  393. package/dist/esm-es5/ion-datetime-button.entry.js +1 -1
  394. package/dist/esm-es5/ion-datetime_3.entry.js +1 -1
  395. package/dist/esm-es5/ion-fab_3.entry.js +1 -1
  396. package/dist/esm-es5/ion-img.entry.js +1 -1
  397. package/dist/esm-es5/ion-infinite-scroll_2.entry.js +1 -1
  398. package/dist/esm-es5/ion-input-password-toggle.entry.js +4 -0
  399. package/dist/esm-es5/ion-input.entry.js +1 -1
  400. package/dist/esm-es5/ion-item-option_3.entry.js +1 -1
  401. package/dist/esm-es5/ion-item_8.entry.js +1 -1
  402. package/dist/esm-es5/ion-loading.entry.js +1 -1
  403. package/dist/esm-es5/ion-menu_3.entry.js +1 -1
  404. package/dist/esm-es5/ion-modal.entry.js +1 -1
  405. package/dist/esm-es5/ion-nav_2.entry.js +1 -1
  406. package/dist/esm-es5/ion-picker-column-option.entry.js +1 -1
  407. package/dist/esm-es5/ion-picker-column.entry.js +1 -1
  408. package/dist/esm-es5/ion-picker.entry.js +1 -1
  409. package/dist/esm-es5/ion-popover.entry.js +1 -1
  410. package/dist/esm-es5/ion-progress-bar.entry.js +1 -1
  411. package/dist/esm-es5/ion-radio_2.entry.js +1 -1
  412. package/dist/esm-es5/ion-range.entry.js +1 -1
  413. package/dist/esm-es5/ion-refresher_2.entry.js +1 -1
  414. package/dist/esm-es5/ion-reorder_2.entry.js +1 -1
  415. package/dist/esm-es5/ion-ripple-effect.entry.js +1 -1
  416. package/dist/esm-es5/ion-route_4.entry.js +1 -1
  417. package/dist/esm-es5/ion-searchbar.entry.js +1 -1
  418. package/dist/esm-es5/ion-segment_2.entry.js +1 -1
  419. package/dist/esm-es5/ion-select_3.entry.js +1 -1
  420. package/dist/esm-es5/ion-spinner.entry.js +1 -1
  421. package/dist/esm-es5/ion-split-pane.entry.js +1 -1
  422. package/dist/esm-es5/ion-tab-bar_2.entry.js +1 -1
  423. package/dist/esm-es5/ion-tab_2.entry.js +1 -1
  424. package/dist/esm-es5/ion-text.entry.js +1 -1
  425. package/dist/esm-es5/ion-textarea.entry.js +1 -1
  426. package/dist/esm-es5/ion-toast.entry.js +1 -1
  427. package/dist/esm-es5/ion-toggle.entry.js +1 -1
  428. package/dist/esm-es5/{ionic-global-a589c12c.js → ionic-global-c4e0c089.js} +1 -1
  429. package/dist/esm-es5/ionic.js +1 -1
  430. package/dist/esm-es5/{ios.transition-fbde96b0.js → ios.transition-8e181a7e.js} +1 -1
  431. package/dist/esm-es5/loader.js +1 -1
  432. package/dist/esm-es5/md.transition-f1c3c737.js +4 -0
  433. package/dist/esm-es5/{notch-controller-00572cf8.js → notch-controller-55b09e11.js} +1 -1
  434. package/dist/esm-es5/{overlays-b1ac1c63.js → overlays-9472c98b.js} +1 -1
  435. package/dist/esm-es5/{status-tap-84b41f36.js → status-tap-39da9160.js} +1 -1
  436. package/dist/esm-es5/{swipe-back-4f2e5d47.js → swipe-back-b613d7db.js} +1 -1
  437. package/dist/html.html-data.json +87 -19
  438. package/dist/ionic/index.esm.js +1 -1
  439. package/dist/ionic/ionic.esm.js +1 -1
  440. package/dist/ionic/ionic.js +1 -1
  441. package/dist/ionic/{p-f15b0bbc.system.entry.js → p-04070329.system.entry.js} +1 -1
  442. package/dist/ionic/p-049fa018.system.entry.js +4 -0
  443. package/dist/ionic/{p-4ba6d7d1.js → p-06e58c4e.js} +1 -1
  444. package/dist/ionic/{p-f8dfae89.system.entry.js → p-07ae133d.system.entry.js} +1 -1
  445. package/dist/ionic/p-0aa4682e.entry.js +4 -0
  446. package/dist/ionic/{p-2028668d.system.entry.js → p-0bbb6edf.system.entry.js} +1 -1
  447. package/dist/ionic/{p-8dfe436d.system.js → p-0c06e09b.system.js} +1 -1
  448. package/dist/ionic/p-0de546bb.entry.js +4 -0
  449. package/dist/ionic/{p-6d75fbe8.system.entry.js → p-0ebb1fe7.system.entry.js} +1 -1
  450. package/dist/ionic/p-0f2d99a6.entry.js +4 -0
  451. package/dist/ionic/p-100bedc4.system.entry.js +4 -0
  452. package/dist/ionic/{p-91567c90.system.entry.js → p-105f7d62.system.entry.js} +1 -1
  453. package/dist/ionic/{p-ff740d68.system.entry.js → p-1672c4fd.system.entry.js} +2 -2
  454. package/dist/ionic/{p-d85eebc3.entry.js → p-17978fce.entry.js} +1 -1
  455. package/dist/ionic/{p-0eb381c3.system.js → p-184fbc9e.system.js} +1 -1
  456. package/dist/ionic/{p-3944820a.system.js → p-19ea7bff.system.js} +1 -1
  457. package/dist/ionic/{p-7200f2da.entry.js → p-1b235142.entry.js} +1 -1
  458. package/dist/ionic/{p-21e88629.entry.js → p-1cff9cad.entry.js} +1 -1
  459. package/dist/ionic/p-1e955a45.system.js +4 -0
  460. package/dist/ionic/{p-234dc736.entry.js → p-1f9cdee2.entry.js} +1 -1
  461. package/dist/ionic/p-23b89985.entry.js +4 -0
  462. package/dist/ionic/{p-53c592ec.system.js → p-25575222.system.js} +1 -1
  463. package/dist/ionic/{p-ea5173f9.system.js → p-266fc56e.system.js} +1 -1
  464. package/dist/ionic/p-2e12bda2.entry.js +4 -0
  465. package/dist/ionic/{p-a5c33d6b.system.entry.js → p-2f6cedaf.system.entry.js} +1 -1
  466. package/dist/ionic/{p-78b3da77.js → p-3040730e.js} +1 -1
  467. package/dist/ionic/{p-75addf49.entry.js → p-3391d9a3.entry.js} +1 -1
  468. package/dist/ionic/{p-4da2ae44.js → p-34b11c24.js} +1 -1
  469. package/dist/ionic/{p-f6db2e96.system.entry.js → p-352f7037.system.entry.js} +2 -2
  470. package/dist/ionic/{p-5054b3db.entry.js → p-35b9e842.entry.js} +1 -1
  471. package/dist/ionic/p-3ad285e3.system.js +4 -0
  472. package/dist/ionic/{p-95648db9.entry.js → p-3c70b01b.entry.js} +1 -1
  473. package/dist/ionic/{p-46a4e4e8.js → p-3cc276f4.js} +1 -1
  474. package/dist/ionic/{p-566818dd.system.entry.js → p-3d6e882f.system.entry.js} +1 -1
  475. package/dist/ionic/{p-2e2635b4.system.entry.js → p-3e3b34f7.system.entry.js} +1 -1
  476. package/dist/ionic/{p-0da58e53.entry.js → p-3f70bfba.entry.js} +1 -1
  477. package/dist/ionic/{p-a43fbe0a.system.entry.js → p-43505ff8.system.entry.js} +1 -1
  478. package/dist/ionic/{p-f012e8f2.system.entry.js → p-4429fc97.system.entry.js} +1 -1
  479. package/dist/ionic/{p-2c560619.system.entry.js → p-4511ba0e.system.entry.js} +1 -1
  480. package/dist/ionic/p-46111310.js +4 -0
  481. package/dist/ionic/p-46f407f0.system.js +4 -0
  482. package/dist/ionic/p-49b6fee0.system.entry.js +4 -0
  483. package/dist/ionic/{p-eb546888.entry.js → p-4a615fea.entry.js} +1 -1
  484. package/dist/ionic/{p-f3e8c505.system.js → p-4dd82d9d.system.js} +1 -1
  485. package/dist/ionic/{p-696db6f4.system.js → p-5033128d.system.js} +2 -2
  486. package/dist/ionic/{p-0afaf65b.system.entry.js → p-510578f3.system.entry.js} +1 -1
  487. package/dist/ionic/{p-7162350a.system.entry.js → p-51b68ec9.system.entry.js} +1 -1
  488. package/dist/ionic/{p-42d9f81e.entry.js → p-51ff648c.entry.js} +1 -1
  489. package/dist/ionic/p-546433d2.js +4 -0
  490. package/dist/ionic/{p-3a572692.js → p-54f76ced.js} +1 -1
  491. package/dist/ionic/{p-66e50777.entry.js → p-56c3b69c.entry.js} +1 -1
  492. package/dist/ionic/p-58ea73f7.system.entry.js +4 -0
  493. package/dist/ionic/p-596e0cf8.system.entry.js +4 -0
  494. package/dist/ionic/p-5ae49f12.entry.js +4 -0
  495. package/dist/ionic/{p-ba9120fe.system.entry.js → p-5b1273f4.system.entry.js} +2 -2
  496. package/dist/ionic/p-5d3f6707.entry.js +4 -0
  497. package/dist/ionic/{p-e5e492d8.entry.js → p-5da04d11.entry.js} +1 -1
  498. package/dist/ionic/p-5e7c32e8.system.entry.js +4 -0
  499. package/dist/ionic/p-65d26d94.system.entry.js +4 -0
  500. package/dist/ionic/{p-cada6331.entry.js → p-6744e460.entry.js} +1 -1
  501. package/dist/ionic/{p-d09c9468.system.entry.js → p-68a1e274.system.entry.js} +1 -1
  502. package/dist/ionic/{p-031c5621.js → p-6994c97a.js} +1 -1
  503. package/dist/ionic/p-69bc14fd.entry.js +4 -0
  504. package/dist/ionic/p-6a7eac5a.js +4 -0
  505. package/dist/ionic/p-6f4db5ce.system.entry.js +4 -0
  506. package/dist/ionic/{p-30dfa360.system.js → p-71215c1d.system.js} +1 -1
  507. package/dist/ionic/{p-063c093d.system.entry.js → p-71688099.system.entry.js} +1 -1
  508. package/dist/ionic/{p-d9dfdbb5.system.entry.js → p-716ab5f8.system.entry.js} +1 -1
  509. package/dist/ionic/p-72812e99.js +4 -0
  510. package/dist/ionic/p-74a9cafe.system.js +5 -0
  511. package/dist/ionic/{p-b996756b.entry.js → p-75280815.entry.js} +1 -1
  512. package/dist/ionic/{p-eee87ebb.js → p-75cddcc9.js} +1 -1
  513. package/dist/ionic/{p-5f9abba8.system.entry.js → p-76907c2f.system.entry.js} +1 -1
  514. package/dist/ionic/p-7d9eefb3.system.js +4 -0
  515. package/dist/ionic/p-7df2c495.entry.js +4 -0
  516. package/dist/ionic/p-7fc505bf.entry.js +4 -0
  517. package/dist/ionic/p-83321ee8.entry.js +4 -0
  518. package/dist/ionic/p-8635f5e6.system.js +4 -0
  519. package/dist/ionic/{p-da5bbd4f.entry.js → p-88cff52d.entry.js} +1 -1
  520. package/dist/ionic/{p-19243ae6.entry.js → p-896111fa.entry.js} +1 -1
  521. package/dist/ionic/p-89b61afc.js +4 -0
  522. package/dist/ionic/{p-824d44c5.system.entry.js → p-8bd567ba.system.entry.js} +1 -1
  523. package/dist/ionic/{p-1acaf641.entry.js → p-8e9ac22d.entry.js} +1 -1
  524. package/dist/ionic/p-9146695e.system.js +4 -0
  525. package/dist/ionic/{p-314ae72a.js → p-96cc4814.js} +1 -1
  526. package/dist/ionic/{p-65374504.entry.js → p-99daf8b7.entry.js} +1 -1
  527. package/dist/ionic/p-9ad82dba.js +5 -0
  528. package/dist/ionic/{p-af9256a0.system.js → p-9d7fc908.system.js} +1 -1
  529. package/dist/ionic/{p-ce36d285.system.js → p-9ea607bd.system.js} +1 -1
  530. package/dist/ionic/p-a15ddedb.system.js +4 -0
  531. package/dist/ionic/{p-f15f8140.system.entry.js → p-a1b4e619.system.entry.js} +1 -1
  532. package/dist/ionic/{p-45a2b1ee.system.entry.js → p-a1f9f629.system.entry.js} +1 -1
  533. package/dist/ionic/{p-7c7e495d.system.js → p-a7ba2dcc.system.js} +1 -1
  534. package/dist/ionic/p-a88fdfac.entry.js +4 -0
  535. package/dist/ionic/{p-01171ead.system.js → p-a8f02173.system.js} +1 -1
  536. package/dist/ionic/p-a93873de.system.js +4 -0
  537. package/dist/ionic/{p-c834c535.system.entry.js → p-aa110ca0.system.entry.js} +1 -1
  538. package/dist/ionic/{p-50d19fc7.system.entry.js → p-aa4f2703.system.entry.js} +1 -1
  539. package/dist/ionic/{p-9c970454.entry.js → p-ab85debb.entry.js} +1 -1
  540. package/dist/ionic/{p-a37d4fe9.system.entry.js → p-ac4e2a74.system.entry.js} +1 -1
  541. package/dist/ionic/p-ac9f44a8.system.entry.js +4 -0
  542. package/dist/ionic/p-b51e4004.js +4 -0
  543. package/dist/ionic/{p-c8f7f923.entry.js → p-b689b8d4.entry.js} +1 -1
  544. package/dist/ionic/p-b7af48c0.js +4 -0
  545. package/dist/ionic/p-bb835b4d.system.entry.js +4 -0
  546. package/dist/ionic/{p-d3c1c23f.entry.js → p-c04d5a75.entry.js} +1 -1
  547. package/dist/ionic/{p-acd64713.system.entry.js → p-c198e1e1.system.entry.js} +1 -1
  548. package/dist/ionic/{p-c4390f10.system.entry.js → p-c1d1d004.system.entry.js} +1 -1
  549. package/dist/ionic/{p-239906f1.js → p-c222f76a.js} +1 -1
  550. package/dist/ionic/{p-03f3ebd2.entry.js → p-c41af68a.entry.js} +1 -1
  551. package/dist/ionic/p-c7e16491.js +4 -0
  552. package/dist/ionic/p-c80d05c9.js +4 -0
  553. package/dist/ionic/{p-0b175848.entry.js → p-c8510ca2.entry.js} +1 -1
  554. package/dist/ionic/{p-2070f8d8.entry.js → p-c8f2b769.entry.js} +1 -1
  555. package/dist/ionic/{p-8c0b08db.entry.js → p-c99ccdc9.entry.js} +1 -1
  556. package/dist/ionic/{p-15e2ff5f.system.entry.js → p-c9c39c98.system.entry.js} +1 -1
  557. package/dist/ionic/{p-070cf7c3.entry.js → p-cae889f9.entry.js} +1 -1
  558. package/dist/ionic/{p-9e3177a5.system.js → p-d2544865.system.js} +1 -1
  559. package/dist/ionic/{p-219c17cf.system.entry.js → p-d5f48185.system.entry.js} +1 -1
  560. package/dist/ionic/{p-4997d7dc.system.js → p-d79542bd.system.js} +1 -1
  561. package/dist/ionic/p-d8067ea4.system.entry.js +4 -0
  562. package/dist/ionic/p-d8f66669.entry.js +4 -0
  563. package/dist/ionic/{p-48fef2f1.entry.js → p-d98c0112.entry.js} +1 -1
  564. package/dist/ionic/p-da2b833b.js +4 -0
  565. package/dist/ionic/p-dc1372e0.entry.js +4 -0
  566. package/dist/ionic/{p-4d6ec139.entry.js → p-df48edd6.entry.js} +1 -1
  567. package/dist/ionic/{p-de4c700f.entry.js → p-df6fa126.entry.js} +1 -1
  568. package/dist/ionic/{p-66596659.entry.js → p-e8a0e731.entry.js} +1 -1
  569. package/dist/ionic/{p-513abaf6.system.entry.js → p-ea2c16b5.system.entry.js} +2 -2
  570. package/dist/ionic/p-ea4be6ac.system.js +4 -0
  571. package/dist/ionic/{p-b0850af6.system.entry.js → p-eb3da535.system.entry.js} +1 -1
  572. package/dist/ionic/{p-07a0190a.system.entry.js → p-ec2d3928.system.entry.js} +1 -1
  573. package/dist/ionic/p-f0392d49.entry.js +4 -0
  574. package/dist/ionic/{p-144ae947.js → p-f4cb521c.js} +1 -1
  575. package/dist/ionic/{p-a7f788ec.entry.js → p-f818b01a.entry.js} +1 -1
  576. package/dist/ionic/p-f94cbfe9.js +4 -0
  577. package/dist/ionic/{p-739f8b95.system.entry.js → p-fab4ecad.system.entry.js} +1 -1
  578. package/dist/ionic/p-fb02eeec.system.entry.js +4 -0
  579. package/dist/ionic/{p-237b1791.system.entry.js → p-fb97326f.system.entry.js} +1 -1
  580. package/dist/ionic/{p-e222fdd1.entry.js → p-fbd30ec7.entry.js} +1 -1
  581. package/dist/ionic/{p-de39f314.entry.js → p-fda4872f.entry.js} +1 -1
  582. package/dist/ionic/{p-25648922.system.entry.js → p-ff2323ba.system.entry.js} +1 -1
  583. package/dist/types/components/button/button.d.ts +5 -0
  584. package/dist/types/components/datetime/datetime.d.ts +1 -0
  585. package/dist/types/components/input/input.d.ts +7 -6
  586. package/dist/types/components/input-password-toggle/input-password-toggle.d.ts +37 -0
  587. package/dist/types/components/modal/animations/sheet.d.ts +4 -4
  588. package/dist/types/components/refresher/refresher.utils.d.ts +2 -2
  589. package/dist/types/components/searchbar/searchbar.d.ts +0 -14
  590. package/dist/types/components/textarea/textarea.d.ts +1 -6
  591. package/dist/types/components/toggle/toggle.d.ts +1 -1
  592. package/dist/types/components.d.ts +49 -5
  593. package/dist/types/utils/animation/animation-utils.d.ts +0 -12
  594. package/dist/types/utils/focus-trap.d.ts +2 -2
  595. package/dist/types/utils/helpers.d.ts +0 -18
  596. package/dist/types/utils/overlays.d.ts +2 -2
  597. package/dist/types/utils/test/playwright/generator.d.ts +3 -3
  598. package/hydrate/index.js +335 -535
  599. package/package.json +7 -2
  600. package/css/themes/dark.always.css.map +0 -1
  601. package/css/themes/dark.class.css.map +0 -1
  602. package/css/themes/dark.system.css.map +0 -1
  603. package/css/themes/high-contrast-dark.always.css.map +0 -1
  604. package/css/themes/high-contrast-dark.class.css.map +0 -1
  605. package/css/themes/high-contrast-dark.system.css.map +0 -1
  606. package/css/themes/high-contrast.always.css.map +0 -1
  607. package/css/themes/high-contrast.class.css.map +0 -1
  608. package/css/themes/high-contrast.system.css.map +0 -1
  609. package/dist/collection/utils/test/aria.spec.js +0 -80
  610. package/dist/esm-es5/animation-9a23ed8d.js +0 -4
  611. package/dist/esm-es5/app-globals-80842d68.js +0 -4
  612. package/dist/esm-es5/framework-delegate-3fd96df8.js +0 -4
  613. package/dist/esm-es5/haptic-554688a5.js +0 -4
  614. package/dist/esm-es5/helpers-f51cf76f.js +0 -4
  615. package/dist/esm-es5/index-1262064c.js +0 -4
  616. package/dist/esm-es5/index-5d6a0317.js +0 -5
  617. package/dist/esm-es5/index-9d7e5d3e.js +0 -4
  618. package/dist/esm-es5/input-shims-2a4ad5a1.js +0 -4
  619. package/dist/esm-es5/md.transition-76e0020b.js +0 -4
  620. package/dist/ionic/p-04f9ce05.system.js +0 -4
  621. package/dist/ionic/p-06e951a9.entry.js +0 -4
  622. package/dist/ionic/p-1d1394da.system.entry.js +0 -4
  623. package/dist/ionic/p-1e5c0c49.js +0 -4
  624. package/dist/ionic/p-29ecf879.entry.js +0 -4
  625. package/dist/ionic/p-2f53f47a.entry.js +0 -4
  626. package/dist/ionic/p-33e39575.system.js +0 -4
  627. package/dist/ionic/p-355736ea.js +0 -4
  628. package/dist/ionic/p-373e757d.entry.js +0 -4
  629. package/dist/ionic/p-39483fc9.js +0 -4
  630. package/dist/ionic/p-39860681.entry.js +0 -4
  631. package/dist/ionic/p-42f189f4.js +0 -4
  632. package/dist/ionic/p-493bce1f.entry.js +0 -4
  633. package/dist/ionic/p-49a205d0.system.js +0 -4
  634. package/dist/ionic/p-4d7230bd.system.entry.js +0 -4
  635. package/dist/ionic/p-517b76cb.entry.js +0 -4
  636. package/dist/ionic/p-51b1a6be.js +0 -4
  637. package/dist/ionic/p-59e86adb.js +0 -4
  638. package/dist/ionic/p-6042920d.system.entry.js +0 -4
  639. package/dist/ionic/p-667290b0.system.js +0 -4
  640. package/dist/ionic/p-67dbcd3b.system.js +0 -4
  641. package/dist/ionic/p-69df28fd.entry.js +0 -4
  642. package/dist/ionic/p-6d0e7669.system.entry.js +0 -4
  643. package/dist/ionic/p-6d1f5de9.system.entry.js +0 -4
  644. package/dist/ionic/p-7d4f6f18.js +0 -4
  645. package/dist/ionic/p-831269de.js +0 -4
  646. package/dist/ionic/p-a03c993e.entry.js +0 -4
  647. package/dist/ionic/p-b0d35de4.system.js +0 -4
  648. package/dist/ionic/p-bb78b64e.entry.js +0 -4
  649. package/dist/ionic/p-bbc4f653.entry.js +0 -4
  650. package/dist/ionic/p-c34d1515.js +0 -4
  651. package/dist/ionic/p-c629d22b.system.js +0 -5
  652. package/dist/ionic/p-c8675b7b.system.entry.js +0 -4
  653. package/dist/ionic/p-c962e9ea.entry.js +0 -4
  654. package/dist/ionic/p-c995da88.system.js +0 -4
  655. package/dist/ionic/p-cc19ecba.system.entry.js +0 -4
  656. package/dist/ionic/p-d10bbab7.entry.js +0 -4
  657. package/dist/ionic/p-d268f7e2.system.entry.js +0 -4
  658. package/dist/ionic/p-d4be0d81.system.entry.js +0 -4
  659. package/dist/ionic/p-d5ef3a0a.entry.js +0 -4
  660. package/dist/ionic/p-dad515dc.js +0 -4
  661. package/dist/ionic/p-dfb6de03.system.js +0 -4
  662. package/dist/ionic/p-e01ebeba.system.js +0 -4
  663. package/dist/ionic/p-e9412fe7.system.entry.js +0 -4
  664. package/dist/ionic/p-f5cb9689.js +0 -4
  665. package/dist/ionic/p-f8502e85.js +0 -5
  666. package/dist/ionic/p-fcec3b7a.system.entry.js +0 -4
  667. package/css/{themes → palettes}/dark.always.css +0 -0
  668. package/css/{themes → palettes}/dark.css +0 -0
  669. package/css/{themes → palettes}/dark.css.map +0 -0
  670. package/css/{themes → palettes}/dark.system.css +0 -0
  671. package/css/{themes → palettes}/high-contrast-dark.always.css +1 -1
  672. package/css/{themes → palettes}/high-contrast-dark.css +0 -0
  673. package/css/{themes → palettes}/high-contrast-dark.css.map +0 -0
  674. package/css/{themes → palettes}/high-contrast-dark.system.css +1 -1
  675. package/css/{themes → palettes}/high-contrast.always.css +25 -25
  676. package/css/{themes → palettes}/high-contrast.css +0 -0
  677. package/css/{themes → palettes}/high-contrast.css.map +0 -0
  678. package/css/{themes → palettes}/high-contrast.system.css +25 -25
@@ -13,9 +13,9 @@ export class Note {
13
13
  }
14
14
  render() {
15
15
  const mode = getIonMode(this);
16
- return (h(Host, { key: 'c28c242d5e60e447c4c926041fa62abfbad3f0fd', class: createColorClasses(this.color, {
16
+ return (h(Host, { key: '4064be8c5aceec02a25b8933338596b1720e19d9', class: createColorClasses(this.color, {
17
17
  [mode]: true,
18
- }) }, h("slot", { key: 'e4c8e1d32527ba4a9c6d10d579aaba06cb040042' })));
18
+ }) }, h("slot", { key: '9b4265b01387096a8a6aba34a1d8217733bb6f1f' })));
19
19
  }
20
20
  static get is() { return "ion-note"; }
21
21
  static get encapsulation() { return "shadow"; }
@@ -474,7 +474,7 @@ export class Picker {
474
474
  this.emitInputModeChange();
475
475
  }
476
476
  render() {
477
- return (h(Host, { key: '6d9d2f8427c722ac1e4ad401e3091f86b95af503', onPointerDown: (ev) => this.onPointerDown(ev), onClick: () => this.onClick() }, h("input", { key: 'b885e06c95ad966d477d873154627766ecf5f5f9', "aria-hidden": "true", tabindex: -1, inputmode: "numeric", type: "number", onKeyDown: (ev) => {
477
+ return (h(Host, { key: '16c8d2d72dcbd64e2b2fb77200ead6a2107d24a6', onPointerDown: (ev) => this.onPointerDown(ev), onClick: () => this.onClick() }, h("input", { key: 'f7f4c77bde934813a18f221308277580c45715e3', "aria-hidden": "true", tabindex: -1, inputmode: "numeric", type: "number", onKeyDown: (ev) => {
478
478
  var _a;
479
479
  /**
480
480
  * The "Enter" key represents
@@ -489,7 +489,7 @@ export class Picker {
489
489
  if (ev.key === 'Enter') {
490
490
  (_a = this.inputEl) === null || _a === void 0 ? void 0 : _a.blur();
491
491
  }
492
- }, ref: (el) => (this.inputEl = el), onInput: () => this.onInputChange(), onBlur: () => this.exitInputMode() }), h("div", { key: '91e060f4dd634ebaca072dbe7726a84f6f2c7040', class: "picker-before" }), h("div", { key: '2e06c9db12040c5a7af48c79ce3e1c32ce7a6ae4', class: "picker-after" }), h("div", { key: '791a934f6886ca89b370f71cd5c848ee6dac5b90', class: "picker-highlight", ref: (el) => (this.highlightEl = el) }), h("slot", { key: 'aed4fe303f87b804ce00f2633b0af4905600670a' })));
492
+ }, ref: (el) => (this.inputEl = el), onInput: () => this.onInputChange(), onBlur: () => this.exitInputMode() }), h("div", { key: '0eead52707acfa004c83fe0acfd4f9162b19f09b', class: "picker-before" }), h("div", { key: '5b4b531e3ed4fd35f1380156cf5332a455433a19', class: "picker-after" }), h("div", { key: '2b478202ac99703e4f72b30906915c7058ca9b9f', class: "picker-highlight", ref: (el) => (this.highlightEl = el) }), h("slot", { key: '4a93ca36194ea1d2cec8bef8a0f402c14ee74576' })));
493
493
  }
494
494
  static get is() { return "ion-picker"; }
495
495
  static get encapsulation() { return "shadow"; }
@@ -275,7 +275,11 @@ export class PickerColumn {
275
275
  */
276
276
  const parentEl = (this.parentEl = this.el.closest('ion-picker'));
277
277
  const visibleCallback = (entries) => {
278
- const ev = entries[0];
278
+ /**
279
+ * Browsers will sometimes group multiple IO events into a single callback.
280
+ * As a result, we want to grab the last/most recent event in case there are multiple events.
281
+ */
282
+ const ev = entries[entries.length - 1];
279
283
  if (ev.isIntersecting) {
280
284
  const { activeItem, el } = this;
281
285
  this.isColumnVisible = true;
@@ -379,14 +383,14 @@ export class PickerColumn {
379
383
  render() {
380
384
  const { color, disabled, isActive, numericInput } = this;
381
385
  const mode = getIonMode(this);
382
- return (h(Host, { key: '6658bfcf04d2e16e5a1acdb82c7b99fba27a6e36', class: createColorClasses(color, {
386
+ return (h(Host, { key: '20de89f624d0fdbb4eadf912a6a8a8c1f3c374bc', class: createColorClasses(color, {
383
387
  [mode]: true,
384
388
  ['picker-column-active']: isActive,
385
389
  ['picker-column-numeric-input']: numericInput,
386
390
  ['picker-column-disabled']: disabled,
387
- }) }, h("slot", { key: 'a763810ee7cdb6757a6b769edc7b22d0e5d31300', name: "prefix" }), h("div", { key: 'b782e731803faa9afddbd7ecf117cf13b7fed392', class: "picker-opts", tabindex: disabled ? undefined : 0, ref: (el) => {
391
+ }) }, h("slot", { key: '39bd2171785e21aef935787d8222949a2d29a771', name: "prefix" }), h("div", { key: '97217b758b65913db869f322b8f127f0da3a1c28', class: "picker-opts", tabindex: disabled ? undefined : 0, ref: (el) => {
388
392
  this.scrollEl = el;
389
- } }, h("div", { key: '1ad66da148e1b68654fb239e5b0378b6588952ec', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0"), h("div", { key: '40d9a15a9387fd6505cf2089dc0bd025c1d024ef', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0"), h("div", { key: '6594be21a3dea1668cc90488d0b9b611ca8f65a8', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0"), h("slot", { key: '3e848b150f81d6283e5a04876f9b7cd61ba8079e' }), h("div", { key: 'e1e4ccb1cd80e937aee528f99fa969cf45228db3', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0"), h("div", { key: '1cc415a51d3f525777f2dfcc0ff0fea670307f9e', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0"), h("div", { key: 'aa247ca6aa986648a5b2822a8eb648d246de695c', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0")), h("slot", { key: '712e32d320c95cf293eb71ec395988414a3aea11', name: "suffix" })));
393
+ } }, h("div", { key: '8cfd8f5de1c274f7b2b5b14c7f6f875d475edc5c', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0"), h("div", { key: 'cfbf7e8abe54c4df98addb9a24e82dd803ba95c0', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0"), h("div", { key: '8049923186d8b5ce28da2ce90ad720c244395f9c', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0"), h("slot", { key: '180efa3b7874e2b4269fb150794eaeab9f648f2e' }), h("div", { key: '9161cc3e344b92354276981813e1d55ef9979dea', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0"), h("div", { key: 'ce703fb3ea07d5ea2abf526d64ca85d2beed15f1', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0"), h("div", { key: '6ce6cb5de80ac316a664e9cfcecf1897c8f90e58', class: "picker-item-empty", "aria-hidden": "true" }, "\u00A0")), h("slot", { key: 'ecccfa6bd8f6d2d641109e74d0788081e3f29801', name: "suffix" })));
390
394
  }
391
395
  static get is() { return "ion-picker-column"; }
392
396
  static get encapsulation() { return "shadow"; }
@@ -76,10 +76,10 @@ export class PickerColumnOption {
76
76
  render() {
77
77
  const { color, disabled, ariaLabel } = this;
78
78
  const mode = getIonMode(this);
79
- return (h(Host, { key: '8307a2917395b704ca995c64b5e84b828a8f3946', class: createColorClasses(color, {
79
+ return (h(Host, { key: '9333d9ac8e9990fc840f31e00391177d9cd563b3', class: createColorClasses(color, {
80
80
  [mode]: true,
81
81
  ['option-disabled']: disabled,
82
- }) }, h("button", { key: '2112f812b169e1fa67ab08ccb1d63c8e14e30872', tabindex: "-1", "aria-label": ariaLabel, disabled: disabled, onClick: () => this.onClick() }, h("slot", { key: '571b4724e055765891db30405488ae368f110dc1' }))));
82
+ }) }, h("button", { key: '6ca92bc584587230135982106eab542589fc4c9d', tabindex: "-1", "aria-label": ariaLabel, disabled: disabled, onClick: () => this.onClick() }, h("slot", { key: 'd9a68906017f77143a0691b9bbc59ae2142da6aa' }))));
83
83
  }
84
84
  static get is() { return "ion-picker-column-option"; }
85
85
  static get encapsulation() { return "shadow"; }
@@ -182,11 +182,11 @@ export class Picker {
182
182
  render() {
183
183
  const { htmlAttributes } = this;
184
184
  const mode = getIonMode(this);
185
- return (h(Host, Object.assign({ key: '4144eef6498c66a82f3873ae5c8e55d2ee1d381e', "aria-modal": "true", tabindex: "-1" }, htmlAttributes, { style: {
185
+ return (h(Host, Object.assign({ key: '91d3d127c46d125a2a86222e3002d804ebd8bc84', "aria-modal": "true", tabindex: "-1" }, htmlAttributes, { style: {
186
186
  zIndex: `${20000 + this.overlayIndex}`,
187
187
  }, class: Object.assign({ [mode]: true,
188
188
  // Used internally for styling
189
- [`picker-${mode}`]: true, 'overlay-hidden': true }, getClassMap(this.cssClass)), onIonBackdropTap: this.onBackdropTap, onIonPickerWillDismiss: this.dispatchCancelHandler }), h("ion-backdrop", { key: '4344a38bea27537a0f907d929ae3e88d16e751a5', visible: this.showBackdrop, tappable: this.backdropDismiss }), h("div", { key: 'a9634e85c6feb73e298407dadb02c1260e2f2f9b', tabindex: "0" }), h("div", { key: '871bb60dbb57c7b0c357491d84da97a2b3900071', class: "picker-wrapper ion-overlay-wrapper", role: "dialog" }, h("div", { key: '92e0d584c0d5e0c365af7d48781181248718e17e', 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: '76c9024a822a96a9f9cd0e121629e5c02ba757e3', class: "picker-columns" }, h("div", { key: 'd1326bb793aedff0a5fc16eb2ddd5d5152210838', class: "picker-above-highlight" }), this.presented && this.columns.map((c) => h("ion-picker-legacy-column", { col: c })), h("div", { key: '1a9273ff23a5fc42003929dbdc267a29587cc5c6', class: "picker-below-highlight" }))), h("div", { key: 'cbc1280639e26e1b50e8dc9b6e640b357eb22c33', tabindex: "0" })));
189
+ [`picker-${mode}`]: true, 'overlay-hidden': true }, getClassMap(this.cssClass)), onIonBackdropTap: this.onBackdropTap, onIonPickerWillDismiss: this.dispatchCancelHandler }), h("ion-backdrop", { key: '63140c43f7a2e3000076adec0406197cb569f985', visible: this.showBackdrop, tappable: this.backdropDismiss }), h("div", { key: '3e86ec5e61adf40983a1d33ef24f66f4f75307e8', tabindex: "0" }), h("div", { key: '3c3844f369da33e35c9a498d88d1b7e4d686b8ce', class: "picker-wrapper ion-overlay-wrapper", role: "dialog" }, h("div", { key: 'e03200231976723409505b0c4070e7f596815e50', 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: 'd59de79e8c364376bc16d2edae3672b21443f3fe', class: "picker-columns" }, h("div", { key: 'e79cb88c5397047bc8c7e71efb4f1a338773e744', class: "picker-above-highlight" }), this.presented && this.columns.map((c) => h("ion-picker-legacy-column", { col: c })), h("div", { key: '776de64da09485ad1dbf78d4d402e297b94348a6', class: "picker-below-highlight" }))), h("div", { key: 'f0aa77e3b467c3fb4950389d27c13769dc913b14', tabindex: "0" })));
190
190
  }
191
191
  static get is() { return "ion-picker-legacy"; }
192
192
  static get encapsulation() { return "scoped"; }
@@ -336,9 +336,9 @@ export class PickerColumnCmp {
336
336
  render() {
337
337
  const col = this.col;
338
338
  const mode = getIonMode(this);
339
- return (h(Host, { key: 'b7342219fdfcf106d905e3badefe021fd46ad12b', class: Object.assign({ [mode]: true, 'picker-col': true, 'picker-opts-left': this.col.align === 'left', 'picker-opts-right': this.col.align === 'right' }, getClassMap(col.cssClass)), style: {
339
+ return (h(Host, { key: '90b9d07917c0643cf8a622f090abefcd2846ac96', class: Object.assign({ [mode]: true, 'picker-col': true, 'picker-opts-left': this.col.align === 'left', 'picker-opts-right': this.col.align === 'right' }, getClassMap(col.cssClass)), style: {
340
340
  'max-width': this.col.columnWidth,
341
- } }, col.prefix && (h("div", { class: "picker-prefix", style: { width: col.prefixWidth } }, col.prefix)), h("div", { key: 'c87f5f3f1efca050c20bcd697aae905f0f370afc', class: "picker-opts", style: { maxWidth: col.optionsWidth }, ref: (el) => (this.optsEl = el) }, col.options.map((o, index) => (h("button", { "aria-label": o.ariaLabel, class: { 'picker-opt': true, 'picker-opt-disabled': !!o.disabled }, "opt-index": index }, o.text)))), col.suffix && (h("div", { class: "picker-suffix", style: { width: col.suffixWidth } }, col.suffix))));
341
+ } }, col.prefix && (h("div", { class: "picker-prefix", style: { width: col.prefixWidth } }, col.prefix)), h("div", { key: '4adca834de9295a18bdb355ebbfa49813f0f93f8', class: "picker-opts", style: { maxWidth: col.optionsWidth }, ref: (el) => (this.optsEl = el) }, col.options.map((o, index) => (h("button", { "aria-label": o.ariaLabel, class: { 'picker-opt': true, 'picker-opt-disabled': !!o.disabled }, "opt-index": index }, o.text)))), col.suffix && (h("div", { class: "picker-suffix", style: { width: col.suffixWidth } }, col.suffix))));
342
342
  }
343
343
  static get is() { return "ion-picker-legacy-column"; }
344
344
  static get originalStyleUrls() {
@@ -336,9 +336,9 @@ export class Popover {
336
336
  const { onLifecycle, parentPopover, dismissOnSelect, side, arrow, htmlAttributes } = this;
337
337
  const desktop = isPlatform('desktop');
338
338
  const enableArrow = arrow && !parentPopover;
339
- return (h(Host, Object.assign({ key: 'fb58b5b3124ea4b0ced6d73558844121245a0951', "aria-modal": "true", "no-router": true, tabindex: "-1" }, htmlAttributes, { style: {
339
+ return (h(Host, Object.assign({ key: '8e3ff2681dbd4d2a659633ba2d5419abb2646858', "aria-modal": "true", "no-router": true, tabindex: "-1" }, htmlAttributes, { style: {
340
340
  zIndex: `${20000 + this.overlayIndex}`,
341
- }, class: Object.assign(Object.assign({}, getClassMap(this.cssClass)), { [mode]: true, 'popover-translucent': this.translucent, 'overlay-hidden': true, 'popover-desktop': desktop, [`popover-side-${side}`]: true, 'popover-nested': !!parentPopover }), onIonPopoverDidPresent: onLifecycle, onIonPopoverWillPresent: onLifecycle, onIonPopoverWillDismiss: onLifecycle, onIonPopoverDidDismiss: onLifecycle, onIonBackdropTap: this.onBackdropTap }), !parentPopover && h("ion-backdrop", { tappable: this.backdropDismiss, visible: this.showBackdrop, part: "backdrop" }), h("div", { key: 'a7b6a76eeeb840b806434cf5c9beaaf43a975867', class: "popover-wrapper ion-overlay-wrapper", onClick: dismissOnSelect ? () => this.dismiss() : undefined }, enableArrow && h("div", { class: "popover-arrow", part: "arrow" }), h("div", { key: '9c59d1a567f66fb939aa194e452b46fd1dbef27c', class: "popover-content", part: "content" }, h("slot", { key: 'a8e260ace3d487c9e9c861725488a4bef7aeeb02' })))));
341
+ }, class: Object.assign(Object.assign({}, getClassMap(this.cssClass)), { [mode]: true, 'popover-translucent': this.translucent, 'overlay-hidden': true, 'popover-desktop': desktop, [`popover-side-${side}`]: true, 'popover-nested': !!parentPopover }), onIonPopoverDidPresent: onLifecycle, onIonPopoverWillPresent: onLifecycle, onIonPopoverWillDismiss: onLifecycle, onIonPopoverDidDismiss: onLifecycle, onIonBackdropTap: this.onBackdropTap }), !parentPopover && h("ion-backdrop", { tappable: this.backdropDismiss, visible: this.showBackdrop, part: "backdrop" }), h("div", { key: '9bdb7b263b7ecaee62fd091dbc55ea3b8cf02b45', class: "popover-wrapper ion-overlay-wrapper", onClick: dismissOnSelect ? () => this.dismiss() : undefined }, enableArrow && h("div", { class: "popover-arrow", part: "arrow" }), h("div", { key: '03bf042a104e8d019bd815ce0cc63a1b503cd644', class: "popover-content", part: "content" }, h("slot", { key: 'dd9e35e0af13da7b98d094cc1d5b1161afaf267b' })))));
342
342
  }
343
343
  static get is() { return "ion-popover"; }
344
344
  static get encapsulation() { return "shadow"; }
@@ -28,7 +28,7 @@ export class ProgressBar {
28
28
  const mode = getIonMode(this);
29
29
  // If the progress is displayed as a solid bar.
30
30
  const progressSolid = buffer === 1;
31
- return (h(Host, { key: 'b38b62bfe013dfe5f847a6faf6934b02ce32c113', role: "progressbar", "aria-valuenow": type === 'determinate' ? value : null, "aria-valuemin": "0", "aria-valuemax": "1", class: createColorClasses(color, {
31
+ return (h(Host, { key: '63b306c91da12d1fa18d6f6c4726871ef727c9f3', role: "progressbar", "aria-valuenow": type === 'determinate' ? value : null, "aria-valuemin": "0", "aria-valuemax": "1", class: createColorClasses(color, {
32
32
  [mode]: true,
33
33
  [`progress-bar-${type}`]: true,
34
34
  'progress-paused': paused,
@@ -4,7 +4,7 @@
4
4
  import AxeBuilder from "@axe-core/playwright";
5
5
  import { expect } from "@playwright/test";
6
6
  import { configs, test } from "../../../../utils/test/playwright/index";
7
- configs({ directions: ['ltr'], themes: ['light', 'dark'] }).forEach(({ title, config }) => {
7
+ configs({ directions: ['ltr'], palettes: ['light', 'dark'] }).forEach(({ title, config }) => {
8
8
  test.describe(title('progress-bar: a11y'), () => {
9
9
  test('should not have accessibility violations', async ({ page }) => {
10
10
  /**
@@ -107,7 +107,7 @@ export class Radio {
107
107
  const { checked, disabled, color, el, justify, labelPlacement, hasLabel, buttonTabindex, alignment } = this;
108
108
  const mode = getIonMode(this);
109
109
  const inItem = hostContext('ion-item', el);
110
- return (h(Host, { key: 'dace1b39a24a928486fa73031277db04c0f437c0', onFocus: this.onFocus, onBlur: this.onBlur, onClick: this.onClick, class: createColorClasses(color, {
110
+ return (h(Host, { key: '46bb0202f75b6cc81df10de71fbe971dc4dcaa68', onFocus: this.onFocus, onBlur: this.onBlur, onClick: this.onClick, class: createColorClasses(color, {
111
111
  [mode]: true,
112
112
  'in-item': inItem,
113
113
  'radio-checked': checked,
@@ -118,10 +118,10 @@ export class Radio {
118
118
  // Focus and active styling should not apply when the radio is in an item
119
119
  'ion-activatable': !inItem,
120
120
  'ion-focusable': !inItem,
121
- }), role: "radio", "aria-checked": checked ? 'true' : 'false', "aria-disabled": disabled ? 'true' : null, tabindex: buttonTabindex }, h("label", { key: '4a9ab56b16003ea5fe2a737adf2bc1f4be02d2c7', class: "radio-wrapper" }, h("div", { key: '4545fc8a73dc428c20f521de02e0d65b4d365dc1', class: {
121
+ }), role: "radio", "aria-checked": checked ? 'true' : 'false', "aria-disabled": disabled ? 'true' : null, tabindex: buttonTabindex }, h("label", { key: '55061e8cc857752d963c9e4a65f46727f5c2cd9d', class: "radio-wrapper" }, h("div", { key: '589fd41fccd0e6d007e7bc502067f3f2447e4b80', class: {
122
122
  'label-text-wrapper': true,
123
123
  'label-text-wrapper-hidden': !hasLabel,
124
- }, part: "label" }, h("slot", { key: '6c0ab29c0a724314c0591915a72ec004d66532e3' })), h("div", { key: '03ce5e87635fdbe5c0b3455e7dc2cbcb0ce189b6', class: "native-wrapper" }, this.renderRadioControl()))));
124
+ }, part: "label" }, h("slot", { key: '0076f1f3b64c1a0cf2bc511424956a63d6cf2db9' })), h("div", { key: '1505a84e6dc8715f8fcb19ce94fab79e624a0622', class: "native-wrapper" }, this.renderRadioControl()))));
125
125
  }
126
126
  static get is() { return "ion-radio"; }
127
127
  static get encapsulation() { return "shadow"; }
@@ -4,7 +4,7 @@
4
4
  import AxeBuilder from "@axe-core/playwright";
5
5
  import { expect } from "@playwright/test";
6
6
  import { configs, test } from "../../../../utils/test/playwright/index";
7
- configs({ directions: ['ltr'], themes: ['light', 'dark'] }).forEach(({ title, config }) => {
7
+ configs({ directions: ['ltr'], palettes: ['light', 'dark'] }).forEach(({ title, config }) => {
8
8
  test.describe(title('radio: a11y'), () => {
9
9
  test('default layout should not have accessibility violations', async ({ page }) => {
10
10
  await page.setContent(`
@@ -153,7 +153,7 @@ export class RadioGroup {
153
153
  const { label, labelId, el, name, value } = this;
154
154
  const mode = getIonMode(this);
155
155
  renderHiddenInput(true, el, name, value, false);
156
- return h(Host, { key: 'db2e1c69be545dcb95fa7c7bd0c36a1fd3423294', role: "radiogroup", "aria-labelledby": label ? labelId : null, onClick: this.onClick, class: mode });
156
+ return h(Host, { key: '3d43aa6696c5293b49fc44cf91e3e41c4f4d12df', role: "radiogroup", "aria-labelledby": label ? labelId : null, onClick: this.onClick, class: mode });
157
157
  }
158
158
  static get is() { return "ion-radio-group"; }
159
159
  static get properties() {
@@ -3,7 +3,7 @@
3
3
  */
4
4
  import { Host, h } from "@stencil/core";
5
5
  import { findClosestIonContent, disableContentScrollY, resetContentScrollY } from "../../utils/content/index";
6
- import { inheritAriaAttributes, clamp, debounceEvent, getAriaLabel, renderHiddenInput } from "../../utils/helpers";
6
+ import { inheritAriaAttributes, clamp, debounceEvent, renderHiddenInput } from "../../utils/helpers";
7
7
  import { printIonWarning } from "../../utils/logging/index";
8
8
  import { isRTL } from "../../utils/rtl/index";
9
9
  import { createColorClasses, hostContext } from "../../utils/theme";
@@ -421,16 +421,7 @@ export class Range {
421
421
  }
422
422
  renderRangeSlider() {
423
423
  var _a;
424
- const { min, max, step, el, handleKeyboard, pressedKnob, disabled, pin, ratioLower, ratioUpper, inheritedAttributes, rangeId, pinFormatter, } = this;
425
- /**
426
- * Look for external label, ion-label, or aria-labelledby.
427
- * If none, see if user placed an aria-label on the host
428
- * and use that instead.
429
- */
430
- let { labelText } = getAriaLabel(el, rangeId);
431
- if (labelText === undefined || labelText === null) {
432
- labelText = inheritedAttributes['aria-label'];
433
- }
424
+ const { min, max, step, handleKeyboard, pressedKnob, disabled, pin, ratioLower, ratioUpper, pinFormatter, inheritedAttributes, } = this;
434
425
  let barStart = `${ratioLower * 100}%`;
435
426
  let barEnd = `${100 - ratioUpper * 100}%`;
436
427
  const rtl = isRTL(this.el);
@@ -490,10 +481,6 @@ export class Range {
490
481
  ticks.push(tick);
491
482
  }
492
483
  }
493
- let labelledBy;
494
- if (this.hasLabel) {
495
- labelledBy = 'range-label';
496
- }
497
484
  return (h("div", { class: "range-slider", ref: (rangeEl) => (this.rangeSlider = rangeEl),
498
485
  /**
499
486
  * Since the gesture has a threshold, the value
@@ -541,8 +528,7 @@ export class Range {
541
528
  handleKeyboard,
542
529
  min,
543
530
  max,
544
- labelText,
545
- labelledBy,
531
+ inheritedAttributes,
546
532
  }), this.dualKnobs &&
547
533
  renderKnob(rtl, {
548
534
  knob: 'B',
@@ -555,8 +541,7 @@ export class Range {
555
541
  handleKeyboard,
556
542
  min,
557
543
  max,
558
- labelText,
559
- labelledBy,
544
+ inheritedAttributes,
560
545
  })));
561
546
  }
562
547
  render() {
@@ -576,7 +561,7 @@ export class Range {
576
561
  const needsEndAdjustment = inItem && !hasEndContent;
577
562
  const mode = getIonMode(this);
578
563
  renderHiddenInput(true, el, this.name, JSON.stringify(this.getValue()), disabled);
579
- return (h(Host, { key: '576015afd256abb6faa88630dc482b75333c69e0', onFocusin: this.onFocus, onFocusout: this.onBlur, id: rangeId, class: createColorClasses(this.color, {
564
+ return (h(Host, { key: '201677b1146738b96d74081e59d3e13a8472326e', onFocusin: this.onFocus, onFocusout: this.onBlur, id: rangeId, class: createColorClasses(this.color, {
580
565
  [mode]: true,
581
566
  'in-item': inItem,
582
567
  'range-disabled': disabled,
@@ -585,10 +570,10 @@ export class Range {
585
570
  [`range-label-placement-${labelPlacement}`]: true,
586
571
  'range-item-start-adjustment': needsStartAdjustment,
587
572
  'range-item-end-adjustment': needsEndAdjustment,
588
- }) }, h("label", { key: '45619166eaf5015154ca24aeac8d088fed9606ec', class: "range-wrapper", id: "range-label" }, h("div", { key: 'e5ce095b0b1545dd9d39a04bc0d81fa643ec3739', class: {
573
+ }) }, h("label", { key: '055dda4f2673432e639b7efdbb01b2794c91e705', class: "range-wrapper", id: "range-label" }, h("div", { key: '3efe1eda1f68810a739a42b7655f2dd71beccf1e', class: {
589
574
  'label-text-wrapper': true,
590
575
  'label-text-wrapper-hidden': !hasLabel,
591
- }, part: "label" }, label !== undefined ? h("div", { class: "label-text" }, label) : h("slot", { name: "label" })), h("div", { key: '9bff70bac89c8439b3a8933c2d4dbf0851a49165', class: "native-wrapper" }, h("slot", { key: '5c62813869cad97aa70a1c766c5df7a8fd279258', name: "start" }), this.renderRangeSlider(), h("slot", { key: '888d5665c12debcda85af5024842f5468b086c70', name: "end" })))));
576
+ }, part: "label" }, label !== undefined ? h("div", { class: "label-text" }, label) : h("slot", { name: "label" })), h("div", { key: '31458b02c2973f4ecf4a10de4c0ae1c4befda37a', class: "native-wrapper" }, h("slot", { key: '21c78b192f312396bd86bf52a0888312ffefea8a', name: "start" }), this.renderRangeSlider(), h("slot", { key: '843193879728ccfec62b4becb1b57d64b6d96804', name: "end" })))));
592
577
  }
593
578
  static get is() { return "ion-range"; }
594
579
  static get encapsulation() { return "shadow"; }
@@ -1055,13 +1040,15 @@ export class Range {
1055
1040
  }];
1056
1041
  }
1057
1042
  }
1058
- const renderKnob = (rtl, { knob, value, ratio, min, max, disabled, pressed, pin, handleKeyboard, labelText, labelledBy, pinFormatter, }) => {
1043
+ const renderKnob = (rtl, { knob, value, ratio, min, max, disabled, pressed, pin, handleKeyboard, pinFormatter, inheritedAttributes }) => {
1059
1044
  const start = rtl ? 'right' : 'left';
1060
1045
  const knobStyle = () => {
1061
1046
  const style = {};
1062
1047
  style[start] = `${ratio * 100}%`;
1063
1048
  return style;
1064
1049
  };
1050
+ // The aria label should be preferred over visible text if both are specified
1051
+ const ariaLabel = inheritedAttributes['aria-label'];
1065
1052
  return (h("div", { onKeyDown: (ev) => {
1066
1053
  const key = ev.key;
1067
1054
  if (key === 'ArrowLeft' || key === 'ArrowDown') {
@@ -1083,7 +1070,7 @@ const renderKnob = (rtl, { knob, value, ratio, min, max, disabled, pressed, pin,
1083
1070
  'range-knob-max': value === max,
1084
1071
  'ion-activatable': true,
1085
1072
  'ion-focusable': true,
1086
- }, style: knobStyle(), role: "slider", tabindex: disabled ? -1 : 0, "aria-label": labelledBy === undefined ? labelText : null, "aria-labelledby": labelledBy !== undefined ? labelledBy : null, "aria-valuemin": min, "aria-valuemax": max, "aria-disabled": disabled ? 'true' : null, "aria-valuenow": value }, pin && (h("div", { class: "range-pin", role: "presentation", part: "pin" }, pinFormatter(value))), h("div", { class: "range-knob", role: "presentation", part: "knob" })));
1073
+ }, style: knobStyle(), role: "slider", tabindex: disabled ? -1 : 0, "aria-label": ariaLabel !== undefined ? ariaLabel : null, "aria-labelledby": ariaLabel === undefined ? 'range-label' : null, "aria-valuemin": min, "aria-valuemax": max, "aria-disabled": disabled ? 'true' : null, "aria-valuenow": value }, pin && (h("div", { class: "range-pin", role: "presentation", part: "pin" }, pinFormatter(value))), h("div", { class: "range-knob", role: "presentation", part: "knob" })));
1087
1074
  };
1088
1075
  const ratioToValue = (ratio, min, max, step) => {
1089
1076
  let value = (max - min) * ratio;
@@ -4,7 +4,7 @@
4
4
  import AxeBuilder from "@axe-core/playwright";
5
5
  import { expect } from "@playwright/test";
6
6
  import { configs, test } from "../../../../utils/test/playwright/index";
7
- configs({ directions: ['ltr'], themes: ['light', 'dark'] }).forEach(({ title, config }) => {
7
+ configs({ directions: ['ltr'], palettes: ['light', 'dark'] }).forEach(({ title, config }) => {
8
8
  test.describe(title('range: a11y'), () => {
9
9
  test('should not have accessibility violations', async ({ page }) => {
10
10
  await page.setContent(`
@@ -20,4 +20,28 @@ describe('range: label', () => {
20
20
  expect(propEl).not.toBeNull();
21
21
  expect(slotEl).toBeNull();
22
22
  });
23
+ it('should prefer aria label if both attribute and visible text provided', async () => {
24
+ const page = await newSpecPage({
25
+ components: [Range],
26
+ html: `
27
+ <ion-range aria-label="Aria Label Text" label="Label Prop Text"></ion-range>
28
+ `,
29
+ });
30
+ const range = page.body.querySelector('ion-range');
31
+ const nativeSlider = range.shadowRoot.querySelector('.range-knob-handle');
32
+ expect(nativeSlider.getAttribute('aria-label')).toBe('Aria Label Text');
33
+ expect(nativeSlider.getAttribute('aria-labelledby')).toBe(null);
34
+ });
35
+ it('should prefer visible label if only visible text provided', async () => {
36
+ const page = await newSpecPage({
37
+ components: [Range],
38
+ html: `
39
+ <ion-range label="Label Prop Text"></ion-range>
40
+ `,
41
+ });
42
+ const range = page.body.querySelector('ion-range');
43
+ const nativeSlider = range.shadowRoot.querySelector('.range-knob-handle');
44
+ expect(nativeSlider.getAttribute('aria-label')).toBe(null);
45
+ expect(nativeSlider.getAttribute('aria-labelledby')).toBe('range-label');
46
+ });
23
47
  });
@@ -594,7 +594,7 @@ export class Refresher {
594
594
  }
595
595
  render() {
596
596
  const mode = getIonMode(this);
597
- return (h(Host, { key: 'b5f7ccfe964f0f970c46ae813649c36625d82a1d', slot: "fixed", class: {
597
+ return (h(Host, { key: '8e4a99ce208ea3162186e91ba0d1e289b4f247a0', slot: "fixed", class: {
598
598
  [mode]: true,
599
599
  // Used internally for styling
600
600
  [`refresher-${mode}`]: true,
@@ -4,7 +4,7 @@
4
4
  import AxeBuilder from "@axe-core/playwright";
5
5
  import { expect } from "@playwright/test";
6
6
  import { configs, test, dragElementBy } from "../../../../utils/test/playwright/index";
7
- configs({ directions: ['ltr'], modes: ['md'], themes: ['light', 'dark'] }).forEach(({ config, title }) => {
7
+ configs({ directions: ['ltr'], modes: ['md'], palettes: ['light', 'dark'] }).forEach(({ config, title }) => {
8
8
  test.describe(title('refresher: a11y for ion-color()'), () => {
9
9
  test('should not have accessibility violations', async ({ page }) => {
10
10
  await page.setContent(`
@@ -52,7 +52,7 @@ export class RefresherContent {
52
52
  const pullingIcon = this.pullingIcon;
53
53
  const hasSpinner = pullingIcon != null && SPINNERS[pullingIcon] !== undefined;
54
54
  const mode = getIonMode(this);
55
- return (h(Host, { key: '14a4ef75a0f56d499ee0e0bb6ba23565626ad442', class: mode }, h("div", { key: 'b738ea69256548d66512744ecaa5cbf651c1f6dd', class: "refresher-pulling" }, this.pullingIcon && hasSpinner && (h("div", { class: "refresher-pulling-icon" }, h("div", { class: "spinner-arrow-container" }, h("ion-spinner", { name: this.pullingIcon, paused: true }), mode === 'md' && this.pullingIcon === 'circular' && (h("div", { class: "arrow-container" }, h("ion-icon", { icon: caretBackSharp, "aria-hidden": "true" })))))), this.pullingIcon && !hasSpinner && (h("div", { class: "refresher-pulling-icon" }, h("ion-icon", { icon: this.pullingIcon, lazy: false, "aria-hidden": "true" }))), this.pullingText !== undefined && this.renderPullingText()), h("div", { key: '6cbcc1f90df56b53c51a99c5a63e185dba00e9b2', class: "refresher-refreshing" }, this.refreshingSpinner && (h("div", { class: "refresher-refreshing-icon" }, h("ion-spinner", { name: this.refreshingSpinner }))), this.refreshingText !== undefined && this.renderRefreshingText())));
55
+ return (h(Host, { key: 'c84cb333293a4b8f749505268d019698f9df431c', class: mode }, h("div", { key: 'fb3c0cd2ca4636762060b6615fc2da3ce93da20c', class: "refresher-pulling" }, this.pullingIcon && hasSpinner && (h("div", { class: "refresher-pulling-icon" }, h("div", { class: "spinner-arrow-container" }, h("ion-spinner", { name: this.pullingIcon, paused: true }), mode === 'md' && this.pullingIcon === 'circular' && (h("div", { class: "arrow-container" }, h("ion-icon", { icon: caretBackSharp, "aria-hidden": "true" })))))), this.pullingIcon && !hasSpinner && (h("div", { class: "refresher-pulling-icon" }, h("ion-icon", { icon: this.pullingIcon, lazy: false, "aria-hidden": "true" }))), this.pullingText !== undefined && this.renderPullingText()), h("div", { key: '4a099f6a15854d9432d5e7ee8ade1023a6051965', class: "refresher-refreshing" }, this.refreshingSpinner && (h("div", { class: "refresher-refreshing-icon" }, h("ion-spinner", { name: this.refreshingSpinner }))), this.refreshingText !== undefined && this.renderRefreshingText())));
56
56
  }
57
57
  static get is() { return "ion-refresher-content"; }
58
58
  static get properties() {
@@ -20,7 +20,7 @@ export class Reorder {
20
20
  render() {
21
21
  const mode = getIonMode(this);
22
22
  const reorderIcon = mode === 'ios' ? reorderThreeOutline : reorderTwoSharp;
23
- return (h(Host, { key: '068457526894b0f557537d5b85f5596781988bbd', class: mode }, h("slot", { key: '006afcb58b0c8c0e4988e58d2c1441a7f4472de1' }, h("ion-icon", { key: '25e63dd8a8eeee62e6c5095bb39f887af2c82124', icon: reorderIcon, lazy: false, class: "reorder-icon", part: "icon", "aria-hidden": "true" }))));
23
+ return (h(Host, { key: '4e02357926b0208480a043ee3fe0617633daca76', class: mode }, h("slot", { key: 'cedcbcdcc9702af91d00ee20664cb8be634f62d1' }, h("ion-icon", { key: 'd78d7035eae7a235f428132c2a80c8e0538c4441', icon: reorderIcon, lazy: false, class: "reorder-icon", part: "icon", "aria-hidden": "true" }))));
24
24
  }
25
25
  static get is() { return "ion-reorder"; }
26
26
  static get encapsulation() { return "shadow"; }
@@ -238,7 +238,7 @@ export class ReorderGroup {
238
238
  }
239
239
  render() {
240
240
  const mode = getIonMode(this);
241
- return (h(Host, { key: '868762829627e101926293f5e7e9f4bcf54490b1', class: {
241
+ return (h(Host, { key: 'b3a4a278423a196c0980ab8d03062175d8b1f52a', class: {
242
242
  [mode]: true,
243
243
  'reorder-enabled': !this.disabled,
244
244
  'reorder-list-active': this.state !== 0 /* ReorderGroupState.Idle */,
@@ -59,7 +59,7 @@ export class RippleEffect {
59
59
  }
60
60
  render() {
61
61
  const mode = getIonMode(this);
62
- return (h(Host, { key: '97bc96ca8dc4bf162302d0cf6980f45534495a3d', role: "presentation", class: {
62
+ return (h(Host, { key: 'ca0ab0deaa7902cbc95e62d4b0c5baeac4387b41', role: "presentation", class: {
63
63
  [mode]: true,
64
64
  unbounded: this.unbounded,
65
65
  } }));
@@ -23,10 +23,10 @@ export class RouterLink {
23
23
  rel: this.rel,
24
24
  target: this.target,
25
25
  };
26
- return (h(Host, { key: '9dac58d3edaa6b5278c3636e0e245c7ddc2cb888', onClick: this.onClick, class: createColorClasses(this.color, {
26
+ return (h(Host, { key: '3affa4bc9806eaef4e1985c9ef7bb298342cbe95', onClick: this.onClick, class: createColorClasses(this.color, {
27
27
  [mode]: true,
28
28
  'ion-activatable': true,
29
- }) }, h("a", Object.assign({ key: '81d2ffd44f798703da2cd6f926576c6e96a7c41f' }, attrs), h("slot", { key: '26853d510e4cdb93b436cdf70ebb5a7dca288bfb' }))));
29
+ }) }, h("a", Object.assign({ key: 'b957040fd9f8bdc1cd1fd338734c9734522c2fc3' }, attrs), h("slot", { key: 'cbf39dbce40865418fc9cd7e09a32d6c6b8f9f69' }))));
30
30
  }
31
31
  static get is() { return "ion-router-link"; }
32
32
  static get encapsulation() { return "shadow"; }
@@ -4,7 +4,7 @@
4
4
  import AxeBuilder from "@axe-core/playwright";
5
5
  import { expect } from "@playwright/test";
6
6
  import { configs, test } from "../../../../utils/test/playwright/index";
7
- configs({ directions: ['ltr'], themes: ['light', 'dark'] }).forEach(({ title, config }) => {
7
+ configs({ directions: ['ltr'], palettes: ['light', 'dark'] }).forEach(({ title, config }) => {
8
8
  test.describe(title('router-link: a11y'), () => {
9
9
  test('should not have accessibility violations', async ({ page }) => {
10
10
  /**
@@ -178,7 +178,7 @@ export class RouterOutlet {
178
178
  return true;
179
179
  }
180
180
  render() {
181
- return h("slot", { key: '3425cdea6102946b2a7f4dcb3bb0133b2c7c561c' });
181
+ return h("slot", { key: '4b9e950f5f918f4f85350c3af9959b8a37e09b2a' });
182
182
  }
183
183
  static get is() { return "ion-router-outlet"; }
184
184
  static get encapsulation() { return "shadow"; }
@@ -5,7 +5,7 @@ import { Host, h } from "@stencil/core";
5
5
  import { getIonMode } from "../../global/ionic-global";
6
6
  export class Row {
7
7
  render() {
8
- return (h(Host, { key: '8b54835ea837e25c278ffa3e298238e92b095ccc', class: getIonMode(this) }, h("slot", { key: 'cb77d85c8d02fdee29a72b58f3091db8daeaf3b2' })));
8
+ return (h(Host, { key: '99e5562cd37159634f14d351e5a09233c9da9611', class: getIonMode(this) }, h("slot", { key: '07beb06113ae641d7b3d6c24307861d74c31a8d5' })));
9
9
  }
10
10
  static get is() { return "ion-row"; }
11
11
  static get encapsulation() { return "shadow"; }
@@ -117,7 +117,7 @@ export class Searchbar {
117
117
  this.noAnimate = true;
118
118
  this.color = undefined;
119
119
  this.animated = false;
120
- this.autocapitalize = undefined;
120
+ this.autocapitalize = 'off';
121
121
  this.autocomplete = 'off';
122
122
  this.autocorrect = 'off';
123
123
  this.cancelButtonIcon = config.get('backButtonIcon', arrowBackSharp);
@@ -372,14 +372,14 @@ export class Searchbar {
372
372
  return true;
373
373
  }
374
374
  render() {
375
- const { cancelButtonText } = this;
375
+ const { cancelButtonText, autocapitalize } = this;
376
376
  const animated = this.animated && config.getBoolean('animated', true);
377
377
  const mode = getIonMode(this);
378
378
  const clearIcon = this.clearIcon || (mode === 'ios' ? closeCircle : closeSharp);
379
379
  const searchIcon = this.searchIcon || (mode === 'ios' ? searchOutline : searchSharp);
380
380
  const shouldShowCancelButton = this.shouldShowCancelButton();
381
- const cancelButton = this.showCancelButton !== 'never' && (h("button", { key: '66091918b5b97012b4105238b9aa1e0bc2133885', "aria-label": cancelButtonText, "aria-hidden": shouldShowCancelButton ? undefined : 'true', type: "button", tabIndex: mode === 'ios' && !shouldShowCancelButton ? -1 : undefined, onMouseDown: this.onCancelSearchbar, onTouchStart: this.onCancelSearchbar, class: "searchbar-cancel-button" }, h("div", { key: 'bfe5602ce36cd82dae870b632de767bde3de2f8a', "aria-hidden": "true" }, mode === 'md' ? (h("ion-icon", { "aria-hidden": "true", mode: mode, icon: this.cancelButtonIcon, lazy: false })) : (cancelButtonText))));
382
- return (h(Host, { key: '8604e83a9e11f5c561c470ce4630bdc5a38f1098', role: "search", "aria-disabled": this.disabled ? 'true' : null, class: createColorClasses(this.color, {
381
+ const cancelButton = this.showCancelButton !== 'never' && (h("button", { key: '988915b91dd135bb3a4ba5ff31b2765f78cc05a0', "aria-label": cancelButtonText, "aria-hidden": shouldShowCancelButton ? undefined : 'true', type: "button", tabIndex: mode === 'ios' && !shouldShowCancelButton ? -1 : undefined, onMouseDown: this.onCancelSearchbar, onTouchStart: this.onCancelSearchbar, class: "searchbar-cancel-button" }, h("div", { key: '239b7d21a29a527f515dcdf7ec1fc87f1aa1cc54', "aria-hidden": "true" }, mode === 'md' ? (h("ion-icon", { "aria-hidden": "true", mode: mode, icon: this.cancelButtonIcon, lazy: false })) : (cancelButtonText))));
382
+ return (h(Host, { key: '78cb90f96e83e11b158baf600af907ee7512abba', role: "search", "aria-disabled": this.disabled ? 'true' : null, class: createColorClasses(this.color, {
383
383
  [mode]: true,
384
384
  'searchbar-animated': animated,
385
385
  'searchbar-disabled': this.disabled,
@@ -389,14 +389,14 @@ export class Searchbar {
389
389
  'searchbar-has-focus': this.focused,
390
390
  'searchbar-should-show-clear': this.shouldShowClearButton(),
391
391
  'searchbar-should-show-cancel': this.shouldShowCancelButton(),
392
- }) }, h("div", { key: '4d94b664e0bb7c47f094a25f26fc92b210b96ae3', class: "searchbar-input-container" }, h("input", Object.assign({ key: '78a82dcd609fdb0327ff153a49b5904a0290663d', "aria-label": "search text", disabled: this.disabled, ref: (el) => (this.nativeInput = el), class: "searchbar-input", inputMode: this.inputmode, enterKeyHint: this.enterkeyhint, name: this.name, onInput: this.onInput, onChange: this.onChange, onBlur: this.onBlur, onFocus: this.onFocus, minLength: this.minlength, maxLength: this.maxlength, placeholder: this.placeholder, type: this.type, value: this.getValue(), autoCapitalize: this.autocapitalize, autoComplete: this.autocomplete, autoCorrect: this.autocorrect, spellcheck: this.spellcheck }, this.inheritedAttributes)), mode === 'md' && cancelButton, h("ion-icon", { key: '4da87bc57573758ed758332789bac63f253b1678', "aria-hidden": "true", mode: mode, icon: searchIcon, lazy: false, class: "searchbar-search-icon" }), h("button", { key: '410d65bac177b3534c0ef7a6ecc1fe6381b46efd', "aria-label": "reset", type: "button", "no-blur": true, class: "searchbar-clear-button", onPointerDown: (ev) => {
392
+ }) }, h("div", { key: '50660dbb27cc15bc69d22fa61e7be643fc6a75c2', class: "searchbar-input-container" }, h("input", Object.assign({ key: 'b84654d68aa77e4f30b9009d7e2e04dfee96717e', "aria-label": "search text", disabled: this.disabled, ref: (el) => (this.nativeInput = el), class: "searchbar-input", inputMode: this.inputmode, enterKeyHint: this.enterkeyhint, name: this.name, onInput: this.onInput, onChange: this.onChange, onBlur: this.onBlur, onFocus: this.onFocus, minLength: this.minlength, maxLength: this.maxlength, placeholder: this.placeholder, type: this.type, value: this.getValue(), autoCapitalize: autocapitalize === 'default' ? undefined : autocapitalize, autoComplete: this.autocomplete, autoCorrect: this.autocorrect, spellcheck: this.spellcheck }, this.inheritedAttributes)), mode === 'md' && cancelButton, h("ion-icon", { key: '7b1ddb05941fd0ada3b256bdeaf4e29153917546', "aria-hidden": "true", mode: mode, icon: searchIcon, lazy: false, class: "searchbar-search-icon" }), h("button", { key: '3219fff5d78ee3fe0ae092e5218b1ab0b1ba2766', "aria-label": "reset", type: "button", "no-blur": true, class: "searchbar-clear-button", onPointerDown: (ev) => {
393
393
  /**
394
394
  * This prevents mobile browsers from
395
395
  * blurring the input when the clear
396
396
  * button is activated.
397
397
  */
398
398
  ev.preventDefault();
399
- }, onClick: () => this.onClearInput(true) }, h("ion-icon", { key: 'feb89ebe3b4df01402762b9d65c56d26852ca1a6', "aria-hidden": "true", mode: mode, icon: clearIcon, lazy: false, class: "searchbar-clear-icon" }))), mode === 'ios' && cancelButton));
399
+ }, onClick: () => this.onClearInput(true) }, h("ion-icon", { key: '859e781c418d1a03992c12f4466f77ac042266e8', "aria-hidden": "true", mode: mode, icon: clearIcon, lazy: false, class: "searchbar-clear-icon" }))), mode === 'ios' && cancelButton));
400
400
  }
401
401
  static get is() { return "ion-searchbar"; }
402
402
  static get encapsulation() { return "scoped"; }
@@ -463,21 +463,22 @@ export class Searchbar {
463
463
  "resolved": "string",
464
464
  "references": {}
465
465
  },
466
- "required": true,
466
+ "required": false,
467
467
  "optional": false,
468
468
  "docs": {
469
469
  "tags": [],
470
470
  "text": "Indicates whether and how the text value should be automatically capitalized as it is entered/edited by the user.\nAvailable options: `\"off\"`, `\"none\"`, `\"on\"`, `\"sentences\"`, `\"words\"`, `\"characters\"`."
471
471
  },
472
472
  "attribute": "autocapitalize",
473
- "reflect": false
473
+ "reflect": false,
474
+ "defaultValue": "'off'"
474
475
  },
475
476
  "autocomplete": {
476
477
  "type": "string",
477
478
  "mutable": false,
478
479
  "complexType": {
479
480
  "original": "AutocompleteTypes",
480
- "resolved": "\"name\" | \"email\" | \"tel\" | \"url\" | \"on\" | \"off\" | \"honorific-prefix\" | \"given-name\" | \"additional-name\" | \"family-name\" | \"honorific-suffix\" | \"nickname\" | \"username\" | \"new-password\" | \"current-password\" | \"one-time-code\" | \"organization-title\" | \"organization\" | \"street-address\" | \"address-line1\" | \"address-line2\" | \"address-line3\" | \"address-level4\" | \"address-level3\" | \"address-level2\" | \"address-level1\" | \"country\" | \"country-name\" | \"postal-code\" | \"cc-name\" | \"cc-given-name\" | \"cc-additional-name\" | \"cc-family-name\" | \"cc-number\" | \"cc-exp\" | \"cc-exp-month\" | \"cc-exp-year\" | \"cc-csc\" | \"cc-type\" | \"transaction-currency\" | \"transaction-amount\" | \"language\" | \"bday\" | \"bday-day\" | \"bday-month\" | \"bday-year\" | \"sex\" | \"tel-country-code\" | \"tel-national\" | \"tel-area-code\" | \"tel-local\" | \"tel-extension\" | \"impp\" | \"photo\"",
481
+ "resolved": "\"name\" | \"on\" | \"off\" | \"honorific-prefix\" | \"given-name\" | \"additional-name\" | \"family-name\" | \"honorific-suffix\" | \"nickname\" | \"email\" | \"username\" | \"new-password\" | \"current-password\" | \"one-time-code\" | \"organization-title\" | \"organization\" | \"street-address\" | \"address-line1\" | \"address-line2\" | \"address-line3\" | \"address-level4\" | \"address-level3\" | \"address-level2\" | \"address-level1\" | \"country\" | \"country-name\" | \"postal-code\" | \"cc-name\" | \"cc-given-name\" | \"cc-additional-name\" | \"cc-family-name\" | \"cc-number\" | \"cc-exp\" | \"cc-exp-month\" | \"cc-exp-year\" | \"cc-csc\" | \"cc-type\" | \"transaction-currency\" | \"transaction-amount\" | \"language\" | \"bday\" | \"bday-day\" | \"bday-month\" | \"bday-year\" | \"sex\" | \"tel\" | \"tel-country-code\" | \"tel-national\" | \"tel-area-code\" | \"tel-local\" | \"tel-extension\" | \"impp\" | \"url\" | \"photo\"",
481
482
  "references": {
482
483
  "AutocompleteTypes": {
483
484
  "location": "import",
@@ -420,14 +420,14 @@ export class Segment {
420
420
  }
421
421
  render() {
422
422
  const mode = getIonMode(this);
423
- return (h(Host, { key: 'a5268f36524465945e66f838c1fcb7b2ca4980b5', role: "tablist", onClick: this.onClick, class: createColorClasses(this.color, {
423
+ return (h(Host, { key: 'c11b46ad7311cf015402f3a6d4d58316d8d48faa', role: "tablist", onClick: this.onClick, class: createColorClasses(this.color, {
424
424
  [mode]: true,
425
425
  'in-toolbar': hostContext('ion-toolbar', this.el),
426
426
  'in-toolbar-color': hostContext('ion-toolbar[color]', this.el),
427
427
  'segment-activated': this.activated,
428
428
  'segment-disabled': this.disabled,
429
429
  'segment-scrollable': this.scrollable,
430
- }) }, h("slot", { key: 'b399f99ec57ab319cdb0635d2bb1efcd74b709bc' })));
430
+ }) }, h("slot", { key: '47ef8ff809cc11ea27fda5116cae25540b0a6f92' })));
431
431
  }
432
432
  static get is() { return "ion-segment"; }
433
433
  static get encapsulation() { return "shadow"; }
@@ -7,7 +7,7 @@ import { configs, test } from "../../../../utils/test/playwright/index";
7
7
  /**
8
8
  * Only md mode uses ion-color() for the segment button
9
9
  */
10
- configs({ directions: ['ltr'], modes: ['md'], themes: ['light', 'dark'] }).forEach(({ title, config }) => {
10
+ configs({ directions: ['ltr'], modes: ['md'], palettes: ['light', 'dark'] }).forEach(({ title, config }) => {
11
11
  test.describe(title('segment: a11y for ion-color()'), () => {
12
12
  test('should not have accessibility violations', async ({ page }) => {
13
13
  await page.setContent(`
@@ -78,7 +78,7 @@ export class SegmentButton {
78
78
  const { checked, type, disabled, hasIcon, hasLabel, layout, segmentEl } = this;
79
79
  const mode = getIonMode(this);
80
80
  const hasSegmentColor = () => (segmentEl === null || segmentEl === void 0 ? void 0 : segmentEl.color) !== undefined;
81
- return (h(Host, { key: 'b2c9b735e7c578e50d7a41cb0c47cf661b83aa49', class: {
81
+ return (h(Host, { key: '67fab48aa470e71df51854a12d9fc3d744435c8f', class: {
82
82
  [mode]: true,
83
83
  'in-toolbar': hostContext('ion-toolbar', this.el),
84
84
  'in-toolbar-color': hostContext('ion-toolbar[color]', this.el),
@@ -94,10 +94,10 @@ export class SegmentButton {
94
94
  'ion-activatable': true,
95
95
  'ion-activatable-instant': true,
96
96
  'ion-focusable': true,
97
- } }, h("button", Object.assign({ key: '1b6e56709f281be94c754a52dd80d9968d1e6bb1', "aria-selected": checked ? 'true' : 'false', role: "tab", ref: (el) => (this.nativeEl = el), type: type, class: "button-native", part: "native", disabled: disabled }, this.inheritedAttributes), h("span", { key: '3a0508e0d859dffd78dc54dc574cf3ed5c03f110', class: "button-inner" }, h("slot", { key: '05f0eb4f773d2cbd929035087af4550a0f4ab038' })), mode === 'md' && h("ion-ripple-effect", null)), h("div", { key: '75370e50f989a5db5d6b8ffa80894acba1797d85', part: "indicator", class: {
97
+ } }, h("button", Object.assign({ key: 'dcc61cd35f1ff3535241c21630ae5f36166f6a7e', "aria-selected": checked ? 'true' : 'false', role: "tab", ref: (el) => (this.nativeEl = el), type: type, class: "button-native", part: "native", disabled: disabled }, this.inheritedAttributes), h("span", { key: '8ea97d13b245a0ac3a37d2452180e8638565f0c7', class: "button-inner" }, h("slot", { key: 'b6abce60c1fa41db06b7af8a4de026f7d940f8d4' })), mode === 'md' && h("ion-ripple-effect", null)), h("div", { key: '2ce136fd46ca6a8b8f2c3a681672a08c6d6c3657', part: "indicator", class: {
98
98
  'segment-button-indicator': true,
99
99
  'segment-button-indicator-animated': true,
100
- } }, h("div", { key: '8123d414c166d97c5e3dae707b89d4e94f2c6f92', part: "indicator-background", class: "segment-button-indicator-background" }))));
100
+ } }, h("div", { key: 'eac73d7b71edeecb92b6cdfc5a489ce6413bfb60', part: "indicator-background", class: "segment-button-indicator-background" }))));
101
101
  }
102
102
  static get is() { return "ion-segment-button"; }
103
103
  static get encapsulation() { return "shadow"; }