@ionic/core 8.8.11 → 8.8.12-dev.11781793379.156d3260

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 (1120) 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-item.d.ts +11 -0
  33. package/components/ion-gallery-item.js +4 -0
  34. package/components/ion-gallery.d.ts +11 -0
  35. package/components/ion-gallery.js +4 -0
  36. package/components/ion-grid.js +1 -1
  37. package/components/ion-header.js +1 -1
  38. package/components/ion-icon.js +1 -1
  39. package/components/ion-img.js +1 -1
  40. package/components/ion-infinite-scroll-content.js +1 -1
  41. package/components/ion-infinite-scroll.js +1 -1
  42. package/components/ion-input-otp.js +1 -1
  43. package/components/ion-input-password-toggle.js +1 -1
  44. package/components/ion-input.js +1 -1
  45. package/components/ion-item-divider.js +1 -1
  46. package/components/ion-item-group.js +1 -1
  47. package/components/ion-item-option.js +1 -1
  48. package/components/ion-item-options.js +1 -1
  49. package/components/ion-item-sliding.js +1 -1
  50. package/components/ion-item.js +1 -1
  51. package/components/ion-label.js +1 -1
  52. package/components/ion-list-header.js +1 -1
  53. package/components/ion-list.js +1 -1
  54. package/components/ion-loading.js +1 -1
  55. package/components/ion-menu-button.js +1 -1
  56. package/components/ion-menu-toggle.js +1 -1
  57. package/components/ion-menu.js +1 -1
  58. package/components/ion-modal.js +1 -1
  59. package/components/ion-nav-link.js +1 -1
  60. package/components/ion-nav.js +1 -1
  61. package/components/ion-note.js +1 -1
  62. package/components/ion-picker-column-option.js +1 -1
  63. package/components/ion-picker-column.js +1 -1
  64. package/components/ion-picker-legacy-column.js +1 -1
  65. package/components/ion-picker-legacy.js +1 -1
  66. package/components/ion-picker.js +1 -1
  67. package/components/ion-popover.js +1 -1
  68. package/components/ion-progress-bar.js +1 -1
  69. package/components/ion-radio-group.js +1 -1
  70. package/components/ion-radio.js +1 -1
  71. package/components/ion-range.js +1 -1
  72. package/components/ion-refresher-content.js +1 -1
  73. package/components/ion-refresher.js +1 -1
  74. package/components/ion-reorder-group.js +1 -1
  75. package/components/ion-reorder.js +1 -1
  76. package/components/ion-ripple-effect.js +1 -1
  77. package/components/ion-route-redirect.js +1 -1
  78. package/components/ion-route.js +1 -1
  79. package/components/ion-router-link.js +1 -1
  80. package/components/ion-router-outlet.js +1 -1
  81. package/components/ion-router.js +1 -1
  82. package/components/ion-row.js +1 -1
  83. package/components/ion-searchbar.js +1 -1
  84. package/components/ion-segment-button.js +1 -1
  85. package/components/ion-segment-content.js +1 -1
  86. package/components/ion-segment-view.js +1 -1
  87. package/components/ion-segment.js +1 -1
  88. package/components/ion-select-modal.js +1 -1
  89. package/components/ion-select-option.js +1 -1
  90. package/components/ion-select-popover.js +1 -1
  91. package/components/ion-select.js +1 -1
  92. package/components/ion-skeleton-text.js +1 -1
  93. package/components/ion-spinner.js +1 -1
  94. package/components/ion-split-pane.js +1 -1
  95. package/components/ion-tab-bar.js +1 -1
  96. package/components/ion-tab-button.js +1 -1
  97. package/components/ion-tab.js +1 -1
  98. package/components/ion-tabs.js +1 -1
  99. package/components/ion-text.js +1 -1
  100. package/components/ion-textarea.js +1 -1
  101. package/components/ion-thumbnail.js +1 -1
  102. package/components/ion-title.js +1 -1
  103. package/components/ion-toast.js +1 -1
  104. package/components/ion-toggle.js +1 -1
  105. package/components/ion-toolbar.js +1 -1
  106. package/components/p-B59jk20F.js +4 -0
  107. package/components/p-B8xhFBOE.js +4 -0
  108. package/components/p-BDqjX7Z_.js +4 -0
  109. package/components/p-BI03N_8J.js +4 -0
  110. package/components/p-BISCDmUD.js +4 -0
  111. package/components/{p-C4t5ymfq.js → p-BKSylJVh.js} +1 -1
  112. package/components/p-BKfkCIKU.js +4 -0
  113. package/components/p-BLlJA2Q9.js +4 -0
  114. package/components/p-BYSs-jZz.js +4 -0
  115. package/components/p-BYZR_5L4.js +4 -0
  116. package/components/p-BaPtaYEC.js +4 -0
  117. package/components/{p-BAYYcg3o.js → p-BbmXEfTR.js} +1 -1
  118. package/components/p-BiG3Zevl.js +4 -0
  119. package/components/p-BjW8SOqw.js +4 -0
  120. package/components/p-BoWc8hp0.js +4 -0
  121. package/components/p-BqRIq3ti.js +4 -0
  122. package/components/p-BskJOMNV.js +4 -0
  123. package/components/p-BwKpO3Is.js +4 -0
  124. package/components/p-BxA8Ha5k.js +4 -0
  125. package/components/p-BxnlgSC0.js +4 -0
  126. package/components/p-C9QYu-sR.js +4 -0
  127. package/components/p-CEY-R8M2.js +4 -0
  128. package/components/p-CEbQglhY.js +4 -0
  129. package/components/p-CGwI_XL6.js +4 -0
  130. package/components/p-CIdlZzoM.js +4 -0
  131. package/components/p-CODBQrPj.js +4 -0
  132. package/components/p-CWq1hA4y.js +4 -0
  133. package/components/p-CeL9Glto.js +4 -0
  134. package/components/p-Ck_9SoHZ.js +4 -0
  135. package/components/p-Cl94E1nn.js +4 -0
  136. package/components/p-CmnPD02Z.js +4 -0
  137. package/components/p-Cog60JgJ.js +4 -0
  138. package/components/p-CtaqMPhV.js +4 -0
  139. package/components/p-CyGaZ-Qb.js +4 -0
  140. package/components/p-CzFNvOq3.js +4 -0
  141. package/components/p-Czw29-II.js +4 -0
  142. package/components/p-D0Iqw6OZ.js +4 -0
  143. package/components/p-D1t981Ih.js +4 -0
  144. package/components/p-D4UIY4kz.js +4 -0
  145. package/components/p-D6oKOaRz.js +4 -0
  146. package/components/p-D6un2jDV.js +4 -0
  147. package/components/p-D9583Eo8.js +4 -0
  148. package/components/p-DABI8XVx.js +4 -0
  149. package/components/p-DBXSwfLt.js +4 -0
  150. package/components/p-DEZQwbtZ.js +4 -0
  151. package/components/p-DEnOtJ3m.js +4 -0
  152. package/components/p-DJw3WM2A.js +4 -0
  153. package/{dist/ionic/p-D13Eaw-8.js → components/p-DP96lPOT.js} +1 -1
  154. package/components/{p-DqLB8yFQ.js → p-DRnK3A-V.js} +1 -1
  155. package/components/p-DTmj4D2t.js +4 -0
  156. package/components/p-DaJxRxSQ.js +4 -0
  157. package/components/p-Daj5LWIm.js +4 -0
  158. package/components/p-Dg8OSVcP.js +4 -0
  159. package/components/p-Dhi5xtNS.js +4 -0
  160. package/components/p-DiKh2eQw.js +4 -0
  161. package/{dist/ionic/p-VAemlbDS.js → components/p-DmVUl5t4.js} +1 -1
  162. package/components/p-Dn77l_LX.js +4 -0
  163. package/components/{p-D5Ubpm7D.js → p-Dqgyr3aJ.js} +1 -1
  164. package/components/{p-cyNmxje6.js → p-Fagxa-Vi.js} +1 -1
  165. package/components/p-I0lsm6wZ.js +4 -0
  166. package/components/p-TaMIMwf5.js +4 -0
  167. package/components/p-ZOOvnqsf.js +4 -0
  168. package/components/p-ZWbVyMi6.js +4 -0
  169. package/components/p-_rgGxkzx.js +4 -0
  170. package/components/p-fIOYmaqA.js +4 -0
  171. package/components/p-vXpMhGrs.js +4 -0
  172. package/css/core.css +1 -1
  173. package/css/core.css.map +1 -1
  174. package/css/display.css +1 -1
  175. package/css/display.css.map +1 -1
  176. package/css/flex-utils.css +1 -1
  177. package/css/flex-utils.css.map +1 -1
  178. package/css/float-elements.css.map +1 -1
  179. package/css/global.bundle.css.map +1 -1
  180. package/css/ionic/bundle.ionic.css +1 -0
  181. package/css/ionic/bundle.ionic.css.map +1 -0
  182. package/css/ionic/core.ionic.css +1 -0
  183. package/css/ionic/core.ionic.css.map +1 -0
  184. package/css/ionic/global.bundle.ionic.css +1 -0
  185. package/css/ionic/global.bundle.ionic.css.map +1 -0
  186. package/css/ionic/ionic-swiper.ionic.css +1 -0
  187. package/css/ionic/ionic-swiper.ionic.css.map +1 -0
  188. package/css/ionic/link.ionic.css +1 -0
  189. package/css/ionic/link.ionic.css.map +1 -0
  190. package/css/ionic/structure.ionic.css +1 -0
  191. package/css/ionic/structure.ionic.css.map +1 -0
  192. package/css/ionic/typography.ionic.css +1 -0
  193. package/css/ionic/typography.ionic.css.map +1 -0
  194. package/css/ionic/utils.bundle.ionic.css +1 -0
  195. package/css/ionic/utils.bundle.ionic.css.map +1 -0
  196. package/css/ionic-swiper.css +1 -1
  197. package/css/ionic-swiper.css.map +1 -1
  198. package/css/ionic.bundle.css +1 -1
  199. package/css/ionic.bundle.css.map +1 -1
  200. package/css/normalize.css.map +1 -1
  201. package/css/padding.css.map +1 -1
  202. package/css/palettes/dark.always.css.map +1 -1
  203. package/css/palettes/dark.class.css.map +1 -1
  204. package/css/palettes/dark.system.css.map +1 -1
  205. package/css/palettes/high-contrast-dark.always.css.map +1 -1
  206. package/css/palettes/high-contrast-dark.class.css.map +1 -1
  207. package/css/palettes/high-contrast-dark.system.css.map +1 -1
  208. package/css/palettes/high-contrast.always.css.map +1 -1
  209. package/css/palettes/high-contrast.class.css.map +1 -1
  210. package/css/palettes/high-contrast.system.css.map +1 -1
  211. package/css/structure.css.map +1 -1
  212. package/css/text-alignment.css.map +1 -1
  213. package/css/text-transformation.css.map +1 -1
  214. package/css/typography.css.map +1 -1
  215. package/css/utils.bundle.css +1 -1
  216. package/css/utils.bundle.css.map +1 -1
  217. package/dist/cjs/{animation-BJq0kcy2.js → animation-B3xfVcDO.js} +3 -3
  218. package/dist/cjs/{app-globals-BlqrqKTN.js → app-globals-3ZoCVkn-.js} +1 -1
  219. package/dist/cjs/{button-active-0mPOKmV2.js → button-active-3tZKuPbT.js} +2 -2
  220. package/dist/cjs/{capacitor-DmA66EwP.js → capacitor-CQSg1uCo.js} +3 -3
  221. package/dist/cjs/caret-down-vtVgfXIs.js +8 -0
  222. package/dist/cjs/caret-left-CxZXLRv5.js +8 -0
  223. package/dist/cjs/caret-right-CRCgv98E.js +8 -0
  224. package/dist/cjs/config-DWdFbSNK.js +35 -0
  225. package/dist/cjs/{data-DLTUw-KF.js → data-DmCm0SEx.js} +6 -6
  226. package/dist/cjs/{focus-visible-CCvKiLh3.js → focus-visible-BIj-I3-C.js} +24 -0
  227. package/dist/cjs/{framework-delegate-BtICZDHr.js → framework-delegate-DC5nq_NN.js} +4 -2
  228. package/dist/cjs/{haptic-ClPPQ_PS.js → haptic-eix26ESE.js} +1 -1
  229. package/dist/cjs/{helpers-Cv23MFHM.js → helpers-DiOgV5hw.js} +71 -4
  230. package/dist/cjs/{index-BERfRao3.js → index-BaJ7_YbC.js} +4 -4
  231. package/dist/cjs/{index-CIrkNXqJ.js → index-BxEZd5IE.js} +2 -2
  232. package/dist/cjs/{index-DqmRDbxg.js → index-CgAbCW6L.js} +2 -0
  233. package/dist/cjs/index-CzFol6Yk.js +414 -0
  234. package/dist/cjs/{index-aC4x3Fk3.js → index-DYRcC3bw.js} +15 -15
  235. package/dist/cjs/{index-Ct7gcRif.js → index-GZU9YrFc.js} +41 -4
  236. package/dist/cjs/{index-D81eLYUM.js → index-bX3nz2vw.js} +9 -8
  237. package/dist/cjs/index.cjs.js +16 -16
  238. package/dist/cjs/{input-shims-CFLg7uzj.js → input-shims-BSEBw22J.js} +18 -17
  239. package/dist/cjs/{input.utils-DetjmtH2.js → input.utils-D68wgI2Y.js} +5 -5
  240. package/dist/cjs/ion-accordion_2.cjs.entry.js +61 -29
  241. package/dist/cjs/ion-action-sheet.cjs.entry.js +41 -22
  242. package/dist/cjs/ion-alert.cjs.entry.js +78 -41
  243. package/dist/cjs/ion-app_8.cjs.entry.js +292 -157
  244. package/dist/cjs/ion-avatar_3.cjs.entry.js +125 -13
  245. package/dist/cjs/ion-back-button.cjs.entry.js +31 -22
  246. package/dist/cjs/ion-backdrop.cjs.entry.js +10 -7
  247. package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +54 -18
  248. package/dist/cjs/ion-button_2.cjs.entry.js +59 -22
  249. package/dist/cjs/ion-card_5.cjs.entry.js +55 -33
  250. package/dist/cjs/ion-checkbox.cjs.entry.js +37 -17
  251. package/dist/cjs/ion-chip.cjs.entry.js +50 -9
  252. package/dist/cjs/ion-col_3.cjs.entry.js +56 -57
  253. package/dist/cjs/ion-datetime-button.cjs.entry.js +13 -9
  254. package/dist/cjs/ion-datetime_3.cjs.entry.js +116 -41
  255. package/dist/cjs/ion-divider.cjs.entry.js +51 -0
  256. package/dist/cjs/ion-fab_3.cjs.entry.js +44 -28
  257. package/dist/cjs/ion-gallery-item.cjs.entry.js +59 -0
  258. package/dist/cjs/ion-gallery.cjs.entry.js +607 -0
  259. package/dist/cjs/ion-img.cjs.entry.js +8 -4
  260. package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +93 -17
  261. package/dist/cjs/ion-input-otp.cjs.entry.js +74 -9
  262. package/dist/cjs/ion-input-password-toggle.cjs.entry.js +53 -15
  263. package/dist/cjs/ion-input.cjs.entry.js +124 -34
  264. package/dist/cjs/ion-item-option_3.cjs.entry.js +467 -52
  265. package/dist/cjs/ion-item_8.cjs.entry.js +121 -50
  266. package/dist/cjs/ion-loading.cjs.entry.js +22 -19
  267. package/dist/cjs/ion-menu_3.cjs.entry.js +47 -29
  268. package/dist/cjs/ion-modal.cjs.entry.js +262 -138
  269. package/dist/cjs/ion-nav_2.cjs.entry.js +14 -11
  270. package/dist/cjs/ion-picker-column-option.cjs.entry.js +12 -8
  271. package/dist/cjs/ion-picker-column.cjs.entry.js +14 -14
  272. package/dist/cjs/ion-picker.cjs.entry.js +10 -6
  273. package/dist/cjs/ion-popover.cjs.entry.js +21 -19
  274. package/dist/cjs/ion-progress-bar.cjs.entry.js +27 -9
  275. package/dist/cjs/ion-radio_2.cjs.entry.js +35 -17
  276. package/dist/cjs/ion-range.cjs.entry.js +20 -13
  277. package/dist/cjs/ion-refresher_2.cjs.entry.js +42 -23
  278. package/dist/cjs/ion-reorder_2.cjs.entry.js +38 -14
  279. package/dist/cjs/ion-ripple-effect.cjs.entry.js +15 -7
  280. package/dist/cjs/ion-route_4.cjs.entry.js +11 -10
  281. package/dist/cjs/ion-searchbar.cjs.entry.js +137 -24
  282. package/dist/cjs/ion-segment-content.cjs.entry.js +2 -2
  283. package/dist/cjs/ion-segment-view.cjs.entry.js +13 -3
  284. package/dist/cjs/ion-segment_2.cjs.entry.js +23 -16
  285. package/dist/cjs/ion-select-modal.cjs.entry.js +114 -38
  286. package/dist/cjs/ion-select_3.cjs.entry.js +556 -107
  287. package/dist/cjs/ion-spinner.cjs.entry.js +30 -8
  288. package/dist/cjs/ion-split-pane.cjs.entry.js +13 -9
  289. package/dist/cjs/ion-tab-bar_2.cjs.entry.js +147 -23
  290. package/dist/cjs/ion-tab_2.cjs.entry.js +8 -7
  291. package/dist/cjs/ion-text.cjs.entry.js +7 -7
  292. package/dist/cjs/ion-textarea.cjs.entry.js +137 -23
  293. package/dist/cjs/ion-toast.cjs.entry.js +70 -46
  294. package/dist/cjs/ion-toggle.cjs.entry.js +82 -25
  295. package/dist/cjs/ionic-global-QoUqobrQ.js +519 -0
  296. package/dist/cjs/ionic.cjs.js +4 -4
  297. package/dist/cjs/{ios.transition-BOSWOaiK.js → ios.transition-DpFQfFfT.js} +7 -5
  298. package/dist/cjs/{keyboard-UuAS4D_9.js → keyboard-Bn0Ppim6.js} +1 -1
  299. package/dist/cjs/{keyboard-controller-GXBiBRKS.js → keyboard-controller-CefyW9lm.js} +11 -9
  300. package/dist/cjs/{keyboard-hHzlEQpk.js → keyboard-faZBQysj.js} +4 -3
  301. package/dist/cjs/list-a-7GSA6K.js +8 -0
  302. package/dist/cjs/loader.cjs.js +4 -4
  303. package/dist/cjs/{md.transition-B8-wBZqt.js → md.transition-ChJcoZUH.js} +6 -5
  304. package/dist/cjs/{notch-controller-18PzRGXd.js → notch-controller-BO0UGB4F.js} +4 -4
  305. package/dist/cjs/overlay-control-label-DnRLQR1t.js +52 -0
  306. package/dist/cjs/{overlays-TbKsuC-K.js → overlays-xkzfBAc_.js} +309 -18
  307. package/dist/cjs/select-option-render-8XQ4CgCm.js +116 -0
  308. package/dist/cjs/{status-tap-BXX8H8_Y.js → status-tap-x2qDo5QR.js} +4 -3
  309. package/dist/cjs/{swipe-back-C0GCB18x.js → swipe-back-CvZt_4YX.js} +3 -2
  310. package/dist/cjs/{theme-CeDs6Hcv.js → theme-IlOsGAz7.js} +25 -1
  311. package/dist/cjs/validity-QmuwEptc.js +51 -0
  312. package/dist/cjs/x-BTF99yFH.js +8 -0
  313. package/dist/collection/collection-manifest.json +9 -1
  314. package/dist/collection/components/accordion/accordion.ionic.css +201 -0
  315. package/dist/collection/components/accordion/accordion.ios.css +73 -58
  316. package/dist/collection/components/accordion/accordion.js +41 -27
  317. package/dist/collection/components/accordion/accordion.md.css +67 -59
  318. package/dist/collection/components/accordion-group/accordion-group.ionic.css +93 -0
  319. package/dist/collection/components/accordion-group/accordion-group.ios.css +16 -4
  320. package/dist/collection/components/accordion-group/accordion-group.js +44 -8
  321. package/dist/collection/components/accordion-group/accordion-group.md.css +22 -4
  322. package/dist/collection/components/action-sheet/action-sheet.ionic.css +491 -0
  323. package/dist/collection/components/action-sheet/action-sheet.ios.css +368 -11
  324. package/dist/collection/components/action-sheet/action-sheet.js +32 -13
  325. package/dist/collection/components/action-sheet/action-sheet.md.css +307 -10
  326. package/dist/collection/components/alert/alert.ionic.css +784 -0
  327. package/dist/collection/components/alert/alert.ios.css +482 -19
  328. package/dist/collection/components/alert/alert.js +67 -30
  329. package/dist/collection/components/alert/alert.md.css +465 -29
  330. package/dist/collection/components/app/app.js +15 -83
  331. package/dist/collection/components/avatar/avatar.ionic.css +391 -0
  332. package/dist/collection/components/avatar/avatar.ios.css +7 -33
  333. package/dist/collection/components/avatar/avatar.js +120 -4
  334. package/dist/collection/components/avatar/avatar.md.css +51 -0
  335. package/dist/collection/components/back-button/back-button.ios.css +60 -48
  336. package/dist/collection/components/back-button/back-button.js +27 -19
  337. package/dist/collection/components/back-button/back-button.md.css +60 -48
  338. package/dist/collection/components/backdrop/backdrop.ionic.css +109 -0
  339. package/dist/collection/components/backdrop/backdrop.ios.css +56 -19
  340. package/dist/collection/components/backdrop/backdrop.js +12 -6
  341. package/dist/collection/components/backdrop/backdrop.md.css +56 -19
  342. package/dist/collection/components/badge/badge.ionic.css +275 -0
  343. package/dist/collection/components/badge/badge.ios.css +139 -12
  344. package/dist/collection/components/badge/badge.js +145 -9
  345. package/dist/collection/components/badge/badge.md.css +123 -12
  346. package/dist/collection/components/breadcrumb/breadcrumb.ios.css +20 -8
  347. package/dist/collection/components/breadcrumb/breadcrumb.js +43 -11
  348. package/dist/collection/components/breadcrumb/breadcrumb.md.css +20 -8
  349. package/dist/collection/components/breadcrumbs/breadcrumbs.ios.css +6 -0
  350. package/dist/collection/components/breadcrumbs/breadcrumbs.js +11 -9
  351. package/dist/collection/components/breadcrumbs/breadcrumbs.md.css +6 -0
  352. package/dist/collection/components/button/button.ionic.css +646 -0
  353. package/dist/collection/components/button/button.ios.css +154 -46
  354. package/dist/collection/components/button/button.js +63 -27
  355. package/dist/collection/components/button/button.md.css +150 -50
  356. package/dist/collection/components/buttons/buttons.ionic.css +97 -0
  357. package/dist/collection/components/buttons/buttons.ios.css +59 -7
  358. package/dist/collection/components/buttons/buttons.js +15 -9
  359. package/dist/collection/components/buttons/buttons.md.css +55 -3
  360. package/dist/collection/components/card/card.ionic.css +144 -0
  361. package/dist/collection/components/card/card.ios.css +65 -14
  362. package/dist/collection/components/card/card.js +41 -10
  363. package/dist/collection/components/card/card.md.css +65 -14
  364. package/dist/collection/components/card-content/card-content.ionic.css +89 -0
  365. package/dist/collection/components/card-content/card-content.ios.css +20 -35
  366. package/dist/collection/components/card-content/card-content.js +12 -10
  367. package/dist/collection/components/card-content/card-content.md.css +20 -35
  368. package/dist/collection/components/card-header/card-header.ionic.css +85 -0
  369. package/dist/collection/components/card-header/card-header.ios.css +27 -15
  370. package/dist/collection/components/card-header/card-header.js +13 -10
  371. package/dist/collection/components/card-header/card-header.md.css +27 -15
  372. package/dist/collection/components/card-subtitle/card-subtitle.ionic.css +144 -0
  373. package/dist/collection/components/card-subtitle/card-subtitle.ios.css +12 -0
  374. package/dist/collection/components/card-subtitle/card-subtitle.js +11 -8
  375. package/dist/collection/components/card-subtitle/card-subtitle.md.css +12 -0
  376. package/dist/collection/components/card-title/card-title.ios.css +73 -0
  377. package/dist/collection/components/card-title/card-title.js +11 -8
  378. package/dist/collection/components/card-title/card-title.md.css +73 -0
  379. package/dist/collection/components/checkbox/checkbox.ionic.css +543 -0
  380. package/dist/collection/components/checkbox/checkbox.ios.css +163 -99
  381. package/dist/collection/components/checkbox/checkbox.js +73 -15
  382. package/dist/collection/components/checkbox/checkbox.md.css +164 -100
  383. package/dist/collection/components/chip/chip.ionic.css +217 -0
  384. package/dist/collection/components/chip/chip.ios.css +67 -14
  385. package/dist/collection/components/chip/chip.js +108 -8
  386. package/dist/collection/components/chip/chip.md.css +67 -14
  387. package/dist/collection/components/col/col.css +192 -4
  388. package/dist/collection/components/col/col.js +211 -61
  389. package/dist/collection/components/content/content.css +8 -2
  390. package/dist/collection/components/content/content.js +16 -11
  391. package/dist/collection/components/datetime/datetime.ionic.css +703 -0
  392. package/dist/collection/components/datetime/datetime.ios.css +302 -106
  393. package/dist/collection/components/datetime/datetime.js +98 -20
  394. package/dist/collection/components/datetime/datetime.md.css +293 -96
  395. package/dist/collection/components/datetime/utils/data.js +5 -5
  396. package/dist/collection/components/datetime-button/datetime-button.ios.css +6 -0
  397. package/dist/collection/components/datetime-button/datetime-button.js +11 -8
  398. package/dist/collection/components/datetime-button/datetime-button.md.css +6 -0
  399. package/dist/collection/components/divider/divider.ionic.css +148 -0
  400. package/dist/collection/components/divider/divider.ios.css +87 -0
  401. package/dist/collection/components/divider/divider.js +94 -0
  402. package/dist/collection/components/divider/divider.md.css +87 -0
  403. package/dist/collection/components/fab/fab.css +25 -1
  404. package/dist/collection/components/fab/fab.js +9 -5
  405. package/dist/collection/components/fab-button/fab-button.ios.css +18 -6
  406. package/dist/collection/components/fab-button/fab-button.js +36 -21
  407. package/dist/collection/components/fab-button/fab-button.md.css +20 -8
  408. package/dist/collection/components/fab-list/fab-list.css +12 -0
  409. package/dist/collection/components/fab-list/fab-list.js +9 -5
  410. package/dist/collection/components/footer/footer.ios.css +14 -2
  411. package/dist/collection/components/footer/footer.js +21 -16
  412. package/dist/collection/components/footer/footer.md.css +12 -0
  413. package/dist/collection/components/gallery/gallery-constants.js +12 -0
  414. package/dist/collection/components/gallery/gallery-interface.js +1 -0
  415. package/dist/collection/components/gallery/gallery.css +15 -0
  416. package/dist/collection/components/gallery/gallery.js +679 -0
  417. package/dist/collection/components/gallery/test/utils.js +100 -0
  418. package/dist/collection/components/gallery-item/gallery-item.css +49 -0
  419. package/dist/collection/components/gallery-item/gallery-item.js +99 -0
  420. package/dist/collection/components/grid/grid.css +12 -0
  421. package/dist/collection/components/grid/grid.js +9 -5
  422. package/dist/collection/components/header/header.ionic.css +97 -0
  423. package/dist/collection/components/header/header.ios.css +25 -10
  424. package/dist/collection/components/header/header.js +50 -19
  425. package/dist/collection/components/header/header.md.css +23 -8
  426. package/dist/collection/components/header/header.utils.js +5 -5
  427. package/dist/collection/components/img/img.js +8 -2
  428. package/dist/collection/components/infinite-scroll/infinite-scroll.js +100 -5
  429. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.ios.css +12 -0
  430. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +16 -10
  431. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.md.css +12 -0
  432. package/dist/collection/components/input/input.ionic.css +889 -0
  433. package/dist/collection/components/input/input.ios.css +223 -135
  434. package/dist/collection/components/input/input.js +148 -37
  435. package/dist/collection/components/input/input.md.css +193 -207
  436. package/dist/collection/components/input-otp/input-otp.ionic.css +371 -0
  437. package/dist/collection/components/input-otp/input-otp.ios.css +105 -60
  438. package/dist/collection/components/input-otp/input-otp.js +74 -7
  439. package/dist/collection/components/input-otp/input-otp.md.css +105 -60
  440. package/dist/collection/components/input-password-toggle/input-password-toggle.ionic.css +78 -0
  441. package/dist/collection/components/input-password-toggle/input-password-toggle.js +48 -12
  442. package/dist/collection/components/input-password-toggle/input-password-toggle.native.css +61 -0
  443. package/dist/collection/components/item/item.ionic.css +496 -0
  444. package/dist/collection/components/item/item.ios.css +109 -69
  445. package/dist/collection/components/item/item.js +56 -21
  446. package/dist/collection/components/item/item.md.css +120 -68
  447. package/dist/collection/components/item-divider/item-divider.ios.css +18 -0
  448. package/dist/collection/components/item-divider/item-divider.js +11 -8
  449. package/dist/collection/components/item-divider/item-divider.md.css +18 -0
  450. package/dist/collection/components/item-group/item-group.ios.css +12 -0
  451. package/dist/collection/components/item-group/item-group.js +13 -7
  452. package/dist/collection/components/item-group/item-group.md.css +12 -0
  453. package/dist/collection/components/item-option/item-option.ionic.css +278 -0
  454. package/dist/collection/components/item-option/item-option.ios.css +136 -29
  455. package/dist/collection/components/item-option/item-option.js +73 -9
  456. package/dist/collection/components/item-option/item-option.md.css +136 -29
  457. package/dist/collection/components/item-options/item-options.ionic.css +221 -0
  458. package/dist/collection/components/item-options/item-options.ios.css +77 -34
  459. package/dist/collection/components/item-options/item-options.js +13 -7
  460. package/dist/collection/components/item-options/item-options.md.css +77 -34
  461. package/dist/collection/components/item-sliding/item-sliding.ionic.css +211 -0
  462. package/dist/collection/components/item-sliding/item-sliding.js +421 -35
  463. package/dist/collection/components/item-sliding/{item-sliding.css → item-sliding.native.css} +84 -9
  464. package/dist/collection/components/item-sliding/test/test.utils.js +13 -0
  465. package/dist/collection/components/label/label.ios.css +18 -0
  466. package/dist/collection/components/label/label.js +11 -8
  467. package/dist/collection/components/label/label.md.css +18 -0
  468. package/dist/collection/components/list/list.ionic.css +212 -0
  469. package/dist/collection/components/list/list.ios.css +54 -14
  470. package/dist/collection/components/list/list.js +48 -9
  471. package/dist/collection/components/list/list.md.css +56 -16
  472. package/dist/collection/components/list-header/list-header.ionic.css +190 -0
  473. package/dist/collection/components/list-header/list-header.ios.css +82 -38
  474. package/dist/collection/components/list-header/list-header.js +11 -8
  475. package/dist/collection/components/list-header/list-header.md.css +82 -38
  476. package/dist/collection/components/loading/loading.ios.css +13 -1
  477. package/dist/collection/components/loading/loading.js +14 -11
  478. package/dist/collection/components/loading/loading.md.css +13 -1
  479. package/dist/collection/components/menu/menu.ios.css +15 -3
  480. package/dist/collection/components/menu/menu.js +12 -7
  481. package/dist/collection/components/menu/menu.md.css +15 -3
  482. package/dist/collection/components/menu-button/menu-button.ionic.css +236 -0
  483. package/dist/collection/components/menu-button/menu-button.ios.css +48 -14
  484. package/dist/collection/components/menu-button/menu-button.js +26 -10
  485. package/dist/collection/components/menu-button/menu-button.md.css +49 -15
  486. package/dist/collection/components/menu-toggle/menu-toggle.js +8 -5
  487. package/dist/collection/components/modal/animations/ionic.enter.js +40 -0
  488. package/dist/collection/components/modal/animations/ionic.leave.js +28 -0
  489. package/dist/collection/components/modal/animations/sheet.js +8 -2
  490. package/dist/collection/components/modal/gestures/sheet.js +76 -10
  491. package/dist/collection/components/modal/modal.ionic.css +247 -0
  492. package/dist/collection/components/modal/modal.ios.css +178 -70
  493. package/dist/collection/components/modal/modal.js +50 -12
  494. package/dist/collection/components/modal/modal.md.css +178 -70
  495. package/dist/collection/components/nav/nav.css +7 -1
  496. package/dist/collection/components/nav/nav.js +11 -5
  497. package/dist/collection/components/nav-link/nav-link.js +5 -1
  498. package/dist/collection/components/note/note.ios.css +12 -0
  499. package/dist/collection/components/note/note.js +11 -8
  500. package/dist/collection/components/note/note.md.css +12 -0
  501. package/dist/collection/components/picker/picker.ios.css +15 -3
  502. package/dist/collection/components/picker/picker.js +8 -5
  503. package/dist/collection/components/picker/picker.md.css +15 -3
  504. package/dist/collection/components/picker-column/picker-column.css +9 -2
  505. package/dist/collection/components/picker-column/picker-column.js +8 -7
  506. package/dist/collection/components/picker-column-option/picker-column-option.ios.css +6 -0
  507. package/dist/collection/components/picker-column-option/picker-column-option.js +13 -7
  508. package/dist/collection/components/picker-column-option/picker-column-option.md.css +6 -0
  509. package/dist/collection/components/picker-legacy/picker.ios.css +13 -1
  510. package/dist/collection/components/picker-legacy/picker.js +7 -6
  511. package/dist/collection/components/picker-legacy/picker.md.css +13 -1
  512. package/dist/collection/components/picker-legacy-column/picker-column.ios.css +12 -0
  513. package/dist/collection/components/picker-legacy-column/picker-column.js +4 -4
  514. package/dist/collection/components/picker-legacy-column/picker-column.md.css +12 -0
  515. package/dist/collection/components/popover/popover.ionic.css +290 -0
  516. package/dist/collection/components/popover/popover.ios.css +29 -1
  517. package/dist/collection/components/popover/popover.js +18 -15
  518. package/dist/collection/components/popover/popover.md.css +29 -1
  519. package/dist/collection/components/progress-bar/progress-bar.ionic.css +287 -0
  520. package/dist/collection/components/progress-bar/progress-bar.ios.css +48 -17
  521. package/dist/collection/components/progress-bar/progress-bar.js +43 -7
  522. package/dist/collection/components/progress-bar/progress-bar.md.css +48 -17
  523. package/dist/collection/components/radio/radio.ionic.css +422 -0
  524. package/dist/collection/components/radio/radio.ios.css +134 -91
  525. package/dist/collection/components/radio/radio.js +14 -9
  526. package/dist/collection/components/radio/radio.md.css +134 -91
  527. package/dist/collection/components/radio-group/radio-group.ionic.css +119 -0
  528. package/dist/collection/components/radio-group/radio-group.ios.css +43 -19
  529. package/dist/collection/components/radio-group/radio-group.js +48 -7
  530. package/dist/collection/components/radio-group/radio-group.md.css +43 -19
  531. package/dist/collection/components/range/range.ionic.css +567 -0
  532. package/dist/collection/components/range/range.ios.css +128 -85
  533. package/dist/collection/components/range/range.js +16 -10
  534. package/dist/collection/components/range/range.md.css +128 -85
  535. package/dist/collection/components/refresher/refresher.ios.css +14 -1
  536. package/dist/collection/components/refresher/refresher.js +11 -8
  537. package/dist/collection/components/refresher/refresher.md.css +15 -2
  538. package/dist/collection/components/refresher-content/refresher-content.js +28 -7
  539. package/dist/collection/components/reorder/reorder.ios.css +6 -0
  540. package/dist/collection/components/reorder/reorder.js +33 -6
  541. package/dist/collection/components/reorder/reorder.md.css +6 -0
  542. package/dist/collection/components/reorder-group/reorder-group.css +6 -0
  543. package/dist/collection/components/reorder-group/reorder-group.js +8 -4
  544. package/dist/collection/components/ripple-effect/{ripple-effect.css → ripple-effect.common.css} +7 -1
  545. package/dist/collection/components/ripple-effect/ripple-effect.ionic.css +215 -0
  546. package/dist/collection/components/ripple-effect/ripple-effect.js +14 -6
  547. package/dist/collection/components/route/route.js +4 -0
  548. package/dist/collection/components/router/router.js +4 -0
  549. package/dist/collection/components/router-link/router-link.css +8 -2
  550. package/dist/collection/components/router-link/router-link.js +9 -5
  551. package/dist/collection/components/router-outlet/router-outlet.css +7 -1
  552. package/dist/collection/components/router-outlet/router-outlet.js +6 -3
  553. package/dist/collection/components/row/row.css +16 -0
  554. package/dist/collection/components/row/row.js +9 -2
  555. package/dist/collection/components/searchbar/searchbar.ionic.css +626 -0
  556. package/dist/collection/components/searchbar/searchbar.ios.css +56 -18
  557. package/dist/collection/components/searchbar/searchbar.js +180 -33
  558. package/dist/collection/components/searchbar/searchbar.md.css +56 -18
  559. package/dist/collection/components/segment/segment.ionic.css +115 -0
  560. package/dist/collection/components/segment/segment.ios.css +45 -2
  561. package/dist/collection/components/segment/segment.js +11 -8
  562. package/dist/collection/components/segment/segment.md.css +45 -2
  563. package/dist/collection/components/segment-button/segment-button.ionic.css +353 -0
  564. package/dist/collection/components/segment-button/segment-button.ios.css +146 -105
  565. package/dist/collection/components/segment-button/segment-button.js +11 -8
  566. package/dist/collection/components/segment-button/segment-button.md.css +148 -107
  567. package/dist/collection/components/segment-content/segment-content.js +1 -1
  568. package/dist/collection/components/segment-view/segment-view.ios.css +6 -0
  569. package/dist/collection/components/segment-view/segment-view.js +13 -4
  570. package/dist/collection/components/segment-view/segment-view.md.css +6 -0
  571. package/dist/collection/components/select/select.ionic.css +810 -0
  572. package/dist/collection/components/select/select.ios.css +348 -176
  573. package/dist/collection/components/select/select.js +521 -92
  574. package/dist/collection/components/select/select.md.css +364 -178
  575. package/dist/collection/components/select-modal/select-modal.ionic.css +254 -0
  576. package/dist/collection/components/select-modal/select-modal.ios.css +467 -0
  577. package/dist/collection/components/select-modal/select-modal.js +126 -30
  578. package/dist/collection/components/select-modal/select-modal.md.css +395 -0
  579. package/dist/collection/components/select-option/select-option.js +70 -2
  580. package/dist/collection/components/select-popover/select-popover.ionic.css +252 -0
  581. package/dist/collection/components/select-popover/select-popover.ios.css +303 -20
  582. package/dist/collection/components/select-popover/select-popover.js +89 -29
  583. package/dist/collection/components/select-popover/select-popover.md.css +346 -0
  584. package/dist/collection/components/skeleton-text/skeleton-text.css +6 -0
  585. package/dist/collection/components/skeleton-text/skeleton-text.js +9 -5
  586. package/dist/collection/components/spinner/{spinner.css → spinner.ionic.css} +78 -10
  587. package/dist/collection/components/spinner/spinner.js +47 -6
  588. package/dist/collection/components/spinner/spinner.native.css +199 -0
  589. package/dist/collection/components/split-pane/split-pane.ios.css +20 -2
  590. package/dist/collection/components/split-pane/split-pane.js +15 -8
  591. package/dist/collection/components/split-pane/split-pane.md.css +20 -2
  592. package/dist/collection/components/tab/tab.js +6 -2
  593. package/dist/collection/components/tab-bar/tab-bar.ionic.css +227 -0
  594. package/dist/collection/components/tab-bar/tab-bar.ios.css +71 -43
  595. package/dist/collection/components/tab-bar/tab-bar.js +171 -13
  596. package/dist/collection/components/tab-bar/tab-bar.md.css +71 -43
  597. package/dist/collection/components/tab-button/tab-button.ionic.css +348 -0
  598. package/dist/collection/components/tab-button/tab-button.ios.css +171 -95
  599. package/dist/collection/components/tab-button/tab-button.js +54 -9
  600. package/dist/collection/components/tab-button/tab-button.md.css +137 -93
  601. package/dist/collection/components/tabs/tabs.css +7 -1
  602. package/dist/collection/components/tabs/tabs.js +4 -1
  603. package/dist/collection/components/text/text.css +6 -0
  604. package/dist/collection/components/text/text.js +7 -6
  605. package/dist/collection/components/textarea/textarea.ionic.css +898 -0
  606. package/dist/collection/components/textarea/textarea.ios.css +298 -158
  607. package/dist/collection/components/textarea/textarea.js +162 -24
  608. package/dist/collection/components/textarea/textarea.md.css +312 -159
  609. package/dist/collection/components/thumbnail/thumbnail.css +6 -0
  610. package/dist/collection/components/thumbnail/thumbnail.js +9 -2
  611. package/dist/collection/components/title/title.ionic.css +127 -0
  612. package/dist/collection/components/title/title.ios.css +32 -4
  613. package/dist/collection/components/title/title.js +13 -7
  614. package/dist/collection/components/title/title.md.css +32 -4
  615. package/dist/collection/components/toast/animations/utils.js +1 -1
  616. package/dist/collection/components/toast/toast.ionic.css +394 -0
  617. package/dist/collection/components/toast/toast.ios.css +84 -45
  618. package/dist/collection/components/toast/toast.js +76 -13
  619. package/dist/collection/components/toast/toast.md.css +84 -45
  620. package/dist/collection/components/toggle/toggle.ionic.css +508 -0
  621. package/dist/collection/components/toggle/toggle.ios.css +247 -131
  622. package/dist/collection/components/toggle/toggle.js +73 -18
  623. package/dist/collection/components/toggle/toggle.md.css +244 -131
  624. package/dist/collection/components/toolbar/test/image.svg +1 -0
  625. package/dist/collection/components/toolbar/toolbar.ionic.css +249 -0
  626. package/dist/collection/components/toolbar/toolbar.ios.css +90 -47
  627. package/dist/collection/components/toolbar/toolbar.js +218 -13
  628. package/dist/collection/components/toolbar/toolbar.md.css +90 -47
  629. package/dist/collection/global/ionic-global.js +241 -13
  630. package/dist/collection/utils/css-value-validation.js +39 -0
  631. package/dist/collection/utils/focus-trap.js +13 -2
  632. package/dist/collection/utils/focus-visible.js +22 -0
  633. package/dist/collection/utils/forms/validity.js +31 -0
  634. package/dist/collection/utils/framework-delegate.js +3 -1
  635. package/dist/collection/utils/hardware-back-button.js +15 -0
  636. package/dist/collection/utils/helpers.js +70 -3
  637. package/dist/collection/utils/keyboard/keyboard-controller.js +3 -1
  638. package/dist/collection/utils/media.js +1 -0
  639. package/dist/collection/utils/menu-controller/animations/overlay.js +3 -3
  640. package/dist/collection/utils/menu-controller/animations/push.js +2 -1
  641. package/dist/collection/utils/menu-controller/animations/reveal.js +2 -1
  642. package/dist/collection/utils/overlay-control-label.js +47 -0
  643. package/dist/collection/utils/overlays.js +290 -8
  644. package/dist/collection/utils/sanitization/index.js +255 -14
  645. package/dist/collection/utils/select-option-render.js +111 -0
  646. package/dist/collection/utils/test/playwright/drag-element.js +32 -9
  647. package/dist/collection/utils/test/playwright/generator.js +48 -23
  648. package/dist/collection/utils/test/playwright/page/utils/goto.js +14 -5
  649. package/dist/collection/utils/test/playwright/page/utils/set-content.js +26 -3
  650. package/dist/collection/utils/theme.js +25 -1
  651. package/dist/collection/utils/transition/ios.transition.js +1 -0
  652. package/dist/docs.json +8975 -283
  653. package/dist/esm/{animation-DLJpuoEz.js → animation-B2qdQ_ou.js} +2 -2
  654. package/dist/esm/{app-globals-D0C5S4hU.js → app-globals-DZ-iIjxA.js} +1 -1
  655. package/dist/esm/{button-active-BSpTQmS9.js → button-active-BmajAby6.js} +2 -2
  656. package/dist/esm/{capacitor-CFERIeaU.js → capacitor-CtQSWUU0.js} +1 -1
  657. package/dist/esm/caret-down-D1t981Ih.js +6 -0
  658. package/dist/esm/caret-left-fIOYmaqA.js +6 -0
  659. package/dist/esm/caret-right-BYSs-jZz.js +6 -0
  660. package/dist/esm/config-BwKpO3Is.js +31 -0
  661. package/dist/esm/{data-DZI70dKr.js → data-CPP_AdEM.js} +6 -6
  662. package/dist/esm/{focus-visible-BmVRXR1y.js → focus-visible-vXpMhGrs.js} +23 -1
  663. package/dist/esm/{framework-delegate-FnPGymXL.js → framework-delegate-DO2QXccA.js} +4 -2
  664. package/dist/esm/{haptic-DzAMWJuk.js → haptic-DFgKNCce.js} +1 -1
  665. package/dist/esm/{helpers-HEqiOzXb.js → helpers-DfF5_wJc.js} +71 -5
  666. package/dist/esm/{index-B_dQk_WE.js → index-BIUWGRUl.js} +4 -4
  667. package/dist/esm/index-BUyahZJ4.js +409 -0
  668. package/dist/esm/{index-BRHzoo00.js → index-BjaaZqVY.js} +4 -3
  669. package/dist/esm/{index-tcQvqkiX.js → index-C0EQceqV.js} +41 -4
  670. package/dist/esm/{index-DV3sJJW8.js → index-D2tu5BUg.js} +2 -1
  671. package/dist/esm/{index-Q6UPU0Ay.js → index-Di034G4O.js} +11 -11
  672. package/dist/esm/{index-MEDq2S8l.js → index-KxK0gcRp.js} +2 -2
  673. package/dist/esm/index.js +14 -14
  674. package/dist/esm/{input-shims-D10mwcw1.js → input-shims-DvNNw70a.js} +7 -6
  675. package/dist/esm/{input.utils-Y6NgW8bw.js → input.utils-_LkBfBWt.js} +3 -3
  676. package/dist/esm/ion-accordion_2.entry.js +61 -29
  677. package/dist/esm/ion-action-sheet.entry.js +41 -22
  678. package/dist/esm/ion-alert.entry.js +77 -40
  679. package/dist/esm/ion-app_8.entry.js +292 -157
  680. package/dist/esm/ion-avatar_3.entry.js +125 -13
  681. package/dist/esm/ion-back-button.entry.js +31 -22
  682. package/dist/esm/ion-backdrop.entry.js +10 -7
  683. package/dist/esm/ion-breadcrumb_2.entry.js +54 -18
  684. package/dist/esm/ion-button_2.entry.js +59 -22
  685. package/dist/esm/ion-card_5.entry.js +55 -33
  686. package/dist/esm/ion-checkbox.entry.js +37 -17
  687. package/dist/esm/ion-chip.entry.js +50 -9
  688. package/dist/esm/ion-col_3.entry.js +56 -57
  689. package/dist/esm/ion-datetime-button.entry.js +13 -9
  690. package/dist/esm/ion-datetime_3.entry.js +116 -41
  691. package/dist/esm/ion-divider.entry.js +49 -0
  692. package/dist/esm/ion-fab_3.entry.js +44 -28
  693. package/dist/esm/ion-gallery-item.entry.js +57 -0
  694. package/dist/esm/ion-gallery.entry.js +605 -0
  695. package/dist/esm/ion-img.entry.js +8 -4
  696. package/dist/esm/ion-infinite-scroll_2.entry.js +92 -16
  697. package/dist/esm/ion-input-otp.entry.js +74 -9
  698. package/dist/esm/ion-input-password-toggle.entry.js +53 -15
  699. package/dist/esm/ion-input.entry.js +124 -34
  700. package/dist/esm/ion-item-option_3.entry.js +467 -52
  701. package/dist/esm/ion-item_8.entry.js +121 -50
  702. package/dist/esm/ion-loading.entry.js +21 -18
  703. package/dist/esm/ion-menu_3.entry.js +47 -29
  704. package/dist/esm/ion-modal.entry.js +215 -91
  705. package/dist/esm/ion-nav_2.entry.js +14 -11
  706. package/dist/esm/ion-picker-column-option.entry.js +12 -8
  707. package/dist/esm/ion-picker-column.entry.js +13 -13
  708. package/dist/esm/ion-picker.entry.js +10 -6
  709. package/dist/esm/ion-popover.entry.js +21 -19
  710. package/dist/esm/ion-progress-bar.entry.js +27 -9
  711. package/dist/esm/ion-radio_2.entry.js +35 -17
  712. package/dist/esm/ion-range.entry.js +20 -13
  713. package/dist/esm/ion-refresher_2.entry.js +40 -21
  714. package/dist/esm/ion-reorder_2.entry.js +38 -14
  715. package/dist/esm/ion-ripple-effect.entry.js +15 -7
  716. package/dist/esm/ion-route_4.entry.js +11 -10
  717. package/dist/esm/ion-searchbar.entry.js +137 -24
  718. package/dist/esm/ion-segment-content.entry.js +2 -2
  719. package/dist/esm/ion-segment-view.entry.js +13 -3
  720. package/dist/esm/ion-segment_2.entry.js +23 -16
  721. package/dist/esm/ion-select-modal.entry.js +114 -38
  722. package/dist/esm/ion-select_3.entry.js +556 -107
  723. package/dist/esm/ion-spinner.entry.js +30 -8
  724. package/dist/esm/ion-split-pane.entry.js +13 -9
  725. package/dist/esm/ion-tab-bar_2.entry.js +147 -23
  726. package/dist/esm/ion-tab_2.entry.js +8 -7
  727. package/dist/esm/ion-text.entry.js +7 -7
  728. package/dist/esm/ion-textarea.entry.js +137 -23
  729. package/dist/esm/ion-toast.entry.js +45 -21
  730. package/dist/esm/ion-toggle.entry.js +82 -25
  731. package/dist/esm/ionic-global-BpkTponr.js +508 -0
  732. package/dist/esm/ionic.js +5 -5
  733. package/dist/esm/{ios.transition-ClFrsIrS.js → ios.transition-CgScDbsb.js} +7 -5
  734. package/dist/esm/{keyboard-CUw4ekVy.js → keyboard-CyyguLDw.js} +1 -1
  735. package/dist/esm/{keyboard-ywgs5efA.js → keyboard-WJix-wcz.js} +4 -3
  736. package/dist/esm/{keyboard-controller-BaaVITYt.js → keyboard-controller-BFwRdk2T.js} +5 -3
  737. package/dist/esm/list-Dhi5xtNS.js +6 -0
  738. package/dist/esm/loader.js +5 -5
  739. package/dist/esm/{md.transition-D0msQmzI.js → md.transition-DThqYazt.js} +6 -5
  740. package/dist/esm/{notch-controller-DKDjU_O7.js → notch-controller-MTblRxjD.js} +2 -2
  741. package/dist/esm/overlay-control-label-CODBQrPj.js +49 -0
  742. package/dist/esm/{overlays-TbiM4mdr.js → overlays-Dnhc5m_r.js} +306 -15
  743. package/dist/esm/select-option-render-qQ99XSVh.js +114 -0
  744. package/dist/esm/{status-tap-Kan2W7sh.js → status-tap-CoPI1M2q.js} +4 -3
  745. package/dist/esm/{swipe-back-DQ1q5MgD.js → swipe-back-qmvTRnSq.js} +3 -2
  746. package/dist/esm/{theme-DiVJyqlX.js → theme-DaJxRxSQ.js} +25 -1
  747. package/dist/esm/validity-BjW8SOqw.js +48 -0
  748. package/dist/esm/x-BDqjX7Z_.js +6 -0
  749. package/dist/html.html-data.json +2653 -146
  750. package/dist/ionic/index.esm.js +1 -1
  751. package/dist/ionic/ionic.esm.js +1 -1
  752. package/dist/ionic/p-05ce9821.entry.js +4 -0
  753. package/dist/ionic/p-066c290a.entry.js +4 -0
  754. package/dist/ionic/p-085b8cdf.entry.js +4 -0
  755. package/dist/ionic/p-0ef6bfc4.entry.js +4 -0
  756. package/dist/ionic/p-18969b6d.entry.js +4 -0
  757. package/dist/ionic/p-18bc4f2d.entry.js +4 -0
  758. package/dist/ionic/p-1b6e3914.entry.js +4 -0
  759. package/dist/ionic/p-25b51635.entry.js +4 -0
  760. package/dist/ionic/p-2740db6e.entry.js +4 -0
  761. package/dist/ionic/p-274a829d.entry.js +4 -0
  762. package/dist/ionic/p-2a1abbb1.entry.js +4 -0
  763. package/dist/ionic/p-3b4c5cb5.entry.js +4 -0
  764. package/dist/ionic/p-3cfb4ff2.entry.js +4 -0
  765. package/dist/ionic/p-43b00c5b.entry.js +4 -0
  766. package/dist/ionic/p-4827557b.entry.js +4 -0
  767. package/dist/ionic/p-4a97918d.entry.js +4 -0
  768. package/dist/ionic/p-52b3aedb.entry.js +4 -0
  769. package/dist/ionic/p-53d4ce5e.entry.js +4 -0
  770. package/dist/ionic/p-56224b93.entry.js +4 -0
  771. package/dist/ionic/p-5732396e.entry.js +4 -0
  772. package/dist/ionic/p-58d8877d.entry.js +4 -0
  773. package/dist/ionic/p-5d079dc1.entry.js +4 -0
  774. package/dist/ionic/p-5e9665dd.entry.js +4 -0
  775. package/dist/ionic/p-5fee5cc1.entry.js +4 -0
  776. package/dist/ionic/p-602cf876.entry.js +4 -0
  777. package/dist/ionic/p-678ee14a.entry.js +4 -0
  778. package/dist/ionic/p-68ea8ed1.entry.js +4 -0
  779. package/dist/ionic/p-6916fea6.entry.js +4 -0
  780. package/dist/ionic/p-6e1ec775.entry.js +4 -0
  781. package/dist/ionic/p-745d6b2b.entry.js +4 -0
  782. package/dist/ionic/p-7ce56473.entry.js +4 -0
  783. package/dist/ionic/p-83acfa2d.entry.js +4 -0
  784. package/dist/ionic/p-849b1759.entry.js +4 -0
  785. package/dist/ionic/p-8cb23f27.entry.js +4 -0
  786. package/dist/ionic/p-8d5fd199.entry.js +4 -0
  787. package/dist/ionic/p-8f2f8f6d.entry.js +4 -0
  788. package/dist/ionic/p-BDSH5ckF.js +4 -0
  789. package/dist/ionic/p-BDqjX7Z_.js +4 -0
  790. package/dist/ionic/p-BFe7BoXu.js +4 -0
  791. package/dist/ionic/p-BFy_BK46.js +4 -0
  792. package/dist/ionic/p-BYSs-jZz.js +4 -0
  793. package/dist/ionic/p-BjW8SOqw.js +4 -0
  794. package/{components/p-CtukzcyX.js → dist/ionic/p-BlZo7Gy-.js} +1 -1
  795. package/dist/ionic/p-Bq8S4vhI.js +4 -0
  796. package/dist/ionic/p-BwKpO3Is.js +4 -0
  797. package/dist/ionic/p-C0EQceqV.js +5 -0
  798. package/dist/ionic/p-C8i6xYLf.js +4 -0
  799. package/dist/ionic/p-CB91Gr9M.js +4 -0
  800. package/dist/ionic/p-CEkwLb3L.js +4 -0
  801. package/dist/ionic/p-CJsJQPQD.js +4 -0
  802. package/dist/ionic/p-CODBQrPj.js +4 -0
  803. package/dist/ionic/p-Ch7MBNn_.js +4 -0
  804. package/{components/p-BT_5jSqG.js → dist/ionic/p-Cm20lBQw.js} +1 -1
  805. package/dist/ionic/p-CnAWnbNK.js +4 -0
  806. package/dist/ionic/p-D1t981Ih.js +4 -0
  807. package/dist/ionic/p-D2tu5BUg.js +4 -0
  808. package/dist/ionic/p-D4MT1z4_.js +4 -0
  809. package/dist/ionic/p-D4veLKCq.js +4 -0
  810. package/dist/ionic/{p-DAAFkPFT.js → p-DDVaMUQI.js} +1 -1
  811. package/dist/ionic/p-DF7ubVci.js +4 -0
  812. package/dist/ionic/p-DMaSfupH.js +4 -0
  813. package/{components/p-D13Eaw-8.js → dist/ionic/p-DQDmksdT.js} +1 -1
  814. package/dist/ionic/p-DTsDGZPd.js +4 -0
  815. package/dist/ionic/p-DaJxRxSQ.js +4 -0
  816. package/dist/ionic/p-DdCaKRle.js +4 -0
  817. package/dist/ionic/p-Dhi5xtNS.js +4 -0
  818. package/dist/ionic/p-MqqcZQSB.js +4 -0
  819. package/dist/ionic/{p-CKvCXMs9.js → p-OkgYzj-7.js} +1 -1
  820. package/dist/ionic/p-WHzwm7OM.js +4 -0
  821. package/dist/ionic/p-a6a9a840.entry.js +4 -0
  822. package/dist/ionic/p-b7327160.entry.js +4 -0
  823. package/dist/ionic/p-ba447506.entry.js +4 -0
  824. package/dist/ionic/p-c04429f2.entry.js +4 -0
  825. package/dist/ionic/p-c25a2a9b.entry.js +4 -0
  826. package/dist/ionic/p-c414ac3a.entry.js +4 -0
  827. package/dist/ionic/p-ca3a07b5.entry.js +4 -0
  828. package/dist/ionic/p-ced3cda1.entry.js +4 -0
  829. package/dist/ionic/p-cf22e991.entry.js +4 -0
  830. package/dist/ionic/p-d0d42da6.entry.js +4 -0
  831. package/dist/ionic/p-d33dfc12.entry.js +4 -0
  832. package/dist/ionic/p-d34bfb61.entry.js +4 -0
  833. package/dist/ionic/p-ddde8df3.entry.js +4 -0
  834. package/dist/ionic/p-df642ef5.entry.js +4 -0
  835. package/dist/ionic/p-e04d63e1.entry.js +4 -0
  836. package/dist/ionic/p-e516b509.entry.js +4 -0
  837. package/dist/ionic/p-f18969f0.entry.js +4 -0
  838. package/dist/ionic/p-fIOYmaqA.js +4 -0
  839. package/dist/ionic/p-fc6d26ff.entry.js +4 -0
  840. package/dist/ionic/p-fce05eae.entry.js +4 -0
  841. package/dist/ionic/p-im8OkZlj.js +4 -0
  842. package/dist/ionic/p-lMb_45ax.js +4 -0
  843. package/dist/ionic/{p-Wk5HzclC.js → p-oUgyLDGL.js} +1 -1
  844. package/dist/ionic/p-vXpMhGrs.js +4 -0
  845. package/dist/types/components/accordion/accordion.d.ts +6 -3
  846. package/dist/types/components/accordion-group/accordion-group.d.ts +12 -1
  847. package/dist/types/components/action-sheet/action-sheet-interface.d.ts +3 -7
  848. package/dist/types/components/action-sheet/action-sheet.d.ts +3 -2
  849. package/dist/types/components/alert/alert-interface.d.ts +3 -7
  850. package/dist/types/components/alert/alert.d.ts +3 -2
  851. package/dist/types/components/app/app.d.ts +4 -5
  852. package/dist/types/components/avatar/avatar.d.ts +32 -0
  853. package/dist/types/components/back-button/back-button.d.ts +2 -1
  854. package/dist/types/components/backdrop/backdrop.d.ts +4 -0
  855. package/dist/types/components/badge/badge.d.ts +34 -1
  856. package/dist/types/components/breadcrumb/breadcrumb.d.ts +4 -1
  857. package/dist/types/components/breadcrumbs/breadcrumbs.d.ts +2 -2
  858. package/dist/types/components/button/button.d.ts +23 -8
  859. package/dist/types/components/buttons/buttons.d.ts +5 -1
  860. package/dist/types/components/card/card.d.ts +8 -1
  861. package/dist/types/components/card-content/card-content.d.ts +2 -1
  862. package/dist/types/components/card-header/card-header.d.ts +3 -2
  863. package/dist/types/components/card-subtitle/card-subtitle.d.ts +2 -1
  864. package/dist/types/components/card-title/card-title.d.ts +2 -1
  865. package/dist/types/components/checkbox/checkbox.d.ts +14 -4
  866. package/dist/types/components/chip/chip.d.ts +26 -1
  867. package/dist/types/components/col/col.d.ts +52 -5
  868. package/dist/types/components/content/content.d.ts +3 -0
  869. package/dist/types/components/datetime/datetime.d.ts +26 -1
  870. package/dist/types/components/datetime/utils/data.d.ts +5 -5
  871. package/dist/types/components/datetime-button/datetime-button.d.ts +2 -1
  872. package/dist/types/components/divider/divider.d.ts +20 -0
  873. package/dist/types/components/fab/fab.d.ts +4 -0
  874. package/dist/types/components/fab-button/fab-button.d.ts +5 -3
  875. package/dist/types/components/fab-list/fab-list.d.ts +4 -0
  876. package/dist/types/components/footer/footer.d.ts +4 -3
  877. package/dist/types/components/gallery/gallery-constants.d.ts +9 -0
  878. package/dist/types/components/gallery/gallery-interface.d.ts +10 -0
  879. package/dist/types/components/gallery/gallery.d.ts +218 -0
  880. package/dist/types/components/gallery/test/utils.d.ts +3 -0
  881. package/dist/types/components/gallery-item/gallery-item.d.ts +33 -0
  882. package/dist/types/components/grid/grid.d.ts +4 -0
  883. package/dist/types/components/header/header.d.ts +9 -3
  884. package/dist/types/components/header/header.utils.d.ts +3 -3
  885. package/dist/types/components/img/img.d.ts +3 -0
  886. package/dist/types/components/infinite-scroll/infinite-scroll.d.ts +21 -0
  887. package/dist/types/components/infinite-scroll-content/infinite-scroll-content.d.ts +4 -0
  888. package/dist/types/components/input/input.d.ts +31 -5
  889. package/dist/types/components/input-otp/input-otp.d.ts +37 -0
  890. package/dist/types/components/input-password-toggle/input-password-toggle.d.ts +2 -0
  891. package/dist/types/components/item/item.d.ts +11 -4
  892. package/dist/types/components/item-divider/item-divider.d.ts +2 -1
  893. package/dist/types/components/item-group/item-group.d.ts +4 -0
  894. package/dist/types/components/item-option/item-option.d.ts +18 -1
  895. package/dist/types/components/item-options/item-options.d.ts +4 -0
  896. package/dist/types/components/item-sliding/item-sliding.d.ts +47 -1
  897. package/dist/types/components/item-sliding/test/test.utils.d.ts +13 -0
  898. package/dist/types/components/label/label.d.ts +2 -1
  899. package/dist/types/components/list/list.d.ts +15 -1
  900. package/dist/types/components/list-header/list-header.d.ts +2 -1
  901. package/dist/types/components/loading/loading-interface.d.ts +2 -7
  902. package/dist/types/components/loading/loading.d.ts +3 -2
  903. package/dist/types/components/menu/menu.d.ts +3 -0
  904. package/dist/types/components/menu-button/menu-button.d.ts +3 -1
  905. package/dist/types/components/menu-toggle/menu-toggle.d.ts +3 -0
  906. package/dist/types/components/modal/animations/ionic.enter.d.ts +6 -0
  907. package/dist/types/components/modal/animations/ionic.leave.d.ts +6 -0
  908. package/dist/types/components/modal/gestures/sheet.d.ts +1 -1
  909. package/dist/types/components/modal/modal-interface.d.ts +4 -7
  910. package/dist/types/components/modal/modal.d.ts +11 -1
  911. package/dist/types/components/nav/nav-interface.d.ts +9 -1
  912. package/dist/types/components/nav/nav.d.ts +5 -1
  913. package/dist/types/components/nav-link/nav-link.d.ts +4 -0
  914. package/dist/types/components/note/note.d.ts +2 -1
  915. package/dist/types/components/picker/picker.d.ts +2 -1
  916. package/dist/types/components/picker-column/picker-column.d.ts +2 -1
  917. package/dist/types/components/picker-column-option/picker-column-option.d.ts +4 -0
  918. package/dist/types/components/picker-legacy/picker.d.ts +2 -1
  919. package/dist/types/components/popover/popover-interface.d.ts +3 -6
  920. package/dist/types/components/popover/popover.d.ts +6 -5
  921. package/dist/types/components/progress-bar/progress-bar.d.ts +10 -1
  922. package/dist/types/components/radio/radio.d.ts +2 -1
  923. package/dist/types/components/radio-group/radio-group.d.ts +12 -0
  924. package/dist/types/components/range/range.d.ts +2 -1
  925. package/dist/types/components/refresher/refresher.d.ts +2 -1
  926. package/dist/types/components/refresher-content/refresher-content.d.ts +4 -0
  927. package/dist/types/components/reorder/reorder.d.ts +9 -0
  928. package/dist/types/components/reorder-group/reorder-group.d.ts +4 -0
  929. package/dist/types/components/ripple-effect/ripple-effect.d.ts +4 -0
  930. package/dist/types/components/route/route.d.ts +4 -0
  931. package/dist/types/components/router/router.d.ts +4 -0
  932. package/dist/types/components/router-link/router-link.d.ts +4 -0
  933. package/dist/types/components/router-outlet/router-outlet.d.ts +4 -1
  934. package/dist/types/components/row/row.d.ts +4 -0
  935. package/dist/types/components/searchbar/searchbar.d.ts +51 -9
  936. package/dist/types/components/segment/segment.d.ts +2 -1
  937. package/dist/types/components/segment-button/segment-button.d.ts +2 -1
  938. package/dist/types/components/select/select-interface.d.ts +31 -0
  939. package/dist/types/components/select/select.d.ts +66 -13
  940. package/dist/types/components/select-modal/select-modal.d.ts +8 -0
  941. package/dist/types/components/select-option/select-option.d.ts +44 -0
  942. package/dist/types/components/select-popover/select-popover.d.ts +3 -0
  943. package/dist/types/components/skeleton-text/skeleton-text.d.ts +4 -0
  944. package/dist/types/components/spinner/spinner.d.ts +15 -0
  945. package/dist/types/components/split-pane/split-pane.d.ts +4 -0
  946. package/dist/types/components/tab/tab.d.ts +4 -0
  947. package/dist/types/components/tab-bar/tab-bar.d.ts +37 -2
  948. package/dist/types/components/tab-button/tab-button.d.ts +12 -1
  949. package/dist/types/components/tabs/tabs.d.ts +3 -0
  950. package/dist/types/components/text/text.d.ts +2 -1
  951. package/dist/types/components/textarea/textarea.d.ts +53 -4
  952. package/dist/types/components/thumbnail/thumbnail.d.ts +4 -0
  953. package/dist/types/components/title/title.d.ts +4 -0
  954. package/dist/types/components/toast/animations/utils.d.ts +2 -2
  955. package/dist/types/components/toast/toast-interface.d.ts +3 -7
  956. package/dist/types/components/toast/toast.d.ts +19 -2
  957. package/dist/types/components/toggle/toggle.d.ts +15 -1
  958. package/dist/types/components/toolbar/toolbar.d.ts +43 -3
  959. package/dist/types/components.d.ts +1852 -205
  960. package/dist/types/global/ionic-global.d.ts +28 -2
  961. package/dist/types/interface.d.ts +3 -0
  962. package/dist/types/utils/config.d.ts +106 -2
  963. package/dist/types/utils/css-value-validation.d.ts +21 -0
  964. package/dist/types/utils/focus-trap.d.ts +1 -1
  965. package/dist/types/utils/focus-visible.d.ts +13 -0
  966. package/dist/types/utils/forms/validity.d.ts +7 -0
  967. package/dist/types/utils/helpers.d.ts +22 -0
  968. package/dist/types/utils/overlay-control-label.d.ts +34 -0
  969. package/dist/types/utils/overlays-interface.d.ts +31 -1
  970. package/dist/types/utils/overlays.d.ts +1 -1
  971. package/dist/types/utils/sanitization/index.d.ts +54 -2
  972. package/dist/types/utils/select-option-render.d.ts +53 -0
  973. package/dist/types/utils/test/playwright/drag-element.d.ts +16 -3
  974. package/dist/types/utils/test/playwright/generator.d.ts +31 -2
  975. package/dist/types/utils/theme.d.ts +9 -0
  976. package/hydrate/index.js +5982 -1347
  977. package/hydrate/index.mjs +5982 -1347
  978. package/package.json +9 -5
  979. package/components/p--JUspHvy.js +0 -4
  980. package/components/p-0NRupjzW.js +0 -4
  981. package/components/p-5bE_Wz4Y.js +0 -4
  982. package/components/p-B60hm8Qv.js +0 -4
  983. package/components/p-B9jFTlwE.js +0 -4
  984. package/components/p-BLmJ0zRm.js +0 -4
  985. package/components/p-BSEgsdFI.js +0 -4
  986. package/components/p-BTPfOxsU.js +0 -4
  987. package/components/p-Baq1XyAy.js +0 -4
  988. package/components/p-BirPFsRD.js +0 -4
  989. package/components/p-BjfgFSSR.js +0 -4
  990. package/components/p-BmVRXR1y.js +0 -4
  991. package/components/p-BnqQlm7c.js +0 -4
  992. package/components/p-BsPelv04.js +0 -4
  993. package/components/p-Bth-EzJ0.js +0 -4
  994. package/components/p-Bz0dSlXZ.js +0 -4
  995. package/components/p-C1aScSTo.js +0 -4
  996. package/components/p-C2lKgrXx.js +0 -4
  997. package/components/p-CHqRYvYm.js +0 -4
  998. package/components/p-CI3ncNZm.js +0 -4
  999. package/components/p-CIGNaXM1.js +0 -4
  1000. package/components/p-CO7fmmxt.js +0 -4
  1001. package/components/p-CSZf8_j0.js +0 -4
  1002. package/components/p-CU5rbWAW.js +0 -4
  1003. package/components/p-C_xFdyXe.js +0 -4
  1004. package/components/p-Cfx4M1Bn.js +0 -4
  1005. package/components/p-Ciz1-FuE.js +0 -4
  1006. package/components/p-CmR5uXej.js +0 -4
  1007. package/components/p-CtWGkNnJ.js +0 -4
  1008. package/components/p-D6Ynv7Xh.js +0 -4
  1009. package/components/p-D7bSXQD3.js +0 -4
  1010. package/components/p-DDWp95gH.js +0 -4
  1011. package/components/p-DIE4pXMl.js +0 -4
  1012. package/components/p-DJztqcrH.js +0 -4
  1013. package/components/p-DNQI6d-L.js +0 -4
  1014. package/components/p-DOFCbuQR.js +0 -4
  1015. package/components/p-DiVJyqlX.js +0 -4
  1016. package/components/p-DnL1c9_X.js +0 -4
  1017. package/components/p-DqZAXv2t.js +0 -4
  1018. package/components/p-Sh0ICmPV.js +0 -4
  1019. package/components/p-W5nO8mX_.js +0 -4
  1020. package/components/p-W9CZ2mWX.js +0 -4
  1021. package/components/p-ZjP4CjeZ.js +0 -4
  1022. package/components/p-dhLYXa7A.js +0 -4
  1023. package/components/p-ijF0iCrA.js +0 -4
  1024. package/components/p-j5IxBIan.js +0 -4
  1025. package/components/p-k_E4tX5Z.js +0 -4
  1026. package/components/p-lE_JGpHD.js +0 -4
  1027. package/components/p-nQi4oKcG.js +0 -4
  1028. package/components/p-rCa2eL0j.js +0 -4
  1029. package/components/p-ryqmO0B-.js +0 -4
  1030. package/components/p-uVRyUM3z.js +0 -4
  1031. package/dist/cjs/config-xninhj0J.js +0 -201
  1032. package/dist/cjs/hardware-back-button-iUuF_76h.js +0 -121
  1033. package/dist/cjs/index-DkNv4J_i.js +0 -10
  1034. package/dist/cjs/ionic-global-B-cA6LkY.js +0 -151
  1035. package/dist/cjs/validity-BpS37YFM.js +0 -19
  1036. package/dist/esm/config-DQCONYYp.js +0 -195
  1037. package/dist/esm/hardware-back-button-B93Gru0Y.js +0 -115
  1038. package/dist/esm/index-ZjP4CjeZ.js +0 -7
  1039. package/dist/esm/ionic-global-Cp_eT4sZ.js +0 -146
  1040. package/dist/esm/validity-DJztqcrH.js +0 -17
  1041. package/dist/ionic/p-00dbb17e.entry.js +0 -4
  1042. package/dist/ionic/p-01f81ea5.entry.js +0 -4
  1043. package/dist/ionic/p-06c232a4.entry.js +0 -4
  1044. package/dist/ionic/p-0d005398.entry.js +0 -4
  1045. package/dist/ionic/p-0fa9c382.entry.js +0 -4
  1046. package/dist/ionic/p-1ae21e4c.entry.js +0 -4
  1047. package/dist/ionic/p-20b1a044.entry.js +0 -4
  1048. package/dist/ionic/p-21eb76d5.entry.js +0 -4
  1049. package/dist/ionic/p-27d30585.entry.js +0 -4
  1050. package/dist/ionic/p-2bb2cb18.entry.js +0 -4
  1051. package/dist/ionic/p-2f55dc1a.entry.js +0 -4
  1052. package/dist/ionic/p-30bf9737.entry.js +0 -4
  1053. package/dist/ionic/p-3353c229.entry.js +0 -4
  1054. package/dist/ionic/p-37e720da.entry.js +0 -4
  1055. package/dist/ionic/p-390ca786.entry.js +0 -4
  1056. package/dist/ionic/p-3a126bca.entry.js +0 -4
  1057. package/dist/ionic/p-3a541154.entry.js +0 -4
  1058. package/dist/ionic/p-3a7d1e91.entry.js +0 -4
  1059. package/dist/ionic/p-3ae5f277.entry.js +0 -4
  1060. package/dist/ionic/p-4745f534.entry.js +0 -4
  1061. package/dist/ionic/p-4858af1f.entry.js +0 -4
  1062. package/dist/ionic/p-485fda23.entry.js +0 -4
  1063. package/dist/ionic/p-4baa5b82.entry.js +0 -4
  1064. package/dist/ionic/p-4dc1c33c.entry.js +0 -4
  1065. package/dist/ionic/p-4e92a11f.entry.js +0 -4
  1066. package/dist/ionic/p-50e1194a.entry.js +0 -4
  1067. package/dist/ionic/p-5d1da0a2.entry.js +0 -4
  1068. package/dist/ionic/p-5fc7e542.entry.js +0 -4
  1069. package/dist/ionic/p-75dc25ba.entry.js +0 -4
  1070. package/dist/ionic/p-81ea5652.entry.js +0 -4
  1071. package/dist/ionic/p-84d5ce05.entry.js +0 -4
  1072. package/dist/ionic/p-874b4bd8.entry.js +0 -4
  1073. package/dist/ionic/p-8c8eee7d.entry.js +0 -4
  1074. package/dist/ionic/p-8eb8ee76.entry.js +0 -4
  1075. package/dist/ionic/p-8fce95d5.entry.js +0 -4
  1076. package/dist/ionic/p-94f2a736.entry.js +0 -4
  1077. package/dist/ionic/p-9a65ac7f.entry.js +0 -4
  1078. package/dist/ionic/p-9eeaBrnk.js +0 -4
  1079. package/dist/ionic/p-9f1103ce.entry.js +0 -4
  1080. package/dist/ionic/p-BGqMS-oh.js +0 -4
  1081. package/dist/ionic/p-BUFIpxKM.js +0 -4
  1082. package/dist/ionic/p-BmVRXR1y.js +0 -4
  1083. package/dist/ionic/p-CFlfIb2g.js +0 -4
  1084. package/dist/ionic/p-CIGNaXM1.js +0 -4
  1085. package/dist/ionic/p-CtWGkNnJ.js +0 -4
  1086. package/dist/ionic/p-Cx3IXROA.js +0 -4
  1087. package/dist/ionic/p-D4uTWt4-.js +0 -4
  1088. package/dist/ionic/p-DC3RagnA.js +0 -4
  1089. package/dist/ionic/p-DIuEbVLu.js +0 -4
  1090. package/dist/ionic/p-DJztqcrH.js +0 -4
  1091. package/dist/ionic/p-DSG2s2Eb.js +0 -4
  1092. package/dist/ionic/p-DV3sJJW8.js +0 -4
  1093. package/dist/ionic/p-Dfbt-q2k.js +0 -4
  1094. package/dist/ionic/p-DiVJyqlX.js +0 -4
  1095. package/dist/ionic/p-DoJvtrbw.js +0 -4
  1096. package/dist/ionic/p-DzWaWHGc.js +0 -4
  1097. package/dist/ionic/p-KjNvRoEp.js +0 -4
  1098. package/dist/ionic/p-Nqf6uvGh.js +0 -4
  1099. package/dist/ionic/p-SNAkTDfm.js +0 -4
  1100. package/dist/ionic/p-ZjP4CjeZ.js +0 -4
  1101. package/dist/ionic/p-a21add2f.entry.js +0 -4
  1102. package/dist/ionic/p-a3bdcae6.entry.js +0 -4
  1103. package/dist/ionic/p-aa5d6b8f.entry.js +0 -4
  1104. package/dist/ionic/p-b6a7397c.entry.js +0 -4
  1105. package/dist/ionic/p-c0fb8edd.entry.js +0 -4
  1106. package/dist/ionic/p-c4d8641b.entry.js +0 -4
  1107. package/dist/ionic/p-c6e49f3f.entry.js +0 -4
  1108. package/dist/ionic/p-dfa8d673.entry.js +0 -4
  1109. package/dist/ionic/p-e0be05c5.entry.js +0 -4
  1110. package/dist/ionic/p-e847a888.entry.js +0 -4
  1111. package/dist/ionic/p-ec090e0a.entry.js +0 -4
  1112. package/dist/ionic/p-ef4c3bee.entry.js +0 -4
  1113. package/dist/ionic/p-f386f6ae.entry.js +0 -4
  1114. package/dist/ionic/p-fabcce6c.entry.js +0 -4
  1115. package/dist/ionic/p-mjKAFv89.js +0 -4
  1116. package/dist/ionic/p-tcQvqkiX.js +0 -5
  1117. package/dist/ionic/p-viFHDgRs.js +0 -4
  1118. package/dist/ionic/p-xOfi7-Zn.js +0 -4
  1119. package/dist/ionic/p-xWb6fgfq.js +0 -4
  1120. /package/dist/collection/components/{input-password-toggle/input-password-toggle.css → refresher-content/refresher-content.css} +0 -0
