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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1106) hide show
  1. package/components/index.js +1 -1
  2. package/components/ion-accordion-group.js +1 -1
  3. package/components/ion-accordion.js +1 -1
  4. package/components/ion-action-sheet.js +1 -1
  5. package/components/ion-alert.js +1 -1
  6. package/components/ion-app.js +1 -1
  7. package/components/ion-avatar.js +1 -1
  8. package/components/ion-back-button.js +1 -1
  9. package/components/ion-backdrop.js +1 -1
  10. package/components/ion-badge.js +1 -1
  11. package/components/ion-breadcrumb.js +1 -1
  12. package/components/ion-breadcrumbs.js +1 -1
  13. package/components/ion-button.js +1 -1
  14. package/components/ion-buttons.js +1 -1
  15. package/components/ion-card-content.js +1 -1
  16. package/components/ion-card-header.js +1 -1
  17. package/components/ion-card-subtitle.js +1 -1
  18. package/components/ion-card-title.js +1 -1
  19. package/components/ion-card.js +1 -1
  20. package/components/ion-checkbox.js +1 -1
  21. package/components/ion-chip.js +1 -1
  22. package/components/ion-col.js +1 -1
  23. package/components/ion-content.js +1 -1
  24. package/components/ion-datetime-button.js +1 -1
  25. package/components/ion-datetime.js +1 -1
  26. package/components/ion-divider.d.ts +11 -0
  27. package/components/ion-divider.js +4 -0
  28. package/components/ion-fab-button.js +1 -1
  29. package/components/ion-fab-list.js +1 -1
  30. package/components/ion-fab.js +1 -1
  31. package/components/ion-footer.js +1 -1
  32. package/components/ion-gallery.d.ts +11 -0
  33. package/components/ion-gallery.js +4 -0
  34. package/components/ion-grid.js +1 -1
  35. package/components/ion-header.js +1 -1
  36. package/components/ion-icon.js +1 -1
  37. package/components/ion-img.js +1 -1
  38. package/components/ion-infinite-scroll-content.js +1 -1
  39. package/components/ion-infinite-scroll.js +1 -1
  40. package/components/ion-input-otp.js +1 -1
  41. package/components/ion-input-password-toggle.js +1 -1
  42. package/components/ion-input.js +1 -1
  43. package/components/ion-item-divider.js +1 -1
  44. package/components/ion-item-group.js +1 -1
  45. package/components/ion-item-option.js +1 -1
  46. package/components/ion-item-options.js +1 -1
  47. package/components/ion-item-sliding.js +1 -1
  48. package/components/ion-item.js +1 -1
  49. package/components/ion-label.js +1 -1
  50. package/components/ion-list-header.js +1 -1
  51. package/components/ion-list.js +1 -1
  52. package/components/ion-loading.js +1 -1
  53. package/components/ion-menu-button.js +1 -1
  54. package/components/ion-menu-toggle.js +1 -1
  55. package/components/ion-menu.js +1 -1
  56. package/components/ion-modal.js +1 -1
  57. package/components/ion-nav-link.js +1 -1
  58. package/components/ion-nav.js +1 -1
  59. package/components/ion-note.js +1 -1
  60. package/components/ion-picker-column-option.js +1 -1
  61. package/components/ion-picker-column.js +1 -1
  62. package/components/ion-picker-legacy-column.js +1 -1
  63. package/components/ion-picker-legacy.js +1 -1
  64. package/components/ion-picker.js +1 -1
  65. package/components/ion-popover.js +1 -1
  66. package/components/ion-progress-bar.js +1 -1
  67. package/components/ion-radio-group.js +1 -1
  68. package/components/ion-radio.js +1 -1
  69. package/components/ion-range.js +1 -1
  70. package/components/ion-refresher-content.js +1 -1
  71. package/components/ion-refresher.js +1 -1
  72. package/components/ion-reorder-group.js +1 -1
  73. package/components/ion-reorder.js +1 -1
  74. package/components/ion-ripple-effect.js +1 -1
  75. package/components/ion-route-redirect.js +1 -1
  76. package/components/ion-route.js +1 -1
  77. package/components/ion-router-link.js +1 -1
  78. package/components/ion-router-outlet.js +1 -1
  79. package/components/ion-router.js +1 -1
  80. package/components/ion-row.js +1 -1
  81. package/components/ion-searchbar.js +1 -1
  82. package/components/ion-segment-button.js +1 -1
  83. package/components/ion-segment-content.js +1 -1
  84. package/components/ion-segment-view.js +1 -1
  85. package/components/ion-segment.js +1 -1
  86. package/components/ion-select-modal.js +1 -1
  87. package/components/ion-select-option.js +1 -1
  88. package/components/ion-select-popover.js +1 -1
  89. package/components/ion-select.js +1 -1
  90. package/components/ion-skeleton-text.js +1 -1
  91. package/components/ion-spinner.js +1 -1
  92. package/components/ion-split-pane.js +1 -1
  93. package/components/ion-tab-bar.js +1 -1
  94. package/components/ion-tab-button.js +1 -1
  95. package/components/ion-tab.js +1 -1
  96. package/components/ion-tabs.js +1 -1
  97. package/components/ion-text.js +1 -1
  98. package/components/ion-textarea.js +1 -1
  99. package/components/ion-thumbnail.js +1 -1
  100. package/components/ion-title.js +1 -1
  101. package/components/ion-toast.js +1 -1
  102. package/components/ion-toggle.js +1 -1
  103. package/components/ion-toolbar.js +1 -1
  104. package/components/p-3Ni1Z654.js +4 -0
  105. package/components/p-7kL3tltU.js +4 -0
  106. package/components/p-B9MABkWm.js +4 -0
  107. package/components/p-BBu2n-9C.js +4 -0
  108. package/components/p-BDcohALy.js +4 -0
  109. package/components/p-BDqjX7Z_.js +4 -0
  110. package/components/p-BJzJdLry.js +4 -0
  111. package/components/p-BYSs-jZz.js +4 -0
  112. package/components/{p-CU1SSH8_.js → p-BZCB7f49.js} +1 -1
  113. package/components/p-B_MdONwD.js +4 -0
  114. package/components/p-BaPtaYEC.js +4 -0
  115. package/components/p-BcbmT6b3.js +4 -0
  116. package/components/p-Bg30AtDZ.js +4 -0
  117. package/components/p-BhkGOA7t.js +4 -0
  118. package/components/p-BjW8SOqw.js +4 -0
  119. package/components/p-Bk9hTY4h.js +4 -0
  120. package/components/p-BqDiJgC_.js +4 -0
  121. package/components/p-BsNpz2u3.js +4 -0
  122. package/components/p-BsSTz5ia.js +4 -0
  123. package/{dist/ionic/p-BxIcPWoV.js → components/p-Bt0d89x3.js} +1 -1
  124. package/components/p-BwQOIWD7.js +4 -0
  125. package/components/{p-CEmXdzGo.js → p-ByW0kK1F.js} +1 -1
  126. package/components/p-C75FIZBC.js +4 -0
  127. package/components/p-C8kBejTT.js +4 -0
  128. package/components/p-CBS0sBAa.js +4 -0
  129. package/components/{p-9VcRUwdB.js → p-CDgDBcU9.js} +1 -1
  130. package/components/p-CUAgUmQC.js +4 -0
  131. package/components/p-Cg-xpJhD.js +4 -0
  132. package/components/p-CgSn4J7d.js +4 -0
  133. package/components/p-CgZLVOCc.js +4 -0
  134. package/{dist/ionic/p-D13Eaw-8.js → components/p-Cllkut-B.js} +1 -1
  135. package/components/p-Cz4uz3Dy.js +4 -0
  136. package/components/p-CzC_ZSgb.js +4 -0
  137. package/components/p-D1t981Ih.js +4 -0
  138. package/components/p-D2mReIu8.js +4 -0
  139. package/components/p-D6g8ud1e.js +4 -0
  140. package/components/p-DDw-NYxz.js +4 -0
  141. package/components/p-DN_scBC7.js +4 -0
  142. package/components/p-DVcs-2q3.js +4 -0
  143. package/components/p-DXehWlOr.js +4 -0
  144. package/components/p-DaJxRxSQ.js +4 -0
  145. package/components/p-DhXUGFNH.js +4 -0
  146. package/components/p-Dhi5xtNS.js +4 -0
  147. package/components/p-Do7NMUwR.js +4 -0
  148. package/components/p-Dp2x0MpA.js +4 -0
  149. package/components/p-GElQZ38c.js +4 -0
  150. package/components/p-GtzfsjJP.js +4 -0
  151. package/components/p-LB-QPk3e.js +4 -0
  152. package/components/p-NVAi5HQQ.js +4 -0
  153. package/components/p-PzmQ86nh.js +4 -0
  154. package/components/p-Skz67GXZ.js +4 -0
  155. package/components/p-VVrXfwLZ.js +4 -0
  156. package/components/p-WdrzoonY.js +4 -0
  157. package/components/p-XegQjlzJ.js +4 -0
  158. package/components/p-fIOYmaqA.js +4 -0
  159. package/components/p-hpwmNJ2Q.js +4 -0
  160. package/components/p-kKYBfhbe.js +4 -0
  161. package/components/p-lGSe6-vg.js +4 -0
  162. package/{dist/ionic/p-BvFYtOdE.js → components/p-oF-CwZ0b.js} +1 -1
  163. package/components/p-pvh0bjpw.js +4 -0
  164. package/components/{p-cyNmxje6.js → p-re70ahxF.js} +1 -1
  165. package/components/p-sToA4Co7.js +4 -0
  166. package/components/p-vXpMhGrs.js +4 -0
  167. package/components/p-wCDzv5Q8.js +4 -0
  168. package/components/{p-YLXPWgVj.js → p-zWP0sUV_.js} +1 -1
  169. package/css/core.css +1 -1
  170. package/css/core.css.map +1 -1
  171. package/css/display.css +1 -1
  172. package/css/display.css.map +1 -1
  173. package/css/flex-utils.css +1 -1
  174. package/css/flex-utils.css.map +1 -1
  175. package/css/float-elements.css.map +1 -1
  176. package/css/global.bundle.css.map +1 -1
  177. package/css/ionic/bundle.ionic.css +1 -0
  178. package/css/ionic/bundle.ionic.css.map +1 -0
  179. package/css/ionic/core.ionic.css +1 -0
  180. package/css/ionic/core.ionic.css.map +1 -0
  181. package/css/ionic/global.bundle.ionic.css +1 -0
  182. package/css/ionic/global.bundle.ionic.css.map +1 -0
  183. package/css/ionic/ionic-swiper.ionic.css +1 -0
  184. package/css/ionic/ionic-swiper.ionic.css.map +1 -0
  185. package/css/ionic/link.ionic.css +1 -0
  186. package/css/ionic/link.ionic.css.map +1 -0
  187. package/css/ionic/structure.ionic.css +1 -0
  188. package/css/ionic/structure.ionic.css.map +1 -0
  189. package/css/ionic/typography.ionic.css +1 -0
  190. package/css/ionic/typography.ionic.css.map +1 -0
  191. package/css/ionic/utils.bundle.ionic.css +1 -0
  192. package/css/ionic/utils.bundle.ionic.css.map +1 -0
  193. package/css/ionic-swiper.css +1 -1
  194. package/css/ionic-swiper.css.map +1 -1
  195. package/css/ionic.bundle.css +1 -1
  196. package/css/ionic.bundle.css.map +1 -1
  197. package/css/normalize.css.map +1 -1
  198. package/css/padding.css.map +1 -1
  199. package/css/palettes/dark.always.css.map +1 -1
  200. package/css/palettes/dark.class.css.map +1 -1
  201. package/css/palettes/dark.system.css.map +1 -1
  202. package/css/palettes/high-contrast-dark.always.css.map +1 -1
  203. package/css/palettes/high-contrast-dark.class.css.map +1 -1
  204. package/css/palettes/high-contrast-dark.system.css.map +1 -1
  205. package/css/palettes/high-contrast.always.css.map +1 -1
  206. package/css/palettes/high-contrast.class.css.map +1 -1
  207. package/css/palettes/high-contrast.system.css.map +1 -1
  208. package/css/structure.css.map +1 -1
  209. package/css/text-alignment.css.map +1 -1
  210. package/css/text-transformation.css.map +1 -1
  211. package/css/typography.css.map +1 -1
  212. package/css/utils.bundle.css +1 -1
  213. package/css/utils.bundle.css.map +1 -1
  214. package/dist/cjs/{animation-Dg4yiuR2.js → animation-BZJ2wKuM.js} +3 -3
  215. package/dist/cjs/{app-globals-CLI8xCmk.js → app-globals-C-d5fQ35.js} +1 -1
  216. package/dist/cjs/{button-active-FscMI17-.js → button-active-B_20Nxkv.js} +2 -2
  217. package/dist/cjs/{capacitor-DmA66EwP.js → capacitor-CXqhdZym.js} +3 -3
  218. package/dist/cjs/caret-down-vtVgfXIs.js +8 -0
  219. package/dist/cjs/caret-left-CxZXLRv5.js +8 -0
  220. package/dist/cjs/caret-right-CRCgv98E.js +8 -0
  221. package/dist/cjs/{config-BukYi_pW.js → config-BiqQSDrb.js} +60 -7
  222. package/dist/cjs/{data-BYlBjkMU.js → data-DuOuKG7I.js} +6 -6
  223. package/dist/cjs/{focus-visible-CCvKiLh3.js → focus-visible-BIj-I3-C.js} +24 -0
  224. package/dist/cjs/{framework-delegate-CRgp8o_p.js → framework-delegate-Dx9FrqAC.js} +4 -2
  225. package/dist/cjs/{haptic-ClPPQ_PS.js → haptic-CQJGW58i.js} +1 -1
  226. package/dist/cjs/{helpers-CxTYJdbT.js → helpers-DJYxKN5U.js} +57 -4
  227. package/dist/cjs/{index-MbaBbWXk.js → index-BJrpF9T3.js} +2 -2
  228. package/dist/cjs/{index-CFUwM5x_.js → index-BekUBS8C.js} +15 -15
  229. package/dist/cjs/{index-DqmRDbxg.js → index-CgAbCW6L.js} +2 -0
  230. package/dist/cjs/{index-YcSftOMz.js → index-CwxYd6UD.js} +9 -8
  231. package/dist/cjs/{index-CqT-2gKy.js → index-CzcLEdQ5.js} +41 -4
  232. package/dist/cjs/{index-C845Ti6K.js → index-DSNlrgfO.js} +4 -4
  233. package/dist/cjs/index.cjs.js +13 -14
  234. package/dist/cjs/{input-shims-CPL2J8F-.js → input-shims-VyZciSxi.js} +18 -17
  235. package/dist/cjs/{input.utils-DmeJ8dmo.js → input.utils-Ct5KzpYv.js} +5 -5
  236. package/dist/cjs/ion-accordion_2.cjs.entry.js +61 -29
  237. package/dist/cjs/ion-action-sheet.cjs.entry.js +40 -22
  238. package/dist/cjs/ion-alert.cjs.entry.js +76 -40
  239. package/dist/cjs/ion-app_8.cjs.entry.js +292 -157
  240. package/dist/cjs/ion-avatar_3.cjs.entry.js +125 -13
  241. package/dist/cjs/ion-back-button.cjs.entry.js +31 -22
  242. package/dist/cjs/ion-backdrop.cjs.entry.js +10 -7
  243. package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +54 -18
  244. package/dist/cjs/ion-button_2.cjs.entry.js +59 -22
  245. package/dist/cjs/ion-card_5.cjs.entry.js +55 -33
  246. package/dist/cjs/ion-checkbox.cjs.entry.js +34 -16
  247. package/dist/cjs/ion-chip.cjs.entry.js +50 -9
  248. package/dist/cjs/ion-col_3.cjs.entry.js +56 -57
  249. package/dist/cjs/ion-datetime-button.cjs.entry.js +13 -9
  250. package/dist/cjs/ion-datetime_3.cjs.entry.js +116 -41
  251. package/dist/cjs/ion-divider.cjs.entry.js +51 -0
  252. package/dist/cjs/ion-fab_3.cjs.entry.js +44 -28
  253. package/dist/cjs/ion-gallery.cjs.entry.js +510 -0
  254. package/dist/cjs/ion-img.cjs.entry.js +8 -4
  255. package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +91 -16
  256. package/dist/cjs/ion-input-otp.cjs.entry.js +74 -9
  257. package/dist/cjs/ion-input-password-toggle.cjs.entry.js +53 -15
  258. package/dist/cjs/ion-input.cjs.entry.js +124 -34
  259. package/dist/cjs/ion-item-option_3.cjs.entry.js +467 -52
  260. package/dist/cjs/ion-item_8.cjs.entry.js +115 -49
  261. package/dist/cjs/ion-loading.cjs.entry.js +20 -18
  262. package/dist/cjs/ion-menu_3.cjs.entry.js +47 -29
  263. package/dist/cjs/ion-modal.cjs.entry.js +262 -138
  264. package/dist/cjs/ion-nav_2.cjs.entry.js +14 -11
  265. package/dist/cjs/ion-picker-column-option.cjs.entry.js +12 -8
  266. package/dist/cjs/ion-picker-column.cjs.entry.js +14 -14
  267. package/dist/cjs/ion-picker.cjs.entry.js +10 -6
  268. package/dist/cjs/ion-popover.cjs.entry.js +21 -19
  269. package/dist/cjs/ion-progress-bar.cjs.entry.js +27 -9
  270. package/dist/cjs/ion-radio_2.cjs.entry.js +35 -17
  271. package/dist/cjs/ion-range.cjs.entry.js +20 -13
  272. package/dist/cjs/ion-refresher_2.cjs.entry.js +39 -21
  273. package/dist/cjs/ion-reorder_2.cjs.entry.js +38 -14
  274. package/dist/cjs/ion-ripple-effect.cjs.entry.js +15 -7
  275. package/dist/cjs/ion-route_4.cjs.entry.js +10 -9
  276. package/dist/cjs/ion-searchbar.cjs.entry.js +137 -24
  277. package/dist/cjs/ion-segment-content.cjs.entry.js +2 -2
  278. package/dist/cjs/ion-segment-view.cjs.entry.js +13 -3
  279. package/dist/cjs/ion-segment_2.cjs.entry.js +23 -16
  280. package/dist/cjs/ion-select-modal.cjs.entry.js +119 -40
  281. package/dist/cjs/ion-select_3.cjs.entry.js +500 -84
  282. package/dist/cjs/ion-spinner.cjs.entry.js +30 -8
  283. package/dist/cjs/ion-split-pane.cjs.entry.js +13 -9
  284. package/dist/cjs/ion-tab-bar_2.cjs.entry.js +147 -23
  285. package/dist/cjs/ion-tab_2.cjs.entry.js +8 -7
  286. package/dist/cjs/ion-text.cjs.entry.js +7 -7
  287. package/dist/cjs/ion-textarea.cjs.entry.js +137 -23
  288. package/dist/cjs/ion-toast.cjs.entry.js +69 -46
  289. package/dist/cjs/ion-toggle.cjs.entry.js +82 -25
  290. package/dist/cjs/ionic-global-BW5tRzrz.js +519 -0
  291. package/dist/cjs/ionic.cjs.js +4 -4
  292. package/dist/cjs/{ios.transition-trBiC95R.js → ios.transition-CyNNpj1i.js} +7 -5
  293. package/dist/cjs/{keyboard-hHzlEQpk.js → keyboard-CA6RtoWx.js} +4 -3
  294. package/dist/cjs/{keyboard-UuAS4D_9.js → keyboard-VLGMzWBE.js} +1 -1
  295. package/dist/cjs/{keyboard-controller-GXBiBRKS.js → keyboard-controller-CCTvHp9l.js} +11 -9
  296. package/dist/cjs/list-a-7GSA6K.js +8 -0
  297. package/dist/cjs/loader.cjs.js +4 -4
  298. package/dist/cjs/{md.transition-CUQECuvD.js → md.transition-BEfrfWKW.js} +6 -5
  299. package/dist/cjs/{notch-controller-sD-lTpdc.js → notch-controller-BTZCPOsd.js} +4 -4
  300. package/dist/cjs/overlay-control-label-t9ZFhCtr.js +51 -0
  301. package/dist/cjs/{overlays-C2jiBSNQ.js → overlays-BuMIwR8B.js} +110 -16
  302. package/dist/cjs/select-option-render-C72N7OsO.js +111 -0
  303. package/dist/cjs/{status-tap-CCJk5VgT.js → status-tap-CTY2dMsZ.js} +4 -3
  304. package/dist/cjs/{swipe-back-BGhTQ1CU.js → swipe-back-jJFi5KCB.js} +3 -2
  305. package/dist/cjs/{theme-CeDs6Hcv.js → theme-IlOsGAz7.js} +25 -1
  306. package/dist/cjs/validity-QmuwEptc.js +51 -0
  307. package/dist/cjs/x-BTF99yFH.js +8 -0
  308. package/dist/collection/collection-manifest.json +7 -0
  309. package/dist/collection/components/accordion/accordion.ionic.css +201 -0
  310. package/dist/collection/components/accordion/accordion.ios.css +73 -58
  311. package/dist/collection/components/accordion/accordion.js +41 -27
  312. package/dist/collection/components/accordion/accordion.md.css +67 -59
  313. package/dist/collection/components/accordion-group/accordion-group.ionic.css +93 -0
  314. package/dist/collection/components/accordion-group/accordion-group.ios.css +16 -4
  315. package/dist/collection/components/accordion-group/accordion-group.js +44 -8
  316. package/dist/collection/components/accordion-group/accordion-group.md.css +22 -4
  317. package/dist/collection/components/action-sheet/action-sheet.ionic.css +439 -0
  318. package/dist/collection/components/action-sheet/action-sheet.ios.css +155 -11
  319. package/dist/collection/components/action-sheet/action-sheet.js +32 -13
  320. package/dist/collection/components/action-sheet/action-sheet.md.css +155 -10
  321. package/dist/collection/components/alert/alert.ionic.css +726 -0
  322. package/dist/collection/components/alert/alert.ios.css +219 -19
  323. package/dist/collection/components/alert/alert.js +67 -30
  324. package/dist/collection/components/alert/alert.md.css +229 -15
  325. package/dist/collection/components/app/app.js +15 -83
  326. package/dist/collection/components/avatar/avatar.ionic.css +391 -0
  327. package/dist/collection/components/avatar/avatar.ios.css +7 -33
  328. package/dist/collection/components/avatar/avatar.js +120 -4
  329. package/dist/collection/components/avatar/avatar.md.css +51 -0
  330. package/dist/collection/components/back-button/back-button.ios.css +60 -48
  331. package/dist/collection/components/back-button/back-button.js +27 -19
  332. package/dist/collection/components/back-button/back-button.md.css +60 -48
  333. package/dist/collection/components/backdrop/backdrop.ionic.css +109 -0
  334. package/dist/collection/components/backdrop/backdrop.ios.css +56 -19
  335. package/dist/collection/components/backdrop/backdrop.js +12 -6
  336. package/dist/collection/components/backdrop/backdrop.md.css +56 -19
  337. package/dist/collection/components/badge/badge.ionic.css +275 -0
  338. package/dist/collection/components/badge/badge.ios.css +139 -12
  339. package/dist/collection/components/badge/badge.js +145 -9
  340. package/dist/collection/components/badge/badge.md.css +123 -12
  341. package/dist/collection/components/breadcrumb/breadcrumb.ios.css +20 -8
  342. package/dist/collection/components/breadcrumb/breadcrumb.js +43 -11
  343. package/dist/collection/components/breadcrumb/breadcrumb.md.css +20 -8
  344. package/dist/collection/components/breadcrumbs/breadcrumbs.ios.css +6 -0
  345. package/dist/collection/components/breadcrumbs/breadcrumbs.js +11 -9
  346. package/dist/collection/components/breadcrumbs/breadcrumbs.md.css +6 -0
  347. package/dist/collection/components/button/button.ionic.css +646 -0
  348. package/dist/collection/components/button/button.ios.css +154 -46
  349. package/dist/collection/components/button/button.js +63 -27
  350. package/dist/collection/components/button/button.md.css +150 -50
  351. package/dist/collection/components/buttons/buttons.ionic.css +97 -0
  352. package/dist/collection/components/buttons/buttons.ios.css +59 -7
  353. package/dist/collection/components/buttons/buttons.js +15 -9
  354. package/dist/collection/components/buttons/buttons.md.css +55 -3
  355. package/dist/collection/components/card/card.ionic.css +144 -0
  356. package/dist/collection/components/card/card.ios.css +65 -14
  357. package/dist/collection/components/card/card.js +41 -10
  358. package/dist/collection/components/card/card.md.css +65 -14
  359. package/dist/collection/components/card-content/card-content.ionic.css +89 -0
  360. package/dist/collection/components/card-content/card-content.ios.css +20 -35
  361. package/dist/collection/components/card-content/card-content.js +12 -10
  362. package/dist/collection/components/card-content/card-content.md.css +20 -35
  363. package/dist/collection/components/card-header/card-header.ionic.css +85 -0
  364. package/dist/collection/components/card-header/card-header.ios.css +27 -15
  365. package/dist/collection/components/card-header/card-header.js +13 -10
  366. package/dist/collection/components/card-header/card-header.md.css +27 -15
  367. package/dist/collection/components/card-subtitle/card-subtitle.ionic.css +144 -0
  368. package/dist/collection/components/card-subtitle/card-subtitle.ios.css +12 -0
  369. package/dist/collection/components/card-subtitle/card-subtitle.js +11 -8
  370. package/dist/collection/components/card-subtitle/card-subtitle.md.css +12 -0
  371. package/dist/collection/components/card-title/card-title.ios.css +73 -0
  372. package/dist/collection/components/card-title/card-title.js +11 -8
  373. package/dist/collection/components/card-title/card-title.md.css +73 -0
  374. package/dist/collection/components/checkbox/checkbox.ionic.css +539 -0
  375. package/dist/collection/components/checkbox/checkbox.ios.css +161 -101
  376. package/dist/collection/components/checkbox/checkbox.js +70 -14
  377. package/dist/collection/components/checkbox/checkbox.md.css +162 -102
  378. package/dist/collection/components/chip/chip.ionic.css +217 -0
  379. package/dist/collection/components/chip/chip.ios.css +67 -14
  380. package/dist/collection/components/chip/chip.js +108 -8
  381. package/dist/collection/components/chip/chip.md.css +67 -14
  382. package/dist/collection/components/col/col.css +192 -4
  383. package/dist/collection/components/col/col.js +211 -61
  384. package/dist/collection/components/content/content.css +8 -2
  385. package/dist/collection/components/content/content.js +16 -11
  386. package/dist/collection/components/datetime/datetime.ionic.css +703 -0
  387. package/dist/collection/components/datetime/datetime.ios.css +302 -106
  388. package/dist/collection/components/datetime/datetime.js +98 -20
  389. package/dist/collection/components/datetime/datetime.md.css +293 -96
  390. package/dist/collection/components/datetime/utils/data.js +5 -5
  391. package/dist/collection/components/datetime-button/datetime-button.ios.css +6 -0
  392. package/dist/collection/components/datetime-button/datetime-button.js +11 -8
  393. package/dist/collection/components/datetime-button/datetime-button.md.css +6 -0
  394. package/dist/collection/components/divider/divider.ionic.css +148 -0
  395. package/dist/collection/components/divider/divider.ios.css +87 -0
  396. package/dist/collection/components/divider/divider.js +94 -0
  397. package/dist/collection/components/divider/divider.md.css +87 -0
  398. package/dist/collection/components/fab/fab.css +25 -1
  399. package/dist/collection/components/fab/fab.js +9 -5
  400. package/dist/collection/components/fab-button/fab-button.ios.css +18 -6
  401. package/dist/collection/components/fab-button/fab-button.js +36 -21
  402. package/dist/collection/components/fab-button/fab-button.md.css +20 -8
  403. package/dist/collection/components/fab-list/fab-list.css +12 -0
  404. package/dist/collection/components/fab-list/fab-list.js +9 -5
  405. package/dist/collection/components/footer/footer.ios.css +14 -2
  406. package/dist/collection/components/footer/footer.js +21 -16
  407. package/dist/collection/components/footer/footer.md.css +12 -0
  408. package/dist/collection/components/gallery/gallery-constants.js +12 -0
  409. package/dist/collection/components/gallery/gallery-interface.js +1 -0
  410. package/dist/collection/components/gallery/gallery.css +100 -0
  411. package/dist/collection/components/gallery/gallery.js +595 -0
  412. package/dist/collection/components/gallery/test/utils.js +100 -0
  413. package/dist/collection/components/grid/grid.css +12 -0
  414. package/dist/collection/components/grid/grid.js +9 -5
  415. package/dist/collection/components/header/header.ionic.css +97 -0
  416. package/dist/collection/components/header/header.ios.css +25 -10
  417. package/dist/collection/components/header/header.js +50 -19
  418. package/dist/collection/components/header/header.md.css +23 -8
  419. package/dist/collection/components/header/header.utils.js +5 -5
  420. package/dist/collection/components/img/img.js +8 -2
  421. package/dist/collection/components/infinite-scroll/infinite-scroll.js +100 -5
  422. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.ios.css +12 -0
  423. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +16 -10
  424. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.md.css +12 -0
  425. package/dist/collection/components/input/input.ionic.css +889 -0
  426. package/dist/collection/components/input/input.ios.css +223 -135
  427. package/dist/collection/components/input/input.js +148 -37
  428. package/dist/collection/components/input/input.md.css +193 -207
  429. package/dist/collection/components/input-otp/input-otp.ionic.css +371 -0
  430. package/dist/collection/components/input-otp/input-otp.ios.css +105 -60
  431. package/dist/collection/components/input-otp/input-otp.js +73 -6
  432. package/dist/collection/components/input-otp/input-otp.md.css +105 -60
  433. package/dist/collection/components/input-password-toggle/input-password-toggle.ionic.css +78 -0
  434. package/dist/collection/components/input-password-toggle/input-password-toggle.js +48 -12
  435. package/dist/collection/components/input-password-toggle/input-password-toggle.native.css +61 -0
  436. package/dist/collection/components/item/item.ionic.css +496 -0
  437. package/dist/collection/components/item/item.ios.css +109 -69
  438. package/dist/collection/components/item/item.js +50 -20
  439. package/dist/collection/components/item/item.md.css +120 -68
  440. package/dist/collection/components/item-divider/item-divider.ios.css +18 -0
  441. package/dist/collection/components/item-divider/item-divider.js +11 -8
  442. package/dist/collection/components/item-divider/item-divider.md.css +18 -0
  443. package/dist/collection/components/item-group/item-group.ios.css +12 -0
  444. package/dist/collection/components/item-group/item-group.js +13 -7
  445. package/dist/collection/components/item-group/item-group.md.css +12 -0
  446. package/dist/collection/components/item-option/item-option.ionic.css +278 -0
  447. package/dist/collection/components/item-option/item-option.ios.css +136 -29
  448. package/dist/collection/components/item-option/item-option.js +73 -9
  449. package/dist/collection/components/item-option/item-option.md.css +136 -29
  450. package/dist/collection/components/item-options/item-options.ionic.css +221 -0
  451. package/dist/collection/components/item-options/item-options.ios.css +77 -34
  452. package/dist/collection/components/item-options/item-options.js +13 -7
  453. package/dist/collection/components/item-options/item-options.md.css +77 -34
  454. package/dist/collection/components/item-sliding/item-sliding.ionic.css +211 -0
  455. package/dist/collection/components/item-sliding/item-sliding.js +421 -35
  456. package/dist/collection/components/item-sliding/{item-sliding.css → item-sliding.native.css} +84 -9
  457. package/dist/collection/components/item-sliding/test/test.utils.js +13 -0
  458. package/dist/collection/components/label/label.ios.css +18 -0
  459. package/dist/collection/components/label/label.js +11 -8
  460. package/dist/collection/components/label/label.md.css +18 -0
  461. package/dist/collection/components/list/list.ionic.css +212 -0
  462. package/dist/collection/components/list/list.ios.css +54 -14
  463. package/dist/collection/components/list/list.js +48 -9
  464. package/dist/collection/components/list/list.md.css +56 -16
  465. package/dist/collection/components/list-header/list-header.ionic.css +190 -0
  466. package/dist/collection/components/list-header/list-header.ios.css +82 -38
  467. package/dist/collection/components/list-header/list-header.js +11 -8
  468. package/dist/collection/components/list-header/list-header.md.css +82 -38
  469. package/dist/collection/components/loading/loading.ios.css +13 -1
  470. package/dist/collection/components/loading/loading.js +14 -11
  471. package/dist/collection/components/loading/loading.md.css +13 -1
  472. package/dist/collection/components/menu/menu.ios.css +15 -3
  473. package/dist/collection/components/menu/menu.js +12 -7
  474. package/dist/collection/components/menu/menu.md.css +15 -3
  475. package/dist/collection/components/menu-button/menu-button.ionic.css +236 -0
  476. package/dist/collection/components/menu-button/menu-button.ios.css +48 -14
  477. package/dist/collection/components/menu-button/menu-button.js +26 -10
  478. package/dist/collection/components/menu-button/menu-button.md.css +49 -15
  479. package/dist/collection/components/menu-toggle/menu-toggle.js +8 -5
  480. package/dist/collection/components/modal/animations/ionic.enter.js +40 -0
  481. package/dist/collection/components/modal/animations/ionic.leave.js +28 -0
  482. package/dist/collection/components/modal/animations/sheet.js +8 -2
  483. package/dist/collection/components/modal/gestures/sheet.js +76 -10
  484. package/dist/collection/components/modal/modal.ionic.css +247 -0
  485. package/dist/collection/components/modal/modal.ios.css +178 -70
  486. package/dist/collection/components/modal/modal.js +50 -12
  487. package/dist/collection/components/modal/modal.md.css +178 -70
  488. package/dist/collection/components/nav/nav.css +7 -1
  489. package/dist/collection/components/nav/nav.js +11 -5
  490. package/dist/collection/components/nav-link/nav-link.js +5 -1
  491. package/dist/collection/components/note/note.ios.css +12 -0
  492. package/dist/collection/components/note/note.js +11 -8
  493. package/dist/collection/components/note/note.md.css +12 -0
  494. package/dist/collection/components/picker/picker.ios.css +15 -3
  495. package/dist/collection/components/picker/picker.js +8 -5
  496. package/dist/collection/components/picker/picker.md.css +15 -3
  497. package/dist/collection/components/picker-column/picker-column.css +9 -2
  498. package/dist/collection/components/picker-column/picker-column.js +8 -7
  499. package/dist/collection/components/picker-column-option/picker-column-option.ios.css +6 -0
  500. package/dist/collection/components/picker-column-option/picker-column-option.js +13 -7
  501. package/dist/collection/components/picker-column-option/picker-column-option.md.css +6 -0
  502. package/dist/collection/components/picker-legacy/picker.ios.css +13 -1
  503. package/dist/collection/components/picker-legacy/picker.js +7 -6
  504. package/dist/collection/components/picker-legacy/picker.md.css +13 -1
  505. package/dist/collection/components/picker-legacy-column/picker-column.ios.css +12 -0
  506. package/dist/collection/components/picker-legacy-column/picker-column.js +4 -4
  507. package/dist/collection/components/picker-legacy-column/picker-column.md.css +12 -0
  508. package/dist/collection/components/popover/popover.ionic.css +290 -0
  509. package/dist/collection/components/popover/popover.ios.css +29 -1
  510. package/dist/collection/components/popover/popover.js +18 -15
  511. package/dist/collection/components/popover/popover.md.css +29 -1
  512. package/dist/collection/components/progress-bar/progress-bar.ionic.css +287 -0
  513. package/dist/collection/components/progress-bar/progress-bar.ios.css +48 -17
  514. package/dist/collection/components/progress-bar/progress-bar.js +43 -7
  515. package/dist/collection/components/progress-bar/progress-bar.md.css +48 -17
  516. package/dist/collection/components/radio/radio.ionic.css +422 -0
  517. package/dist/collection/components/radio/radio.ios.css +134 -91
  518. package/dist/collection/components/radio/radio.js +14 -9
  519. package/dist/collection/components/radio/radio.md.css +134 -91
  520. package/dist/collection/components/radio-group/radio-group.ionic.css +119 -0
  521. package/dist/collection/components/radio-group/radio-group.ios.css +43 -19
  522. package/dist/collection/components/radio-group/radio-group.js +48 -7
  523. package/dist/collection/components/radio-group/radio-group.md.css +43 -19
  524. package/dist/collection/components/range/range.ionic.css +567 -0
  525. package/dist/collection/components/range/range.ios.css +128 -85
  526. package/dist/collection/components/range/range.js +16 -10
  527. package/dist/collection/components/range/range.md.css +128 -85
  528. package/dist/collection/components/refresher/refresher.ios.css +14 -1
  529. package/dist/collection/components/refresher/refresher.js +11 -8
  530. package/dist/collection/components/refresher/refresher.md.css +15 -2
  531. package/dist/collection/components/refresher-content/refresher-content.js +28 -7
  532. package/dist/collection/components/reorder/reorder.ios.css +6 -0
  533. package/dist/collection/components/reorder/reorder.js +33 -6
  534. package/dist/collection/components/reorder/reorder.md.css +6 -0
  535. package/dist/collection/components/reorder-group/reorder-group.css +6 -0
  536. package/dist/collection/components/reorder-group/reorder-group.js +8 -4
  537. package/dist/collection/components/ripple-effect/{ripple-effect.css → ripple-effect.common.css} +7 -1
  538. package/dist/collection/components/ripple-effect/ripple-effect.ionic.css +215 -0
  539. package/dist/collection/components/ripple-effect/ripple-effect.js +14 -6
  540. package/dist/collection/components/route/route.js +4 -0
  541. package/dist/collection/components/router/router.js +4 -0
  542. package/dist/collection/components/router-link/router-link.css +8 -2
  543. package/dist/collection/components/router-link/router-link.js +9 -5
  544. package/dist/collection/components/router-outlet/router-outlet.css +7 -1
  545. package/dist/collection/components/router-outlet/router-outlet.js +6 -3
  546. package/dist/collection/components/row/row.css +16 -0
  547. package/dist/collection/components/row/row.js +9 -2
  548. package/dist/collection/components/searchbar/searchbar.ionic.css +626 -0
  549. package/dist/collection/components/searchbar/searchbar.ios.css +56 -18
  550. package/dist/collection/components/searchbar/searchbar.js +180 -33
  551. package/dist/collection/components/searchbar/searchbar.md.css +56 -18
  552. package/dist/collection/components/segment/segment.ionic.css +115 -0
  553. package/dist/collection/components/segment/segment.ios.css +45 -2
  554. package/dist/collection/components/segment/segment.js +11 -8
  555. package/dist/collection/components/segment/segment.md.css +45 -2
  556. package/dist/collection/components/segment-button/segment-button.ionic.css +353 -0
  557. package/dist/collection/components/segment-button/segment-button.ios.css +146 -105
  558. package/dist/collection/components/segment-button/segment-button.js +11 -8
  559. package/dist/collection/components/segment-button/segment-button.md.css +148 -107
  560. package/dist/collection/components/segment-content/segment-content.js +1 -1
  561. package/dist/collection/components/segment-view/segment-view.ios.css +6 -0
  562. package/dist/collection/components/segment-view/segment-view.js +13 -4
  563. package/dist/collection/components/segment-view/segment-view.md.css +6 -0
  564. package/dist/collection/components/select/select.ionic.css +810 -0
  565. package/dist/collection/components/select/select.ios.css +348 -176
  566. package/dist/collection/components/select/select.js +460 -66
  567. package/dist/collection/components/select/select.md.css +364 -178
  568. package/dist/collection/components/select-modal/select-modal.ionic.css +221 -0
  569. package/dist/collection/components/select-modal/select-modal.ios.css +156 -0
  570. package/dist/collection/components/select-modal/select-modal.js +132 -32
  571. package/dist/collection/components/select-modal/select-modal.md.css +139 -0
  572. package/dist/collection/components/select-option/select-option.js +70 -2
  573. package/dist/collection/components/select-popover/select-popover.ionic.css +220 -0
  574. package/dist/collection/components/select-popover/select-popover.ios.css +117 -23
  575. package/dist/collection/components/select-popover/select-popover.js +94 -31
  576. package/dist/collection/components/select-popover/select-popover.md.css +117 -22
  577. package/dist/collection/components/skeleton-text/skeleton-text.css +6 -0
  578. package/dist/collection/components/skeleton-text/skeleton-text.js +9 -5
  579. package/dist/collection/components/spinner/{spinner.css → spinner.ionic.css} +78 -10
  580. package/dist/collection/components/spinner/spinner.js +47 -6
  581. package/dist/collection/components/spinner/spinner.native.css +199 -0
  582. package/dist/collection/components/split-pane/split-pane.ios.css +20 -2
  583. package/dist/collection/components/split-pane/split-pane.js +15 -8
  584. package/dist/collection/components/split-pane/split-pane.md.css +20 -2
  585. package/dist/collection/components/tab/tab.js +6 -2
  586. package/dist/collection/components/tab-bar/tab-bar.ionic.css +227 -0
  587. package/dist/collection/components/tab-bar/tab-bar.ios.css +71 -43
  588. package/dist/collection/components/tab-bar/tab-bar.js +171 -13
  589. package/dist/collection/components/tab-bar/tab-bar.md.css +71 -43
  590. package/dist/collection/components/tab-button/tab-button.ionic.css +348 -0
  591. package/dist/collection/components/tab-button/tab-button.ios.css +171 -95
  592. package/dist/collection/components/tab-button/tab-button.js +54 -9
  593. package/dist/collection/components/tab-button/tab-button.md.css +137 -93
  594. package/dist/collection/components/tabs/tabs.css +7 -1
  595. package/dist/collection/components/tabs/tabs.js +4 -1
  596. package/dist/collection/components/text/text.css +6 -0
  597. package/dist/collection/components/text/text.js +7 -6
  598. package/dist/collection/components/textarea/textarea.ionic.css +898 -0
  599. package/dist/collection/components/textarea/textarea.ios.css +298 -158
  600. package/dist/collection/components/textarea/textarea.js +162 -24
  601. package/dist/collection/components/textarea/textarea.md.css +312 -159
  602. package/dist/collection/components/thumbnail/thumbnail.css +6 -0
  603. package/dist/collection/components/thumbnail/thumbnail.js +9 -2
  604. package/dist/collection/components/title/title.ionic.css +127 -0
  605. package/dist/collection/components/title/title.ios.css +32 -4
  606. package/dist/collection/components/title/title.js +13 -7
  607. package/dist/collection/components/title/title.md.css +32 -4
  608. package/dist/collection/components/toast/animations/utils.js +1 -1
  609. package/dist/collection/components/toast/toast.ionic.css +394 -0
  610. package/dist/collection/components/toast/toast.ios.css +84 -45
  611. package/dist/collection/components/toast/toast.js +76 -13
  612. package/dist/collection/components/toast/toast.md.css +84 -45
  613. package/dist/collection/components/toggle/toggle.ionic.css +508 -0
  614. package/dist/collection/components/toggle/toggle.ios.css +247 -131
  615. package/dist/collection/components/toggle/toggle.js +73 -18
  616. package/dist/collection/components/toggle/toggle.md.css +244 -131
  617. package/dist/collection/components/toolbar/test/image.svg +1 -0
  618. package/dist/collection/components/toolbar/toolbar.ionic.css +249 -0
  619. package/dist/collection/components/toolbar/toolbar.ios.css +90 -47
  620. package/dist/collection/components/toolbar/toolbar.js +218 -13
  621. package/dist/collection/components/toolbar/toolbar.md.css +90 -47
  622. package/dist/collection/global/ionic-global.js +241 -13
  623. package/dist/collection/utils/css-value-validation.js +25 -0
  624. package/dist/collection/utils/focus-trap.js +13 -2
  625. package/dist/collection/utils/focus-visible.js +22 -0
  626. package/dist/collection/utils/forms/validity.js +31 -0
  627. package/dist/collection/utils/framework-delegate.js +3 -1
  628. package/dist/collection/utils/hardware-back-button.js +15 -0
  629. package/dist/collection/utils/helpers.js +57 -3
  630. package/dist/collection/utils/keyboard/keyboard-controller.js +3 -1
  631. package/dist/collection/utils/media.js +1 -0
  632. package/dist/collection/utils/menu-controller/animations/overlay.js +3 -3
  633. package/dist/collection/utils/menu-controller/animations/push.js +2 -1
  634. package/dist/collection/utils/menu-controller/animations/reveal.js +2 -1
  635. package/dist/collection/utils/overlay-control-label.js +46 -0
  636. package/dist/collection/utils/overlays.js +91 -6
  637. package/dist/collection/utils/sanitization/index.js +58 -6
  638. package/dist/collection/utils/select-option-render.js +106 -0
  639. package/dist/collection/utils/test/playwright/drag-element.js +32 -9
  640. package/dist/collection/utils/test/playwright/generator.js +48 -23
  641. package/dist/collection/utils/test/playwright/page/utils/goto.js +14 -5
  642. package/dist/collection/utils/test/playwright/page/utils/set-content.js +26 -3
  643. package/dist/collection/utils/theme.js +25 -1
  644. package/dist/collection/utils/transition/ios.transition.js +1 -0
  645. package/dist/docs.json +8891 -283
  646. package/dist/esm/{animation-CnGMT4ji.js → animation-Cd1EA2ar.js} +2 -2
  647. package/dist/esm/{app-globals-DhZjtldk.js → app-globals-9x_U7ofY.js} +1 -1
  648. package/dist/esm/{button-active-BBx21brx.js → button-active-B016u5N-.js} +2 -2
  649. package/dist/esm/{capacitor-CFERIeaU.js → capacitor-13SFuT1K.js} +1 -1
  650. package/dist/esm/caret-down-D1t981Ih.js +6 -0
  651. package/dist/esm/caret-left-fIOYmaqA.js +6 -0
  652. package/dist/esm/caret-right-BYSs-jZz.js +6 -0
  653. package/dist/esm/{config-TO1rZH52.js → config-DLfuRiEz.js} +60 -8
  654. package/dist/esm/{data-B9iGR5YO.js → data-BNKYavC3.js} +6 -6
  655. package/dist/esm/{focus-visible-BmVRXR1y.js → focus-visible-vXpMhGrs.js} +23 -1
  656. package/dist/esm/{framework-delegate-CyxE1S_P.js → framework-delegate-CjVwn_KZ.js} +4 -2
  657. package/dist/esm/{haptic-DzAMWJuk.js → haptic-CbnKC3go.js} +1 -1
  658. package/dist/esm/{helpers-Tl8jw6S2.js → helpers-Do7zwvM1.js} +58 -5
  659. package/dist/esm/{index-B-hkiOUh.js → index-B2VWavcK.js} +4 -4
  660. package/dist/esm/{index-B2KwgBLx.js → index-BWMvrRiE.js} +11 -11
  661. package/dist/esm/{index-hW6eNZ3o.js → index-BmkLokUL.js} +2 -2
  662. package/dist/esm/{index-DV3sJJW8.js → index-D2tu5BUg.js} +2 -1
  663. package/dist/esm/{index-BtUdxPjv.js → index-D3WueHpT.js} +4 -3
  664. package/dist/esm/{index-IGIE5vDm.js → index-Omi_TcwW.js} +41 -4
  665. package/dist/esm/index.js +13 -14
  666. package/dist/esm/{input-shims-DbrgeeNb.js → input-shims-DU23z7Hg.js} +7 -6
  667. package/dist/esm/{input.utils-Bxa_DQ7-.js → input.utils-C64RbLd_.js} +3 -3
  668. package/dist/esm/ion-accordion_2.entry.js +61 -29
  669. package/dist/esm/ion-action-sheet.entry.js +40 -22
  670. package/dist/esm/ion-alert.entry.js +76 -40
  671. package/dist/esm/ion-app_8.entry.js +292 -157
  672. package/dist/esm/ion-avatar_3.entry.js +125 -13
  673. package/dist/esm/ion-back-button.entry.js +31 -22
  674. package/dist/esm/ion-backdrop.entry.js +10 -7
  675. package/dist/esm/ion-breadcrumb_2.entry.js +54 -18
  676. package/dist/esm/ion-button_2.entry.js +59 -22
  677. package/dist/esm/ion-card_5.entry.js +55 -33
  678. package/dist/esm/ion-checkbox.entry.js +34 -16
  679. package/dist/esm/ion-chip.entry.js +50 -9
  680. package/dist/esm/ion-col_3.entry.js +56 -57
  681. package/dist/esm/ion-datetime-button.entry.js +13 -9
  682. package/dist/esm/ion-datetime_3.entry.js +116 -41
  683. package/dist/esm/ion-divider.entry.js +49 -0
  684. package/dist/esm/ion-fab_3.entry.js +44 -28
  685. package/dist/esm/ion-gallery.entry.js +508 -0
  686. package/dist/esm/ion-img.entry.js +8 -4
  687. package/dist/esm/ion-infinite-scroll_2.entry.js +91 -16
  688. package/dist/esm/ion-input-otp.entry.js +74 -9
  689. package/dist/esm/ion-input-password-toggle.entry.js +53 -15
  690. package/dist/esm/ion-input.entry.js +124 -34
  691. package/dist/esm/ion-item-option_3.entry.js +467 -52
  692. package/dist/esm/ion-item_8.entry.js +115 -49
  693. package/dist/esm/ion-loading.entry.js +20 -18
  694. package/dist/esm/ion-menu_3.entry.js +47 -29
  695. package/dist/esm/ion-modal.entry.js +215 -91
  696. package/dist/esm/ion-nav_2.entry.js +14 -11
  697. package/dist/esm/ion-picker-column-option.entry.js +12 -8
  698. package/dist/esm/ion-picker-column.entry.js +13 -13
  699. package/dist/esm/ion-picker.entry.js +10 -6
  700. package/dist/esm/ion-popover.entry.js +21 -19
  701. package/dist/esm/ion-progress-bar.entry.js +27 -9
  702. package/dist/esm/ion-radio_2.entry.js +35 -17
  703. package/dist/esm/ion-range.entry.js +20 -13
  704. package/dist/esm/ion-refresher_2.entry.js +39 -21
  705. package/dist/esm/ion-reorder_2.entry.js +38 -14
  706. package/dist/esm/ion-ripple-effect.entry.js +15 -7
  707. package/dist/esm/ion-route_4.entry.js +10 -9
  708. package/dist/esm/ion-searchbar.entry.js +137 -24
  709. package/dist/esm/ion-segment-content.entry.js +2 -2
  710. package/dist/esm/ion-segment-view.entry.js +13 -3
  711. package/dist/esm/ion-segment_2.entry.js +23 -16
  712. package/dist/esm/ion-select-modal.entry.js +119 -40
  713. package/dist/esm/ion-select_3.entry.js +500 -84
  714. package/dist/esm/ion-spinner.entry.js +30 -8
  715. package/dist/esm/ion-split-pane.entry.js +13 -9
  716. package/dist/esm/ion-tab-bar_2.entry.js +147 -23
  717. package/dist/esm/ion-tab_2.entry.js +8 -7
  718. package/dist/esm/ion-text.entry.js +7 -7
  719. package/dist/esm/ion-textarea.entry.js +137 -23
  720. package/dist/esm/ion-toast.entry.js +44 -21
  721. package/dist/esm/ion-toggle.entry.js +82 -25
  722. package/dist/esm/ionic-global--9mOmThr.js +508 -0
  723. package/dist/esm/ionic.js +5 -5
  724. package/dist/esm/{ios.transition--aMF-pDH.js → ios.transition-DoQTN5Jk.js} +7 -5
  725. package/dist/esm/{keyboard-ywgs5efA.js → keyboard-Ca1zVCcH.js} +4 -3
  726. package/dist/esm/{keyboard-CUw4ekVy.js → keyboard-Dnno7-Ci.js} +1 -1
  727. package/dist/esm/{keyboard-controller-BaaVITYt.js → keyboard-controller-BpOdk6xN.js} +5 -3
  728. package/dist/esm/list-Dhi5xtNS.js +6 -0
  729. package/dist/esm/loader.js +5 -5
  730. package/dist/esm/{md.transition-BEVbfm8j.js → md.transition-DZydrWwq.js} +6 -5
  731. package/dist/esm/{notch-controller-DAcvKU57.js → notch-controller-klgNWpjJ.js} +2 -2
  732. package/dist/esm/overlay-control-label-PzmQ86nh.js +48 -0
  733. package/dist/esm/{overlays-F8GHPo-e.js → overlays-CpQ6Df2g.js} +107 -13
  734. package/dist/esm/select-option-render-y_4XoEqH.js +109 -0
  735. package/dist/esm/{status-tap-BfJqFSLF.js → status-tap-fYFdZg6z.js} +4 -3
  736. package/dist/esm/{swipe-back-BZBFwTQV.js → swipe-back-BzGqTrrq.js} +3 -2
  737. package/dist/esm/{theme-DiVJyqlX.js → theme-DaJxRxSQ.js} +25 -1
  738. package/dist/esm/validity-BjW8SOqw.js +48 -0
  739. package/dist/esm/x-BDqjX7Z_.js +6 -0
  740. package/dist/html.html-data.json +2570 -105
  741. package/dist/ionic/index.esm.js +1 -1
  742. package/dist/ionic/ionic.esm.js +1 -1
  743. package/dist/ionic/p-0030507d.entry.js +4 -0
  744. package/dist/ionic/p-084c2623.entry.js +4 -0
  745. package/dist/ionic/p-09f8a57f.entry.js +4 -0
  746. package/dist/ionic/p-108c0f30.entry.js +4 -0
  747. package/dist/ionic/p-1439fecb.entry.js +4 -0
  748. package/dist/ionic/p-199bffb3.entry.js +4 -0
  749. package/dist/ionic/p-19a1ff9a.entry.js +4 -0
  750. package/dist/ionic/p-1a026890.entry.js +4 -0
  751. package/dist/ionic/p-1ad16c09.entry.js +4 -0
  752. package/dist/ionic/p-2aa7567e.entry.js +4 -0
  753. package/dist/ionic/p-3656314c.entry.js +4 -0
  754. package/dist/ionic/p-379cc989.entry.js +4 -0
  755. package/dist/ionic/p-3f18dfe9.entry.js +4 -0
  756. package/dist/ionic/p-3f1dbb47.entry.js +4 -0
  757. package/dist/ionic/p-40d9e029.entry.js +4 -0
  758. package/dist/ionic/p-410d60c5.entry.js +4 -0
  759. package/dist/ionic/p-456736d1.entry.js +4 -0
  760. package/dist/ionic/p-48e3cb9e.entry.js +4 -0
  761. package/dist/ionic/p-497f6391.entry.js +4 -0
  762. package/dist/ionic/p-64b4e6eb.entry.js +4 -0
  763. package/dist/ionic/p-66eb0193.entry.js +4 -0
  764. package/dist/ionic/p-67c2d349.entry.js +4 -0
  765. package/dist/ionic/p-7054a1b9.entry.js +4 -0
  766. package/dist/ionic/p-70ee89c9.entry.js +4 -0
  767. package/dist/ionic/p-7186786e.entry.js +4 -0
  768. package/dist/ionic/p-7194f6fa.entry.js +4 -0
  769. package/dist/ionic/p-76c70824.entry.js +4 -0
  770. package/dist/ionic/p-7e6112fc.entry.js +4 -0
  771. package/dist/ionic/p-7f294078.entry.js +4 -0
  772. package/dist/ionic/p-8458f1b6.entry.js +4 -0
  773. package/dist/ionic/p-88e7f52a.entry.js +4 -0
  774. package/dist/ionic/p-89eab395.entry.js +4 -0
  775. package/dist/ionic/p-93315d96.entry.js +4 -0
  776. package/dist/ionic/p-9ccfb733.entry.js +4 -0
  777. package/dist/ionic/p-9dfbe98d.entry.js +4 -0
  778. package/dist/ionic/{p-DjriolRs.js → p-B2-sg7NJ.js} +1 -1
  779. package/dist/ionic/p-B4ikoeaj.js +4 -0
  780. package/dist/ionic/p-BDqjX7Z_.js +4 -0
  781. package/dist/ionic/p-BFBCtvFI.js +4 -0
  782. package/dist/ionic/p-BQgCYKKG.js +4 -0
  783. package/dist/ionic/p-BYAxJDlE.js +4 -0
  784. package/dist/ionic/p-BYSs-jZz.js +4 -0
  785. package/dist/ionic/p-BjW8SOqw.js +4 -0
  786. package/dist/ionic/{p-CKvCXMs9.js → p-BmEwy3tY.js} +1 -1
  787. package/{components/p-BS1TtEiJ.js → dist/ionic/p-C8IHbcuP.js} +1 -1
  788. package/dist/ionic/p-CDn0uNJA.js +4 -0
  789. package/dist/ionic/p-CHE1xWbg.js +4 -0
  790. package/dist/ionic/p-CK179dBb.js +4 -0
  791. package/dist/ionic/p-CLHjFE18.js +4 -0
  792. package/dist/ionic/p-CYhXBSjd.js +4 -0
  793. package/{components/p-D13Eaw-8.js → dist/ionic/p-CuGhCBt7.js} +1 -1
  794. package/dist/ionic/p-D1t981Ih.js +4 -0
  795. package/dist/ionic/p-D2tu5BUg.js +4 -0
  796. package/dist/ionic/p-DDFhx1YX.js +4 -0
  797. package/dist/ionic/{p-B8xlpH8p.js → p-DKWXAwlR.js} +1 -1
  798. package/dist/ionic/p-DNGqaUsl.js +4 -0
  799. package/dist/ionic/p-DaJxRxSQ.js +4 -0
  800. package/dist/ionic/p-DaknVxZR.js +4 -0
  801. package/dist/ionic/p-Dhi5xtNS.js +4 -0
  802. package/dist/ionic/p-DoyDJ2X5.js +4 -0
  803. package/dist/ionic/p-E1wtzfO0.js +4 -0
  804. package/dist/ionic/p-FvDKM4Ax.js +4 -0
  805. package/dist/ionic/p-IXZW3FBt.js +4 -0
  806. package/dist/ionic/p-Omi_TcwW.js +5 -0
  807. package/dist/ionic/p-PoSbs6oh.js +4 -0
  808. package/dist/ionic/p-PzmQ86nh.js +4 -0
  809. package/dist/ionic/p-VAJ_3beW.js +4 -0
  810. package/dist/ionic/p-a3f9be52.entry.js +4 -0
  811. package/dist/ionic/p-ad4d0138.entry.js +4 -0
  812. package/dist/ionic/p-b4ba0050.entry.js +4 -0
  813. package/dist/ionic/p-b4fd91b8.entry.js +4 -0
  814. package/dist/ionic/p-b653f4c2.entry.js +4 -0
  815. package/dist/ionic/p-b69add0e.entry.js +4 -0
  816. package/dist/ionic/p-b7235e85.entry.js +4 -0
  817. package/dist/ionic/p-bc317965.entry.js +4 -0
  818. package/dist/ionic/p-bsfLvRbd.js +4 -0
  819. package/dist/ionic/p-c21a780d.entry.js +4 -0
  820. package/dist/ionic/p-c5118189.entry.js +4 -0
  821. package/dist/ionic/p-c684a3b6.entry.js +4 -0
  822. package/dist/ionic/p-c7139c41.entry.js +4 -0
  823. package/dist/ionic/p-c94fbdab.entry.js +4 -0
  824. package/dist/ionic/p-dac1d4de.entry.js +4 -0
  825. package/dist/ionic/p-dd2981d0.entry.js +4 -0
  826. package/dist/ionic/p-eTI_FbQJ.js +4 -0
  827. package/dist/ionic/p-f72200cc.entry.js +4 -0
  828. package/dist/ionic/p-fIOYmaqA.js +4 -0
  829. package/dist/ionic/p-fbdbdb3e.entry.js +4 -0
  830. package/dist/ionic/p-fd519e2b.entry.js +4 -0
  831. package/dist/ionic/p-ff09d2a5.entry.js +4 -0
  832. package/dist/ionic/p-u6HLvq0g.js +4 -0
  833. package/dist/ionic/p-vXpMhGrs.js +4 -0
  834. package/dist/types/components/accordion/accordion.d.ts +6 -3
  835. package/dist/types/components/accordion-group/accordion-group.d.ts +12 -1
  836. package/dist/types/components/action-sheet/action-sheet-interface.d.ts +3 -7
  837. package/dist/types/components/action-sheet/action-sheet.d.ts +3 -2
  838. package/dist/types/components/alert/alert-interface.d.ts +3 -7
  839. package/dist/types/components/alert/alert.d.ts +3 -2
  840. package/dist/types/components/app/app.d.ts +4 -5
  841. package/dist/types/components/avatar/avatar.d.ts +32 -0
  842. package/dist/types/components/back-button/back-button.d.ts +2 -1
  843. package/dist/types/components/backdrop/backdrop.d.ts +4 -0
  844. package/dist/types/components/badge/badge.d.ts +34 -1
  845. package/dist/types/components/breadcrumb/breadcrumb.d.ts +4 -1
  846. package/dist/types/components/breadcrumbs/breadcrumbs.d.ts +2 -2
  847. package/dist/types/components/button/button.d.ts +23 -8
  848. package/dist/types/components/buttons/buttons.d.ts +5 -1
  849. package/dist/types/components/card/card.d.ts +8 -1
  850. package/dist/types/components/card-content/card-content.d.ts +2 -1
  851. package/dist/types/components/card-header/card-header.d.ts +3 -2
  852. package/dist/types/components/card-subtitle/card-subtitle.d.ts +2 -1
  853. package/dist/types/components/card-title/card-title.d.ts +2 -1
  854. package/dist/types/components/checkbox/checkbox.d.ts +14 -4
  855. package/dist/types/components/chip/chip.d.ts +26 -1
  856. package/dist/types/components/col/col.d.ts +52 -5
  857. package/dist/types/components/content/content.d.ts +3 -0
  858. package/dist/types/components/datetime/datetime.d.ts +26 -1
  859. package/dist/types/components/datetime/utils/data.d.ts +5 -5
  860. package/dist/types/components/datetime-button/datetime-button.d.ts +2 -1
  861. package/dist/types/components/divider/divider.d.ts +20 -0
  862. package/dist/types/components/fab/fab.d.ts +4 -0
  863. package/dist/types/components/fab-button/fab-button.d.ts +5 -3
  864. package/dist/types/components/fab-list/fab-list.d.ts +4 -0
  865. package/dist/types/components/footer/footer.d.ts +4 -3
  866. package/dist/types/components/gallery/gallery-constants.d.ts +9 -0
  867. package/dist/types/components/gallery/gallery-interface.d.ts +10 -0
  868. package/dist/types/components/gallery/gallery.d.ts +183 -0
  869. package/dist/types/components/gallery/test/utils.d.ts +2 -0
  870. package/dist/types/components/grid/grid.d.ts +4 -0
  871. package/dist/types/components/header/header.d.ts +9 -3
  872. package/dist/types/components/header/header.utils.d.ts +3 -3
  873. package/dist/types/components/img/img.d.ts +3 -0
  874. package/dist/types/components/infinite-scroll/infinite-scroll.d.ts +21 -0
  875. package/dist/types/components/infinite-scroll-content/infinite-scroll-content.d.ts +4 -0
  876. package/dist/types/components/input/input.d.ts +31 -5
  877. package/dist/types/components/input-otp/input-otp.d.ts +37 -0
  878. package/dist/types/components/input-password-toggle/input-password-toggle.d.ts +2 -0
  879. package/dist/types/components/item/item.d.ts +11 -4
  880. package/dist/types/components/item-divider/item-divider.d.ts +2 -1
  881. package/dist/types/components/item-group/item-group.d.ts +4 -0
  882. package/dist/types/components/item-option/item-option.d.ts +18 -1
  883. package/dist/types/components/item-options/item-options.d.ts +4 -0
  884. package/dist/types/components/item-sliding/item-sliding.d.ts +47 -1
  885. package/dist/types/components/item-sliding/test/test.utils.d.ts +13 -0
  886. package/dist/types/components/label/label.d.ts +2 -1
  887. package/dist/types/components/list/list.d.ts +15 -1
  888. package/dist/types/components/list-header/list-header.d.ts +2 -1
  889. package/dist/types/components/loading/loading-interface.d.ts +2 -7
  890. package/dist/types/components/loading/loading.d.ts +3 -2
  891. package/dist/types/components/menu/menu.d.ts +3 -0
  892. package/dist/types/components/menu-button/menu-button.d.ts +3 -1
  893. package/dist/types/components/menu-toggle/menu-toggle.d.ts +3 -0
  894. package/dist/types/components/modal/animations/ionic.enter.d.ts +6 -0
  895. package/dist/types/components/modal/animations/ionic.leave.d.ts +6 -0
  896. package/dist/types/components/modal/gestures/sheet.d.ts +1 -1
  897. package/dist/types/components/modal/modal-interface.d.ts +4 -7
  898. package/dist/types/components/modal/modal.d.ts +11 -1
  899. package/dist/types/components/nav/nav-interface.d.ts +9 -1
  900. package/dist/types/components/nav/nav.d.ts +5 -1
  901. package/dist/types/components/nav-link/nav-link.d.ts +4 -0
  902. package/dist/types/components/note/note.d.ts +2 -1
  903. package/dist/types/components/picker/picker.d.ts +2 -1
  904. package/dist/types/components/picker-column/picker-column.d.ts +2 -1
  905. package/dist/types/components/picker-column-option/picker-column-option.d.ts +4 -0
  906. package/dist/types/components/picker-legacy/picker.d.ts +2 -1
  907. package/dist/types/components/popover/popover-interface.d.ts +3 -6
  908. package/dist/types/components/popover/popover.d.ts +6 -5
  909. package/dist/types/components/progress-bar/progress-bar.d.ts +10 -1
  910. package/dist/types/components/radio/radio.d.ts +2 -1
  911. package/dist/types/components/radio-group/radio-group.d.ts +12 -0
  912. package/dist/types/components/range/range.d.ts +2 -1
  913. package/dist/types/components/refresher/refresher.d.ts +2 -1
  914. package/dist/types/components/refresher-content/refresher-content.d.ts +4 -0
  915. package/dist/types/components/reorder/reorder.d.ts +9 -0
  916. package/dist/types/components/reorder-group/reorder-group.d.ts +4 -0
  917. package/dist/types/components/ripple-effect/ripple-effect.d.ts +4 -0
  918. package/dist/types/components/route/route.d.ts +4 -0
  919. package/dist/types/components/router/router.d.ts +4 -0
  920. package/dist/types/components/router-link/router-link.d.ts +4 -0
  921. package/dist/types/components/router-outlet/router-outlet.d.ts +4 -1
  922. package/dist/types/components/row/row.d.ts +4 -0
  923. package/dist/types/components/searchbar/searchbar.d.ts +51 -9
  924. package/dist/types/components/segment/segment.d.ts +2 -1
  925. package/dist/types/components/segment-button/segment-button.d.ts +2 -1
  926. package/dist/types/components/select/select-interface.d.ts +31 -0
  927. package/dist/types/components/select/select.d.ts +66 -13
  928. package/dist/types/components/select-modal/select-modal.d.ts +8 -0
  929. package/dist/types/components/select-option/select-option.d.ts +44 -0
  930. package/dist/types/components/select-popover/select-popover.d.ts +3 -0
  931. package/dist/types/components/skeleton-text/skeleton-text.d.ts +4 -0
  932. package/dist/types/components/spinner/spinner.d.ts +15 -0
  933. package/dist/types/components/split-pane/split-pane.d.ts +4 -0
  934. package/dist/types/components/tab/tab.d.ts +4 -0
  935. package/dist/types/components/tab-bar/tab-bar.d.ts +37 -2
  936. package/dist/types/components/tab-button/tab-button.d.ts +12 -1
  937. package/dist/types/components/tabs/tabs.d.ts +3 -0
  938. package/dist/types/components/text/text.d.ts +2 -1
  939. package/dist/types/components/textarea/textarea.d.ts +53 -4
  940. package/dist/types/components/thumbnail/thumbnail.d.ts +4 -0
  941. package/dist/types/components/title/title.d.ts +4 -0
  942. package/dist/types/components/toast/animations/utils.d.ts +2 -2
  943. package/dist/types/components/toast/toast-interface.d.ts +3 -7
  944. package/dist/types/components/toast/toast.d.ts +19 -2
  945. package/dist/types/components/toggle/toggle.d.ts +15 -1
  946. package/dist/types/components/toolbar/toolbar.d.ts +43 -3
  947. package/dist/types/components.d.ts +1819 -205
  948. package/dist/types/global/ionic-global.d.ts +28 -2
  949. package/dist/types/interface.d.ts +3 -0
  950. package/dist/types/utils/config.d.ts +106 -2
  951. package/dist/types/utils/css-value-validation.d.ts +12 -0
  952. package/dist/types/utils/focus-trap.d.ts +1 -1
  953. package/dist/types/utils/focus-visible.d.ts +13 -0
  954. package/dist/types/utils/forms/validity.d.ts +7 -0
  955. package/dist/types/utils/helpers.d.ts +11 -0
  956. package/dist/types/utils/overlay-control-label.d.ts +34 -0
  957. package/dist/types/utils/overlays-interface.d.ts +31 -1
  958. package/dist/types/utils/overlays.d.ts +1 -1
  959. package/dist/types/utils/sanitization/index.d.ts +32 -2
  960. package/dist/types/utils/select-option-render.d.ts +22 -0
  961. package/dist/types/utils/test/playwright/drag-element.d.ts +16 -3
  962. package/dist/types/utils/test/playwright/generator.d.ts +31 -2
  963. package/dist/types/utils/theme.d.ts +9 -0
  964. package/hydrate/index.js +5211 -1182
  965. package/hydrate/index.mjs +5211 -1182
  966. package/package.json +8 -4
  967. package/components/p-B6FQ0cKR.js +0 -4
  968. package/components/p-B6HaBl3o.js +0 -4
  969. package/components/p-B8b1Ukl9.js +0 -4
  970. package/components/p-BJoMtgfR.js +0 -4
  971. package/components/p-BNAG-aVv.js +0 -4
  972. package/components/p-BR3tZJmu.js +0 -4
  973. package/components/p-BSB38Tek.js +0 -4
  974. package/components/p-BTeL5HCK.js +0 -4
  975. package/components/p-BUbsoBOV.js +0 -4
  976. package/components/p-BYDc3hSE.js +0 -4
  977. package/components/p-BagjAGC0.js +0 -4
  978. package/components/p-BegtE7nr.js +0 -4
  979. package/components/p-BgwEQWW6.js +0 -4
  980. package/components/p-BmVRXR1y.js +0 -4
  981. package/components/p-BxwWvu-b.js +0 -4
  982. package/components/p-C4jPsTQa.js +0 -4
  983. package/components/p-C59ryAuS.js +0 -4
  984. package/components/p-CBzELu-H.js +0 -4
  985. package/components/p-CDfQnFrd.js +0 -4
  986. package/components/p-CIGNaXM1.js +0 -4
  987. package/components/p-CO7fmmxt.js +0 -4
  988. package/components/p-Cf6Z1pmL.js +0 -4
  989. package/components/p-CgfaEEem.js +0 -4
  990. package/components/p-CgqKJg96.js +0 -4
  991. package/components/p-CneGxKsZ.js +0 -4
  992. package/components/p-CoA-aqGF.js +0 -4
  993. package/components/p-Cq8cQ0NL.js +0 -4
  994. package/components/p-Csw8xuz4.js +0 -4
  995. package/components/p-CtWGkNnJ.js +0 -4
  996. package/components/p-Cy5XSfIk.js +0 -4
  997. package/components/p-Cyxa_4PV.js +0 -4
  998. package/components/p-Cz5nLPGT.js +0 -4
  999. package/components/p-D-cP12ZN.js +0 -4
  1000. package/components/p-D6NJwNJN.js +0 -4
  1001. package/components/p-D6Ynv7Xh.js +0 -4
  1002. package/components/p-DHsZWn1l.js +0 -4
  1003. package/components/p-DJMZehmW.js +0 -4
  1004. package/components/p-DJztqcrH.js +0 -4
  1005. package/components/p-DYdpXONG.js +0 -4
  1006. package/components/p-DZhbcvo5.js +0 -4
  1007. package/components/p-DgbT0exM.js +0 -4
  1008. package/components/p-DiVJyqlX.js +0 -4
  1009. package/components/p-DlgpdeOi.js +0 -4
  1010. package/components/p-DvOO1fxp.js +0 -4
  1011. package/components/p-FBcnjE5W.js +0 -4
  1012. package/components/p-Q1-Xy3As.js +0 -4
  1013. package/components/p-SBseW5KJ.js +0 -4
  1014. package/components/p-ZjP4CjeZ.js +0 -4
  1015. package/components/p-ZuZOauwD.js +0 -4
  1016. package/components/p-ak_d-z48.js +0 -4
  1017. package/components/p-fpbh6w3f.js +0 -4
  1018. package/components/p-kvaDs24J.js +0 -4
  1019. package/components/p-vEbVo2hO.js +0 -4
  1020. package/dist/cjs/hardware-back-button-C4rMJ5uI.js +0 -121
  1021. package/dist/cjs/index-DkNv4J_i.js +0 -10
  1022. package/dist/cjs/ionic-global-Bc3kJi1Z.js +0 -151
  1023. package/dist/cjs/validity-BpS37YFM.js +0 -19
  1024. package/dist/esm/hardware-back-button-CTe4XmL7.js +0 -115
  1025. package/dist/esm/index-ZjP4CjeZ.js +0 -7
  1026. package/dist/esm/ionic-global-DfbeLwcV.js +0 -146
  1027. package/dist/esm/validity-DJztqcrH.js +0 -17
  1028. package/dist/ionic/p-031b76f7.entry.js +0 -4
  1029. package/dist/ionic/p-045a6a42.entry.js +0 -4
  1030. package/dist/ionic/p-07506134.entry.js +0 -4
  1031. package/dist/ionic/p-078037da.entry.js +0 -4
  1032. package/dist/ionic/p-084c25b2.entry.js +0 -4
  1033. package/dist/ionic/p-0d8b5c38.entry.js +0 -4
  1034. package/dist/ionic/p-16813ce7.entry.js +0 -4
  1035. package/dist/ionic/p-1b169fb6.entry.js +0 -4
  1036. package/dist/ionic/p-1ca9c36b.entry.js +0 -4
  1037. package/dist/ionic/p-23ec35e4.entry.js +0 -4
  1038. package/dist/ionic/p-23fac490.entry.js +0 -4
  1039. package/dist/ionic/p-28a9e720.entry.js +0 -4
  1040. package/dist/ionic/p-294f4bb5.entry.js +0 -4
  1041. package/dist/ionic/p-2a68388b.entry.js +0 -4
  1042. package/dist/ionic/p-2f5a8140.entry.js +0 -4
  1043. package/dist/ionic/p-2fd110aa.entry.js +0 -4
  1044. package/dist/ionic/p-301c43f8.entry.js +0 -4
  1045. package/dist/ionic/p-370a60ee.entry.js +0 -4
  1046. package/dist/ionic/p-53f750a5.entry.js +0 -4
  1047. package/dist/ionic/p-6888a88b.entry.js +0 -4
  1048. package/dist/ionic/p-6af16209.entry.js +0 -4
  1049. package/dist/ionic/p-6b701daa.entry.js +0 -4
  1050. package/dist/ionic/p-6b97f2a3.entry.js +0 -4
  1051. package/dist/ionic/p-7620be24.entry.js +0 -4
  1052. package/dist/ionic/p-771b27a5.entry.js +0 -4
  1053. package/dist/ionic/p-7761ef65.entry.js +0 -4
  1054. package/dist/ionic/p-7ca71c83.entry.js +0 -4
  1055. package/dist/ionic/p-80cac7a2.entry.js +0 -4
  1056. package/dist/ionic/p-87125490.entry.js +0 -4
  1057. package/dist/ionic/p-8fda6a62.entry.js +0 -4
  1058. package/dist/ionic/p-9833cf63.entry.js +0 -4
  1059. package/dist/ionic/p-9cbc6f1f.entry.js +0 -4
  1060. package/dist/ionic/p-9eeaBrnk.js +0 -4
  1061. package/dist/ionic/p-BAt5H1ac.js +0 -4
  1062. package/dist/ionic/p-BW_TRJm8.js +0 -4
  1063. package/dist/ionic/p-BmVRXR1y.js +0 -4
  1064. package/dist/ionic/p-Bum7H1fw.js +0 -4
  1065. package/dist/ionic/p-C0JvVFMv.js +0 -4
  1066. package/dist/ionic/p-CGmVTdWh.js +0 -4
  1067. package/dist/ionic/p-CIGNaXM1.js +0 -4
  1068. package/dist/ionic/p-CYbRmDdy.js +0 -4
  1069. package/dist/ionic/p-CmFz1Mjc.js +0 -4
  1070. package/dist/ionic/p-CtA-yJYy.js +0 -4
  1071. package/dist/ionic/p-CtWGkNnJ.js +0 -4
  1072. package/dist/ionic/p-D8HJQ1qq.js +0 -4
  1073. package/dist/ionic/p-DB_iPQC-.js +0 -4
  1074. package/dist/ionic/p-DJztqcrH.js +0 -4
  1075. package/dist/ionic/p-DLbbmF9h.js +0 -4
  1076. package/dist/ionic/p-DTPR1Wpn.js +0 -4
  1077. package/dist/ionic/p-DV3sJJW8.js +0 -4
  1078. package/dist/ionic/p-DcSNwXfb.js +0 -4
  1079. package/dist/ionic/p-DiVJyqlX.js +0 -4
  1080. package/dist/ionic/p-DtVZDHlS.js +0 -4
  1081. package/dist/ionic/p-IGIE5vDm.js +0 -5
  1082. package/dist/ionic/p-NFFyoJ4Q.js +0 -4
  1083. package/dist/ionic/p-ZjP4CjeZ.js +0 -4
  1084. package/dist/ionic/p-a805674e.entry.js +0 -4
  1085. package/dist/ionic/p-a84f2d21.entry.js +0 -4
  1086. package/dist/ionic/p-a893c61c.entry.js +0 -4
  1087. package/dist/ionic/p-aa812c4b.entry.js +0 -4
  1088. package/dist/ionic/p-b325a113.entry.js +0 -4
  1089. package/dist/ionic/p-b6e0ff03.entry.js +0 -4
  1090. package/dist/ionic/p-bcaa827e.entry.js +0 -4
  1091. package/dist/ionic/p-c3cce9d8.entry.js +0 -4
  1092. package/dist/ionic/p-ca31010f.entry.js +0 -4
  1093. package/dist/ionic/p-cf8757a7.entry.js +0 -4
  1094. package/dist/ionic/p-d4e8b473.entry.js +0 -4
  1095. package/dist/ionic/p-e663bc5a.entry.js +0 -4
  1096. package/dist/ionic/p-e6cedcd7.entry.js +0 -4
  1097. package/dist/ionic/p-e863ffe8.entry.js +0 -4
  1098. package/dist/ionic/p-f2deaceb.entry.js +0 -4
  1099. package/dist/ionic/p-f3e7b155.entry.js +0 -4
  1100. package/dist/ionic/p-f5dfb9a3.entry.js +0 -4
  1101. package/dist/ionic/p-f69a5f71.entry.js +0 -4
  1102. package/dist/ionic/p-f8186550.entry.js +0 -4
  1103. package/dist/ionic/p-fdbc90d4.entry.js +0 -4
  1104. package/dist/ionic/p-gbVXD275.js +0 -4
  1105. package/dist/ionic/p-hNN3VvaC.js +0 -4
  1106. /package/dist/collection/components/{input-password-toggle/input-password-toggle.css → refresher-content/refresher-content.css} +0 -0
