@ionic/core 8.6.0 → 8.6.1-dev.11749483665.140e610d

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 (1082) hide show
  1. package/components/action-sheet.js +13 -9
  2. package/components/alert.js +14 -11
  3. package/components/animation.js +1 -1
  4. package/components/backdrop.js +9 -6
  5. package/components/button.js +41 -10
  6. package/components/buttons.js +11 -8
  7. package/components/capacitor.js +1 -1
  8. package/components/caret-down.js +6 -0
  9. package/components/caret-left.js +6 -0
  10. package/components/caret-right.js +6 -0
  11. package/components/checkbox.js +31 -12
  12. package/components/content.js +14 -12
  13. package/components/data.js +5 -5
  14. package/components/focus-visible.js +23 -1
  15. package/components/framework-delegate.js +3 -1
  16. package/components/header.js +28 -16
  17. package/components/helpers.js +42 -3
  18. package/components/index5.js +8 -8
  19. package/components/index6.js +3 -3
  20. package/components/index7.js +111 -150
  21. package/components/index8.js +150 -111
  22. package/components/input-shims.js +2 -2
  23. package/components/input.utils.js +1 -1
  24. package/components/ion-accordion-group.js +23 -5
  25. package/components/ion-accordion.js +32 -21
  26. package/components/ion-app.js +14 -77
  27. package/components/ion-avatar.js +58 -5
  28. package/components/ion-back-button.js +27 -19
  29. package/components/ion-badge.js +73 -9
  30. package/components/ion-breadcrumb.js +43 -10
  31. package/components/ion-breadcrumbs.js +8 -5
  32. package/components/ion-card-content.js +10 -7
  33. package/components/ion-card-header.js +9 -6
  34. package/components/ion-card-subtitle.js +8 -5
  35. package/components/ion-card-title.js +8 -5
  36. package/components/ion-card.js +21 -9
  37. package/components/ion-chip.js +53 -8
  38. package/components/ion-col.js +5 -5
  39. package/components/ion-datetime-button.js +8 -5
  40. package/components/ion-datetime.js +98 -21
  41. package/components/ion-divider.d.ts +11 -0
  42. package/components/ion-divider.js +70 -0
  43. package/components/ion-fab-button.js +31 -15
  44. package/components/ion-fab-list.js +5 -5
  45. package/components/ion-fab.js +6 -6
  46. package/components/ion-footer.js +18 -13
  47. package/components/ion-grid.js +5 -5
  48. package/components/ion-img.js +5 -2
  49. package/components/ion-infinite-scroll-content.js +11 -8
  50. package/components/ion-infinite-scroll.js +5 -5
  51. package/components/ion-input-otp.js +4 -4
  52. package/components/ion-input-password-toggle.js +51 -13
  53. package/components/ion-input.js +120 -28
  54. package/components/ion-item-divider.js +8 -5
  55. package/components/ion-item-group.js +8 -5
  56. package/components/ion-item-option.js +36 -9
  57. package/components/ion-item-options.js +10 -7
  58. package/components/ion-item-sliding.js +5 -5
  59. package/components/ion-loading.js +12 -9
  60. package/components/ion-menu-button.js +26 -10
  61. package/components/ion-menu-toggle.js +5 -5
  62. package/components/ion-menu.js +10 -8
  63. package/components/ion-nav-link.js +1 -1
  64. package/components/ion-nav.js +7 -5
  65. package/components/ion-note.js +8 -5
  66. package/components/ion-picker-legacy.js +7 -7
  67. package/components/ion-progress-bar.js +25 -7
  68. package/components/ion-range.js +12 -9
  69. package/components/ion-refresher-content.js +23 -8
  70. package/components/ion-refresher.js +10 -7
  71. package/components/ion-reorder-group.js +5 -5
  72. package/components/ion-reorder.js +30 -5
  73. package/components/ion-router-link.js +6 -6
  74. package/components/ion-router-outlet.js +4 -4
  75. package/components/ion-row.js +5 -2
  76. package/components/ion-searchbar.js +137 -23
  77. package/components/ion-segment-button.js +10 -7
  78. package/components/ion-segment-content.js +1 -1
  79. package/components/ion-segment-view.js +5 -2
  80. package/components/ion-segment.js +10 -7
  81. package/components/ion-select-option.js +5 -2
  82. package/components/ion-select.js +117 -33
  83. package/components/ion-skeleton-text.js +5 -5
  84. package/components/ion-split-pane.js +11 -8
  85. package/components/ion-tab-bar.js +39 -9
  86. package/components/ion-tab-button.js +25 -7
  87. package/components/ion-tab.js +2 -2
  88. package/components/ion-tabs.js +2 -2
  89. package/components/ion-text.js +5 -5
  90. package/components/ion-textarea.js +52 -11
  91. package/components/ion-thumbnail.js +5 -2
  92. package/components/ion-toast.js +37 -12
  93. package/components/ion-toggle.js +74 -17
  94. package/components/ionic-global.js +349 -15
  95. package/components/ios.transition.js +1 -0
  96. package/components/item.js +39 -14
  97. package/components/keyboard-controller.js +4 -2
  98. package/components/label.js +8 -5
  99. package/components/list-header.js +10 -7
  100. package/components/list.js +27 -6
  101. package/components/list2.js +6 -0
  102. package/components/modal.js +48 -20
  103. package/components/notch-controller.js +1 -1
  104. package/components/overlays.js +3 -4
  105. package/components/picker-column-option.js +8 -5
  106. package/components/picker-column.js +7 -8
  107. package/components/picker-column2.js +4 -4
  108. package/components/picker.js +7 -4
  109. package/components/popover.js +12 -9
  110. package/components/radio-group.js +10 -5
  111. package/components/radio.js +11 -8
  112. package/components/ripple-effect.js +15 -7
  113. package/components/select-modal.js +4 -4
  114. package/components/select-popover.js +8 -2
  115. package/components/spinner.js +31 -8
  116. package/components/status-tap.js +1 -1
  117. package/components/title.js +10 -7
  118. package/components/toolbar.js +137 -9
  119. package/components/x.js +6 -0
  120. package/css/core.css +1 -1
  121. package/css/core.css.map +1 -1
  122. package/css/display.css +1 -1
  123. package/css/display.css.map +1 -1
  124. package/css/flex-utils.css +1 -1
  125. package/css/flex-utils.css.map +1 -1
  126. package/css/float-elements.css.map +1 -1
  127. package/css/global.bundle.css.map +1 -1
  128. package/css/ionic/bundle.ionic.css +1 -0
  129. package/css/ionic/bundle.ionic.css.map +1 -0
  130. package/css/ionic/core.ionic.css +1 -0
  131. package/css/ionic/core.ionic.css.map +1 -0
  132. package/css/ionic/global.bundle.ionic.css +1 -0
  133. package/css/ionic/global.bundle.ionic.css.map +1 -0
  134. package/css/ionic/ionic-swiper.ionic.css +1 -0
  135. package/css/ionic/ionic-swiper.ionic.css.map +1 -0
  136. package/css/ionic/link.ionic.css +1 -0
  137. package/css/ionic/link.ionic.css.map +1 -0
  138. package/css/ionic/structure.ionic.css +1 -0
  139. package/css/ionic/structure.ionic.css.map +1 -0
  140. package/css/ionic/typography.ionic.css +1 -0
  141. package/css/ionic/typography.ionic.css.map +1 -0
  142. package/css/ionic/utils.bundle.ionic.css +1 -0
  143. package/css/ionic/utils.bundle.ionic.css.map +1 -0
  144. package/css/ionic-swiper.css +1 -1
  145. package/css/ionic-swiper.css.map +1 -1
  146. package/css/ionic.bundle.css +1 -1
  147. package/css/ionic.bundle.css.map +1 -1
  148. package/css/normalize.css.map +1 -1
  149. package/css/padding.css.map +1 -1
  150. package/css/palettes/dark.always.css.map +1 -1
  151. package/css/palettes/dark.class.css.map +1 -1
  152. package/css/palettes/dark.system.css.map +1 -1
  153. package/css/palettes/high-contrast-dark.always.css.map +1 -1
  154. package/css/palettes/high-contrast-dark.class.css.map +1 -1
  155. package/css/palettes/high-contrast-dark.system.css.map +1 -1
  156. package/css/palettes/high-contrast.always.css.map +1 -1
  157. package/css/palettes/high-contrast.class.css.map +1 -1
  158. package/css/palettes/high-contrast.system.css.map +1 -1
  159. package/css/structure.css.map +1 -1
  160. package/css/text-alignment.css.map +1 -1
  161. package/css/text-transformation.css.map +1 -1
  162. package/css/typography.css.map +1 -1
  163. package/css/utils.bundle.css +1 -1
  164. package/css/utils.bundle.css.map +1 -1
  165. package/dist/cjs/{animation-0T7gKwOt.js → animation-Bcz4qmJk.js} +2 -3
  166. package/dist/cjs/{button-active-C-4ud7Ht.js → button-active-1nO6qpCH.js} +2 -2
  167. package/dist/cjs/{capacitor-DmA66EwP.js → capacitor-CzFst28-.js} +1 -1
  168. package/dist/cjs/caret-down-vtVgfXIs.js +8 -0
  169. package/dist/cjs/caret-left-CxZXLRv5.js +8 -0
  170. package/dist/cjs/caret-right-CRCgv98E.js +8 -0
  171. package/dist/cjs/{config-U7OAuj53.js → config-DGKt4XfG.js} +1 -1
  172. package/dist/cjs/{data-DRqa6oM4.js → data-B3i-krcw.js} +6 -6
  173. package/dist/{esm/focus-visible-BmVRXR1y.js → cjs/focus-visible-BIj-I3-C.js} +27 -1
  174. package/dist/cjs/{framework-delegate-C7sIJyT5.js → framework-delegate-DfEY5uyC.js} +4 -2
  175. package/dist/cjs/{haptic-ClPPQ_PS.js → haptic-DbqPcCc9.js} +1 -1
  176. package/dist/cjs/{helpers-BITAzJfi.js → helpers-DmAvmm2T.js} +42 -3
  177. package/dist/cjs/{index-CVa6JE57.js → index-CaZ3uzAD.js} +2 -2
  178. package/dist/cjs/{index-DODXXb_r.js → index-CmckMMX1.js} +352 -12
  179. package/dist/cjs/{index-CPbAsnJK.js → index-DPBLiXfW.js} +2 -2
  180. package/dist/cjs/{index-CxfLS2mX.js → index-DcPe_YcG.js} +12 -12
  181. package/dist/cjs/{index-y0QaNtCi.js → index-DxVhwe3d.js} +4 -4
  182. package/dist/cjs/{index-BDBT0u4l.js → index-YEjC0pvJ.js} +3 -3
  183. package/dist/cjs/index.cjs.js +11 -12
  184. package/dist/cjs/{input-shims-D1Mfgd4s.js → input-shims-BwdlNkON.js} +6 -6
  185. package/dist/cjs/{input.utils-DSoBEyUu.js → input.utils-CfjyQhpu.js} +3 -4
  186. package/dist/cjs/ion-accordion_2.cjs.entry.js +56 -27
  187. package/dist/cjs/ion-action-sheet.cjs.entry.js +21 -18
  188. package/dist/cjs/ion-alert.cjs.entry.js +23 -21
  189. package/dist/cjs/ion-app_8.cjs.entry.js +229 -144
  190. package/dist/cjs/ion-avatar_3.cjs.entry.js +123 -11
  191. package/dist/cjs/ion-back-button.cjs.entry.js +29 -20
  192. package/dist/cjs/ion-backdrop.cjs.entry.js +9 -6
  193. package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +52 -16
  194. package/dist/cjs/ion-button_2.cjs.entry.js +43 -11
  195. package/dist/cjs/ion-card_5.cjs.entry.js +53 -29
  196. package/dist/cjs/ion-checkbox.cjs.entry.js +31 -13
  197. package/dist/cjs/ion-chip.cjs.entry.js +48 -7
  198. package/dist/cjs/ion-col_3.cjs.entry.js +13 -10
  199. package/dist/cjs/ion-datetime-button.cjs.entry.js +11 -7
  200. package/dist/cjs/ion-datetime_3.cjs.entry.js +114 -39
  201. package/dist/cjs/ion-divider.cjs.entry.js +50 -0
  202. package/dist/cjs/ion-fab_3.cjs.entry.js +42 -26
  203. package/dist/cjs/ion-img.cjs.entry.js +7 -3
  204. package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +18 -14
  205. package/dist/cjs/ion-input-otp.cjs.entry.js +6 -5
  206. package/dist/cjs/ion-input-password-toggle.cjs.entry.js +51 -13
  207. package/dist/cjs/ion-input.cjs.entry.js +121 -31
  208. package/dist/cjs/ion-item-option_3.cjs.entry.js +48 -19
  209. package/dist/cjs/ion-item_8.cjs.entry.js +106 -46
  210. package/dist/cjs/ion-loading.cjs.entry.js +18 -16
  211. package/dist/cjs/ion-menu_3.cjs.entry.js +45 -27
  212. package/dist/cjs/ion-modal.cjs.entry.js +80 -53
  213. package/dist/cjs/ion-nav_2.cjs.entry.js +13 -10
  214. package/dist/cjs/ion-picker-column-option.cjs.entry.js +10 -6
  215. package/dist/cjs/ion-picker-column.cjs.entry.js +12 -12
  216. package/dist/cjs/ion-picker.cjs.entry.js +10 -6
  217. package/dist/cjs/ion-popover.cjs.entry.js +18 -16
  218. package/dist/cjs/ion-progress-bar.cjs.entry.js +25 -7
  219. package/dist/cjs/ion-radio_2.cjs.entry.js +22 -13
  220. package/dist/cjs/ion-range.cjs.entry.js +14 -10
  221. package/dist/cjs/ion-refresher_2.cjs.entry.js +38 -20
  222. package/dist/cjs/ion-reorder_2.cjs.entry.js +37 -13
  223. package/dist/cjs/ion-ripple-effect.cjs.entry.js +14 -6
  224. package/dist/cjs/ion-route_4.cjs.entry.js +8 -7
  225. package/dist/cjs/ion-searchbar.cjs.entry.js +135 -22
  226. package/dist/cjs/ion-segment-content.cjs.entry.js +2 -2
  227. package/dist/cjs/ion-segment-view.cjs.entry.js +6 -3
  228. package/dist/cjs/ion-segment_2.cjs.entry.js +21 -14
  229. package/dist/cjs/ion-select-modal.cjs.entry.js +8 -9
  230. package/dist/cjs/ion-select_3.cjs.entry.js +130 -39
  231. package/dist/cjs/ion-spinner.cjs.entry.js +28 -6
  232. package/dist/cjs/ion-split-pane.cjs.entry.js +11 -8
  233. package/dist/cjs/ion-tab-bar_2.cjs.entry.js +65 -20
  234. package/dist/cjs/ion-tab_2.cjs.entry.js +8 -7
  235. package/dist/cjs/ion-text.cjs.entry.js +5 -5
  236. package/dist/cjs/ion-textarea.cjs.entry.js +55 -15
  237. package/dist/cjs/ion-toast.cjs.entry.js +65 -42
  238. package/dist/cjs/ion-toggle.cjs.entry.js +79 -22
  239. package/dist/cjs/ionic.cjs.js +2 -2
  240. package/dist/cjs/{ios.transition-baEy2tr4.js → ios.transition-BMRClUxZ.js} +6 -5
  241. package/dist/cjs/{keyboard-UuAS4D_9.js → keyboard-Chl5cusY.js} +1 -1
  242. package/dist/cjs/{keyboard-controller-GXBiBRKS.js → keyboard-controller-yLvXRMuh.js} +4 -3
  243. package/dist/cjs/{keyboard-hHzlEQpk.js → keyboard-nXDIskl9.js} +3 -3
  244. package/dist/cjs/list-a-7GSA6K.js +8 -0
  245. package/dist/cjs/loader.cjs.js +2 -2
  246. package/dist/cjs/{md.transition-Bvc-JrM5.js → md.transition-D2ZL4jgW.js} +5 -5
  247. package/dist/cjs/{notch-controller-BAbqGXRi.js → notch-controller-S50JyZJs.js} +2 -2
  248. package/dist/cjs/{overlays-DRDumz2b.js → overlays-DbrifhWu.js} +13 -14
  249. package/dist/cjs/{status-tap-Db3WeCkO.js → status-tap-DMaRrHIS.js} +4 -3
  250. package/dist/cjs/{swipe-back-D_VN6H9r.js → swipe-back-CEVlQT7C.js} +3 -2
  251. package/dist/cjs/x-BTF99yFH.js +8 -0
  252. package/dist/collection/collection-manifest.json +1 -0
  253. package/dist/collection/components/accordion/accordion.ionic.css +197 -0
  254. package/dist/collection/components/accordion/accordion.ios.css +73 -58
  255. package/dist/collection/components/accordion/accordion.js +36 -26
  256. package/dist/collection/components/accordion/accordion.md.css +67 -59
  257. package/dist/collection/components/accordion-group/accordion-group.ionic.css +95 -0
  258. package/dist/collection/components/accordion-group/accordion-group.ios.css +16 -4
  259. package/dist/collection/components/accordion-group/accordion-group.js +44 -8
  260. package/dist/collection/components/accordion-group/accordion-group.md.css +22 -4
  261. package/dist/collection/components/action-sheet/action-sheet.ios.css +18 -6
  262. package/dist/collection/components/action-sheet/action-sheet.js +15 -11
  263. package/dist/collection/components/action-sheet/action-sheet.md.css +17 -5
  264. package/dist/collection/components/alert/alert.ios.css +19 -1
  265. package/dist/collection/components/alert/alert.js +16 -13
  266. package/dist/collection/components/alert/alert.md.css +19 -1
  267. package/dist/collection/components/app/app.js +22 -80
  268. package/dist/collection/components/avatar/avatar.ionic.css +365 -0
  269. package/dist/collection/components/avatar/avatar.ios.css +7 -33
  270. package/dist/collection/components/avatar/avatar.js +120 -4
  271. package/dist/collection/components/avatar/avatar.md.css +51 -0
  272. package/dist/collection/components/back-button/back-button.ios.css +60 -48
  273. package/dist/collection/components/back-button/back-button.js +27 -19
  274. package/dist/collection/components/back-button/back-button.md.css +60 -48
  275. package/dist/collection/components/backdrop/backdrop.ionic.css +111 -0
  276. package/dist/collection/components/backdrop/backdrop.ios.css +56 -19
  277. package/dist/collection/components/backdrop/backdrop.js +12 -6
  278. package/dist/collection/components/backdrop/backdrop.md.css +56 -19
  279. package/dist/collection/components/badge/badge.ionic.css +277 -0
  280. package/dist/collection/components/badge/badge.ios.css +139 -12
  281. package/dist/collection/components/badge/badge.js +145 -9
  282. package/dist/collection/components/badge/badge.md.css +123 -12
  283. package/dist/collection/components/breadcrumb/breadcrumb.ios.css +20 -8
  284. package/dist/collection/components/breadcrumb/breadcrumb.js +43 -11
  285. package/dist/collection/components/breadcrumb/breadcrumb.md.css +20 -8
  286. package/dist/collection/components/breadcrumbs/breadcrumbs.ios.css +6 -0
  287. package/dist/collection/components/breadcrumbs/breadcrumbs.js +11 -9
  288. package/dist/collection/components/breadcrumbs/breadcrumbs.md.css +6 -0
  289. package/dist/collection/components/button/button.ionic.css +622 -0
  290. package/dist/collection/components/button/button.ios.css +135 -46
  291. package/dist/collection/components/button/button.js +48 -17
  292. package/dist/collection/components/button/button.md.css +126 -50
  293. package/dist/collection/components/buttons/buttons.ionic.css +100 -0
  294. package/dist/collection/components/buttons/buttons.ios.css +59 -7
  295. package/dist/collection/components/buttons/buttons.js +15 -9
  296. package/dist/collection/components/buttons/buttons.md.css +55 -3
  297. package/dist/collection/components/card/card.ionic.css +146 -0
  298. package/dist/collection/components/card/card.ios.css +65 -14
  299. package/dist/collection/components/card/card.js +41 -10
  300. package/dist/collection/components/card/card.md.css +65 -14
  301. package/dist/collection/components/card-content/card-content.ionic.css +94 -0
  302. package/dist/collection/components/card-content/card-content.ios.css +16 -1
  303. package/dist/collection/components/card-content/card-content.js +11 -8
  304. package/dist/collection/components/card-content/card-content.md.css +16 -1
  305. package/dist/collection/components/card-header/card-header.ionic.css +87 -0
  306. package/dist/collection/components/card-header/card-header.ios.css +27 -15
  307. package/dist/collection/components/card-header/card-header.js +13 -10
  308. package/dist/collection/components/card-header/card-header.md.css +27 -15
  309. package/dist/collection/components/card-subtitle/card-subtitle.ionic.css +146 -0
  310. package/dist/collection/components/card-subtitle/card-subtitle.ios.css +12 -0
  311. package/dist/collection/components/card-subtitle/card-subtitle.js +11 -8
  312. package/dist/collection/components/card-subtitle/card-subtitle.md.css +12 -0
  313. package/dist/collection/components/card-title/card-title.ios.css +73 -0
  314. package/dist/collection/components/card-title/card-title.js +11 -8
  315. package/dist/collection/components/card-title/card-title.md.css +73 -0
  316. package/dist/collection/components/checkbox/checkbox.ionic.css +527 -0
  317. package/dist/collection/components/checkbox/checkbox.ios.css +161 -101
  318. package/dist/collection/components/checkbox/checkbox.js +70 -14
  319. package/dist/collection/components/checkbox/checkbox.md.css +162 -102
  320. package/dist/collection/components/chip/chip.ionic.css +230 -0
  321. package/dist/collection/components/chip/chip.ios.css +67 -14
  322. package/dist/collection/components/chip/chip.js +108 -8
  323. package/dist/collection/components/chip/chip.md.css +67 -14
  324. package/dist/collection/components/col/col.css +12 -0
  325. package/dist/collection/components/col/col.js +9 -5
  326. package/dist/collection/components/content/content.css +8 -2
  327. package/dist/collection/components/content/content.js +16 -11
  328. package/dist/collection/components/datetime/datetime.ionic.css +673 -0
  329. package/dist/collection/components/datetime/datetime.ios.css +242 -86
  330. package/dist/collection/components/datetime/datetime.js +98 -20
  331. package/dist/collection/components/datetime/datetime.md.css +242 -86
  332. package/dist/collection/components/datetime/utils/data.js +5 -5
  333. package/dist/collection/components/datetime-button/datetime-button.ios.css +6 -0
  334. package/dist/collection/components/datetime-button/datetime-button.js +11 -8
  335. package/dist/collection/components/datetime-button/datetime-button.md.css +6 -0
  336. package/dist/collection/components/divider/divider.ionic.css +150 -0
  337. package/dist/collection/components/divider/divider.ios.css +87 -0
  338. package/dist/collection/components/divider/divider.js +94 -0
  339. package/dist/collection/components/divider/divider.md.css +87 -0
  340. package/dist/collection/components/fab/fab.css +25 -1
  341. package/dist/collection/components/fab/fab.js +9 -5
  342. package/dist/collection/components/fab-button/fab-button.ios.css +18 -6
  343. package/dist/collection/components/fab-button/fab-button.js +36 -21
  344. package/dist/collection/components/fab-button/fab-button.md.css +20 -8
  345. package/dist/collection/components/fab-list/fab-list.css +12 -0
  346. package/dist/collection/components/fab-list/fab-list.js +9 -5
  347. package/dist/collection/components/footer/footer.ios.css +14 -2
  348. package/dist/collection/components/footer/footer.js +21 -16
  349. package/dist/collection/components/footer/footer.md.css +12 -0
  350. package/dist/collection/components/grid/grid.css +12 -0
  351. package/dist/collection/components/grid/grid.js +9 -5
  352. package/dist/collection/components/header/header.ionic.css +86 -0
  353. package/dist/collection/components/header/header.ios.css +25 -10
  354. package/dist/collection/components/header/header.js +49 -18
  355. package/dist/collection/components/header/header.md.css +23 -8
  356. package/dist/collection/components/img/img.js +8 -2
  357. package/dist/collection/components/infinite-scroll/infinite-scroll.js +8 -4
  358. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.ios.css +12 -0
  359. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +16 -10
  360. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.md.css +12 -0
  361. package/dist/collection/components/input/input.ionic.css +883 -0
  362. package/dist/collection/components/input/input.ios.css +223 -140
  363. package/dist/collection/components/input/input.js +149 -38
  364. package/dist/collection/components/input/input.md.css +193 -212
  365. package/dist/collection/components/input-otp/input-otp.ios.css +12 -0
  366. package/dist/collection/components/input-otp/input-otp.js +3 -3
  367. package/dist/collection/components/input-otp/input-otp.md.css +12 -0
  368. package/dist/collection/components/input-password-toggle/input-password-toggle.ionic.css +80 -0
  369. package/dist/collection/components/input-password-toggle/input-password-toggle.js +48 -12
  370. package/dist/collection/components/input-password-toggle/input-password-toggle.native.css +61 -0
  371. package/dist/collection/components/item/item.ionic.css +502 -0
  372. package/dist/collection/components/item/item.ios.css +109 -69
  373. package/dist/collection/components/item/item.js +43 -19
  374. package/dist/collection/components/item/item.md.css +120 -68
  375. package/dist/collection/components/item-divider/item-divider.ios.css +18 -0
  376. package/dist/collection/components/item-divider/item-divider.js +11 -8
  377. package/dist/collection/components/item-divider/item-divider.md.css +18 -0
  378. package/dist/collection/components/item-group/item-group.ios.css +12 -0
  379. package/dist/collection/components/item-group/item-group.js +13 -7
  380. package/dist/collection/components/item-group/item-group.md.css +12 -0
  381. package/dist/collection/components/item-option/item-option.ionic.css +280 -0
  382. package/dist/collection/components/item-option/item-option.ios.css +136 -29
  383. package/dist/collection/components/item-option/item-option.js +73 -9
  384. package/dist/collection/components/item-option/item-option.md.css +136 -29
  385. package/dist/collection/components/item-options/item-options.ionic.css +223 -0
  386. package/dist/collection/components/item-options/item-options.ios.css +77 -34
  387. package/dist/collection/components/item-options/item-options.js +13 -7
  388. package/dist/collection/components/item-options/item-options.md.css +77 -34
  389. package/dist/collection/components/item-sliding/item-sliding.css +6 -0
  390. package/dist/collection/components/item-sliding/item-sliding.js +8 -4
  391. package/dist/collection/components/label/label.ios.css +18 -0
  392. package/dist/collection/components/label/label.js +11 -8
  393. package/dist/collection/components/label/label.md.css +18 -0
  394. package/dist/collection/components/list/list.ionic.css +214 -0
  395. package/dist/collection/components/list/list.ios.css +54 -14
  396. package/dist/collection/components/list/list.js +48 -9
  397. package/dist/collection/components/list/list.md.css +56 -16
  398. package/dist/collection/components/list-header/list-header.ionic.css +192 -0
  399. package/dist/collection/components/list-header/list-header.ios.css +82 -38
  400. package/dist/collection/components/list-header/list-header.js +11 -8
  401. package/dist/collection/components/list-header/list-header.md.css +82 -38
  402. package/dist/collection/components/loading/loading.ios.css +13 -1
  403. package/dist/collection/components/loading/loading.js +14 -11
  404. package/dist/collection/components/loading/loading.md.css +13 -1
  405. package/dist/collection/components/menu/menu.ios.css +15 -3
  406. package/dist/collection/components/menu/menu.js +12 -7
  407. package/dist/collection/components/menu/menu.md.css +15 -3
  408. package/dist/collection/components/menu-button/menu-button.ionic.css +238 -0
  409. package/dist/collection/components/menu-button/menu-button.ios.css +48 -14
  410. package/dist/collection/components/menu-button/menu-button.js +26 -10
  411. package/dist/collection/components/menu-button/menu-button.md.css +49 -15
  412. package/dist/collection/components/menu-toggle/menu-toggle.js +8 -5
  413. package/dist/collection/components/modal/animations/sheet.js +8 -2
  414. package/dist/collection/components/modal/gestures/sheet.js +10 -6
  415. package/dist/collection/components/modal/modal.ionic.css +243 -0
  416. package/dist/collection/components/modal/modal.ios.css +174 -70
  417. package/dist/collection/components/modal/modal.js +48 -11
  418. package/dist/collection/components/modal/modal.md.css +174 -70
  419. package/dist/collection/components/nav/nav.css +7 -1
  420. package/dist/collection/components/nav/nav.js +11 -5
  421. package/dist/collection/components/nav-link/nav-link.js +5 -1
  422. package/dist/collection/components/note/note.ios.css +12 -0
  423. package/dist/collection/components/note/note.js +11 -8
  424. package/dist/collection/components/note/note.md.css +12 -0
  425. package/dist/collection/components/picker/picker.ios.css +15 -3
  426. package/dist/collection/components/picker/picker.js +8 -5
  427. package/dist/collection/components/picker/picker.md.css +15 -3
  428. package/dist/collection/components/picker-column/picker-column.css +9 -2
  429. package/dist/collection/components/picker-column/picker-column.js +8 -7
  430. package/dist/collection/components/picker-column-option/picker-column-option.ios.css +6 -0
  431. package/dist/collection/components/picker-column-option/picker-column-option.js +13 -7
  432. package/dist/collection/components/picker-column-option/picker-column-option.md.css +6 -0
  433. package/dist/collection/components/picker-legacy/picker.ios.css +13 -1
  434. package/dist/collection/components/picker-legacy/picker.js +7 -6
  435. package/dist/collection/components/picker-legacy/picker.md.css +13 -1
  436. package/dist/collection/components/picker-legacy-column/picker-column.ios.css +12 -0
  437. package/dist/collection/components/picker-legacy-column/picker-column.js +4 -4
  438. package/dist/collection/components/picker-legacy-column/picker-column.md.css +12 -0
  439. package/dist/collection/components/popover/popover.ios.css +13 -1
  440. package/dist/collection/components/popover/popover.js +17 -14
  441. package/dist/collection/components/popover/popover.md.css +13 -1
  442. package/dist/collection/components/progress-bar/progress-bar.ionic.css +289 -0
  443. package/dist/collection/components/progress-bar/progress-bar.ios.css +48 -17
  444. package/dist/collection/components/progress-bar/progress-bar.js +43 -7
  445. package/dist/collection/components/progress-bar/progress-bar.md.css +48 -17
  446. package/dist/collection/components/radio/radio.ionic.css +424 -0
  447. package/dist/collection/components/radio/radio.ios.css +134 -91
  448. package/dist/collection/components/radio/radio.js +12 -9
  449. package/dist/collection/components/radio/radio.md.css +134 -91
  450. package/dist/collection/components/radio-group/radio-group.ionic.css +127 -0
  451. package/dist/collection/components/radio-group/radio-group.ios.css +42 -18
  452. package/dist/collection/components/radio-group/radio-group.js +13 -5
  453. package/dist/collection/components/radio-group/radio-group.md.css +42 -18
  454. package/dist/collection/components/range/range.ionic.css +555 -0
  455. package/dist/collection/components/range/range.ios.css +128 -85
  456. package/dist/collection/components/range/range.js +12 -9
  457. package/dist/collection/components/range/range.md.css +128 -85
  458. package/dist/collection/components/refresher/refresher.ios.css +14 -1
  459. package/dist/collection/components/refresher/refresher.js +11 -8
  460. package/dist/collection/components/refresher/refresher.md.css +15 -2
  461. package/dist/collection/components/refresher-content/refresher-content.js +28 -7
  462. package/dist/collection/components/reorder/reorder.ios.css +6 -0
  463. package/dist/collection/components/reorder/reorder.js +33 -6
  464. package/dist/collection/components/reorder/reorder.md.css +6 -0
  465. package/dist/collection/components/reorder-group/reorder-group.css +6 -0
  466. package/dist/collection/components/reorder-group/reorder-group.js +8 -4
  467. package/dist/collection/components/ripple-effect/{ripple-effect.css → ripple-effect.common.css} +7 -1
  468. package/dist/collection/components/ripple-effect/ripple-effect.ionic.css +217 -0
  469. package/dist/collection/components/ripple-effect/ripple-effect.js +14 -6
  470. package/dist/collection/components/route/route.js +4 -0
  471. package/dist/collection/components/router/router.js +4 -0
  472. package/dist/collection/components/router-link/router-link.css +8 -2
  473. package/dist/collection/components/router-link/router-link.js +9 -5
  474. package/dist/collection/components/router-outlet/router-outlet.css +7 -1
  475. package/dist/collection/components/router-outlet/router-outlet.js +6 -3
  476. package/dist/collection/components/row/row.css +12 -0
  477. package/dist/collection/components/row/row.js +9 -2
  478. package/dist/collection/components/searchbar/searchbar.ionic.css +628 -0
  479. package/dist/collection/components/searchbar/searchbar.ios.css +56 -18
  480. package/dist/collection/components/searchbar/searchbar.js +181 -34
  481. package/dist/collection/components/searchbar/searchbar.md.css +56 -18
  482. package/dist/collection/components/segment/segment.ionic.css +117 -0
  483. package/dist/collection/components/segment/segment.ios.css +45 -2
  484. package/dist/collection/components/segment/segment.js +11 -8
  485. package/dist/collection/components/segment/segment.md.css +45 -2
  486. package/dist/collection/components/segment-button/segment-button.ionic.css +355 -0
  487. package/dist/collection/components/segment-button/segment-button.ios.css +146 -105
  488. package/dist/collection/components/segment-button/segment-button.js +11 -8
  489. package/dist/collection/components/segment-button/segment-button.md.css +148 -107
  490. package/dist/collection/components/segment-content/segment-content.js +1 -1
  491. package/dist/collection/components/segment-view/segment-view.ios.css +6 -0
  492. package/dist/collection/components/segment-view/segment-view.js +6 -4
  493. package/dist/collection/components/segment-view/segment-view.md.css +6 -0
  494. package/dist/collection/components/select/select.ionic.css +765 -0
  495. package/dist/collection/components/select/select.ios.css +315 -176
  496. package/dist/collection/components/select/select.js +157 -54
  497. package/dist/collection/components/select/select.md.css +331 -178
  498. package/dist/collection/components/select-modal/select-modal.ionic.css +121 -0
  499. package/dist/collection/components/select-modal/select-modal.ios.css +18 -0
  500. package/dist/collection/components/select-modal/select-modal.js +3 -3
  501. package/dist/collection/components/select-modal/select-modal.md.css +7 -3
  502. package/dist/collection/components/select-option/select-option.js +9 -2
  503. package/dist/collection/components/select-popover/select-popover.ios.css +18 -0
  504. package/dist/collection/components/select-popover/select-popover.js +12 -4
  505. package/dist/collection/components/select-popover/select-popover.md.css +18 -0
  506. package/dist/collection/components/skeleton-text/skeleton-text.css +6 -0
  507. package/dist/collection/components/skeleton-text/skeleton-text.js +9 -5
  508. package/dist/collection/components/spinner/{spinner.css → spinner.ionic.css} +79 -10
  509. package/dist/collection/components/spinner/spinner.js +47 -6
  510. package/dist/collection/components/spinner/spinner.native.css +198 -0
  511. package/dist/collection/components/split-pane/split-pane.ios.css +20 -2
  512. package/dist/collection/components/split-pane/split-pane.js +14 -8
  513. package/dist/collection/components/split-pane/split-pane.md.css +20 -2
  514. package/dist/collection/components/tab/tab.js +6 -2
  515. package/dist/collection/components/tab-bar/tab-bar.ionic.css +188 -0
  516. package/dist/collection/components/tab-bar/tab-bar.ios.css +71 -43
  517. package/dist/collection/components/tab-bar/tab-bar.js +78 -11
  518. package/dist/collection/components/tab-bar/tab-bar.md.css +71 -43
  519. package/dist/collection/components/tab-button/tab-button.ionic.css +338 -0
  520. package/dist/collection/components/tab-button/tab-button.ios.css +171 -95
  521. package/dist/collection/components/tab-button/tab-button.js +44 -8
  522. package/dist/collection/components/tab-button/tab-button.md.css +137 -93
  523. package/dist/collection/components/tabs/tabs.css +7 -1
  524. package/dist/collection/components/tabs/tabs.js +4 -1
  525. package/dist/collection/components/text/text.css +6 -0
  526. package/dist/collection/components/text/text.js +7 -6
  527. package/dist/collection/components/textarea/textarea.ionic.css +830 -0
  528. package/dist/collection/components/textarea/textarea.ios.css +275 -139
  529. package/dist/collection/components/textarea/textarea.js +76 -16
  530. package/dist/collection/components/textarea/textarea.md.css +288 -140
  531. package/dist/collection/components/thumbnail/thumbnail.css +6 -0
  532. package/dist/collection/components/thumbnail/thumbnail.js +9 -2
  533. package/dist/collection/components/title/title.ionic.css +129 -0
  534. package/dist/collection/components/title/title.ios.css +32 -4
  535. package/dist/collection/components/title/title.js +13 -7
  536. package/dist/collection/components/title/title.md.css +32 -4
  537. package/dist/collection/components/toast/animations/utils.js +1 -1
  538. package/dist/collection/components/toast/toast.ionic.css +396 -0
  539. package/dist/collection/components/toast/toast.ios.css +84 -45
  540. package/dist/collection/components/toast/toast.js +75 -12
  541. package/dist/collection/components/toast/toast.md.css +84 -45
  542. package/dist/collection/components/toggle/toggle.ionic.css +509 -0
  543. package/dist/collection/components/toggle/toggle.ios.css +247 -131
  544. package/dist/collection/components/toggle/toggle.js +73 -18
  545. package/dist/collection/components/toggle/toggle.md.css +244 -131
  546. package/dist/collection/components/toolbar/toolbar.ionic.css +238 -0
  547. package/dist/collection/components/toolbar/toolbar.ios.css +90 -47
  548. package/dist/collection/components/toolbar/toolbar.js +141 -13
  549. package/dist/collection/components/toolbar/toolbar.md.css +90 -47
  550. package/dist/collection/global/ionic-global.js +228 -13
  551. package/dist/collection/utils/focus-visible.js +22 -0
  552. package/dist/collection/utils/framework-delegate.js +3 -1
  553. package/dist/collection/utils/helpers.js +42 -2
  554. package/dist/collection/utils/keyboard/keyboard-controller.js +3 -1
  555. package/dist/collection/utils/menu-controller/animations/overlay.js +3 -3
  556. package/dist/collection/utils/menu-controller/animations/push.js +2 -1
  557. package/dist/collection/utils/menu-controller/animations/reveal.js +2 -1
  558. package/dist/collection/utils/overlays.js +2 -1
  559. package/dist/collection/utils/test/playwright/generator.js +48 -23
  560. package/dist/collection/utils/test/playwright/page/utils/goto.js +14 -5
  561. package/dist/collection/utils/test/playwright/page/utils/set-content.js +16 -2
  562. package/dist/collection/utils/transition/ios.transition.js +1 -0
  563. package/dist/docs.json +7739 -362
  564. package/dist/esm/{animation-BWcUKtbn.js → animation-Cgfm6Out.js} +1 -2
  565. package/dist/esm/{button-active-Bxcnevju.js → button-active-DvzVF2u_.js} +2 -2
  566. package/dist/esm/{capacitor-CFERIeaU.js → capacitor-Dvc8Ydvg.js} +1 -1
  567. package/dist/esm/caret-down-D1t981Ih.js +6 -0
  568. package/dist/esm/caret-left-fIOYmaqA.js +6 -0
  569. package/dist/esm/caret-right-BYSs-jZz.js +6 -0
  570. package/dist/esm/{config-AaTyISnm.js → config-DwiPHIF5.js} +1 -1
  571. package/dist/esm/{data-GIsHsYIB.js → data-HHZs0eLV.js} +6 -6
  572. package/dist/{cjs/focus-visible-CCvKiLh3.js → esm/focus-visible-vXpMhGrs.js} +23 -3
  573. package/dist/esm/{framework-delegate-DxcnWic_.js → framework-delegate-B4Rily6A.js} +4 -2
  574. package/dist/esm/{haptic-DzAMWJuk.js → haptic-ZZTn7IWt.js} +1 -1
  575. package/dist/esm/{helpers-1O4D2b7y.js → helpers-D_90HVv6.js} +42 -3
  576. package/dist/esm/{index-B_U9CtaY.js → index-BBrR3goV.js} +347 -13
  577. package/dist/esm/{index-DfBA5ztX.js → index-BoSPzYKk.js} +4 -4
  578. package/dist/esm/{index-BlJTBdxG.js → index-ByqmqxGO.js} +2 -2
  579. package/dist/esm/{index-BLV6ykCk.js → index-CFd-a2gp.js} +3 -3
  580. package/dist/esm/{index-D8sncTHY.js → index-D4D_NUAr.js} +10 -10
  581. package/dist/esm/{index-CWbP1eJz.js → index-k4x4i7EL.js} +3 -3
  582. package/dist/esm/index.js +11 -12
  583. package/dist/esm/{input-shims-C3lNp93k.js → input-shims-DEtEJcaS.js} +6 -6
  584. package/dist/esm/{input.utils-zWijNCrx.js → input.utils-DNE0LB5g.js} +2 -3
  585. package/dist/esm/ion-accordion_2.entry.js +56 -27
  586. package/dist/esm/ion-action-sheet.entry.js +21 -18
  587. package/dist/esm/ion-alert.entry.js +23 -21
  588. package/dist/esm/ion-app_8.entry.js +229 -144
  589. package/dist/esm/ion-avatar_3.entry.js +124 -12
  590. package/dist/esm/ion-back-button.entry.js +29 -20
  591. package/dist/esm/ion-backdrop.entry.js +9 -6
  592. package/dist/esm/ion-breadcrumb_2.entry.js +52 -16
  593. package/dist/esm/ion-button_2.entry.js +43 -11
  594. package/dist/esm/ion-card_5.entry.js +53 -29
  595. package/dist/esm/ion-checkbox.entry.js +31 -13
  596. package/dist/esm/ion-chip.entry.js +48 -7
  597. package/dist/esm/ion-col_3.entry.js +13 -10
  598. package/dist/esm/ion-datetime-button.entry.js +11 -7
  599. package/dist/esm/ion-datetime_3.entry.js +114 -39
  600. package/dist/esm/ion-divider.entry.js +48 -0
  601. package/dist/esm/ion-fab_3.entry.js +42 -26
  602. package/dist/esm/ion-img.entry.js +7 -3
  603. package/dist/esm/ion-infinite-scroll_2.entry.js +18 -14
  604. package/dist/esm/ion-input-otp.entry.js +6 -5
  605. package/dist/esm/ion-input-password-toggle.entry.js +51 -13
  606. package/dist/esm/ion-input.entry.js +121 -31
  607. package/dist/esm/ion-item-option_3.entry.js +48 -19
  608. package/dist/esm/ion-item_8.entry.js +106 -46
  609. package/dist/esm/ion-loading.entry.js +18 -16
  610. package/dist/esm/ion-menu_3.entry.js +45 -27
  611. package/dist/esm/ion-modal.entry.js +56 -29
  612. package/dist/esm/ion-nav_2.entry.js +13 -10
  613. package/dist/esm/ion-picker-column-option.entry.js +10 -6
  614. package/dist/esm/ion-picker-column.entry.js +11 -11
  615. package/dist/esm/ion-picker.entry.js +10 -6
  616. package/dist/esm/ion-popover.entry.js +18 -16
  617. package/dist/esm/ion-progress-bar.entry.js +25 -7
  618. package/dist/esm/ion-radio_2.entry.js +22 -13
  619. package/dist/esm/ion-range.entry.js +14 -10
  620. package/dist/esm/ion-refresher_2.entry.js +38 -20
  621. package/dist/esm/ion-reorder_2.entry.js +37 -13
  622. package/dist/esm/ion-ripple-effect.entry.js +14 -6
  623. package/dist/esm/ion-route_4.entry.js +8 -7
  624. package/dist/esm/ion-searchbar.entry.js +136 -23
  625. package/dist/esm/ion-segment-content.entry.js +2 -2
  626. package/dist/esm/ion-segment-view.entry.js +6 -3
  627. package/dist/esm/ion-segment_2.entry.js +21 -14
  628. package/dist/esm/ion-select-modal.entry.js +8 -9
  629. package/dist/esm/ion-select_3.entry.js +130 -39
  630. package/dist/esm/ion-spinner.entry.js +28 -6
  631. package/dist/esm/ion-split-pane.entry.js +11 -8
  632. package/dist/esm/ion-tab-bar_2.entry.js +65 -20
  633. package/dist/esm/ion-tab_2.entry.js +8 -7
  634. package/dist/esm/ion-text.entry.js +5 -5
  635. package/dist/esm/ion-textarea.entry.js +55 -15
  636. package/dist/esm/ion-toast.entry.js +41 -18
  637. package/dist/esm/ion-toggle.entry.js +79 -22
  638. package/dist/esm/ionic.js +3 -3
  639. package/dist/esm/{ios.transition-BmXtMRXZ.js → ios.transition-C_-UP8wE.js} +6 -5
  640. package/dist/esm/{keyboard-ywgs5efA.js → keyboard-BsZp3qPH.js} +3 -3
  641. package/dist/esm/{keyboard-CUw4ekVy.js → keyboard-Cvigb3Rv.js} +1 -1
  642. package/dist/esm/{keyboard-controller-BaaVITYt.js → keyboard-controller-lts2Pswq.js} +4 -3
  643. package/dist/esm/list-Dhi5xtNS.js +6 -0
  644. package/dist/esm/loader.js +3 -3
  645. package/dist/esm/{md.transition-CLI683c7.js → md.transition-BDWkLsNw.js} +5 -5
  646. package/dist/esm/{notch-controller-C5LPspO8.js → notch-controller-ClKrf2l9.js} +2 -2
  647. package/dist/esm/{overlays-8Y2rA-ps.js → overlays-DDeOq6un.js} +5 -6
  648. package/dist/esm/{status-tap-7t9T91bG.js → status-tap-DLatL9pG.js} +4 -3
  649. package/dist/esm/{swipe-back-VdaUzLWy.js → swipe-back-YYylMb0l.js} +3 -2
  650. package/dist/esm/x-BDqjX7Z_.js +6 -0
  651. package/dist/html.html-data.json +2508 -230
  652. package/dist/ionic/index.esm.js +1 -1
  653. package/dist/ionic/ionic.esm.js +1 -1
  654. package/dist/ionic/p-034b2ca2.entry.js +4 -0
  655. package/dist/ionic/p-08dfb85e.entry.js +4 -0
  656. package/dist/ionic/p-08e18904.entry.js +4 -0
  657. package/dist/ionic/p-0eab9ecf.entry.js +4 -0
  658. package/dist/ionic/p-11734cc5.entry.js +4 -0
  659. package/dist/ionic/p-1984e701.entry.js +4 -0
  660. package/dist/ionic/p-19959eec.entry.js +4 -0
  661. package/dist/ionic/p-1f976fad.entry.js +4 -0
  662. package/dist/ionic/p-1fd06a55.entry.js +4 -0
  663. package/dist/ionic/p-208954ca.entry.js +4 -0
  664. package/dist/ionic/p-232ba539.entry.js +4 -0
  665. package/dist/ionic/p-30c2256c.entry.js +4 -0
  666. package/dist/ionic/p-32f9c041.entry.js +4 -0
  667. package/dist/ionic/p-331b28f8.entry.js +4 -0
  668. package/dist/ionic/p-3c361403.entry.js +4 -0
  669. package/dist/ionic/p-4903685c.entry.js +4 -0
  670. package/dist/ionic/p-4d7ac4db.entry.js +4 -0
  671. package/dist/ionic/p-5ae4d6a0.entry.js +4 -0
  672. package/dist/ionic/p-6d2dc9d7.entry.js +4 -0
  673. package/dist/ionic/p-6e6ce506.entry.js +4 -0
  674. package/dist/ionic/p-6ea34add.entry.js +4 -0
  675. package/dist/ionic/p-6f17f8ed.entry.js +4 -0
  676. package/dist/ionic/p-7049bf1c.entry.js +4 -0
  677. package/dist/ionic/p-7ace7638.entry.js +4 -0
  678. package/dist/ionic/p-7f1e83a4.entry.js +4 -0
  679. package/dist/ionic/p-82796bb0.entry.js +4 -0
  680. package/dist/ionic/p-931716a5.entry.js +4 -0
  681. package/dist/ionic/p-9cb0fd91.entry.js +4 -0
  682. package/dist/ionic/p-BDqjX7Z_.js +4 -0
  683. package/dist/ionic/p-BJ-EYogw.js +4 -0
  684. package/dist/ionic/p-BK3Vo2GA.js +4 -0
  685. package/dist/ionic/p-BKDxK6_S.js +4 -0
  686. package/dist/ionic/p-BMPzyWDm.js +4 -0
  687. package/dist/ionic/p-BTqHM5hg.js +4 -0
  688. package/dist/ionic/p-BYSs-jZz.js +4 -0
  689. package/dist/ionic/p-BZR5I9yn.js +4 -0
  690. package/dist/ionic/p-BZSKvxFv.js +4 -0
  691. package/dist/ionic/p-BaAcx1TO.js +4 -0
  692. package/dist/ionic/p-BeJdFlAB.js +4 -0
  693. package/dist/ionic/{p-D13Eaw-8.js → p-Bi_aZreq.js} +1 -1
  694. package/dist/ionic/p-BpUl-Ubc.js +4 -0
  695. package/dist/ionic/{p-CKvCXMs9.js → p-BuAY53fC.js} +1 -1
  696. package/dist/ionic/{p-BLV6ykCk.js → p-CFd-a2gp.js} +1 -1
  697. package/dist/ionic/p-CnPZjTVf.js +4 -0
  698. package/dist/ionic/{p-7qk7mxdr.js → p-D-g7JYuH.js} +1 -1
  699. package/dist/ionic/p-D1t981Ih.js +4 -0
  700. package/dist/ionic/p-D6quDhlh.js +4 -0
  701. package/dist/ionic/{p-CPgXVSua.js → p-DIZM2shZ.js} +1 -1
  702. package/dist/ionic/p-DJD59Sq4.js +4 -0
  703. package/dist/ionic/p-DZmL55Qn.js +4 -0
  704. package/dist/ionic/p-Dhi5xtNS.js +4 -0
  705. package/dist/ionic/p-DjxV6ul_.js +4 -0
  706. package/dist/ionic/p-DkXsr7m2.js +4 -0
  707. package/dist/ionic/p-Dpa-63kX.js +4 -0
  708. package/dist/ionic/p-HOJ_eq4V.js +5 -0
  709. package/dist/ionic/p-MBiM0IFp.js +4 -0
  710. package/dist/ionic/p-a036ba35.entry.js +4 -0
  711. package/dist/ionic/p-a1af546a.entry.js +4 -0
  712. package/dist/ionic/p-a7acdba0.entry.js +4 -0
  713. package/dist/ionic/p-aa8d1f1d.entry.js +4 -0
  714. package/dist/ionic/p-ae3dad82.entry.js +4 -0
  715. package/dist/ionic/{p-a9ac80bd.entry.js → p-b2fe9962.entry.js} +1 -1
  716. package/dist/ionic/p-b493f149.entry.js +4 -0
  717. package/dist/ionic/p-b767c96a.entry.js +4 -0
  718. package/dist/ionic/p-b9b3ba1e.entry.js +4 -0
  719. package/dist/ionic/p-bb85830d.entry.js +4 -0
  720. package/dist/ionic/p-c565e353.entry.js +4 -0
  721. package/dist/ionic/p-ccf3b065.entry.js +4 -0
  722. package/dist/ionic/p-cedb36aa.entry.js +4 -0
  723. package/dist/ionic/p-d5b34bac.entry.js +4 -0
  724. package/dist/ionic/p-da78db37.entry.js +4 -0
  725. package/dist/ionic/p-db6e0330.entry.js +4 -0
  726. package/dist/ionic/p-dd5e8e7a.entry.js +4 -0
  727. package/dist/ionic/p-e4ed2971.entry.js +4 -0
  728. package/dist/ionic/p-e56f0f4b.entry.js +4 -0
  729. package/dist/ionic/p-e5897321.entry.js +4 -0
  730. package/dist/ionic/p-e89e89eb.entry.js +4 -0
  731. package/dist/ionic/{p-ei_RiGrl.js → p-eZzo_1L1.js} +1 -1
  732. package/dist/ionic/p-ed214a9c.entry.js +4 -0
  733. package/dist/ionic/p-eebf0420.entry.js +4 -0
  734. package/dist/ionic/p-f6a66956.entry.js +4 -0
  735. package/dist/ionic/p-fIOYmaqA.js +4 -0
  736. package/dist/ionic/p-fc8e47a4.entry.js +4 -0
  737. package/dist/ionic/p-vXpMhGrs.js +4 -0
  738. package/dist/ionic/svg/accessibility-outline.svg +1 -1
  739. package/dist/ionic/svg/accessibility-sharp.svg +1 -1
  740. package/dist/ionic/svg/accessibility.svg +1 -1
  741. package/dist/ionic/svg/arrow-down-left-box-outline.svg +1 -0
  742. package/dist/ionic/svg/arrow-down-left-box-sharp.svg +1 -0
  743. package/dist/ionic/svg/arrow-down-left-box.svg +1 -0
  744. package/dist/ionic/svg/arrow-down-right-box-outline.svg +1 -0
  745. package/dist/ionic/svg/arrow-down-right-box-sharp.svg +1 -0
  746. package/dist/ionic/svg/arrow-down-right-box.svg +1 -0
  747. package/dist/ionic/svg/arrow-up-left-box-outline.svg +1 -0
  748. package/dist/ionic/svg/arrow-up-left-box-sharp.svg +1 -0
  749. package/dist/ionic/svg/arrow-up-left-box.svg +1 -0
  750. package/dist/ionic/svg/arrow-up-right-box-outline.svg +1 -0
  751. package/dist/ionic/svg/arrow-up-right-box-sharp.svg +1 -0
  752. package/dist/ionic/svg/arrow-up-right-box.svg +1 -0
  753. package/dist/ionic/svg/bag-add-outline.svg +1 -1
  754. package/dist/ionic/svg/bag-add-sharp.svg +1 -1
  755. package/dist/ionic/svg/bag-add.svg +1 -1
  756. package/dist/ionic/svg/bag-check-outline.svg +1 -1
  757. package/dist/ionic/svg/bag-check-sharp.svg +1 -1
  758. package/dist/ionic/svg/bag-check.svg +1 -1
  759. package/dist/ionic/svg/bag-handle-outline.svg +1 -1
  760. package/dist/ionic/svg/bag-handle-sharp.svg +1 -1
  761. package/dist/ionic/svg/bag-handle.svg +1 -1
  762. package/dist/ionic/svg/bag-outline.svg +1 -1
  763. package/dist/ionic/svg/bag-remove-outline.svg +1 -1
  764. package/dist/ionic/svg/bag-remove-sharp.svg +1 -1
  765. package/dist/ionic/svg/bag-remove.svg +1 -1
  766. package/dist/ionic/svg/bag-sharp.svg +1 -1
  767. package/dist/ionic/svg/bag.svg +1 -1
  768. package/dist/ionic/svg/balloon-outline.svg +1 -1
  769. package/dist/ionic/svg/balloon-sharp.svg +1 -1
  770. package/dist/ionic/svg/balloon.svg +1 -1
  771. package/dist/ionic/svg/ban-outline.svg +1 -1
  772. package/dist/ionic/svg/ban-sharp.svg +1 -1
  773. package/dist/ionic/svg/ban.svg +1 -1
  774. package/dist/ionic/svg/binoculars-outline.svg +1 -0
  775. package/dist/ionic/svg/binoculars-sharp.svg +1 -0
  776. package/dist/ionic/svg/binoculars.svg +1 -0
  777. package/dist/ionic/svg/body-outline.svg +1 -1
  778. package/dist/ionic/svg/bowling-ball-outline.svg +1 -1
  779. package/dist/ionic/svg/bowling-ball-sharp.svg +1 -1
  780. package/dist/ionic/svg/bowling-ball.svg +1 -1
  781. package/dist/ionic/svg/calendar-clear-outline.svg +1 -1
  782. package/dist/ionic/svg/calendar-clear-sharp.svg +1 -1
  783. package/dist/ionic/svg/calendar-clear.svg +1 -1
  784. package/dist/ionic/svg/calendar-number-outline.svg +1 -1
  785. package/dist/ionic/svg/calendar-number-sharp.svg +1 -1
  786. package/dist/ionic/svg/calendar-number.svg +1 -1
  787. package/dist/ionic/svg/calendar-outline.svg +1 -1
  788. package/dist/ionic/svg/calendar-sharp.svg +1 -1
  789. package/dist/ionic/svg/calendar.svg +1 -1
  790. package/dist/ionic/svg/chevron-collapse-outline.svg +1 -1
  791. package/dist/ionic/svg/chevron-collapse-sharp.svg +1 -1
  792. package/dist/ionic/svg/chevron-collapse.svg +1 -1
  793. package/dist/ionic/svg/chevron-expand-outline.svg +1 -1
  794. package/dist/ionic/svg/chevron-expand-sharp.svg +1 -1
  795. package/dist/ionic/svg/chevron-expand.svg +1 -1
  796. package/dist/ionic/svg/color-wand-outline.svg +1 -1
  797. package/dist/ionic/svg/color-wand.svg +1 -1
  798. package/dist/ionic/svg/diamond-outline.svg +1 -1
  799. package/dist/ionic/svg/diamond-sharp.svg +1 -1
  800. package/dist/ionic/svg/diamond.svg +1 -1
  801. package/dist/ionic/svg/dice-outline.svg +1 -1
  802. package/dist/ionic/svg/dice-sharp.svg +1 -1
  803. package/dist/ionic/svg/dice.svg +1 -1
  804. package/dist/ionic/svg/document-lock-outline.svg +1 -1
  805. package/dist/ionic/svg/document-lock-sharp.svg +1 -1
  806. package/dist/ionic/svg/document-lock.svg +1 -1
  807. package/dist/ionic/svg/extension-puzzle-outline.svg +1 -1
  808. package/dist/ionic/svg/extension-puzzle-sharp.svg +1 -1
  809. package/dist/ionic/svg/extension-puzzle.svg +1 -1
  810. package/dist/ionic/svg/filter-circle-outline.svg +1 -1
  811. package/dist/ionic/svg/filter-circle-sharp.svg +1 -1
  812. package/dist/ionic/svg/filter-circle.svg +1 -1
  813. package/dist/ionic/svg/fish-outline.svg +1 -1
  814. package/dist/ionic/svg/fish-sharp.svg +1 -1
  815. package/dist/ionic/svg/fish.svg +1 -1
  816. package/dist/ionic/svg/footsteps-outline.svg +1 -1
  817. package/dist/ionic/svg/footsteps-sharp.svg +1 -1
  818. package/dist/ionic/svg/footsteps.svg +1 -1
  819. package/dist/ionic/svg/id-card-outline.svg +1 -1
  820. package/dist/ionic/svg/id-card-sharp.svg +1 -1
  821. package/dist/ionic/svg/id-card.svg +1 -1
  822. package/dist/ionic/svg/invert-mode-outline.svg +1 -1
  823. package/dist/ionic/svg/invert-mode-sharp.svg +1 -1
  824. package/dist/ionic/svg/invert-mode.svg +1 -1
  825. package/dist/ionic/svg/logo-alipay.svg +1 -1
  826. package/dist/ionic/svg/logo-android.svg +1 -1
  827. package/dist/ionic/svg/logo-appflow.svg +1 -0
  828. package/dist/ionic/svg/logo-apple-ar.svg +1 -1
  829. package/dist/ionic/svg/logo-behance.svg +1 -1
  830. package/dist/ionic/svg/logo-bitbucket.svg +1 -1
  831. package/dist/ionic/svg/logo-deviantart.svg +1 -1
  832. package/dist/ionic/svg/logo-discord.svg +1 -1
  833. package/dist/ionic/svg/logo-docker.svg +1 -1
  834. package/dist/ionic/svg/logo-edge.svg +1 -1
  835. package/dist/ionic/svg/logo-facebook.svg +1 -1
  836. package/dist/ionic/svg/logo-figma.svg +1 -1
  837. package/dist/ionic/svg/logo-firebase.svg +1 -1
  838. package/dist/ionic/svg/logo-gitlab.svg +1 -1
  839. package/dist/ionic/svg/logo-ionic.svg +1 -1
  840. package/dist/ionic/svg/logo-mastodon.svg +1 -1
  841. package/dist/ionic/svg/logo-medium.svg +1 -1
  842. package/dist/ionic/svg/logo-microsoft.svg +1 -1
  843. package/dist/ionic/svg/logo-npm.svg +1 -1
  844. package/dist/ionic/svg/logo-paypal.svg +1 -1
  845. package/dist/ionic/svg/logo-soundcloud.svg +1 -1
  846. package/dist/ionic/svg/logo-tableau.svg +1 -1
  847. package/dist/ionic/svg/logo-tiktok.svg +1 -1
  848. package/dist/ionic/svg/logo-trapeze.svg +1 -0
  849. package/dist/ionic/svg/logo-venmo.svg +1 -1
  850. package/dist/ionic/svg/logo-vercel.svg +1 -1
  851. package/dist/ionic/svg/logo-wechat.svg +1 -1
  852. package/dist/ionic/svg/logo-x.svg +1 -0
  853. package/dist/ionic/svg/logo-yahoo.svg +1 -1
  854. package/dist/ionic/svg/prism-outline.svg +1 -1
  855. package/dist/ionic/svg/prism-sharp.svg +1 -1
  856. package/dist/ionic/svg/prism.svg +1 -1
  857. package/dist/ionic/svg/scale-outline.svg +1 -1
  858. package/dist/ionic/svg/scale-sharp.svg +1 -1
  859. package/dist/ionic/svg/scale.svg +1 -1
  860. package/dist/ionic/svg/server-outline.svg +1 -1
  861. package/dist/ionic/svg/server-sharp.svg +1 -1
  862. package/dist/ionic/svg/server.svg +1 -1
  863. package/dist/ionic/svg/shield-half-outline.svg +1 -1
  864. package/dist/ionic/svg/shield-half-sharp.svg +1 -1
  865. package/dist/ionic/svg/shield-half.svg +1 -1
  866. package/dist/ionic/svg/sparkles-outline.svg +1 -1
  867. package/dist/ionic/svg/sparkles-sharp.svg +1 -1
  868. package/dist/ionic/svg/sparkles.svg +1 -1
  869. package/dist/ionic/svg/storefront-outline.svg +1 -1
  870. package/dist/ionic/svg/storefront-sharp.svg +1 -1
  871. package/dist/ionic/svg/storefront.svg +1 -1
  872. package/dist/ionic/svg/telescope-outline.svg +1 -1
  873. package/dist/ionic/svg/telescope-sharp.svg +1 -1
  874. package/dist/ionic/svg/telescope.svg +1 -1
  875. package/dist/ionic/svg/ticket-outline.svg +1 -1
  876. package/dist/ionic/svg/ticket-sharp.svg +1 -1
  877. package/dist/ionic/svg/ticket.svg +1 -1
  878. package/dist/ionic/svg/today-outline.svg +1 -1
  879. package/dist/ionic/svg/today-sharp.svg +1 -1
  880. package/dist/ionic/svg/today.svg +1 -1
  881. package/dist/ionic/svg/unlink-outline.svg +1 -1
  882. package/dist/ionic/svg/unlink-sharp.svg +1 -1
  883. package/dist/ionic/svg/unlink.svg +1 -1
  884. package/dist/ionic/svg/videocam-off-outline.svg +1 -1
  885. package/dist/ionic/svg/videocam-off-sharp.svg +1 -1
  886. package/dist/ionic/svg/videocam-off.svg +1 -1
  887. package/dist/ionic/svg/wifi-outline.svg +1 -1
  888. package/dist/ionic/svg/wifi-sharp.svg +1 -1
  889. package/dist/ionic/svg/wifi.svg +1 -1
  890. package/dist/types/components/accordion/accordion.d.ts +5 -3
  891. package/dist/types/components/accordion-group/accordion-group.d.ts +12 -1
  892. package/dist/types/components/action-sheet/action-sheet-interface.d.ts +3 -7
  893. package/dist/types/components/action-sheet/action-sheet.d.ts +3 -2
  894. package/dist/types/components/alert/alert-interface.d.ts +3 -7
  895. package/dist/types/components/alert/alert.d.ts +3 -2
  896. package/dist/types/components/app/app.d.ts +6 -2
  897. package/dist/types/components/avatar/avatar.d.ts +32 -0
  898. package/dist/types/components/back-button/back-button.d.ts +2 -1
  899. package/dist/types/components/backdrop/backdrop.d.ts +4 -0
  900. package/dist/types/components/badge/badge.d.ts +34 -1
  901. package/dist/types/components/breadcrumb/breadcrumb.d.ts +4 -1
  902. package/dist/types/components/breadcrumbs/breadcrumbs.d.ts +2 -2
  903. package/dist/types/components/button/button.d.ts +19 -6
  904. package/dist/types/components/buttons/buttons.d.ts +5 -1
  905. package/dist/types/components/card/card.d.ts +8 -1
  906. package/dist/types/components/card-content/card-content.d.ts +2 -1
  907. package/dist/types/components/card-header/card-header.d.ts +3 -2
  908. package/dist/types/components/card-subtitle/card-subtitle.d.ts +2 -1
  909. package/dist/types/components/card-title/card-title.d.ts +2 -1
  910. package/dist/types/components/checkbox/checkbox.d.ts +14 -4
  911. package/dist/types/components/chip/chip.d.ts +26 -1
  912. package/dist/types/components/col/col.d.ts +4 -0
  913. package/dist/types/components/content/content.d.ts +3 -0
  914. package/dist/types/components/datetime/datetime.d.ts +26 -1
  915. package/dist/types/components/datetime/utils/data.d.ts +5 -5
  916. package/dist/types/components/datetime-button/datetime-button.d.ts +2 -1
  917. package/dist/types/components/divider/divider.d.ts +20 -0
  918. package/dist/types/components/fab/fab.d.ts +4 -0
  919. package/dist/types/components/fab-button/fab-button.d.ts +5 -3
  920. package/dist/types/components/fab-list/fab-list.d.ts +4 -0
  921. package/dist/types/components/footer/footer.d.ts +4 -3
  922. package/dist/types/components/grid/grid.d.ts +4 -0
  923. package/dist/types/components/header/header.d.ts +9 -3
  924. package/dist/types/components/img/img.d.ts +3 -0
  925. package/dist/types/components/infinite-scroll/infinite-scroll.d.ts +4 -0
  926. package/dist/types/components/infinite-scroll-content/infinite-scroll-content.d.ts +4 -0
  927. package/dist/types/components/input/input.d.ts +31 -5
  928. package/dist/types/components/input-password-toggle/input-password-toggle.d.ts +2 -0
  929. package/dist/types/components/item/item.d.ts +11 -4
  930. package/dist/types/components/item-divider/item-divider.d.ts +2 -1
  931. package/dist/types/components/item-group/item-group.d.ts +4 -0
  932. package/dist/types/components/item-option/item-option.d.ts +18 -1
  933. package/dist/types/components/item-options/item-options.d.ts +4 -0
  934. package/dist/types/components/item-sliding/item-sliding.d.ts +4 -0
  935. package/dist/types/components/label/label.d.ts +2 -1
  936. package/dist/types/components/list/list.d.ts +15 -1
  937. package/dist/types/components/list-header/list-header.d.ts +2 -1
  938. package/dist/types/components/loading/loading-interface.d.ts +2 -7
  939. package/dist/types/components/loading/loading.d.ts +3 -2
  940. package/dist/types/components/menu/menu.d.ts +3 -0
  941. package/dist/types/components/menu-button/menu-button.d.ts +3 -1
  942. package/dist/types/components/menu-toggle/menu-toggle.d.ts +3 -0
  943. package/dist/types/components/modal/gestures/sheet.d.ts +1 -1
  944. package/dist/types/components/modal/modal-interface.d.ts +4 -7
  945. package/dist/types/components/modal/modal.d.ts +11 -1
  946. package/dist/types/components/nav/nav-interface.d.ts +9 -1
  947. package/dist/types/components/nav/nav.d.ts +5 -1
  948. package/dist/types/components/nav-link/nav-link.d.ts +4 -0
  949. package/dist/types/components/note/note.d.ts +2 -1
  950. package/dist/types/components/picker/picker.d.ts +2 -1
  951. package/dist/types/components/picker-column/picker-column.d.ts +2 -1
  952. package/dist/types/components/picker-column-option/picker-column-option.d.ts +4 -0
  953. package/dist/types/components/picker-legacy/picker.d.ts +2 -1
  954. package/dist/types/components/popover/popover-interface.d.ts +3 -6
  955. package/dist/types/components/popover/popover.d.ts +6 -5
  956. package/dist/types/components/progress-bar/progress-bar.d.ts +10 -1
  957. package/dist/types/components/radio/radio.d.ts +2 -1
  958. package/dist/types/components/radio-group/radio-group.d.ts +4 -0
  959. package/dist/types/components/range/range.d.ts +2 -1
  960. package/dist/types/components/refresher/refresher.d.ts +2 -1
  961. package/dist/types/components/refresher-content/refresher-content.d.ts +4 -0
  962. package/dist/types/components/reorder/reorder.d.ts +9 -0
  963. package/dist/types/components/reorder-group/reorder-group.d.ts +4 -0
  964. package/dist/types/components/ripple-effect/ripple-effect.d.ts +4 -0
  965. package/dist/types/components/route/route.d.ts +4 -0
  966. package/dist/types/components/router/router.d.ts +4 -0
  967. package/dist/types/components/router-link/router-link.d.ts +4 -0
  968. package/dist/types/components/router-outlet/router-outlet.d.ts +4 -1
  969. package/dist/types/components/row/row.d.ts +4 -0
  970. package/dist/types/components/searchbar/searchbar.d.ts +51 -9
  971. package/dist/types/components/segment/segment.d.ts +2 -1
  972. package/dist/types/components/segment-button/segment-button.d.ts +2 -1
  973. package/dist/types/components/select/select.d.ts +41 -13
  974. package/dist/types/components/select-option/select-option.d.ts +4 -0
  975. package/dist/types/components/select-popover/select-popover.d.ts +3 -0
  976. package/dist/types/components/skeleton-text/skeleton-text.d.ts +4 -0
  977. package/dist/types/components/spinner/spinner.d.ts +15 -0
  978. package/dist/types/components/split-pane/split-pane.d.ts +4 -0
  979. package/dist/types/components/tab/tab.d.ts +4 -0
  980. package/dist/types/components/tab-bar/tab-bar.d.ts +22 -2
  981. package/dist/types/components/tab-button/tab-button.d.ts +11 -1
  982. package/dist/types/components/tabs/tabs.d.ts +3 -0
  983. package/dist/types/components/text/text.d.ts +2 -1
  984. package/dist/types/components/textarea/textarea.d.ts +17 -4
  985. package/dist/types/components/thumbnail/thumbnail.d.ts +4 -0
  986. package/dist/types/components/title/title.d.ts +4 -0
  987. package/dist/types/components/toast/animations/utils.d.ts +2 -2
  988. package/dist/types/components/toast/toast-interface.d.ts +3 -7
  989. package/dist/types/components/toast/toast.d.ts +19 -2
  990. package/dist/types/components/toggle/toggle.d.ts +15 -1
  991. package/dist/types/components/toolbar/toolbar.d.ts +20 -3
  992. package/dist/types/components.d.ts +1512 -196
  993. package/dist/types/global/ionic-global.d.ts +27 -2
  994. package/dist/types/interface.d.ts +3 -0
  995. package/dist/types/utils/config.d.ts +106 -2
  996. package/dist/types/utils/focus-visible.d.ts +13 -0
  997. package/dist/types/utils/helpers.d.ts +11 -0
  998. package/dist/types/utils/overlays-interface.d.ts +31 -1
  999. package/dist/types/utils/test/playwright/generator.d.ts +31 -2
  1000. package/hydrate/index.js +2714 -902
  1001. package/hydrate/index.mjs +2714 -902
  1002. package/package.json +9 -4
  1003. package/components/hardware-back-button.js +0 -115
  1004. package/components/index9.js +0 -7
  1005. package/dist/cjs/hardware-back-button-D90qZxju.js +0 -121
  1006. package/dist/cjs/index-DkNv4J_i.js +0 -10
  1007. package/dist/esm/hardware-back-button-DcH0BbDp.js +0 -115
  1008. package/dist/esm/index-ZjP4CjeZ.js +0 -7
  1009. package/dist/ionic/p-0fc6fc38.entry.js +0 -4
  1010. package/dist/ionic/p-14ae45e4.entry.js +0 -4
  1011. package/dist/ionic/p-15da9760.entry.js +0 -4
  1012. package/dist/ionic/p-1739f5f2.entry.js +0 -4
  1013. package/dist/ionic/p-18f1813b.entry.js +0 -4
  1014. package/dist/ionic/p-2020aa51.entry.js +0 -4
  1015. package/dist/ionic/p-2c6c6991.entry.js +0 -4
  1016. package/dist/ionic/p-2cfd6b61.entry.js +0 -4
  1017. package/dist/ionic/p-2da6a16b.entry.js +0 -4
  1018. package/dist/ionic/p-3a4feac2.entry.js +0 -4
  1019. package/dist/ionic/p-473877b6.entry.js +0 -4
  1020. package/dist/ionic/p-4b7d1f35.entry.js +0 -4
  1021. package/dist/ionic/p-4d61f20b.entry.js +0 -4
  1022. package/dist/ionic/p-4ddc10ef.entry.js +0 -4
  1023. package/dist/ionic/p-56712fd4.entry.js +0 -4
  1024. package/dist/ionic/p-66510682.entry.js +0 -4
  1025. package/dist/ionic/p-6b666996.entry.js +0 -4
  1026. package/dist/ionic/p-7149db7e.entry.js +0 -4
  1027. package/dist/ionic/p-73d7ad90.entry.js +0 -4
  1028. package/dist/ionic/p-76b697a3.entry.js +0 -4
  1029. package/dist/ionic/p-8957540a.entry.js +0 -4
  1030. package/dist/ionic/p-8a8ef46b.entry.js +0 -4
  1031. package/dist/ionic/p-8c674371.entry.js +0 -4
  1032. package/dist/ionic/p-8f2f76e0.entry.js +0 -4
  1033. package/dist/ionic/p-90f87086.entry.js +0 -4
  1034. package/dist/ionic/p-91bde659.entry.js +0 -4
  1035. package/dist/ionic/p-96389029.entry.js +0 -4
  1036. package/dist/ionic/p-97667b9c.entry.js +0 -4
  1037. package/dist/ionic/p-9b46b31b.entry.js +0 -4
  1038. package/dist/ionic/p-9e699d4a.entry.js +0 -4
  1039. package/dist/ionic/p-9eeaBrnk.js +0 -4
  1040. package/dist/ionic/p-B1MNHTYX.js +0 -4
  1041. package/dist/ionic/p-B3XSxWNQ.js +0 -4
  1042. package/dist/ionic/p-BROiNJRB.js +0 -4
  1043. package/dist/ionic/p-B_U9CtaY.js +0 -5
  1044. package/dist/ionic/p-BhLqfMrf.js +0 -4
  1045. package/dist/ionic/p-BmQduG8c.js +0 -4
  1046. package/dist/ionic/p-BmVRXR1y.js +0 -4
  1047. package/dist/ionic/p-CIGNaXM1.js +0 -4
  1048. package/dist/ionic/p-CL-KfWxq.js +0 -4
  1049. package/dist/ionic/p-CRiGyYOA.js +0 -4
  1050. package/dist/ionic/p-CbI9XwwW.js +0 -4
  1051. package/dist/ionic/p-CtWGkNnJ.js +0 -4
  1052. package/dist/ionic/p-D-7TeYC4.js +0 -4
  1053. package/dist/ionic/p-DCfS5Jk_.js +0 -4
  1054. package/dist/ionic/p-DgdWETCP.js +0 -4
  1055. package/dist/ionic/p-Do-uqmtX.js +0 -4
  1056. package/dist/ionic/p-DzH0J0yi.js +0 -4
  1057. package/dist/ionic/p-QwEXyOze.js +0 -4
  1058. package/dist/ionic/p-ZjP4CjeZ.js +0 -4
  1059. package/dist/ionic/p-a6282370.entry.js +0 -4
  1060. package/dist/ionic/p-a9f99c74.entry.js +0 -4
  1061. package/dist/ionic/p-aIxOGKys.js +0 -4
  1062. package/dist/ionic/p-aa8956c2.entry.js +0 -4
  1063. package/dist/ionic/p-b37dbc31.entry.js +0 -4
  1064. package/dist/ionic/p-b9f79efc.entry.js +0 -4
  1065. package/dist/ionic/p-bNmY-WfR.js +0 -4
  1066. package/dist/ionic/p-bc01c127.entry.js +0 -4
  1067. package/dist/ionic/p-bec79123.entry.js +0 -4
  1068. package/dist/ionic/p-c0335397.entry.js +0 -4
  1069. package/dist/ionic/p-c4912ca5.entry.js +0 -4
  1070. package/dist/ionic/p-c884d7e3.entry.js +0 -4
  1071. package/dist/ionic/p-cb787a4b.entry.js +0 -4
  1072. package/dist/ionic/p-cd12ed1c.entry.js +0 -4
  1073. package/dist/ionic/p-cf632ee2.entry.js +0 -4
  1074. package/dist/ionic/p-d47b85ea.entry.js +0 -4
  1075. package/dist/ionic/p-d8ed5df0.entry.js +0 -4
  1076. package/dist/ionic/p-e1260ed5.entry.js +0 -4
  1077. package/dist/ionic/p-e30ff968.entry.js +0 -4
  1078. package/dist/ionic/p-ead42a37.entry.js +0 -4
  1079. package/dist/ionic/p-f83db8cd.entry.js +0 -4
  1080. package/dist/ionic/p-fbc5481b.entry.js +0 -4
  1081. package/dist/ionic/p-fcc7437b.entry.js +0 -4
  1082. /package/dist/collection/components/{input-password-toggle/input-password-toggle.css → refresher-content/refresher-content.css} +0 -0
