@ionic/core 8.8.5 → 8.8.6-dev.11777559143.1d1ad1ad

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 (1085) hide show
  1. package/components/index.js +1 -1
  2. package/components/ion-accordion-group.js +1 -1
  3. package/components/ion-accordion.js +1 -1
  4. package/components/ion-action-sheet.js +1 -1
  5. package/components/ion-alert.js +1 -1
  6. package/components/ion-app.js +1 -1
  7. package/components/ion-avatar.js +1 -1
  8. package/components/ion-back-button.js +1 -1
  9. package/components/ion-backdrop.js +1 -1
  10. package/components/ion-badge.js +1 -1
  11. package/components/ion-breadcrumb.js +1 -1
  12. package/components/ion-breadcrumbs.js +1 -1
  13. package/components/ion-button.js +1 -1
  14. package/components/ion-buttons.js +1 -1
  15. package/components/ion-card-content.js +1 -1
  16. package/components/ion-card-header.js +1 -1
  17. package/components/ion-card-subtitle.js +1 -1
  18. package/components/ion-card-title.js +1 -1
  19. package/components/ion-card.js +1 -1
  20. package/components/ion-checkbox.js +1 -1
  21. package/components/ion-chip.js +1 -1
  22. package/components/ion-col.js +1 -1
  23. package/components/ion-content.js +1 -1
  24. package/components/ion-datetime-button.js +1 -1
  25. package/components/ion-datetime.js +1 -1
  26. package/components/ion-divider.d.ts +11 -0
  27. package/components/ion-divider.js +4 -0
  28. package/components/ion-fab-button.js +1 -1
  29. package/components/ion-fab-list.js +1 -1
  30. package/components/ion-fab.js +1 -1
  31. package/components/ion-footer.js +1 -1
  32. package/components/ion-grid.js +1 -1
  33. package/components/ion-header.js +1 -1
  34. package/components/ion-icon.js +1 -1
  35. package/components/ion-img.js +1 -1
  36. package/components/ion-infinite-scroll-content.js +1 -1
  37. package/components/ion-infinite-scroll.js +1 -1
  38. package/components/ion-input-otp.js +1 -1
  39. package/components/ion-input-password-toggle.js +1 -1
  40. package/components/ion-input.js +1 -1
  41. package/components/ion-item-divider.js +1 -1
  42. package/components/ion-item-group.js +1 -1
  43. package/components/ion-item-option.js +1 -1
  44. package/components/ion-item-options.js +1 -1
  45. package/components/ion-item-sliding.js +1 -1
  46. package/components/ion-item.js +1 -1
  47. package/components/ion-label.js +1 -1
  48. package/components/ion-list-header.js +1 -1
  49. package/components/ion-list.js +1 -1
  50. package/components/ion-loading.js +1 -1
  51. package/components/ion-menu-button.js +1 -1
  52. package/components/ion-menu-toggle.js +1 -1
  53. package/components/ion-menu.js +1 -1
  54. package/components/ion-modal.js +1 -1
  55. package/components/ion-nav-link.js +1 -1
  56. package/components/ion-nav.js +1 -1
  57. package/components/ion-note.js +1 -1
  58. package/components/ion-picker-column-option.js +1 -1
  59. package/components/ion-picker-column.js +1 -1
  60. package/components/ion-picker-legacy-column.js +1 -1
  61. package/components/ion-picker-legacy.js +1 -1
  62. package/components/ion-picker.js +1 -1
  63. package/components/ion-popover.js +1 -1
  64. package/components/ion-progress-bar.js +1 -1
  65. package/components/ion-radio-group.js +1 -1
  66. package/components/ion-radio.js +1 -1
  67. package/components/ion-range.js +1 -1
  68. package/components/ion-refresher-content.js +1 -1
  69. package/components/ion-refresher.js +1 -1
  70. package/components/ion-reorder-group.js +1 -1
  71. package/components/ion-reorder.js +1 -1
  72. package/components/ion-ripple-effect.js +1 -1
  73. package/components/ion-route-redirect.js +1 -1
  74. package/components/ion-route.js +1 -1
  75. package/components/ion-router-link.js +1 -1
  76. package/components/ion-router-outlet.js +1 -1
  77. package/components/ion-router.js +1 -1
  78. package/components/ion-row.js +1 -1
  79. package/components/ion-searchbar.js +1 -1
  80. package/components/ion-segment-button.js +1 -1
  81. package/components/ion-segment-content.js +1 -1
  82. package/components/ion-segment-view.js +1 -1
  83. package/components/ion-segment.js +1 -1
  84. package/components/ion-select-modal.js +1 -1
  85. package/components/ion-select-option.js +1 -1
  86. package/components/ion-select-popover.js +1 -1
  87. package/components/ion-select.js +1 -1
  88. package/components/ion-skeleton-text.js +1 -1
  89. package/components/ion-spinner.js +1 -1
  90. package/components/ion-split-pane.js +1 -1
  91. package/components/ion-tab-bar.js +1 -1
  92. package/components/ion-tab-button.js +1 -1
  93. package/components/ion-tab.js +1 -1
  94. package/components/ion-tabs.js +1 -1
  95. package/components/ion-text.js +1 -1
  96. package/components/ion-textarea.js +1 -1
  97. package/components/ion-thumbnail.js +1 -1
  98. package/components/ion-title.js +1 -1
  99. package/components/ion-toast.js +1 -1
  100. package/components/ion-toggle.js +1 -1
  101. package/components/ion-toolbar.js +1 -1
  102. package/components/p-0sa2JgYA.js +4 -0
  103. package/components/p-3Ni1Z654.js +4 -0
  104. package/{dist/ionic/p-D13Eaw-8.js → components/p-9gxM3tAr.js} +1 -1
  105. package/components/{p-ak_d-z48.js → p-B636tzQ7.js} +1 -1
  106. package/components/p-B8Oa6a_k.js +4 -0
  107. package/components/p-BCDEEm9n.js +4 -0
  108. package/components/p-BDndEqui.js +4 -0
  109. package/components/p-BDqjX7Z_.js +4 -0
  110. package/components/p-BErKjY03.js +4 -0
  111. package/components/p-BFCM_1oE.js +4 -0
  112. package/components/{p-cyNmxje6.js → p-BLysWQA1.js} +1 -1
  113. package/components/p-BO4aickU.js +4 -0
  114. package/components/p-BTYqyHph.js +4 -0
  115. package/components/p-BU8N7ZrK.js +4 -0
  116. package/components/p-BYSs-jZz.js +4 -0
  117. package/components/p-BaPtaYEC.js +4 -0
  118. package/components/p-BbQGmZyu.js +4 -0
  119. package/components/p-BcbmT6b3.js +4 -0
  120. package/components/p-BeVlsaLA.js +4 -0
  121. package/components/p-BfHB6wX_.js +4 -0
  122. package/components/p-BhfW3d9j.js +4 -0
  123. package/components/p-BjW8SOqw.js +4 -0
  124. package/components/p-Bp__mr16.js +4 -0
  125. package/components/p-BqDiJgC_.js +4 -0
  126. package/components/p-Brxa0j7O.js +4 -0
  127. package/components/p-BtAlyZ0b.js +4 -0
  128. package/components/p-BwKpO3Is.js +4 -0
  129. package/components/p-ByuCfbYy.js +4 -0
  130. package/components/p-C-_EGKki.js +4 -0
  131. package/components/p-C00Y_WJv.js +4 -0
  132. package/components/p-C0U8YqYW.js +4 -0
  133. package/components/p-C2cZvGcF.js +4 -0
  134. package/components/p-CKfNwyAb.js +4 -0
  135. package/components/p-CVBkx7m1.js +4 -0
  136. package/components/p-Cb9imMZh.js +4 -0
  137. package/components/p-CdYTq34D.js +4 -0
  138. package/components/p-CeYwuysM.js +4 -0
  139. package/components/p-Cf9-xP7P.js +4 -0
  140. package/components/{p-Cwv-vmkN.js → p-CjSx8W-k.js} +1 -1
  141. package/components/p-Cmql_g3_.js +4 -0
  142. package/components/p-CnOTQxHB.js +4 -0
  143. package/components/p-CnwZE7CW.js +4 -0
  144. package/components/p-CoarhFWH.js +4 -0
  145. package/components/p-CtiqM786.js +4 -0
  146. package/components/p-D1t981Ih.js +4 -0
  147. package/components/p-D5lMX0xt.js +4 -0
  148. package/components/p-DAeMHNER.js +4 -0
  149. package/components/p-DDw-NYxz.js +4 -0
  150. package/components/p-DVcs-2q3.js +4 -0
  151. package/components/p-DaJxRxSQ.js +4 -0
  152. package/components/p-Dhi5xtNS.js +4 -0
  153. package/components/p-GnGGIfCd.js +4 -0
  154. package/components/p-TpZHKDyk.js +4 -0
  155. package/components/p-XFUFdPrc.js +4 -0
  156. package/components/p-XegQjlzJ.js +4 -0
  157. package/components/p-fIOYmaqA.js +4 -0
  158. package/components/p-lIOqnNXn.js +4 -0
  159. package/{dist/ionic/p-BvFYtOdE.js → components/p-oF-CwZ0b.js} +1 -1
  160. package/components/p-sK-FK9CT.js +4 -0
  161. package/components/p-t98_NeNv.js +4 -0
  162. package/components/p-tYh73xQe.js +4 -0
  163. package/components/p-vCpF32Z7.js +4 -0
  164. package/components/p-vXpMhGrs.js +4 -0
  165. package/components/p-wCDzv5Q8.js +4 -0
  166. package/components/{p-YLXPWgVj.js → p-zWP0sUV_.js} +1 -1
  167. package/css/core.css +1 -1
  168. package/css/core.css.map +1 -1
  169. package/css/display.css +1 -1
  170. package/css/display.css.map +1 -1
  171. package/css/flex-utils.css +1 -1
  172. package/css/flex-utils.css.map +1 -1
  173. package/css/float-elements.css.map +1 -1
  174. package/css/global.bundle.css.map +1 -1
  175. package/css/ionic/bundle.ionic.css +1 -0
  176. package/css/ionic/bundle.ionic.css.map +1 -0
  177. package/css/ionic/core.ionic.css +1 -0
  178. package/css/ionic/core.ionic.css.map +1 -0
  179. package/css/ionic/global.bundle.ionic.css +1 -0
  180. package/css/ionic/global.bundle.ionic.css.map +1 -0
  181. package/css/ionic/ionic-swiper.ionic.css +1 -0
  182. package/css/ionic/ionic-swiper.ionic.css.map +1 -0
  183. package/css/ionic/link.ionic.css +1 -0
  184. package/css/ionic/link.ionic.css.map +1 -0
  185. package/css/ionic/structure.ionic.css +1 -0
  186. package/css/ionic/structure.ionic.css.map +1 -0
  187. package/css/ionic/typography.ionic.css +1 -0
  188. package/css/ionic/typography.ionic.css.map +1 -0
  189. package/css/ionic/utils.bundle.ionic.css +1 -0
  190. package/css/ionic/utils.bundle.ionic.css.map +1 -0
  191. package/css/ionic-swiper.css +1 -1
  192. package/css/ionic-swiper.css.map +1 -1
  193. package/css/ionic.bundle.css +1 -1
  194. package/css/ionic.bundle.css.map +1 -1
  195. package/css/normalize.css.map +1 -1
  196. package/css/padding.css.map +1 -1
  197. package/css/palettes/dark.always.css.map +1 -1
  198. package/css/palettes/dark.class.css.map +1 -1
  199. package/css/palettes/dark.system.css.map +1 -1
  200. package/css/palettes/high-contrast-dark.always.css.map +1 -1
  201. package/css/palettes/high-contrast-dark.class.css.map +1 -1
  202. package/css/palettes/high-contrast-dark.system.css.map +1 -1
  203. package/css/palettes/high-contrast.always.css.map +1 -1
  204. package/css/palettes/high-contrast.class.css.map +1 -1
  205. package/css/palettes/high-contrast.system.css.map +1 -1
  206. package/css/structure.css.map +1 -1
  207. package/css/text-alignment.css.map +1 -1
  208. package/css/text-transformation.css.map +1 -1
  209. package/css/typography.css.map +1 -1
  210. package/css/utils.bundle.css +1 -1
  211. package/css/utils.bundle.css.map +1 -1
  212. package/dist/cjs/{animation-Dg4yiuR2.js → animation-DknMeJ3x.js} +3 -3
  213. package/dist/cjs/{app-globals-CLI8xCmk.js → app-globals-DtAeky3x.js} +1 -1
  214. package/dist/cjs/{button-active-FscMI17-.js → button-active-JoIWyYri.js} +2 -2
  215. package/dist/cjs/{capacitor-DmA66EwP.js → capacitor-BnRBm_ys.js} +3 -3
  216. package/dist/cjs/caret-down-vtVgfXIs.js +8 -0
  217. package/dist/cjs/caret-left-CxZXLRv5.js +8 -0
  218. package/dist/cjs/caret-right-CRCgv98E.js +8 -0
  219. package/dist/cjs/config-DWdFbSNK.js +35 -0
  220. package/dist/cjs/{data-BYlBjkMU.js → data-DuOuKG7I.js} +6 -6
  221. package/dist/cjs/{focus-visible-CCvKiLh3.js → focus-visible-BIj-I3-C.js} +24 -0
  222. package/dist/cjs/{framework-delegate-CRgp8o_p.js → framework-delegate-Dx9FrqAC.js} +4 -2
  223. package/dist/cjs/{haptic-ClPPQ_PS.js → haptic-D3Ay9mmg.js} +1 -1
  224. package/dist/cjs/{helpers-CxTYJdbT.js → helpers-DJYxKN5U.js} +57 -4
  225. package/dist/cjs/{config-BukYi_pW.js → index-BJlwOs11.js} +1 -31
  226. package/dist/cjs/{index-MbaBbWXk.js → index-BJrpF9T3.js} +2 -2
  227. package/dist/cjs/{index-CFUwM5x_.js → index-Cer2Qy4I.js} +15 -15
  228. package/dist/cjs/{index-DqmRDbxg.js → index-CgAbCW6L.js} +2 -0
  229. package/dist/cjs/{index-CqT-2gKy.js → index-CzcLEdQ5.js} +41 -4
  230. package/dist/cjs/{index-YcSftOMz.js → index-DMJjUhXH.js} +9 -8
  231. package/dist/cjs/{index-C845Ti6K.js → index-D_mPAIqF.js} +4 -4
  232. package/dist/cjs/index.cjs.js +16 -16
  233. package/dist/cjs/{input-shims-Dl5cnc_e.js → input-shims-Dn33gFln.js} +18 -17
  234. package/dist/cjs/{input.utils-DmeJ8dmo.js → input.utils-DnVnhWEF.js} +5 -5
  235. package/dist/cjs/ion-accordion_2.cjs.entry.js +61 -29
  236. package/dist/cjs/ion-action-sheet.cjs.entry.js +41 -22
  237. package/dist/cjs/ion-alert.cjs.entry.js +62 -41
  238. package/dist/cjs/ion-app_8.cjs.entry.js +292 -157
  239. package/dist/cjs/ion-avatar_3.cjs.entry.js +125 -13
  240. package/dist/cjs/ion-back-button.cjs.entry.js +31 -22
  241. package/dist/cjs/ion-backdrop.cjs.entry.js +10 -7
  242. package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +54 -18
  243. package/dist/cjs/ion-button_2.cjs.entry.js +59 -22
  244. package/dist/cjs/ion-card_5.cjs.entry.js +55 -33
  245. package/dist/cjs/ion-checkbox.cjs.entry.js +34 -16
  246. package/dist/cjs/ion-chip.cjs.entry.js +50 -9
  247. package/dist/cjs/ion-col_3.cjs.entry.js +54 -57
  248. package/dist/cjs/ion-datetime-button.cjs.entry.js +13 -9
  249. package/dist/cjs/ion-datetime_3.cjs.entry.js +116 -41
  250. package/dist/cjs/ion-divider.cjs.entry.js +51 -0
  251. package/dist/cjs/ion-fab_3.cjs.entry.js +44 -28
  252. package/dist/cjs/ion-img.cjs.entry.js +8 -4
  253. package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +93 -17
  254. package/dist/cjs/ion-input-otp.cjs.entry.js +74 -9
  255. package/dist/cjs/ion-input-password-toggle.cjs.entry.js +53 -15
  256. package/dist/cjs/ion-input.cjs.entry.js +124 -34
  257. package/dist/cjs/ion-item-option_3.cjs.entry.js +186 -21
  258. package/dist/cjs/ion-item_8.cjs.entry.js +116 -49
  259. package/dist/cjs/ion-loading.cjs.entry.js +22 -19
  260. package/dist/cjs/ion-menu_3.cjs.entry.js +47 -29
  261. package/dist/cjs/ion-modal.cjs.entry.js +262 -138
  262. package/dist/cjs/ion-nav_2.cjs.entry.js +14 -11
  263. package/dist/cjs/ion-picker-column-option.cjs.entry.js +12 -8
  264. package/dist/cjs/ion-picker-column.cjs.entry.js +14 -14
  265. package/dist/cjs/ion-picker.cjs.entry.js +10 -6
  266. package/dist/cjs/ion-popover.cjs.entry.js +21 -19
  267. package/dist/cjs/ion-progress-bar.cjs.entry.js +27 -9
  268. package/dist/cjs/ion-radio_2.cjs.entry.js +35 -17
  269. package/dist/cjs/ion-range.cjs.entry.js +20 -13
  270. package/dist/cjs/ion-refresher_2.cjs.entry.js +42 -23
  271. package/dist/cjs/ion-reorder_2.cjs.entry.js +38 -14
  272. package/dist/cjs/ion-ripple-effect.cjs.entry.js +15 -7
  273. package/dist/cjs/ion-route_4.cjs.entry.js +10 -9
  274. package/dist/cjs/ion-searchbar.cjs.entry.js +137 -24
  275. package/dist/cjs/ion-segment-content.cjs.entry.js +2 -2
  276. package/dist/cjs/ion-segment-view.cjs.entry.js +6 -3
  277. package/dist/cjs/ion-segment_2.cjs.entry.js +23 -16
  278. package/dist/cjs/ion-select-modal.cjs.entry.js +97 -40
  279. package/dist/cjs/ion-select_3.cjs.entry.js +453 -84
  280. package/dist/cjs/ion-spinner.cjs.entry.js +30 -8
  281. package/dist/cjs/ion-split-pane.cjs.entry.js +12 -9
  282. package/dist/cjs/ion-tab-bar_2.cjs.entry.js +147 -23
  283. package/dist/cjs/ion-tab_2.cjs.entry.js +8 -7
  284. package/dist/cjs/ion-text.cjs.entry.js +7 -7
  285. package/dist/cjs/ion-textarea.cjs.entry.js +137 -23
  286. package/dist/cjs/ion-toast.cjs.entry.js +70 -46
  287. package/dist/cjs/ion-toggle.cjs.entry.js +82 -25
  288. package/dist/cjs/ionic-global-CSEbHD_F.js +519 -0
  289. package/dist/cjs/ionic.cjs.js +4 -4
  290. package/dist/cjs/{ios.transition-trBiC95R.js → ios.transition-UCjoxA3D.js} +7 -5
  291. package/dist/cjs/{keyboard-hHzlEQpk.js → keyboard-Bhav6x-R.js} +4 -3
  292. package/dist/cjs/{keyboard-UuAS4D_9.js → keyboard-Dsczf-iT.js} +1 -1
  293. package/dist/cjs/{keyboard-controller-GXBiBRKS.js → keyboard-controller-tqGDP9SU.js} +11 -9
  294. package/dist/cjs/list-a-7GSA6K.js +8 -0
  295. package/dist/cjs/loader.cjs.js +4 -4
  296. package/dist/cjs/{md.transition-CUQECuvD.js → md.transition-CNwlchQn.js} +6 -5
  297. package/dist/cjs/{notch-controller-sD-lTpdc.js → notch-controller-CgtkBzy0.js} +4 -4
  298. package/dist/cjs/{overlays-C2jiBSNQ.js → overlays-Hci_7vw_.js} +110 -16
  299. package/dist/cjs/select-option-render-C7klBX2H.js +81 -0
  300. package/dist/cjs/{status-tap-CCJk5VgT.js → status-tap-CTY2dMsZ.js} +4 -3
  301. package/dist/cjs/{swipe-back-BGhTQ1CU.js → swipe-back-jJFi5KCB.js} +3 -2
  302. package/dist/cjs/{theme-CeDs6Hcv.js → theme-IlOsGAz7.js} +25 -1
  303. package/dist/cjs/validity-QmuwEptc.js +51 -0
  304. package/dist/cjs/x-BTF99yFH.js +8 -0
  305. package/dist/collection/collection-manifest.json +1 -0
  306. package/dist/collection/components/accordion/accordion.ionic.css +201 -0
  307. package/dist/collection/components/accordion/accordion.ios.css +73 -58
  308. package/dist/collection/components/accordion/accordion.js +41 -27
  309. package/dist/collection/components/accordion/accordion.md.css +67 -59
  310. package/dist/collection/components/accordion-group/accordion-group.ionic.css +93 -0
  311. package/dist/collection/components/accordion-group/accordion-group.ios.css +16 -4
  312. package/dist/collection/components/accordion-group/accordion-group.js +44 -8
  313. package/dist/collection/components/accordion-group/accordion-group.md.css +22 -4
  314. package/dist/collection/components/action-sheet/action-sheet.ionic.css +834 -0
  315. package/dist/collection/components/action-sheet/action-sheet.ios.css +102 -6
  316. package/dist/collection/components/action-sheet/action-sheet.js +32 -13
  317. package/dist/collection/components/action-sheet/action-sheet.md.css +101 -5
  318. package/dist/collection/components/alert/alert.ionic.css +1165 -0
  319. package/dist/collection/components/alert/alert.ios.css +102 -1
  320. package/dist/collection/components/alert/alert.js +51 -30
  321. package/dist/collection/components/alert/alert.md.css +102 -1
  322. package/dist/collection/components/app/app.js +15 -83
  323. package/dist/collection/components/avatar/avatar.ionic.css +391 -0
  324. package/dist/collection/components/avatar/avatar.ios.css +7 -33
  325. package/dist/collection/components/avatar/avatar.js +120 -4
  326. package/dist/collection/components/avatar/avatar.md.css +51 -0
  327. package/dist/collection/components/back-button/back-button.ios.css +60 -48
  328. package/dist/collection/components/back-button/back-button.js +27 -19
  329. package/dist/collection/components/back-button/back-button.md.css +60 -48
  330. package/dist/collection/components/backdrop/backdrop.ionic.css +109 -0
  331. package/dist/collection/components/backdrop/backdrop.ios.css +56 -19
  332. package/dist/collection/components/backdrop/backdrop.js +12 -6
  333. package/dist/collection/components/backdrop/backdrop.md.css +56 -19
  334. package/dist/collection/components/badge/badge.ionic.css +275 -0
  335. package/dist/collection/components/badge/badge.ios.css +139 -12
  336. package/dist/collection/components/badge/badge.js +145 -9
  337. package/dist/collection/components/badge/badge.md.css +123 -12
  338. package/dist/collection/components/breadcrumb/breadcrumb.ios.css +20 -8
  339. package/dist/collection/components/breadcrumb/breadcrumb.js +43 -11
  340. package/dist/collection/components/breadcrumb/breadcrumb.md.css +20 -8
  341. package/dist/collection/components/breadcrumbs/breadcrumbs.ios.css +6 -0
  342. package/dist/collection/components/breadcrumbs/breadcrumbs.js +11 -9
  343. package/dist/collection/components/breadcrumbs/breadcrumbs.md.css +6 -0
  344. package/dist/collection/components/button/button.ionic.css +646 -0
  345. package/dist/collection/components/button/button.ios.css +154 -46
  346. package/dist/collection/components/button/button.js +63 -27
  347. package/dist/collection/components/button/button.md.css +150 -50
  348. package/dist/collection/components/buttons/buttons.ionic.css +97 -0
  349. package/dist/collection/components/buttons/buttons.ios.css +59 -7
  350. package/dist/collection/components/buttons/buttons.js +15 -9
  351. package/dist/collection/components/buttons/buttons.md.css +55 -3
  352. package/dist/collection/components/card/card.ionic.css +144 -0
  353. package/dist/collection/components/card/card.ios.css +65 -14
  354. package/dist/collection/components/card/card.js +41 -10
  355. package/dist/collection/components/card/card.md.css +65 -14
  356. package/dist/collection/components/card-content/card-content.ionic.css +89 -0
  357. package/dist/collection/components/card-content/card-content.ios.css +20 -35
  358. package/dist/collection/components/card-content/card-content.js +12 -10
  359. package/dist/collection/components/card-content/card-content.md.css +20 -35
  360. package/dist/collection/components/card-header/card-header.ionic.css +85 -0
  361. package/dist/collection/components/card-header/card-header.ios.css +27 -15
  362. package/dist/collection/components/card-header/card-header.js +13 -10
  363. package/dist/collection/components/card-header/card-header.md.css +27 -15
  364. package/dist/collection/components/card-subtitle/card-subtitle.ionic.css +144 -0
  365. package/dist/collection/components/card-subtitle/card-subtitle.ios.css +12 -0
  366. package/dist/collection/components/card-subtitle/card-subtitle.js +11 -8
  367. package/dist/collection/components/card-subtitle/card-subtitle.md.css +12 -0
  368. package/dist/collection/components/card-title/card-title.ios.css +73 -0
  369. package/dist/collection/components/card-title/card-title.js +11 -8
  370. package/dist/collection/components/card-title/card-title.md.css +73 -0
  371. package/dist/collection/components/checkbox/checkbox.ionic.css +539 -0
  372. package/dist/collection/components/checkbox/checkbox.ios.css +161 -101
  373. package/dist/collection/components/checkbox/checkbox.js +70 -14
  374. package/dist/collection/components/checkbox/checkbox.md.css +162 -102
  375. package/dist/collection/components/chip/chip.ionic.css +217 -0
  376. package/dist/collection/components/chip/chip.ios.css +67 -14
  377. package/dist/collection/components/chip/chip.js +108 -8
  378. package/dist/collection/components/chip/chip.md.css +67 -14
  379. package/dist/collection/components/col/col.css +192 -4
  380. package/dist/collection/components/col/col.js +210 -61
  381. package/dist/collection/components/content/content.css +8 -2
  382. package/dist/collection/components/content/content.js +16 -11
  383. package/dist/collection/components/datetime/datetime.ionic.css +703 -0
  384. package/dist/collection/components/datetime/datetime.ios.css +302 -106
  385. package/dist/collection/components/datetime/datetime.js +98 -20
  386. package/dist/collection/components/datetime/datetime.md.css +293 -96
  387. package/dist/collection/components/datetime/utils/data.js +5 -5
  388. package/dist/collection/components/datetime-button/datetime-button.ios.css +6 -0
  389. package/dist/collection/components/datetime-button/datetime-button.js +11 -8
  390. package/dist/collection/components/datetime-button/datetime-button.md.css +6 -0
  391. package/dist/collection/components/divider/divider.ionic.css +148 -0
  392. package/dist/collection/components/divider/divider.ios.css +87 -0
  393. package/dist/collection/components/divider/divider.js +94 -0
  394. package/dist/collection/components/divider/divider.md.css +87 -0
  395. package/dist/collection/components/fab/fab.css +25 -1
  396. package/dist/collection/components/fab/fab.js +9 -5
  397. package/dist/collection/components/fab-button/fab-button.ios.css +18 -6
  398. package/dist/collection/components/fab-button/fab-button.js +36 -21
  399. package/dist/collection/components/fab-button/fab-button.md.css +20 -8
  400. package/dist/collection/components/fab-list/fab-list.css +12 -0
  401. package/dist/collection/components/fab-list/fab-list.js +9 -5
  402. package/dist/collection/components/footer/footer.ios.css +14 -2
  403. package/dist/collection/components/footer/footer.js +21 -16
  404. package/dist/collection/components/footer/footer.md.css +12 -0
  405. package/dist/collection/components/grid/grid.css +12 -0
  406. package/dist/collection/components/grid/grid.js +9 -5
  407. package/dist/collection/components/header/header.ionic.css +97 -0
  408. package/dist/collection/components/header/header.ios.css +25 -10
  409. package/dist/collection/components/header/header.js +50 -19
  410. package/dist/collection/components/header/header.md.css +23 -8
  411. package/dist/collection/components/header/header.utils.js +5 -5
  412. package/dist/collection/components/img/img.js +8 -2
  413. package/dist/collection/components/infinite-scroll/infinite-scroll.js +100 -5
  414. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.ios.css +12 -0
  415. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +16 -10
  416. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.md.css +12 -0
  417. package/dist/collection/components/input/input.ionic.css +889 -0
  418. package/dist/collection/components/input/input.ios.css +223 -135
  419. package/dist/collection/components/input/input.js +148 -37
  420. package/dist/collection/components/input/input.md.css +193 -207
  421. package/dist/collection/components/input-otp/input-otp.ionic.css +371 -0
  422. package/dist/collection/components/input-otp/input-otp.ios.css +105 -60
  423. package/dist/collection/components/input-otp/input-otp.js +73 -6
  424. package/dist/collection/components/input-otp/input-otp.md.css +105 -60
  425. package/dist/collection/components/input-password-toggle/input-password-toggle.ionic.css +78 -0
  426. package/dist/collection/components/input-password-toggle/input-password-toggle.js +48 -12
  427. package/dist/collection/components/input-password-toggle/input-password-toggle.native.css +61 -0
  428. package/dist/collection/components/item/item.ionic.css +508 -0
  429. package/dist/collection/components/item/item.ios.css +109 -69
  430. package/dist/collection/components/item/item.js +51 -20
  431. package/dist/collection/components/item/item.md.css +120 -68
  432. package/dist/collection/components/item-divider/item-divider.ios.css +18 -0
  433. package/dist/collection/components/item-divider/item-divider.js +11 -8
  434. package/dist/collection/components/item-divider/item-divider.md.css +18 -0
  435. package/dist/collection/components/item-group/item-group.ios.css +12 -0
  436. package/dist/collection/components/item-group/item-group.js +13 -7
  437. package/dist/collection/components/item-group/item-group.md.css +12 -0
  438. package/dist/collection/components/item-option/item-option.ionic.css +278 -0
  439. package/dist/collection/components/item-option/item-option.ios.css +136 -29
  440. package/dist/collection/components/item-option/item-option.js +73 -9
  441. package/dist/collection/components/item-option/item-option.md.css +136 -29
  442. package/dist/collection/components/item-options/item-options.ionic.css +221 -0
  443. package/dist/collection/components/item-options/item-options.ios.css +77 -34
  444. package/dist/collection/components/item-options/item-options.js +13 -7
  445. package/dist/collection/components/item-options/item-options.md.css +77 -34
  446. package/dist/collection/components/item-sliding/item-sliding.css +6 -0
  447. package/dist/collection/components/item-sliding/item-sliding.js +144 -4
  448. package/dist/collection/components/item-sliding/test/test.utils.js +13 -0
  449. package/dist/collection/components/label/label.ios.css +18 -0
  450. package/dist/collection/components/label/label.js +11 -8
  451. package/dist/collection/components/label/label.md.css +18 -0
  452. package/dist/collection/components/list/list.ionic.css +212 -0
  453. package/dist/collection/components/list/list.ios.css +54 -14
  454. package/dist/collection/components/list/list.js +48 -9
  455. package/dist/collection/components/list/list.md.css +56 -16
  456. package/dist/collection/components/list-header/list-header.ionic.css +190 -0
  457. package/dist/collection/components/list-header/list-header.ios.css +82 -38
  458. package/dist/collection/components/list-header/list-header.js +11 -8
  459. package/dist/collection/components/list-header/list-header.md.css +82 -38
  460. package/dist/collection/components/loading/loading.ios.css +13 -1
  461. package/dist/collection/components/loading/loading.js +14 -11
  462. package/dist/collection/components/loading/loading.md.css +13 -1
  463. package/dist/collection/components/menu/menu.ios.css +15 -3
  464. package/dist/collection/components/menu/menu.js +12 -7
  465. package/dist/collection/components/menu/menu.md.css +15 -3
  466. package/dist/collection/components/menu-button/menu-button.ionic.css +236 -0
  467. package/dist/collection/components/menu-button/menu-button.ios.css +48 -14
  468. package/dist/collection/components/menu-button/menu-button.js +26 -10
  469. package/dist/collection/components/menu-button/menu-button.md.css +49 -15
  470. package/dist/collection/components/menu-toggle/menu-toggle.js +8 -5
  471. package/dist/collection/components/modal/animations/ionic.enter.js +40 -0
  472. package/dist/collection/components/modal/animations/ionic.leave.js +28 -0
  473. package/dist/collection/components/modal/animations/sheet.js +8 -2
  474. package/dist/collection/components/modal/gestures/sheet.js +76 -10
  475. package/dist/collection/components/modal/modal.ionic.css +247 -0
  476. package/dist/collection/components/modal/modal.ios.css +178 -70
  477. package/dist/collection/components/modal/modal.js +50 -12
  478. package/dist/collection/components/modal/modal.md.css +178 -70
  479. package/dist/collection/components/nav/nav.css +7 -1
  480. package/dist/collection/components/nav/nav.js +11 -5
  481. package/dist/collection/components/nav-link/nav-link.js +5 -1
  482. package/dist/collection/components/note/note.ios.css +12 -0
  483. package/dist/collection/components/note/note.js +11 -8
  484. package/dist/collection/components/note/note.md.css +12 -0
  485. package/dist/collection/components/picker/picker.ios.css +15 -3
  486. package/dist/collection/components/picker/picker.js +8 -5
  487. package/dist/collection/components/picker/picker.md.css +15 -3
  488. package/dist/collection/components/picker-column/picker-column.css +9 -2
  489. package/dist/collection/components/picker-column/picker-column.js +8 -7
  490. package/dist/collection/components/picker-column-option/picker-column-option.ios.css +6 -0
  491. package/dist/collection/components/picker-column-option/picker-column-option.js +13 -7
  492. package/dist/collection/components/picker-column-option/picker-column-option.md.css +6 -0
  493. package/dist/collection/components/picker-legacy/picker.ios.css +13 -1
  494. package/dist/collection/components/picker-legacy/picker.js +7 -6
  495. package/dist/collection/components/picker-legacy/picker.md.css +13 -1
  496. package/dist/collection/components/picker-legacy-column/picker-column.ios.css +12 -0
  497. package/dist/collection/components/picker-legacy-column/picker-column.js +4 -4
  498. package/dist/collection/components/picker-legacy-column/picker-column.md.css +12 -0
  499. package/dist/collection/components/popover/popover.ionic.css +290 -0
  500. package/dist/collection/components/popover/popover.ios.css +29 -1
  501. package/dist/collection/components/popover/popover.js +18 -15
  502. package/dist/collection/components/popover/popover.md.css +29 -1
  503. package/dist/collection/components/progress-bar/progress-bar.ionic.css +287 -0
  504. package/dist/collection/components/progress-bar/progress-bar.ios.css +48 -17
  505. package/dist/collection/components/progress-bar/progress-bar.js +43 -7
  506. package/dist/collection/components/progress-bar/progress-bar.md.css +48 -17
  507. package/dist/collection/components/radio/radio.ionic.css +422 -0
  508. package/dist/collection/components/radio/radio.ios.css +134 -91
  509. package/dist/collection/components/radio/radio.js +14 -9
  510. package/dist/collection/components/radio/radio.md.css +134 -91
  511. package/dist/collection/components/radio-group/radio-group.ionic.css +119 -0
  512. package/dist/collection/components/radio-group/radio-group.ios.css +43 -19
  513. package/dist/collection/components/radio-group/radio-group.js +48 -7
  514. package/dist/collection/components/radio-group/radio-group.md.css +43 -19
  515. package/dist/collection/components/range/range.ionic.css +567 -0
  516. package/dist/collection/components/range/range.ios.css +128 -85
  517. package/dist/collection/components/range/range.js +16 -10
  518. package/dist/collection/components/range/range.md.css +128 -85
  519. package/dist/collection/components/refresher/refresher.ios.css +14 -1
  520. package/dist/collection/components/refresher/refresher.js +11 -8
  521. package/dist/collection/components/refresher/refresher.md.css +15 -2
  522. package/dist/collection/components/refresher-content/refresher-content.js +28 -7
  523. package/dist/collection/components/reorder/reorder.ios.css +6 -0
  524. package/dist/collection/components/reorder/reorder.js +33 -6
  525. package/dist/collection/components/reorder/reorder.md.css +6 -0
  526. package/dist/collection/components/reorder-group/reorder-group.css +6 -0
  527. package/dist/collection/components/reorder-group/reorder-group.js +8 -4
  528. package/dist/collection/components/ripple-effect/{ripple-effect.css → ripple-effect.common.css} +7 -1
  529. package/dist/collection/components/ripple-effect/ripple-effect.ionic.css +215 -0
  530. package/dist/collection/components/ripple-effect/ripple-effect.js +14 -6
  531. package/dist/collection/components/route/route.js +4 -0
  532. package/dist/collection/components/router/router.js +4 -0
  533. package/dist/collection/components/router-link/router-link.css +8 -2
  534. package/dist/collection/components/router-link/router-link.js +9 -5
  535. package/dist/collection/components/router-outlet/router-outlet.css +7 -1
  536. package/dist/collection/components/router-outlet/router-outlet.js +6 -3
  537. package/dist/collection/components/row/row.css +16 -0
  538. package/dist/collection/components/row/row.js +9 -2
  539. package/dist/collection/components/searchbar/searchbar.ionic.css +626 -0
  540. package/dist/collection/components/searchbar/searchbar.ios.css +56 -18
  541. package/dist/collection/components/searchbar/searchbar.js +180 -33
  542. package/dist/collection/components/searchbar/searchbar.md.css +56 -18
  543. package/dist/collection/components/segment/segment.ionic.css +115 -0
  544. package/dist/collection/components/segment/segment.ios.css +45 -2
  545. package/dist/collection/components/segment/segment.js +11 -8
  546. package/dist/collection/components/segment/segment.md.css +45 -2
  547. package/dist/collection/components/segment-button/segment-button.ionic.css +353 -0
  548. package/dist/collection/components/segment-button/segment-button.ios.css +146 -105
  549. package/dist/collection/components/segment-button/segment-button.js +11 -8
  550. package/dist/collection/components/segment-button/segment-button.md.css +148 -107
  551. package/dist/collection/components/segment-content/segment-content.js +1 -1
  552. package/dist/collection/components/segment-view/segment-view.ios.css +6 -0
  553. package/dist/collection/components/segment-view/segment-view.js +6 -4
  554. package/dist/collection/components/segment-view/segment-view.md.css +6 -0
  555. package/dist/collection/components/select/select.ionic.css +810 -0
  556. package/dist/collection/components/select/select.ios.css +348 -176
  557. package/dist/collection/components/select/select.js +434 -66
  558. package/dist/collection/components/select/select.md.css +364 -178
  559. package/dist/collection/components/select-modal/select-modal.ionic.css +154 -0
  560. package/dist/collection/components/select-modal/select-modal.ios.css +95 -0
  561. package/dist/collection/components/select-modal/select-modal.js +109 -32
  562. package/dist/collection/components/select-modal/select-modal.md.css +83 -0
  563. package/dist/collection/components/select-option/select-option.js +32 -2
  564. package/dist/collection/components/select-popover/select-popover.ionic.css +499 -0
  565. package/dist/collection/components/select-popover/select-popover.ios.css +100 -0
  566. package/dist/collection/components/select-popover/select-popover.js +72 -31
  567. package/dist/collection/components/select-popover/select-popover.md.css +100 -0
  568. package/dist/collection/components/skeleton-text/skeleton-text.css +6 -0
  569. package/dist/collection/components/skeleton-text/skeleton-text.js +9 -5
  570. package/dist/collection/components/spinner/{spinner.css → spinner.ionic.css} +78 -10
  571. package/dist/collection/components/spinner/spinner.js +47 -6
  572. package/dist/collection/components/spinner/spinner.native.css +199 -0
  573. package/dist/collection/components/split-pane/split-pane.ios.css +20 -2
  574. package/dist/collection/components/split-pane/split-pane.js +14 -8
  575. package/dist/collection/components/split-pane/split-pane.md.css +20 -2
  576. package/dist/collection/components/tab/tab.js +6 -2
  577. package/dist/collection/components/tab-bar/tab-bar.ionic.css +227 -0
  578. package/dist/collection/components/tab-bar/tab-bar.ios.css +71 -43
  579. package/dist/collection/components/tab-bar/tab-bar.js +171 -13
  580. package/dist/collection/components/tab-bar/tab-bar.md.css +71 -43
  581. package/dist/collection/components/tab-button/tab-button.ionic.css +348 -0
  582. package/dist/collection/components/tab-button/tab-button.ios.css +171 -95
  583. package/dist/collection/components/tab-button/tab-button.js +54 -9
  584. package/dist/collection/components/tab-button/tab-button.md.css +137 -93
  585. package/dist/collection/components/tabs/tabs.css +7 -1
  586. package/dist/collection/components/tabs/tabs.js +4 -1
  587. package/dist/collection/components/text/text.css +6 -0
  588. package/dist/collection/components/text/text.js +7 -6
  589. package/dist/collection/components/textarea/textarea.ionic.css +898 -0
  590. package/dist/collection/components/textarea/textarea.ios.css +298 -158
  591. package/dist/collection/components/textarea/textarea.js +162 -24
  592. package/dist/collection/components/textarea/textarea.md.css +312 -159
  593. package/dist/collection/components/thumbnail/thumbnail.css +6 -0
  594. package/dist/collection/components/thumbnail/thumbnail.js +9 -2
  595. package/dist/collection/components/title/title.ionic.css +127 -0
  596. package/dist/collection/components/title/title.ios.css +32 -4
  597. package/dist/collection/components/title/title.js +13 -7
  598. package/dist/collection/components/title/title.md.css +32 -4
  599. package/dist/collection/components/toast/animations/utils.js +1 -1
  600. package/dist/collection/components/toast/toast.ionic.css +394 -0
  601. package/dist/collection/components/toast/toast.ios.css +84 -45
  602. package/dist/collection/components/toast/toast.js +76 -13
  603. package/dist/collection/components/toast/toast.md.css +84 -45
  604. package/dist/collection/components/toggle/toggle.ionic.css +508 -0
  605. package/dist/collection/components/toggle/toggle.ios.css +247 -131
  606. package/dist/collection/components/toggle/toggle.js +73 -18
  607. package/dist/collection/components/toggle/toggle.md.css +244 -131
  608. package/dist/collection/components/toolbar/test/image.svg +1 -0
  609. package/dist/collection/components/toolbar/toolbar.ionic.css +249 -0
  610. package/dist/collection/components/toolbar/toolbar.ios.css +90 -47
  611. package/dist/collection/components/toolbar/toolbar.js +218 -13
  612. package/dist/collection/components/toolbar/toolbar.md.css +90 -47
  613. package/dist/collection/global/ionic-global.js +241 -13
  614. package/dist/collection/utils/focus-trap.js +13 -2
  615. package/dist/collection/utils/focus-visible.js +22 -0
  616. package/dist/collection/utils/forms/validity.js +31 -0
  617. package/dist/collection/utils/framework-delegate.js +3 -1
  618. package/dist/collection/utils/hardware-back-button.js +15 -0
  619. package/dist/collection/utils/helpers.js +57 -3
  620. package/dist/collection/utils/keyboard/keyboard-controller.js +3 -1
  621. package/dist/collection/utils/menu-controller/animations/overlay.js +3 -3
  622. package/dist/collection/utils/menu-controller/animations/push.js +2 -1
  623. package/dist/collection/utils/menu-controller/animations/reveal.js +2 -1
  624. package/dist/collection/utils/overlays.js +91 -6
  625. package/dist/collection/utils/select-option-render.js +76 -0
  626. package/dist/collection/utils/test/playwright/drag-element.js +32 -9
  627. package/dist/collection/utils/test/playwright/generator.js +48 -23
  628. package/dist/collection/utils/test/playwright/page/utils/goto.js +14 -5
  629. package/dist/collection/utils/test/playwright/page/utils/set-content.js +26 -3
  630. package/dist/collection/utils/theme.js +25 -1
  631. package/dist/collection/utils/transition/ios.transition.js +1 -0
  632. package/dist/docs.json +8570 -283
  633. package/dist/esm/{animation-CnGMT4ji.js → animation-Cqe2x-Pt.js} +2 -2
  634. package/dist/esm/{app-globals-DhZjtldk.js → app-globals-Dk1rB3aE.js} +1 -1
  635. package/dist/esm/{button-active-BBx21brx.js → button-active-g6ZnZzDZ.js} +2 -2
  636. package/dist/esm/{capacitor-CFERIeaU.js → capacitor-C4lYa1nV.js} +1 -1
  637. package/dist/esm/caret-down-D1t981Ih.js +6 -0
  638. package/dist/esm/caret-left-fIOYmaqA.js +6 -0
  639. package/dist/esm/caret-right-BYSs-jZz.js +6 -0
  640. package/dist/esm/config-BwKpO3Is.js +31 -0
  641. package/dist/esm/{data-B9iGR5YO.js → data-BNKYavC3.js} +6 -6
  642. package/dist/esm/{focus-visible-BmVRXR1y.js → focus-visible-vXpMhGrs.js} +23 -1
  643. package/dist/esm/{framework-delegate-CyxE1S_P.js → framework-delegate-CjVwn_KZ.js} +4 -2
  644. package/dist/esm/{haptic-DzAMWJuk.js → haptic-_88k1V5U.js} +1 -1
  645. package/dist/esm/{helpers-Tl8jw6S2.js → helpers-Do7zwvM1.js} +58 -5
  646. package/dist/esm/{index-hW6eNZ3o.js → index-BmkLokUL.js} +2 -2
  647. package/dist/esm/{index-BtUdxPjv.js → index-C5t9-ciC.js} +4 -3
  648. package/dist/esm/{index-B-hkiOUh.js → index-CGthURny.js} +4 -4
  649. package/dist/esm/{index-DV3sJJW8.js → index-D2tu5BUg.js} +2 -1
  650. package/dist/esm/{config-TO1rZH52.js → index-D4ugF_sT.js} +2 -29
  651. package/dist/esm/{index-IGIE5vDm.js → index-Omi_TcwW.js} +41 -4
  652. package/dist/esm/{index-B2KwgBLx.js → index-hpH08p5s.js} +11 -11
  653. package/dist/esm/index.js +14 -14
  654. package/dist/esm/{input-shims-AaDhOpKN.js → input-shims-vDjCsx95.js} +7 -6
  655. package/dist/esm/{input.utils-Bxa_DQ7-.js → input.utils-B9Q5xHp6.js} +3 -3
  656. package/dist/esm/ion-accordion_2.entry.js +61 -29
  657. package/dist/esm/ion-action-sheet.entry.js +41 -22
  658. package/dist/esm/ion-alert.entry.js +61 -40
  659. package/dist/esm/ion-app_8.entry.js +292 -157
  660. package/dist/esm/ion-avatar_3.entry.js +125 -13
  661. package/dist/esm/ion-back-button.entry.js +31 -22
  662. package/dist/esm/ion-backdrop.entry.js +10 -7
  663. package/dist/esm/ion-breadcrumb_2.entry.js +54 -18
  664. package/dist/esm/ion-button_2.entry.js +59 -22
  665. package/dist/esm/ion-card_5.entry.js +55 -33
  666. package/dist/esm/ion-checkbox.entry.js +34 -16
  667. package/dist/esm/ion-chip.entry.js +50 -9
  668. package/dist/esm/ion-col_3.entry.js +54 -57
  669. package/dist/esm/ion-datetime-button.entry.js +13 -9
  670. package/dist/esm/ion-datetime_3.entry.js +116 -41
  671. package/dist/esm/ion-divider.entry.js +49 -0
  672. package/dist/esm/ion-fab_3.entry.js +44 -28
  673. package/dist/esm/ion-img.entry.js +8 -4
  674. package/dist/esm/ion-infinite-scroll_2.entry.js +92 -16
  675. package/dist/esm/ion-input-otp.entry.js +74 -9
  676. package/dist/esm/ion-input-password-toggle.entry.js +53 -15
  677. package/dist/esm/ion-input.entry.js +124 -34
  678. package/dist/esm/ion-item-option_3.entry.js +186 -21
  679. package/dist/esm/ion-item_8.entry.js +116 -49
  680. package/dist/esm/ion-loading.entry.js +21 -18
  681. package/dist/esm/ion-menu_3.entry.js +47 -29
  682. package/dist/esm/ion-modal.entry.js +215 -91
  683. package/dist/esm/ion-nav_2.entry.js +14 -11
  684. package/dist/esm/ion-picker-column-option.entry.js +12 -8
  685. package/dist/esm/ion-picker-column.entry.js +13 -13
  686. package/dist/esm/ion-picker.entry.js +10 -6
  687. package/dist/esm/ion-popover.entry.js +21 -19
  688. package/dist/esm/ion-progress-bar.entry.js +27 -9
  689. package/dist/esm/ion-radio_2.entry.js +35 -17
  690. package/dist/esm/ion-range.entry.js +20 -13
  691. package/dist/esm/ion-refresher_2.entry.js +40 -21
  692. package/dist/esm/ion-reorder_2.entry.js +38 -14
  693. package/dist/esm/ion-ripple-effect.entry.js +15 -7
  694. package/dist/esm/ion-route_4.entry.js +10 -9
  695. package/dist/esm/ion-searchbar.entry.js +137 -24
  696. package/dist/esm/ion-segment-content.entry.js +2 -2
  697. package/dist/esm/ion-segment-view.entry.js +6 -3
  698. package/dist/esm/ion-segment_2.entry.js +23 -16
  699. package/dist/esm/ion-select-modal.entry.js +97 -40
  700. package/dist/esm/ion-select_3.entry.js +453 -84
  701. package/dist/esm/ion-spinner.entry.js +30 -8
  702. package/dist/esm/ion-split-pane.entry.js +12 -9
  703. package/dist/esm/ion-tab-bar_2.entry.js +147 -23
  704. package/dist/esm/ion-tab_2.entry.js +8 -7
  705. package/dist/esm/ion-text.entry.js +7 -7
  706. package/dist/esm/ion-textarea.entry.js +137 -23
  707. package/dist/esm/ion-toast.entry.js +45 -21
  708. package/dist/esm/ion-toggle.entry.js +82 -25
  709. package/dist/esm/ionic-global-CAZb-5i-.js +508 -0
  710. package/dist/esm/ionic.js +5 -5
  711. package/dist/esm/{ios.transition--aMF-pDH.js → ios.transition-CzSncKQg.js} +7 -5
  712. package/dist/esm/{keyboard-CUw4ekVy.js → keyboard-Cpw6xVLJ.js} +1 -1
  713. package/dist/esm/{keyboard-ywgs5efA.js → keyboard-DJpS2IGK.js} +4 -3
  714. package/dist/esm/{keyboard-controller-BaaVITYt.js → keyboard-controller-CAc33ylR.js} +5 -3
  715. package/dist/esm/list-Dhi5xtNS.js +6 -0
  716. package/dist/esm/loader.js +5 -5
  717. package/dist/esm/{md.transition-BEVbfm8j.js → md.transition-DIsWqYBZ.js} +6 -5
  718. package/dist/esm/{notch-controller-DAcvKU57.js → notch-controller-DiBq57w8.js} +2 -2
  719. package/dist/esm/{overlays-F8GHPo-e.js → overlays-rwDDzEs4.js} +107 -13
  720. package/dist/esm/select-option-render-B2qc5ZP7.js +79 -0
  721. package/dist/esm/{status-tap-BfJqFSLF.js → status-tap-fYFdZg6z.js} +4 -3
  722. package/dist/esm/{swipe-back-BZBFwTQV.js → swipe-back-BzGqTrrq.js} +3 -2
  723. package/dist/esm/{theme-DiVJyqlX.js → theme-DaJxRxSQ.js} +25 -1
  724. package/dist/esm/validity-BjW8SOqw.js +48 -0
  725. package/dist/esm/x-BDqjX7Z_.js +6 -0
  726. package/dist/html.html-data.json +2463 -99
  727. package/dist/ionic/index.esm.js +1 -1
  728. package/dist/ionic/ionic.esm.js +1 -1
  729. package/dist/ionic/p-07d3388f.entry.js +4 -0
  730. package/dist/ionic/p-091a95ea.entry.js +4 -0
  731. package/dist/ionic/p-11nqcMM3.js +4 -0
  732. package/dist/ionic/p-139d02eb.entry.js +4 -0
  733. package/dist/ionic/p-1855fcb6.entry.js +4 -0
  734. package/dist/ionic/p-192e7509.entry.js +4 -0
  735. package/dist/ionic/p-1faf270d.entry.js +4 -0
  736. package/dist/ionic/p-228b6a9c.entry.js +4 -0
  737. package/dist/ionic/p-2311e660.entry.js +4 -0
  738. package/dist/ionic/p-2aa44c65.entry.js +4 -0
  739. package/dist/ionic/p-2bf931ae.entry.js +4 -0
  740. package/dist/ionic/p-2effd05d.entry.js +4 -0
  741. package/dist/ionic/p-308beb71.entry.js +4 -0
  742. package/dist/ionic/p-3093958a.entry.js +4 -0
  743. package/dist/ionic/p-37ccbee4.entry.js +4 -0
  744. package/dist/ionic/p-3aba19e2.entry.js +4 -0
  745. package/dist/ionic/p-3bf01c2c.entry.js +4 -0
  746. package/dist/ionic/p-4091ad21.entry.js +4 -0
  747. package/dist/ionic/p-45825c2c.entry.js +4 -0
  748. package/dist/ionic/p-4610e447.entry.js +4 -0
  749. package/dist/ionic/p-488992b6.entry.js +4 -0
  750. package/dist/ionic/p-4a0260e6.entry.js +4 -0
  751. package/dist/ionic/p-4c864eb2.entry.js +4 -0
  752. package/dist/ionic/p-4e46439d.entry.js +4 -0
  753. package/dist/ionic/p-50d90690.entry.js +4 -0
  754. package/dist/ionic/p-59b4f8d0.entry.js +4 -0
  755. package/dist/ionic/p-5a3fc28e.entry.js +4 -0
  756. package/dist/ionic/p-5ac21be2.entry.js +4 -0
  757. package/dist/ionic/p-64341e32.entry.js +4 -0
  758. package/dist/ionic/p-68c21b2a.entry.js +4 -0
  759. package/dist/ionic/p-6c8c37c2.entry.js +4 -0
  760. package/dist/ionic/p-6fbead83.entry.js +4 -0
  761. package/dist/ionic/p-7194f6fa.entry.js +4 -0
  762. package/dist/ionic/p-76d0e7ef.entry.js +4 -0
  763. package/dist/ionic/p-79ae0425.entry.js +4 -0
  764. package/dist/ionic/p-7d267dc6.entry.js +4 -0
  765. package/dist/ionic/p-8180abe5.entry.js +4 -0
  766. package/dist/ionic/p-8516eb69.entry.js +4 -0
  767. package/dist/ionic/p-8uDL7fql.js +4 -0
  768. package/dist/ionic/p-96549175.entry.js +4 -0
  769. package/dist/ionic/p-98c34fd7.entry.js +4 -0
  770. package/dist/ionic/p-9b9b1450.entry.js +4 -0
  771. package/dist/ionic/p-BDqjX7Z_.js +4 -0
  772. package/dist/ionic/p-BYSs-jZz.js +4 -0
  773. package/dist/ionic/p-BjW8SOqw.js +4 -0
  774. package/{components/p-9VcRUwdB.js → dist/ionic/p-BsfuYVMP.js} +1 -1
  775. package/dist/ionic/p-BwKpO3Is.js +4 -0
  776. package/dist/ionic/p-Bx0bt2Ar.js +4 -0
  777. package/dist/ionic/p-C2mpVKI1.js +4 -0
  778. package/dist/ionic/p-C4uUM9DM.js +4 -0
  779. package/dist/ionic/p-C5zxLmJ_.js +4 -0
  780. package/{components/p-BS1TtEiJ.js → dist/ionic/p-C8IHbcuP.js} +1 -1
  781. package/dist/ionic/p-CBV-BGvD.js +4 -0
  782. package/dist/ionic/p-CDn0uNJA.js +4 -0
  783. package/dist/ionic/p-CFjI63GE.js +4 -0
  784. package/dist/ionic/p-CHE1xWbg.js +4 -0
  785. package/dist/ionic/p-CIk5QtPm.js +4 -0
  786. package/dist/ionic/p-CQKe4n56.js +4 -0
  787. package/dist/ionic/p-CVp2D--1.js +4 -0
  788. package/dist/ionic/p-CWJdc8f_.js +4 -0
  789. package/dist/ionic/p-CXqdKf1K.js +4 -0
  790. package/dist/ionic/p-Cb-0O4h8.js +4 -0
  791. package/dist/ionic/{p-CKvCXMs9.js → p-CbkICFBN.js} +1 -1
  792. package/dist/ionic/p-D1t981Ih.js +4 -0
  793. package/dist/ionic/p-D2tu5BUg.js +4 -0
  794. package/dist/ionic/{p-B8xlpH8p.js → p-DKWXAwlR.js} +1 -1
  795. package/dist/ionic/p-DaJxRxSQ.js +4 -0
  796. package/dist/ionic/p-Dhi5xtNS.js +4 -0
  797. package/dist/ionic/p-DoyDJ2X5.js +4 -0
  798. package/dist/ionic/p-FvDKM4Ax.js +4 -0
  799. package/dist/ionic/p-Omi_TcwW.js +5 -0
  800. package/{components/p-D13Eaw-8.js → dist/ionic/p-SJmaFQ0H.js} +1 -1
  801. package/dist/ionic/p-SOASChNu.js +4 -0
  802. package/dist/ionic/{p-DjriolRs.js → p-ZqkJDyhe.js} +1 -1
  803. package/dist/ionic/p-a53a3ecc.entry.js +4 -0
  804. package/dist/ionic/p-acdc21a6.entry.js +4 -0
  805. package/dist/ionic/p-ae4ea663.entry.js +4 -0
  806. package/dist/ionic/p-b0c54b4c.entry.js +4 -0
  807. package/dist/ionic/p-b8b20b7e.entry.js +4 -0
  808. package/dist/ionic/p-bc5713f7.entry.js +4 -0
  809. package/dist/ionic/p-d954cd19.entry.js +4 -0
  810. package/dist/ionic/p-e7f216ae.entry.js +4 -0
  811. package/dist/ionic/p-edb0b0c8.entry.js +4 -0
  812. package/dist/ionic/p-f02ba305.entry.js +4 -0
  813. package/dist/ionic/p-f061fcb7.entry.js +4 -0
  814. package/dist/ionic/p-f740c359.entry.js +4 -0
  815. package/dist/ionic/p-f85942f8.entry.js +4 -0
  816. package/dist/ionic/p-fIOYmaqA.js +4 -0
  817. package/dist/ionic/p-qETiT38a.js +4 -0
  818. package/dist/ionic/p-vXpMhGrs.js +4 -0
  819. package/dist/types/components/accordion/accordion.d.ts +6 -3
  820. package/dist/types/components/accordion-group/accordion-group.d.ts +12 -1
  821. package/dist/types/components/action-sheet/action-sheet-interface.d.ts +3 -7
  822. package/dist/types/components/action-sheet/action-sheet.d.ts +3 -2
  823. package/dist/types/components/alert/alert-interface.d.ts +3 -7
  824. package/dist/types/components/alert/alert.d.ts +3 -2
  825. package/dist/types/components/app/app.d.ts +4 -5
  826. package/dist/types/components/avatar/avatar.d.ts +32 -0
  827. package/dist/types/components/back-button/back-button.d.ts +2 -1
  828. package/dist/types/components/backdrop/backdrop.d.ts +4 -0
  829. package/dist/types/components/badge/badge.d.ts +34 -1
  830. package/dist/types/components/breadcrumb/breadcrumb.d.ts +4 -1
  831. package/dist/types/components/breadcrumbs/breadcrumbs.d.ts +2 -2
  832. package/dist/types/components/button/button.d.ts +23 -8
  833. package/dist/types/components/buttons/buttons.d.ts +5 -1
  834. package/dist/types/components/card/card.d.ts +8 -1
  835. package/dist/types/components/card-content/card-content.d.ts +2 -1
  836. package/dist/types/components/card-header/card-header.d.ts +3 -2
  837. package/dist/types/components/card-subtitle/card-subtitle.d.ts +2 -1
  838. package/dist/types/components/card-title/card-title.d.ts +2 -1
  839. package/dist/types/components/checkbox/checkbox.d.ts +14 -4
  840. package/dist/types/components/chip/chip.d.ts +26 -1
  841. package/dist/types/components/col/col.d.ts +52 -5
  842. package/dist/types/components/content/content.d.ts +3 -0
  843. package/dist/types/components/datetime/datetime.d.ts +26 -1
  844. package/dist/types/components/datetime/utils/data.d.ts +5 -5
  845. package/dist/types/components/datetime-button/datetime-button.d.ts +2 -1
  846. package/dist/types/components/divider/divider.d.ts +20 -0
  847. package/dist/types/components/fab/fab.d.ts +4 -0
  848. package/dist/types/components/fab-button/fab-button.d.ts +5 -3
  849. package/dist/types/components/fab-list/fab-list.d.ts +4 -0
  850. package/dist/types/components/footer/footer.d.ts +4 -3
  851. package/dist/types/components/grid/grid.d.ts +4 -0
  852. package/dist/types/components/header/header.d.ts +9 -3
  853. package/dist/types/components/header/header.utils.d.ts +3 -3
  854. package/dist/types/components/img/img.d.ts +3 -0
  855. package/dist/types/components/infinite-scroll/infinite-scroll.d.ts +21 -0
  856. package/dist/types/components/infinite-scroll-content/infinite-scroll-content.d.ts +4 -0
  857. package/dist/types/components/input/input.d.ts +31 -5
  858. package/dist/types/components/input-otp/input-otp.d.ts +37 -0
  859. package/dist/types/components/input-password-toggle/input-password-toggle.d.ts +2 -0
  860. package/dist/types/components/item/item.d.ts +11 -4
  861. package/dist/types/components/item-divider/item-divider.d.ts +2 -1
  862. package/dist/types/components/item-group/item-group.d.ts +4 -0
  863. package/dist/types/components/item-option/item-option.d.ts +18 -1
  864. package/dist/types/components/item-options/item-options.d.ts +4 -0
  865. package/dist/types/components/item-sliding/item-sliding.d.ts +32 -1
  866. package/dist/types/components/item-sliding/test/test.utils.d.ts +13 -0
  867. package/dist/types/components/label/label.d.ts +2 -1
  868. package/dist/types/components/list/list.d.ts +15 -1
  869. package/dist/types/components/list-header/list-header.d.ts +2 -1
  870. package/dist/types/components/loading/loading-interface.d.ts +2 -7
  871. package/dist/types/components/loading/loading.d.ts +3 -2
  872. package/dist/types/components/menu/menu.d.ts +3 -0
  873. package/dist/types/components/menu-button/menu-button.d.ts +3 -1
  874. package/dist/types/components/menu-toggle/menu-toggle.d.ts +3 -0
  875. package/dist/types/components/modal/animations/ionic.enter.d.ts +6 -0
  876. package/dist/types/components/modal/animations/ionic.leave.d.ts +6 -0
  877. package/dist/types/components/modal/gestures/sheet.d.ts +1 -1
  878. package/dist/types/components/modal/modal-interface.d.ts +4 -7
  879. package/dist/types/components/modal/modal.d.ts +11 -1
  880. package/dist/types/components/nav/nav-interface.d.ts +9 -1
  881. package/dist/types/components/nav/nav.d.ts +5 -1
  882. package/dist/types/components/nav-link/nav-link.d.ts +4 -0
  883. package/dist/types/components/note/note.d.ts +2 -1
  884. package/dist/types/components/picker/picker.d.ts +2 -1
  885. package/dist/types/components/picker-column/picker-column.d.ts +2 -1
  886. package/dist/types/components/picker-column-option/picker-column-option.d.ts +4 -0
  887. package/dist/types/components/picker-legacy/picker.d.ts +2 -1
  888. package/dist/types/components/popover/popover-interface.d.ts +3 -6
  889. package/dist/types/components/popover/popover.d.ts +6 -5
  890. package/dist/types/components/progress-bar/progress-bar.d.ts +10 -1
  891. package/dist/types/components/radio/radio.d.ts +2 -1
  892. package/dist/types/components/radio-group/radio-group.d.ts +12 -0
  893. package/dist/types/components/range/range.d.ts +2 -1
  894. package/dist/types/components/refresher/refresher.d.ts +2 -1
  895. package/dist/types/components/refresher-content/refresher-content.d.ts +4 -0
  896. package/dist/types/components/reorder/reorder.d.ts +9 -0
  897. package/dist/types/components/reorder-group/reorder-group.d.ts +4 -0
  898. package/dist/types/components/ripple-effect/ripple-effect.d.ts +4 -0
  899. package/dist/types/components/route/route.d.ts +4 -0
  900. package/dist/types/components/router/router.d.ts +4 -0
  901. package/dist/types/components/router-link/router-link.d.ts +4 -0
  902. package/dist/types/components/router-outlet/router-outlet.d.ts +4 -1
  903. package/dist/types/components/row/row.d.ts +4 -0
  904. package/dist/types/components/searchbar/searchbar.d.ts +51 -9
  905. package/dist/types/components/segment/segment.d.ts +2 -1
  906. package/dist/types/components/segment-button/segment-button.d.ts +2 -1
  907. package/dist/types/components/select/select-interface.d.ts +23 -0
  908. package/dist/types/components/select/select.d.ts +66 -13
  909. package/dist/types/components/select-modal/select-modal.d.ts +8 -0
  910. package/dist/types/components/select-option/select-option.d.ts +12 -0
  911. package/dist/types/components/select-popover/select-popover.d.ts +3 -0
  912. package/dist/types/components/skeleton-text/skeleton-text.d.ts +4 -0
  913. package/dist/types/components/spinner/spinner.d.ts +15 -0
  914. package/dist/types/components/split-pane/split-pane.d.ts +4 -0
  915. package/dist/types/components/tab/tab.d.ts +4 -0
  916. package/dist/types/components/tab-bar/tab-bar.d.ts +37 -2
  917. package/dist/types/components/tab-button/tab-button.d.ts +12 -1
  918. package/dist/types/components/tabs/tabs.d.ts +3 -0
  919. package/dist/types/components/text/text.d.ts +2 -1
  920. package/dist/types/components/textarea/textarea.d.ts +53 -4
  921. package/dist/types/components/thumbnail/thumbnail.d.ts +4 -0
  922. package/dist/types/components/title/title.d.ts +4 -0
  923. package/dist/types/components/toast/animations/utils.d.ts +2 -2
  924. package/dist/types/components/toast/toast-interface.d.ts +3 -7
  925. package/dist/types/components/toast/toast.d.ts +19 -2
  926. package/dist/types/components/toggle/toggle.d.ts +15 -1
  927. package/dist/types/components/toolbar/toolbar.d.ts +43 -3
  928. package/dist/types/components.d.ts +1727 -206
  929. package/dist/types/global/ionic-global.d.ts +28 -2
  930. package/dist/types/interface.d.ts +3 -0
  931. package/dist/types/utils/config.d.ts +106 -2
  932. package/dist/types/utils/focus-trap.d.ts +1 -1
  933. package/dist/types/utils/focus-visible.d.ts +13 -0
  934. package/dist/types/utils/forms/validity.d.ts +7 -0
  935. package/dist/types/utils/helpers.d.ts +11 -0
  936. package/dist/types/utils/overlays-interface.d.ts +31 -1
  937. package/dist/types/utils/overlays.d.ts +1 -1
  938. package/dist/types/utils/select-option-render.d.ts +22 -0
  939. package/dist/types/utils/test/playwright/drag-element.d.ts +16 -3
  940. package/dist/types/utils/test/playwright/generator.d.ts +31 -2
  941. package/dist/types/utils/theme.d.ts +9 -0
  942. package/hydrate/index.js +4337 -1299
  943. package/hydrate/index.mjs +4337 -1299
  944. package/package.json +8 -4
  945. package/components/p-1KVKSLu5.js +0 -4
  946. package/components/p-B6FQ0cKR.js +0 -4
  947. package/components/p-B6HaBl3o.js +0 -4
  948. package/components/p-B8b1Ukl9.js +0 -4
  949. package/components/p-BGHGpkPX.js +0 -4
  950. package/components/p-BJoMtgfR.js +0 -4
  951. package/components/p-BNAG-aVv.js +0 -4
  952. package/components/p-BR3tZJmu.js +0 -4
  953. package/components/p-BSB38Tek.js +0 -4
  954. package/components/p-BTeL5HCK.js +0 -4
  955. package/components/p-BUbsoBOV.js +0 -4
  956. package/components/p-BYDc3hSE.js +0 -4
  957. package/components/p-BagjAGC0.js +0 -4
  958. package/components/p-BegtE7nr.js +0 -4
  959. package/components/p-BgwEQWW6.js +0 -4
  960. package/components/p-BlNv564p.js +0 -4
  961. package/components/p-BmVRXR1y.js +0 -4
  962. package/components/p-BxwWvu-b.js +0 -4
  963. package/components/p-C4jPsTQa.js +0 -4
  964. package/components/p-C59ryAuS.js +0 -4
  965. package/components/p-CBzELu-H.js +0 -4
  966. package/components/p-CDfQnFrd.js +0 -4
  967. package/components/p-CH0NYjKq.js +0 -4
  968. package/components/p-CIGNaXM1.js +0 -4
  969. package/components/p-CO7fmmxt.js +0 -4
  970. package/components/p-CU1SSH8_.js +0 -4
  971. package/components/p-CgfaEEem.js +0 -4
  972. package/components/p-CgqKJg96.js +0 -4
  973. package/components/p-CneGxKsZ.js +0 -4
  974. package/components/p-CoA-aqGF.js +0 -4
  975. package/components/p-Cq8cQ0NL.js +0 -4
  976. package/components/p-Csw8xuz4.js +0 -4
  977. package/components/p-CtWGkNnJ.js +0 -4
  978. package/components/p-Cy5XSfIk.js +0 -4
  979. package/components/p-Cyxa_4PV.js +0 -4
  980. package/components/p-Cz5nLPGT.js +0 -4
  981. package/components/p-D-cP12ZN.js +0 -4
  982. package/components/p-D6NJwNJN.js +0 -4
  983. package/components/p-D6Ynv7Xh.js +0 -4
  984. package/components/p-DHsZWn1l.js +0 -4
  985. package/components/p-DJMZehmW.js +0 -4
  986. package/components/p-DJztqcrH.js +0 -4
  987. package/components/p-DUqnmRFi.js +0 -4
  988. package/components/p-DYdpXONG.js +0 -4
  989. package/components/p-DgbT0exM.js +0 -4
  990. package/components/p-DiVJyqlX.js +0 -4
  991. package/components/p-DvOO1fxp.js +0 -4
  992. package/components/p-FBcnjE5W.js +0 -4
  993. package/components/p-SBseW5KJ.js +0 -4
  994. package/components/p-ZjP4CjeZ.js +0 -4
  995. package/components/p-fpbh6w3f.js +0 -4
  996. package/components/p-kvaDs24J.js +0 -4
  997. package/components/p-vEbVo2hO.js +0 -4
  998. package/dist/cjs/hardware-back-button-C4rMJ5uI.js +0 -121
  999. package/dist/cjs/index-DkNv4J_i.js +0 -10
  1000. package/dist/cjs/ionic-global-Bc3kJi1Z.js +0 -151
  1001. package/dist/cjs/validity-BpS37YFM.js +0 -19
  1002. package/dist/esm/hardware-back-button-CTe4XmL7.js +0 -115
  1003. package/dist/esm/index-ZjP4CjeZ.js +0 -7
  1004. package/dist/esm/ionic-global-DfbeLwcV.js +0 -146
  1005. package/dist/esm/validity-DJztqcrH.js +0 -17
  1006. package/dist/ionic/p-031b76f7.entry.js +0 -4
  1007. package/dist/ionic/p-045a6a42.entry.js +0 -4
  1008. package/dist/ionic/p-07506134.entry.js +0 -4
  1009. package/dist/ionic/p-078037da.entry.js +0 -4
  1010. package/dist/ionic/p-084c25b2.entry.js +0 -4
  1011. package/dist/ionic/p-0d8b5c38.entry.js +0 -4
  1012. package/dist/ionic/p-16813ce7.entry.js +0 -4
  1013. package/dist/ionic/p-1b02923f.entry.js +0 -4
  1014. package/dist/ionic/p-1b169fb6.entry.js +0 -4
  1015. package/dist/ionic/p-23ec35e4.entry.js +0 -4
  1016. package/dist/ionic/p-23fac490.entry.js +0 -4
  1017. package/dist/ionic/p-28a9e720.entry.js +0 -4
  1018. package/dist/ionic/p-294f4bb5.entry.js +0 -4
  1019. package/dist/ionic/p-2a68388b.entry.js +0 -4
  1020. package/dist/ionic/p-2f5a8140.entry.js +0 -4
  1021. package/dist/ionic/p-2fd110aa.entry.js +0 -4
  1022. package/dist/ionic/p-301c43f8.entry.js +0 -4
  1023. package/dist/ionic/p-370a60ee.entry.js +0 -4
  1024. package/dist/ionic/p-4c67ce4c.entry.js +0 -4
  1025. package/dist/ionic/p-51c11c47.entry.js +0 -4
  1026. package/dist/ionic/p-53f750a5.entry.js +0 -4
  1027. package/dist/ionic/p-6af16209.entry.js +0 -4
  1028. package/dist/ionic/p-6b701daa.entry.js +0 -4
  1029. package/dist/ionic/p-6b97f2a3.entry.js +0 -4
  1030. package/dist/ionic/p-7620be24.entry.js +0 -4
  1031. package/dist/ionic/p-771b27a5.entry.js +0 -4
  1032. package/dist/ionic/p-7ca71c83.entry.js +0 -4
  1033. package/dist/ionic/p-80cac7a2.entry.js +0 -4
  1034. package/dist/ionic/p-87125490.entry.js +0 -4
  1035. package/dist/ionic/p-8fda6a62.entry.js +0 -4
  1036. package/dist/ionic/p-9833cf63.entry.js +0 -4
  1037. package/dist/ionic/p-9cbc6f1f.entry.js +0 -4
  1038. package/dist/ionic/p-9cdbabbb.entry.js +0 -4
  1039. package/dist/ionic/p-9eeaBrnk.js +0 -4
  1040. package/dist/ionic/p-BAt5H1ac.js +0 -4
  1041. package/dist/ionic/p-BW_TRJm8.js +0 -4
  1042. package/dist/ionic/p-BmVRXR1y.js +0 -4
  1043. package/dist/ionic/p-Bum7H1fw.js +0 -4
  1044. package/dist/ionic/p-BxIcPWoV.js +0 -4
  1045. package/dist/ionic/p-C0JvVFMv.js +0 -4
  1046. package/dist/ionic/p-CGmVTdWh.js +0 -4
  1047. package/dist/ionic/p-CIGNaXM1.js +0 -4
  1048. package/dist/ionic/p-CYbRmDdy.js +0 -4
  1049. package/dist/ionic/p-CYvM5g3q.js +0 -4
  1050. package/dist/ionic/p-CmFz1Mjc.js +0 -4
  1051. package/dist/ionic/p-CtA-yJYy.js +0 -4
  1052. package/dist/ionic/p-CtWGkNnJ.js +0 -4
  1053. package/dist/ionic/p-D8HJQ1qq.js +0 -4
  1054. package/dist/ionic/p-DB_iPQC-.js +0 -4
  1055. package/dist/ionic/p-DJztqcrH.js +0 -4
  1056. package/dist/ionic/p-DLbbmF9h.js +0 -4
  1057. package/dist/ionic/p-DTPR1Wpn.js +0 -4
  1058. package/dist/ionic/p-DV3sJJW8.js +0 -4
  1059. package/dist/ionic/p-DiVJyqlX.js +0 -4
  1060. package/dist/ionic/p-DtVZDHlS.js +0 -4
  1061. package/dist/ionic/p-IGIE5vDm.js +0 -5
  1062. package/dist/ionic/p-NFFyoJ4Q.js +0 -4
  1063. package/dist/ionic/p-ZjP4CjeZ.js +0 -4
  1064. package/dist/ionic/p-a805674e.entry.js +0 -4
  1065. package/dist/ionic/p-a84f2d21.entry.js +0 -4
  1066. package/dist/ionic/p-aa812c4b.entry.js +0 -4
  1067. package/dist/ionic/p-b325a113.entry.js +0 -4
  1068. package/dist/ionic/p-b5ea8cdd.entry.js +0 -4
  1069. package/dist/ionic/p-b6e0ff03.entry.js +0 -4
  1070. package/dist/ionic/p-bcaa827e.entry.js +0 -4
  1071. package/dist/ionic/p-c3cce9d8.entry.js +0 -4
  1072. package/dist/ionic/p-ca31010f.entry.js +0 -4
  1073. package/dist/ionic/p-d4e8b473.entry.js +0 -4
  1074. package/dist/ionic/p-e0287f41.entry.js +0 -4
  1075. package/dist/ionic/p-e663bc5a.entry.js +0 -4
  1076. package/dist/ionic/p-e6cedcd7.entry.js +0 -4
  1077. package/dist/ionic/p-e863ffe8.entry.js +0 -4
  1078. package/dist/ionic/p-f2deaceb.entry.js +0 -4
  1079. package/dist/ionic/p-f5dfb9a3.entry.js +0 -4
  1080. package/dist/ionic/p-f69a5f71.entry.js +0 -4
  1081. package/dist/ionic/p-f8186550.entry.js +0 -4
  1082. package/dist/ionic/p-fdbc90d4.entry.js +0 -4
  1083. package/dist/ionic/p-gbVXD275.js +0 -4
  1084. package/dist/ionic/p-hNN3VvaC.js +0 -4
  1085. /package/dist/collection/components/{input-password-toggle/input-password-toggle.css → refresher-content/refresher-content.css} +0 -0