@@ -1,16 +1,19 @@
1
1
  /*!
2
2
  * (C) Ionic http://ionicframework.com - MIT License
3
3
  */
4
- import { r as registerInstance, h, d as Host, g as getElement, c as createEvent, f as printIonWarning } from './index-IGIE5vDm.js';
5
- import { c as createColorClasses } from './theme-DiVJyqlX.js';
6
- import { b as getIonMode } from './ionic-global-DfbeLwcV.js';
7
- import { o as isEndSide } from './helpers-Tl8jw6S2.js';
8
- import { f as findClosestIonContent, d as disableContentScrollY, r as resetContentScrollY } from './index-hW6eNZ3o.js';
4
+ import { r as registerInstance, h, d as Host, g as getElement, c as createEvent, f as printIonWarning } from './index-Omi_TcwW.js';
5
+ import { c as createColorClasses } from './theme-DaJxRxSQ.js';
6
+ import { c as getIonTheme } from './ionic-global--9mOmThr.js';
7
+ import { p as isEndSide } from './helpers-Do7zwvM1.js';
8
+ import { f as findClosestIonContent, d as disableContentScrollY, r as resetContentScrollY } from './index-BmkLokUL.js';
9
9
  import { w as watchForOptions } from './watch-options-Dtdm8lKC.js';
