@ionic/core 8.8.8 → 8.8.9-dev.11779403760.13ea2a08

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 (1106) hide show
  1. package/components/index.js +1 -1
  2. package/components/ion-accordion-group.js +1 -1
  3. package/components/ion-accordion.js +1 -1
  4. package/components/ion-action-sheet.js +1 -1
  5. package/components/ion-alert.js +1 -1
  6. package/components/ion-app.js +1 -1
  7. package/components/ion-avatar.js +1 -1
  8. package/components/ion-back-button.js +1 -1
  9. package/components/ion-backdrop.js +1 -1
  10. package/components/ion-badge.js +1 -1
  11. package/components/ion-breadcrumb.js +1 -1
  12. package/components/ion-breadcrumbs.js +1 -1
  13. package/components/ion-button.js +1 -1
  14. package/components/ion-buttons.js +1 -1
  15. package/components/ion-card-content.js +1 -1
  16. package/components/ion-card-header.js +1 -1
  17. package/components/ion-card-subtitle.js +1 -1
  18. package/components/ion-card-title.js +1 -1
  19. package/components/ion-card.js +1 -1
  20. package/components/ion-checkbox.js +1 -1
  21. package/components/ion-chip.js +1 -1
  22. package/components/ion-col.js +1 -1
  23. package/components/ion-content.js +1 -1
  24. package/components/ion-datetime-button.js +1 -1
  25. package/components/ion-datetime.js +1 -1
  26. package/components/ion-divider.d.ts +11 -0
  27. package/components/ion-divider.js +4 -0
  28. package/components/ion-fab-button.js +1 -1
  29. package/components/ion-fab-list.js +1 -1
  30. package/components/ion-fab.js +1 -1
  31. package/components/ion-footer.js +1 -1
  32. package/components/ion-gallery.d.ts +11 -0
  33. package/components/ion-gallery.js +4 -0
  34. package/components/ion-grid.js +1 -1
  35. package/components/ion-header.js +1 -1
  36. package/components/ion-icon.js +1 -1
  37. package/components/ion-img.js +1 -1
  38. package/components/ion-infinite-scroll-content.js +1 -1
  39. package/components/ion-infinite-scroll.js +1 -1
  40. package/components/ion-input-otp.js +1 -1
  41. package/components/ion-input-password-toggle.js +1 -1
  42. package/components/ion-input.js +1 -1
  43. package/components/ion-item-divider.js +1 -1
  44. package/components/ion-item-group.js +1 -1
  45. package/components/ion-item-option.js +1 -1
  46. package/components/ion-item-options.js +1 -1
  47. package/components/ion-item-sliding.js +1 -1
  48. package/components/ion-item.js +1 -1
  49. package/components/ion-label.js +1 -1
  50. package/components/ion-list-header.js +1 -1
  51. package/components/ion-list.js +1 -1
  52. package/components/ion-loading.js +1 -1
  53. package/components/ion-menu-button.js +1 -1
  54. package/components/ion-menu-toggle.js +1 -1
  55. package/components/ion-menu.js +1 -1
  56. package/components/ion-modal.js +1 -1
  57. package/components/ion-nav-link.js +1 -1
  58. package/components/ion-nav.js +1 -1
  59. package/components/ion-note.js +1 -1
  60. package/components/ion-picker-column-option.js +1 -1
  61. package/components/ion-picker-column.js +1 -1
  62. package/components/ion-picker-legacy-column.js +1 -1
  63. package/components/ion-picker-legacy.js +1 -1
  64. package/components/ion-picker.js +1 -1
  65. package/components/ion-popover.js +1 -1
  66. package/components/ion-progress-bar.js +1 -1
  67. package/components/ion-radio-group.js +1 -1
  68. package/components/ion-radio.js +1 -1
  69. package/components/ion-range.js +1 -1
  70. package/components/ion-refresher-content.js +1 -1
  71. package/components/ion-refresher.js +1 -1
  72. package/components/ion-reorder-group.js +1 -1
  73. package/components/ion-reorder.js +1 -1
  74. package/components/ion-ripple-effect.js +1 -1
  75. package/components/ion-route-redirect.js +1 -1
  76. package/components/ion-route.js +1 -1
  77. package/components/ion-router-link.js +1 -1
  78. package/components/ion-router-outlet.js +1 -1
  79. package/components/ion-router.js +1 -1
  80. package/components/ion-row.js +1 -1
  81. package/components/ion-searchbar.js +1 -1
  82. package/components/ion-segment-button.js +1 -1
  83. package/components/ion-segment-content.js +1 -1
  84. package/components/ion-segment-view.js +1 -1
  85. package/components/ion-segment.js +1 -1
  86. package/components/ion-select-modal.js +1 -1
  87. package/components/ion-select-option.js +1 -1
  88. package/components/ion-select-popover.js +1 -1
  89. package/components/ion-select.js +1 -1
  90. package/components/ion-skeleton-text.js +1 -1
  91. package/components/ion-spinner.js +1 -1
  92. package/components/ion-split-pane.js +1 -1
  93. package/components/ion-tab-bar.js +1 -1
  94. package/components/ion-tab-button.js +1 -1
  95. package/components/ion-tab.js +1 -1
  96. package/components/ion-tabs.js +1 -1
  97. package/components/ion-text.js +1 -1
  98. package/components/ion-textarea.js +1 -1
  99. package/components/ion-thumbnail.js +1 -1
  100. package/components/ion-title.js +1 -1
  101. package/components/ion-toast.js +1 -1
  102. package/components/ion-toggle.js +1 -1
  103. package/components/ion-toolbar.js +1 -1
  104. package/components/p-3Ni1Z654.js +4 -0
  105. package/components/p-7kL3tltU.js +4 -0
  106. package/components/p-B9MABkWm.js +4 -0
  107. package/components/p-BBu2n-9C.js +4 -0
  108. package/components/p-BDcohALy.js +4 -0
  109. package/components/p-BDqjX7Z_.js +4 -0
  110. package/components/p-BJzJdLry.js +4 -0
  111. package/components/p-BYSs-jZz.js +4 -0
  112. package/components/{p-CU1SSH8_.js → p-BZCB7f49.js} +1 -1
  113. package/components/p-B_MdONwD.js +4 -0
  114. package/components/p-BaPtaYEC.js +4 -0
  115. package/components/p-BcbmT6b3.js +4 -0
  116. package/components/p-Bg30AtDZ.js +4 -0
  117. package/components/p-BhkGOA7t.js +4 -0
  118. package/components/p-BjW8SOqw.js +4 -0
  119. package/components/p-Bk9hTY4h.js +4 -0
  120. package/components/p-BqDiJgC_.js +4 -0
  121. package/components/p-BsNpz2u3.js +4 -0
  122. package/components/p-BsSTz5ia.js +4 -0
  123. package/{dist/ionic/p-BxIcPWoV.js → components/p-Bt0d89x3.js} +1 -1
  124. package/components/p-BwQOIWD7.js +4 -0
  125. package/components/{p-CEmXdzGo.js → p-ByW0kK1F.js} +1 -1
  126. package/components/p-C75FIZBC.js +4 -0
  127. package/components/p-C8kBejTT.js +4 -0
  128. package/components/p-CBS0sBAa.js +4 -0
  129. package/components/{p-9VcRUwdB.js → p-CDgDBcU9.js} +1 -1
  130. package/components/p-CUAgUmQC.js +4 -0
  131. package/components/p-Cg-xpJhD.js +4 -0
  132. package/components/p-CgSn4J7d.js +4 -0
  133. package/components/p-CgZLVOCc.js +4 -0
  134. package/{dist/ionic/p-D13Eaw-8.js → components/p-Cllkut-B.js} +1 -1
  135. package/components/p-Cz4uz3Dy.js +4 -0
  136. package/components/p-CzC_ZSgb.js +4 -0
  137. package/components/p-D1t981Ih.js +4 -0
  138. package/components/p-D2mReIu8.js +4 -0
  139. package/components/p-D6g8ud1e.js +4 -0
  140. package/components/p-DDw-NYxz.js +4 -0
  141. package/components/p-DN_scBC7.js +4 -0
  142. package/components/p-DVcs-2q3.js +4 -0
  143. package/components/p-DXehWlOr.js +4 -0
  144. package/components/p-DaJxRxSQ.js +4 -0
  145. package/components/p-DhXUGFNH.js +4 -0
  146. package/components/p-Dhi5xtNS.js +4 -0
  147. package/components/p-Do7NMUwR.js +4 -0
  148. package/components/p-Dp2x0MpA.js +4 -0
  149. package/components/p-GElQZ38c.js +4 -0
  150. package/components/p-GtzfsjJP.js +4 -0
  151. package/components/p-LB-QPk3e.js +4 -0
  152. package/components/p-NVAi5HQQ.js +4 -0
  153. package/components/p-PzmQ86nh.js +4 -0
  154. package/components/p-Skz67GXZ.js +4 -0
  155. package/components/p-VVrXfwLZ.js +4 -0
  156. package/components/p-WdrzoonY.js +4 -0
  157. package/components/p-XegQjlzJ.js +4 -0
  158. package/components/p-fIOYmaqA.js +4 -0
  159. package/components/p-hpwmNJ2Q.js +4 -0
  160. package/components/p-kKYBfhbe.js +4 -0
  161. package/components/p-lGSe6-vg.js +4 -0
  162. package/{dist/ionic/p-BvFYtOdE.js → components/p-oF-CwZ0b.js} +1 -1
  163. package/components/p-pvh0bjpw.js +4 -0
  164. package/components/{p-cyNmxje6.js → p-re70ahxF.js} +1 -1
  165. package/components/p-sToA4Co7.js +4 -0
  166. package/components/p-vXpMhGrs.js +4 -0
  167. package/components/p-wCDzv5Q8.js +4 -0
  168. package/components/{p-YLXPWgVj.js → p-zWP0sUV_.js} +1 -1
  169. package/css/core.css +1 -1
  170. package/css/core.css.map +1 -1
  171. package/css/display.css +1 -1
  172. package/css/display.css.map +1 -1
  173. package/css/flex-utils.css +1 -1
  174. package/css/flex-utils.css.map +1 -1
  175. package/css/float-elements.css.map +1 -1
  176. package/css/global.bundle.css.map +1 -1
  177. package/css/ionic/bundle.ionic.css +1 -0
  178. package/css/ionic/bundle.ionic.css.map +1 -0
  179. package/css/ionic/core.ionic.css +1 -0
  180. package/css/ionic/core.ionic.css.map +1 -0
  181. package/css/ionic/global.bundle.ionic.css +1 -0
  182. package/css/ionic/global.bundle.ionic.css.map +1 -0
  183. package/css/ionic/ionic-swiper.ionic.css +1 -0
  184. package/css/ionic/ionic-swiper.ionic.css.map +1 -0
  185. package/css/ionic/link.ionic.css +1 -0
  186. package/css/ionic/link.ionic.css.map +1 -0
  187. package/css/ionic/structure.ionic.css +1 -0
  188. package/css/ionic/structure.ionic.css.map +1 -0
  189. package/css/ionic/typography.ionic.css +1 -0
  190. package/css/ionic/typography.ionic.css.map +1 -0
  191. package/css/ionic/utils.bundle.ionic.css +1 -0
  192. package/css/ionic/utils.bundle.ionic.css.map +1 -0
  193. package/css/ionic-swiper.css +1 -1
  194. package/css/ionic-swiper.css.map +1 -1
  195. package/css/ionic.bundle.css +1 -1
  196. package/css/ionic.bundle.css.map +1 -1
  197. package/css/normalize.css.map +1 -1
  198. package/css/padding.css.map +1 -1
  199. package/css/palettes/dark.always.css.map +1 -1
  200. package/css/palettes/dark.class.css.map +1 -1
  201. package/css/palettes/dark.system.css.map +1 -1
  202. package/css/palettes/high-contrast-dark.always.css.map +1 -1
  203. package/css/palettes/high-contrast-dark.class.css.map +1 -1
  204. package/css/palettes/high-contrast-dark.system.css.map +1 -1
  205. package/css/palettes/high-contrast.always.css.map +1 -1
  206. package/css/palettes/high-contrast.class.css.map +1 -1
  207. package/css/palettes/high-contrast.system.css.map +1 -1
  208. package/css/structure.css.map +1 -1
  209. package/css/text-alignment.css.map +1 -1
  210. package/css/text-transformation.css.map +1 -1
  211. package/css/typography.css.map +1 -1
  212. package/css/utils.bundle.css +1 -1
  213. package/css/utils.bundle.css.map +1 -1
  214. package/dist/cjs/{animation-Dg4yiuR2.js → animation-BZJ2wKuM.js} +3 -3
  215. package/dist/cjs/{app-globals-CLI8xCmk.js → app-globals-C-d5fQ35.js} +1 -1
  216. package/dist/cjs/{button-active-FscMI17-.js → button-active-B_20Nxkv.js} +2 -2
  217. package/dist/cjs/{capacitor-DmA66EwP.js → capacitor-CXqhdZym.js} +3 -3
  218. package/dist/cjs/caret-down-vtVgfXIs.js +8 -0
  219. package/dist/cjs/caret-left-CxZXLRv5.js +8 -0
  220. package/dist/cjs/caret-right-CRCgv98E.js +8 -0
  221. package/dist/cjs/{config-BukYi_pW.js → config-BiqQSDrb.js} +60 -7
  222. package/dist/cjs/{data-BYlBjkMU.js → data-DuOuKG7I.js} +6 -6
  223. package/dist/cjs/{focus-visible-CCvKiLh3.js → focus-visible-BIj-I3-C.js} +24 -0
  224. package/dist/cjs/{framework-delegate-CRgp8o_p.js → framework-delegate-Dx9FrqAC.js} +4 -2
  225. package/dist/cjs/{haptic-ClPPQ_PS.js → haptic-CQJGW58i.js} +1 -1
  226. package/dist/cjs/{helpers-CxTYJdbT.js → helpers-DJYxKN5U.js} +57 -4
  227. package/dist/cjs/{index-MbaBbWXk.js → index-BJrpF9T3.js} +2 -2
  228. package/dist/cjs/{index-CFUwM5x_.js → index-BekUBS8C.js} +15 -15
  229. package/dist/cjs/{index-DqmRDbxg.js → index-CgAbCW6L.js} +2 -0
  230. package/dist/cjs/{index-YcSftOMz.js → index-CwxYd6UD.js} +9 -8
  231. package/dist/cjs/{index-CqT-2gKy.js → index-CzcLEdQ5.js} +41 -4
  232. package/dist/cjs/{index-C845Ti6K.js → index-DSNlrgfO.js} +4 -4
  233. package/dist/cjs/index.cjs.js +13 -14
  234. package/dist/cjs/{input-shims-CPL2J8F-.js → input-shims-VyZciSxi.js} +18 -17
  235. package/dist/cjs/{input.utils-DmeJ8dmo.js → input.utils-Ct5KzpYv.js} +5 -5
  236. package/dist/cjs/ion-accordion_2.cjs.entry.js +61 -29
  237. package/dist/cjs/ion-action-sheet.cjs.entry.js +40 -22
  238. package/dist/cjs/ion-alert.cjs.entry.js +76 -40
  239. package/dist/cjs/ion-app_8.cjs.entry.js +292 -157
  240. package/dist/cjs/ion-avatar_3.cjs.entry.js +125 -13
  241. package/dist/cjs/ion-back-button.cjs.entry.js +31 -22
  242. package/dist/cjs/ion-backdrop.cjs.entry.js +10 -7
  243. package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +54 -18
  244. package/dist/cjs/ion-button_2.cjs.entry.js +59 -22
  245. package/dist/cjs/ion-card_5.cjs.entry.js +55 -33
  246. package/dist/cjs/ion-checkbox.cjs.entry.js +34 -16
  247. package/dist/cjs/ion-chip.cjs.entry.js +50 -9
  248. package/dist/cjs/ion-col_3.cjs.entry.js +56 -57
  249. package/dist/cjs/ion-datetime-button.cjs.entry.js +13 -9
  250. package/dist/cjs/ion-datetime_3.cjs.entry.js +116 -41
  251. package/dist/cjs/ion-divider.cjs.entry.js +51 -0
  252. package/dist/cjs/ion-fab_3.cjs.entry.js +44 -28
  253. package/dist/cjs/ion-gallery.cjs.entry.js +510 -0
  254. package/dist/cjs/ion-img.cjs.entry.js +8 -4
  255. package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +91 -16
  256. package/dist/cjs/ion-input-otp.cjs.entry.js +74 -9
  257. package/dist/cjs/ion-input-password-toggle.cjs.entry.js +53 -15
  258. package/dist/cjs/ion-input.cjs.entry.js +124 -34
  259. package/dist/cjs/ion-item-option_3.cjs.entry.js +467 -52
  260. package/dist/cjs/ion-item_8.cjs.entry.js +115 -49
  261. package/dist/cjs/ion-loading.cjs.entry.js +20 -18
  262. package/dist/cjs/ion-menu_3.cjs.entry.js +47 -29
  263. package/dist/cjs/ion-modal.cjs.entry.js +262 -138
  264. package/dist/cjs/ion-nav_2.cjs.entry.js +14 -11
  265. package/dist/cjs/ion-picker-column-option.cjs.entry.js +12 -8
  266. package/dist/cjs/ion-picker-column.cjs.entry.js +14 -14
  267. package/dist/cjs/ion-picker.cjs.entry.js +10 -6
  268. package/dist/cjs/ion-popover.cjs.entry.js +21 -19
  269. package/dist/cjs/ion-progress-bar.cjs.entry.js +27 -9
  270. package/dist/cjs/ion-radio_2.cjs.entry.js +35 -17
  271. package/dist/cjs/ion-range.cjs.entry.js +20 -13
  272. package/dist/cjs/ion-refresher_2.cjs.entry.js +39 -21
  273. package/dist/cjs/ion-reorder_2.cjs.entry.js +38 -14
  274. package/dist/cjs/ion-ripple-effect.cjs.entry.js +15 -7
  275. package/dist/cjs/ion-route_4.cjs.entry.js +10 -9
  276. package/dist/cjs/ion-searchbar.cjs.entry.js +137 -24
  277. package/dist/cjs/ion-segment-content.cjs.entry.js +2 -2
  278. package/dist/cjs/ion-segment-view.cjs.entry.js +13 -3
  279. package/dist/cjs/ion-segment_2.cjs.entry.js +23 -16
  280. package/dist/cjs/ion-select-modal.cjs.entry.js +119 -40
  281. package/dist/cjs/ion-select_3.cjs.entry.js +500 -84
  282. package/dist/cjs/ion-spinner.cjs.entry.js +30 -8
  283. package/dist/cjs/ion-split-pane.cjs.entry.js +13 -9
  284. package/dist/cjs/ion-tab-bar_2.cjs.entry.js +147 -23
  285. package/dist/cjs/ion-tab_2.cjs.entry.js +8 -7
  286. package/dist/cjs/ion-text.cjs.entry.js +7 -7
  287. package/dist/cjs/ion-textarea.cjs.entry.js +137 -23
  288. package/dist/cjs/ion-toast.cjs.entry.js +69 -46
  289. package/dist/cjs/ion-toggle.cjs.entry.js +82 -25
  290. package/dist/cjs/ionic-global-BW5tRzrz.js +519 -0
  291. package/dist/cjs/ionic.cjs.js +4 -4
  292. package/dist/cjs/{ios.transition-trBiC95R.js → ios.transition-CyNNpj1i.js} +7 -5
  293. package/dist/cjs/{keyboard-hHzlEQpk.js → keyboard-CA6RtoWx.js} +4 -3
  294. package/dist/cjs/{keyboard-UuAS4D_9.js → keyboard-VLGMzWBE.js} +1 -1
  295. package/dist/cjs/{keyboard-controller-GXBiBRKS.js → keyboard-controller-CCTvHp9l.js} +11 -9
  296. package/dist/cjs/list-a-7GSA6K.js +8 -0
  297. package/dist/cjs/loader.cjs.js +4 -4
  298. package/dist/cjs/{md.transition-CUQECuvD.js → md.transition-BEfrfWKW.js} +6 -5
  299. package/dist/cjs/{notch-controller-sD-lTpdc.js → notch-controller-BTZCPOsd.js} +4 -4
  300. package/dist/cjs/overlay-control-label-t9ZFhCtr.js +51 -0
  301. package/dist/cjs/{overlays-C2jiBSNQ.js → overlays-BuMIwR8B.js} +110 -16
  302. package/dist/cjs/select-option-render-C72N7OsO.js +111 -0
  303. package/dist/cjs/{status-tap-CCJk5VgT.js → status-tap-CTY2dMsZ.js} +4 -3
  304. package/dist/cjs/{swipe-back-BGhTQ1CU.js → swipe-back-jJFi5KCB.js} +3 -2
  305. package/dist/cjs/{theme-CeDs6Hcv.js → theme-IlOsGAz7.js} +25 -1
  306. package/dist/cjs/validity-QmuwEptc.js +51 -0
  307. package/dist/cjs/x-BTF99yFH.js +8 -0
  308. package/dist/collection/collection-manifest.json +7 -0
  309. package/dist/collection/components/accordion/accordion.ionic.css +201 -0
  310. package/dist/collection/components/accordion/accordion.ios.css +73 -58
  311. package/dist/collection/components/accordion/accordion.js +41 -27
  312. package/dist/collection/components/accordion/accordion.md.css +67 -59
  313. package/dist/collection/components/accordion-group/accordion-group.ionic.css +93 -0
  314. package/dist/collection/components/accordion-group/accordion-group.ios.css +16 -4
  315. package/dist/collection/components/accordion-group/accordion-group.js +44 -8
  316. package/dist/collection/components/accordion-group/accordion-group.md.css +22 -4
  317. package/dist/collection/components/action-sheet/action-sheet.ionic.css +439 -0
  318. package/dist/collection/components/action-sheet/action-sheet.ios.css +155 -11
  319. package/dist/collection/components/action-sheet/action-sheet.js +32 -13
  320. package/dist/collection/components/action-sheet/action-sheet.md.css +155 -10
  321. package/dist/collection/components/alert/alert.ionic.css +726 -0
  322. package/dist/collection/components/alert/alert.ios.css +219 -19
  323. package/dist/collection/components/alert/alert.js +67 -30
  324. package/dist/collection/components/alert/alert.md.css +229 -15
  325. package/dist/collection/components/app/app.js +15 -83
  326. package/dist/collection/components/avatar/avatar.ionic.css +391 -0
  327. package/dist/collection/components/avatar/avatar.ios.css +7 -33
  328. package/dist/collection/components/avatar/avatar.js +120 -4
  329. package/dist/collection/components/avatar/avatar.md.css +51 -0
  330. package/dist/collection/components/back-button/back-button.ios.css +60 -48
  331. package/dist/collection/components/back-button/back-button.js +27 -19
  332. package/dist/collection/components/back-button/back-button.md.css +60 -48
  333. package/dist/collection/components/backdrop/backdrop.ionic.css +109 -0
  334. package/dist/collection/components/backdrop/backdrop.ios.css +56 -19
  335. package/dist/collection/components/backdrop/backdrop.js +12 -6
  336. package/dist/collection/components/backdrop/backdrop.md.css +56 -19
  337. package/dist/collection/components/badge/badge.ionic.css +275 -0
  338. package/dist/collection/components/badge/badge.ios.css +139 -12
  339. package/dist/collection/components/badge/badge.js +145 -9
  340. package/dist/collection/components/badge/badge.md.css +123 -12
  341. package/dist/collection/components/breadcrumb/breadcrumb.ios.css +20 -8
  342. package/dist/collection/components/breadcrumb/breadcrumb.js +43 -11
  343. package/dist/collection/components/breadcrumb/breadcrumb.md.css +20 -8
  344. package/dist/collection/components/breadcrumbs/breadcrumbs.ios.css +6 -0
  345. package/dist/collection/components/breadcrumbs/breadcrumbs.js +11 -9
  346. package/dist/collection/components/breadcrumbs/breadcrumbs.md.css +6 -0
  347. package/dist/collection/components/button/button.ionic.css +646 -0
  348. package/dist/collection/components/button/button.ios.css +154 -46
  349. package/dist/collection/components/button/button.js +63 -27
  350. package/dist/collection/components/button/button.md.css +150 -50
  351. package/dist/collection/components/buttons/buttons.ionic.css +97 -0
  352. package/dist/collection/components/buttons/buttons.ios.css +59 -7
  353. package/dist/collection/components/buttons/buttons.js +15 -9
  354. package/dist/collection/components/buttons/buttons.md.css +55 -3
  355. package/dist/collection/components/card/card.ionic.css +144 -0
  356. package/dist/collection/components/card/card.ios.css +65 -14
  357. package/dist/collection/components/card/card.js +41 -10
  358. package/dist/collection/components/card/card.md.css +65 -14
  359. package/dist/collection/components/card-content/card-content.ionic.css +89 -0
  360. package/dist/collection/components/card-content/card-content.ios.css +20 -35
  361. package/dist/collection/components/card-content/card-content.js +12 -10
  362. package/dist/collection/components/card-content/card-content.md.css +20 -35
  363. package/dist/collection/components/card-header/card-header.ionic.css +85 -0
  364. package/dist/collection/components/card-header/card-header.ios.css +27 -15
  365. package/dist/collection/components/card-header/card-header.js +13 -10
  366. package/dist/collection/components/card-header/card-header.md.css +27 -15
  367. package/dist/collection/components/card-subtitle/card-subtitle.ionic.css +144 -0
  368. package/dist/collection/components/card-subtitle/card-subtitle.ios.css +12 -0
  369. package/dist/collection/components/card-subtitle/card-subtitle.js +11 -8
  370. package/dist/collection/components/card-subtitle/card-subtitle.md.css +12 -0
  371. package/dist/collection/components/card-title/card-title.ios.css +73 -0
  372. package/dist/collection/components/card-title/card-title.js +11 -8
  373. package/dist/collection/components/card-title/card-title.md.css +73 -0
  374. package/dist/collection/components/checkbox/checkbox.ionic.css +539 -0
  375. package/dist/collection/components/checkbox/checkbox.ios.css +161 -101
  376. package/dist/collection/components/checkbox/checkbox.js +70 -14
  377. package/dist/collection/components/checkbox/checkbox.md.css +162 -102
  378. package/dist/collection/components/chip/chip.ionic.css +217 -0
  379. package/dist/collection/components/chip/chip.ios.css +67 -14
  380. package/dist/collection/components/chip/chip.js +108 -8
  381. package/dist/collection/components/chip/chip.md.css +67 -14
  382. package/dist/collection/components/col/col.css +192 -4
  383. package/dist/collection/components/col/col.js +211 -61
  384. package/dist/collection/components/content/content.css +8 -2
  385. package/dist/collection/components/content/content.js +16 -11
  386. package/dist/collection/components/datetime/datetime.ionic.css +703 -0
  387. package/dist/collection/components/datetime/datetime.ios.css +302 -106
  388. package/dist/collection/components/datetime/datetime.js +98 -20
  389. package/dist/collection/components/datetime/datetime.md.css +293 -96
  390. package/dist/collection/components/datetime/utils/data.js +5 -5
  391. package/dist/collection/components/datetime-button/datetime-button.ios.css +6 -0
  392. package/dist/collection/components/datetime-button/datetime-button.js +11 -8
  393. package/dist/collection/components/datetime-button/datetime-button.md.css +6 -0
  394. package/dist/collection/components/divider/divider.ionic.css +148 -0
  395. package/dist/collection/components/divider/divider.ios.css +87 -0
  396. package/dist/collection/components/divider/divider.js +94 -0
  397. package/dist/collection/components/divider/divider.md.css +87 -0
  398. package/dist/collection/components/fab/fab.css +25 -1
  399. package/dist/collection/components/fab/fab.js +9 -5
  400. package/dist/collection/components/fab-button/fab-button.ios.css +18 -6
  401. package/dist/collection/components/fab-button/fab-button.js +36 -21
  402. package/dist/collection/components/fab-button/fab-button.md.css +20 -8
  403. package/dist/collection/components/fab-list/fab-list.css +12 -0
  404. package/dist/collection/components/fab-list/fab-list.js +9 -5
  405. package/dist/collection/components/footer/footer.ios.css +14 -2
  406. package/dist/collection/components/footer/footer.js +21 -16
  407. package/dist/collection/components/footer/footer.md.css +12 -0
  408. package/dist/collection/components/gallery/gallery-constants.js +12 -0
  409. package/dist/collection/components/gallery/gallery-interface.js +1 -0
  410. package/dist/collection/components/gallery/gallery.css +100 -0
  411. package/dist/collection/components/gallery/gallery.js +595 -0
  412. package/dist/collection/components/gallery/test/utils.js +100 -0
  413. package/dist/collection/components/grid/grid.css +12 -0
  414. package/dist/collection/components/grid/grid.js +9 -5
  415. package/dist/collection/components/header/header.ionic.css +97 -0
  416. package/dist/collection/components/header/header.ios.css +25 -10
  417. package/dist/collection/components/header/header.js +50 -19
  418. package/dist/collection/components/header/header.md.css +23 -8
  419. package/dist/collection/components/header/header.utils.js +5 -5
  420. package/dist/collection/components/img/img.js +8 -2
  421. package/dist/collection/components/infinite-scroll/infinite-scroll.js +100 -5
  422. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.ios.css +12 -0
  423. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +16 -10
  424. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.md.css +12 -0
  425. package/dist/collection/components/input/input.ionic.css +889 -0
  426. package/dist/collection/components/input/input.ios.css +223 -135
  427. package/dist/collection/components/input/input.js +148 -37
  428. package/dist/collection/components/input/input.md.css +193 -207
  429. package/dist/collection/components/input-otp/input-otp.ionic.css +371 -0
  430. package/dist/collection/components/input-otp/input-otp.ios.css +105 -60
  431. package/dist/collection/components/input-otp/input-otp.js +73 -6
  432. package/dist/collection/components/input-otp/input-otp.md.css +105 -60
  433. package/dist/collection/components/input-password-toggle/input-password-toggle.ionic.css +78 -0
  434. package/dist/collection/components/input-password-toggle/input-password-toggle.js +48 -12
  435. package/dist/collection/components/input-password-toggle/input-password-toggle.native.css +61 -0
  436. package/dist/collection/components/item/item.ionic.css +496 -0
  437. package/dist/collection/components/item/item.ios.css +109 -69
  438. package/dist/collection/components/item/item.js +50 -20
  439. package/dist/collection/components/item/item.md.css +120 -68
  440. package/dist/collection/components/item-divider/item-divider.ios.css +18 -0
  441. package/dist/collection/components/item-divider/item-divider.js +11 -8
  442. package/dist/collection/components/item-divider/item-divider.md.css +18 -0
  443. package/dist/collection/components/item-group/item-group.ios.css +12 -0
  444. package/dist/collection/components/item-group/item-group.js +13 -7
  445. package/dist/collection/components/item-group/item-group.md.css +12 -0
  446. package/dist/collection/components/item-option/item-option.ionic.css +278 -0
  447. package/dist/collection/components/item-option/item-option.ios.css +136 -29
  448. package/dist/collection/components/item-option/item-option.js +73 -9
  449. package/dist/collection/components/item-option/item-option.md.css +136 -29
  450. package/dist/collection/components/item-options/item-options.ionic.css +221 -0
  451. package/dist/collection/components/item-options/item-options.ios.css +77 -34
  452. package/dist/collection/components/item-options/item-options.js +13 -7
  453. package/dist/collection/components/item-options/item-options.md.css +77 -34
  454. package/dist/collection/components/item-sliding/item-sliding.ionic.css +211 -0
  455. package/dist/collection/components/item-sliding/item-sliding.js +421 -35
  456. package/dist/collection/components/item-sliding/{item-sliding.css → item-sliding.native.css} +84 -9
  457. package/dist/collection/components/item-sliding/test/test.utils.js +13 -0
  458. package/dist/collection/components/label/label.ios.css +18 -0
  459. package/dist/collection/components/label/label.js +11 -8
  460. package/dist/collection/components/label/label.md.css +18 -0
  461. package/dist/collection/components/list/list.ionic.css +212 -0
  462. package/dist/collection/components/list/list.ios.css +54 -14
  463. package/dist/collection/components/list/list.js +48 -9
  464. package/dist/collection/components/list/list.md.css +56 -16
  465. package/dist/collection/components/list-header/list-header.ionic.css +190 -0
  466. package/dist/collection/components/list-header/list-header.ios.css +82 -38
  467. package/dist/collection/components/list-header/list-header.js +11 -8
  468. package/dist/collection/components/list-header/list-header.md.css +82 -38
  469. package/dist/collection/components/loading/loading.ios.css +13 -1
  470. package/dist/collection/components/loading/loading.js +14 -11
  471. package/dist/collection/components/loading/loading.md.css +13 -1
  472. package/dist/collection/components/menu/menu.ios.css +15 -3
  473. package/dist/collection/components/menu/menu.js +12 -7
  474. package/dist/collection/components/menu/menu.md.css +15 -3
  475. package/dist/collection/components/menu-button/menu-button.ionic.css +236 -0
  476. package/dist/collection/components/menu-button/menu-button.ios.css +48 -14
  477. package/dist/collection/components/menu-button/menu-button.js +26 -10
  478. package/dist/collection/components/menu-button/menu-button.md.css +49 -15
  479. package/dist/collection/components/menu-toggle/menu-toggle.js +8 -5
  480. package/dist/collection/components/modal/animations/ionic.enter.js +40 -0
  481. package/dist/collection/components/modal/animations/ionic.leave.js +28 -0
  482. package/dist/collection/components/modal/animations/sheet.js +8 -2
  483. package/dist/collection/components/modal/gestures/sheet.js +76 -10
  484. package/dist/collection/components/modal/modal.ionic.css +247 -0
  485. package/dist/collection/components/modal/modal.ios.css +178 -70
  486. package/dist/collection/components/modal/modal.js +50 -12
  487. package/dist/collection/components/modal/modal.md.css +178 -70
  488. package/dist/collection/components/nav/nav.css +7 -1
  489. package/dist/collection/components/nav/nav.js +11 -5
  490. package/dist/collection/components/nav-link/nav-link.js +5 -1
  491. package/dist/collection/components/note/note.ios.css +12 -0
  492. package/dist/collection/components/note/note.js +11 -8
  493. package/dist/collection/components/note/note.md.css +12 -0
  494. package/dist/collection/components/picker/picker.ios.css +15 -3
  495. package/dist/collection/components/picker/picker.js +8 -5
  496. package/dist/collection/components/picker/picker.md.css +15 -3
  497. package/dist/collection/components/picker-column/picker-column.css +9 -2
  498. package/dist/collection/components/picker-column/picker-column.js +8 -7
  499. package/dist/collection/components/picker-column-option/picker-column-option.ios.css +6 -0
  500. package/dist/collection/components/picker-column-option/picker-column-option.js +13 -7
  501. package/dist/collection/components/picker-column-option/picker-column-option.md.css +6 -0
  502. package/dist/collection/components/picker-legacy/picker.ios.css +13 -1
  503. package/dist/collection/components/picker-legacy/picker.js +7 -6
  504. package/dist/collection/components/picker-legacy/picker.md.css +13 -1
  505. package/dist/collection/components/picker-legacy-column/picker-column.ios.css +12 -0
  506. package/dist/collection/components/picker-legacy-column/picker-column.js +4 -4
  507. package/dist/collection/components/picker-legacy-column/picker-column.md.css +12 -0
  508. package/dist/collection/components/popover/popover.ionic.css +290 -0
  509. package/dist/collection/components/popover/popover.ios.css +29 -1
  510. package/dist/collection/components/popover/popover.js +18 -15
  511. package/dist/collection/components/popover/popover.md.css +29 -1
  512. package/dist/collection/components/progress-bar/progress-bar.ionic.css +287 -0
  513. package/dist/collection/components/progress-bar/progress-bar.ios.css +48 -17
  514. package/dist/collection/components/progress-bar/progress-bar.js +43 -7
  515. package/dist/collection/components/progress-bar/progress-bar.md.css +48 -17
  516. package/dist/collection/components/radio/radio.ionic.css +422 -0
  517. package/dist/collection/components/radio/radio.ios.css +134 -91
  518. package/dist/collection/components/radio/radio.js +14 -9
  519. package/dist/collection/components/radio/radio.md.css +134 -91
  520. package/dist/collection/components/radio-group/radio-group.ionic.css +119 -0
  521. package/dist/collection/components/radio-group/radio-group.ios.css +43 -19
  522. package/dist/collection/components/radio-group/radio-group.js +48 -7
  523. package/dist/collection/components/radio-group/radio-group.md.css +43 -19
  524. package/dist/collection/components/range/range.ionic.css +567 -0
  525. package/dist/collection/components/range/range.ios.css +128 -85
  526. package/dist/collection/components/range/range.js +16 -10
  527. package/dist/collection/components/range/range.md.css +128 -85
  528. package/dist/collection/components/refresher/refresher.ios.css +14 -1
  529. package/dist/collection/components/refresher/refresher.js +11 -8
  530. package/dist/collection/components/refresher/refresher.md.css +15 -2
  531. package/dist/collection/components/refresher-content/refresher-content.js +28 -7
  532. package/dist/collection/components/reorder/reorder.ios.css +6 -0
  533. package/dist/collection/components/reorder/reorder.js +33 -6
  534. package/dist/collection/components/reorder/reorder.md.css +6 -0
  535. package/dist/collection/components/reorder-group/reorder-group.css +6 -0
  536. package/dist/collection/components/reorder-group/reorder-group.js +8 -4
  537. package/dist/collection/components/ripple-effect/{ripple-effect.css → ripple-effect.common.css} +7 -1
  538. package/dist/collection/components/ripple-effect/ripple-effect.ionic.css +215 -0
  539. package/dist/collection/components/ripple-effect/ripple-effect.js +14 -6
  540. package/dist/collection/components/route/route.js +4 -0
  541. package/dist/collection/components/router/router.js +4 -0
  542. package/dist/collection/components/router-link/router-link.css +8 -2
  543. package/dist/collection/components/router-link/router-link.js +9 -5
  544. package/dist/collection/components/router-outlet/router-outlet.css +7 -1
  545. package/dist/collection/components/router-outlet/router-outlet.js +6 -3
  546. package/dist/collection/components/row/row.css +16 -0
  547. package/dist/collection/components/row/row.js +9 -2
  548. package/dist/collection/components/searchbar/searchbar.ionic.css +626 -0
  549. package/dist/collection/components/searchbar/searchbar.ios.css +56 -18
  550. package/dist/collection/components/searchbar/searchbar.js +180 -33
  551. package/dist/collection/components/searchbar/searchbar.md.css +56 -18
  552. package/dist/collection/components/segment/segment.ionic.css +115 -0
  553. package/dist/collection/components/segment/segment.ios.css +45 -2
  554. package/dist/collection/components/segment/segment.js +11 -8
  555. package/dist/collection/components/segment/segment.md.css +45 -2
  556. package/dist/collection/components/segment-button/segment-button.ionic.css +353 -0
  557. package/dist/collection/components/segment-button/segment-button.ios.css +146 -105
  558. package/dist/collection/components/segment-button/segment-button.js +11 -8
  559. package/dist/collection/components/segment-button/segment-button.md.css +148 -107
  560. package/dist/collection/components/segment-content/segment-content.js +1 -1
  561. package/dist/collection/components/segment-view/segment-view.ios.css +6 -0
  562. package/dist/collection/components/segment-view/segment-view.js +13 -4
  563. package/dist/collection/components/segment-view/segment-view.md.css +6 -0
  564. package/dist/collection/components/select/select.ionic.css +810 -0
  565. package/dist/collection/components/select/select.ios.css +348 -176
  566. package/dist/collection/components/select/select.js +460 -66
  567. package/dist/collection/components/select/select.md.css +364 -178
  568. package/dist/collection/components/select-modal/select-modal.ionic.css +221 -0
  569. package/dist/collection/components/select-modal/select-modal.ios.css +156 -0
  570. package/dist/collection/components/select-modal/select-modal.js +132 -32
  571. package/dist/collection/components/select-modal/select-modal.md.css +139 -0
  572. package/dist/collection/components/select-option/select-option.js +70 -2
  573. package/dist/collection/components/select-popover/select-popover.ionic.css +220 -0
  574. package/dist/collection/components/select-popover/select-popover.ios.css +117 -23
  575. package/dist/collection/components/select-popover/select-popover.js +94 -31
  576. package/dist/collection/components/select-popover/select-popover.md.css +117 -22
  577. package/dist/collection/components/skeleton-text/skeleton-text.css +6 -0
  578. package/dist/collection/components/skeleton-text/skeleton-text.js +9 -5
  579. package/dist/collection/components/spinner/{spinner.css → spinner.ionic.css} +78 -10
  580. package/dist/collection/components/spinner/spinner.js +47 -6
  581. package/dist/collection/components/spinner/spinner.native.css +199 -0
  582. package/dist/collection/components/split-pane/split-pane.ios.css +20 -2
  583. package/dist/collection/components/split-pane/split-pane.js +15 -8
  584. package/dist/collection/components/split-pane/split-pane.md.css +20 -2
  585. package/dist/collection/components/tab/tab.js +6 -2
  586. package/dist/collection/components/tab-bar/tab-bar.ionic.css +227 -0
  587. package/dist/collection/components/tab-bar/tab-bar.ios.css +71 -43
  588. package/dist/collection/components/tab-bar/tab-bar.js +171 -13
  589. package/dist/collection/components/tab-bar/tab-bar.md.css +71 -43
  590. package/dist/collection/components/tab-button/tab-button.ionic.css +348 -0
  591. package/dist/collection/components/tab-button/tab-button.ios.css +171 -95
  592. package/dist/collection/components/tab-button/tab-button.js +54 -9
  593. package/dist/collection/components/tab-button/tab-button.md.css +137 -93
  594. package/dist/collection/components/tabs/tabs.css +7 -1
  595. package/dist/collection/components/tabs/tabs.js +4 -1
  596. package/dist/collection/components/text/text.css +6 -0
  597. package/dist/collection/components/text/text.js +7 -6
  598. package/dist/collection/components/textarea/textarea.ionic.css +898 -0
  599. package/dist/collection/components/textarea/textarea.ios.css +298 -158
  600. package/dist/collection/components/textarea/textarea.js +162 -24
  601. package/dist/collection/components/textarea/textarea.md.css +312 -159
  602. package/dist/collection/components/thumbnail/thumbnail.css +6 -0
  603. package/dist/collection/components/thumbnail/thumbnail.js +9 -2
  604. package/dist/collection/components/title/title.ionic.css +127 -0
  605. package/dist/collection/components/title/title.ios.css +32 -4
  606. package/dist/collection/components/title/title.js +13 -7
  607. package/dist/collection/components/title/title.md.css +32 -4
  608. package/dist/collection/components/toast/animations/utils.js +1 -1
  609. package/dist/collection/components/toast/toast.ionic.css +394 -0
  610. package/dist/collection/components/toast/toast.ios.css +84 -45
  611. package/dist/collection/components/toast/toast.js +76 -13
  612. package/dist/collection/components/toast/toast.md.css +84 -45
  613. package/dist/collection/components/toggle/toggle.ionic.css +508 -0
  614. package/dist/collection/components/toggle/toggle.ios.css +247 -131
  615. package/dist/collection/components/toggle/toggle.js +73 -18
  616. package/dist/collection/components/toggle/toggle.md.css +244 -131
  617. package/dist/collection/components/toolbar/test/image.svg +1 -0
  618. package/dist/collection/components/toolbar/toolbar.ionic.css +249 -0
  619. package/dist/collection/components/toolbar/toolbar.ios.css +90 -47
  620. package/dist/collection/components/toolbar/toolbar.js +218 -13
  621. package/dist/collection/components/toolbar/toolbar.md.css +90 -47
  622. package/dist/collection/global/ionic-global.js +241 -13
  623. package/dist/collection/utils/css-value-validation.js +25 -0
  624. package/dist/collection/utils/focus-trap.js +13 -2
  625. package/dist/collection/utils/focus-visible.js +22 -0
  626. package/dist/collection/utils/forms/validity.js +31 -0
  627. package/dist/collection/utils/framework-delegate.js +3 -1
  628. package/dist/collection/utils/hardware-back-button.js +15 -0
  629. package/dist/collection/utils/helpers.js +57 -3
  630. package/dist/collection/utils/keyboard/keyboard-controller.js +3 -1
  631. package/dist/collection/utils/media.js +1 -0
  632. package/dist/collection/utils/menu-controller/animations/overlay.js +3 -3
  633. package/dist/collection/utils/menu-controller/animations/push.js +2 -1
  634. package/dist/collection/utils/menu-controller/animations/reveal.js +2 -1
  635. package/dist/collection/utils/overlay-control-label.js +46 -0
  636. package/dist/collection/utils/overlays.js +91 -6
  637. package/dist/collection/utils/sanitization/index.js +58 -6
  638. package/dist/collection/utils/select-option-render.js +106 -0
  639. package/dist/collection/utils/test/playwright/drag-element.js +32 -9
  640. package/dist/collection/utils/test/playwright/generator.js +48 -23
  641. package/dist/collection/utils/test/playwright/page/utils/goto.js +14 -5
  642. package/dist/collection/utils/test/playwright/page/utils/set-content.js +26 -3
  643. package/dist/collection/utils/theme.js +25 -1
  644. package/dist/collection/utils/transition/ios.transition.js +1 -0
  645. package/dist/docs.json +8891 -283
  646. package/dist/esm/{animation-CnGMT4ji.js → animation-Cd1EA2ar.js} +2 -2
  647. package/dist/esm/{app-globals-DhZjtldk.js → app-globals-9x_U7ofY.js} +1 -1
  648. package/dist/esm/{button-active-BBx21brx.js → button-active-B016u5N-.js} +2 -2
  649. package/dist/esm/{capacitor-CFERIeaU.js → capacitor-13SFuT1K.js} +1 -1
  650. package/dist/esm/caret-down-D1t981Ih.js +6 -0
  651. package/dist/esm/caret-left-fIOYmaqA.js +6 -0
  652. package/dist/esm/caret-right-BYSs-jZz.js +6 -0
  653. package/dist/esm/{config-TO1rZH52.js → config-DLfuRiEz.js} +60 -8
  654. package/dist/esm/{data-B9iGR5YO.js → data-BNKYavC3.js} +6 -6
  655. package/dist/esm/{focus-visible-BmVRXR1y.js → focus-visible-vXpMhGrs.js} +23 -1
  656. package/dist/esm/{framework-delegate-CyxE1S_P.js → framework-delegate-CjVwn_KZ.js} +4 -2
  657. package/dist/esm/{haptic-DzAMWJuk.js → haptic-CbnKC3go.js} +1 -1
  658. package/dist/esm/{helpers-Tl8jw6S2.js → helpers-Do7zwvM1.js} +58 -5
  659. package/dist/esm/{index-B-hkiOUh.js → index-B2VWavcK.js} +4 -4
  660. package/dist/esm/{index-B2KwgBLx.js → index-BWMvrRiE.js} +11 -11
  661. package/dist/esm/{index-hW6eNZ3o.js → index-BmkLokUL.js} +2 -2
  662. package/dist/esm/{index-DV3sJJW8.js → index-D2tu5BUg.js} +2 -1
  663. package/dist/esm/{index-BtUdxPjv.js → index-D3WueHpT.js} +4 -3
  664. package/dist/esm/{index-IGIE5vDm.js → index-Omi_TcwW.js} +41 -4
  665. package/dist/esm/index.js +13 -14
  666. package/dist/esm/{input-shims-DbrgeeNb.js → input-shims-DU23z7Hg.js} +7 -6
  667. package/dist/esm/{input.utils-Bxa_DQ7-.js → input.utils-C64RbLd_.js} +3 -3
  668. package/dist/esm/ion-accordion_2.entry.js +61 -29
  669. package/dist/esm/ion-action-sheet.entry.js +40 -22
  670. package/dist/esm/ion-alert.entry.js +76 -40
  671. package/dist/esm/ion-app_8.entry.js +292 -157
  672. package/dist/esm/ion-avatar_3.entry.js +125 -13
  673. package/dist/esm/ion-back-button.entry.js +31 -22
  674. package/dist/esm/ion-backdrop.entry.js +10 -7
  675. package/dist/esm/ion-breadcrumb_2.entry.js +54 -18
  676. package/dist/esm/ion-button_2.entry.js +59 -22
  677. package/dist/esm/ion-card_5.entry.js +55 -33
  678. package/dist/esm/ion-checkbox.entry.js +34 -16
  679. package/dist/esm/ion-chip.entry.js +50 -9
  680. package/dist/esm/ion-col_3.entry.js +56 -57
  681. package/dist/esm/ion-datetime-button.entry.js +13 -9
  682. package/dist/esm/ion-datetime_3.entry.js +116 -41
  683. package/dist/esm/ion-divider.entry.js +49 -0
  684. package/dist/esm/ion-fab_3.entry.js +44 -28
  685. package/dist/esm/ion-gallery.entry.js +508 -0
  686. package/dist/esm/ion-img.entry.js +8 -4
  687. package/dist/esm/ion-infinite-scroll_2.entry.js +91 -16
  688. package/dist/esm/ion-input-otp.entry.js +74 -9
  689. package/dist/esm/ion-input-password-toggle.entry.js +53 -15
  690. package/dist/esm/ion-input.entry.js +124 -34
  691. package/dist/esm/ion-item-option_3.entry.js +467 -52
  692. package/dist/esm/ion-item_8.entry.js +115 -49
  693. package/dist/esm/ion-loading.entry.js +20 -18
  694. package/dist/esm/ion-menu_3.entry.js +47 -29
  695. package/dist/esm/ion-modal.entry.js +215 -91
  696. package/dist/esm/ion-nav_2.entry.js +14 -11
  697. package/dist/esm/ion-picker-column-option.entry.js +12 -8
  698. package/dist/esm/ion-picker-column.entry.js +13 -13
  699. package/dist/esm/ion-picker.entry.js +10 -6
  700. package/dist/esm/ion-popover.entry.js +21 -19
  701. package/dist/esm/ion-progress-bar.entry.js +27 -9
  702. package/dist/esm/ion-radio_2.entry.js +35 -17
  703. package/dist/esm/ion-range.entry.js +20 -13
  704. package/dist/esm/ion-refresher_2.entry.js +39 -21
  705. package/dist/esm/ion-reorder_2.entry.js +38 -14
  706. package/dist/esm/ion-ripple-effect.entry.js +15 -7
  707. package/dist/esm/ion-route_4.entry.js +10 -9
  708. package/dist/esm/ion-searchbar.entry.js +137 -24
  709. package/dist/esm/ion-segment-content.entry.js +2 -2
  710. package/dist/esm/ion-segment-view.entry.js +13 -3
  711. package/dist/esm/ion-segment_2.entry.js +23 -16
  712. package/dist/esm/ion-select-modal.entry.js +119 -40
  713. package/dist/esm/ion-select_3.entry.js +500 -84
  714. package/dist/esm/ion-spinner.entry.js +30 -8
  715. package/dist/esm/ion-split-pane.entry.js +13 -9
  716. package/dist/esm/ion-tab-bar_2.entry.js +147 -23
  717. package/dist/esm/ion-tab_2.entry.js +8 -7
  718. package/dist/esm/ion-text.entry.js +7 -7
  719. package/dist/esm/ion-textarea.entry.js +137 -23
  720. package/dist/esm/ion-toast.entry.js +44 -21
  721. package/dist/esm/ion-toggle.entry.js +82 -25
  722. package/dist/esm/ionic-global--9mOmThr.js +508 -0
  723. package/dist/esm/ionic.js +5 -5
  724. package/dist/esm/{ios.transition--aMF-pDH.js → ios.transition-DoQTN5Jk.js} +7 -5
  725. package/dist/esm/{keyboard-ywgs5efA.js → keyboard-Ca1zVCcH.js} +4 -3
  726. package/dist/esm/{keyboard-CUw4ekVy.js → keyboard-Dnno7-Ci.js} +1 -1
  727. package/dist/esm/{keyboard-controller-BaaVITYt.js → keyboard-controller-BpOdk6xN.js} +5 -3
  728. package/dist/esm/list-Dhi5xtNS.js +6 -0
  729. package/dist/esm/loader.js +5 -5
  730. package/dist/esm/{md.transition-BEVbfm8j.js → md.transition-DZydrWwq.js} +6 -5
  731. package/dist/esm/{notch-controller-DAcvKU57.js → notch-controller-klgNWpjJ.js} +2 -2
  732. package/dist/esm/overlay-control-label-PzmQ86nh.js +48 -0
  733. package/dist/esm/{overlays-F8GHPo-e.js → overlays-CpQ6Df2g.js} +107 -13
  734. package/dist/esm/select-option-render-y_4XoEqH.js +109 -0
  735. package/dist/esm/{status-tap-BfJqFSLF.js → status-tap-fYFdZg6z.js} +4 -3
  736. package/dist/esm/{swipe-back-BZBFwTQV.js → swipe-back-BzGqTrrq.js} +3 -2
  737. package/dist/esm/{theme-DiVJyqlX.js → theme-DaJxRxSQ.js} +25 -1
  738. package/dist/esm/validity-BjW8SOqw.js +48 -0
  739. package/dist/esm/x-BDqjX7Z_.js +6 -0
  740. package/dist/html.html-data.json +2570 -105
  741. package/dist/ionic/index.esm.js +1 -1
  742. package/dist/ionic/ionic.esm.js +1 -1
  743. package/dist/ionic/p-0030507d.entry.js +4 -0
  744. package/dist/ionic/p-084c2623.entry.js +4 -0
  745. package/dist/ionic/p-09f8a57f.entry.js +4 -0
  746. package/dist/ionic/p-108c0f30.entry.js +4 -0
  747. package/dist/ionic/p-1439fecb.entry.js +4 -0
  748. package/dist/ionic/p-199bffb3.entry.js +4 -0
  749. package/dist/ionic/p-19a1ff9a.entry.js +4 -0
  750. package/dist/ionic/p-1a026890.entry.js +4 -0
  751. package/dist/ionic/p-1ad16c09.entry.js +4 -0
  752. package/dist/ionic/p-2aa7567e.entry.js +4 -0
  753. package/dist/ionic/p-3656314c.entry.js +4 -0
  754. package/dist/ionic/p-379cc989.entry.js +4 -0
  755. package/dist/ionic/p-3f18dfe9.entry.js +4 -0
  756. package/dist/ionic/p-3f1dbb47.entry.js +4 -0
  757. package/dist/ionic/p-40d9e029.entry.js +4 -0
  758. package/dist/ionic/p-410d60c5.entry.js +4 -0
  759. package/dist/ionic/p-456736d1.entry.js +4 -0
  760. package/dist/ionic/p-48e3cb9e.entry.js +4 -0
  761. package/dist/ionic/p-497f6391.entry.js +4 -0
  762. package/dist/ionic/p-64b4e6eb.entry.js +4 -0
  763. package/dist/ionic/p-66eb0193.entry.js +4 -0
  764. package/dist/ionic/p-67c2d349.entry.js +4 -0
  765. package/dist/ionic/p-7054a1b9.entry.js +4 -0
  766. package/dist/ionic/p-70ee89c9.entry.js +4 -0
  767. package/dist/ionic/p-7186786e.entry.js +4 -0
  768. package/dist/ionic/p-7194f6fa.entry.js +4 -0
  769. package/dist/ionic/p-76c70824.entry.js +4 -0
  770. package/dist/ionic/p-7e6112fc.entry.js +4 -0
  771. package/dist/ionic/p-7f294078.entry.js +4 -0
  772. package/dist/ionic/p-8458f1b6.entry.js +4 -0
  773. package/dist/ionic/p-88e7f52a.entry.js +4 -0
  774. package/dist/ionic/p-89eab395.entry.js +4 -0
  775. package/dist/ionic/p-93315d96.entry.js +4 -0
  776. package/dist/ionic/p-9ccfb733.entry.js +4 -0
  777. package/dist/ionic/p-9dfbe98d.entry.js +4 -0
  778. package/dist/ionic/{p-DjriolRs.js → p-B2-sg7NJ.js} +1 -1
  779. package/dist/ionic/p-B4ikoeaj.js +4 -0
  780. package/dist/ionic/p-BDqjX7Z_.js +4 -0
  781. package/dist/ionic/p-BFBCtvFI.js +4 -0
  782. package/dist/ionic/p-BQgCYKKG.js +4 -0
  783. package/dist/ionic/p-BYAxJDlE.js +4 -0
  784. package/dist/ionic/p-BYSs-jZz.js +4 -0
  785. package/dist/ionic/p-BjW8SOqw.js +4 -0
  786. package/dist/ionic/{p-CKvCXMs9.js → p-BmEwy3tY.js} +1 -1
  787. package/{components/p-BS1TtEiJ.js → dist/ionic/p-C8IHbcuP.js} +1 -1
  788. package/dist/ionic/p-CDn0uNJA.js +4 -0
  789. package/dist/ionic/p-CHE1xWbg.js +4 -0
  790. package/dist/ionic/p-CK179dBb.js +4 -0
  791. package/dist/ionic/p-CLHjFE18.js +4 -0
  792. package/dist/ionic/p-CYhXBSjd.js +4 -0
  793. package/{components/p-D13Eaw-8.js → dist/ionic/p-CuGhCBt7.js} +1 -1
  794. package/dist/ionic/p-D1t981Ih.js +4 -0
  795. package/dist/ionic/p-D2tu5BUg.js +4 -0
  796. package/dist/ionic/p-DDFhx1YX.js +4 -0
  797. package/dist/ionic/{p-B8xlpH8p.js → p-DKWXAwlR.js} +1 -1
  798. package/dist/ionic/p-DNGqaUsl.js +4 -0
  799. package/dist/ionic/p-DaJxRxSQ.js +4 -0
  800. package/dist/ionic/p-DaknVxZR.js +4 -0
  801. package/dist/ionic/p-Dhi5xtNS.js +4 -0
  802. package/dist/ionic/p-DoyDJ2X5.js +4 -0
  803. package/dist/ionic/p-E1wtzfO0.js +4 -0
  804. package/dist/ionic/p-FvDKM4Ax.js +4 -0
  805. package/dist/ionic/p-IXZW3FBt.js +4 -0
  806. package/dist/ionic/p-Omi_TcwW.js +5 -0
  807. package/dist/ionic/p-PoSbs6oh.js +4 -0
  808. package/dist/ionic/p-PzmQ86nh.js +4 -0
  809. package/dist/ionic/p-VAJ_3beW.js +4 -0
  810. package/dist/ionic/p-a3f9be52.entry.js +4 -0
  811. package/dist/ionic/p-ad4d0138.entry.js +4 -0
  812. package/dist/ionic/p-b4ba0050.entry.js +4 -0
  813. package/dist/ionic/p-b4fd91b8.entry.js +4 -0
  814. package/dist/ionic/p-b653f4c2.entry.js +4 -0
  815. package/dist/ionic/p-b69add0e.entry.js +4 -0
  816. package/dist/ionic/p-b7235e85.entry.js +4 -0
  817. package/dist/ionic/p-bc317965.entry.js +4 -0
  818. package/dist/ionic/p-bsfLvRbd.js +4 -0
  819. package/dist/ionic/p-c21a780d.entry.js +4 -0
  820. package/dist/ionic/p-c5118189.entry.js +4 -0
  821. package/dist/ionic/p-c684a3b6.entry.js +4 -0
  822. package/dist/ionic/p-c7139c41.entry.js +4 -0
  823. package/dist/ionic/p-c94fbdab.entry.js +4 -0
  824. package/dist/ionic/p-dac1d4de.entry.js +4 -0
  825. package/dist/ionic/p-dd2981d0.entry.js +4 -0
  826. package/dist/ionic/p-eTI_FbQJ.js +4 -0
  827. package/dist/ionic/p-f72200cc.entry.js +4 -0
  828. package/dist/ionic/p-fIOYmaqA.js +4 -0
  829. package/dist/ionic/p-fbdbdb3e.entry.js +4 -0
  830. package/dist/ionic/p-fd519e2b.entry.js +4 -0
  831. package/dist/ionic/p-ff09d2a5.entry.js +4 -0
  832. package/dist/ionic/p-u6HLvq0g.js +4 -0
  833. package/dist/ionic/p-vXpMhGrs.js +4 -0
  834. package/dist/types/components/accordion/accordion.d.ts +6 -3
  835. package/dist/types/components/accordion-group/accordion-group.d.ts +12 -1
  836. package/dist/types/components/action-sheet/action-sheet-interface.d.ts +3 -7
  837. package/dist/types/components/action-sheet/action-sheet.d.ts +3 -2
  838. package/dist/types/components/alert/alert-interface.d.ts +3 -7
  839. package/dist/types/components/alert/alert.d.ts +3 -2
  840. package/dist/types/components/app/app.d.ts +4 -5
  841. package/dist/types/components/avatar/avatar.d.ts +32 -0
  842. package/dist/types/components/back-button/back-button.d.ts +2 -1
  843. package/dist/types/components/backdrop/backdrop.d.ts +4 -0
  844. package/dist/types/components/badge/badge.d.ts +34 -1
  845. package/dist/types/components/breadcrumb/breadcrumb.d.ts +4 -1
  846. package/dist/types/components/breadcrumbs/breadcrumbs.d.ts +2 -2
  847. package/dist/types/components/button/button.d.ts +23 -8
  848. package/dist/types/components/buttons/buttons.d.ts +5 -1
  849. package/dist/types/components/card/card.d.ts +8 -1
  850. package/dist/types/components/card-content/card-content.d.ts +2 -1
  851. package/dist/types/components/card-header/card-header.d.ts +3 -2
  852. package/dist/types/components/card-subtitle/card-subtitle.d.ts +2 -1
  853. package/dist/types/components/card-title/card-title.d.ts +2 -1
  854. package/dist/types/components/checkbox/checkbox.d.ts +14 -4
  855. package/dist/types/components/chip/chip.d.ts +26 -1
  856. package/dist/types/components/col/col.d.ts +52 -5
  857. package/dist/types/components/content/content.d.ts +3 -0
  858. package/dist/types/components/datetime/datetime.d.ts +26 -1
  859. package/dist/types/components/datetime/utils/data.d.ts +5 -5
  860. package/dist/types/components/datetime-button/datetime-button.d.ts +2 -1
  861. package/dist/types/components/divider/divider.d.ts +20 -0
  862. package/dist/types/components/fab/fab.d.ts +4 -0
  863. package/dist/types/components/fab-button/fab-button.d.ts +5 -3
  864. package/dist/types/components/fab-list/fab-list.d.ts +4 -0
  865. package/dist/types/components/footer/footer.d.ts +4 -3
  866. package/dist/types/components/gallery/gallery-constants.d.ts +9 -0
  867. package/dist/types/components/gallery/gallery-interface.d.ts +10 -0
  868. package/dist/types/components/gallery/gallery.d.ts +183 -0
  869. package/dist/types/components/gallery/test/utils.d.ts +2 -0
  870. package/dist/types/components/grid/grid.d.ts +4 -0
  871. package/dist/types/components/header/header.d.ts +9 -3
  872. package/dist/types/components/header/header.utils.d.ts +3 -3
  873. package/dist/types/components/img/img.d.ts +3 -0
  874. package/dist/types/components/infinite-scroll/infinite-scroll.d.ts +21 -0
  875. package/dist/types/components/infinite-scroll-content/infinite-scroll-content.d.ts +4 -0
  876. package/dist/types/components/input/input.d.ts +31 -5
  877. package/dist/types/components/input-otp/input-otp.d.ts +37 -0
  878. package/dist/types/components/input-password-toggle/input-password-toggle.d.ts +2 -0
  879. package/dist/types/components/item/item.d.ts +11 -4
  880. package/dist/types/components/item-divider/item-divider.d.ts +2 -1
  881. package/dist/types/components/item-group/item-group.d.ts +4 -0
  882. package/dist/types/components/item-option/item-option.d.ts +18 -1
  883. package/dist/types/components/item-options/item-options.d.ts +4 -0
  884. package/dist/types/components/item-sliding/item-sliding.d.ts +47 -1
  885. package/dist/types/components/item-sliding/test/test.utils.d.ts +13 -0
  886. package/dist/types/components/label/label.d.ts +2 -1
  887. package/dist/types/components/list/list.d.ts +15 -1
  888. package/dist/types/components/list-header/list-header.d.ts +2 -1
  889. package/dist/types/components/loading/loading-interface.d.ts +2 -7
  890. package/dist/types/components/loading/loading.d.ts +3 -2
  891. package/dist/types/components/menu/menu.d.ts +3 -0
  892. package/dist/types/components/menu-button/menu-button.d.ts +3 -1
  893. package/dist/types/components/menu-toggle/menu-toggle.d.ts +3 -0
  894. package/dist/types/components/modal/animations/ionic.enter.d.ts +6 -0
  895. package/dist/types/components/modal/animations/ionic.leave.d.ts +6 -0
  896. package/dist/types/components/modal/gestures/sheet.d.ts +1 -1
  897. package/dist/types/components/modal/modal-interface.d.ts +4 -7
  898. package/dist/types/components/modal/modal.d.ts +11 -1
  899. package/dist/types/components/nav/nav-interface.d.ts +9 -1
  900. package/dist/types/components/nav/nav.d.ts +5 -1
  901. package/dist/types/components/nav-link/nav-link.d.ts +4 -0
  902. package/dist/types/components/note/note.d.ts +2 -1
  903. package/dist/types/components/picker/picker.d.ts +2 -1
  904. package/dist/types/components/picker-column/picker-column.d.ts +2 -1
  905. package/dist/types/components/picker-column-option/picker-column-option.d.ts +4 -0
  906. package/dist/types/components/picker-legacy/picker.d.ts +2 -1
  907. package/dist/types/components/popover/popover-interface.d.ts +3 -6
  908. package/dist/types/components/popover/popover.d.ts +6 -5
  909. package/dist/types/components/progress-bar/progress-bar.d.ts +10 -1
  910. package/dist/types/components/radio/radio.d.ts +2 -1
  911. package/dist/types/components/radio-group/radio-group.d.ts +12 -0
  912. package/dist/types/components/range/range.d.ts +2 -1
  913. package/dist/types/components/refresher/refresher.d.ts +2 -1
  914. package/dist/types/components/refresher-content/refresher-content.d.ts +4 -0
  915. package/dist/types/components/reorder/reorder.d.ts +9 -0
  916. package/dist/types/components/reorder-group/reorder-group.d.ts +4 -0
  917. package/dist/types/components/ripple-effect/ripple-effect.d.ts +4 -0
  918. package/dist/types/components/route/route.d.ts +4 -0
  919. package/dist/types/components/router/router.d.ts +4 -0
  920. package/dist/types/components/router-link/router-link.d.ts +4 -0
  921. package/dist/types/components/router-outlet/router-outlet.d.ts +4 -1
  922. package/dist/types/components/row/row.d.ts +4 -0
  923. package/dist/types/components/searchbar/searchbar.d.ts +51 -9
  924. package/dist/types/components/segment/segment.d.ts +2 -1
  925. package/dist/types/components/segment-button/segment-button.d.ts +2 -1
  926. package/dist/types/components/select/select-interface.d.ts +31 -0
  927. package/dist/types/components/select/select.d.ts +66 -13
  928. package/dist/types/components/select-modal/select-modal.d.ts +8 -0
  929. package/dist/types/components/select-option/select-option.d.ts +44 -0
  930. package/dist/types/components/select-popover/select-popover.d.ts +3 -0
  931. package/dist/types/components/skeleton-text/skeleton-text.d.ts +4 -0
  932. package/dist/types/components/spinner/spinner.d.ts +15 -0
  933. package/dist/types/components/split-pane/split-pane.d.ts +4 -0
  934. package/dist/types/components/tab/tab.d.ts +4 -0
  935. package/dist/types/components/tab-bar/tab-bar.d.ts +37 -2
  936. package/dist/types/components/tab-button/tab-button.d.ts +12 -1
  937. package/dist/types/components/tabs/tabs.d.ts +3 -0
  938. package/dist/types/components/text/text.d.ts +2 -1
  939. package/dist/types/components/textarea/textarea.d.ts +53 -4
  940. package/dist/types/components/thumbnail/thumbnail.d.ts +4 -0
  941. package/dist/types/components/title/title.d.ts +4 -0
  942. package/dist/types/components/toast/animations/utils.d.ts +2 -2
  943. package/dist/types/components/toast/toast-interface.d.ts +3 -7
  944. package/dist/types/components/toast/toast.d.ts +19 -2
  945. package/dist/types/components/toggle/toggle.d.ts +15 -1
  946. package/dist/types/components/toolbar/toolbar.d.ts +43 -3
  947. package/dist/types/components.d.ts +1819 -205
  948. package/dist/types/global/ionic-global.d.ts +28 -2
  949. package/dist/types/interface.d.ts +3 -0
  950. package/dist/types/utils/config.d.ts +106 -2
  951. package/dist/types/utils/css-value-validation.d.ts +12 -0
  952. package/dist/types/utils/focus-trap.d.ts +1 -1
  953. package/dist/types/utils/focus-visible.d.ts +13 -0
  954. package/dist/types/utils/forms/validity.d.ts +7 -0
  955. package/dist/types/utils/helpers.d.ts +11 -0
  956. package/dist/types/utils/overlay-control-label.d.ts +34 -0
  957. package/dist/types/utils/overlays-interface.d.ts +31 -1
  958. package/dist/types/utils/overlays.d.ts +1 -1
  959. package/dist/types/utils/sanitization/index.d.ts +32 -2
  960. package/dist/types/utils/select-option-render.d.ts +22 -0
  961. package/dist/types/utils/test/playwright/drag-element.d.ts +16 -3
  962. package/dist/types/utils/test/playwright/generator.d.ts +31 -2
  963. package/dist/types/utils/theme.d.ts +9 -0
  964. package/hydrate/index.js +5211 -1182
  965. package/hydrate/index.mjs +5211 -1182
  966. package/package.json +8 -4
  967. package/components/p-B6FQ0cKR.js +0 -4
  968. package/components/p-B6HaBl3o.js +0 -4
  969. package/components/p-B8b1Ukl9.js +0 -4
  970. package/components/p-BJoMtgfR.js +0 -4
  971. package/components/p-BNAG-aVv.js +0 -4
  972. package/components/p-BR3tZJmu.js +0 -4
  973. package/components/p-BSB38Tek.js +0 -4
  974. package/components/p-BTeL5HCK.js +0 -4
  975. package/components/p-BUbsoBOV.js +0 -4
  976. package/components/p-BYDc3hSE.js +0 -4
  977. package/components/p-BagjAGC0.js +0 -4
  978. package/components/p-BegtE7nr.js +0 -4
  979. package/components/p-BgwEQWW6.js +0 -4
  980. package/components/p-BmVRXR1y.js +0 -4
  981. package/components/p-BxwWvu-b.js +0 -4
  982. package/components/p-C4jPsTQa.js +0 -4
  983. package/components/p-C59ryAuS.js +0 -4
  984. package/components/p-CBzELu-H.js +0 -4
  985. package/components/p-CDfQnFrd.js +0 -4
  986. package/components/p-CIGNaXM1.js +0 -4
  987. package/components/p-CO7fmmxt.js +0 -4
  988. package/components/p-Cf6Z1pmL.js +0 -4
  989. package/components/p-CgfaEEem.js +0 -4
  990. package/components/p-CgqKJg96.js +0 -4
  991. package/components/p-CneGxKsZ.js +0 -4
  992. package/components/p-CoA-aqGF.js +0 -4
  993. package/components/p-Cq8cQ0NL.js +0 -4
  994. package/components/p-Csw8xuz4.js +0 -4
  995. package/components/p-CtWGkNnJ.js +0 -4
  996. package/components/p-Cy5XSfIk.js +0 -4
  997. package/components/p-Cyxa_4PV.js +0 -4
  998. package/components/p-Cz5nLPGT.js +0 -4
  999. package/components/p-D-cP12ZN.js +0 -4
  1000. package/components/p-D6NJwNJN.js +0 -4
  1001. package/components/p-D6Ynv7Xh.js +0 -4
  1002. package/components/p-DHsZWn1l.js +0 -4
  1003. package/components/p-DJMZehmW.js +0 -4
  1004. package/components/p-DJztqcrH.js +0 -4
  1005. package/components/p-DYdpXONG.js +0 -4
  1006. package/components/p-DZhbcvo5.js +0 -4
  1007. package/components/p-DgbT0exM.js +0 -4
  1008. package/components/p-DiVJyqlX.js +0 -4
  1009. package/components/p-DlgpdeOi.js +0 -4
  1010. package/components/p-DvOO1fxp.js +0 -4
  1011. package/components/p-FBcnjE5W.js +0 -4
  1012. package/components/p-Q1-Xy3As.js +0 -4
  1013. package/components/p-SBseW5KJ.js +0 -4
  1014. package/components/p-ZjP4CjeZ.js +0 -4
  1015. package/components/p-ZuZOauwD.js +0 -4
  1016. package/components/p-ak_d-z48.js +0 -4
  1017. package/components/p-fpbh6w3f.js +0 -4
  1018. package/components/p-kvaDs24J.js +0 -4
  1019. package/components/p-vEbVo2hO.js +0 -4
  1020. package/dist/cjs/hardware-back-button-C4rMJ5uI.js +0 -121
  1021. package/dist/cjs/index-DkNv4J_i.js +0 -10
  1022. package/dist/cjs/ionic-global-Bc3kJi1Z.js +0 -151
  1023. package/dist/cjs/validity-BpS37YFM.js +0 -19
  1024. package/dist/esm/hardware-back-button-CTe4XmL7.js +0 -115
  1025. package/dist/esm/index-ZjP4CjeZ.js +0 -7
  1026. package/dist/esm/ionic-global-DfbeLwcV.js +0 -146
  1027. package/dist/esm/validity-DJztqcrH.js +0 -17
  1028. package/dist/ionic/p-031b76f7.entry.js +0 -4
  1029. package/dist/ionic/p-045a6a42.entry.js +0 -4
  1030. package/dist/ionic/p-07506134.entry.js +0 -4
  1031. package/dist/ionic/p-078037da.entry.js +0 -4
  1032. package/dist/ionic/p-084c25b2.entry.js +0 -4
  1033. package/dist/ionic/p-0d8b5c38.entry.js +0 -4
  1034. package/dist/ionic/p-16813ce7.entry.js +0 -4
  1035. package/dist/ionic/p-1b169fb6.entry.js +0 -4
  1036. package/dist/ionic/p-1ca9c36b.entry.js +0 -4
  1037. package/dist/ionic/p-23ec35e4.entry.js +0 -4
  1038. package/dist/ionic/p-23fac490.entry.js +0 -4
  1039. package/dist/ionic/p-28a9e720.entry.js +0 -4
  1040. package/dist/ionic/p-294f4bb5.entry.js +0 -4
  1041. package/dist/ionic/p-2a68388b.entry.js +0 -4
  1042. package/dist/ionic/p-2f5a8140.entry.js +0 -4
  1043. package/dist/ionic/p-2fd110aa.entry.js +0 -4
  1044. package/dist/ionic/p-301c43f8.entry.js +0 -4
  1045. package/dist/ionic/p-370a60ee.entry.js +0 -4
  1046. package/dist/ionic/p-53f750a5.entry.js +0 -4
  1047. package/dist/ionic/p-6888a88b.entry.js +0 -4
  1048. package/dist/ionic/p-6af16209.entry.js +0 -4
  1049. package/dist/ionic/p-6b701daa.entry.js +0 -4
  1050. package/dist/ionic/p-6b97f2a3.entry.js +0 -4
  1051. package/dist/ionic/p-7620be24.entry.js +0 -4
  1052. package/dist/ionic/p-771b27a5.entry.js +0 -4
  1053. package/dist/ionic/p-7761ef65.entry.js +0 -4
  1054. package/dist/ionic/p-7ca71c83.entry.js +0 -4
  1055. package/dist/ionic/p-80cac7a2.entry.js +0 -4
  1056. package/dist/ionic/p-87125490.entry.js +0 -4
  1057. package/dist/ionic/p-8fda6a62.entry.js +0 -4
  1058. package/dist/ionic/p-9833cf63.entry.js +0 -4
  1059. package/dist/ionic/p-9cbc6f1f.entry.js +0 -4
  1060. package/dist/ionic/p-9eeaBrnk.js +0 -4
  1061. package/dist/ionic/p-BAt5H1ac.js +0 -4
  1062. package/dist/ionic/p-BW_TRJm8.js +0 -4
  1063. package/dist/ionic/p-BmVRXR1y.js +0 -4
  1064. package/dist/ionic/p-Bum7H1fw.js +0 -4
  1065. package/dist/ionic/p-C0JvVFMv.js +0 -4
  1066. package/dist/ionic/p-CGmVTdWh.js +0 -4
  1067. package/dist/ionic/p-CIGNaXM1.js +0 -4
  1068. package/dist/ionic/p-CYbRmDdy.js +0 -4
  1069. package/dist/ionic/p-CmFz1Mjc.js +0 -4
  1070. package/dist/ionic/p-CtA-yJYy.js +0 -4
  1071. package/dist/ionic/p-CtWGkNnJ.js +0 -4
  1072. package/dist/ionic/p-D8HJQ1qq.js +0 -4
  1073. package/dist/ionic/p-DB_iPQC-.js +0 -4
  1074. package/dist/ionic/p-DJztqcrH.js +0 -4
  1075. package/dist/ionic/p-DLbbmF9h.js +0 -4
  1076. package/dist/ionic/p-DTPR1Wpn.js +0 -4
  1077. package/dist/ionic/p-DV3sJJW8.js +0 -4
  1078. package/dist/ionic/p-DcSNwXfb.js +0 -4
  1079. package/dist/ionic/p-DiVJyqlX.js +0 -4
  1080. package/dist/ionic/p-DtVZDHlS.js +0 -4
  1081. package/dist/ionic/p-IGIE5vDm.js +0 -5
  1082. package/dist/ionic/p-NFFyoJ4Q.js +0 -4
  1083. package/dist/ionic/p-ZjP4CjeZ.js +0 -4
  1084. package/dist/ionic/p-a805674e.entry.js +0 -4
  1085. package/dist/ionic/p-a84f2d21.entry.js +0 -4
  1086. package/dist/ionic/p-a893c61c.entry.js +0 -4
  1087. package/dist/ionic/p-aa812c4b.entry.js +0 -4
  1088. package/dist/ionic/p-b325a113.entry.js +0 -4
  1089. package/dist/ionic/p-b6e0ff03.entry.js +0 -4
  1090. package/dist/ionic/p-bcaa827e.entry.js +0 -4
  1091. package/dist/ionic/p-c3cce9d8.entry.js +0 -4
  1092. package/dist/ionic/p-ca31010f.entry.js +0 -4
  1093. package/dist/ionic/p-cf8757a7.entry.js +0 -4
  1094. package/dist/ionic/p-d4e8b473.entry.js +0 -4
  1095. package/dist/ionic/p-e663bc5a.entry.js +0 -4
  1096. package/dist/ionic/p-e6cedcd7.entry.js +0 -4
  1097. package/dist/ionic/p-e863ffe8.entry.js +0 -4
  1098. package/dist/ionic/p-f2deaceb.entry.js +0 -4
  1099. package/dist/ionic/p-f3e7b155.entry.js +0 -4
  1100. package/dist/ionic/p-f5dfb9a3.entry.js +0 -4
  1101. package/dist/ionic/p-f69a5f71.entry.js +0 -4
  1102. package/dist/ionic/p-f8186550.entry.js +0 -4
  1103. package/dist/ionic/p-fdbc90d4.entry.js +0 -4
  1104. package/dist/ionic/p-gbVXD275.js +0 -4
  1105. package/dist/ionic/p-hNN3VvaC.js +0 -4
  1106. /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