@@ -3,20 +3,19 @@
3
3
  */
4
4
  'use strict';
5
5
 
6
- var index = require('./index-DODXXb_r.js');
7
- var hardwareBackButton = require('./hardware-back-button-D90qZxju.js');
8
- var helpers = require('./helpers-BITAzJfi.js');
6
+ var index = require('./index-CmckMMX1.js');
7
+ var focusVisible = require('./focus-visible-BIj-I3-C.js');
8
+ var helpers = require('./helpers-DmAvmm2T.js');
9
9
  var dir = require('./dir-Cn0z1rJH.js');
10
10
  var theme = require('./theme-CeDs6Hcv.js');
11
- var index$1 = require('./index-CVa6JE57.js');
12
- var keyboardController = require('./keyboard-controller-GXBiBRKS.js');
11
+ var index$1 = require('./index-CaZ3uzAD.js');
12
+ var keyboardController = require('./keyboard-controller-yLvXRMuh.js');
13
13
  var cubicBezier = require('./cubic-bezier-DAjy1V-e.js');
14
- var frameworkDelegate = require('./framework-delegate-C7sIJyT5.js');
14
+ var frameworkDelegate = require('./framework-delegate-DfEY5uyC.js');
15
15
  var lockController = require('./lock-controller-aDB9wrEf.js');