10
+ import './focus-visible-vXpMhGrs.js';
10
11
 
11
- const itemOptionIosCss = () => `:host{--background:var(--ion-color-primary, #0054e9);--color:var(--ion-color-primary-contrast, #fff);background:var(--background);color:var(--color);font-family:var(--ion-font-family, inherit)}:host(.ion-color){background:var(--ion-color-base);color:var(--ion-color-contrast)}.button-native{font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;text-align:inherit;white-space:inherit;color:inherit;-webkit-padding-start:0.7em;padding-inline-start:0.7em;-webkit-padding-end:0.7em;padding-inline-end:0.7em;padding-top:0;padding-bottom:0;display:inline-block;position:relative;width:100%;height:100%;border:0;outline:none;background:transparent;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-box-sizing:border-box;box-sizing:border-box}.button-inner{display:-ms-flexbox;display:flex;-ms-flex-flow:column nowrap;flex-flow:column nowrap;-ms-flex-negative:0;flex-shrink:0;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:100%;height:100%}.horizontal-wrapper{display:-ms-flexbox;display:flex;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-ms-flex-negative:0;flex-shrink:0;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:100%}::slotted(*){-ms-flex-negative:0;flex-shrink:0}::slotted([slot=start]){-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:5px;margin-inline-end:5px;margin-top:0;margin-bottom:0}::slotted([slot=end]){-webkit-margin-start:5px;margin-inline-start:5px;-webkit-margin-end:0;margin-inline-end:0;margin-top:0;margin-bottom:0}::slotted([slot=icon-only]){padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;-webkit-margin-start:10px;margin-inline-start:10px;-webkit-margin-end:10px;margin-inline-end:10px;margin-top:0;margin-bottom:0;min-width:0.9em;font-size:1.8em}:host(.item-option-expandable){-ms-flex-negative:0;flex-shrink:0;-webkit-transition-duration:0;transition-duration:0;-webkit-transition-property:none;transition-property:none;-webkit-transition-timing-function:cubic-bezier(0.65, 0.05, 0.36, 1);transition-timing-function:cubic-bezier(0.65, 0.05, 0.36, 1)}:host(.item-option-disabled){pointer-events:none}:host(.item-option-disabled) .button-native{cursor:default;opacity:0.5;pointer-events:none}:host{font-size:clamp(16px, 1rem, 35.2px)}:host(.ion-activated){background:var(--ion-color-primary-shade, #004acd)}:host(.ion-color.ion-activated){background:var(--ion-color-shade)}`;
12
+ const itemOptionIonicCss = () => `:host{background:var(--background);color:var(--color)}.button-native{color:inherit;font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-align:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;white-space:inherit;display:inline-block;position:relative;width:100%;height:100%;border:0;outline:none;background:transparent;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-box-sizing:border-box;box-sizing:border-box}.button-inner{display:-ms-flexbox;display:flex;-ms-flex-flow:column nowrap;flex-flow:column nowrap;-ms-flex-negative:0;flex-shrink:0;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:100%;height:100%}.horizontal-wrapper{display:-ms-flexbox;display:flex;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-ms-flex-negative:0;flex-shrink:0;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:100%}::slotted(*){-ms-flex-negative:0;flex-shrink:0}:host(.item-option-expandable){-ms-flex-negative:0;flex-shrink:0;-webkit-transition-duration:0;transition-duration:0;-webkit-transition-property:none;transition-property:none}:host(.item-option-disabled){pointer-events:none}:host(.item-option-disabled) .button-native{cursor:default;pointer-events:none}:host{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;font-size:var(--token-font-size-350, 0.875rem);font-weight:var(--token-font-weight-medium, 500);letter-spacing:var(--token-font-letter-spacing-1, 1%);line-height:var(--token-font-line-height-500, var(--token-scale-500, 20px));text-decoration:none;text-transform:none}.button-native{-webkit-padding-start:var(--token-space-200, var(--token-scale-200, 8px));padding-inline-start:var(--token-space-200, var(--token-scale-200, 8px));-webkit-padding-end:var(--token-space-200, var(--token-scale-200, 8px));padding-inline-end:var(--token-space-200, var(--token-scale-200, 8px));padding-top:var(--token-space-200, var(--token-scale-200, 8px));padding-bottom:var(--token-space-200, var(--token-scale-200, 8px));min-width:var(--token-scale-1600, 64px);height:var(--token-scale-1600, 64px)}::slotted([slot=top]){margin-left:0;margin-right:0;margin-top:0;margin-bottom:var(--token-space-100, var(--token-scale-100, 4px))}::slotted([slot=bottom]){margin-left:0;margin-right:0;margin-top:var(--token-space-100, var(--token-scale-100, 4px));margin-bottom:0}::slotted([slot=start]){-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:var(--token-space-100, var(--token-scale-100, 4px));margin-inline-end:var(--token-space-100, var(--token-scale-100, 4px));margin-top:0;margin-bottom:0}::slotted([slot=end]){-webkit-margin-start:var(--token-space-100, var(--token-scale-100, 4px));margin-inline-start:var(--token-space-100, var(--token-scale-100, 4px));-webkit-margin-end:0;margin-inline-end:0;margin-top:0;margin-bottom:0}::slotted(ion-icon),::slotted([slot=icon-only]){margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;width:var(--token-scale-500, 20px);min-width:initial;height:var(--token-scale-500, 20px)}:host(.item-option-round){border-radius:var(--token-border-radius-300, var(--token-scale-300, 12px))}:host(.item-option-soft){border-radius:var(--token-border-radius-200, var(--token-scale-200, 8px))}:host(.item-option-rectangular){border-radius:var(--token-border-radius-0, var(--token-scale-0, 0px))}:host(.item-option-disabled)::after{right:0;left:0;top:0;bottom:0;position:absolute;background-color:var(--token-state-disabled, rgba(255, 255, 255, 0.6));content:"";pointer-events:none}:host(.item-option-disabled) .button-native{opacity:1}:host(.item-option-subtle){--background:var(--ion-color-primary-subtle, var(--token-bg-primary-subtle-default, var(--token-semantics-primary-100, var(--token-primitives-blue-100, #e9ecfc))));--background-activated:var(--ion-color-primary-subtle-shade, var(--token-bg-primary-subtle-press, var(--token-semantics-primary-300, var(--token-primitives-blue-300, #d0d7fa))));--color:var(--ion-color-primary-subtle-contrast, var(--token-text-primary, var(--token-semantics-primary-900, var(--token-primitives-blue-900, #0d4bc3))))}:host(.item-option-subtle.ion-color){background:var(--ion-color-subtle-base);color:var(--ion-color-subtle-contrast)}:host(.item-option-bold){--background:var(--ion-color-primary, var(--token-bg-primary-base-default, var(--token-semantics-primary-base, var(--token-semantics-primary-700, var(--token-primitives-blue-700, #105cef)))));--background-activated:var(--ion-color-primary-shade, var(--token-bg-primary-base-press, var(--token-semantics-primary-900, var(--token-primitives-blue-900, #0d4bc3))));--color:var(--ion-color-primary-contrast, var(--token-text-inverse, var(--token-primitives-base-white, #ffffff)))}:host(.item-option-bold.ion-color){background:var(--ion-color-base);color:var(--ion-color-contrast)}:host(.item-option-expand-threshold){-webkit-filter:brightness(0.92);filter:brightness(0.92)}`;
12
13
 