@@ -3,11 +3,13 @@
3
3
  */
4
4
  'use strict';
5
5
 
6
- var index = require('./index-Ct7gcRif.js');
7
- var index$1 = require('./index-CIrkNXqJ.js');
8
- var ionicGlobal = require('./ionic-global-B-cA6LkY.js');
9
- var config = require('./config-xninhj0J.js');
10
- require('./helpers-Cv23MFHM.js');
6
+ var index = require('./index-GZU9YrFc.js');
7
+ var index$1 = require('./index-BxEZd5IE.js');
8
+ var ionicGlobal = require('./ionic-global-QoUqobrQ.js');
9
+ var config = require('./config-DWdFbSNK.js');
10
+ var index$2 = require('./index-CzFol6Yk.js');
11
+ require('./helpers-DiOgV5hw.js');
12
+ require('./focus-visible-BIj-I3-C.js');
11
13
 
12
14
  const infiniteScrollCss = () => `ion-infinite-scroll{display:none;width:100%}.infinite-scroll-enabled{display:block}`;
13
15
 
@@ -17,6 +19,7 @@ const InfiniteScroll = class {
17
19
  this.ionInfinite = index.createEvent(this, "ionInfinite", 7);
18
20
  this.thrPx = 0;
19
21
  this.thrPc = 0;
22
+ this.minHeightLocked = false;
20
23
  /**
21
24
  * didFire exists so that ionInfinite
22
25
  * does not fire multiple times if
@@ -52,6 +55,12 @@ const InfiniteScroll = class {
52
55
  * The value can be either `top` or `bottom`.
53
56
  */
54
57
  this.position = 'bottom';
58
+ /**
59
+ * If `true`, the infinite scroll will preserve the scroll position
60
+ * when the content is re-rendered. This is useful when the content is
61
+ * re-rendered with new keys, and the scroll position should be preserved.
62
+ */
63
+ this.preserveRerenderScrollPosition = false;
55
64
  this.onScroll = () => {
56
65
  const scrollEl = this.scrollEl;
57
66
  if (!scrollEl || !this.canStart()) {
@@ -73,7 +82,16 @@ const InfiniteScroll = class {
73
82
  if (!this.didFire) {
74
83
  this.isLoading = true;
75
84
  this.didFire = true;
76
- this.ionInfinite.emit();
85
+ if (this.preserveRerenderScrollPosition) {
86
+ // Lock the min height of the siblings of the infinite scroll
87
+ // if we are preserving the rerender scroll position
88
+ this.lockSiblingMinHeight(true).then(() => {
89
+ this.ionInfinite.emit();
90
+ });
91
+ }
92
+ else {
93
+ this.ionInfinite.emit();
94
+ }
77
95
  return 3;
78
96
  }
79
97
  }
@@ -120,6 +138,54 @@ const InfiniteScroll = class {
120
138
  this.enableScrollEvents(false);
121
139
  this.scrollEl = undefined;
122
140
  }
141
+ /**
142
+ * Loop through our sibling elements and lock or unlock their min height.
143
+ * This keeps our siblings, for example `ion-list`, the same height as their
144
+ * content currently is, so when it loads new data and the DOM removes the old
145
+ * data, the height of the container doesn't change and we don't lose our scroll position.
146
+ *
147
+ * We preserve existing min-height values, if they're set, so we don't erase what
148
+ * has been previously set by the user when we restore after complete is called.
149
+ */
150
+ lockSiblingMinHeight(lock) {
151
+ return new Promise((resolve) => {
152
+ var _a;
153
+ const siblings = ((_a = this.el.parentElement) === null || _a === void 0 ? void 0 : _a.children) || [];
154
+ const writes = [];
155
+ for (const sibling of siblings) {
156
+ // Loop through all the siblings of the infinite scroll, but ignore ourself
157
+ if (sibling !== this.el && sibling instanceof HTMLElement) {
158
+ if (lock) {
159
+ const elementHeight = sibling.getBoundingClientRect().height;
160
+ writes.push(() => {
161
+ if (this.minHeightLocked) {
162
+ // The previous min height is from us locking it before, so we can disregard it
163
+ // We still need to lock the min height if we're already locked, though, because
164
+ // the user could have triggered a new load before we've finished the previous one.
165
+ const previousMinHeight = sibling.style.minHeight;
166
+ if (previousMinHeight) {
167
+ sibling.style.setProperty('--ion-previous-min-height', previousMinHeight);
168
+ }
169
+ }
170
+ sibling.style.minHeight = `${elementHeight}px`;
171
+ });
172
+ }
173
+ else {
174
+ writes.push(() => {
175
+ const previousMinHeight = sibling.style.getPropertyValue('--ion-previous-min-height');
176
+ sibling.style.minHeight = previousMinHeight || 'auto';
177
+ sibling.style.removeProperty('--ion-previous-min-height');
178
+ });
179
+ }
180
+ }
181
+ }
182
+ index.writeTask(() => {
183
+ writes.forEach((w) => w());
184
+ this.minHeightLocked = lock;
185
+ resolve();
186
+ });
187
+ });
188
+ }
123
189
  /**
124
190
  * Call `complete()` within the `ionInfinite` output event handler when
125
191
  * your async operation has completed. For example, the `loading`
@@ -181,6 +247,13 @@ const InfiniteScroll = class {
181
247
  else {
182
248
  this.didFire = false;
183
249
  }
250
+ // Unlock the min height of the siblings of the infinite scroll
251
+ // if we are preserving the rerender scroll position
252
+ if (this.preserveRerenderScrollPosition) {
253
+ setTimeout(async () => {
254
+ await this.lockSiblingMinHeight(false);
255
+ }, 100);
256
+ }
184
257
  }
185
258
  canStart() {
186
259
  return !this.disabled && !this.isBusy && !!this.scrollEl && !this.isLoading;
@@ -196,10 +269,10 @@ const InfiniteScroll = class {
196
269
  }
197
270
  }
198
271
  render() {
199
- const mode = ionicGlobal.getIonMode(this);
272
+ const theme = ionicGlobal.getIonTheme(this);
200
273
  const disabled = this.disabled;
201
- return (index.h(index.Host, { key: 'e844956795f69be33396ce4480aa7a54ad01b28c', class: {
202
- [mode]: true,
274
+ return (index.h(index.Host, { key: 'e3a3cde079dfd6f07e565eb462765df757cbb128', class: {
275
+ [theme]: true,
203
276
  'infinite-scroll-loading': this.isLoading,
204
277
  'infinite-scroll-enabled': !disabled,
205
278
  } }));
@@ -216,6 +289,8 @@ const InfiniteScroll = class {
216
289
  };
217
290
  InfiniteScroll.style = infiniteScrollCss();
218
291
 
292
+ const ionicInfiniteScrollContentMdCss = () => `ion-infinite-scroll-content{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;-ms-flex-pack:center;justify-content:center;min-height:84px;text-align:center;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.infinite-loading{margin-left:0;margin-right:0;margin-top:0;margin-bottom:32px;display:none;width:100%}.infinite-loading-text{-webkit-margin-start:32px;margin-inline-start:32px;-webkit-margin-end:32px;margin-inline-end:32px;margin-top:4px;margin-bottom:0}.infinite-scroll-loading ion-infinite-scroll-content>.infinite-loading{display:block}.infinite-scroll-content-md .infinite-loading-text{color:var(--ion-color-step-600, var(--ion-text-color-step-400, #666666))}.infinite-scroll-content-md .infinite-loading-spinner .spinner-lines-md line,.infinite-scroll-content-md .infinite-loading-spinner .spinner-lines-small-md line,.infinite-scroll-content-md .infinite-loading-spinner .spinner-crescent circle{stroke:var(--ion-color-step-600, var(--ion-text-color-step-400, #666666))}.infinite-scroll-content-md .infinite-loading-spinner .spinner-bubbles circle,.infinite-scroll-content-md .infinite-loading-spinner .spinner-circles circle,.infinite-scroll-content-md .infinite-loading-spinner .spinner-dots circle{fill:var(--ion-color-step-600, var(--ion-text-color-step-400, #666666))}`;
293
+
219
294
  const infiniteScrollContentIosCss = () => `ion-infinite-scroll-content{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;-ms-flex-pack:center;justify-content:center;min-height:84px;text-align:center;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.infinite-loading{margin-left:0;margin-right:0;margin-top:0;margin-bottom:32px;display:none;width:100%}.infinite-loading-text{-webkit-margin-start:32px;margin-inline-start:32px;-webkit-margin-end:32px;margin-inline-end:32px;margin-top:4px;margin-bottom:0}.infinite-scroll-loading ion-infinite-scroll-content>.infinite-loading{display:block}.infinite-scroll-content-ios .infinite-loading-text{color:var(--ion-color-step-600, var(--ion-text-color-step-400, #666666))}.infinite-scroll-content-ios .infinite-loading-spinner .spinner-lines-ios line,.infinite-scroll-content-ios .infinite-loading-spinner .spinner-lines-small-ios line,.infinite-scroll-content-ios .infinite-loading-spinner .spinner-crescent circle{stroke:var(--ion-color-step-600, var(--ion-text-color-step-400, #666666))}.infinite-scroll-content-ios .infinite-loading-spinner .spinner-bubbles circle,.infinite-scroll-content-ios .infinite-loading-spinner .spinner-circles circle,.infinite-scroll-content-ios .infinite-loading-spinner .spinner-dots circle{fill:var(--ion-color-step-600, var(--ion-text-color-step-400, #666666))}`;
220
295
 
221
296
  const infiniteScrollContentMdCss = () => `ion-infinite-scroll-content{display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;-ms-flex-pack:center;justify-content:center;min-height:84px;text-align:center;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.infinite-loading{margin-left:0;margin-right:0;margin-top:0;margin-bottom:32px;display:none;width:100%}.infinite-loading-text{-webkit-margin-start:32px;margin-inline-start:32px;-webkit-margin-end:32px;margin-inline-end:32px;margin-top:4px;margin-bottom:0}.infinite-scroll-loading ion-infinite-scroll-content>.infinite-loading{display:block}.infinite-scroll-content-md .infinite-loading-text{color:var(--ion-color-step-600, var(--ion-text-color-step-400, #666666))}.infinite-scroll-content-md .infinite-loading-spinner .spinner-lines-md line,.infinite-scroll-content-md .infinite-loading-spinner .spinner-lines-small-md line,.infinite-scroll-content-md .infinite-loading-spinner .spinner-crescent circle{stroke:var(--ion-color-step-600, var(--ion-text-color-step-400, #666666))}.infinite-scroll-content-md .infinite-loading-spinner .spinner-bubbles circle,.infinite-scroll-content-md .infinite-loading-spinner .spinner-circles circle,.infinite-scroll-content-md .infinite-loading-spinner .spinner-dots circle{fill:var(--ion-color-step-600, var(--ion-text-color-step-400, #666666))}`;
@@ -227,27 +302,28 @@ const InfiniteScrollContent = class {
227
302
  }
228
303
  componentDidLoad() {
229
304
  if (this.loadingSpinner === undefined) {
230
- const mode = ionicGlobal.getIonMode(this);
231
- this.loadingSpinner = index.config.get('infiniteLoadingSpinner', index.config.get('spinner', mode === 'ios' ? 'lines' : 'crescent'));
305
+ const theme = ionicGlobal.getIonTheme(this);
306
+ this.loadingSpinner = index.config.get('infiniteLoadingSpinner', index.config.get('spinner', theme === 'ios' ? 'lines' : 'crescent'));
232
307
  }
233
308
  }
234
309
  renderLoadingText() {
235
310
  const { customHTMLEnabled, loadingText } = this;
236
311
  if (customHTMLEnabled) {
237
- return index.h("div", { class: "infinite-loading-text", innerHTML: config.sanitizeDOMString(loadingText) });
312
+ return index.h("div", { class: "infinite-loading-text", innerHTML: index$2.sanitizeDOMString(loadingText) });
238
313
  }
239
314
  return index.h("div", { class: "infinite-loading-text" }, this.loadingText);
240
315
  }
241
316
  render() {
242
- const mode = ionicGlobal.getIonMode(this);
243
- return (index.h(index.Host, { key: '7c16060dcfe2a0b0fb3e2f8f4c449589a76f1baa', class: {
244
- [mode]: true,
317
+ const theme = ionicGlobal.getIonTheme(this);
318
+ return (index.h(index.Host, { key: '263a27297159ced042f7552a1e14b8c6aba62fa8', class: {
319
+ [theme]: true,
245
320
  // Used internally for styling
246
- [`infinite-scroll-content-${mode}`]: true,
247
- } }, index.h("div", { key: 'a94f4d8746e053dc718f97520bd7e48cb316443a', class: "infinite-loading" }, this.loadingSpinner && (index.h("div", { key: '10143d5d2a50a2a2bc5de1cee8e7ab51263bcf23', class: "infinite-loading-spinner" }, index.h("ion-spinner", { key: '8846e88191690d9c61a0b462889ed56fbfed8b0d', name: this.loadingSpinner }))), this.loadingText !== undefined && this.renderLoadingText())));
321
+ [`infinite-scroll-content-${theme}`]: true,
322
+ } }, index.h("div", { key: 'ee38d3c52df9dc5de186406b3087f20917a17252', class: "infinite-loading" }, this.loadingSpinner && (index.h("div", { key: 'e2348727f79a26f52f42641d4334a0ba9d4aa03e', class: "infinite-loading-spinner" }, index.h("ion-spinner", { key: '41be6f2747f3af5f46c8738e2ef56083ecd95e99', name: this.loadingSpinner }))), this.loadingText !== undefined && this.renderLoadingText())));
248
323
  }
249
324
  };
250
325
  InfiniteScrollContent.style = {
326
+ ionic: ionicInfiniteScrollContentMdCss(),
251
327
  ios: infiniteScrollContentIosCss(),
252
328
  md: infiniteScrollContentMdCss()
253
329
  };
@@ -3,15 +3,19 @@
3
3
  */
4
4
  'use strict';
5
5
 
6
- var index = require('./index-Ct7gcRif.js');
7
- var helpers = require('./helpers-Cv23MFHM.js');
6
+ var index = require('./index-GZU9YrFc.js');
7
+ var helpers = require('./helpers-DiOgV5hw.js');
8
+ var validity = require('./validity-QmuwEptc.js');
8
9
  var dir = require('./dir-Cn0z1rJH.js');
9
- var theme = require('./theme-CeDs6Hcv.js');
10
- var ionicGlobal = require('./ionic-global-B-cA6LkY.js');
10
+ var theme = require('./theme-IlOsGAz7.js');
11
+ var ionicGlobal = require('./ionic-global-QoUqobrQ.js');
12
+ require('./focus-visible-BIj-I3-C.js');
11
13
 
12
- const inputOtpIosCss = () => `.sc-ion-input-otp-ios-h{--margin-top:0;--margin-end:0;--margin-bottom:0;--margin-start:0;--padding-top:16px;--padding-end:0;--padding-bottom:16px;--padding-start:0;--color:initial;--min-width:40px;--separator-width:8px;--separator-height:var(--separator-width);--separator-border-radius:999px;--separator-color:var(--ion-color-step-150, var(--ion-background-color-step-150, #d9d9d9));--highlight-color-focused:var(--ion-color-primary, #0054e9);--highlight-color-valid:var(--ion-color-success, #2dd55b);--highlight-color-invalid:var(--ion-color-danger, #c5000f);--highlight-color:var(--highlight-color-focused);display:block;position:relative;font-size:0.875rem}.input-otp-group.sc-ion-input-otp-ios{-webkit-margin-start:var(--margin-start);margin-inline-start:var(--margin-start);-webkit-margin-end:var(--margin-end);margin-inline-end:var(--margin-end);margin-top:var(--margin-top);margin-bottom:var(--margin-bottom);-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center}.native-wrapper.sc-ion-input-otp-ios{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;min-width:var(--min-width)}.native-input.sc-ion-input-otp-ios{border-radius:var(--border-radius);width:var(--width);min-width:inherit;height:var(--height);border-width:var(--border-width);border-style:solid;border-color:var(--border-color);background:var(--background);color:var(--color);font-size:inherit;text-align:center;-webkit-appearance:none;-moz-appearance:none;appearance:none}.has-focus.sc-ion-input-otp-ios-h .native-input.sc-ion-input-otp-ios{caret-color:var(--highlight-color)}.input-otp-description.sc-ion-input-otp-ios{color:var(--ion-color-step-700, var(--ion-text-color-step-300, #4d4d4d));font-size:0.75rem;line-height:1.25rem;text-align:center}.input-otp-description-hidden.sc-ion-input-otp-ios{display:none}.input-otp-separator.sc-ion-input-otp-ios{border-radius:var(--separator-border-radius);-ms-flex-negative:0;flex-shrink:0;width:var(--separator-width);height:var(--separator-height);background:var(--separator-color)}.input-otp-size-small.sc-ion-input-otp-ios-h{--width:40px;--height:40px}.input-otp-size-small.sc-ion-input-otp-ios-h .input-otp-group.sc-ion-input-otp-ios{gap:8px}.input-otp-size-medium.sc-ion-input-otp-ios-h{--width:48px;--height:48px}.input-otp-size-large.sc-ion-input-otp-ios-h{--width:56px;--height:56px}.input-otp-size-medium.sc-ion-input-otp-ios-h .input-otp-group.sc-ion-input-otp-ios,.input-otp-size-large.sc-ion-input-otp-ios-h .input-otp-group.sc-ion-input-otp-ios{gap:12px}.input-otp-shape-round.sc-ion-input-otp-ios-h{--border-radius:16px}.input-otp-shape-soft.sc-ion-input-otp-ios-h{--border-radius:8px}.input-otp-shape-rectangular.sc-ion-input-otp-ios-h{--border-radius:0}.input-otp-fill-outline.sc-ion-input-otp-ios-h{--background:none}.input-otp-fill-solid.sc-ion-input-otp-ios-h{--border-color:var(--ion-color-step-50, var(--ion-background-color-step-50, #f2f2f2));--background:var(--ion-color-step-50, var(--ion-background-color-step-50, #f2f2f2))}.input-otp-disabled.sc-ion-input-otp-ios-h{--color:var(--ion-color-step-350, var(--ion-text-color-step-650, #a6a6a6))}.input-otp-fill-outline.input-otp-disabled.sc-ion-input-otp-ios-h{--background:var(--ion-color-step-50, var(--ion-background-color-step-50, #f2f2f2));--border-color:var(--ion-color-step-100, var(--ion-background-color-step-100, #e6e6e6))}.input-otp-disabled.sc-ion-input-otp-ios-h,.input-otp-disabled.sc-ion-input-otp-ios-h .native-input.sc-ion-input-otp-ios:disabled{cursor:not-allowed}.has-focus.sc-ion-input-otp-ios-h .native-input.sc-ion-input-otp-ios:focus{--border-color:var(--highlight-color);outline:none}.input-otp-fill-outline.input-otp-readonly.sc-ion-input-otp-ios-h{--background:var(--ion-color-step-50, var(--ion-background-color-step-50, #f2f2f2))}.input-otp-fill-solid.input-otp-disabled.sc-ion-input-otp-ios-h,.input-otp-fill-solid.input-otp-readonly.sc-ion-input-otp-ios-h{--border-color:var(--ion-color-step-100, var(--ion-background-color-step-100, #e6e6e6));--background:var(--ion-color-step-100, var(--ion-background-color-step-100, #e6e6e6))}.ion-touched.ion-invalid.sc-ion-input-otp-ios-h{--highlight-color:var(--highlight-color-invalid)}.ion-valid.sc-ion-input-otp-ios-h{--highlight-color:var(--highlight-color-valid)}.has-focus.ion-valid.sc-ion-input-otp-ios-h,.ion-touched.ion-invalid.sc-ion-input-otp-ios-h{--border-color:var(--highlight-color)}.ion-color.sc-ion-input-otp-ios-h{--highlight-color-focused:var(--ion-color-base)}.input-otp-fill-outline.ion-color.sc-ion-input-otp-ios-h .native-input.sc-ion-input-otp-ios,.input-otp-fill-solid.ion-color.sc-ion-input-otp-ios-h .native-input.sc-ion-input-otp-ios:focus{border-color:rgba(var(--ion-color-base-rgb), 0.6)}.input-otp-fill-outline.ion-color.ion-invalid.sc-ion-input-otp-ios-h .native-input.sc-ion-input-otp-ios,.input-otp-fill-solid.ion-color.ion-invalid.sc-ion-input-otp-ios-h .native-input.sc-ion-input-otp-ios,.input-otp-fill-outline.ion-color.has-focus.ion-invalid.sc-ion-input-otp-ios-h .native-input.sc-ion-input-otp-ios,.input-otp-fill-solid.ion-color.has-focus.ion-invalid.sc-ion-input-otp-ios-h .native-input.sc-ion-input-otp-ios{border-color:var(--ion-color-danger, #c5000f)}.input-otp-fill-outline.ion-color.ion-valid.sc-ion-input-otp-ios-h .native-input.sc-ion-input-otp-ios,.input-otp-fill-solid.ion-color.ion-valid.sc-ion-input-otp-ios-h .native-input.sc-ion-input-otp-ios,.input-otp-fill-outline.ion-color.has-focus.ion-valid.sc-ion-input-otp-ios-h .native-input.sc-ion-input-otp-ios,.input-otp-fill-solid.ion-color.has-focus.ion-valid.sc-ion-input-otp-ios-h .native-input.sc-ion-input-otp-ios{border-color:var(--ion-color-success, #2dd55b)}.input-otp-fill-outline.input-otp-disabled.ion-color.sc-ion-input-otp-ios-h .native-input.sc-ion-input-otp-ios{border-color:rgba(var(--ion-color-base-rgb), 0.3)}.sc-ion-input-otp-ios-h{--border-width:0.55px}.has-focus.sc-ion-input-otp-ios-h .native-input.sc-ion-input-otp-ios:focus{--border-width:1px}.input-otp-fill-outline.sc-ion-input-otp-ios-h{--border-color:var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-250, var(--ion-background-color-step-250, #c8c7cc))))}`;
14
+ const inputOtpIonicCss = () => `:host{--margin-top:0;--margin-end:0;--margin-bottom:0;--margin-start:0;--separator-height:var(--separator-width);--highlight-color:var(--highlight-color-focused);display:block;position:relative}.input-otp-group{-webkit-margin-start:var(--margin-start);margin-inline-start:var(--margin-start);-webkit-margin-end:var(--margin-end);margin-inline-end:var(--margin-end);margin-top:var(--margin-top);margin-bottom:var(--margin-bottom);-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center}.native-wrapper{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;min-width:var(--min-width)}.native-input{border-radius:var(--border-radius);width:var(--width);min-width:inherit;height:var(--height);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);background:var(--background);color:var(--color);font-family:inherit;font-size:inherit;text-align:center;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-box-sizing:border-box;box-sizing:border-box}:host(.has-focus) .native-input{caret-color:var(--highlight-color)}.input-otp-description{text-align:center}.input-otp-description-hidden{display:none}.input-otp-separator{border-radius:var(--separator-border-radius);-ms-flex-negative:0;flex-shrink:0;width:var(--separator-width);height:var(--separator-height);background:var(--separator-color)}:host(.input-otp-disabled),:host(.input-otp-disabled) .native-input:disabled{cursor:not-allowed}:host(.has-focus) .native-input:focus{--border-color:var(--highlight-color);outline:none}:host(.ion-touched.ion-invalid){--highlight-color:var(--highlight-color-invalid)}:host(.ion-valid){--highlight-color:var(--highlight-color-valid)}:host(.has-focus.ion-valid),:host(.ion-touched.ion-invalid){--border-color:var(--highlight-color)}:host{--padding-top:var(--token-space-400, var(--token-scale-400, 16px));--padding-end:var(--token-space-0, var(--token-scale-0, 0px));--padding-bottom:var(--token-space-400, var(--token-scale-400, 16px));--padding-start:var(--token-space-0, var(--token-scale-0, 0px));--color:var(--token-text-default, var(--token-primitives-neutral-1200, #242424));--min-width:var(--token-scale-1000, 40px);--border-width:var(--token-border-size-025, var(--token-scale-025, 1px));--border-style:var(--token-border-style-solid, solid);--border-color:var(--token-border-input-default, var(--token-primitives-neutral-600, #8c8c8c));--separator-width:var(--token-scale-200, 8px);--separator-border-radius:var(--token-border-radius-full, 999px);--separator-color:var(--token-bg-neutral-subtle-press, var(--token-primitives-neutral-400, #d5d5d5));--highlight-color-focused:var(--token-border-focus-default, var(--token-primitives-blue-400, #b5c0f7));--highlight-color-valid:var(--token-border-success, var(--token-semantics-success-900, var(--token-primitives-green-900, #126f23)));--highlight-color-invalid:var(--token-border-danger-default, var(--token-semantics-danger-800, var(--token-primitives-red-800, #bf2222)));font-size:var(--token-font-size-350, 0.875rem);font-weight:var(--token-font-weight-regular, 400);letter-spacing:var(--token-font-letter-spacing-0, 0%);line-height:var(--token-font-line-height-600, var(--token-scale-600, 24px));text-decoration:none;text-transform:none}:host(.has-focus) .native-input:focus{--border-width:var(--token-border-size-050, var(--token-scale-050, 2px))}.input-otp-description{font-size:var(--token-font-size-300, 0.75rem);font-weight:var(--token-font-weight-medium, 500);letter-spacing:var(--token-font-letter-spacing-0, 0%);line-height:var(--token-font-line-height-500, var(--token-scale-500, 20px));text-decoration:none;text-transform:none;color:var(--token-text-subtlest, var(--token-primitives-neutral-800, #626262))}:host(.input-otp-size-small){--width:var(--token-scale-1000, 40px);--height:var(--token-scale-1000, 40px)}:host(.input-otp-size-small) .input-otp-group{gap:var(--token-space-200, var(--token-scale-200, 8px))}:host(.input-otp-size-medium){--width:var(--token-scale-1200, 48px);--height:var(--token-scale-1200, 48px)}:host(.input-otp-size-large){--width:var(--token-scale-1400, 56px);--height:var(--token-scale-1400, 56px)}:host(.input-otp-size-medium) .input-otp-group,:host(.input-otp-size-large) .input-otp-group{gap:var(--token-space-300, var(--token-scale-300, 12px))}:host(.input-otp-shape-round){--border-radius:var(--token-round-xl, var(--token-border-radius-400, var(--token-scale-400, 16px)))}:host(.input-otp-shape-soft){--border-radius:var(--token-soft-xl, var(--token-border-radius-200, var(--token-scale-200, 8px)))}:host(.input-otp-shape-rectangular){--border-radius:var(--token-rectangular-xl, var(--token-border-radius-0, var(--token-scale-0, 0px)))}:host(.input-otp-fill-outline){--background:var(--token-bg-input-default, var(--token-primitives-base-white, #ffffff))}:host(.input-otp-fill-solid){--border-color:var(--token-bg-input-bold-default, var(--token-primitives-neutral-200, #eae9e9));--background:var(--token-bg-input-bold-default, var(--token-primitives-neutral-200, #eae9e9))}:host(.input-otp-disabled){--color:var(--token-text-disabled, var(--token-primitives-neutral-500, #a2a2a2))}:host(.input-otp-fill-outline.input-otp-disabled){--background:var(--token-bg-input-disabled, var(--token-primitives-neutral-100, #f3f3f3));--border-color:var(--token-border-disabled, var(--token-primitives-neutral-300, #e0e0e0))}:host(.input-otp-fill-outline.input-otp-readonly){--background:var(--token-bg-input-read-only, var(--token-primitives-neutral-100, #f3f3f3))}:host(.input-otp-fill-solid.input-otp-disabled){--border-color:var(--token-bg-input-bold-disabled, var(--token-primitives-neutral-300, #e0e0e0));--background:var(--token-bg-input-bold-disabled, var(--token-primitives-neutral-300, #e0e0e0))}:host(.input-otp-fill-solid.input-otp-readonly){--border-color:var(--token-bg-input-bold-read-only, var(--token-primitives-neutral-300, #e0e0e0));--background:var(--token-bg-input-bold-read-only, var(--token-primitives-neutral-300, #e0e0e0))}:host(.ion-color){--highlight-color-focused:var(--ion-color-base)}:host(.input-otp-fill-outline.ion-color) .native-input,:host(.input-otp-fill-solid.ion-color) .native-input:focus{border-color:rgba(var(--ion-color-base-rgb), 0.6)}:host(.input-otp-fill-outline.ion-color.ion-invalid) .native-input,:host(.input-otp-fill-solid.ion-color.ion-invalid) .native-input,:host(.input-otp-fill-outline.ion-color.has-focus.ion-invalid) .native-input,:host(.input-otp-fill-solid.ion-color.has-focus.ion-invalid) .native-input{border-color:var(--ion-color-danger, var(--token-bg-danger-base-default, var(--token-semantics-danger-800, var(--token-primitives-red-800, #bf2222))))}:host(.input-otp-fill-outline.ion-color.ion-valid) .native-input,:host(.input-otp-fill-solid.ion-color.ion-valid) .native-input,:host(.input-otp-fill-outline.ion-color.has-focus.ion-valid) .native-input,:host(.input-otp-fill-solid.ion-color.has-focus.ion-valid) .native-input{border-color:var(--ion-color-success, var(--token-bg-success-base-default, var(--token-semantics-success-900, var(--token-primitives-green-900, #126f23))))}:host(.input-otp-fill-outline.input-otp-disabled.ion-color) .native-input{border-color:rgba(var(--ion-color-base-rgb), 0.3)}`;
13
15
 
14
- const inputOtpMdCss = () => `.sc-ion-input-otp-md-h{--margin-top:0;--margin-end:0;--margin-bottom:0;--margin-start:0;--padding-top:16px;--padding-end:0;--padding-bottom:16px;--padding-start:0;--color:initial;--min-width:40px;--separator-width:8px;--separator-height:var(--separator-width);--separator-border-radius:999px;--separator-color:var(--ion-color-step-150, var(--ion-background-color-step-150, #d9d9d9));--highlight-color-focused:var(--ion-color-primary, #0054e9);--highlight-color-valid:var(--ion-color-success, #2dd55b);--highlight-color-invalid:var(--ion-color-danger, #c5000f);--highlight-color:var(--highlight-color-focused);display:block;position:relative;font-size:0.875rem}.input-otp-group.sc-ion-input-otp-md{-webkit-margin-start:var(--margin-start);margin-inline-start:var(--margin-start);-webkit-margin-end:var(--margin-end);margin-inline-end:var(--margin-end);margin-top:var(--margin-top);margin-bottom:var(--margin-bottom);-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center}.native-wrapper.sc-ion-input-otp-md{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;min-width:var(--min-width)}.native-input.sc-ion-input-otp-md{border-radius:var(--border-radius);width:var(--width);min-width:inherit;height:var(--height);border-width:var(--border-width);border-style:solid;border-color:var(--border-color);background:var(--background);color:var(--color);font-size:inherit;text-align:center;-webkit-appearance:none;-moz-appearance:none;appearance:none}.has-focus.sc-ion-input-otp-md-h .native-input.sc-ion-input-otp-md{caret-color:var(--highlight-color)}.input-otp-description.sc-ion-input-otp-md{color:var(--ion-color-step-700, var(--ion-text-color-step-300, #4d4d4d));font-size:0.75rem;line-height:1.25rem;text-align:center}.input-otp-description-hidden.sc-ion-input-otp-md{display:none}.input-otp-separator.sc-ion-input-otp-md{border-radius:var(--separator-border-radius);-ms-flex-negative:0;flex-shrink:0;width:var(--separator-width);height:var(--separator-height);background:var(--separator-color)}.input-otp-size-small.sc-ion-input-otp-md-h{--width:40px;--height:40px}.input-otp-size-small.sc-ion-input-otp-md-h .input-otp-group.sc-ion-input-otp-md{gap:8px}.input-otp-size-medium.sc-ion-input-otp-md-h{--width:48px;--height:48px}.input-otp-size-large.sc-ion-input-otp-md-h{--width:56px;--height:56px}.input-otp-size-medium.sc-ion-input-otp-md-h .input-otp-group.sc-ion-input-otp-md,.input-otp-size-large.sc-ion-input-otp-md-h .input-otp-group.sc-ion-input-otp-md{gap:12px}.input-otp-shape-round.sc-ion-input-otp-md-h{--border-radius:16px}.input-otp-shape-soft.sc-ion-input-otp-md-h{--border-radius:8px}.input-otp-shape-rectangular.sc-ion-input-otp-md-h{--border-radius:0}.input-otp-fill-outline.sc-ion-input-otp-md-h{--background:none}.input-otp-fill-solid.sc-ion-input-otp-md-h{--border-color:var(--ion-color-step-50, var(--ion-background-color-step-50, #f2f2f2));--background:var(--ion-color-step-50, var(--ion-background-color-step-50, #f2f2f2))}.input-otp-disabled.sc-ion-input-otp-md-h{--color:var(--ion-color-step-350, var(--ion-text-color-step-650, #a6a6a6))}.input-otp-fill-outline.input-otp-disabled.sc-ion-input-otp-md-h{--background:var(--ion-color-step-50, var(--ion-background-color-step-50, #f2f2f2));--border-color:var(--ion-color-step-100, var(--ion-background-color-step-100, #e6e6e6))}.input-otp-disabled.sc-ion-input-otp-md-h,.input-otp-disabled.sc-ion-input-otp-md-h .native-input.sc-ion-input-otp-md:disabled{cursor:not-allowed}.has-focus.sc-ion-input-otp-md-h .native-input.sc-ion-input-otp-md:focus{--border-color:var(--highlight-color);outline:none}.input-otp-fill-outline.input-otp-readonly.sc-ion-input-otp-md-h{--background:var(--ion-color-step-50, var(--ion-background-color-step-50, #f2f2f2))}.input-otp-fill-solid.input-otp-disabled.sc-ion-input-otp-md-h,.input-otp-fill-solid.input-otp-readonly.sc-ion-input-otp-md-h{--border-color:var(--ion-color-step-100, var(--ion-background-color-step-100, #e6e6e6));--background:var(--ion-color-step-100, var(--ion-background-color-step-100, #e6e6e6))}.ion-touched.ion-invalid.sc-ion-input-otp-md-h{--highlight-color:var(--highlight-color-invalid)}.ion-valid.sc-ion-input-otp-md-h{--highlight-color:var(--highlight-color-valid)}.has-focus.ion-valid.sc-ion-input-otp-md-h,.ion-touched.ion-invalid.sc-ion-input-otp-md-h{--border-color:var(--highlight-color)}.ion-color.sc-ion-input-otp-md-h{--highlight-color-focused:var(--ion-color-base)}.input-otp-fill-outline.ion-color.sc-ion-input-otp-md-h .native-input.sc-ion-input-otp-md,.input-otp-fill-solid.ion-color.sc-ion-input-otp-md-h .native-input.sc-ion-input-otp-md:focus{border-color:rgba(var(--ion-color-base-rgb), 0.6)}.input-otp-fill-outline.ion-color.ion-invalid.sc-ion-input-otp-md-h .native-input.sc-ion-input-otp-md,.input-otp-fill-solid.ion-color.ion-invalid.sc-ion-input-otp-md-h .native-input.sc-ion-input-otp-md,.input-otp-fill-outline.ion-color.has-focus.ion-invalid.sc-ion-input-otp-md-h .native-input.sc-ion-input-otp-md,.input-otp-fill-solid.ion-color.has-focus.ion-invalid.sc-ion-input-otp-md-h .native-input.sc-ion-input-otp-md{border-color:var(--ion-color-danger, #c5000f)}.input-otp-fill-outline.ion-color.ion-valid.sc-ion-input-otp-md-h .native-input.sc-ion-input-otp-md,.input-otp-fill-solid.ion-color.ion-valid.sc-ion-input-otp-md-h .native-input.sc-ion-input-otp-md,.input-otp-fill-outline.ion-color.has-focus.ion-valid.sc-ion-input-otp-md-h .native-input.sc-ion-input-otp-md,.input-otp-fill-solid.ion-color.has-focus.ion-valid.sc-ion-input-otp-md-h .native-input.sc-ion-input-otp-md{border-color:var(--ion-color-success, #2dd55b)}.input-otp-fill-outline.input-otp-disabled.ion-color.sc-ion-input-otp-md-h .native-input.sc-ion-input-otp-md{border-color:rgba(var(--ion-color-base-rgb), 0.3)}.sc-ion-input-otp-md-h{--border-width:1px}.has-focus.sc-ion-input-otp-md-h .native-input.sc-ion-input-otp-md:focus{--border-width:2px}.input-otp-fill-outline.sc-ion-input-otp-md-h{--border-color:var(--ion-color-step-300, var(--ion-background-color-step-300, #b3b3b3))}`;
16
+ const inputOtpIosCss = () => `:host{--margin-top:0;--margin-end:0;--margin-bottom:0;--margin-start:0;--separator-height:var(--separator-width);--highlight-color:var(--highlight-color-focused);display:block;position:relative}.input-otp-group{-webkit-margin-start:var(--margin-start);margin-inline-start:var(--margin-start);-webkit-margin-end:var(--margin-end);margin-inline-end:var(--margin-end);margin-top:var(--margin-top);margin-bottom:var(--margin-bottom);-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center}.native-wrapper{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;min-width:var(--min-width)}.native-input{border-radius:var(--border-radius);width:var(--width);min-width:inherit;height:var(--height);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);background:var(--background);color:var(--color);font-family:inherit;font-size:inherit;text-align:center;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-box-sizing:border-box;box-sizing:border-box}:host(.has-focus) .native-input{caret-color:var(--highlight-color)}.input-otp-description{text-align:center}.input-otp-description-hidden{display:none}.input-otp-separator{border-radius:var(--separator-border-radius);-ms-flex-negative:0;flex-shrink:0;width:var(--separator-width);height:var(--separator-height);background:var(--separator-color)}:host(.input-otp-disabled),:host(.input-otp-disabled) .native-input:disabled{cursor:not-allowed}:host(.has-focus) .native-input:focus{--border-color:var(--highlight-color);outline:none}:host(.ion-touched.ion-invalid){--highlight-color:var(--highlight-color-invalid)}:host(.ion-valid){--highlight-color:var(--highlight-color-valid)}:host(.has-focus.ion-valid),:host(.ion-touched.ion-invalid){--border-color:var(--highlight-color)}:host{--padding-top:16px;--padding-end:0;--padding-bottom:16px;--padding-start:0;--color:initial;--min-width:40px;--border-style:solid;--separator-width:8px;--separator-border-radius:999px;--separator-color:var(--ion-color-step-150, var(--ion-background-color-step-150, #d9d9d9));--highlight-color-focused:var(--ion-color-primary, #0054e9);--highlight-color-valid:var(--ion-color-success, #2dd55b);--highlight-color-invalid:var(--ion-color-danger, #c5000f);font-family:var(--ion-font-family, inherit);font-size:0.875rem}.input-otp-description{color:var(--ion-color-step-700, var(--ion-text-color-step-300, #4d4d4d));font-size:0.75rem;line-height:1.25rem}:host(.input-otp-size-small){--width:40px;--height:40px}:host(.input-otp-size-small) .input-otp-group{gap:8px}:host(.input-otp-size-medium){--width:48px;--height:48px}:host(.input-otp-size-large){--width:56px;--height:56px}:host(.input-otp-size-medium) .input-otp-group,:host(.input-otp-size-large) .input-otp-group{gap:12px}:host(.input-otp-shape-round){--border-radius:16px}:host(.input-otp-shape-soft){--border-radius:8px}:host(.input-otp-shape-rectangular){--border-radius:0}:host(.input-otp-fill-outline){--background:none}:host(.input-otp-fill-solid){--border-color:var(--ion-color-step-50, var(--ion-background-color-step-50, #f2f2f2));--background:var(--ion-color-step-50, var(--ion-background-color-step-50, #f2f2f2))}:host(.input-otp-disabled){--color:var(--ion-color-step-350, var(--ion-text-color-step-650, #a6a6a6))}:host(.input-otp-fill-outline.input-otp-disabled){--background:var(--ion-color-step-50, var(--ion-background-color-step-50, #f2f2f2));--border-color:var(--ion-color-step-100, var(--ion-background-color-step-100, #e6e6e6))}:host(.input-otp-fill-outline.input-otp-readonly){--background:var(--ion-color-step-50, var(--ion-background-color-step-50, #f2f2f2))}:host(.input-otp-fill-solid.input-otp-disabled),:host(.input-otp-fill-solid.input-otp-readonly){--border-color:var(--ion-color-step-100, var(--ion-background-color-step-100, #e6e6e6));--background:var(--ion-color-step-100, var(--ion-background-color-step-100, #e6e6e6))}:host(.ion-color){--highlight-color-focused:var(--ion-color-base)}:host(.input-otp-fill-outline.ion-color) .native-input,:host(.input-otp-fill-solid.ion-color) .native-input:focus{border-color:rgba(var(--ion-color-base-rgb), 0.6)}:host(.input-otp-fill-outline.ion-color.ion-invalid) .native-input,:host(.input-otp-fill-solid.ion-color.ion-invalid) .native-input,:host(.input-otp-fill-outline.ion-color.has-focus.ion-invalid) .native-input,:host(.input-otp-fill-solid.ion-color.has-focus.ion-invalid) .native-input{border-color:var(--ion-color-danger, #c5000f)}:host(.input-otp-fill-outline.ion-color.ion-valid) .native-input,:host(.input-otp-fill-solid.ion-color.ion-valid) .native-input,:host(.input-otp-fill-outline.ion-color.has-focus.ion-valid) .native-input,:host(.input-otp-fill-solid.ion-color.has-focus.ion-valid) .native-input{border-color:var(--ion-color-success, #2dd55b)}:host(.input-otp-fill-outline.input-otp-disabled.ion-color) .native-input{border-color:rgba(var(--ion-color-base-rgb), 0.3)}:host{--border-width:0.55px}:host(.has-focus) .native-input:focus{--border-width:1px}:host(.input-otp-fill-outline){--border-color:var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-250, var(--ion-background-color-step-250, #c8c7cc))))}`;
17
+
18
+ const inputOtpMdCss = () => `:host{--margin-top:0;--margin-end:0;--margin-bottom:0;--margin-start:0;--separator-height:var(--separator-width);--highlight-color:var(--highlight-color-focused);display:block;position:relative}.input-otp-group{-webkit-margin-start:var(--margin-start);margin-inline-start:var(--margin-start);-webkit-margin-end:var(--margin-end);margin-inline-end:var(--margin-end);margin-top:var(--margin-top);margin-bottom:var(--margin-bottom);-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center}.native-wrapper{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;min-width:var(--min-width)}.native-input{border-radius:var(--border-radius);width:var(--width);min-width:inherit;height:var(--height);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);background:var(--background);color:var(--color);font-family:inherit;font-size:inherit;text-align:center;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-box-sizing:border-box;box-sizing:border-box}:host(.has-focus) .native-input{caret-color:var(--highlight-color)}.input-otp-description{text-align:center}.input-otp-description-hidden{display:none}.input-otp-separator{border-radius:var(--separator-border-radius);-ms-flex-negative:0;flex-shrink:0;width:var(--separator-width);height:var(--separator-height);background:var(--separator-color)}:host(.input-otp-disabled),:host(.input-otp-disabled) .native-input:disabled{cursor:not-allowed}:host(.has-focus) .native-input:focus{--border-color:var(--highlight-color);outline:none}:host(.ion-touched.ion-invalid){--highlight-color:var(--highlight-color-invalid)}:host(.ion-valid){--highlight-color:var(--highlight-color-valid)}:host(.has-focus.ion-valid),:host(.ion-touched.ion-invalid){--border-color:var(--highlight-color)}:host{--padding-top:16px;--padding-end:0;--padding-bottom:16px;--padding-start:0;--color:initial;--min-width:40px;--border-style:solid;--separator-width:8px;--separator-border-radius:999px;--separator-color:var(--ion-color-step-150, var(--ion-background-color-step-150, #d9d9d9));--highlight-color-focused:var(--ion-color-primary, #0054e9);--highlight-color-valid:var(--ion-color-success, #2dd55b);--highlight-color-invalid:var(--ion-color-danger, #c5000f);font-family:var(--ion-font-family, inherit);font-size:0.875rem}.input-otp-description{color:var(--ion-color-step-700, var(--ion-text-color-step-300, #4d4d4d));font-size:0.75rem;line-height:1.25rem}:host(.input-otp-size-small){--width:40px;--height:40px}:host(.input-otp-size-small) .input-otp-group{gap:8px}:host(.input-otp-size-medium){--width:48px;--height:48px}:host(.input-otp-size-large){--width:56px;--height:56px}:host(.input-otp-size-medium) .input-otp-group,:host(.input-otp-size-large) .input-otp-group{gap:12px}:host(.input-otp-shape-round){--border-radius:16px}:host(.input-otp-shape-soft){--border-radius:8px}:host(.input-otp-shape-rectangular){--border-radius:0}:host(.input-otp-fill-outline){--background:none}:host(.input-otp-fill-solid){--border-color:var(--ion-color-step-50, var(--ion-background-color-step-50, #f2f2f2));--background:var(--ion-color-step-50, var(--ion-background-color-step-50, #f2f2f2))}:host(.input-otp-disabled){--color:var(--ion-color-step-350, var(--ion-text-color-step-650, #a6a6a6))}:host(.input-otp-fill-outline.input-otp-disabled){--background:var(--ion-color-step-50, var(--ion-background-color-step-50, #f2f2f2));--border-color:var(--ion-color-step-100, var(--ion-background-color-step-100, #e6e6e6))}:host(.input-otp-fill-outline.input-otp-readonly){--background:var(--ion-color-step-50, var(--ion-background-color-step-50, #f2f2f2))}:host(.input-otp-fill-solid.input-otp-disabled),:host(.input-otp-fill-solid.input-otp-readonly){--border-color:var(--ion-color-step-100, var(--ion-background-color-step-100, #e6e6e6));--background:var(--ion-color-step-100, var(--ion-background-color-step-100, #e6e6e6))}:host(.ion-color){--highlight-color-focused:var(--ion-color-base)}:host(.input-otp-fill-outline.ion-color) .native-input,:host(.input-otp-fill-solid.ion-color) .native-input:focus{border-color:rgba(var(--ion-color-base-rgb), 0.6)}:host(.input-otp-fill-outline.ion-color.ion-invalid) .native-input,:host(.input-otp-fill-solid.ion-color.ion-invalid) .native-input,:host(.input-otp-fill-outline.ion-color.has-focus.ion-invalid) .native-input,:host(.input-otp-fill-solid.ion-color.has-focus.ion-invalid) .native-input{border-color:var(--ion-color-danger, #c5000f)}:host(.input-otp-fill-outline.ion-color.ion-valid) .native-input,:host(.input-otp-fill-solid.ion-color.ion-valid) .native-input,:host(.input-otp-fill-outline.ion-color.has-focus.ion-valid) .native-input,:host(.input-otp-fill-solid.ion-color.has-focus.ion-valid) .native-input{border-color:var(--ion-color-success, #2dd55b)}:host(.input-otp-fill-outline.input-otp-disabled.ion-color) .native-input{border-color:rgba(var(--ion-color-base-rgb), 0.3)}:host{--border-width:1px}:host(.has-focus) .native-input:focus{--border-width:2px}:host(.input-otp-fill-outline){--border-color:var(--ion-color-step-300, var(--ion-background-color-step-300, #b3b3b3))}`;
15
19
 
16
20
  const InputOTP = class {
17
21
  constructor(hostRef) {
@@ -21,6 +25,13 @@ const InputOTP = class {
21
25
  this.ionComplete = index.createEvent(this, "ionComplete", 7);
22
26
  this.ionBlur = index.createEvent(this, "ionBlur", 7);
23
27
  this.ionFocus = index.createEvent(this, "ionFocus", 7);
28
+ if (hostRef.$hostElement$["s-ei"]) {
29
+ this.internals = hostRef.$hostElement$["s-ei"];
30
+ }
31
+ else {
32
+ this.internals = hostRef.$hostElement$.attachInternals();
33
+ hostRef.$hostElement$["s-ei"] = this.internals;
34
+ }
24
35
  this.inheritedAttributes = {};
25
36
  this.inputRefs = [];
26
37
  this.inputId = `ion-input-otp-${inputIds++}`;
@@ -374,6 +385,12 @@ const InputOTP = class {
374
385
  (_b = inputRefs[nextEmptyIndex]) === null || _b === void 0 ? void 0 : _b.focus();
375
386
  };
376
387
  }
388
+ /**
389
+ * Update element internals when disabled prop changes
390
+ */
391
+ disabledChanged() {
392
+ this.updateElementInternals();
393
+ }
377
394
  /**
378
395
  * Sets focus to an input box.
379
396
  * @param index - The index of the input box to focus (0-based).
@@ -394,6 +411,7 @@ const InputOTP = class {
394
411
  valueChanged() {
395
412
  this.initializeValues();
396
413
  this.updateTabIndexes();
414
+ this.updateElementInternals();
397
415
  }
398
416
  /**
399
417
  * Processes the separators prop into an array of numbers.
@@ -450,6 +468,7 @@ const InputOTP = class {
450
468
  }
451
469
  componentDidLoad() {
452
470
  this.updateTabIndexes();
471
+ this.updateElementInternals();
453
472
  }
454
473
  /**
455
474
  * Get the regex pattern for allowed characters.
@@ -526,6 +545,47 @@ const InputOTP = class {
526
545
  this.ionComplete.emit({ value: newValue });
527
546
  }
528
547
  }
548
+ /**
549
+ * Gets the value of the input group as a string for form submission.
550
+ * Returns an empty string if the value is null or undefined.
551
+ */
552
+ getValue() {
553
+ return this.value != null ? this.value.toString() : '';
554
+ }
555
+ /**
556
+ * Called when the form state is restored.
557
+ * Restores the component's value.
558
+ */
559
+ formStateRestoreCallback(value) {
560
+ this.value = value;
561
+ }
562
+ /**
563
+ * Called when the form is reset.
564
+ * Resets the component's value.
565
+ */
566
+ formResetCallback() {
567
+ this.value = '';
568
+ }
569
+ /**
570
+ * Updates the form value and reports validity state to the browser via
571
+ * ElementInternals. This should be called when the component loads, when
572
+ * the disabled prop changes, and when the value changes to ensure the form
573
+ * value stays in sync and validation state is updated.
574
+ */
575
+ updateElementInternals() {
576
+ var _a;
577
+ // Disabled form controls should not be included in form data
578
+ // Pass null to setFormValue when disabled to exclude it from form submission
579
+ const value = this.disabled ? null : this.getValue();
580
+ // ElementInternals may not be fully available in test environments
581
+ // so we need to check if the method exists before calling it
582
+ if (typeof this.internals.setFormValue === 'function') {
583
+ this.internals.setFormValue(value);
584
+ }
585
+ // Use the first input element for validity reporting since all inputs
586
+ // share the same validation state
587
+ validity.reportValidityToElementInternals((_a = this.inputRefs[0]) !== null && _a !== void 0 ? _a : null, this.internals);
588
+ }
529
589
  /**
530
590
  * Emits an `ionChange` event.
531
591
  * This API should be called for user committed changes.
@@ -632,7 +692,7 @@ const InputOTP = class {
632
692
  const tabbableIndex = this.getTabbableIndex();
633
693
  const pattern = this.getPattern();
634
694
  const hasDescription = ((_b = (_a = el.querySelector('.input-otp-description')) === null || _a === void 0 ? void 0 : _a.textContent) === null || _b === void 0 ? void 0 : _b.trim()) !== '';
635
- return (index.h(index.Host, { key: 'ffeec6d07b5d3cd375b72d4c9f4fe755d80ac094', class: theme.createColorClasses(color, {
695
+ return (index.h(index.Host, { key: '2bdd205b13281373a43d1a86a25df950a6f36ae1', class: theme.createColorClasses(color, {
636
696
  [mode]: true,
637
697
  'has-focus': hasFocus,
638
698
  [`input-otp-size-${size}`]: true,
@@ -640,13 +700,17 @@ const InputOTP = class {
640
700
  [`input-otp-fill-${fill}`]: true,
641
701
  'input-otp-disabled': disabled,
642
702
  'input-otp-readonly': readonly,
643
- }) }, index.h("div", Object.assign({ key: 'f42471e4ed8054f07162a52b42a0ca49c3d57bb0', role: "group", "aria-label": "One-time password input", class: "input-otp-group" }, inheritedAttributes), Array.from({ length }).map((_, index$1) => (index.h(index.Fragment, null, index.h("div", { class: "native-wrapper" }, index.h("input", { class: "native-input", id: `${inputId}-${index$1}`, "aria-label": `Input ${index$1 + 1} of ${length}`, type: "text", autoCapitalize: autocapitalize, inputmode: inputmode, pattern: pattern, disabled: disabled, readOnly: readonly, tabIndex: index$1 === tabbableIndex ? 0 : -1, value: inputValues[index$1] || '', autocomplete: "one-time-code", ref: (el) => (inputRefs[index$1] = el), onInput: this.onInput(index$1), onBlur: this.onBlur, onFocus: this.onFocus(index$1), onKeyDown: this.onKeyDown(index$1), onPaste: this.onPaste })), this.showSeparator(index$1) && index.h("div", { class: "input-otp-separator" }))))), index.h("div", { key: 'b06461605b2404476b856785b7116e18b4dbaeaa', class: {
703
+ }) }, index.h("div", Object.assign({ key: 'b82d198138929327cd5429bbeb482248935ae88d', role: "group", "aria-label": "One-time password input", class: "input-otp-group", part: "group" }, inheritedAttributes), Array.from({ length }).map((_, index$1) => (index.h(index.Fragment, null, index.h("div", { class: "native-wrapper", part: "container" }, index.h("input", { class: "native-input", part: "native", id: `${inputId}-${index$1}`, "aria-label": `Input ${index$1 + 1} of ${length}`, type: "text", autoCapitalize: autocapitalize, inputmode: inputmode, pattern: pattern, disabled: disabled, readOnly: readonly, tabIndex: index$1 === tabbableIndex ? 0 : -1, value: inputValues[index$1] || '', autocomplete: "one-time-code", ref: (el) => (inputRefs[index$1] = el), onInput: this.onInput(index$1), onBlur: this.onBlur, onFocus: this.onFocus(index$1), onKeyDown: this.onKeyDown(index$1), onPaste: this.onPaste })), this.showSeparator(index$1) && index.h("div", { class: "input-otp-separator", part: "separator" }))))), index.h("div", { key: '0bb5444d4e653bb7310abec502f5b1d76e681c37', class: {
644
704
  'input-otp-description': true,
645
705
  'input-otp-description-hidden': !hasDescription,
646
- } }, index.h("slot", { key: '5bf9e7dc365f6caf0d4b13ae26e5559cdbbd162c' }))));
706
+ }, part: "description" }, index.h("slot", { key: 'f717bda988a6e9b97d67025c1d3163d838f27bb5' }))));
647
707
  }
708
+ static get formAssociated() { return true; }
648
709
  get el() { return index.getElement(this); }
649
710
  static get watchers() { return {
711
+ "disabled": [{
712
+ "disabledChanged": 0
713
+ }],
650
714
  "value": [{
651
715
  "valueChanged": 0
652
716
  }],
@@ -660,6 +724,7 @@ const InputOTP = class {
660
724
  };
661
725
  let inputIds = 0;
662
726
  InputOTP.style = {
727
+ ionic: inputOtpIonicCss(),
663
728
  ios: inputOtpIosCss(),
664
729
  md: inputOtpMdCss()
665
730
  };
@@ -3,14 +3,20 @@
3
3
  */
4
4
  'use strict';
5
5
 
6
- var index = require('./index-Ct7gcRif.js');
7
- var theme = require('./theme-CeDs6Hcv.js');
8
- var index$1 = require('./index-DqmRDbxg.js');
9
- var ionicGlobal = require('./ionic-global-B-cA6LkY.js');
6
+ var index = require('./index-GZU9YrFc.js');
7
+ var theme = require('./theme-IlOsGAz7.js');
8
+ var index$1 = require('./index-CgAbCW6L.js');
9
+ var ionicGlobal = require('./ionic-global-QoUqobrQ.js');
10
10
 
11
- const iosInputPasswordToggleCss = () => ``;
11
+ const eyeSlashSvg = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyNTYgMjU2IiBmaWxsPSJjdXJyZW50Q29sb3IiPjxwYXRoIGQ9Ik01My45MiwzNC42MkE4LDgsMCwxLDAsNDIuMDgsNDUuMzhMNjEuMzIsNjYuNTVDMjUsODguODQsOS4zOCwxMjMuMiw4LjY5LDEyNC43NmE4LDgsMCwwLDAsMCw2LjVjLjM1Ljc5LDguODIsMTkuNTcsMjcuNjUsMzguNEM2MS40MywxOTQuNzQsOTMuMTIsMjA4LDEyOCwyMDhhMTI3LjExLDEyNy4xMSwwLDAsMCw1Mi4wNy0xMC44M2wyMiwyNC4yMWE4LDgsMCwxLDAsMTEuODQtMTAuNzZabTQ3LjMzLDc1Ljg0LDQxLjY3LDQ1Ljg1YTMyLDMyLDAsMCwxLTQxLjY3LTQ1Ljg1Wk0xMjgsMTkyYy0zMC43OCwwLTU3LjY3LTExLjE5LTc5LjkzLTMzLjI1QTEzMy4xNiwxMzMuMTYsMCwwLDEsMjUsMTI4YzQuNjktOC43OSwxOS42Ni0zMy4zOSw0Ny4zNS00OS4zOGwxOCwxOS43NWE0OCw0OCwwLDAsMCw2My42Niw3MGwxNC43MywxNi4yQTExMiwxMTIsMCwwLDEsMTI4LDE5MlptNi05NS40M2E4LDgsMCwwLDEsMy0xNS43Miw0OC4xNiw0OC4xNiwwLDAsMSwzOC43Nyw0Mi42NCw4LDgsMCwwLDEtNy4yMiw4LjcxLDYuMzksNi4zOSwwLDAsMS0uNzUsMCw4LDgsMCwwLDEtOC03LjI2QTMyLjA5LDMyLjA5LDAsMCwwLDEzNCw5Ni41N1ptMTEzLjI4LDM0LjY5Yy0uNDIuOTQtMTAuNTUsMjMuMzctMzMuMzYsNDMuOGE4LDgsMCwxLDEtMTAuNjctMTEuOTJBMTMyLjc3LDEzMi43NywwLDAsMCwyMzEuMDUsMTI4YTEzMy4xNSwxMzMuMTUsMCwwLDAtMjMuMTItMzAuNzdDMTg1LjY3LDc1LjE5LDE1OC43OCw2NCwxMjgsNjRhMTE4LjM3LDExOC4zNywwLDAsMC0xOS4zNiwxLjU3QTgsOCwwLDEsMSwxMDYsNDkuNzksMTM0LDEzNCwwLDAsMSwxMjgsNDhjMzQuODgsMCw2Ni41NywxMy4yNiw5MS42NiwzOC4zNSwxOC44MywxOC44MywyNy4zLDM3LjYyLDI3LjY1LDM4LjQxQTgsOCwwLDAsMSwyNDcuMzEsMTMxLjI2WiIvPjwvc3ZnPg==';
12
12
 
13
- const mdInputPasswordToggleCss = () => ``;
13
+ const eyeSvg = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyNTYgMjU2IiBmaWxsPSJjdXJyZW50Q29sb3IiPjxwYXRoIGQ9Ik0yNDcuMzEsMTI0Ljc2Yy0uMzUtLjc5LTguODItMTkuNTgtMjcuNjUtMzguNDFDMTk0LjU3LDYxLjI2LDE2Mi44OCw0OCwxMjgsNDhTNjEuNDMsNjEuMjYsMzYuMzQsODYuMzVDMTcuNTEsMTA1LjE4LDksMTI0LDguNjksMTI0Ljc2YTgsOCwwLDAsMCwwLDYuNWMuMzUuNzksOC44MiwxOS41NywyNy42NSwzOC40QzYxLjQzLDE5NC43NCw5My4xMiwyMDgsMTI4LDIwOHM2Ni41Ny0xMy4yNiw5MS42Ni0zOC4zNGMxOC44My0xOC44MywyNy4zLTM3LjYxLDI3LjY1LTM4LjRBOCw4LDAsMCwwLDI0Ny4zMSwxMjQuNzZaTTEyOCwxOTJjLTMwLjc4LDAtNTcuNjctMTEuMTktNzkuOTMtMzMuMjVBMTMzLjQ3LDEzMy40NywwLDAsMSwyNSwxMjgsMTMzLjMzLDEzMy4zMywwLDAsMSw0OC4wNyw5Ny4yNUM3MC4zMyw3NS4xOSw5Ny4yMiw2NCwxMjgsNjRzNTcuNjcsMTEuMTksNzkuOTMsMzMuMjVBMTMzLjQ2LDEzMy40NiwwLDAsMSwyMzEuMDUsMTI4QzIyMy44NCwxNDEuNDYsMTkyLjQzLDE5MiwxMjgsMTkyWm0wLTExMmE0OCw0OCwwLDEsMCw0OCw0OEE0OC4wNSw0OC4wNSwwLDAsMCwxMjgsODBabTAsODBhMzIsMzIsMCwxLDEsMzItMzJBMzIsMzIsMCwwLDEsMTI4LDE2MFoiLz48L3N2Zz4=';
14
+
15
+ const inputPasswordToggleIonicCss = () => `:host ion-button{--color:var(--token-primitives-neutral-800, #626262);--margin-end:calc(-1 * var(--padding-end));--padding-end:inherit;--icon-size:var(--token-font-size-400, 1rem);-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:var(--margin-end);margin-inline-end:var(--margin-end);margin-top:0;margin-bottom:0;width:var(--size);height:var(--size)}:host ion-button ion-icon{font-size:var(--icon-size)}`;
16
+
17
+ const iosInputPasswordToggleNativeCss = () => ``;
18
+
19
+ const mdInputPasswordToggleNativeCss = () => ``;
14
20
 
15
21
  const InputPasswordToggle = class {
16
22
  constructor(hostRef) {
@@ -57,23 +63,54 @@ const InputPasswordToggle = class {
57
63
  disconnectedCallback() {
58
64
  this.inputElRef = null;
59
65
  }
66
+ get inputPasswordHideIcon() {
67
+ // Return the icon if it is explicitly set
68
+ if (this.hideIcon != null) {
69
+ return this.hideIcon;
70
+ }
71
+ // Determine the theme and map to default icons
72
+ const theme = ionicGlobal.getIonTheme(this);
73
+ const defaultIcons = {
74
+ ios: index$1.eyeOff,
75
+ ionic: eyeSlashSvg,
76
+ md: index$1.eyeOff,
77
+ };
78
+ // Get the default icon based on the theme, falling back to 'md' icon if necessary
79
+ const defaultIcon = defaultIcons[theme] || defaultIcons.md;
80
+ // Return the configured input password hide icon or the default icon
81
+ return index.config.get('inputPasswordHideIcon', defaultIcon);
82
+ }
83
+ get inputPasswordShowIcon() {
84
+ // Return the icon if it is explicitly set
85
+ if (this.showIcon != null) {
86
+ return this.showIcon;
87
+ }
88
+ // Determine the theme and map to default icons
89
+ const theme = ionicGlobal.getIonTheme(this);
90
+ const defaultIcons = {
91
+ ios: index$1.eye,
92
+ ionic: eyeSvg,
93
+ md: index$1.eye,
94
+ };
95
+ // Get the default icon based on the theme, falling back to 'md' icon if necessary
96
+ const defaultIcon = defaultIcons[theme] || defaultIcons.md;
97
+ // Return the configured input password show icon or the default icon
98
+ return index.config.get('inputPasswordShowIcon', defaultIcon);
99
+ }
60
100
  render() {
61
- var _a, _b;
62
- const { color, type } = this;
101
+ const { color, inputPasswordHideIcon, inputPasswordShowIcon, type } = this;
63
102
  const mode = ionicGlobal.getIonMode(this);
64
- const showPasswordIcon = (_a = this.showIcon) !== null && _a !== void 0 ? _a : index$1.eye;
65
- const hidePasswordIcon = (_b = this.hideIcon) !== null && _b !== void 0 ? _b : index$1.eyeOff;
66
103
  const isPasswordVisible = type === 'text';
67
- return (index.h(index.Host, { key: '91bc55664d496fe457518bd112865dd7811d0c17', class: theme.createColorClasses(color, {
104
+ return (index.h(index.Host, { key: 'f11e3bf4d3255e003aec504e6dd3ee1e0caaf767', class: theme.createColorClasses(color, {
68
105
  [mode]: true,
69
- }) }, index.h("ion-button", { key: '6344d6838f5cdcba54c6bf4b592f036092044de0', mode: mode, color: color, fill: "clear", shape: "round", "aria-label": isPasswordVisible ? 'Hide password' : 'Show password', "aria-pressed": isPasswordVisible ? 'true' : 'false', type: "button", onPointerDown: (ev) => {
106
+ }) }, index.h("ion-button", { key: '5bba43f7755857fd9347612bb906c389b60386b4', mode: mode, color: color, fill: "clear", shape: "round", "aria-label": isPasswordVisible ? 'Hide password' : 'Show password', "aria-pressed": isPasswordVisible ? 'true' : 'false', type: "button", onPointerDown: (ev) => {
70
107
  /**
71
108
  * This prevents mobile browsers from
72
109
  * blurring the input when the password toggle
73
110
  * button is activated.
74
111
  */
75
112
  ev.preventDefault();
76
- }, onClick: this.togglePasswordVisibility }, index.h("ion-icon", { key: 'a2bd9197c2635bf8cb155ff25ce022e7d7dc6d00', slot: "icon-only", "aria-hidden": "true", icon: isPasswordVisible ? hidePasswordIcon : showPasswordIcon }))));
113
+ }, onClick: this.togglePasswordVisibility }, index.h("ion-icon", { key: 'c0eb0e4e2f3e9553bfd519ff655064c9f62af406', slot: "icon-only", "aria-hidden": "true", icon: isPasswordVisible ? inputPasswordHideIcon : inputPasswordShowIcon }))));
77
114
  }
78
115
  get el() { return index.getElement(this); }
79
116
  static get watchers() { return {
@@ -83,8 +120,9 @@ const InputPasswordToggle = class {
83
120
  }; }
84
121
  };
85
122
  InputPasswordToggle.style = {
86
- ios: iosInputPasswordToggleCss(),
87
- md: mdInputPasswordToggleCss()
123
+ ionic: inputPasswordToggleIonicCss(),
124
+ ios: iosInputPasswordToggleNativeCss(),
125
+ md: mdInputPasswordToggleNativeCss()
88
126
  };
89
127
 
90
128
  exports.ion_input_password_toggle = InputPasswordToggle;