16
- var index$2 = require('./index-y0QaNtCi.js');
17
- require('./index-DkNv4J_i.js');
18
- require('./keyboard-UuAS4D_9.js');
19
- require('./capacitor-DmA66EwP.js');
16
+ var index$2 = require('./index-DxVhwe3d.js');
17
+ require('./keyboard-Chl5cusY.js');
18
+ require('./capacitor-CzFst28-.js');
20
19
 
21
20
  const appCss = "html.plt-mobile ion-app{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}html.plt-mobile ion-app [contenteditable]{-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text;user-select:text}ion-app.force-statusbar-padding{--ion-safe-area-top:20px}";
22
21
 
@@ -24,46 +23,6 @@ const App = class {
24
23
  constructor(hostRef) {
25
24
  index.registerInstance(this, hostRef);
26
25
  }
27
- componentDidLoad() {
28
- {
29
- rIC(async () => {
30
- const isHybrid = index.isPlatform(window, 'hybrid');
31
- if (!index.config.getBoolean('_testing')) {
32
- Promise.resolve().then(function () { return require('./index-BDBT0u4l.js'); }).then((module) => module.startTapClick(index.config));
33
- }
34
- if (index.config.getBoolean('statusTap', isHybrid)) {
35
- Promise.resolve().then(function () { return require('./status-tap-Db3WeCkO.js'); }).then((module) => module.startStatusTap());
36
- }
37
- if (index.config.getBoolean('inputShims', needInputShims())) {
38
- /**
39
- * needInputShims() ensures that only iOS and Android
40
- * platforms proceed into this block.
41
- */
42
- const platform = index.isPlatform(window, 'ios') ? 'ios' : 'android';
43
- Promise.resolve().then(function () { return require('./input-shims-D1Mfgd4s.js'); }).then((module) => module.startInputShims(index.config, platform));
44
- }
45
- const hardwareBackButtonModule = await Promise.resolve().then(function () { return require('./hardware-back-button-D90qZxju.js'); });
46
- const supportsHardwareBackButtonEvents = isHybrid || hardwareBackButton.shouldUseCloseWatcher();
47
- if (index.config.getBoolean('hardwareBackButton', supportsHardwareBackButtonEvents)) {
48
- hardwareBackButtonModule.startHardwareBackButton();
49
- }
50
- else {
51
- /**
52
- * If an app sets hardwareBackButton: false and experimentalCloseWatcher: true
53
- * then the close watcher will not be used.
54
- */
55
- if (hardwareBackButton.shouldUseCloseWatcher()) {
56
- index.printIonWarning('[ion-app] - experimentalCloseWatcher was set to `true`, but hardwareBackButton was set to `false`. Both config options must be `true` for the Close Watcher API to be used.');
57
- }
58
- hardwareBackButtonModule.blockHardwareBackButton();
59
- }
60
- if (typeof window !== 'undefined') {
61
- Promise.resolve().then(function () { return require('./keyboard-hHzlEQpk.js'); }).then((module) => module.startKeyboardAssist(window));
62
- }
63
- Promise.resolve().then(function () { return require('./focus-visible-CCvKiLh3.js'); }).then((module) => (this.focusVisible = module.startFocusVisible()));
64
- });
65
- }
66
- }
67
26
  /**
68
27
  * Used to set focus on an element that uses `ion-focusable`.
69
28
  * Do not use this if focusing the element as a result of a keyboard
@@ -72,54 +31,33 @@ const App = class {
72
31
  * a result of another user action. (Ex: We focus the first element
73
32
  * inside of a popover when the user presents it, but the popover is not always
74
33
  * presented as a result of keyboard action.)
34
+ *
35
+ * @param elements - The elements to set focus on.
75
36
  */
76
37
  async setFocus(elements) {
77
- if (this.focusVisible) {
78
- this.focusVisible.setFocus(elements);
79
- }
38
+ /**
39
+ * The focus-visible utility is used to set focus on an
40
+ * element that uses `ion-focusable`.
41
+ */
42
+ focusVisible.focusElements(elements);
80
43
  }
81
44
  render() {
82
- const mode = index.getIonMode(this);
83
- return (index.h(index.Host, { key: '03aa892f986330078d112b1e8b010df98fa7e39e', class: {
84
- [mode]: true,
45
+ const theme = index.getIonTheme(this);
46
+ return (index.h(index.Host, { key: '25667e21b2fffa03ccf013044c340e96bd7faad9', class: {
47
+ [theme]: true,
85
48
  'ion-page': true,
86
49
  'force-statusbar-padding': index.config.getBoolean('_forceStatusbarPadding'),
87
50
  } }));
88
51
  }
89
52
  get el() { return index.getElement(this); }
90
53
  };
91
- const needInputShims = () => {
92
- /**
93
- * iOS always needs input shims
94
- */
95
- const needsShimsIOS = index.isPlatform(window, 'ios') && index.isPlatform(window, 'mobile');
96
- if (needsShimsIOS) {
97
- return true;
98
- }
99
- /**
100
- * Android only needs input shims when running
101
- * in the browser and only if the browser is using the
102
- * new Chrome 108+ resize behavior: https://developer.chrome.com/blog/viewport-resize-behavior/
103
- */
104
- const isAndroidMobileWeb = index.isPlatform(window, 'android') && index.isPlatform(window, 'mobileweb');
105
- if (isAndroidMobileWeb) {
106
- return true;
107
- }
108
- return false;
109
- };
110
- const rIC = (callback) => {
111
- if ('requestIdleCallback' in window) {
112
- window.requestIdleCallback(callback);
113
- }
114
- else {
115
- setTimeout(callback, 32);
116
- }
117
- };
118
54
  App.style = appCss;
119
55
 
120
- const buttonsIosCss = ".sc-ion-buttons-ios-h{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-webkit-transform:translateZ(0);transform:translateZ(0);z-index:99}.sc-ion-buttons-ios-s ion-button{--padding-top:0;--padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}.sc-ion-buttons-ios-s ion-button{--padding-top:3px;--padding-bottom:3px;--padding-start:5px;--padding-end:5px;-webkit-margin-start:2px;margin-inline-start:2px;-webkit-margin-end:2px;margin-inline-end:2px;min-height:32px}.sc-ion-buttons-ios-s .button-has-icon-only{--padding-top:0;--padding-bottom:0}.sc-ion-buttons-ios-s ion-button:not(.button-round){--border-radius:4px}.sc-ion-buttons-ios-h.ion-color.sc-ion-buttons-ios-s .button,.ion-color .sc-ion-buttons-ios-h.sc-ion-buttons-ios-s .button{--color:initial;--border-color:initial;--background-focused:var(--ion-color-contrast)}.sc-ion-buttons-ios-h.ion-color.sc-ion-buttons-ios-s .button-solid,.ion-color .sc-ion-buttons-ios-h.sc-ion-buttons-ios-s .button-solid{--background:var(--ion-color-contrast);--background-focused:#000;--background-focused-opacity:.12;--background-activated:#000;--background-activated-opacity:.12;--background-hover:var(--ion-color-base);--background-hover-opacity:0.45;--color:var(--ion-color-base);--color-focused:var(--ion-color-base)}.sc-ion-buttons-ios-h.ion-color.sc-ion-buttons-ios-s .button-clear,.ion-color .sc-ion-buttons-ios-h.sc-ion-buttons-ios-s .button-clear{--color-activated:var(--ion-color-contrast);--color-focused:var(--ion-color-contrast)}.sc-ion-buttons-ios-h.ion-color.sc-ion-buttons-ios-s .button-outline,.ion-color .sc-ion-buttons-ios-h.sc-ion-buttons-ios-s .button-outline{--color-activated:var(--ion-color-base);--color-focused:var(--ion-color-contrast);--background-activated:var(--ion-color-contrast)}.sc-ion-buttons-ios-s .button-clear,.sc-ion-buttons-ios-s .button-outline{--background-activated:transparent;--background-focused:currentColor;--background-hover:transparent}.sc-ion-buttons-ios-s .button-solid:not(.ion-color){--background-focused:#000;--background-focused-opacity:.12;--background-activated:#000;--background-activated-opacity:.12}.sc-ion-buttons-ios-s ion-icon[slot=start]{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;-webkit-margin-end:0.3em;margin-inline-end:0.3em;font-size:1.41em;line-height:0.67}.sc-ion-buttons-ios-s ion-icon[slot=end]{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;-webkit-margin-start:0.4em;margin-inline-start:0.4em;font-size:1.41em;line-height:0.67}.sc-ion-buttons-ios-s ion-icon[slot=icon-only]{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;font-size:1.65em;line-height:0.67}";
56
+ const buttonsIonicCss = ".sc-ion-buttons-ionic-h{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-webkit-transform:translateZ(0);transform:translateZ(0)}.sc-ion-buttons-ionic-s ion-button{--padding-top:0;--padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}.sc-ion-buttons-ionic-s .button-has-icon-only{--padding-top:0;--padding-bottom:0}.sc-ion-buttons-ionic-s .button-clear{--color:var(--ion-primitives-neutral-1200, #242424);--background:transparent;--background-activated:transparent;--background-focused:transparent;--background-hover:transparent}.sc-ion-buttons-ionic-s .button-has-icon-only{width:var(--ion-scale-1000, 40px);height:var(--ion-scale-1000, 40px)}.sc-ion-buttons-ionic-s ion-icon[slot=icon-only]{font-size:var(--ion-font-size-600, 1.5rem)}";
57
+
58
+ const buttonsIosCss = ".sc-ion-buttons-ios-h{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-webkit-transform:translateZ(0);transform:translateZ(0)}.sc-ion-buttons-ios-s ion-button{--padding-top:0;--padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}.sc-ion-buttons-ios-h{z-index:99}.sc-ion-buttons-ios-s ion-button{--padding-top:0;--padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}.sc-ion-buttons-ios-s ion-button{--padding-top:3px;--padding-bottom:3px;--padding-start:5px;--padding-end:5px;-webkit-margin-start:2px;margin-inline-start:2px;-webkit-margin-end:2px;margin-inline-end:2px;min-height:32px}.sc-ion-buttons-ios-s .button-has-icon-only{--padding-top:0;--padding-bottom:0}.sc-ion-buttons-ios-s ion-button:not(.button-round){--border-radius:4px}.sc-ion-buttons-ios-h.ion-color.sc-ion-buttons-ios-s .button,.ion-color .sc-ion-buttons-ios-h.sc-ion-buttons-ios-s .button{--color:initial;--border-color:initial;--background-focused:var(--ion-color-contrast)}.sc-ion-buttons-ios-h.ion-color.sc-ion-buttons-ios-s .button-solid,.ion-color .sc-ion-buttons-ios-h.sc-ion-buttons-ios-s .button-solid{--background:var(--ion-color-contrast);--background-focused:#000;--background-focused-opacity:0.12;--background-activated:#000;--background-activated-opacity:0.12;--background-hover:var(--ion-color-base);--background-hover-opacity:0.45;--color:var(--ion-color-base);--color-focused:var(--ion-color-base)}.sc-ion-buttons-ios-h.ion-color.sc-ion-buttons-ios-s .button-clear,.ion-color .sc-ion-buttons-ios-h.sc-ion-buttons-ios-s .button-clear{--color-activated:var(--ion-color-contrast);--color-focused:var(--ion-color-contrast)}.sc-ion-buttons-ios-h.ion-color.sc-ion-buttons-ios-s .button-outline,.ion-color .sc-ion-buttons-ios-h.sc-ion-buttons-ios-s .button-outline{--color-activated:var(--ion-color-base);--color-focused:var(--ion-color-contrast);--background-activated:var(--ion-color-contrast)}.sc-ion-buttons-ios-s .button-clear,.sc-ion-buttons-ios-s .button-outline{--background-activated:transparent;--background-focused:currentColor;--background-hover:transparent}.sc-ion-buttons-ios-s .button-solid:not(.ion-color){--background-focused:#000;--background-focused-opacity:0.12;--background-activated:#000;--background-activated-opacity:0.12}.sc-ion-buttons-ios-s ion-icon[slot=start]{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;-webkit-margin-end:0.3em;margin-inline-end:0.3em;font-size:1.41em;line-height:0.67}.sc-ion-buttons-ios-s ion-icon[slot=end]{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;-webkit-margin-start:0.4em;margin-inline-start:0.4em;font-size:1.41em;line-height:0.67}.sc-ion-buttons-ios-s ion-icon[slot=icon-only]{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;font-size:1.65em;line-height:0.67}";
121
59
 
122
- const buttonsMdCss = ".sc-ion-buttons-md-h{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-webkit-transform:translateZ(0);transform:translateZ(0);z-index:99}.sc-ion-buttons-md-s ion-button{--padding-top:0;--padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}.sc-ion-buttons-md-s ion-button{--padding-top:3px;--padding-bottom:3px;--padding-start:8px;--padding-end:8px;--box-shadow:none;-webkit-margin-start:2px;margin-inline-start:2px;-webkit-margin-end:2px;margin-inline-end:2px;min-height:32px}.sc-ion-buttons-md-s .button-has-icon-only{--padding-top:0;--padding-bottom:0}.sc-ion-buttons-md-s ion-button:not(.button-round){--border-radius:2px}.sc-ion-buttons-md-h.ion-color.sc-ion-buttons-md-s .button,.ion-color .sc-ion-buttons-md-h.sc-ion-buttons-md-s .button{--color:initial;--color-focused:var(--ion-color-contrast);--color-hover:var(--ion-color-contrast);--background-activated:transparent;--background-focused:var(--ion-color-contrast);--background-hover:var(--ion-color-contrast)}.sc-ion-buttons-md-h.ion-color.sc-ion-buttons-md-s .button-solid,.ion-color .sc-ion-buttons-md-h.sc-ion-buttons-md-s .button-solid{--background:var(--ion-color-contrast);--background-activated:transparent;--background-focused:var(--ion-color-shade);--background-hover:var(--ion-color-base);--color:var(--ion-color-base);--color-focused:var(--ion-color-base);--color-hover:var(--ion-color-base)}.sc-ion-buttons-md-h.ion-color.sc-ion-buttons-md-s .button-outline,.ion-color .sc-ion-buttons-md-h.sc-ion-buttons-md-s .button-outline{--border-color:var(--ion-color-contrast)}.sc-ion-buttons-md-s .button-has-icon-only.button-clear{--padding-top:12px;--padding-end:12px;--padding-bottom:12px;--padding-start:12px;--border-radius:50%;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;width:3rem;height:3rem}.sc-ion-buttons-md-s .button{--background-hover:currentColor}.sc-ion-buttons-md-s .button-solid{--color:var(--ion-toolbar-background, var(--ion-background-color, #fff));--background:var(--ion-toolbar-color, var(--ion-text-color, #424242));--background-activated:transparent;--background-focused:currentColor}.sc-ion-buttons-md-s .button-outline{--color:initial;--background:transparent;--background-activated:transparent;--background-focused:currentColor;--background-hover:currentColor;--border-color:currentColor}.sc-ion-buttons-md-s .button-clear{--color:initial;--background:transparent;--background-activated:transparent;--background-focused:currentColor;--background-hover:currentColor}.sc-ion-buttons-md-s ion-icon[slot=start]{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;-webkit-margin-end:0.3em;margin-inline-end:0.3em;font-size:1.4em}.sc-ion-buttons-md-s ion-icon[slot=end]{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;-webkit-margin-start:0.4em;margin-inline-start:0.4em;font-size:1.4em}.sc-ion-buttons-md-s ion-icon[slot=icon-only]{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;font-size:1.8em}";
60
+ const buttonsMdCss = ".sc-ion-buttons-md-h{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-webkit-transform:translateZ(0);transform:translateZ(0)}.sc-ion-buttons-md-s ion-button{--padding-top:0;--padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}.sc-ion-buttons-md-h{z-index:99}.sc-ion-buttons-md-s ion-button{--padding-top:0;--padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}.sc-ion-buttons-md-s ion-button{--padding-top:3px;--padding-bottom:3px;--padding-start:8px;--padding-end:8px;--box-shadow:none;-webkit-margin-start:2px;margin-inline-start:2px;-webkit-margin-end:2px;margin-inline-end:2px;min-height:32px}.sc-ion-buttons-md-s .button-has-icon-only{--padding-top:0;--padding-bottom:0}.sc-ion-buttons-md-s ion-button:not(.button-round){--border-radius:2px}.sc-ion-buttons-md-h.ion-color.sc-ion-buttons-md-s .button,.ion-color .sc-ion-buttons-md-h.sc-ion-buttons-md-s .button{--color:initial;--color-focused:var(--ion-color-contrast);--color-hover:var(--ion-color-contrast);--background-activated:transparent;--background-focused:var(--ion-color-contrast);--background-hover:var(--ion-color-contrast)}.sc-ion-buttons-md-h.ion-color.sc-ion-buttons-md-s .button-solid,.ion-color .sc-ion-buttons-md-h.sc-ion-buttons-md-s .button-solid{--background:var(--ion-color-contrast);--background-activated:transparent;--background-focused:var(--ion-color-shade);--background-hover:var(--ion-color-base);--color:var(--ion-color-base);--color-focused:var(--ion-color-base);--color-hover:var(--ion-color-base)}.sc-ion-buttons-md-h.ion-color.sc-ion-buttons-md-s .button-outline,.ion-color .sc-ion-buttons-md-h.sc-ion-buttons-md-s .button-outline{--border-color:var(--ion-color-contrast)}.sc-ion-buttons-md-s .button-has-icon-only.button-clear{--padding-top:12px;--padding-end:12px;--padding-bottom:12px;--padding-start:12px;--border-radius:50%;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;width:3rem;height:3rem}.sc-ion-buttons-md-s .button{--background-hover:currentColor}.sc-ion-buttons-md-s .button-solid{--color:var(--ion-toolbar-background, var(--ion-background-color, #fff));--background:var(--ion-toolbar-color, var(--ion-text-color, #424242));--background-activated:transparent;--background-focused:currentColor}.sc-ion-buttons-md-s .button-outline{--color:initial;--background:transparent;--background-activated:transparent;--background-focused:currentColor;--background-hover:currentColor;--border-color:currentColor}.sc-ion-buttons-md-s .button-clear{--color:initial;--background:transparent;--background-activated:transparent;--background-focused:currentColor;--background-hover:currentColor}.sc-ion-buttons-md-s ion-icon[slot=start]{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;-webkit-margin-end:0.3em;margin-inline-end:0.3em;font-size:1.4em}.sc-ion-buttons-md-s ion-icon[slot=end]{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;-webkit-margin-start:0.4em;margin-inline-start:0.4em;font-size:1.4em}.sc-ion-buttons-md-s ion-icon[slot=icon-only]{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;font-size:1.8em}";
123
61
 
124
62
  const Buttons = class {
125
63
  constructor(hostRef) {
@@ -131,7 +69,7 @@ const Buttons = class {
131
69
  * first toolbar, the buttons will be hidden and will
132
70
  * only be shown once all toolbars have fully collapsed.
133
71
  *
134
- * Only applies in `ios` mode with `collapse` set to
72
+ * Only applies in the `ios` theme with `collapse` set to
135
73
  * `true` on `ion-header`.
136
74
  *
137
75
  * Typically used for [Collapsible Large Titles](https://ionicframework.com/docs/api/title#collapsible-large-titles)
@@ -139,19 +77,20 @@ const Buttons = class {
139
77
  this.collapse = false;
140
78
  }
141
79
  render() {
142
- const mode = index.getIonMode(this);
143
- return (index.h(index.Host, { key: '58c1fc5eb867d0731c63549b1ccb3ec3bbbe6e1b', class: {
144
- [mode]: true,
80
+ const theme = index.getIonTheme(this);
81
+ return (index.h(index.Host, { key: '95c107ba7871c801a5ef14c636dc8e2fe69debf3', class: {
82
+ [theme]: true,
145
83
  ['buttons-collapse']: this.collapse,
146
- } }, index.h("slot", { key: '0c8f95b9840c8fa0c4e50be84c5159620a3eb5c8' })));
84
+ } }, index.h("slot", { key: '58669abfce458e1344b84286d4200e305017b958' })));
147
85
  }
148
86
  };
149
87
  Buttons.style = {
88
+ ionic: buttonsIonicCss,
150
89
  ios: buttonsIosCss,
151
90
  md: buttonsMdCss
152
91
  };
153
92
 
154
- const contentCss = ":host{--background:var(--ion-background-color, #fff);--color:var(--ion-text-color, #000);--padding-top:0px;--padding-bottom:0px;--padding-start:0px;--padding-end:0px;--keyboard-offset:0px;--offset-top:0px;--offset-bottom:0px;--overflow:auto;display:block;position:relative;-ms-flex:1;flex:1;width:100%;height:100%;margin:0 !important;padding:0 !important;font-family:var(--ion-font-family, inherit);contain:size style}:host(.ion-color) .inner-scroll{background:var(--ion-color-base);color:var(--ion-color-contrast)}#background-content{left:0px;right:0px;top:calc(var(--offset-top) * -1);bottom:calc(var(--offset-bottom) * -1);position:absolute;background:var(--background)}.inner-scroll{left:0px;right:0px;top:calc(var(--offset-top) * -1);bottom:calc(var(--offset-bottom) * -1);-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end);padding-top:calc(var(--padding-top) + var(--offset-top));padding-bottom:calc(var(--padding-bottom) + var(--keyboard-offset) + var(--offset-bottom));position:absolute;color:var(--color);-webkit-box-sizing:border-box;box-sizing:border-box;overflow:hidden;-ms-touch-action:pan-x pan-y pinch-zoom;touch-action:pan-x pan-y pinch-zoom}.scroll-y,.scroll-x{-webkit-overflow-scrolling:touch;z-index:0;will-change:scroll-position}.scroll-y{overflow-y:var(--overflow);overscroll-behavior-y:contain}.scroll-x{overflow-x:var(--overflow);overscroll-behavior-x:contain}.overscroll::before,.overscroll::after{position:absolute;width:1px;height:1px;content:\"\"}.overscroll::before{bottom:-1px}.overscroll::after{top:-1px}:host(.content-sizing){display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;min-height:0;contain:none}:host(.content-sizing) .inner-scroll{position:relative;top:0;bottom:0;margin-top:calc(var(--offset-top) * -1);margin-bottom:calc(var(--offset-bottom) * -1)}.transition-effect{display:none;position:absolute;width:100%;height:100vh;opacity:0;pointer-events:none}:host(.content-ltr) .transition-effect{left:-100%;}:host(.content-rtl) .transition-effect{right:-100%;}.transition-cover{position:absolute;right:0;width:100%;height:100%;background:black;opacity:0.1}.transition-shadow{display:block;position:absolute;width:100%;height:100%;-webkit-box-shadow:inset -9px 0 9px 0 rgba(0, 0, 100, 0.03);box-shadow:inset -9px 0 9px 0 rgba(0, 0, 100, 0.03)}:host(.content-ltr) .transition-shadow{right:0;}:host(.content-rtl) .transition-shadow{left:0;-webkit-transform:scaleX(-1);transform:scaleX(-1)}::slotted([slot=fixed]){position:absolute;-webkit-transform:translateZ(0);transform:translateZ(0)}";
93
+ const contentCss = ":host{--background:var(--ion-background-color, #fff);--color:var(--ion-text-color, #000);--padding-top:0px;--padding-bottom:0px;--padding-start:0px;--padding-end:0px;--keyboard-offset:0px;--offset-top:0px;--offset-bottom:0px;--overflow:auto;display:block;position:relative;-ms-flex:1;flex:1;width:100%;height:100%;margin:0 !important;padding:0 !important;font-family:var(--ion-font-family, inherit);contain:size style}:host(.ion-color) .inner-scroll{background:var(--ion-color-base);color:var(--ion-color-contrast)}#background-content{right:0px;left:0px;top:calc(var(--offset-top) * -1);bottom:calc(var(--offset-bottom) * -1);position:absolute;background:var(--background)}.inner-scroll{right:0px;left:0px;top:calc(var(--offset-top) * -1);bottom:calc(var(--offset-bottom) * -1);-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end);padding-top:calc(var(--padding-top) + var(--offset-top));padding-bottom:calc(var(--padding-bottom) + var(--keyboard-offset) + var(--offset-bottom));position:absolute;color:var(--color);-webkit-box-sizing:border-box;box-sizing:border-box;overflow:hidden;-ms-touch-action:pan-x pan-y pinch-zoom;touch-action:pan-x pan-y pinch-zoom}.scroll-y,.scroll-x{-webkit-overflow-scrolling:touch;z-index:0;will-change:scroll-position}.scroll-y{overflow-y:var(--overflow);overscroll-behavior-y:contain}.scroll-x{overflow-x:var(--overflow);overscroll-behavior-x:contain}.overscroll::before,.overscroll::after{position:absolute;width:1px;height:1px;content:\"\"}.overscroll::before{bottom:-1px}.overscroll::after{top:-1px}:host(.content-sizing){display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;min-height:0;contain:none}:host(.content-sizing) .inner-scroll{position:relative;top:0;bottom:0;margin-top:calc(var(--offset-top) * -1);margin-bottom:calc(var(--offset-bottom) * -1)}.transition-effect{display:none;position:absolute;width:100%;height:100vh;opacity:0;pointer-events:none}:host(.content-ltr) .transition-effect{left:-100%;}:host(.content-rtl) .transition-effect{right:-100%;}.transition-cover{position:absolute;right:0;width:100%;height:100%;background:black;opacity:0.1}.transition-shadow{display:block;position:absolute;width:100%;height:100%;-webkit-box-shadow:inset -9px 0 9px 0 rgba(0, 0, 100, 0.03);box-shadow:inset -9px 0 9px 0 rgba(0, 0, 100, 0.03)}:host(.content-ltr) .transition-shadow{right:0;}:host(.content-rtl) .transition-shadow{left:0;-webkit-transform:scaleX(-1);transform:scaleX(-1)}::slotted([slot=fixed]){position:absolute;-webkit-transform:translateZ(0);transform:translateZ(0)}";
155
94
 
156
95
  const Content = class {
157
96
  constructor(hostRef) {
@@ -310,9 +249,8 @@ const Content = class {
310
249
  this.resize();
311
250
  }, 100);
312
251
  }
313
- shouldForceOverscroll() {
252
+ shouldForceOverscroll(mode) {
314
253
  const { forceOverscroll } = this;
315
- const mode = index.getIonMode(this);
316
254
  return forceOverscroll === undefined ? mode === 'ios' && index.isPlatform('ios') : forceOverscroll;
317
255
  }
318
256
  resize() {
@@ -499,24 +437,25 @@ const Content = class {
499
437
  render() {
500
438
  const { fixedSlotPlacement, inheritedAttributes, isMainContent, scrollX, scrollY, el } = this;
501
439
  const rtl = dir.isRTL(el) ? 'rtl' : 'ltr';
502
- const mode = index.getIonMode(this);
503
- const forceOverscroll = this.shouldForceOverscroll();
504
- const transitionShadow = mode === 'ios';
440
+ const theme$1 = index.getIonTheme(this);
441
+ const mode = index.getIonMode(this, theme$1);
442
+ const forceOverscroll = this.shouldForceOverscroll(mode);
443
+ const transitionShadow = theme$1 === 'ios';
505
444
  this.resize();
506
- return (index.h(index.Host, Object.assign({ key: 'f2a24aa66dbf5c76f9d4b06f708eb73cadc239df', role: isMainContent ? 'main' : undefined, class: theme.createColorClasses(this.color, {
507
- [mode]: true,
445
+ return (index.h(index.Host, Object.assign({ key: 'ee94e34dd128cb2a21ef2b370d35e099a1125447', role: isMainContent ? 'main' : undefined, class: theme.createColorClasses(this.color, {
446
+ [theme$1]: true,
508
447
  'content-sizing': theme.hostContext('ion-popover', this.el),
509
448
  overscroll: forceOverscroll,
510
449
  [`content-${rtl}`]: true,
511
450
  }), style: {
512
451
  '--offset-top': `${this.cTop}px`,
513
452
  '--offset-bottom': `${this.cBottom}px`,
514
- } }, inheritedAttributes), index.h("div", { key: '6480ca7648b278abb36477b3838bccbcd4995e2a', ref: (el) => (this.backgroundContentEl = el), id: "background-content", part: "background" }), fixedSlotPlacement === 'before' ? index.h("slot", { name: "fixed" }) : null, index.h("div", { key: '29a23b663f5f0215bb000820c01e1814c0d55985', class: {
453
+ } }, inheritedAttributes), index.h("div", { key: '75954692de33cae260441064d0c4034d818b7de6', ref: (el) => (this.backgroundContentEl = el), id: "background-content", part: "background" }), fixedSlotPlacement === 'before' ? index.h("slot", { name: "fixed" }) : null, index.h("div", { key: '374f5d2da6f15b42df0ad268c2f9a188ac6aedcb', class: {
515
454
  'inner-scroll': true,
516
455
  'scroll-x': scrollX,
517
456
  'scroll-y': scrollY,
518
457
  overscroll: (scrollX || scrollY) && forceOverscroll,
519
- }, ref: (scrollEl) => (this.scrollEl = scrollEl), onScroll: this.scrollEvents ? (ev) => this.onScroll(ev) : undefined, part: "scroll" }, index.h("slot", { key: '0fe1bd05609a4b88ae2ce9addf5d5dc5dc1806f0' })), transitionShadow ? (index.h("div", { class: "transition-effect" }, index.h("div", { class: "transition-cover" }), index.h("div", { class: "transition-shadow" }))) : null, fixedSlotPlacement === 'after' ? index.h("slot", { name: "fixed" }) : null));
458
+ }, ref: (scrollEl) => (this.scrollEl = scrollEl), onScroll: this.scrollEvents ? (ev) => this.onScroll(ev) : undefined, part: "scroll" }, index.h("slot", { key: '625c1dc26f6b6c43ade2de6f61a92ae7a8bcbaa7' })), transitionShadow ? (index.h("div", { class: "transition-effect" }, index.h("div", { class: "transition-cover" }), index.h("div", { class: "transition-shadow" }))) : null, fixedSlotPlacement === 'after' ? index.h("slot", { name: "fixed" }) : null));
520
459
  }
521
460
  get el() { return index.getElement(this); }
522
461
  };
@@ -542,7 +481,8 @@ const getPageElement = (el) => {
542
481
  * between the popover and the edges of the screen. But if the popover contains
543
482
  * its own page element, we should use that instead.
544
483
  */
545
- const page = el.closest('ion-app, ion-page, .ion-page, page-inner, .popover-content');
484
+ const appRootSelector = index.config.get('appRootSelector', 'ion-app');
485
+ const page = el.closest(`${appRootSelector}, ion-page, .ion-page, page-inner, .popover-content`);
546
486
  if (page) {
547
487
  return page;
548
488
  }
@@ -606,7 +546,9 @@ const handleFooterFade = (scrollEl, baseEl) => {
606
546
  });
607
547
  };
608
548
 
609
- const footerIosCss = "ion-footer{display:block;position:relative;-ms-flex-order:1;order:1;width:100%;z-index:10}ion-footer.footer-toolbar-padding ion-toolbar:last-of-type{padding-bottom:var(--ion-safe-area-bottom, 0)}.footer-ios ion-toolbar:first-of-type{--border-width:0.55px 0 0}@supports ((-webkit-backdrop-filter: blur(0)) or (backdrop-filter: blur(0))){.footer-background{left:0;right:0;top:0;bottom:0;position:absolute;-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px)}.footer-translucent-ios ion-toolbar{--opacity:.8}}.footer-ios.ion-no-border ion-toolbar:first-of-type{--border-width:0}.footer-collapse-fade ion-toolbar{--opacity-scale:inherit}";
549
+ const ionicFooterMdCss = "ion-footer{display:block;position:relative;-ms-flex-order:1;order:1;width:100%;z-index:10}ion-footer.footer-toolbar-padding ion-toolbar:last-of-type{padding-bottom:var(--ion-safe-area-bottom, 0)}.footer-md{-webkit-box-shadow:0 2px 4px -1px rgba(0, 0, 0, 0.2), 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12);box-shadow:0 2px 4px -1px rgba(0, 0, 0, 0.2), 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12)}.footer-md.ion-no-border{-webkit-box-shadow:none;box-shadow:none}";
550
+
551
+ const footerIosCss = "ion-footer{display:block;position:relative;-ms-flex-order:1;order:1;width:100%;z-index:10}ion-footer.footer-toolbar-padding ion-toolbar:last-of-type{padding-bottom:var(--ion-safe-area-bottom, 0)}.footer-ios ion-toolbar:first-of-type{--border-width:0.55px 0 0}@supports ((-webkit-backdrop-filter: blur(0)) or (backdrop-filter: blur(0))){.footer-background{right:0;left:0;top:0;bottom:0;position:absolute;-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px)}.footer-translucent-ios ion-toolbar{--opacity:0.8}}.footer-ios.ion-no-border ion-toolbar:first-of-type{--border-width:0}.footer-collapse-fade ion-toolbar{--opacity-scale:inherit}";
610
552
 
611
553
  const footerMdCss = "ion-footer{display:block;position:relative;-ms-flex-order:1;order:1;width:100%;z-index:10}ion-footer.footer-toolbar-padding ion-toolbar:last-of-type{padding-bottom:var(--ion-safe-area-bottom, 0)}.footer-md{-webkit-box-shadow:0 2px 4px -1px rgba(0, 0, 0, 0.2), 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12);box-shadow:0 2px 4px -1px rgba(0, 0, 0, 0.2), 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12)}.footer-md.ion-no-border{-webkit-box-shadow:none;box-shadow:none}";
612
554
 
@@ -617,7 +559,7 @@ const Footer = class {
617
559
  this.keyboardVisible = false;
618
560
  /**
619
561
  * If `true`, the footer will be translucent.
620
- * Only applies when the mode is `"ios"` and the device supports
562
+ * Only applies when the theme is `"ios"` and the device supports
621
563
  * [`backdrop-filter`](https://developer.mozilla.org/en-US/docs/Web/CSS/backdrop-filter#Browser_compatibility).
622
564
  *
623
565
  * Note: In order to scroll content behind the footer, the `fullscreen`
@@ -625,15 +567,16 @@ const Footer = class {
625
567
  */
626
568
  this.translucent = false;
627
569
  this.checkCollapsibleFooter = () => {
628
- const mode = index.getIonMode(this);
629
- if (mode !== 'ios') {
570
+ const theme = index.getIonTheme(this);
571
+ if (theme !== 'ios') {
630
572
  return;
631
573
  }
632
574
  const { collapse } = this;
633
575
  const hasFade = collapse === 'fade';
634
576
  this.destroyCollapsibleFooter();
635
577
  if (hasFade) {
636
- const pageEl = this.el.closest('ion-app,ion-page,.ion-page,page-inner');
578
+ const appRootSelector = index.config.get('appRootSelector', 'ion-app');
579
+ const pageEl = this.el.closest(`${appRootSelector},ion-page,.ion-page,page-inner`);
637
580
  const contentEl = pageEl ? index$1.findIonContent(pageEl) : null;
638
581
  if (!contentEl) {
639
582
  index$1.printIonContentErrorMsg(this.el);
@@ -686,22 +629,23 @@ const Footer = class {
686
629
  }
687
630
  render() {
688
631
  const { translucent, collapse } = this;
689
- const mode = index.getIonMode(this);
632
+ const theme = index.getIonTheme(this);
690
633
  const tabs = this.el.closest('ion-tabs');
691
634
  const tabBar = tabs === null || tabs === void 0 ? void 0 : tabs.querySelector(':scope > ion-tab-bar');
692
- return (index.h(index.Host, { key: 'ddc228f1a1e7fa4f707dccf74db2490ca3241137', role: "contentinfo", class: {
693
- [mode]: true,
635
+ return (index.h(index.Host, { key: 'e70e2616f69a6205a1c2045bf13a792c9a6bc27c', role: "contentinfo", class: {
636
+ [theme]: true,
694
637
  // Used internally for styling
695
- [`footer-${mode}`]: true,
638
+ [`footer-${theme}`]: true,
696
639
  [`footer-translucent`]: translucent,
697
- [`footer-translucent-${mode}`]: translucent,
640
+ [`footer-translucent-${theme}`]: translucent,
698
641
  ['footer-toolbar-padding']: !this.keyboardVisible && (!tabBar || tabBar.slot !== 'bottom'),
699
642
  [`footer-collapse-${collapse}`]: collapse !== undefined,
700
- } }, mode === 'ios' && translucent && index.h("div", { key: 'e16ed4963ff94e06de77eb8038201820af73937c', class: "footer-background" }), index.h("slot", { key: 'f186934febf85d37133d9351a96c1a64b0a4b203' })));
643
+ } }, theme === 'ios' && translucent && index.h("div", { key: '72803059c1d82a766a0ce69e5a8a6a3b7e576700', class: "footer-background" }), index.h("slot", { key: 'de450e4eb8f5c63b11f548061f29d957ef308539' })));
701
644
  }
702
645
  get el() { return index.getElement(this); }
703
646
  };
704
647
  Footer.style = {
648
+ ionic: ionicFooterMdCss,
705
649
  ios: footerIosCss,
706
650
  md: footerMdCss
707
651
  };
@@ -901,17 +845,24 @@ const handleHeaderFade = (scrollEl, baseEl, condenseHeader) => {
901
845
  });
902
846
  };
903
847
 
904
- const headerIosCss = "ion-header{display:block;position:relative;-ms-flex-order:-1;order:-1;width:100%;z-index:10}ion-header ion-toolbar:first-of-type{padding-top:var(--ion-safe-area-top, 0)}.header-ios ion-toolbar:last-of-type{--border-width:0 0 0.55px}@supports ((-webkit-backdrop-filter: blur(0)) or (backdrop-filter: blur(0))){.header-background{left:0;right:0;top:0;bottom:0;position:absolute;-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px)}.header-translucent-ios ion-toolbar{--opacity:.8}.header-collapse-condense-inactive .header-background{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}}.header-ios.ion-no-border ion-toolbar:last-of-type{--border-width:0}.header-collapse-fade ion-toolbar{--opacity-scale:inherit}.header-collapse-condense{z-index:9}.header-collapse-condense ion-toolbar{position:-webkit-sticky;position:sticky;top:0}.header-collapse-condense ion-toolbar:first-of-type{padding-top:0px;z-index:1}.header-collapse-condense ion-toolbar{--background:var(--ion-background-color, #fff);z-index:0}.header-collapse-condense ion-toolbar:last-of-type{--border-width:0px}.header-collapse-condense ion-toolbar ion-searchbar{padding-top:0px;padding-bottom:13px}.header-collapse-main{--opacity-scale:1}.header-collapse-main ion-toolbar{--opacity-scale:inherit}.header-collapse-main ion-toolbar.in-toolbar ion-title,.header-collapse-main ion-toolbar.in-toolbar ion-buttons{-webkit-transition:all 0.2s ease-in-out;transition:all 0.2s ease-in-out}.header-collapse-condense-inactive:not(.header-collapse-condense) ion-toolbar.in-toolbar ion-title,.header-collapse-condense-inactive:not(.header-collapse-condense) ion-toolbar.in-toolbar ion-buttons.buttons-collapse{opacity:0;pointer-events:none}.header-collapse-condense-inactive.header-collapse-condense ion-toolbar.in-toolbar ion-title,.header-collapse-condense-inactive.header-collapse-condense ion-toolbar.in-toolbar ion-buttons.buttons-collapse{visibility:hidden}ion-header.header-ios:not(.header-collapse-main):has(~ion-content ion-header.header-ios[collapse=condense],~ion-content ion-header.header-ios.header-collapse-condense){opacity:0}";
848
+ const headerIonicCss = "ion-header{display:block;position:relative;-ms-flex-order:-1;order:-1;width:100%}ion-header ion-toolbar:first-of-type{padding-top:var(--ion-safe-area-top, 0)}ion-header{-webkit-box-shadow:var(--ion-elevation-2, 0px 1px 5px 0px rgba(0, 0, 0, 0.05), 0px 8px 25px 0px rgba(0, 0, 0, 0.08));box-shadow:var(--ion-elevation-2, 0px 1px 5px 0px rgba(0, 0, 0, 0.05), 0px 8px 25px 0px rgba(0, 0, 0, 0.08));z-index:10}ion-header.header-divider{border-bottom:var(--ion-border-size-025, var(--ion-scale-025, 1px)) var(--ion-border-style-solid, solid) var(--ion-primitives-neutral-300, #e0e0e0)}ion-toolbar+ion-toolbar{--padding-start:var(--ion-space-400, var(--ion-scale-400, 16px));--padding-end:var(--ion-space-400, var(--ion-scale-400, 16px))}";
849
+
850
+ const headerIosCss = "ion-header{display:block;position:relative;-ms-flex-order:-1;order:-1;width:100%}ion-header ion-toolbar:first-of-type{padding-top:var(--ion-safe-area-top, 0)}ion-header{z-index:10}.header-ios ion-toolbar:last-of-type{--border-width:0 0 0.55px}@supports ((-webkit-backdrop-filter: blur(0)) or (backdrop-filter: blur(0))){.header-background{right:0;left:0;top:0;bottom:0;position:absolute;-webkit-backdrop-filter:saturate(180%) blur(20px);backdrop-filter:saturate(180%) blur(20px)}.header-translucent-ios ion-toolbar{--opacity:0.8}.header-collapse-condense-inactive .header-background{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}}.header-ios.ion-no-border ion-toolbar:last-of-type{--border-width:0}.header-collapse-fade ion-toolbar{--opacity-scale:inherit}.header-collapse-condense{z-index:9}.header-collapse-condense ion-toolbar{position:-webkit-sticky;position:sticky;top:0}.header-collapse-condense ion-toolbar:first-of-type{padding-top:0px;z-index:1}.header-collapse-condense ion-toolbar{--background:var(--ion-background-color, #fff);z-index:0}.header-collapse-condense ion-toolbar:last-of-type{--border-width:0px}.header-collapse-condense ion-toolbar ion-searchbar{padding-top:0px;padding-bottom:13px}.header-collapse-main{--opacity-scale:1}.header-collapse-main ion-toolbar{--opacity-scale:inherit}.header-collapse-main ion-toolbar.in-toolbar ion-title,.header-collapse-main ion-toolbar.in-toolbar ion-buttons{-webkit-transition:all 0.2s ease-in-out;transition:all 0.2s ease-in-out}.header-collapse-condense-inactive:not(.header-collapse-condense) ion-toolbar.in-toolbar ion-title,.header-collapse-condense-inactive:not(.header-collapse-condense) ion-toolbar.in-toolbar ion-buttons.buttons-collapse{opacity:0;pointer-events:none}.header-collapse-condense-inactive.header-collapse-condense ion-toolbar.in-toolbar ion-title,.header-collapse-condense-inactive.header-collapse-condense ion-toolbar.in-toolbar ion-buttons.buttons-collapse{visibility:hidden}ion-header.header-ios:not(.header-collapse-main):has(~ion-content ion-header.header-ios[collapse=condense],~ion-content ion-header.header-ios.header-collapse-condense){opacity:0}";
905
851
 
906
- const headerMdCss = "ion-header{display:block;position:relative;-ms-flex-order:-1;order:-1;width:100%;z-index:10}ion-header ion-toolbar:first-of-type{padding-top:var(--ion-safe-area-top, 0)}.header-md{-webkit-box-shadow:0 2px 4px -1px rgba(0, 0, 0, 0.2), 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12);box-shadow:0 2px 4px -1px rgba(0, 0, 0, 0.2), 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12)}.header-collapse-condense{display:none}.header-md.ion-no-border{-webkit-box-shadow:none;box-shadow:none}";
852
+ const headerMdCss = "ion-header{display:block;position:relative;-ms-flex-order:-1;order:-1;width:100%}ion-header ion-toolbar:first-of-type{padding-top:var(--ion-safe-area-top, 0)}ion-header{z-index:10}.header-md{-webkit-box-shadow:0 2px 4px -1px rgba(0, 0, 0, 0.2), 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12);box-shadow:0 2px 4px -1px rgba(0, 0, 0, 0.2), 0 4px 5px 0 rgba(0, 0, 0, 0.14), 0 1px 10px 0 rgba(0, 0, 0, 0.12)}.header-collapse-condense{display:none}.header-md.ion-no-border{-webkit-box-shadow:none;box-shadow:none}";
907
853
 
908
854
  const Header = class {
909
855
  constructor(hostRef) {
910
856
  index.registerInstance(this, hostRef);
911
857
  this.inheritedAttributes = {};
858
+ /**
859
+ * If `true`, the header will have a line at the bottom.
860
+ * TODO(ROU-10855): add support for this prop on ios/md themes
861
+ */
862
+ this.divider = false;
912
863
  /**
913
864
  * If `true`, the header will be translucent.
914
- * Only applies when the mode is `"ios"` and the device supports
865
+ * Only applies when the theme is `"ios"` and the device supports
915
866
  * [`backdrop-filter`](https://developer.mozilla.org/en-US/docs/Web/CSS/backdrop-filter#Browser_compatibility).
916
867
  *
917
868
  * Note: In order to scroll content behind the header, the `fullscreen`
@@ -943,16 +894,17 @@ const Header = class {
943
894
  this.destroyCollapsibleHeader();
944
895
  }
945
896
  async checkCollapsibleHeader() {
946
- const mode = index.getIonMode(this);
947
- if (mode !== 'ios') {
897
+ const theme = index.getIonTheme(this);
898
+ if (theme !== 'ios') {
948
899
  return;
949
900
  }
950
901
  const { collapse } = this;
951
902
  const hasCondense = collapse === 'condense';
952
903
  const hasFade = collapse === 'fade';
953
904
  this.destroyCollapsibleHeader();
905
+ const appRootSelector = index.config.get('appRootSelector', 'ion-app');
954
906
  if (hasCondense) {
955
- const pageEl = this.el.closest('ion-app,ion-page,.ion-page,page-inner');
907
+ const pageEl = this.el.closest(`${appRootSelector},ion-page,.ion-page,page-inner`);
956
908
  const contentEl = pageEl ? index$1.findIonContent(pageEl) : null;
957
909
  // Cloned elements are always needed in iOS transition
958
910
  index.writeTask(() => {
@@ -963,7 +915,7 @@ const Header = class {
963
915
  await this.setupCondenseHeader(contentEl, pageEl);
964
916
  }
965
917
  else if (hasFade) {
966
- const pageEl = this.el.closest('ion-app,ion-page,.ion-page,page-inner');
918
+ const pageEl = this.el.closest(`${appRootSelector},ion-page,.ion-page,page-inner`);
967
919
  const contentEl = pageEl ? index$1.findIonContent(pageEl) : null;
968
920
  if (!contentEl) {
969
921
  index$1.printIonContentErrorMsg(this.el);
@@ -1038,28 +990,30 @@ const Header = class {
1038
990
  });
1039
991
  }
1040
992
  render() {
1041
- const { translucent, inheritedAttributes } = this;
1042
- const mode = index.getIonMode(this);
993
+ const { translucent, inheritedAttributes, divider } = this;
994
+ const theme$1 = index.getIonTheme(this);
1043
995
  const collapse = this.collapse || 'none';
1044
996
  // banner role must be at top level, so remove role if inside a menu
1045
997
  const roleType = theme.hostContext('ion-menu', this.el) ? 'none' : 'banner';
1046
- return (index.h(index.Host, Object.assign({ key: 'b6cc27f0b08afc9fcc889683525da765d80ba672', role: roleType, class: {
1047
- [mode]: true,
998
+ return (index.h(index.Host, Object.assign({ key: '7f58480b7f04b9d700bcc08d2418d121ec8f4124', role: roleType, class: {
999
+ [theme$1]: true,
1048
1000
  // Used internally for styling
1049
- [`header-${mode}`]: true,
1001
+ [`header-${theme$1}`]: true,
1050
1002
  [`header-translucent`]: this.translucent,
1051
1003
  [`header-collapse-${collapse}`]: true,
1052
- [`header-translucent-${mode}`]: this.translucent,
1053
- } }, inheritedAttributes), mode === 'ios' && translucent && index.h("div", { key: '395766d4dcee3398bc91960db21f922095292f14', class: "header-background" }), index.h("slot", { key: '09a67ece27b258ff1248805d43d92a49b2c6859a' })));
1004
+ [`header-translucent-${theme$1}`]: this.translucent,
1005
+ ['header-divider']: divider,
1006
+ } }, inheritedAttributes), theme$1 === 'ios' && translucent && index.h("div", { key: 'c1c77a735ed96e93a5ee9511415c19a80989dbc9', class: "header-background" }), index.h("slot", { key: '13a06aa2aa3358ba3d4f61fe6119b8506b866c14' })));
1054
1007
  }
1055
1008
  get el() { return index.getElement(this); }
1056
1009
  };
1057
1010
  Header.style = {
1011
+ ionic: headerIonicCss,
1058
1012
  ios: headerIosCss,
1059
1013
  md: headerMdCss
1060
1014
  };
1061
1015
 
1062
- const routerOutletCss = ":host{left:0;right:0;top:0;bottom:0;position:absolute;contain:layout size style;z-index:0}";
1016
+ const routerOutletCss = ":host{right:0;left:0;top:0;bottom:0;position:absolute;contain:layout size style;z-index:0}";
1063
1017
 
1064
1018
  const RouterOutlet = class {
1065
1019
  constructor(hostRef) {
@@ -1070,7 +1024,7 @@ const RouterOutlet = class {
1070
1024
  this.lockController = lockController.createLockController();
1071
1025
  this.gestureOrAnimationInProgress = false;
1072
1026
  /**
1073
- * The mode determines which platform styles to use.
1027
+ * The mode determines the platform behaviors of the component.
1074
1028
  */
1075
1029
  this.mode = index.getIonMode(this);
1076
1030
  /**
@@ -1090,7 +1044,7 @@ const RouterOutlet = class {
1090
1044
  this.swipeHandler.onStart();
1091
1045
  }
1092
1046
  };
1093
- this.gesture = (await Promise.resolve().then(function () { return require('./swipe-back-D_VN6H9r.js'); })).createSwipeBackGesture(this.el, () => !this.gestureOrAnimationInProgress && !!this.swipeHandler && this.swipeHandler.canStart(), () => onStart(), (step) => { var _a; return (_a = this.ani) === null || _a === void 0 ? void 0 : _a.progressStep(step); }, (shouldComplete, step, dur) => {
1047
+ this.gesture = (await Promise.resolve().then(function () { return require('./swipe-back-CEVlQT7C.js'); })).createSwipeBackGesture(this.el, () => !this.gestureOrAnimationInProgress && !!this.swipeHandler && this.swipeHandler.canStart(), () => onStart(), (step) => { var _a; return (_a = this.ani) === null || _a === void 0 ? void 0 : _a.progressStep(step); }, (shouldComplete, step, dur) => {
1094
1048
  if (this.ani) {
1095
1049
  this.ani.onFinish(() => {
1096
1050
  this.gestureOrAnimationInProgress = false;
@@ -1236,7 +1190,7 @@ const RouterOutlet = class {
1236
1190
  return true;
1237
1191
  }
1238
1192
  render() {
1239
- return index.h("slot", { key: '84b50f1155b0d780dff802ee13223287259fd525' });
1193
+ return index.h("slot", { key: '3f107f085a977b4d27c7266771a9564e3219f736' });
1240
1194
  }
1241
1195
  get el() { return index.getElement(this); }
1242
1196
  static get watchers() { return {
@@ -1245,9 +1199,11 @@ const RouterOutlet = class {
1245
1199
  };
1246
1200
  RouterOutlet.style = routerOutletCss;
1247
1201
 
1248
- const titleIosCss = ":host{--color:initial;display:-ms-flexbox;display:flex;-ms-flex:1;flex:1;-ms-flex-align:center;align-items:center;-webkit-transform:translateZ(0);transform:translateZ(0);color:var(--color)}:host(.ion-color){color:var(--ion-color-base)}.toolbar-title{display:block;width:100%;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;pointer-events:auto}:host(.title-small) .toolbar-title{white-space:normal}:host{top:0;-webkit-padding-start:90px;padding-inline-start:90px;-webkit-padding-end:90px;padding-inline-end:90px;padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);position:absolute;width:100%;height:100%;-webkit-transform:translateZ(0);transform:translateZ(0);font-size:min(1.0625rem, 20.4px);font-weight:600;text-align:center;-webkit-box-sizing:border-box;box-sizing:border-box;pointer-events:none}:host{inset-inline-start:0}:host(.title-small){-webkit-padding-start:9px;padding-inline-start:9px;-webkit-padding-end:9px;padding-inline-end:9px;padding-top:6px;padding-bottom:16px;position:relative;font-size:min(0.8125rem, 23.4px);font-weight:normal}:host(.title-large){-webkit-padding-start:12px;padding-inline-start:12px;-webkit-padding-end:12px;padding-inline-end:12px;padding-top:2px;padding-bottom:4px;-webkit-transform-origin:left center;transform-origin:left center;position:static;-ms-flex-align:end;align-items:flex-end;min-width:100%;font-size:min(2.125rem, 61.2px);font-weight:700;text-align:start}:host(.title-large.title-rtl){-webkit-transform-origin:right center;transform-origin:right center}:host(.title-large.ion-cloned-element){--color:var(--ion-text-color, #000);font-family:var(--ion-font-family)}:host(.title-large) .toolbar-title{-webkit-transform-origin:inherit;transform-origin:inherit;width:auto}:host-context([dir=rtl]):host(.title-large) .toolbar-title,:host-context([dir=rtl]).title-large .toolbar-title{-webkit-transform-origin:calc(100% - inherit);transform-origin:calc(100% - inherit)}@supports selector(:dir(rtl)){:host(.title-large:dir(rtl)) .toolbar-title{-webkit-transform-origin:calc(100% - inherit);transform-origin:calc(100% - inherit)}}";
1202
+ const titleIonicCss = ":host{--color:initial;display:-ms-flexbox;display:flex;-ms-flex:1;flex:1;-ms-flex-align:center;align-items:center;-webkit-transform:translateZ(0);transform:translateZ(0);color:var(--color)}.toolbar-title{display:block;width:100%;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;pointer-events:auto}:host(.title-small) .toolbar-title{white-space:normal}:host{font-size:var(--ion-font-size-450, 1.125rem);font-weight:var(--ion-font-weight-medium, 500);letter-spacing:var(--ion-font-letter-spacing-0, 0%);line-height:var(--ion-font-line-height-700, var(--ion-scale-700, 28px));text-decoration:none;text-transform:none;-webkit-box-sizing:border-box;box-sizing:border-box;pointer-events:none}:host(.title-large){font-size:var(--ion-font-size-700, 1.75rem);font-weight:var(--ion-font-weight-medium, 500);letter-spacing:var(--ion-font-letter-spacing-0, 0%);line-height:var(--ion-font-line-height-900, var(--ion-scale-900, 36px));text-decoration:none;text-transform:none}";
1203
+
1204
+ const titleIosCss = ":host{--color:initial;display:-ms-flexbox;display:flex;-ms-flex:1;flex:1;-ms-flex-align:center;align-items:center;-webkit-transform:translateZ(0);transform:translateZ(0);color:var(--color)}.toolbar-title{display:block;width:100%;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;pointer-events:auto}:host(.title-small) .toolbar-title{white-space:normal}:host(.ion-color){color:var(--ion-color-base)}:host{top:0;-webkit-padding-start:90px;padding-inline-start:90px;-webkit-padding-end:90px;padding-inline-end:90px;padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);position:absolute;width:100%;height:100%;-webkit-transform:translateZ(0);transform:translateZ(0);font-size:min(1.0625rem, 20.4px);font-weight:600;text-align:center;-webkit-box-sizing:border-box;box-sizing:border-box;pointer-events:none}:host{inset-inline-start:0}:host(.title-small){-webkit-padding-start:9px;padding-inline-start:9px;-webkit-padding-end:9px;padding-inline-end:9px;padding-top:6px;padding-bottom:16px;position:relative;font-size:min(0.8125rem, 23.4px);font-weight:normal}:host(.title-large){-webkit-padding-start:12px;padding-inline-start:12px;-webkit-padding-end:12px;padding-inline-end:12px;padding-top:2px;padding-bottom:4px;-webkit-transform-origin:left center;transform-origin:left center;position:static;-ms-flex-align:end;align-items:flex-end;min-width:100%;font-size:min(2.125rem, 61.2px);font-weight:700;text-align:start}:host(.title-large.title-rtl){-webkit-transform-origin:right center;transform-origin:right center}:host(.title-large.ion-cloned-element){--color:var(--ion-text-color, #000);font-family:var(--ion-font-family)}:host(.title-large) .toolbar-title{-webkit-transform-origin:inherit;transform-origin:inherit;width:auto}:host-context([dir=rtl]):host(.title-large) .toolbar-title,:host-context([dir=rtl]).title-large .toolbar-title{-webkit-transform-origin:calc(100% - inherit);transform-origin:calc(100% - inherit)}@supports selector(:dir(rtl)){:host(.title-large:dir(rtl)) .toolbar-title{-webkit-transform-origin:calc(100% - inherit);transform-origin:calc(100% - inherit)}}";
1249
1205
 
1250
- const titleMdCss = ":host{--color:initial;display:-ms-flexbox;display:flex;-ms-flex:1;flex:1;-ms-flex-align:center;align-items:center;-webkit-transform:translateZ(0);transform:translateZ(0);color:var(--color)}:host(.ion-color){color:var(--ion-color-base)}.toolbar-title{display:block;width:100%;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;pointer-events:auto}:host(.title-small) .toolbar-title{white-space:normal}:host{-webkit-padding-start:20px;padding-inline-start:20px;-webkit-padding-end:20px;padding-inline-end:20px;padding-top:0;padding-bottom:0;font-size:1.25rem;font-weight:500;letter-spacing:0.0125em}:host(.title-small){width:100%;height:100%;font-size:0.9375rem;font-weight:normal}";
1206
+ const titleMdCss = ":host{--color:initial;display:-ms-flexbox;display:flex;-ms-flex:1;flex:1;-ms-flex-align:center;align-items:center;-webkit-transform:translateZ(0);transform:translateZ(0);color:var(--color)}.toolbar-title{display:block;width:100%;text-overflow:ellipsis;white-space:nowrap;overflow:hidden;pointer-events:auto}:host(.title-small) .toolbar-title{white-space:normal}:host(.ion-color){color:var(--ion-color-base)}:host{-webkit-padding-start:20px;padding-inline-start:20px;-webkit-padding-end:20px;padding-inline-end:20px;padding-top:0;padding-bottom:0;font-size:1.25rem;font-weight:500;letter-spacing:0.0125em}:host(.title-small){width:100%;height:100%;font-size:0.9375rem;font-weight:normal}";
1251
1207
 
1252
1208
  const ToolbarTitle = class {
1253
1209
  constructor(hostRef) {
@@ -1270,13 +1226,13 @@ const ToolbarTitle = class {
1270
1226
  return this.size !== undefined ? this.size : 'default';
1271
1227
  }
1272
1228
  render() {
1273
- const mode = index.getIonMode(this);
1229
+ const theme$1 = index.getIonTheme(this);
1274
1230
  const size = this.getSize();
1275
- return (index.h(index.Host, { key: 'e599c0bf1b0817df3fa8360bdcd6d787f751c371', class: theme.createColorClasses(this.color, {
1276
- [mode]: true,
1231
+ return (index.h(index.Host, { key: '8db3e5f9dbd8b1762a9919eaeef29c98649dfb25', class: theme.createColorClasses(this.color, {
1232
+ [theme$1]: true,
1277
1233
  [`title-${size}`]: true,
1278
1234
  'title-rtl': document.dir === 'rtl',
1279
- }) }, index.h("div", { key: '6e7eee9047d6759876bb31d7305b76efc7c4338c', class: "toolbar-title" }, index.h("slot", { key: 'bf790eb4c83dd0af4f2fd1f85ab4af5819f46ff4' }))));
1235
+ }) }, index.h("div", { key: 'a31ebae2c494a51d2145eec69d0b1bc635108a01', class: "toolbar-title" }, index.h("slot", { key: 'f5975b44b3e3afbf98dcbdb53fc78447b49407b3' }))));
1280
1236
  }
1281
1237
  get el() { return index.getElement(this); }
1282
1238
  static get watchers() { return {
@@ -1284,13 +1240,16 @@ const ToolbarTitle = class {
1284
1240
  }; }
1285
1241
  };
1286
1242
  ToolbarTitle.style = {
1243
+ ionic: titleIonicCss,
1287
1244
  ios: titleIosCss,
1288
1245
  md: titleMdCss
1289
1246
  };
1290
1247
 
1291
- const toolbarIosCss = ":host{--border-width:0;--border-style:solid;--opacity:1;--opacity-scale:1;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;display:block;position:relative;width:100%;padding-right:var(--ion-safe-area-right);padding-left:var(--ion-safe-area-left);color:var(--color);font-family:var(--ion-font-family, inherit);contain:content;z-index:10;-webkit-box-sizing:border-box;box-sizing:border-box}:host(.ion-color){color:var(--ion-color-contrast)}:host(.ion-color) .toolbar-background{background:var(--ion-color-base)}.toolbar-container{-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);display:-ms-flexbox;display:flex;position:relative;-ms-flex-direction:row;flex-direction:row;-ms-flex-align:center;align-items:center;-ms-flex-pack:justify;justify-content:space-between;width:100%;min-height:var(--min-height);contain:content;overflow:hidden;z-index:10;-webkit-box-sizing:border-box;box-sizing:border-box}.toolbar-background{left:0;right:0;top:0;bottom:0;position:absolute;-webkit-transform:translateZ(0);transform:translateZ(0);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);background:var(--background);contain:strict;opacity:calc(var(--opacity) * var(--opacity-scale));z-index:-1;pointer-events:none}::slotted(ion-progress-bar){left:0;right:0;bottom:0;position:absolute}:host{--background:var(--ion-toolbar-background, var(--ion-color-step-50, var(--ion-background-color-step-50, #f7f7f7)));--color:var(--ion-toolbar-color, var(--ion-text-color, #000));--border-color:var(--ion-toolbar-border-color, var(--ion-border-color, var(--ion-color-step-150, var(--ion-background-color-step-150, rgba(0, 0, 0, 0.2)))));--padding-top:3px;--padding-bottom:3px;--padding-start:4px;--padding-end:4px;--min-height:44px}.toolbar-content{-ms-flex:1;flex:1;-ms-flex-order:4;order:4;min-width:0}:host(.toolbar-segment) .toolbar-content{display:-ms-inline-flexbox;display:inline-flex}:host(.toolbar-searchbar) .toolbar-container{padding-top:0;padding-bottom:0}:host(.toolbar-searchbar) ::slotted(*){-ms-flex-item-align:start;align-self:start}:host(.toolbar-searchbar) ::slotted(ion-chip){margin-top:3px}::slotted(ion-buttons){min-height:38px}::slotted([slot=start]){-ms-flex-order:2;order:2}::slotted([slot=secondary]){-ms-flex-order:3;order:3}::slotted([slot=primary]){-ms-flex-order:5;order:5;text-align:end}::slotted([slot=end]){-ms-flex-order:6;order:6;text-align:end}:host(.toolbar-title-large) .toolbar-container{-ms-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-align:start;align-items:flex-start}:host(.toolbar-title-large) .toolbar-content ion-title{-ms-flex:1;flex:1;-ms-flex-order:8;order:8;min-width:100%}";
1248
+ const toolbarIonicCss = ":host{--border-width:0;--border-style:solid;--opacity:1;--opacity-scale:1;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;display:block;position:relative;width:100%;padding-right:var(--ion-safe-area-right);padding-left:var(--ion-safe-area-left);color:var(--color);contain:content;-webkit-box-sizing:border-box;box-sizing:border-box}.toolbar-container{-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);display:-ms-flexbox;display:flex;position:relative;-ms-flex-direction:row;flex-direction:row;-ms-flex-align:center;align-items:center;-ms-flex-pack:justify;justify-content:space-between;width:100%;min-height:var(--min-height);contain:content;overflow:hidden;-webkit-box-sizing:border-box;box-sizing:border-box}.toolbar-background{right:0;left:0;top:0;bottom:0;position:absolute;-webkit-transform:translateZ(0);transform:translateZ(0);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);background:var(--background);contain:strict;opacity:calc(var(--opacity) * var(--opacity-scale));pointer-events:none}::slotted(ion-progress-bar){right:0;left:0;bottom:0;position:absolute}:host{--background:var(--ion-primitives-base-white, #ffffff);--color:var(--ion-primitives-neutral-1200, #242424);--border-color:currentColor;--padding-top:var(--ion-space-200, var(--ion-scale-200, 8px));--padding-bottom:var(--ion-space-200, var(--ion-scale-200, 8px));--padding-start:var(--ion-space-200, var(--ion-scale-200, 8px));--padding-end:var(--ion-space-200, var(--ion-scale-200, 8px));--min-height:var(--ion-scale-1400, 56px)}.toolbar-container{gap:var(--ion-space-400, var(--ion-scale-400, 16px))}.toolbar-content{-ms-flex:1 1 auto;flex:1 1 auto;min-width:0}:host(.toolbar-searchbar) ::slotted(ion-searchbar){padding-left:0;padding-right:0;padding-top:0;padding-bottom:0}::slotted(ion-buttons){gap:var(--ion-space-200, var(--ion-scale-200, 8px))}::slotted(ion-title){-webkit-padding-start:var(--ion-space-200, var(--ion-scale-200, 8px));padding-inline-start:var(--ion-space-200, var(--ion-scale-200, 8px));-webkit-padding-end:var(--ion-space-200, var(--ion-scale-200, 8px));padding-inline-end:var(--ion-space-200, var(--ion-scale-200, 8px))}:host(.toolbar-title-default) ::slotted(ion-title){text-align:center}:host(.toolbar-title-large) ::slotted(ion-title){-webkit-padding-start:var(--ion-space-400, var(--ion-scale-400, 16px));padding-inline-start:var(--ion-space-400, var(--ion-scale-400, 16px));-webkit-padding-end:var(--ion-space-400, var(--ion-scale-400, 16px));padding-inline-end:var(--ion-space-400, var(--ion-scale-400, 16px))}:host(.has-end-content) slot[name=end],:host(.show-end) slot[name=end]{display:-ms-flexbox;display:flex;-ms-flex:0 0 var(--start-end-size, 0);flex:0 0 var(--start-end-size, 0);-ms-flex-pack:end;justify-content:flex-end;text-align:end}:host(.has-start-content) slot[name=start],:host(.show-start) slot[name=start]{display:-ms-flexbox;display:flex;-ms-flex:0 0 var(--start-end-size, 0);flex:0 0 var(--start-end-size, 0)}:host(.has-primary-content) slot[name=primary],:host(.show-primary) slot[name=primary]{display:-ms-flexbox;display:flex;-ms-flex:0 0 var(--primary-secondary-size, 0);flex:0 0 var(--primary-secondary-size, 0);-ms-flex-pack:end;justify-content:flex-end;text-align:end}:host(.has-secondary-content) slot[name=secondary],:host(.show-secondary) slot[name=secondary]{display:-ms-flexbox;display:flex;-ms-flex:0 0 var(--primary-secondary-size, 0);flex:0 0 var(--primary-secondary-size, 0)}";
1292
1249
 
1293
- const toolbarMdCss = ":host{--border-width:0;--border-style:solid;--opacity:1;--opacity-scale:1;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;display:block;position:relative;width:100%;padding-right:var(--ion-safe-area-right);padding-left:var(--ion-safe-area-left);color:var(--color);font-family:var(--ion-font-family, inherit);contain:content;z-index:10;-webkit-box-sizing:border-box;box-sizing:border-box}:host(.ion-color){color:var(--ion-color-contrast)}:host(.ion-color) .toolbar-background{background:var(--ion-color-base)}.toolbar-container{-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);display:-ms-flexbox;display:flex;position:relative;-ms-flex-direction:row;flex-direction:row;-ms-flex-align:center;align-items:center;-ms-flex-pack:justify;justify-content:space-between;width:100%;min-height:var(--min-height);contain:content;overflow:hidden;z-index:10;-webkit-box-sizing:border-box;box-sizing:border-box}.toolbar-background{left:0;right:0;top:0;bottom:0;position:absolute;-webkit-transform:translateZ(0);transform:translateZ(0);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);background:var(--background);contain:strict;opacity:calc(var(--opacity) * var(--opacity-scale));z-index:-1;pointer-events:none}::slotted(ion-progress-bar){left:0;right:0;bottom:0;position:absolute}:host{--background:var(--ion-toolbar-background, var(--ion-background-color, #fff));--color:var(--ion-toolbar-color, var(--ion-text-color, #424242));--border-color:var(--ion-toolbar-border-color, var(--ion-border-color, var(--ion-color-step-150, var(--ion-background-color-step-150, #c1c4cd))));--padding-top:0;--padding-bottom:0;--padding-start:0;--padding-end:0;--min-height:56px}.toolbar-content{-ms-flex:1;flex:1;-ms-flex-order:3;order:3;min-width:0;max-width:100%}::slotted(.buttons-first-slot){-webkit-margin-start:4px;margin-inline-start:4px}::slotted(.buttons-last-slot){-webkit-margin-end:4px;margin-inline-end:4px}::slotted([slot=start]){-ms-flex-order:2;order:2}::slotted([slot=secondary]){-ms-flex-order:4;order:4}::slotted([slot=primary]){-ms-flex-order:5;order:5;text-align:end}::slotted([slot=end]){-ms-flex-order:6;order:6;text-align:end}";
1250
+ const toolbarIosCss = ":host{--border-width:0;--border-style:solid;--opacity:1;--opacity-scale:1;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;display:block;position:relative;width:100%;padding-right:var(--ion-safe-area-right);padding-left:var(--ion-safe-area-left);color:var(--color);contain:content;-webkit-box-sizing:border-box;box-sizing:border-box}.toolbar-container{-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);display:-ms-flexbox;display:flex;position:relative;-ms-flex-direction:row;flex-direction:row;-ms-flex-align:center;align-items:center;-ms-flex-pack:justify;justify-content:space-between;width:100%;min-height:var(--min-height);contain:content;overflow:hidden;-webkit-box-sizing:border-box;box-sizing:border-box}.toolbar-background{right:0;left:0;top:0;bottom:0;position:absolute;-webkit-transform:translateZ(0);transform:translateZ(0);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);background:var(--background);contain:strict;opacity:calc(var(--opacity) * var(--opacity-scale));pointer-events:none}::slotted(ion-progress-bar){right:0;left:0;bottom:0;position:absolute}:host{font-family:var(--ion-font-family, inherit);z-index:10}:host(.ion-color){color:var(--ion-color-contrast)}:host(.ion-color) .toolbar-background{background:var(--ion-color-base)}.toolbar-container{z-index:10}.toolbar-background{z-index:-1}:host{--background:var(--ion-toolbar-background, var(--ion-color-step-50, var(--ion-background-color-step-50, #f7f7f7)));--color:var(--ion-toolbar-color, var(--ion-text-color, #000));--border-color:var(--ion-toolbar-border-color, var(--ion-border-color, var(--ion-color-step-150, var(--ion-background-color-step-150, rgba(0, 0, 0, 0.2)))));--padding-top:3px;--padding-bottom:3px;--padding-start:4px;--padding-end:4px;--min-height:44px}.toolbar-content{-ms-flex:1;flex:1;-ms-flex-order:4;order:4;min-width:0}:host(.toolbar-segment) .toolbar-content{display:-ms-inline-flexbox;display:inline-flex}:host(.toolbar-searchbar) .toolbar-container{padding-top:0;padding-bottom:0}:host(.toolbar-searchbar) ::slotted(*){-ms-flex-item-align:start;align-self:start}:host(.toolbar-searchbar) ::slotted(ion-chip){margin-top:3px}::slotted(ion-buttons){min-height:38px}::slotted([slot=start]){-ms-flex-order:2;order:2}::slotted([slot=secondary]){-ms-flex-order:3;order:3}::slotted([slot=primary]){-ms-flex-order:5;order:5;text-align:end}::slotted([slot=end]){-ms-flex-order:6;order:6;text-align:end}:host(.toolbar-title-large) .toolbar-container{-ms-flex-wrap:wrap;flex-wrap:wrap;-ms-flex-align:start;align-items:flex-start}:host(.toolbar-title-large) .toolbar-content ion-title{-ms-flex:1;flex:1;-ms-flex-order:8;order:8;min-width:100%}";
1251
+
1252
+ const toolbarMdCss = ":host{--border-width:0;--border-style:solid;--opacity:1;--opacity-scale:1;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;display:block;position:relative;width:100%;padding-right:var(--ion-safe-area-right);padding-left:var(--ion-safe-area-left);color:var(--color);contain:content;-webkit-box-sizing:border-box;box-sizing:border-box}.toolbar-container{-webkit-padding-start:var(--padding-start);padding-inline-start:var(--padding-start);-webkit-padding-end:var(--padding-end);padding-inline-end:var(--padding-end);padding-top:var(--padding-top);padding-bottom:var(--padding-bottom);display:-ms-flexbox;display:flex;position:relative;-ms-flex-direction:row;flex-direction:row;-ms-flex-align:center;align-items:center;-ms-flex-pack:justify;justify-content:space-between;width:100%;min-height:var(--min-height);contain:content;overflow:hidden;-webkit-box-sizing:border-box;box-sizing:border-box}.toolbar-background{right:0;left:0;top:0;bottom:0;position:absolute;-webkit-transform:translateZ(0);transform:translateZ(0);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);background:var(--background);contain:strict;opacity:calc(var(--opacity) * var(--opacity-scale));pointer-events:none}::slotted(ion-progress-bar){right:0;left:0;bottom:0;position:absolute}:host{font-family:var(--ion-font-family, inherit);z-index:10}:host(.ion-color){color:var(--ion-color-contrast)}:host(.ion-color) .toolbar-background{background:var(--ion-color-base)}.toolbar-container{z-index:10}.toolbar-background{z-index:-1}:host{--background:var(--ion-toolbar-background, var(--ion-background-color, #fff));--color:var(--ion-toolbar-color, var(--ion-text-color, #424242));--border-color:var(--ion-toolbar-border-color, var(--ion-border-color, var(--ion-color-step-150, var(--ion-background-color-step-150, #c1c4cd))));--padding-top:0;--padding-bottom:0;--padding-start:0;--padding-end:0;--min-height:56px}.toolbar-content{-ms-flex:1;flex:1;-ms-flex-order:3;order:3;min-width:0;max-width:100%}::slotted(.buttons-first-slot){-webkit-margin-start:4px;margin-inline-start:4px}::slotted(.buttons-last-slot){-webkit-margin-end:4px;margin-inline-end:4px}::slotted([slot=start]){-ms-flex-order:2;order:2}::slotted([slot=secondary]){-ms-flex-order:4;order:4}::slotted([slot=primary]){-ms-flex-order:5;order:5;text-align:end}::slotted([slot=end]){-ms-flex-order:6;order:6;text-align:end}";
1294
1253
 
1295
1254
  const Toolbar = class {
1296
1255
  constructor(hostRef) {
@@ -1312,6 +1271,131 @@ const Toolbar = class {
1312
1271
  if (lastButtons) {
1313
1272
  lastButtons.classList.add('buttons-last-slot');
1314
1273
  }
1274
+ this.updateSlotClasses();
1275
+ }
1276
+ componentDidLoad() {
1277
+ this.updateSlotClasses();
1278
+ this.updateSlotWidths();
1279
+ }
1280
+ /**
1281
+ * Updates the CSS custom properties for slot widths
1282
+ * This ensures that slots shown by their met conditions
1283
+ * have a minimum width matching their required slot
1284
+ */
1285
+ updateSlotWidths(tries = 0) {
1286
+ // Set timeout to try to execute after everything is rendered
1287
+ setTimeout(() => {
1288
+ // Attempt to measure and update
1289
+ const success = this.measureAndUpdateSlots();
1290
+ // If not all measurements were successful, try again in 100 ms
1291
+ // cap recursion at 5 tries for safety
1292
+ if (!success && tries < 5) {
1293
+ setTimeout(() => {
1294
+ this.updateSlotWidths(tries + 1);
1295
+ }, 100);
1296
+ }
1297
+ });
1298
+ }
1299
+ /**
1300
+ * Measure the widths of the slots and update the CSS custom properties
1301
+ * for the minimum width of each pair of slots based on the largest width in each pair.
1302
+ * Returns whether we successfully measured all of the slots we expect to have content.
1303
+ * If not, the content probably hasn't rendered yet and we need to try again.
1304
+ */
1305
+ measureAndUpdateSlots() {
1306
+ // Define the relationship between slots based on the conditions array
1307
+ // Group slots that should have the same width
1308
+ const slotPairs = [
1309
+ { name: 'start-end', slots: ['start', 'end'] },
1310
+ { name: 'primary-secondary', slots: ['primary', 'secondary'] },
1311
+ ];
1312
+ // First, measure all slot widths
1313
+ const slotWidths = new Map();
1314
+ let allMeasurementsSuccessful = true;
1315
+ // Measure all slots with content
1316
+ const slots = ['start', 'end', 'primary', 'secondary'];
1317
+ slots.forEach((slot) => {
1318
+ var _a;
1319
+ if (this.el.classList.contains(`has-${slot}-content`)) {
1320
+ const slotElement = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector(`slot[name="${slot}"]`);
1321
+ if (slotElement) {
1322
+ const width = slotElement.offsetWidth;
1323
+ if (width > 0) {
1324
+ slotWidths.set(slot, width);
1325
+ }
1326
+ else {
1327
+ allMeasurementsSuccessful = false;
1328
+ }
1329
+ }
1330
+ }
1331
+ });
1332
+ // Then set the CSS custom properties based on the largest width in each pair
1333
+ slotPairs.forEach(({ name, slots }) => {
1334
+ // Find the maximum width among the slots in this pair
1335
+ let maxWidth = 0;
1336
+ let hasAnyContent = false;
1337
+ slots.forEach((slot) => {
1338
+ var _a;
1339
+ if (slotWidths.has(slot)) {
1340
+ hasAnyContent = true;
1341
+ maxWidth = Math.max(maxWidth, (_a = slotWidths.get(slot)) !== null && _a !== void 0 ? _a : 0);
1342
+ }
1343
+ });
1344
+ // If at least one slot in the pair has content, set the min-width for the pair
1345
+ if (hasAnyContent && maxWidth > 0) {
1346
+ // Set a single CSS variable for the pair
1347
+ this.el.style.setProperty(`--${name}-size`, `${maxWidth}px`);
1348
+ }
1349
+ });
1350
+ return allMeasurementsSuccessful;
1351
+ }
1352
+ updateSlotClasses() {
1353
+ // Check if slots have content
1354
+ const slots = ['start', 'end', 'primary', 'secondary'];
1355
+ const classesToAdd = [];
1356
+ const classesToRemove = [];
1357
+ slots.forEach((slot) => {
1358
+ const slotHasContent = this.hasSlotContent(slot);
1359
+ const slotClass = `has-${slot}-content`;
1360
+ if (slotHasContent) {
1361
+ classesToAdd.push(slotClass);
1362
+ }
1363
+ else {
1364
+ classesToRemove.push(slotClass);
1365
+ }
1366
+ });
1367
+ // Force visibilities in certain conditions. This works by adding a class to the toolbar
1368
+ // named `show-{slot}`. This class will be added if the toolbar has the required slots
1369
+ // and does not have any of the excluded slots, otherwise it will be removed.
1370
+ // This is useful to enforce centering of the toolbar content when there are different amounts
1371
+ // of slots on either side of the toolbar.
1372
+ const conditions = [
1373
+ { name: 'end', requiredSlots: ['start'], excludeSlots: ['end', 'primary'] },
1374
+ { name: 'start', requiredSlots: ['end'], excludeSlots: ['start', 'secondary'] },
1375
+ { name: 'secondary', requiredSlots: ['primary'], excludeSlots: ['secondary', 'start'] },
1376
+ { name: 'primary', requiredSlots: ['secondary'], excludeSlots: ['primary', 'end'] },
1377
+ ];
1378
+ conditions.forEach((condition) => {
1379
+ const hasRequiredSlots = condition.requiredSlots.every((slot) => classesToAdd.includes(`has-${slot}-content`));
1380
+ const hasExcludedSlots = condition.excludeSlots.some((slot) => classesToAdd.includes(`has-${slot}-content`));
1381
+ const className = `show-${condition.name}`;
1382
+ if (hasRequiredSlots && !hasExcludedSlots) {
1383
+ classesToAdd.push(className);
1384
+ }
1385
+ else {
1386
+ classesToRemove.push(className);
1387
+ }
1388
+ });
1389
+ // Add classes to the toolbar element
1390
+ this.el.classList.add(...classesToAdd);
1391
+ this.el.classList.remove(...classesToRemove);
1392
+ // Update slot widths after classes have been updated
1393
+ this.updateSlotWidths();
1394
+ }
1395
+ hasSlotContent(slotName) {
1396
+ var _a;
1397
+ const slotNode = (_a = this.el.shadowRoot) === null || _a === void 0 ? void 0 : _a.querySelector(`slot[name="${slotName}"]`);
1398
+ return !!slotNode && slotNode.assignedNodes().length > 0;
1315
1399
  }
1316
1400
  childrenStyle(ev) {
1317
1401
  ev.stopPropagation();
@@ -1336,19 +1420,20 @@ const Toolbar = class {
1336
1420
  }
1337
1421
  }
1338
1422
  render() {
1339
- const mode = index.getIonMode(this);
1423
+ const theme$1 = index.getIonTheme(this);
1340
1424
  const childStyles = {};
1341
- this.childrenStyles.forEach((value) => {
1342
- Object.assign(childStyles, value);
1425
+ this.childrenStyles.forEach((style) => {
1426
+ Object.assign(childStyles, style);
1343
1427
  });
1344
- return (index.h(index.Host, { key: 'f6c4f669a6a61c5eac4cbb5ea0aa97c48ae5bd46', class: Object.assign(Object.assign({}, childStyles), theme.createColorClasses(this.color, {
1345
- [mode]: true,
1428
+ return (index.h(index.Host, { key: 'ad4eba3711de175bb53b1f1e9f05f2a86476cbc5', class: Object.assign(Object.assign({}, theme.createColorClasses(this.color, {
1429
+ [theme$1]: true,
1346
1430
  'in-toolbar': theme.hostContext('ion-toolbar', this.el),
1347
- })) }, index.h("div", { key: '9c81742ffa02de9ba7417025b077d05e67305074', class: "toolbar-background", part: "background" }), index.h("div", { key: '5fc96d166fa47894a062e41541a9beee38078a36', class: "toolbar-container", part: "container" }, index.h("slot", { key: 'b62c0d9d59a70176bdbf769aec6090d7a166853b', name: "start" }), index.h("slot", { key: 'd01d3cc2c50e5aaa49c345b209fe8dbdf3d48131', name: "secondary" }), index.h("div", { key: '3aaa3a2810aedd38c37eb616158ec7b9638528fc', class: "toolbar-content", part: "content" }, index.h("slot", { key: '357246690f8d5e1cc3ca369611d4845a79edf610' })), index.h("slot", { key: '06ed3cca4f7ebff4a54cd877dad3cc925ccf9f75', name: "primary" }), index.h("slot", { key: 'e453d43d14a26b0d72f41e1b81a554bab8ece811', name: "end" }))));
1431
+ })), childStyles) }, index.h("div", { key: '49eb79b6f2c50cbba597f85b983f08d2c0a855db', class: "toolbar-background", part: "background" }), index.h("div", { key: '2fcc719c425441634f3884187d520a8b25fd4bea', class: "toolbar-container", part: "container" }, index.h("slot", { key: '73d53e48c0d0d5cdb69ea16b1c1e575fd076f969', name: "start", onSlotchange: () => this.updateSlotClasses }), index.h("slot", { key: '778d386d9221133b00e242bf2afb76fa2cdfcc64', name: "secondary", onSlotchange: () => this.updateSlotClasses }), index.h("div", { key: 'cce95e43317894e60dbdf895a75e5f13bcf6beda', class: "toolbar-content", part: "content" }, index.h("slot", { key: '917523b2e85e4f6fa112e9fb9d2a8078ca17ded4' })), index.h("slot", { key: '3a859e5d5beacc246f9312b675502d93862c502a', name: "primary", onSlotchange: () => this.updateSlotClasses }), index.h("slot", { key: '7bbcb9bc46b56033afb4c210188baa02c2485807', name: "end", onSlotchange: () => this.updateSlotClasses }))));
1348
1432
  }
1349
1433
  get el() { return index.getElement(this); }
1350
1434
  };
1351
1435
  Toolbar.style = {
1436
+ ionic: toolbarIonicCss,
1352
1437
  ios: toolbarIosCss,
1353
1438
  md: toolbarMdCss
1354
1439
  };