13
- const itemOptionMdCss = () => `:host{--background:var(--ion-color-primary, #0054e9);--color:var(--ion-color-primary-contrast, #fff);background:var(--background);color:var(--color);font-family:var(--ion-font-family, inherit)}:host(.ion-color){background:var(--ion-color-base);color:var(--ion-color-contrast)}.button-native{font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;text-align:inherit;white-space:inherit;color:inherit;-webkit-padding-start:0.7em;padding-inline-start:0.7em;-webkit-padding-end:0.7em;padding-inline-end:0.7em;padding-top:0;padding-bottom:0;display:inline-block;position:relative;width:100%;height:100%;border:0;outline:none;background:transparent;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-box-sizing:border-box;box-sizing:border-box}.button-inner{display:-ms-flexbox;display:flex;-ms-flex-flow:column nowrap;flex-flow:column nowrap;-ms-flex-negative:0;flex-shrink:0;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:100%;height:100%}.horizontal-wrapper{display:-ms-flexbox;display:flex;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-ms-flex-negative:0;flex-shrink:0;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:100%}::slotted(*){-ms-flex-negative:0;flex-shrink:0}::slotted([slot=start]){-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:5px;margin-inline-end:5px;margin-top:0;margin-bottom:0}::slotted([slot=end]){-webkit-margin-start:5px;margin-inline-start:5px;-webkit-margin-end:0;margin-inline-end:0;margin-top:0;margin-bottom:0}::slotted([slot=icon-only]){padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;-webkit-margin-start:10px;margin-inline-start:10px;-webkit-margin-end:10px;margin-inline-end:10px;margin-top:0;margin-bottom:0;min-width:0.9em;font-size:1.8em}:host(.item-option-expandable){-ms-flex-negative:0;flex-shrink:0;-webkit-transition-duration:0;transition-duration:0;-webkit-transition-property:none;transition-property:none;-webkit-transition-timing-function:cubic-bezier(0.65, 0.05, 0.36, 1);transition-timing-function:cubic-bezier(0.65, 0.05, 0.36, 1)}:host(.item-option-disabled){pointer-events:none}:host(.item-option-disabled) .button-native{cursor:default;opacity:0.5;pointer-events:none}:host{font-size:0.875rem;font-weight:500;text-transform:uppercase}`;
14
+ const itemOptionIosCss = () => `:host{background:var(--background);color:var(--color)}.button-native{color:inherit;font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-align:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;white-space:inherit;display:inline-block;position:relative;width:100%;height:100%;border:0;outline:none;background:transparent;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-box-sizing:border-box;box-sizing:border-box}.button-inner{display:-ms-flexbox;display:flex;-ms-flex-flow:column nowrap;flex-flow:column nowrap;-ms-flex-negative:0;flex-shrink:0;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:100%;height:100%}.horizontal-wrapper{display:-ms-flexbox;display:flex;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-ms-flex-negative:0;flex-shrink:0;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:100%}::slotted(*){-ms-flex-negative:0;flex-shrink:0}:host(.item-option-expandable){-ms-flex-negative:0;flex-shrink:0;-webkit-transition-duration:0;transition-duration:0;-webkit-transition-property:none;transition-property:none}:host(.item-option-disabled){pointer-events:none}:host(.item-option-disabled) .button-native{cursor:default;pointer-events:none}:host{--background:var(--ion-color-primary, #0054e9);--color:var(--ion-color-primary-contrast, #fff);font-family:var(--ion-font-family, inherit)}:host(.ion-color){background:var(--ion-color-base);color:var(--ion-color-contrast)}.button-native{-webkit-padding-start:0.7em;padding-inline-start:0.7em;-webkit-padding-end:0.7em;padding-inline-end:0.7em;padding-top:0;padding-bottom:0}::slotted([slot=start]){-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:5px;margin-inline-end:5px;margin-top:0;margin-bottom:0}::slotted([slot=end]){-webkit-margin-start:5px;margin-inline-start:5px;-webkit-margin-end:0;margin-inline-end:0;margin-top:0;margin-bottom:0}::slotted([slot=icon-only]){padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;-webkit-margin-start:10px;margin-inline-start:10px;-webkit-margin-end:10px;margin-inline-end:10px;margin-top:0;margin-bottom:0;min-width:0.9em;font-size:1.8em}:host(.item-option-disabled) .button-native{opacity:0.5}:host(.item-option-expandable){-webkit-transition-timing-function:cubic-bezier(0.65, 0.05, 0.36, 1);transition-timing-function:cubic-bezier(0.65, 0.05, 0.36, 1)}:host{font-size:clamp(16px, 1rem, 35.2px)}:host(.ion-activated){background:var(--ion-color-primary-shade, #004acd)}:host(.ion-color.ion-activated){background:var(--ion-color-shade)}`;
15
+
16
+ const itemOptionMdCss = () => `:host{background:var(--background);color:var(--color)}.button-native{color:inherit;font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-align:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;white-space:inherit;display:inline-block;position:relative;width:100%;height:100%;border:0;outline:none;background:transparent;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-box-sizing:border-box;box-sizing:border-box}.button-inner{display:-ms-flexbox;display:flex;-ms-flex-flow:column nowrap;flex-flow:column nowrap;-ms-flex-negative:0;flex-shrink:0;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:100%;height:100%}.horizontal-wrapper{display:-ms-flexbox;display:flex;-ms-flex-flow:row nowrap;flex-flow:row nowrap;-ms-flex-negative:0;flex-shrink:0;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;width:100%}::slotted(*){-ms-flex-negative:0;flex-shrink:0}:host(.item-option-expandable){-ms-flex-negative:0;flex-shrink:0;-webkit-transition-duration:0;transition-duration:0;-webkit-transition-property:none;transition-property:none}:host(.item-option-disabled){pointer-events:none}:host(.item-option-disabled) .button-native{cursor:default;pointer-events:none}:host{--background:var(--ion-color-primary, #0054e9);--color:var(--ion-color-primary-contrast, #fff);font-family:var(--ion-font-family, inherit)}:host(.ion-color){background:var(--ion-color-base);color:var(--ion-color-contrast)}.button-native{-webkit-padding-start:0.7em;padding-inline-start:0.7em;-webkit-padding-end:0.7em;padding-inline-end:0.7em;padding-top:0;padding-bottom:0}::slotted([slot=start]){-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:5px;margin-inline-end:5px;margin-top:0;margin-bottom:0}::slotted([slot=end]){-webkit-margin-start:5px;margin-inline-start:5px;-webkit-margin-end:0;margin-inline-end:0;margin-top:0;margin-bottom:0}::slotted([slot=icon-only]){padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;-webkit-margin-start:10px;margin-inline-start:10px;-webkit-margin-end:10px;margin-inline-end:10px;margin-top:0;margin-bottom:0;min-width:0.9em;font-size:1.8em}:host(.item-option-disabled) .button-native{opacity:0.5}:host(.item-option-expandable){-webkit-transition-timing-function:cubic-bezier(0.65, 0.05, 0.36, 1);transition-timing-function:cubic-bezier(0.65, 0.05, 0.36, 1)}:host{font-size:0.875rem;font-weight:500;text-transform:uppercase}`;
14
17
 