@@ -6,7 +6,7 @@ import { focusFirstDescendant, focusLastDescendant, focusableQueryString } from
6
6
  import { shouldUseCloseWatcher } from "./hardware-back-button";
7
7
  import { printIonError, printIonWarning } from "./logging/index";
8
8
  import { config } from "../global/config";
9
- import { getIonMode } from "../global/ionic-global";
9
+ import { getIonMode, getIonTheme } from "../global/ionic-global";
10
10
  import { CoreDelegate } from "./framework-delegate";
11
11
  import { BACKDROP_NO_SCROLL } from "./gesture/gesture-controller";
12
12
  import { OVERLAY_BACK_BUTTON_PRIORITY } from "./hardware-back-button";
@@ -319,6 +319,86 @@ const connectListeners = (doc) => {
319
319
  doc.addEventListener('focus', (ev) => {
320
320
  trapKeyboardFocus(ev, doc);
321
321
  }, true);
322
+ // Listen for keydown events to intercept Tab navigation.
323
+ // This is needed for Safari and Firefox which may skip focusable
324
+ // elements or allow focus to escape the overlay.
325
+ // It also ensures proper focus delegation for shadow DOM elements
326
+ // like ion-textarea.
327
+ doc.addEventListener('keydown', (ev) => {
328
+ var _a, _b, _c;
329
+ if (ev.key !== 'Tab' && ev.key !== 'Alt+Tab')
330
+ return;
331
+ const lastOverlay = getPresentedOverlay(doc, 'ion-alert,ion-action-sheet,ion-loading,ion-modal,ion-picker-legacy,ion-popover');
332
+ if (!lastOverlay || lastOverlay.classList.contains(FOCUS_TRAP_DISABLE_CLASS))
333
+ return;
334
+ const activeElement = doc.activeElement;
335
+ if (activeElement === lastOverlay) {
336
+ ev.preventDefault();
337
+ focusFirstDescendant(lastOverlay);
338
+ return;
339
+ }
340
+ // Check if activeElement is inside the overlay (including shadow DOM)
341
+ const isInsideOverlay = activeElement
342
+ ? lastOverlay.contains(activeElement) ||
343
+ (activeElement.getRootNode() instanceof ShadowRoot &&
344
+ lastOverlay.contains(activeElement.getRootNode().host)) ||
345
+ ((_b = (_a = lastOverlay.shadowRoot) === null || _a === void 0 ? void 0 : _a.contains(activeElement)) !== null && _b !== void 0 ? _b : false)
346
+ : false;
347
+ if (!isInsideOverlay)
348
+ return;
349
+ // Get all focusable elements from both light and shadow DOM
350
+ const allFocusable = [
351
+ ...lastOverlay.querySelectorAll(focusableQueryString),
352
+ ...(((_c = lastOverlay.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelectorAll(focusableQueryString)) || []),
353
+ ];
354
+ if (allFocusable.length === 0) {
355
+ ev.preventDefault();
356
+ return;
357
+ }
358
+ // Find current element's index (accounting for shadow DOM)
359
+ const currentIndex = activeElement
360
+ ? allFocusable.findIndex((el) => {
361
+ var _a;
362
+ if (el === activeElement)
363
+ return true;
364
+ if ((_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.contains(activeElement))
365
+ return true;
366
+ const rootNode = activeElement.getRootNode();
367
+ return rootNode instanceof ShadowRoot && rootNode.host === el;
368
+ })
369
+ : -1;
370
+ ev.preventDefault();
371
+ // Helper to focus an element, handling shadow DOM properly
372
+ const focusElement = (element) => {
373
+ const shadowRoot = element.shadowRoot;
374
+ if (shadowRoot) {
375
+ const innerFocusable = shadowRoot.querySelector(focusableQueryString);
376
+ if (innerFocusable && typeof element.setFocus !== 'function') {
377
+ focusVisibleElement(innerFocusable);
378
+ return;
379
+ }
380
+ }
381
+ focusVisibleElement(element);
382
+ };
383
+ if (ev.shiftKey) {
384
+ // Shift+Tab: previous element, wrap to last if at first
385
+ if (currentIndex <= 0) {
386
+ focusLastDescendant(lastOverlay);
387
+ }
388
+ else {
389
+ focusElement(allFocusable[currentIndex - 1]);
390
+ }
391
+ }
392
+ else {
393
+ // Tab: next element, wrap to first if at last
394
+ if (currentIndex < 0 || currentIndex >= allFocusable.length - 1) {
395
+ focusFirstDescendant(lastOverlay);
396
+ }
397
+ else {
398
+ focusElement(allFocusable[currentIndex + 1]);
399
+ }
400
+ }
401
+ }, true);
322
402
  // handle back-button click
323
403
  doc.addEventListener('ionBackButton', (ev) => {
324
404
  const lastOverlay = getPresentedOverlay(doc);
@@ -432,7 +512,7 @@ export const setRootAriaHidden = (hidden = false) => {
432
512
  viewContainer.removeAttribute('aria-hidden');
433
513
  }
434
514
  };
435
- export const present = async (overlay, name, iosEnterAnimation, mdEnterAnimation, opts) => {
515
+ export const present = async (overlay, name, iosEnterAnimation, mdEnterAnimation, ionicEnterAnimation, opts) => {
436
516
  var _a, _b;
437
517
  if (overlay.presented) {
438
518
  return;
@@ -480,11 +560,15 @@ export const present = async (overlay, name, iosEnterAnimation, mdEnterAnimation
480
560
  document.body.classList.add(BACKDROP_NO_SCROLL);
481
561
  }
482
562
  (_a = overlay.willPresentShorthand) === null || _a === void 0 ? void 0 : _a.emit();
563
+ const theme = getIonTheme(overlay);
483
564
  const mode = getIonMode(overlay);
565
+ const selectedAnimation = mode === 'ios'
566
+ ? iosEnterAnimation
567
+ : theme === 'ionic' && ionicEnterAnimation
568
+ ? ionicEnterAnimation
569
+ : mdEnterAnimation;
484
570
  // get the user's animation fn if one was provided
485
- const animationBuilder = overlay.enterAnimation
486
- ? overlay.enterAnimation
487
- : config.get(name, mode === 'ios' ? iosEnterAnimation : mdEnterAnimation);
571
+ const animationBuilder = overlay.enterAnimation ? overlay.enterAnimation : config.get(name, selectedAnimation);
488
572
  const completed = await overlayAnimation(overlay, animationBuilder, overlay.el, opts);
489
573
  if (completed) {
490
574
  overlay.didPresent.emit();
@@ -639,7 +723,8 @@ export const dismiss = async (overlay, data, role, name, iosLeaveAnimation, mdLe
639
723
  return true;
640
724
  };
641
725
  const getAppRoot = (doc) => {
642
- return doc.querySelector('ion-app') || doc.body;
726
+ const appRootSelector = config.get('appRootSelector', 'ion-app');
727
+ return doc.querySelector(appRootSelector) || doc.body;
643
728
  };
644
729
  const overlayAnimation = async (overlay, animationBuilder, baseEl, opts) => {
645
730
  // Make overlay visible in case it's hidden
@@ -0,0 +1,76 @@
1
+ /*!
2
+ * (C) Ionic http://ionicframework.com - MIT License
3
+ */
4
+ import { h } from "@stencil/core";
5
+ import { sanitizeDOMString } from "./sanitization";
6
+ /**
7
+ * Cache that maps rendered span elements to the source HTMLElement
8
+ * they were cloned from. This prevents flickering when a user
9
+ * selects an option that has rich content, as the content will only be
10
+ * re-rendered if the source HTMLElement changes.
11
+ */
12
+ const contentCache = new WeakMap();
13
+ /**
14
+ * Renders cloned DOM content into an element via a ref callback.
15
+ * The content is only cloned when the source element changes,
16
+ * preventing flicker caused by destroying and recreating web
17
+ * components (e.g., ion-avatar) on every re-render cycle.
18
+ *
19
+ * Span elements should be used when this content renders within buttons,
20
+ * depending on the select interface. Buttons can only have phrasing
21
+ * content to prevent accessibility issues.
22
+ *
23
+ * @param id - Unique identifier for generating stable virtual DOM keys.
24
+ * @param content - The HTMLElement container whose child nodes will be cloned.
25
+ * @param className - CSS class applied to the wrapper span.
26
+ * @param useSpan - Whether to use a span element instead of a div for the wrapper.
27
+ */
28
+ const renderClonedContent = (id, content, className, useSpan = false) => {
29
+ const Tag = useSpan ? 'span' : 'div';
30
+ return (h(Tag, { class: className, key: `${className}-${id}`, ref: (el) => {
31
+ if (el) {
32
+ const cached = contentCache.get(el);
33
+ // Skip if this element already has clones from the same source
34
+ if (cached === content) {
35
+ return;
36
+ }
37
+ const sanitized = sanitizeDOMString(content.innerHTML);
38
+ el.innerHTML = sanitized !== null && sanitized !== void 0 ? sanitized : '';
39
+ contentCache.set(el, content);
40
+ }
41
+ } }));
42
+ };
43
+ /**
44
+ * Renders the label content for a select option within an overlay
45
+ * interface based on the presence of rich content.
46
+ *
47
+ * Span elements should be used when this content renders within buttons,
48
+ * depending on the select interface. Buttons can only have phrasing
49
+ * content to prevent accessibility issues.
50
+ *
51
+ * @param option - The content option data containing label, slots,
52
+ * and description.
53
+ * @param className - The base CSS class for the label element.
54
+ * @param useSpan - Whether to use a span element instead of a div for the label.
55
+ */
56
+ export const renderOptionLabel = (option, className, useSpan = false) => {
57
+ const { id, label, startContent, endContent, description } = option;
58
+ const hasRichContent = !!startContent || !!endContent || !!description;
59
+ const Tag = useSpan ? 'span' : 'div';
60
+ // Render simple string label if there is no rich content to display
61
+ if (!hasRichContent && (typeof label === 'string' || !label)) {
62
+ return (h(Tag, { class: className, key: `${className}-${id}` }, label));
63
+ }
64
+ // Render the main label
65
+ const labelEl = typeof label === 'string' || !label ? (
66
+ // Label is a simple string or undefined
67
+ h(Tag, { key: `${className}-label-${id}` }, label)) : (
68
+ // Label is an HTMLElement with potential rich content
69
+ renderClonedContent(id, label, `${className}-text`, useSpan));
70
+ // No rich content, render just the label
71
+ if (!hasRichContent) {
72
+ return (h(Tag, { class: className, key: `${className}-${id}` }, labelEl));
73
+ }
74
+ // Render label with rich content (start, end, description)
75
+ return (h(Tag, { class: className, key: `${className}-${id}` }, startContent && renderClonedContent(id, startContent, 'select-option-start', useSpan), h(Tag, { class: "select-option-content", key: `${className}-content-${id}` }, labelEl, description && (h(Tag, { class: "select-option-description", key: `${className}-desc-${id}` }, description))), endContent && renderClonedContent(id, endContent, 'select-option-end', useSpan)));
76
+ };
@@ -8,7 +8,19 @@
8
8
  *
9
9
  * See https://playwright.dev/docs/api/class-mouse#mouse-move for more information.
10
10
  */
11
- export const dragElementBy = async (el, page, dragByX = 0, dragByY = 0, startXCoord, startYCoord, releaseDrag = true) => {
11
+ /**
12
+ * Drags an element by the given number of pixels on the X and Y axes.
13
+ *
14
+ * @param el The element to drag.
15
+ * @param page The E2E Page object.
16
+ * @param dragByX The number of pixels to drag on the X axis. Negative values drag left, positive values drag right.
17
+ * @param dragByY The number of pixels to drag on the Y axis. Negative values drag up, positive values drag down.
18
+ * @param startXCoord The X coordinate to start the drag from. Defaults to the center of the element.
19
+ * @param startYCoord The Y coordinate to start the drag from. Defaults to the center of the element.
20
+ * @param releaseDrag Whether to release the drag at the end of the gesture. Defaults to `true`.
21
+ * @param steps The number of steps to divide the drag into. More steps reduce velocity; fewer steps increase it. Use this to control whether velocity-based thresholds (e.g. full-swipe) are triggered, particularly in Safari where gesture velocity is calculated relative to animation frames. Defaults to `10`.
22
+ */
23
+ export const dragElementBy = async (el, page, dragByX = 0, dragByY = 0, startXCoord, startYCoord, releaseDrag = true, steps) => {
12
24
  const boundingBox = await el.boundingBox();
13
25
  if (!boundingBox) {
14
26
  throw new Error('Cannot get a bounding box for an element that is not visible. See https://playwright.dev/docs/api/class-locator#locator-bounding-box for more information');
@@ -19,17 +31,18 @@ export const dragElementBy = async (el, page, dragByX = 0, dragByY = 0, startXCo
19
31
  await page.mouse.move(startX, startY);
20
32
  await page.mouse.down();
21
33
  // Drag the element.
22
- await moveElement(page, startX, startY, dragByX, dragByY);
34
+ await moveElement(page, startX, startY, dragByX, dragByY, steps);
23
35
  if (releaseDrag) {
24
36
  await page.mouse.up();
25
37
  }
26
38
  };
27
39
  /**
28
40
  * Drags an element by the given amount of pixels on the Y axis.
41
+ *
29
42
  * @param el The element to drag.
30
43
  * @param page The E2E Page object.
31
- * @param dragByY The amount of pixels to drag the element by.
32
- * @param startYCoord The Y coordinate to start the drag gesture at. Defaults to the center of the element.
44
+ * @param dragByY The number of pixels to drag on the Y axis.
45
+ * @param startYCoord The Y coordinate to start the drag from. Defaults to the center of the element.
33
46
  */
34
47
  export const dragElementByYAxis = async (el, page, dragByY, startYCoord) => {
35
48
  const boundingBox = await el.boundingBox();
@@ -71,8 +84,7 @@ const validateDragByY = (startY, dragByY, viewportHeight) => {
71
84
  throw new Error(`The element is being dragged past the top of the viewport. Update the dragByY value to prevent going out of bounds. A recommended value is ${recommendedDragByY}.`);
72
85
  }
73
86
  };
74
- const moveElement = async (page, startX, startY, dragByX = 0, dragByY = 0) => {
75
- const steps = 10;
87
+ const moveElement = async (page, startX, startY, dragByX = 0, dragByY = 0, steps = 10) => {
76
88
  const browser = page.context().browser().browserType().name();
77
89
  const viewport = page.viewportSize();
78
90
  if (viewport === null) {
@@ -87,10 +99,21 @@ const moveElement = async (page, startX, startY, dragByX = 0, dragByY = 0) => {
87
99
  const middleX = startX + (endX - startX) * (i / steps);
88
100
  const middleY = startY + (endY - startY) * (i / steps);
89
101
  await page.mouse.move(middleX, middleY);
90
- // Safari needs to wait for a repaint to occur before moving the mouse again.
102
+ /**
103
+ * In Safari, gesture velocity is calculated relative to animation
104
+ * frames, causing velocity to accumulate faster than in other
105
+ * browsers. Without waiting for a repaint, consecutive `mouse.move`
106
+ * events arrive with ~0ms time delta and velocity never accumulates,
107
+ * causing gesture
108
+ * detection to fail.
109
+ */
91
110
  if (browser === 'webkit' && i % 2 === 0) {
92
- // Repainting every 2 steps is enough to keep the drag gesture smooth.
93
- // Anything past 4 steps will cause the drag gesture to be flaky.
111
+ /**
112
+ * Repainting every 2 steps is enough to keep the drag gesture
113
+ * smooth. Repainting on every step makes the test slow, and
114
+ * repainting every 4+ steps means Safari does not see enough
115
+ * frames to track the gesture reliably.
116
+ */
94
117
  await page.evaluate(() => new Promise(requestAnimationFrame));
95
118
  }
96
119
  }
@@ -8,34 +8,56 @@
8
8
  * each test title is unique.
9
9
  */
10
10
  const generateTitle = (title, config) => {
11
- const { mode, direction, palette } = config;
12
- if (palette === 'light') {
13
- /**
14
- * Ionic has many existing tests that existed prior to
15
- * the introduction of palette testing. To maintain backwards
16
- * compatibility, we will not include the palette in the test
17
- * title if the palette is set to light.
18
- */
19
- return `${title} - ${mode}/${direction}`;
11
+ const { direction, palette, mode, theme } = config;
12
+ /**
13
+ * The iOS theme can only be used with the iOS mode,
14
+ * and the MD theme can only be used with the MD mode.
15
+ *
16
+ * This logic enables the fallback behavior for existing tests,
17
+ * where we only tested against a mode, which accounted for both
18
+ * the theme and mode.
19
+ */
20
+ if (theme === 'ios' || theme === 'md') {
21
+ if (palette === 'light') {
22
+ /**
23
+ * Ionic has many existing tests that existed prior to
24
+ * the introduction of theme testing. To maintain backwards
25
+ * compatibility, we will not include the theme in the test
26
+ * title if the theme is set to light.
27
+ */
28
+ return `${title} - ${mode}/${direction}`;
29
+ }
30
+ return `${title} - ${mode}/${direction}/${palette}`;
20
31
  }
21
- return `${title} - ${mode}/${direction}/${palette}`;
32
+ return `${title} - ${theme}/${mode}/${direction}/${palette}`;
22
33
  };
23
34
  /**
24
35
  * Generates a unique filename based on a base filename
25
36
  * and a test config.
26
37
  */
27
38
  const generateScreenshotName = (fileName, config) => {
28
- const { mode, direction, palette } = config;
29
- if (palette === 'light') {
30
- /**
31
- * Ionic has many existing tests that existed prior to
32
- * the introduction of palette testing. To maintain backwards
33
- * compatibility, we will not include the palette in the screenshot
34
- * name if the palette is set to light.
35
- */
36
- return `${fileName}-${mode}-${direction}.png`;
39
+ const { direction, palette, mode, theme } = config;
40
+ /**
41
+ * The iOS theme can only be used with the iOS mode,
42
+ * and the MD theme can only be used with the MD mode.
43
+ *
44
+ * This logic enables the fallback behavior for existing tests,
45
+ * where we only tested against a mode, which accounted for both
46
+ * the theme and mode.
47
+ */
48
+ if (theme === 'ios' || theme === 'md') {
49
+ if (palette === 'light') {
50
+ /**
51
+ * Ionic has many existing tests that existed prior to
52
+ * the introduction of theme testing. To maintain backwards
53
+ * compatibility, we will not include the theme in the screenshot
54
+ * name if the theme is set to light.
55
+ */
56
+ return `${fileName}-${mode}-${direction}.png`;
57
+ }
58
+ return `${fileName}-${mode}-${direction}-${palette}.png`;
37
59
  }
38
- return `${fileName}-${mode}-${direction}-${palette}.png`;
60
+ return `${fileName}-${theme}-${mode}-${direction}-${palette}.png`;
39
61
  };
40
62
  /**
41
63
  * Given a config generate an array of test variants.
@@ -48,13 +70,16 @@ export const configs = (testConfig = DEFAULT_TEST_CONFIG_OPTION) => {
48
70
  * If certain options are not provided,
49
71
  * fall back to the defaults.
50
72
  */
51
- const processedMode = modes !== null && modes !== void 0 ? modes : DEFAULT_MODES;
73
+ const processedModes = modes !== null && modes !== void 0 ? modes : DEFAULT_MODES;
52
74
  const processedDirection = directions !== null && directions !== void 0 ? directions : DEFAULT_DIRECTIONS;
53
75
  const processedPalette = (_a = testConfig.palettes) !== null && _a !== void 0 ? _a : DEFAULT_PALETTES;
54
- processedMode.forEach((mode) => {
76
+ processedModes.forEach((mode) => {
77
+ const [themeOrCombinedMode, modeName] = mode.split('-');
78
+ const parsedTheme = themeOrCombinedMode;
79
+ const parsedMode = modeName !== null && modeName !== void 0 ? modeName : themeOrCombinedMode;
55
80
  processedDirection.forEach((direction) => {
56
81
  processedPalette.forEach((palette) => {
57
- configs.push({ mode, direction, palette });
82
+ configs.push({ direction, palette, mode: parsedMode, theme: parsedTheme });
58
83
  });
59
84
  });
60
85
  });
@@ -9,7 +9,7 @@
9
9
  * to be hydrated before proceeding with the test.
10
10
  */
11
11
  export const goto = async (page, url, testInfo, originalFn, options) => {
12
- var _a, _b, _c, _d;
12
+ var _a, _b, _c, _d, _e;
13
13
  if (options === undefined && testInfo.project.metadata.mode === undefined) {
14
14
  throw new Error(`
15
15
  A config must be passed to page.goto to use a generator test:
@@ -21,15 +21,18 @@ configs().forEach(({ config, title }) => {
21
21
  });`);
22
22
  }
23
23
  let mode;
24
+ let theme;
24
25
  let direction;
25
26
  let palette;
26
27
  if (options == undefined) {
27
28
  mode = testInfo.project.metadata.mode;
29
+ theme = testInfo.project.metadata.theme;
28
30
  direction = testInfo.project.metadata.rtl ? 'rtl' : 'ltr';
29
31
  palette = testInfo.project.metadata.palette;
30
32
  }
31
33
  else {
32
34
  mode = options.mode;
35
+ theme = options.theme;
33
36
  direction = options.direction;
34
37
  palette = options.palette;
35
38
  }
@@ -42,13 +45,15 @@ configs().forEach(({ config, title }) => {
42
45
  */
43
46
  const urlToParams = new URLSearchParams(paramsString);
44
47
  const formattedMode = (_a = urlToParams.get('ionic:mode')) !== null && _a !== void 0 ? _a : mode;
45
- const formattedRtl = (_b = urlToParams.get('rtl')) !== null && _b !== void 0 ? _b : rtlString;
46
- const formattedPalette = (_c = urlToParams.get('palette')) !== null && _c !== void 0 ? _c : palette;
47
- const ionicTesting = (_d = urlToParams.get('ionic:_testing')) !== null && _d !== void 0 ? _d : true;
48
+ const formattedTheme = (_b = urlToParams.get('ionic:theme')) !== null && _b !== void 0 ? _b : theme;
49
+ const formattedRtl = (_c = urlToParams.get('rtl')) !== null && _c !== void 0 ? _c : rtlString;
50
+ const formattedPalette = (_d = urlToParams.get('palette')) !== null && _d !== void 0 ? _d : palette;
51
+ const ionicTesting = (_e = urlToParams.get('ionic:_testing')) !== null && _e !== void 0 ? _e : true;
48
52
  /**
49
53
  * Pass through other custom query params
50
54
  */
51
55
  urlToParams.delete('ionic:mode');
56
+ urlToParams.delete('ionic:theme');
52
57
  urlToParams.delete('rtl');
53
58
  urlToParams.delete('palette');
54
59
  urlToParams.delete('ionic:_testing');
@@ -59,11 +64,15 @@ configs().forEach(({ config, title }) => {
59
64
  */
60
65
  const remainingQueryParams = decodeURIComponent(urlToParams.toString());
61
66
  const remainingQueryParamsString = remainingQueryParams == '' ? '' : `&${remainingQueryParams}`;
62
- const formattedUrl = `${splitUrl[0]}?ionic:_testing=${ionicTesting}&ionic:mode=${formattedMode}&rtl=${formattedRtl}&palette=${formattedPalette}${remainingQueryParamsString}`;
67
+ const formattedUrl = `${splitUrl[0]}?ionic:_testing=${ionicTesting}&ionic:mode=${formattedMode}&ionic:theme=${formattedTheme}&rtl=${formattedRtl}&palette=${formattedPalette}${remainingQueryParamsString}`;
63
68
  testInfo.annotations.push({
64
69
  type: 'mode',
65
70
  description: formattedMode,
66
71
  });
72
+ testInfo.annotations.push({
73
+ type: 'theme',
74
+ description: formattedTheme,
75
+ });
67
76
  testInfo.annotations.push({
68
77
  type: 'direction',
69
78
  description: formattedRtl === 'true' ? 'rtl' : 'ltr',
@@ -18,29 +18,43 @@ export const setContent = async (page, html, testInfo, options) => {
18
18
  }
19
19
  let mode;
20
20
  let direction;
21
+ let theme;
21
22
  let palette;
22
23
  if (options == undefined) {
23
24
  mode = testInfo.project.metadata.mode;
24
25
  direction = testInfo.project.metadata.rtl ? 'rtl' : 'ltr';
26
+ theme = testInfo.project.metadata.theme;
25
27
  palette = testInfo.project.metadata.palette;
26
28
  }
27
29
  else {
28
30
  mode = options.mode;
29
31
  direction = options.direction;
32
+ theme = options.theme;
30
33
  palette = options.palette;
31
34
  }
32
35
  const baseUrl = process.env.PLAYWRIGHT_TEST_BASE_URL;
33
36
  // The Ionic bundle is included locally by default unless the test
34
37
  // config passes in the importIonicFromCDN option. This is useful
35
38
  // when testing with the CDN version of Ionic.
36
- let ionicCSSImports = `
39
+ let ionicCSSImports = theme === 'ionic'
40
+ ? `
41
+ <link href="${baseUrl}/css/ionic/bundle.ionic.css" rel="stylesheet" />
42
+ <link href="${baseUrl}/css/utils.bundle.css" rel="stylesheet" />
43
+ `
44
+ : `
37
45
  <link href="${baseUrl}/css/ionic.bundle.css" rel="stylesheet" />
38
46
  `;
39
47
  let ionicJSImports = `
40
48
  <script type="module" src="${baseUrl}/dist/ionic/ionic.esm.js"></script>
41
49
  `;
42
50
  if (options === null || options === void 0 ? void 0 : options.importIonicFromCDN) {
43
- ionicCSSImports = `
51
+ ionicCSSImports =
52
+ theme === 'ionic'
53
+ ? `
54
+ <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@ionic/core/css/ionic/bundle.ionic.css" />
55
+ <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@ionic/core/css/utils.bundle.css" />
56
+ `
57
+ : `
44
58
  <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@ionic/core/css/ionic.bundle.css" />
45
59
  `;
46
60
  ionicJSImports = `
@@ -63,7 +77,8 @@ export const setContent = async (page, html, testInfo, options) => {
63
77
  <script>
64
78
  window.Ionic = {
65
79
  config: {
66
- mode: '${mode}'
80
+ mode: '${mode}',
81
+ theme: '${theme}'
67
82
  }
68
83
  }
69
84
  </script>
@@ -73,10 +88,18 @@ export const setContent = async (page, html, testInfo, options) => {
73
88
  </body>
74
89
  </html>
75
90
  `;
91
+ testInfo.annotations.push({
92
+ type: 'mode',
93
+ description: mode,
94
+ });
76
95
  testInfo.annotations.push({
77
96
  type: 'palette',
78
97
  description: palette,
79
98
  });
99
+ testInfo.annotations.push({
100
+ type: 'theme',
101
+ description: theme,
102
+ });
80
103
  if (baseUrl) {
81
104
  await page.route(baseUrl, (route) => {
82
105
  if (route.request().url() === `${baseUrl}/`) {
@@ -1,8 +1,32 @@
1
1
  /*!
2
2
  * (C) Ionic http://ionicframework.com - MIT License
3
3
  */
4
+ /**
5
+ * Checks if an element has a parent matching the specified selector.
6
+ * This handles an element in both light DOM and shadow DOM contexts.
7
+ * @param selector The parent selector to check for (e.g., 'ion-datetime'
8
+ * or 'ion-toolbar[color]').
9
+ * @param el The element to check.
10
+ * @returns `true` if the element has a parent matching the specified selector,
11
+ * `false` otherwise.
12
+ */
4
13
  export const hostContext = (selector, el) => {
5
- return el.closest(selector) !== null;
14
+ // Check the light DOM first
15
+ if (el.closest(selector) !== null) {
16
+ return true;
17
+ }
18
+ // For attribute or class selectors (e.g., 'ion-toolbar[color]' or
19
+ // 'ion-toolbar.ion-color') we can only check light DOM since tagName
20
+ // doesn't include attributes or classes.
21
+ if (selector.includes('[') || selector.includes('.')) {
22
+ return false;
23
+ }
24
+ // Check the shadow DOM by looking at the shadow root host and
25
+ // converting the selector to uppercase to compare with tagName
26
+ const upperCaseTagName = selector.toUpperCase();
27
+ const rootNode = el.getRootNode();
28
+ const shadowHost = rootNode instanceof ShadowRoot ? rootNode.host : null;
29
+ return (shadowHost === null || shadowHost === void 0 ? void 0 : shadowHost.tagName) === upperCaseTagName;
6
30
  };
7
31
  /**
8
32
  * Create the mode and color classes for the component based on the classes passed in
@@ -191,6 +191,7 @@ const animateBackButton = (rootAnimation, rtl, backDirection, backButtonEl, back
191
191
  const clonedBackButtonIconEl = shadow(clonedBackButtonEl).querySelector('ion-icon');
192
192
  clonedBackButtonEl.text = backButtonEl.text;
193
193
  clonedBackButtonEl.mode = backButtonEl.mode;
194
+ clonedBackButtonEl.theme = backButtonEl.theme;
194
195
  clonedBackButtonEl.icon = backButtonEl.icon;
195
196
  clonedBackButtonEl.color = backButtonEl.color;
196
197
  clonedBackButtonEl.disabled = backButtonEl.disabled;