@@ -3,8 +3,22 @@
3
3
  */
4
4
  import { printIonError } from "../logging/index";
5
5
  /**
6
- * Does a simple sanitization of all elements
7
- * in an untrusted string
6
+ * Sanitize an untrusted HTML string.
7
+ *
8
+ * Parses the string into a detached DOM, removes blocked tags, strips
9
+ * attributes outside the strict `allowedAttributes` list, and scrubs
10
+ * `javascript:` URLs. Returns the sanitized HTML string.
11
+ *
12
+ * Use this when you have an HTML string from an unknown source and need
13
+ * to render it via `innerHTML`. Prefer `sanitizeDOMTree` when the source
14
+ * is author-controlled DOM that must keep its component attributes
15
+ * (`size`, `color`, `shape`, etc.).
16
+ *
17
+ * @param untrustedString - The HTML string to sanitize. Pass an
18
+ * `IonicSafeString` to bypass sanitization, or `undefined` to short-circuit.
19
+ * @returns The sanitized HTML string, or `undefined` if the input was
20
+ * `undefined`. Returns `''` if sanitization fails or the input contains
21
+ * an inline `onload=` handler.
8
22
  */
9
23
  export const sanitizeDOMString = (untrustedString) => {
10
24
  try {
@@ -80,13 +94,40 @@ export const sanitizeDOMString = (untrustedString) => {
80
94
  return '';
81
95
  }
82
96
  };
97
+ /**
98
+ * Sanitize an entire author-controlled DOM tree in place.
99
+ *
100
+ * Removes blocked tags (`script`, `iframe`, etc.) from the subtree and
101
+ * then sanitizes attributes on every remaining element. Author-written
102
+ * attributes like `size`, `color`, and `shape` are preserved; event
103
+ * handlers (`on*`) and `javascript:` URLs are stripped.
104
+ *
105
+ * Use this when you have a DOM tree that the developer authored (e.g.
106
+ * cloned slot content from a component) and you need to render it
107
+ * elsewhere safely.
108
+ *
109
+ * @param root - The root element whose subtree will be sanitized in
110
+ * place. No-op when the sanitizer is disabled via `Ionic.config`.
111
+ */
112
+ export const sanitizeDOMTree = (root) => {
113
+ if (!isSanitizerEnabled()) {
114
+ return;
115
+ }
116
+ blockedTags.forEach((tag) => {
117
+ const matches = root.querySelectorAll(tag);
118
+ for (let i = matches.length - 1; i >= 0; i--) {
119
+ matches[i].remove();
120
+ }
121
+ });
122
+ sanitizeElement(root, true);
123
+ };
83
124
  /**
84
125
  * Clean up current element based on allowed attributes
85
126
  * and then recursively dig down into any child elements to
86
127
  * clean those up as well
87
128
  */
88
129
  // TODO(FW-2832): type (using Element triggers other type errors as well)
89
- const sanitizeElement = (element) => {
130
+ const sanitizeElement = (element, allowSafeAuthorAttributes = false) => {
90
131
  // IE uses childNodes, so ignore nodes that are not elements
91
132
  if (element.nodeType && element.nodeType !== 1) {
92
133
  return;
@@ -104,8 +145,15 @@ const sanitizeElement = (element) => {
104
145
  for (let i = element.attributes.length - 1; i >= 0; i--) {
105
146
  const attribute = element.attributes.item(i);
106
147
  const attributeName = attribute.name;
148
+ const lowerName = attributeName.toLowerCase();
107
149
  // remove non-allowed attribs
108
- if (!allowedAttributes.includes(attributeName.toLowerCase())) {
150
+ if (!allowSafeAuthorAttributes && !allowedAttributes.includes(lowerName)) {
151
+ element.removeAttribute(attributeName);
152
+ continue;
153
+ }
154
+ // strip event-handler attributes (already removed by the allowlist
155
+ // when !allowSafeAuthorAttributes; this guards the permissive path)
156
+ if (lowerName.startsWith('on')) {
109
157
  element.removeAttribute(attributeName);
110
158
  continue;
111
159
  }
@@ -118,9 +166,13 @@ const sanitizeElement = (element) => {
118
166
  * such as &Tab; and still be valid (i.e. java&Tab;script)
119
167
  */
120
168
  const propertyValue = element[attributeName];
169
+ // Only call .toLowerCase() when propertyValue is a string. Some DOM
170
+ // properties (e.g. `disabled`) are booleans and would throw.
121
171
  /* eslint-disable */
122
172
  if ((attributeValue != null && attributeValue.toLowerCase().includes('javascript:')) ||
123
- (propertyValue != null && propertyValue.toLowerCase().includes('javascript:'))) {
173
+ (propertyValue != null &&
174
+ typeof propertyValue === 'string' &&
175
+ propertyValue.toLowerCase().includes('javascript:'))) {
124
176
  element.removeAttribute(attributeName);
125
177
  }
126
178
  /* eslint-enable */
@@ -131,7 +183,7 @@ const sanitizeElement = (element) => {
131
183
  const childElements = getElementChildren(element);
132
184
  /* eslint-disable-next-line */
133
185
  for (let i = 0; i < childElements.length; i++) {
134
- sanitizeElement(childElements[i]);
186
+ sanitizeElement(childElements[i], allowSafeAuthorAttributes);
135
187
  }
136
188
  };
137
189
  /**
@@ -0,0 +1,106 @@
1
+ /*!
2
+ * (C) Ionic http://ionicframework.com - MIT License
3
+ */
4
+ import { h } from "@stencil/core";
5
+ /**
6
+ * Converts a DOM node into a Stencil VNode (or text string) so the
7
+ * resulting tree is rendered through the component's normal render
8
+ * path. Rendering through Stencil ensures that scoped CSS classes
9
+ * (e.g. `sc-ion-action-sheet-ionic`) are applied to every element.
10
+ *
11
+ * Highly recommended to pre-sanitize the source DOM (see
12
+ * `getOptionContent` in select.tsx). This function performs pure
13
+ * structural conversion — no security filtering.
14
+ *
15
+ * Preserves attributes only — properties set imperatively on the source
16
+ * element (e.g. `input.value` after a user types) won't carry through.
17
+ * In practice this isn't a concern: interactive controls shouldn't
18
+ * appear in select-option rich content since they'd nest inside the
19
+ * overlay's button/radio/checkbox wrapper, which is invalid HTML and
20
+ * an accessibility issue.
21
+ *
22
+ * @param node - The DOM node to convert. Text nodes become strings,
23
+ * element nodes become VNodes, and any other node types are skipped.
24
+ * @param keyPrefix - String prefix used to build a stable VNode key,
25
+ * so Stencil's diff can preserve elements across re-renders.
26
+ * @param index - Position of this node among its siblings. Combined
27
+ * with `keyPrefix` to form the final unique key.
28
+ * @returns The converted VNode, a text string, or `null` if the node
29
+ * type isn't supported.
30
+ */
31
+ const cloneToVNode = (node, keyPrefix, index) => {
32
+ var _a;
33
+ if (node.nodeType === Node.TEXT_NODE) {
34
+ return (_a = node.textContent) !== null && _a !== void 0 ? _a : '';
35
+ }
36
+ if (node.nodeType !== Node.ELEMENT_NODE) {
37
+ return null;
38
+ }
39
+ const el = node;
40
+ const tag = el.tagName.toLowerCase();
41
+ const key = `${keyPrefix}-${index}`;
42
+ const attrs = { key };
43
+ for (let i = 0; i < el.attributes.length; i++) {
44
+ const attr = el.attributes.item(i);
45
+ attrs[attr.name] = attr.value;
46
+ }
47
+ const children = Array.from(el.childNodes)
48
+ .map((child, i) => cloneToVNode(child, key, i))
49
+ .filter((c) => c !== null);
50
+ return h(tag, attrs, children);
51
+ };
52
+ /**
53
+ * Renders cloned DOM content as Stencil JSX. Walking the source DOM
54
+ * into VNodes (rather than injecting it via innerHTML) keeps the
55
+ * content inside Stencil's render path, so scoped CSS classes are
56
+ * applied automatically and component attributes like `size` or
57
+ * `color` survive intact.
58
+ *
59
+ * Span elements should be used when this content renders within buttons,
60
+ * depending on the select interface. Buttons can only have phrasing
61
+ * content to prevent accessibility issues.
62
+ *
63
+ * @param id - Unique identifier for generating stable virtual DOM keys.
64
+ * @param content - The HTMLElement container whose child nodes will be cloned.
65
+ * @param className - CSS class applied to the wrapper element.
66
+ * @param useSpan - Whether to use a span element instead of a div for the wrapper.
67
+ */
68
+ const renderClonedContent = (id, content, className, useSpan = false) => {
69
+ const Tag = useSpan ? 'span' : 'div';
70
+ const keyPrefix = `${className}-${id}`;
71
+ return (h(Tag, { class: className, key: keyPrefix }, Array.from(content.childNodes).map((child, i) => cloneToVNode(child, keyPrefix, i))));
72
+ };
73
+ /**
74
+ * Renders the label content for a select option within an overlay
75
+ * interface based on the presence of rich content.
76
+ *
77
+ * Span elements should be used when this content renders within buttons,
78
+ * depending on the select interface. Buttons can only have phrasing
79
+ * content to prevent accessibility issues.
80
+ *
81
+ * @param option - The content option data containing label, slots,
82
+ * and description.
83
+ * @param className - The base CSS class for the label element.
84
+ * @param useSpan - Whether to use a span element instead of a div for the label.
85
+ */
86
+ export const renderOptionLabel = (option, className, useSpan = false) => {
87
+ const { id, label, startContent, endContent, description } = option;
88
+ const hasRichContent = !!startContent || !!endContent || !!description;
89
+ const Tag = useSpan ? 'span' : 'div';
90
+ // Render simple string label if there is no rich content to display
91
+ if (!hasRichContent && (typeof label === 'string' || !label)) {
92
+ return (h(Tag, { class: className, key: `${className}-${id}` }, label));
93
+ }
94
+ // Render the main label
95
+ const labelEl = typeof label === 'string' || !label ? (
96
+ // Label is a simple string or undefined
97
+ h(Tag, { key: `${className}-label-${id}` }, label)) : (
98
+ // Label is an HTMLElement with potential rich content
99
+ renderClonedContent(id, label, `${className}-text`, useSpan));
100
+ // No rich content, render just the label
101
+ if (!hasRichContent) {
102
+ return (h(Tag, { class: className, key: `${className}-${id}` }, labelEl));
103
+ }
104
+ // Render label with rich content (start, end, description)
105
+ return (h(Tag, { class: `${className} ${className}-has-rich-content`, 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)));
106
+ };
@@ -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}/`) {