15
18
  const ItemOption = class {
16
19
  constructor(hostRef) {
@@ -23,6 +26,13 @@ const ItemOption = class {
23
26
  * If `true`, the option will expand to take up the available width and cover any other options.
24
27
  */
25
28
  this.expandable = false;
29
+ /**
30
+ * Set to `"bold"` for an option with vibrant, bold colors or to `"subtle"` for
31
+ * an option with muted, subtle colors.
32
+ *
33
+ * Only applies to the `ionic` theme.
34
+ */
35
+ this.hue = 'subtle';
26
36
  /**
27
37
  * The type of the button.
28
38
  */
@@ -34,10 +44,23 @@ const ItemOption = class {
34
44
  }
35
45
  };
36
46
  }
47
+ getShape() {
48
+ const theme = getIonTheme(this);
49
+ const { shape } = this;
50
+ // TODO(ROU-10841): Remove theme check when shapes are defined for all themes.
51
+ if (theme !== 'ionic') {
52
+ return undefined;
53
+ }
54
+ if (shape === undefined) {
55
+ return 'round';
56
+ }
57
+ return shape;
58
+ }
37
59
  render() {
38
- const { disabled, expandable, href } = this;
60
+ const { disabled, expandable, href, hue } = this;
39
61
  const TagType = href === undefined ? 'button' : 'a';
40
- const mode = getIonMode(this);
62
+ const theme = getIonTheme(this);
63
+ const shape = this.getShape();
41
64
  const attrs = TagType === 'button'
42
65
  ? { type: this.type }
43
66
  : {
@@ -45,23 +68,28 @@ const ItemOption = class {
45
68
  href: this.href,
46
69
  target: this.target,
47
70
  };
48
- return (h(Host, { key: 'b576e8f449ee9a03e659abd923421b051f7427c8', onClick: this.onClick, class: createColorClasses(this.color, {
49
- [mode]: true,
71
+ return (h(Host, { key: 'bfade0042108ff525077dfbdfd45169ccfd6b920', onClick: this.onClick, class: createColorClasses(this.color, {
72
+ [theme]: true,
73
+ [`item-option-${shape}`]: shape !== undefined,
74
+ [`item-option-${hue}`]: hue !== undefined,
50
75
  'item-option-disabled': disabled,
51
76
  'item-option-expandable': expandable,
52
77
  'ion-activatable': true,
53
- }) }, h(TagType, Object.assign({ key: '568c7de194ecef7d1efec2abdf855b3fce71aa03' }, attrs, { class: "button-native", part: "native", disabled: disabled }), h("span", { key: 'fe1a494a40febc5c415098d8c9b2edad9fac02c9', class: "button-inner", part: "inner" }, h("slot", { key: '8e4ec73c1a9c047a29dac8ad09ff1cce94a751c7', name: "top" }), h("div", { key: '7828c6413d2cab692a3a2e5aa2a17240e0dcb230', class: "horizontal-wrapper", part: "container" }, h("slot", { key: 'c8eb9881db296280ba895ab249e5d1bb3fc27206', name: "start" }), h("slot", { key: '144b18f7ea90a45abbe0b1fa878c87e623897b7b', name: "icon-only" }), h("slot", { key: '6c63ebad29552a32e1ed9ca3c95aa005b35b9b86' }), h("slot", { key: '99478d52600bf32342649a2f74ed8e1eb07407d4', name: "end" })), h("slot", { key: '00247fc54e61cface4e6ac6e8ea05a0685f5e26e', name: "bottom" })), mode === 'md' && h("ion-ripple-effect", { key: 'dc5057f2ff0926b2e5fd1520fed6cf7dc3197cf8' }))));
78
+ }) }, h(TagType, Object.assign({ key: '38466b511f4a20a3728f37dbf6779b852eba531a' }, attrs, { class: "button-native", part: "native", disabled: disabled }), h("span", { key: 'bb8f1b332afa2f575bcc69b340bd8f1faa5ca925', class: "button-inner", part: "inner" }, h("slot", { key: '41d627511e1615283956712e1b9519bae92460f6', name: "top" }), h("div", { key: 'bb949a43a586a8996933ee7528e5491beb647aa5', class: "horizontal-wrapper", part: "container" }, h("slot", { key: 'c0d6a73ef49082bfbdf0f542f7465d044ccb6521', name: "start" }), h("slot", { key: '79c6103e680983b2c1a17f1f11dbc41224cd4016', name: "icon-only" }), h("slot", { key: '6c7f17723544d3f6e8b9689b84ddf6196f1897a5' }), h("slot", { key: 'e15d0e02fde71bad8ff7bab0eded7d49508a926e', name: "end" })), h("slot", { key: 'c509d54d44ce33f5a34597b9d0ec29960bbcff62', name: "bottom" })), theme === 'md' && h("ion-ripple-effect", { key: '412d4dc645c941d0b4356cf982be3d5bc2686f13' }))));
54
79
  }
55
80
  get el() { return getElement(this); }
56
81
  };
57
82
  ItemOption.style = {
83
+ ionic: itemOptionIonicCss(),
58
84
  ios: itemOptionIosCss(),
59
85
  md: itemOptionMdCss()
60
86
  };
61
87
 
62
- const itemOptionsIosCss = () => `ion-item-options{top:0;right:0;-ms-flex-pack:end;justify-content:flex-end;display:none;position:absolute;height:100%;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;z-index:1}:host-context([dir=rtl]) ion-item-options{-ms-flex-pack:start;justify-content:flex-start}:host-context([dir=rtl]) ion-item-options:not(.item-options-end){right:auto;left:0;-ms-flex-pack:end;justify-content:flex-end}[dir=rtl] ion-item-options{-ms-flex-pack:start;justify-content:flex-start}[dir=rtl] ion-item-options:not(.item-options-end){right:auto;left:0;-ms-flex-pack:end;justify-content:flex-end}@supports selector(:dir(rtl)){ion-item-options:dir(rtl){-ms-flex-pack:start;justify-content:flex-start}ion-item-options:dir(rtl):not(.item-options-end){right:auto;left:0;-ms-flex-pack:end;justify-content:flex-end}}.item-options-start{right:auto;left:0;-ms-flex-pack:start;justify-content:flex-start}:host-context([dir=rtl]) .item-options-start{-ms-flex-pack:end;justify-content:flex-end}[dir=rtl] .item-options-start{-ms-flex-pack:end;justify-content:flex-end}@supports selector(:dir(rtl)){.item-options-start:dir(rtl){-ms-flex-pack:end;justify-content:flex-end}}[dir=ltr] .item-options-start ion-item-option:first-child,[dir=rtl] .item-options-start ion-item-option:last-child{padding-left:var(--ion-safe-area-left)}[dir=ltr] .item-options-end ion-item-option:last-child,[dir=rtl] .item-options-end ion-item-option:first-child{padding-right:var(--ion-safe-area-right)}:host-context([dir=rtl]) .item-sliding-active-slide.item-sliding-active-options-start ion-item-options:not(.item-options-end){width:100%;visibility:visible}[dir=rtl] .item-sliding-active-slide.item-sliding-active-options-start ion-item-options:not(.item-options-end){width:100%;visibility:visible}@supports selector(:dir(rtl)){.item-sliding-active-slide:dir(rtl).item-sliding-active-options-start ion-item-options:not(.item-options-end){width:100%;visibility:visible}}.item-sliding-active-slide ion-item-options{display:-ms-flexbox;display:flex;visibility:hidden}.item-sliding-active-slide.item-sliding-active-options-start .item-options-start,.item-sliding-active-slide.item-sliding-active-options-end ion-item-options:not(.item-options-start){width:100%;visibility:visible}.item-options-ios{border-bottom-width:0;border-bottom-style:solid;border-bottom-color:var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-250, var(--ion-background-color-step-250, #c8c7cc))))}.item-options-ios.item-options-end{border-bottom-width:0.55px}.list-ios-lines-none .item-options-ios{border-bottom-width:0}.list-ios-lines-full .item-options-ios,.list-ios-lines-inset .item-options-ios.item-options-end{border-bottom-width:0.55px}`;
88
+ const itemOptionsIonicCss = () => `ion-item-options{top:0;right:0;-ms-flex-pack:end;justify-content:flex-end;display:none;position:absolute;height:100%;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}:host-context([dir=rtl]) ion-item-options{-ms-flex-pack:start;justify-content:flex-start}:host-context([dir=rtl]) ion-item-options:not(.item-options-end){right:auto;left:0;-ms-flex-pack:end;justify-content:flex-end}[dir=rtl] ion-item-options{-ms-flex-pack:start;justify-content:flex-start}[dir=rtl] ion-item-options:not(.item-options-end){right:auto;left:0;-ms-flex-pack:end;justify-content:flex-end}@supports selector(:dir(rtl)){ion-item-options:dir(rtl){-ms-flex-pack:start;justify-content:flex-start}ion-item-options:dir(rtl):not(.item-options-end){right:auto;left:0;-ms-flex-pack:end;justify-content:flex-end}}.item-options-start{right:auto;left:0;-ms-flex-pack:start;justify-content:flex-start}:host-context([dir=rtl]) .item-options-start{-ms-flex-pack:end;justify-content:flex-end}[dir=rtl] .item-options-start{-ms-flex-pack:end;justify-content:flex-end}@supports selector(:dir(rtl)){.item-options-start:dir(rtl){-ms-flex-pack:end;justify-content:flex-end}}[dir=ltr] .item-options-start ion-item-option:first-child,[dir=rtl] .item-options-start ion-item-option:last-child{padding-left:var(--ion-safe-area-left)}[dir=ltr] .item-options-end ion-item-option:last-child,[dir=rtl] .item-options-end ion-item-option:first-child{padding-right:var(--ion-safe-area-right)}:host-context([dir=rtl]) .item-sliding-active-slide.item-sliding-active-options-start ion-item-options:not(.item-options-end){width:100%;visibility:visible}[dir=rtl] .item-sliding-active-slide.item-sliding-active-options-start ion-item-options:not(.item-options-end){width:100%;visibility:visible}@supports selector(:dir(rtl)){.item-sliding-active-slide:dir(rtl).item-sliding-active-options-start ion-item-options:not(.item-options-end){width:100%;visibility:visible}}.item-sliding-active-slide ion-item-options{display:-ms-flexbox;display:flex;visibility:hidden}.item-sliding-active-slide.item-sliding-active-options-start .item-options-start,.item-sliding-active-slide.item-sliding-active-options-end ion-item-options:not(.item-options-start){width:100%;visibility:visible}ion-item-options{z-index:1}.item-options-ionic{-ms-flex-align:center;align-items:center;background:var(--token-bg-surface-default, var(--token-primitives-base-white, #ffffff));gap:var(--token-space-100, var(--token-scale-100, 4px))}[dir=ltr] .item-options-start ion-item-option:last-child,[dir=rtl] .item-options-start ion-item-option:first-child{margin-right:var(--token-space-200, var(--token-scale-200, 8px))}[dir=ltr] .item-options-start ion-item-option:first-child,[dir=rtl] .item-options-start ion-item-option:last-child{margin-left:calc(var(--token-space-200, var(--token-scale-200, 8px)) + var(--ion-safe-area-left, 0));padding-left:initial}[dir=ltr] .item-options-end ion-item-option:first-child,[dir=rtl] .item-options-end ion-item-option:last-child{margin-left:var(--token-space-200, var(--token-scale-200, 8px))}[dir=ltr] .item-options-end ion-item-option:last-child,[dir=rtl] .item-options-end ion-item-option:first-child{margin-right:calc(var(--token-space-200, var(--token-scale-200, 8px)) + var(--ion-safe-area-right, 0));padding-right:initial}`;
63
89
 
64
- const itemOptionsMdCss = () => `ion-item-options{top:0;right:0;-ms-flex-pack:end;justify-content:flex-end;display:none;position:absolute;height:100%;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;z-index:1}:host-context([dir=rtl]) ion-item-options{-ms-flex-pack:start;justify-content:flex-start}:host-context([dir=rtl]) ion-item-options:not(.item-options-end){right:auto;left:0;-ms-flex-pack:end;justify-content:flex-end}[dir=rtl] ion-item-options{-ms-flex-pack:start;justify-content:flex-start}[dir=rtl] ion-item-options:not(.item-options-end){right:auto;left:0;-ms-flex-pack:end;justify-content:flex-end}@supports selector(:dir(rtl)){ion-item-options:dir(rtl){-ms-flex-pack:start;justify-content:flex-start}ion-item-options:dir(rtl):not(.item-options-end){right:auto;left:0;-ms-flex-pack:end;justify-content:flex-end}}.item-options-start{right:auto;left:0;-ms-flex-pack:start;justify-content:flex-start}:host-context([dir=rtl]) .item-options-start{-ms-flex-pack:end;justify-content:flex-end}[dir=rtl] .item-options-start{-ms-flex-pack:end;justify-content:flex-end}@supports selector(:dir(rtl)){.item-options-start:dir(rtl){-ms-flex-pack:end;justify-content:flex-end}}[dir=ltr] .item-options-start ion-item-option:first-child,[dir=rtl] .item-options-start ion-item-option:last-child{padding-left:var(--ion-safe-area-left)}[dir=ltr] .item-options-end ion-item-option:last-child,[dir=rtl] .item-options-end ion-item-option:first-child{padding-right:var(--ion-safe-area-right)}:host-context([dir=rtl]) .item-sliding-active-slide.item-sliding-active-options-start ion-item-options:not(.item-options-end){width:100%;visibility:visible}[dir=rtl] .item-sliding-active-slide.item-sliding-active-options-start ion-item-options:not(.item-options-end){width:100%;visibility:visible}@supports selector(:dir(rtl)){.item-sliding-active-slide:dir(rtl).item-sliding-active-options-start ion-item-options:not(.item-options-end){width:100%;visibility:visible}}.item-sliding-active-slide ion-item-options{display:-ms-flexbox;display:flex;visibility:hidden}.item-sliding-active-slide.item-sliding-active-options-start .item-options-start,.item-sliding-active-slide.item-sliding-active-options-end ion-item-options:not(.item-options-start){width:100%;visibility:visible}.item-options-md{border-bottom-width:0;border-bottom-style:solid;border-bottom-color:var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-150, var(--ion-background-color-step-150, rgba(0, 0, 0, 0.13)))))}.list-md-lines-none .item-options-md{border-bottom-width:0}.list-md-lines-full .item-options-md,.list-md-lines-inset .item-options-md.item-options-end{border-bottom-width:1px}`;
90
+ const itemOptionsIosCss = () => `ion-item-options{top:0;right:0;-ms-flex-pack:end;justify-content:flex-end;display:none;position:absolute;height:100%;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}:host-context([dir=rtl]) ion-item-options{-ms-flex-pack:start;justify-content:flex-start}:host-context([dir=rtl]) ion-item-options:not(.item-options-end){right:auto;left:0;-ms-flex-pack:end;justify-content:flex-end}[dir=rtl] ion-item-options{-ms-flex-pack:start;justify-content:flex-start}[dir=rtl] ion-item-options:not(.item-options-end){right:auto;left:0;-ms-flex-pack:end;justify-content:flex-end}@supports selector(:dir(rtl)){ion-item-options:dir(rtl){-ms-flex-pack:start;justify-content:flex-start}ion-item-options:dir(rtl):not(.item-options-end){right:auto;left:0;-ms-flex-pack:end;justify-content:flex-end}}.item-options-start{right:auto;left:0;-ms-flex-pack:start;justify-content:flex-start}:host-context([dir=rtl]) .item-options-start{-ms-flex-pack:end;justify-content:flex-end}[dir=rtl] .item-options-start{-ms-flex-pack:end;justify-content:flex-end}@supports selector(:dir(rtl)){.item-options-start:dir(rtl){-ms-flex-pack:end;justify-content:flex-end}}[dir=ltr] .item-options-start ion-item-option:first-child,[dir=rtl] .item-options-start ion-item-option:last-child{padding-left:var(--ion-safe-area-left)}[dir=ltr] .item-options-end ion-item-option:last-child,[dir=rtl] .item-options-end ion-item-option:first-child{padding-right:var(--ion-safe-area-right)}:host-context([dir=rtl]) .item-sliding-active-slide.item-sliding-active-options-start ion-item-options:not(.item-options-end){width:100%;visibility:visible}[dir=rtl] .item-sliding-active-slide.item-sliding-active-options-start ion-item-options:not(.item-options-end){width:100%;visibility:visible}@supports selector(:dir(rtl)){.item-sliding-active-slide:dir(rtl).item-sliding-active-options-start ion-item-options:not(.item-options-end){width:100%;visibility:visible}}.item-sliding-active-slide ion-item-options{display:-ms-flexbox;display:flex;visibility:hidden}.item-sliding-active-slide.item-sliding-active-options-start .item-options-start,.item-sliding-active-slide.item-sliding-active-options-end ion-item-options:not(.item-options-start){width:100%;visibility:visible}ion-item-options{z-index:1}.item-options-ios{border-bottom-width:0;border-bottom-style:solid;border-bottom-color:var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-250, var(--ion-background-color-step-250, #c8c7cc))))}.item-options-ios.item-options-end{border-bottom-width:0.55px}.list-ios-lines-none .item-options-ios{border-bottom-width:0}.list-ios-lines-full .item-options-ios,.list-ios-lines-inset .item-options-ios.item-options-end{border-bottom-width:0.55px}`;
91
+
92
+ const itemOptionsMdCss = () => `ion-item-options{top:0;right:0;-ms-flex-pack:end;justify-content:flex-end;display:none;position:absolute;height:100%;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}:host-context([dir=rtl]) ion-item-options{-ms-flex-pack:start;justify-content:flex-start}:host-context([dir=rtl]) ion-item-options:not(.item-options-end){right:auto;left:0;-ms-flex-pack:end;justify-content:flex-end}[dir=rtl] ion-item-options{-ms-flex-pack:start;justify-content:flex-start}[dir=rtl] ion-item-options:not(.item-options-end){right:auto;left:0;-ms-flex-pack:end;justify-content:flex-end}@supports selector(:dir(rtl)){ion-item-options:dir(rtl){-ms-flex-pack:start;justify-content:flex-start}ion-item-options:dir(rtl):not(.item-options-end){right:auto;left:0;-ms-flex-pack:end;justify-content:flex-end}}.item-options-start{right:auto;left:0;-ms-flex-pack:start;justify-content:flex-start}:host-context([dir=rtl]) .item-options-start{-ms-flex-pack:end;justify-content:flex-end}[dir=rtl] .item-options-start{-ms-flex-pack:end;justify-content:flex-end}@supports selector(:dir(rtl)){.item-options-start:dir(rtl){-ms-flex-pack:end;justify-content:flex-end}}[dir=ltr] .item-options-start ion-item-option:first-child,[dir=rtl] .item-options-start ion-item-option:last-child{padding-left:var(--ion-safe-area-left)}[dir=ltr] .item-options-end ion-item-option:last-child,[dir=rtl] .item-options-end ion-item-option:first-child{padding-right:var(--ion-safe-area-right)}:host-context([dir=rtl]) .item-sliding-active-slide.item-sliding-active-options-start ion-item-options:not(.item-options-end){width:100%;visibility:visible}[dir=rtl] .item-sliding-active-slide.item-sliding-active-options-start ion-item-options:not(.item-options-end){width:100%;visibility:visible}@supports selector(:dir(rtl)){.item-sliding-active-slide:dir(rtl).item-sliding-active-options-start ion-item-options:not(.item-options-end){width:100%;visibility:visible}}.item-sliding-active-slide ion-item-options{display:-ms-flexbox;display:flex;visibility:hidden}.item-sliding-active-slide.item-sliding-active-options-start .item-options-start,.item-sliding-active-slide.item-sliding-active-options-end ion-item-options:not(.item-options-start){width:100%;visibility:visible}ion-item-options{z-index:1}.item-options-md{border-bottom-width:0;border-bottom-style:solid;border-bottom-color:var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-150, var(--ion-background-color-step-150, rgba(0, 0, 0, 0.13)))))}.list-md-lines-none .item-options-md{border-bottom-width:0}.list-md-lines-full .item-options-md,.list-md-lines-inset .item-options-md.item-options-end{border-bottom-width:1px}`;
65
93
 
66
94
  const ItemOptions = class {
67
95
  constructor(hostRef) {
@@ -80,12 +108,12 @@ const ItemOptions = class {
80
108
  });
81
109
  }
82
110
  render() {
83
- const mode = getIonMode(this);
111
+ const theme = getIonTheme(this);
84
112
  const isEnd = isEndSide(this.side);
85
- return (h(Host, { key: '7b4b93984182222c64c7a2a22a18e52ac19e3049', class: {
86
- [mode]: true,
113
+ return (h(Host, { key: 'f3bb726a28c571101791d33d946df9017f47e5ec', class: {
114
+ [theme]: true,
87
115
  // Used internally for styling
88
- [`item-options-${mode}`]: true,
116
+ [`item-options-${theme}`]: true,
89
117
  /**
90
118
  * Note: The "start" and "end" terms refer to the
91
119
  * direction ion-item-option instances within ion-item-options flow.
@@ -101,14 +129,31 @@ const ItemOptions = class {
101
129
  get el() { return getElement(this); }
102
130
  };
103
131
  ItemOptions.style = {
132
+ ionic: itemOptionsIonicCss(),
104
133
  ios: itemOptionsIosCss(),
105
134
  md: itemOptionsMdCss()
106
135
  };
107
136
 
108
- const itemSlidingCss = () => `ion-item-sliding{display:block;position:relative;width:100%;overflow:hidden;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}ion-item-sliding .item{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.item-sliding-active-slide .item{position:relative;-webkit-transition:-webkit-transform 500ms cubic-bezier(0.36, 0.66, 0.04, 1);transition:-webkit-transform 500ms cubic-bezier(0.36, 0.66, 0.04, 1);transition:transform 500ms cubic-bezier(0.36, 0.66, 0.04, 1);transition:transform 500ms cubic-bezier(0.36, 0.66, 0.04, 1), -webkit-transform 500ms cubic-bezier(0.36, 0.66, 0.04, 1);opacity:1;z-index:2;pointer-events:none;will-change:transform}.item-sliding-closing ion-item-options{pointer-events:none}.item-sliding-active-swipe-end .item-options-end .item-option-expandable{padding-left:100%;-ms-flex-order:1;order:1;-webkit-transition-duration:0.6s;transition-duration:0.6s;-webkit-transition-property:padding-left;transition-property:padding-left}:host-context([dir=rtl]) .item-sliding-active-swipe-end .item-options-end .item-option-expandable{-ms-flex-order:-1;order:-1}[dir=rtl] .item-sliding-active-swipe-end .item-options-end .item-option-expandable{-ms-flex-order:-1;order:-1}@supports selector(:dir(rtl)){.item-sliding-active-swipe-end .item-options-end .item-option-expandable:dir(rtl){-ms-flex-order:-1;order:-1}}.item-sliding-active-swipe-start .item-options-start .item-option-expandable{padding-right:100%;-ms-flex-order:-1;order:-1;-webkit-transition-duration:0.6s;transition-duration:0.6s;-webkit-transition-property:padding-right;transition-property:padding-right}:host-context([dir=rtl]) .item-sliding-active-swipe-start .item-options-start .item-option-expandable{-ms-flex-order:1;order:1}[dir=rtl] .item-sliding-active-swipe-start .item-options-start .item-option-expandable{-ms-flex-order:1;order:1}@supports selector(:dir(rtl)){.item-sliding-active-swipe-start .item-options-start .item-option-expandable:dir(rtl){-ms-flex-order:1;order:1}}`;
137
+ const itemSlidingIonicCss = () => `ion-item-sliding{display:block;position:relative;width:100%;overflow:hidden;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}ion-item-sliding .item{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.item-sliding-closing ion-item-options{pointer-events:none}.item-sliding-active-swipe-end .item-options-end .item-option-expandable{padding-left:100%;-ms-flex-order:1;order:1;-webkit-transition-duration:0.6s;transition-duration:0.6s;-webkit-transition-property:padding-left;transition-property:padding-left}:host-context([dir=rtl]) .item-sliding-active-swipe-end .item-options-end .item-option-expandable{-ms-flex-order:-1;order:-1}[dir=rtl] .item-sliding-active-swipe-end .item-options-end .item-option-expandable{-ms-flex-order:-1;order:-1}@supports selector(:dir(rtl)){.item-sliding-active-swipe-end .item-options-end .item-option-expandable:dir(rtl){-ms-flex-order:-1;order:-1}}.item-sliding-active-swipe-start .item-options-start .item-option-expandable{padding-right:100%;-ms-flex-order:-1;order:-1;-webkit-transition-duration:0.6s;transition-duration:0.6s;-webkit-transition-property:padding-right;transition-property:padding-right}:host-context([dir=rtl]) .item-sliding-active-swipe-start .item-options-start .item-option-expandable{-ms-flex-order:1;order:1}[dir=rtl] .item-sliding-active-swipe-start .item-options-start .item-option-expandable{-ms-flex-order:1;order:1}@supports selector(:dir(rtl)){.item-sliding-active-swipe-start .item-options-start .item-option-expandable:dir(rtl){-ms-flex-order:1;order:1}}.item-sliding-transition-open .item{-webkit-transition:-webkit-transform var(--token-transition-time-250, 250ms) var(--token-transition-curve-smooth, cubic-bezier(0.25, 1, 0.5, 1));transition:-webkit-transform var(--token-transition-time-250, 250ms) var(--token-transition-curve-smooth, cubic-bezier(0.25, 1, 0.5, 1));transition:transform var(--token-transition-time-250, 250ms) var(--token-transition-curve-smooth, cubic-bezier(0.25, 1, 0.5, 1));transition:transform var(--token-transition-time-250, 250ms) var(--token-transition-curve-smooth, cubic-bezier(0.25, 1, 0.5, 1)), -webkit-transform var(--token-transition-time-250, 250ms) var(--token-transition-curve-smooth, cubic-bezier(0.25, 1, 0.5, 1))}.item-sliding-transition-snapback .item{-webkit-transition:-webkit-transform var(--token-transition-time-300, 300ms) var(--token-transition-curve-bounce, cubic-bezier(0.47, 0, 0.23, 1.38));transition:-webkit-transform var(--token-transition-time-300, 300ms) var(--token-transition-curve-bounce, cubic-bezier(0.47, 0, 0.23, 1.38));transition:transform var(--token-transition-time-300, 300ms) var(--token-transition-curve-bounce, cubic-bezier(0.47, 0, 0.23, 1.38));transition:transform var(--token-transition-time-300, 300ms) var(--token-transition-curve-bounce, cubic-bezier(0.47, 0, 0.23, 1.38)), -webkit-transform var(--token-transition-time-300, 300ms) var(--token-transition-curve-bounce, cubic-bezier(0.47, 0, 0.23, 1.38))}.item-sliding-confirm-item-in .item{-webkit-transition:-webkit-transform var(--token-transition-time-150, 150ms) var(--token-transition-curve-base, cubic-bezier(0.4, 0, 1, 1));transition:-webkit-transform var(--token-transition-time-150, 150ms) var(--token-transition-curve-base, cubic-bezier(0.4, 0, 1, 1));transition:transform var(--token-transition-time-150, 150ms) var(--token-transition-curve-base, cubic-bezier(0.4, 0, 1, 1));transition:transform var(--token-transition-time-150, 150ms) var(--token-transition-curve-base, cubic-bezier(0.4, 0, 1, 1)), -webkit-transform var(--token-transition-time-150, 150ms) var(--token-transition-curve-base, cubic-bezier(0.4, 0, 1, 1))}.item-sliding-confirm-item-back .item{-webkit-transition:-webkit-transform var(--token-transition-time-500, 500ms) var(--token-transition-curve-bounce, cubic-bezier(0.47, 0, 0.23, 1.38));transition:-webkit-transform var(--token-transition-time-500, 500ms) var(--token-transition-curve-bounce, cubic-bezier(0.47, 0, 0.23, 1.38));transition:transform var(--token-transition-time-500, 500ms) var(--token-transition-curve-bounce, cubic-bezier(0.47, 0, 0.23, 1.38));transition:transform var(--token-transition-time-500, 500ms) var(--token-transition-curve-bounce, cubic-bezier(0.47, 0, 0.23, 1.38)), -webkit-transform var(--token-transition-time-500, 500ms) var(--token-transition-curve-bounce, cubic-bezier(0.47, 0, 0.23, 1.38))}ion-item-option.item-sliding-expandable-width-in{-webkit-transition:width var(--token-transition-time-150, 150ms) var(--token-transition-curve-base, cubic-bezier(0.4, 0, 1, 1));transition:width var(--token-transition-time-150, 150ms) var(--token-transition-curve-base, cubic-bezier(0.4, 0, 1, 1))}ion-item-option.item-sliding-expandable-width-back{-webkit-transition:width var(--token-transition-time-500, 500ms) var(--token-transition-curve-bounce, cubic-bezier(0.47, 0, 0.23, 1.38));transition:width var(--token-transition-time-500, 500ms) var(--token-transition-curve-bounce, cubic-bezier(0.47, 0, 0.23, 1.38))}.item-sliding-active-slide .item{position:relative;opacity:1;z-index:var(--token-z-index-100, 100);pointer-events:none;will-change:transform}`;
138
+
139
+ const iosItemSlidingNativeCss = () => `ion-item-sliding{display:block;position:relative;width:100%;overflow:hidden;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}ion-item-sliding .item{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.item-sliding-closing ion-item-options{pointer-events:none}.item-sliding-active-swipe-end .item-options-end .item-option-expandable{padding-left:100%;-ms-flex-order:1;order:1;-webkit-transition-duration:0.6s;transition-duration:0.6s;-webkit-transition-property:padding-left;transition-property:padding-left}:host-context([dir=rtl]) .item-sliding-active-swipe-end .item-options-end .item-option-expandable{-ms-flex-order:-1;order:-1}[dir=rtl] .item-sliding-active-swipe-end .item-options-end .item-option-expandable{-ms-flex-order:-1;order:-1}@supports selector(:dir(rtl)){.item-sliding-active-swipe-end .item-options-end .item-option-expandable:dir(rtl){-ms-flex-order:-1;order:-1}}.item-sliding-active-swipe-start .item-options-start .item-option-expandable{padding-right:100%;-ms-flex-order:-1;order:-1;-webkit-transition-duration:0.6s;transition-duration:0.6s;-webkit-transition-property:padding-right;transition-property:padding-right}:host-context([dir=rtl]) .item-sliding-active-swipe-start .item-options-start .item-option-expandable{-ms-flex-order:1;order:1}[dir=rtl] .item-sliding-active-swipe-start .item-options-start .item-option-expandable{-ms-flex-order:1;order:1}@supports selector(:dir(rtl)){.item-sliding-active-swipe-start .item-options-start .item-option-expandable:dir(rtl){-ms-flex-order:1;order:1}}.item-sliding-active-slide .item{position:relative;-webkit-transition:-webkit-transform 500ms cubic-bezier(0.36, 0.66, 0.04, 1);transition:-webkit-transform 500ms cubic-bezier(0.36, 0.66, 0.04, 1);transition:transform 500ms cubic-bezier(0.36, 0.66, 0.04, 1);transition:transform 500ms cubic-bezier(0.36, 0.66, 0.04, 1), -webkit-transform 500ms cubic-bezier(0.36, 0.66, 0.04, 1);opacity:1;z-index:2;pointer-events:none;will-change:transform}.item-sliding-active-slide.item-sliding-full-swipe-transition .item{-webkit-transition:-webkit-transform 250ms ease-out;transition:-webkit-transform 250ms ease-out;transition:transform 250ms ease-out;transition:transform 250ms ease-out, -webkit-transform 250ms ease-out}.item-sliding-active-slide.item-sliding-dragging .item{-webkit-transition:none;transition:none}`;
140
+
141
+ const mdItemSlidingNativeCss = () => `ion-item-sliding{display:block;position:relative;width:100%;overflow:hidden;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}ion-item-sliding .item{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.item-sliding-closing ion-item-options{pointer-events:none}.item-sliding-active-swipe-end .item-options-end .item-option-expandable{padding-left:100%;-ms-flex-order:1;order:1;-webkit-transition-duration:0.6s;transition-duration:0.6s;-webkit-transition-property:padding-left;transition-property:padding-left}:host-context([dir=rtl]) .item-sliding-active-swipe-end .item-options-end .item-option-expandable{-ms-flex-order:-1;order:-1}[dir=rtl] .item-sliding-active-swipe-end .item-options-end .item-option-expandable{-ms-flex-order:-1;order:-1}@supports selector(:dir(rtl)){.item-sliding-active-swipe-end .item-options-end .item-option-expandable:dir(rtl){-ms-flex-order:-1;order:-1}}.item-sliding-active-swipe-start .item-options-start .item-option-expandable{padding-right:100%;-ms-flex-order:-1;order:-1;-webkit-transition-duration:0.6s;transition-duration:0.6s;-webkit-transition-property:padding-right;transition-property:padding-right}:host-context([dir=rtl]) .item-sliding-active-swipe-start .item-options-start .item-option-expandable{-ms-flex-order:1;order:1}[dir=rtl] .item-sliding-active-swipe-start .item-options-start .item-option-expandable{-ms-flex-order:1;order:1}@supports selector(:dir(rtl)){.item-sliding-active-swipe-start .item-options-start .item-option-expandable:dir(rtl){-ms-flex-order:1;order:1}}.item-sliding-active-slide .item{position:relative;-webkit-transition:-webkit-transform 500ms cubic-bezier(0.36, 0.66, 0.04, 1);transition:-webkit-transform 500ms cubic-bezier(0.36, 0.66, 0.04, 1);transition:transform 500ms cubic-bezier(0.36, 0.66, 0.04, 1);transition:transform 500ms cubic-bezier(0.36, 0.66, 0.04, 1), -webkit-transform 500ms cubic-bezier(0.36, 0.66, 0.04, 1);opacity:1;z-index:2;pointer-events:none;will-change:transform}.item-sliding-active-slide.item-sliding-full-swipe-transition .item{-webkit-transition:-webkit-transform 250ms ease-out;transition:-webkit-transform 250ms ease-out;transition:transform 250ms ease-out;transition:transform 250ms ease-out, -webkit-transform 250ms ease-out}.item-sliding-active-slide.item-sliding-dragging .item{-webkit-transition:none;transition:none}`;
109
142
 
110
143
  const SWIPE_MARGIN = 30;
111
144
  const ELASTIC_FACTOR = 0.55;
145
+ const IONIC_ELASTIC_FACTOR = 0.15;
146
+ const IONIC_SNAP_OPEN_RATIO = 0.4;
147
+ const IONIC_EXPAND_TRIGGER = 40;
148
+ const IONIC_FULL_SWIPE_VELOCITY_THRESHOLD = 400;
149
+ const IONIC_OPEN_VELOCITY_THRESHOLD = 200;
150
+ const IONIC_ACTION_BASE_WIDTH = 64;
151
+ const IONIC_CONFIRM_PAUSE = 300;
152
+ const FULL_SWIPE_TRANSITION_MS = 250;
153
+ const IONIC_EXPAND_RESISTANCE_FACTOR = 0.95;
154
+ /** Expandable, non-disabled option (matches item-option expandable class). */
155
+ const EXPANDABLE_OPTION_SELECTOR = 'ion-item-option.item-option-expandable:not(.item-option-disabled)';
156
+ const ITEM_OPTION_EXPAND_THRESHOLD_CLASS = 'item-option-expand-threshold';
112
157
  let openSlidingItem;
113
158
  const ItemSliding = class {
114
159
  constructor(hostRef) {
@@ -123,12 +168,17 @@ const ItemSliding = class {
123
168
  this.optsDirty = true;
124
169
  this.contentEl = null;
125
170
  this.initialContentScrollY = true;
171
+ this.leftExpandableBaseWidth = IONIC_ACTION_BASE_WIDTH;
172
+ this.rightExpandableBaseWidth = IONIC_ACTION_BASE_WIDTH;
126
173
  this.state = 2 /* SlidingState.Disabled */;
127
174
  /**
128
175
  * If `true`, the user cannot interact with the sliding item.
129
176
  */
130
177
  this.disabled = false;
131
178
  }
179
+ isIonicTheme() {
180
+ return getIonTheme(this) === 'ionic';
181
+ }
132
182
  disabledChanged() {
133
183
  if (this.gesture) {
134
184
  this.gesture.enable(!this.disabled);
@@ -162,10 +212,18 @@ const ItemSliding = class {
162
212
  this.disabledChanged();
163
213
  }
164
214
  disconnectedCallback() {
215
+ var _a;
165
216
  if (this.gesture) {
166
217
  this.gesture.destroy();
167
218
  this.gesture = undefined;
168
219
  }
220
+ if (this.tmr !== undefined) {
221
+ clearTimeout(this.tmr);
222
+ this.tmr = undefined;
223
+ }
224
+ // Abort any in-progress animation. The abort handler rejects the pending
225
+ // promise, causing animateFullSwipe's finally block to run cleanup.
226
+ (_a = this.animationAbortController) === null || _a === void 0 ? void 0 : _a.abort();
169
227
  this.item = null;
170
228
  this.leftOptions = this.rightOptions = undefined;
171
229
  if (openSlidingItem === this.el) {
@@ -199,6 +257,9 @@ const ItemSliding = class {
199
257
  */
200
258
  async open(side) {
201
259
  var _a;
260
+ if ((this.state & 128 /* SlidingState.AnimatingFullSwipe */) !== 0) {
261
+ return;
262
+ }
202
263
  /**
203
264
  * It is possible for the item to be added to the DOM
204
265
  * after the item-sliding component was created. As a result,
@@ -250,6 +311,9 @@ const ItemSliding = class {
250
311
  * Close the sliding item. Items can also be closed from the [List](./list).
251
312
  */
252
313
  async close() {
314
+ if ((this.state & 128 /* SlidingState.AnimatingFullSwipe */) !== 0) {
315
+ return;
316
+ }
253
317
  this.setOpenAmount(0, true);
254
318
  }
255
319
  /**
@@ -280,6 +344,265 @@ const ItemSliding = class {
280
344
  return this.rightOptions;
281
345
  }
282
346
  }
347
+ /**
348
+ * Check if the given item options element contains at least one expandable, non-disabled option.
349
+ */
350
+ hasExpandableOptions(options) {
351
+ if (!options)
352
+ return false;
353
+ const optionElements = options.querySelectorAll('ion-item-option');
354
+ return Array.from(optionElements).some((option) => {
355
+ return option.expandable === true && !option.disabled;
356
+ });
357
+ }
358
+ /**
359
+ * Returns a Promise that resolves after `ms` milliseconds, or rejects if the
360
+ * given AbortSignal is fired before the timer expires.
361
+ */
362
+ delay(ms, signal) {
363
+ return new Promise((resolve, reject) => {
364
+ const id = setTimeout(resolve, ms);
365
+ signal.addEventListener('abort', () => {
366
+ clearTimeout(id);
367
+ reject(new DOMException('Animation cancelled', 'AbortError'));
368
+ }, { once: true });
369
+ });
370
+ }
371
+ /**
372
+ * Animate the item to a specific position using CSS transitions.
373
+ * Returns a Promise that resolves when the animation completes, or rejects if
374
+ * the given AbortSignal is fired.
375
+ */
376
+ animateToPosition(position, duration, signal) {
377
+ return new Promise((resolve, reject) => {
378
+ if (!this.item) {
379
+ return resolve();
380
+ }
381
+ this.el.classList.add('item-sliding-full-swipe-transition');
382
+ this.item.style.transform = `translate3d(${-position}px, 0, 0)`;
383
+ const id = setTimeout(resolve, duration);
384
+ signal.addEventListener('abort', () => {
385
+ clearTimeout(id);
386
+ reject(new DOMException('Animation cancelled', 'AbortError'));
387
+ }, { once: true });
388
+ });
389
+ }
390
+ /**
391
+ * Calculate the swipe threshold distance required to trigger a full swipe animation.
392
+ * Returns the maximum options width plus a margin to ensure it's achievable.
393
+ */
394
+ getSwipeThreshold(direction) {
395
+ const maxWidth = direction === 'end' ? this.optsWidthRightSide : this.optsWidthLeftSide;
396
+ return maxWidth + SWIPE_MARGIN;
397
+ }
398
+ /**
399
+ * Native (ios/md) full swipe: off-screen → fire swipe → return.
400
+ * Ionic theme uses `animateIonicFullSwipe` instead (see `onEndIonic`).
401
+ */
402
+ async animateFullSwipe(direction) {
403
+ const abortController = new AbortController();
404
+ this.animationAbortController = abortController;
405
+ const { signal } = abortController;
406
+ // Prevent interruption during animation
407
+ if (this.gesture) {
408
+ this.gesture.enable(false);
409
+ }
410
+ try {
411
+ const options = direction === 'end' ? this.rightOptions : this.leftOptions;
412
+ // Trigger expandable state without moving the item
413
+ // Set state directly so expandable option fills its container, starting from
414
+ // the exact position where the user released, without any visual snap.
415
+ this.state =
416
+ direction === 'end'
417
+ ? 8 /* SlidingState.End */ | 32 /* SlidingState.SwipeEnd */ | 128 /* SlidingState.AnimatingFullSwipe */
418
+ : 16 /* SlidingState.Start */ | 64 /* SlidingState.SwipeStart */ | 128 /* SlidingState.AnimatingFullSwipe */;
419
+ await this.delay(100, signal);
420
+ // Animate off-screen while maintaining the expanded state
421
+ const offScreenDistance = direction === 'end' ? window.innerWidth : -window.innerWidth;
422
+ await this.animateToPosition(offScreenDistance, FULL_SWIPE_TRANSITION_MS, signal);
423
+ // Trigger action
424
+ if (options) {
425
+ options.fireSwipeEvent();
426
+ }
427
+ // Small delay before returning
428
+ await this.delay(300, signal);
429
+ // Return to closed state
430
+ await this.animateToPosition(0, FULL_SWIPE_TRANSITION_MS, signal);
431
+ }
432
+ catch (_a) {
433
+ // Animation was aborted (e.g. component disconnected). finally handles cleanup.
434
+ }
435
+ finally {
436
+ this.animationAbortController = undefined;
437
+ // Reset state
438
+ this.el.classList.remove('item-sliding-full-swipe-transition');
439
+ if (this.item) {
440
+ this.item.style.transform = '';
441
+ }
442
+ this.openAmount = 0;
443
+ this.state = 2 /* SlidingState.Disabled */;
444
+ if (openSlidingItem === this.el) {
445
+ openSlidingItem = undefined;
446
+ }
447
+ if (this.gesture) {
448
+ this.gesture.enable(!this.disabled);
449
+ }
450
+ }
451
+ }
452
+ queryExpandableOption(options) {
453
+ if (!options) {
454
+ return undefined;
455
+ }
456
+ const expandableOptions = Array.from(options.querySelectorAll(EXPANDABLE_OPTION_SELECTOR));
457
+ if (expandableOptions.length === 0) {
458
+ return undefined;
459
+ }
460
+ if (expandableOptions.length === 1) {
461
+ return expandableOptions[0];
462
+ }
463
+ const isRTL = document.dir === 'rtl';
464
+ const isEndSide = options.classList.contains('item-options-end');
465
+ // Match native edge behavior for multi-expandable configs
466
+ const pickLast = (isEndSide && !isRTL) || (!isEndSide && isRTL);
467
+ return pickLast ? expandableOptions[expandableOptions.length - 1] : expandableOptions[0];
468
+ }
469
+ getExpandableOption(direction) {
470
+ return this.queryExpandableOption(direction === 'end' ? this.rightOptions : this.leftOptions);
471
+ }
472
+ getOpenDirectionFromAmount(openAmount) {
473
+ if (openAmount > 0) {
474
+ return 'end';
475
+ }
476
+ if (openAmount < 0) {
477
+ return 'start';
478
+ }
479
+ return undefined;
480
+ }
481
+ getOptionsWidthForDirection(direction) {
482
+ return direction === 'end' ? this.optsWidthRightSide : this.optsWidthLeftSide;
483
+ }
484
+ getExpandableBaseWidth(direction) {
485
+ return direction === 'end' ? this.rightExpandableBaseWidth : this.leftExpandableBaseWidth;
486
+ }
487
+ setIonicExpandableWidth(direction, width) {
488
+ const expandableOption = this.getExpandableOption(direction);
489
+ if (!expandableOption) {
490
+ return;
491
+ }
492
+ const style = expandableOption.style;
493
+ const baseWidth = this.getExpandableBaseWidth(direction);
494
+ style.width = `${Math.max(baseWidth, width)}px`;
495
+ }
496
+ resetIonicExpandableOptions() {
497
+ [this.leftOptions, this.rightOptions].forEach((options) => {
498
+ if (!options) {
499
+ return;
500
+ }
501
+ options.querySelectorAll(EXPANDABLE_OPTION_SELECTOR).forEach((node) => {
502
+ node.classList.remove(ITEM_OPTION_EXPAND_THRESHOLD_CLASS);
503
+ });
504
+ const expandableOption = this.queryExpandableOption(options);
505
+ if (!expandableOption) {
506
+ return;
507
+ }
508
+ expandableOption.style.width = '';
509
+ expandableOption.classList.remove('item-sliding-expandable-open', 'item-sliding-expandable-snapback', 'item-sliding-expandable-width-in', 'item-sliding-expandable-width-back');
510
+ });
511
+ }
512
+ updateIonicExpandableFromOpenAmount(openAmount, isFinal, previousOpenAmount) {
513
+ var _a;
514
+ if ((this.state & 128 /* SlidingState.AnimatingFullSwipe */) !== 0) {
515
+ return;
516
+ }
517
+ const direction = this.getOpenDirectionFromAmount(openAmount);
518
+ if (direction === undefined) {
519
+ const previousDirection = this.getOpenDirectionFromAmount(previousOpenAmount);
520
+ if (previousDirection === undefined) {
521
+ this.resetIonicExpandableOptions();
522
+ return;
523
+ }
524
+ (_a = this.queryExpandableOption(previousDirection === 'end' ? this.rightOptions : this.leftOptions)) === null || _a === void 0 ? void 0 : _a.classList.remove(ITEM_OPTION_EXPAND_THRESHOLD_CLASS);
525
+ this.setIonicExpandableWidth(previousDirection, this.getExpandableBaseWidth(previousDirection));
526
+ return;
527
+ }
528
+ const baseWidth = this.getExpandableBaseWidth(direction);
529
+ const optionsWidth = this.getOptionsWidthForDirection(direction);
530
+ const extraWidth = Math.max(0, Math.abs(openAmount) - optionsWidth);
531
+ const resistedExtraWidth = isFinal ? extraWidth : extraWidth * IONIC_EXPAND_RESISTANCE_FACTOR;
532
+ const targetWidth = baseWidth + resistedExtraWidth;
533
+ const expandableOption = this.getExpandableOption(direction);
534
+ if (expandableOption) {
535
+ if (!isFinal && extraWidth >= IONIC_EXPAND_TRIGGER) {
536
+ expandableOption.classList.add(ITEM_OPTION_EXPAND_THRESHOLD_CLASS);
537
+ }
538
+ else {
539
+ expandableOption.classList.remove(ITEM_OPTION_EXPAND_THRESHOLD_CLASS);
540
+ }
541
+ }
542
+ this.setIonicExpandableWidth(direction, targetWidth);
543
+ }
544
+ async animateIonicFullSwipe(direction) {
545
+ const abortController = new AbortController();
546
+ this.animationAbortController = abortController;
547
+ const { signal } = abortController;
548
+ const expandableOption = this.getExpandableOption(direction);
549
+ const options = direction === 'end' ? this.rightOptions : this.leftOptions;
550
+ if (this.gesture) {
551
+ this.gesture.enable(false);
552
+ }
553
+ try {
554
+ this.state =
555
+ direction === 'end'
556
+ ? 8 /* SlidingState.End */ | 128 /* SlidingState.AnimatingFullSwipe */
557
+ : 16 /* SlidingState.Start */ | 128 /* SlidingState.AnimatingFullSwipe */;
558
+ if (!this.item) {
559
+ return;
560
+ }
561
+ const itemWidth = this.el.offsetWidth || window.innerWidth;
562
+ const baseWidth = this.getExpandableBaseWidth(direction);
563
+ const expandableTargetWidth = Math.max(baseWidth, itemWidth - 16);
564
+ const offScreenPosition = direction === 'end' ? itemWidth : -itemWidth;
565
+ if (expandableOption) {
566
+ expandableOption.classList.remove('item-sliding-expandable-width-back');
567
+ expandableOption.classList.add('item-sliding-expandable-width-in');
568
+ expandableOption.style.width = `${expandableTargetWidth}px`;
569
+ }
570
+ this.el.classList.remove('item-sliding-confirm-item-back');
571
+ this.el.classList.add('item-sliding-confirm-item-in');
572
+ this.item.style.transform = `translate3d(${-offScreenPosition}px, 0, 0)`;
573
+ await this.delay(150, signal);
574
+ options === null || options === void 0 ? void 0 : options.fireSwipeEvent();
575
+ await this.delay(IONIC_CONFIRM_PAUSE, signal);
576
+ if (expandableOption) {
577
+ expandableOption.classList.remove('item-sliding-expandable-width-in');
578
+ expandableOption.classList.add('item-sliding-expandable-width-back');
579
+ expandableOption.style.width = `${baseWidth}px`;
580
+ }
581
+ this.el.classList.remove('item-sliding-confirm-item-in');
582
+ this.el.classList.add('item-sliding-confirm-item-back');
583
+ this.item.style.transform = 'translate3d(0, 0, 0)';
584
+ await this.delay(500, signal);
585
+ }
586
+ catch (_a) {
587
+ // Animation was aborted. finally handles cleanup.
588
+ }
589
+ finally {
590
+ this.animationAbortController = undefined;
591
+ this.el.classList.remove('item-sliding-confirm-item-in', 'item-sliding-confirm-item-back');
592
+ if (this.item) {
593
+ this.item.style.transform = '';
594
+ }
595
+ this.resetIonicExpandableOptions();
596
+ this.openAmount = 0;
597
+ this.state = 2 /* SlidingState.Disabled */;
598
+ if (openSlidingItem === this.el) {
599
+ openSlidingItem = undefined;
600
+ }
601
+ if (this.gesture) {
602
+ this.gesture.enable(!this.disabled);
603
+ }
604
+ }
605
+ }
283
606
  async updateOptions() {
284
607
  var _a;
285
608
  const options = this.el.querySelectorAll('ion-item-options');
@@ -347,7 +670,12 @@ const ItemSliding = class {
347
670
  }
348
671
  this.initialOpenAmount = this.openAmount;
349
672
  if (this.item) {
350
- this.item.style.transition = 'none';
673
+ if (this.isIonicTheme()) {
674
+ this.el.classList.remove('item-sliding-transition-open', 'item-sliding-transition-snapback');
675
+ }
676
+ else {
677
+ this.el.classList.add('item-sliding-dragging');
678
+ }
351
679
  }
352
680
  }
353
681
  onMove(gesture) {
@@ -370,22 +698,63 @@ const ItemSliding = class {
370
698
  printIonWarning('[ion-item-sliding] - invalid ItemSideFlags value', this.sides);
371
699
  break;
372
700
  }
373
- let optsWidth;
374
- if (openAmount > this.optsWidthRightSide) {
375
- optsWidth = this.optsWidthRightSide;
376
- openAmount = optsWidth + (openAmount - optsWidth) * ELASTIC_FACTOR;
701
+ if (this.isIonicTheme()) {
702
+ if (openAmount > this.optsWidthRightSide) {
703
+ const overDrag = openAmount - this.optsWidthRightSide;
704
+ openAmount = this.optsWidthRightSide + overDrag * IONIC_ELASTIC_FACTOR;
705
+ }
706
+ else if (openAmount < -this.optsWidthLeftSide) {
707
+ const overDrag = openAmount + this.optsWidthLeftSide;
708
+ openAmount = -this.optsWidthLeftSide + overDrag * IONIC_ELASTIC_FACTOR;
709
+ }
377
710
  }
378
- else if (openAmount < -this.optsWidthLeftSide) {
379
- optsWidth = -this.optsWidthLeftSide;
380
- openAmount = optsWidth + (openAmount - optsWidth) * ELASTIC_FACTOR;
711
+ else {
712
+ let optsWidth;
713
+ if (openAmount > this.optsWidthRightSide) {
714
+ optsWidth = this.optsWidthRightSide;
715
+ openAmount = optsWidth + (openAmount - optsWidth) * ELASTIC_FACTOR;
716
+ }
717
+ else if (openAmount < -this.optsWidthLeftSide) {
718
+ optsWidth = -this.optsWidthLeftSide;
719
+ openAmount = optsWidth + (openAmount - optsWidth) * ELASTIC_FACTOR;
720
+ }
381
721
  }
382
722
  this.setOpenAmount(openAmount, false);
383
723
  }
384
724
  onEnd(gesture) {
725
+ this.el.classList.remove('item-sliding-dragging');
726
+ this.restoreContentScrollAfterSlide();
727
+ if (this.isIonicTheme()) {
728
+ this.onEndIonic(gesture);
729
+ }
730
+ else {
731
+ this.onEndNative(gesture);
732
+ }
733
+ }
734
+ restoreContentScrollAfterSlide() {
385
735
  const { contentEl, initialContentScrollY } = this;
386
736
  if (contentEl) {
387
737
  resetContentScrollY(contentEl, initialContentScrollY);
388
738
  }
739
+ }
740
+ onEndNative(gesture) {
741
+ // Check for full swipe conditions with expandable options
742
+ const rawSwipeDistance = Math.abs(gesture.deltaX);
743
+ const direction = gesture.deltaX < 0 ? 'end' : 'start';
744
+ const options = direction === 'end' ? this.rightOptions : this.leftOptions;
745
+ const hasExpandable = this.hasExpandableOptions(options);
746
+ const shouldTriggerFullSwipe = hasExpandable &&
747
+ (rawSwipeDistance > this.getSwipeThreshold(direction) ||
748
+ (Math.abs(gesture.velocityX) > 0.5 &&
749
+ rawSwipeDistance > (direction === 'end' ? this.optsWidthRightSide : this.optsWidthLeftSide) * 0.5));
750
+ if (shouldTriggerFullSwipe) {
751
+ this.animateFullSwipe(direction).catch(() => {
752
+ if (this.gesture) {
753
+ this.gesture.enable(!this.disabled);
754
+ }
755
+ });
756
+ return;
757
+ }
389
758
  const velocity = gesture.velocityX;
390
759
  let restingPoint = this.openAmount > 0 ? this.optsWidthRightSide : -this.optsWidthLeftSide;
391
760
  // Check if the drag didn't clear the buttons mid-point
@@ -405,17 +774,64 @@ const ItemSliding = class {
405
774
  this.leftOptions.fireSwipeEvent();
406
775
  }
407
776
  }
777
+ onEndIonic(gesture) {
778
+ const velocity = gesture.velocityX;
779
+ const velocityX = velocity * 1000;
780
+ const activeDirection = this.getOpenDirectionFromAmount(this.openAmount);
781
+ if (activeDirection === undefined) {
782
+ this.setOpenAmount(0, true);
783
+ return;
784
+ }
785
+ const optionsWidth = this.getOptionsWidthForDirection(activeDirection);
786
+ const extraWidth = Math.max(0, Math.abs(this.openAmount) - optionsWidth);
787
+ const hasExpandable = this.hasExpandableOptions(activeDirection === 'end' ? this.rightOptions : this.leftOptions);
788
+ const closeDirection = activeDirection === 'end'
789
+ ? velocityX > IONIC_FULL_SWIPE_VELOCITY_THRESHOLD
790
+ : velocityX < -400;
791
+ if (closeDirection) {
792
+ this.setOpenAmount(0, true);
793
+ return;
794
+ }
795
+ if (hasExpandable &&
796
+ (extraWidth >= IONIC_EXPAND_TRIGGER ||
797
+ (extraWidth > 0 && Math.abs(velocityX) > IONIC_FULL_SWIPE_VELOCITY_THRESHOLD))) {
798
+ this.animateIonicFullSwipe(activeDirection).catch(() => {
799
+ if (this.gesture) {
800
+ this.gesture.enable(!this.disabled);
801
+ }
802
+ });
803
+ return;
804
+ }
805
+ const flickOpen = activeDirection === 'end'
806
+ ? velocityX < -200
807
+ : velocityX > IONIC_OPEN_VELOCITY_THRESHOLD;
808
+ const fullOpen = activeDirection === 'end' ? this.optsWidthRightSide : -this.optsWidthLeftSide;
809
+ const openThreshold = optionsWidth * IONIC_SNAP_OPEN_RATIO;
810
+ const shouldSnapOpen = flickOpen || Math.abs(this.openAmount) > openThreshold;
811
+ const restingPoint = shouldSnapOpen ? fullOpen : 0;
812
+ this.setOpenAmount(restingPoint, true);
813
+ }
408
814
  calculateOptsWidth() {
409
815
  this.optsWidthRightSide = 0;
410
816
  if (this.rightOptions) {
411
817
  this.rightOptions.style.display = 'flex';
412
818
  this.optsWidthRightSide = this.rightOptions.offsetWidth;
819
+ const rightExpandable = this.queryExpandableOption(this.rightOptions);
820
+ if (rightExpandable) {
821
+ rightExpandable.style.width = '';
822
+ this.rightExpandableBaseWidth = Math.max(IONIC_ACTION_BASE_WIDTH, rightExpandable.getBoundingClientRect().width);
823
+ }
413
824
  this.rightOptions.style.display = '';
414
825
  }
415
826
  this.optsWidthLeftSide = 0;
416
827
  if (this.leftOptions) {
417
828
  this.leftOptions.style.display = 'flex';
418
829
  this.optsWidthLeftSide = this.leftOptions.offsetWidth;
830
+ const leftExpandable = this.queryExpandableOption(this.leftOptions);
831
+ if (leftExpandable) {
832
+ leftExpandable.style.width = '';
833
+ this.leftExpandableBaseWidth = Math.max(IONIC_ACTION_BASE_WIDTH, leftExpandable.getBoundingClientRect().width);
834
+ }
419
835
  this.leftOptions.style.display = '';
420
836
  }
421
837
  this.optsDirty = false;
@@ -430,35 +846,30 @@ const ItemSliding = class {
430
846
  }
431
847
  const { el } = this;
432
848
  const style = this.item.style;
849
+ const previousOpenAmount = this.openAmount;
433
850
  this.openAmount = openAmount;
434
- if (isFinal) {
435
- style.transition = '';
851
+ if (this.isIonicTheme()) {
852
+ this.updateIonicExpandableFromOpenAmount(openAmount, isFinal, previousOpenAmount);
853
+ }
854
+ if (this.isIonicTheme() && isFinal) {
855
+ const closing = Math.abs(openAmount) < Math.abs(previousOpenAmount);
856
+ if (closing) {
857
+ this.el.classList.add('item-sliding-transition-snapback');
858
+ }
859
+ else {
860
+ this.el.classList.add('item-sliding-transition-open');
861
+ }
436
862
  }
437
863
  if (openAmount > 0) {
438
- this.state =
439
- openAmount >= this.optsWidthRightSide + SWIPE_MARGIN
440
- ? 8 /* SlidingState.End */ | 32 /* SlidingState.SwipeEnd */
441
- : 8 /* SlidingState.End */;
864
+ const fullSwipe = !this.isIonicTheme() && openAmount >= this.optsWidthRightSide + SWIPE_MARGIN;
865
+ this.state = fullSwipe ? 8 /* SlidingState.End */ | 32 /* SlidingState.SwipeEnd */ : 8 /* SlidingState.End */;
442
866
  }
443
867
  else if (openAmount < 0) {
444
- this.state =
445
- openAmount <= -this.optsWidthLeftSide - SWIPE_MARGIN
446
- ? 16 /* SlidingState.Start */ | 64 /* SlidingState.SwipeStart */
447
- : 16 /* SlidingState.Start */;
868
+ const fullSwipe = !this.isIonicTheme() && openAmount <= -this.optsWidthLeftSide - SWIPE_MARGIN;
869
+ this.state = fullSwipe ? 16 /* SlidingState.Start */ | 64 /* SlidingState.SwipeStart */ : 16 /* SlidingState.Start */;
448
870
  }
449
871
  else {
450
- /**
451
- * The sliding options should not be
452
- * clickable while the item is closing.
453
- */
454
872
  el.classList.add('item-sliding-closing');
455
- /**
456
- * Item sliding cannot be interrupted
457
- * while closing the item. If it did,
458
- * it would allow the item to get into an
459
- * inconsistent state where multiple
460
- * items are then open at the same time.
461
- */
462
873
  if (this.gesture) {
463
874
  this.gesture.enable(false);
464
875
  }
@@ -492,9 +903,9 @@ const ItemSliding = class {
492
903
  }
493
904
  }
494
905
  render() {
495
- const mode = getIonMode(this);
496
- return (h(Host, { key: '8fd81d74701402294a48b79c56d6eceadafd4881', class: {
497
- [mode]: true,
906
+ const theme = getIonTheme(this);
907
+ return (h(Host, { key: 'e6890a1b14faaf9121a07912b1c2f46e06148202', class: {
908
+ [theme]: true,
498
909
  'item-sliding-active-slide': this.state !== 2 /* SlidingState.Disabled */,
499
910
  'item-sliding-active-options-end': (this.state & 8 /* SlidingState.End */) !== 0,
500
911
  'item-sliding-active-options-start': (this.state & 16 /* SlidingState.Start */) !== 0,
@@ -526,6 +937,10 @@ const swipeShouldReset = (isResetDirection, isMovingFast, isOnResetZone) => {
526
937
  // The resulting expression was generated by resolving the K-map (Karnaugh map):
527
938
  return (!isMovingFast && isOnResetZone) || (isResetDirection && isMovingFast);
528
939
  };
529
- ItemSliding.style = itemSlidingCss();
940
+ ItemSliding.style = {
941
+ ionic: itemSlidingIonicCss(),
942
+ ios: iosItemSlidingNativeCss(),
943
+ md: mdItemSlidingNativeCss()
944
+ };
530
945
 
531
946
  export { ItemOption as ion_item_option, ItemOptions as ion_item_options, ItemSliding as ion_item_sliding };