@ionic/core 8.7.13-dev.11765920447.1a01ab8b → 8.7.13-dev.11765925297.1bb45463

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 (953) hide show
  1. package/components/action-sheet.js +15 -11
  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 +34 -22
  17. package/components/helpers.js +57 -4
  18. package/components/index5.js +8 -8
  19. package/components/index6.js +1 -1
  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 +12 -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 +51 -50
  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 +72 -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 +78 -6
  51. package/components/ion-input-otp.js +9 -6
  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 +6 -3
  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 +35 -8
  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 +112 -19
  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 +47 -15
  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 +96 -6
  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 +15 -7
  111. package/components/radio.js +11 -8
  112. package/components/ripple-effect.js +15 -7
  113. package/components/select-modal.js +12 -5
  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 +153 -9
  119. package/components/validity.js +32 -1
  120. package/components/x.js +6 -0
  121. package/css/core.css +1 -1
  122. package/css/core.css.map +1 -1
  123. package/css/display.css +1 -1
  124. package/css/display.css.map +1 -1
  125. package/css/flex-utils.css +1 -1
  126. package/css/flex-utils.css.map +1 -1
  127. package/css/float-elements.css.map +1 -1
  128. package/css/global.bundle.css.map +1 -1
  129. package/css/ionic/bundle.ionic.css +1 -0
  130. package/css/ionic/bundle.ionic.css.map +1 -0
  131. package/css/ionic/core.ionic.css +1 -0
  132. package/css/ionic/core.ionic.css.map +1 -0
  133. package/css/ionic/global.bundle.ionic.css +1 -0
  134. package/css/ionic/global.bundle.ionic.css.map +1 -0
  135. package/css/ionic/ionic-swiper.ionic.css +1 -0
  136. package/css/ionic/ionic-swiper.ionic.css.map +1 -0
  137. package/css/ionic/link.ionic.css +1 -0
  138. package/css/ionic/link.ionic.css.map +1 -0
  139. package/css/ionic/structure.ionic.css +1 -0
  140. package/css/ionic/structure.ionic.css.map +1 -0
  141. package/css/ionic/typography.ionic.css +1 -0
  142. package/css/ionic/typography.ionic.css.map +1 -0
  143. package/css/ionic/utils.bundle.ionic.css +1 -0
  144. package/css/ionic/utils.bundle.ionic.css.map +1 -0
  145. package/css/ionic-swiper.css +1 -1
  146. package/css/ionic-swiper.css.map +1 -1
  147. package/css/ionic.bundle.css +1 -1
  148. package/css/ionic.bundle.css.map +1 -1
  149. package/css/normalize.css.map +1 -1
  150. package/css/padding.css.map +1 -1
  151. package/css/palettes/dark.always.css.map +1 -1
  152. package/css/palettes/dark.class.css.map +1 -1
  153. package/css/palettes/dark.system.css.map +1 -1
  154. package/css/palettes/high-contrast-dark.always.css.map +1 -1
  155. package/css/palettes/high-contrast-dark.class.css.map +1 -1
  156. package/css/palettes/high-contrast-dark.system.css.map +1 -1
  157. package/css/palettes/high-contrast.always.css.map +1 -1
  158. package/css/palettes/high-contrast.class.css.map +1 -1
  159. package/css/palettes/high-contrast.system.css.map +1 -1
  160. package/css/structure.css.map +1 -1
  161. package/css/text-alignment.css.map +1 -1
  162. package/css/text-transformation.css.map +1 -1
  163. package/css/typography.css.map +1 -1
  164. package/css/utils.bundle.css +1 -1
  165. package/css/utils.bundle.css.map +1 -1
  166. package/dist/cjs/{animation-Bt3H9L1C.js → animation-BBT4oe7B.js} +3 -3
  167. package/dist/cjs/{app-globals-Ciccnk9_.js → app-globals-DjZzKNoV.js} +1 -1
  168. package/dist/cjs/{button-active-CMc8cD90.js → button-active-DQ3Dd_Zw.js} +2 -2
  169. package/dist/cjs/{capacitor-DmA66EwP.js → capacitor-G2rS2zAS.js} +3 -3
  170. package/dist/cjs/caret-down-vtVgfXIs.js +8 -0
  171. package/dist/cjs/caret-left-CxZXLRv5.js +8 -0
  172. package/dist/cjs/caret-right-CRCgv98E.js +8 -0
  173. package/dist/cjs/{config-C5fsO43a.js → config-CPCkFfH2.js} +1 -1
  174. package/dist/cjs/{data-JwZKaIQB.js → data-BpYscHnl.js} +6 -6
  175. package/dist/cjs/{focus-visible-CCvKiLh3.js → focus-visible-BIj-I3-C.js} +24 -0
  176. package/dist/cjs/{framework-delegate-DMJRBuDi.js → framework-delegate-C7fZ8bup.js} +4 -2
  177. package/dist/cjs/{haptic-ClPPQ_PS.js → haptic-CYXFB5MG.js} +1 -1
  178. package/dist/cjs/{helpers-DrTqNghc.js → helpers-DF1tCuxf.js} +57 -4
  179. package/dist/cjs/{index-094mMFB-.js → index-BIUQBJ4M.js} +4 -4
  180. package/dist/cjs/{index-DrMUZJj6.js → index-BsTUIYWV.js} +15 -15
  181. package/dist/cjs/{index-CO6eryBo.js → index-C2sRwpb7.js} +2 -2
  182. package/dist/cjs/{index-D6Wc6v08.js → index-DjlJwy91.js} +41 -4
  183. package/dist/cjs/{index-C534ULug.js → index-h_4y8nIV.js} +9 -8
  184. package/dist/cjs/index.cjs.js +12 -13
  185. package/dist/cjs/{input-shims-CW0KUFTQ.js → input-shims-co__iqWN.js} +18 -17
  186. package/dist/cjs/{input.utils-B_QROI2g.js → input.utils-DyXMjrIY.js} +5 -5
  187. package/dist/cjs/ion-accordion_2.cjs.entry.js +56 -27
  188. package/dist/cjs/ion-action-sheet.cjs.entry.js +24 -21
  189. package/dist/cjs/ion-alert.cjs.entry.js +24 -22
  190. package/dist/cjs/ion-app_8.cjs.entry.js +250 -151
  191. package/dist/cjs/ion-avatar_3.cjs.entry.js +124 -12
  192. package/dist/cjs/ion-back-button.cjs.entry.js +29 -20
  193. package/dist/cjs/ion-backdrop.cjs.entry.js +10 -7
  194. package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +52 -16
  195. package/dist/cjs/ion-button_2.cjs.entry.js +44 -12
  196. package/dist/cjs/ion-card_5.cjs.entry.js +54 -30
  197. package/dist/cjs/ion-checkbox.cjs.entry.js +33 -15
  198. package/dist/cjs/ion-chip.cjs.entry.js +49 -8
  199. package/dist/cjs/ion-col_3.cjs.entry.js +54 -57
  200. package/dist/cjs/ion-datetime-button.cjs.entry.js +12 -8
  201. package/dist/cjs/ion-datetime_3.cjs.entry.js +114 -39
  202. package/dist/cjs/ion-divider.cjs.entry.js +51 -0
  203. package/dist/cjs/ion-fab_3.cjs.entry.js +42 -26
  204. package/dist/cjs/ion-img.cjs.entry.js +8 -4
  205. package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +91 -16
  206. package/dist/cjs/ion-input-otp.cjs.entry.js +12 -8
  207. package/dist/cjs/ion-input-password-toggle.cjs.entry.js +51 -13
  208. package/dist/cjs/ion-input.cjs.entry.js +122 -32
  209. package/dist/cjs/ion-item-option_3.cjs.entry.js +49 -20
  210. package/dist/cjs/ion-item_8.cjs.entry.js +114 -47
  211. package/dist/cjs/ion-loading.cjs.entry.js +19 -17
  212. package/dist/cjs/ion-menu_3.cjs.entry.js +45 -27
  213. package/dist/cjs/ion-modal.cjs.entry.js +96 -69
  214. package/dist/cjs/ion-nav_2.cjs.entry.js +14 -11
  215. package/dist/cjs/ion-picker-column-option.cjs.entry.js +11 -7
  216. package/dist/cjs/ion-picker-column.cjs.entry.js +13 -13
  217. package/dist/cjs/ion-picker.cjs.entry.js +10 -6
  218. package/dist/cjs/ion-popover.cjs.entry.js +19 -17
  219. package/dist/cjs/ion-progress-bar.cjs.entry.js +26 -8
  220. package/dist/cjs/ion-radio_2.cjs.entry.js +26 -16
  221. package/dist/cjs/ion-range.cjs.entry.js +15 -11
  222. package/dist/cjs/ion-refresher_2.cjs.entry.js +38 -20
  223. package/dist/cjs/ion-reorder_2.cjs.entry.js +37 -13
  224. package/dist/cjs/ion-ripple-effect.cjs.entry.js +15 -7
  225. package/dist/cjs/ion-route_4.cjs.entry.js +9 -8
  226. package/dist/cjs/ion-searchbar.cjs.entry.js +135 -22
  227. package/dist/cjs/ion-segment-content.cjs.entry.js +2 -2
  228. package/dist/cjs/ion-segment-view.cjs.entry.js +6 -3
  229. package/dist/cjs/ion-segment_2.cjs.entry.js +22 -15
  230. package/dist/cjs/ion-select-modal.cjs.entry.js +16 -10
  231. package/dist/cjs/ion-select_3.cjs.entry.js +131 -40
  232. package/dist/cjs/ion-spinner.cjs.entry.js +29 -7
  233. package/dist/cjs/ion-split-pane.cjs.entry.js +12 -9
  234. package/dist/cjs/ion-tab-bar_2.cjs.entry.js +76 -22
  235. package/dist/cjs/ion-tab_2.cjs.entry.js +8 -7
  236. package/dist/cjs/ion-text.cjs.entry.js +6 -6
  237. package/dist/cjs/ion-textarea.cjs.entry.js +117 -22
  238. package/dist/cjs/ion-toast.cjs.entry.js +67 -44
  239. package/dist/cjs/ion-toggle.cjs.entry.js +80 -23
  240. package/dist/cjs/ionic-global-DlkD8-ZL.js +491 -0
  241. package/dist/cjs/ionic.cjs.js +4 -4
  242. package/dist/cjs/{ios.transition-BOt_uW73.js → ios.transition-cjE5173V.js} +7 -5
  243. package/dist/cjs/{keyboard-UuAS4D_9.js → keyboard-BiIvvomq.js} +1 -1
  244. package/dist/cjs/{keyboard-hHzlEQpk.js → keyboard-Dxl3DPOc.js} +4 -3
  245. package/dist/cjs/{keyboard-controller-GXBiBRKS.js → keyboard-controller-5GsVQphE.js} +11 -9
  246. package/dist/cjs/list-a-7GSA6K.js +8 -0
  247. package/dist/cjs/loader.cjs.js +4 -4
  248. package/dist/cjs/{md.transition-Dt968VXB.js → md.transition-ChCLDEkm.js} +6 -5
  249. package/dist/cjs/{notch-controller-Bzqhjm4f.js → notch-controller-BGNMnptF.js} +4 -4
  250. package/dist/cjs/{overlays--dagG4QM.js → overlays-DPjo0yW3.js} +102 -12
  251. package/dist/cjs/{status-tap-g0sWWkXk.js → status-tap-BLw3gi_z.js} +4 -3
  252. package/dist/cjs/{swipe-back-BIayeNOD.js → swipe-back-BD2lWufH.js} +3 -2
  253. package/dist/cjs/validity-QmuwEptc.js +51 -0
  254. package/dist/cjs/x-BTF99yFH.js +8 -0
  255. package/dist/collection/collection-manifest.json +1 -0
  256. package/dist/collection/components/accordion/accordion.ionic.css +196 -0
  257. package/dist/collection/components/accordion/accordion.ios.css +73 -58
  258. package/dist/collection/components/accordion/accordion.js +36 -26
  259. package/dist/collection/components/accordion/accordion.md.css +67 -59
  260. package/dist/collection/components/accordion-group/accordion-group.ionic.css +93 -0
  261. package/dist/collection/components/accordion-group/accordion-group.ios.css +16 -4
  262. package/dist/collection/components/accordion-group/accordion-group.js +44 -8
  263. package/dist/collection/components/accordion-group/accordion-group.md.css +22 -4
  264. package/dist/collection/components/action-sheet/action-sheet.ios.css +18 -6
  265. package/dist/collection/components/action-sheet/action-sheet.js +17 -13
  266. package/dist/collection/components/action-sheet/action-sheet.md.css +17 -5
  267. package/dist/collection/components/alert/alert.ios.css +19 -1
  268. package/dist/collection/components/alert/alert.js +16 -13
  269. package/dist/collection/components/alert/alert.md.css +19 -1
  270. package/dist/collection/components/app/app.js +15 -78
  271. package/dist/collection/components/avatar/avatar.ionic.css +391 -0
  272. package/dist/collection/components/avatar/avatar.ios.css +7 -33
  273. package/dist/collection/components/avatar/avatar.js +120 -4
  274. package/dist/collection/components/avatar/avatar.md.css +51 -0
  275. package/dist/collection/components/back-button/back-button.ios.css +60 -48
  276. package/dist/collection/components/back-button/back-button.js +27 -19
  277. package/dist/collection/components/back-button/back-button.md.css +60 -48
  278. package/dist/collection/components/backdrop/backdrop.ionic.css +109 -0
  279. package/dist/collection/components/backdrop/backdrop.ios.css +56 -19
  280. package/dist/collection/components/backdrop/backdrop.js +12 -6
  281. package/dist/collection/components/backdrop/backdrop.md.css +56 -19
  282. package/dist/collection/components/badge/badge.ionic.css +275 -0
  283. package/dist/collection/components/badge/badge.ios.css +139 -12
  284. package/dist/collection/components/badge/badge.js +145 -9
  285. package/dist/collection/components/badge/badge.md.css +123 -12
  286. package/dist/collection/components/breadcrumb/breadcrumb.ios.css +20 -8
  287. package/dist/collection/components/breadcrumb/breadcrumb.js +43 -11
  288. package/dist/collection/components/breadcrumb/breadcrumb.md.css +20 -8
  289. package/dist/collection/components/breadcrumbs/breadcrumbs.ios.css +6 -0
  290. package/dist/collection/components/breadcrumbs/breadcrumbs.js +11 -9
  291. package/dist/collection/components/breadcrumbs/breadcrumbs.md.css +6 -0
  292. package/dist/collection/components/button/button.ionic.css +636 -0
  293. package/dist/collection/components/button/button.ios.css +135 -46
  294. package/dist/collection/components/button/button.js +48 -17
  295. package/dist/collection/components/button/button.md.css +126 -50
  296. package/dist/collection/components/buttons/buttons.ionic.css +97 -0
  297. package/dist/collection/components/buttons/buttons.ios.css +59 -7
  298. package/dist/collection/components/buttons/buttons.js +15 -9
  299. package/dist/collection/components/buttons/buttons.md.css +55 -3
  300. package/dist/collection/components/card/card.ionic.css +144 -0
  301. package/dist/collection/components/card/card.ios.css +65 -14
  302. package/dist/collection/components/card/card.js +41 -10
  303. package/dist/collection/components/card/card.md.css +65 -14
  304. package/dist/collection/components/card-content/card-content.ionic.css +92 -0
  305. package/dist/collection/components/card-content/card-content.ios.css +16 -1
  306. package/dist/collection/components/card-content/card-content.js +11 -8
  307. package/dist/collection/components/card-content/card-content.md.css +16 -1
  308. package/dist/collection/components/card-header/card-header.ionic.css +85 -0
  309. package/dist/collection/components/card-header/card-header.ios.css +27 -15
  310. package/dist/collection/components/card-header/card-header.js +13 -10
  311. package/dist/collection/components/card-header/card-header.md.css +27 -15
  312. package/dist/collection/components/card-subtitle/card-subtitle.ionic.css +144 -0
  313. package/dist/collection/components/card-subtitle/card-subtitle.ios.css +12 -0
  314. package/dist/collection/components/card-subtitle/card-subtitle.js +11 -8
  315. package/dist/collection/components/card-subtitle/card-subtitle.md.css +12 -0
  316. package/dist/collection/components/card-title/card-title.ios.css +73 -0
  317. package/dist/collection/components/card-title/card-title.js +11 -8
  318. package/dist/collection/components/card-title/card-title.md.css +73 -0
  319. package/dist/collection/components/checkbox/checkbox.ionic.css +539 -0
  320. package/dist/collection/components/checkbox/checkbox.ios.css +161 -101
  321. package/dist/collection/components/checkbox/checkbox.js +70 -14
  322. package/dist/collection/components/checkbox/checkbox.md.css +162 -102
  323. package/dist/collection/components/chip/chip.ionic.css +215 -0
  324. package/dist/collection/components/chip/chip.ios.css +67 -14
  325. package/dist/collection/components/chip/chip.js +108 -8
  326. package/dist/collection/components/chip/chip.md.css +67 -14
  327. package/dist/collection/components/col/col.css +192 -4
  328. package/dist/collection/components/col/col.js +210 -61
  329. package/dist/collection/components/content/content.css +8 -2
  330. package/dist/collection/components/content/content.js +16 -11
  331. package/dist/collection/components/datetime/datetime.ionic.css +711 -0
  332. package/dist/collection/components/datetime/datetime.ios.css +258 -96
  333. package/dist/collection/components/datetime/datetime.js +98 -20
  334. package/dist/collection/components/datetime/datetime.md.css +258 -96
  335. package/dist/collection/components/datetime/utils/data.js +5 -5
  336. package/dist/collection/components/datetime-button/datetime-button.ios.css +6 -0
  337. package/dist/collection/components/datetime-button/datetime-button.js +11 -8
  338. package/dist/collection/components/datetime-button/datetime-button.md.css +6 -0
  339. package/dist/collection/components/divider/divider.ionic.css +148 -0
  340. package/dist/collection/components/divider/divider.ios.css +87 -0
  341. package/dist/collection/components/divider/divider.js +94 -0
  342. package/dist/collection/components/divider/divider.md.css +87 -0
  343. package/dist/collection/components/fab/fab.css +25 -1
  344. package/dist/collection/components/fab/fab.js +9 -5
  345. package/dist/collection/components/fab-button/fab-button.ios.css +18 -6
  346. package/dist/collection/components/fab-button/fab-button.js +36 -21
  347. package/dist/collection/components/fab-button/fab-button.md.css +20 -8
  348. package/dist/collection/components/fab-list/fab-list.css +12 -0
  349. package/dist/collection/components/fab-list/fab-list.js +9 -5
  350. package/dist/collection/components/footer/footer.ios.css +14 -2
  351. package/dist/collection/components/footer/footer.js +21 -16
  352. package/dist/collection/components/footer/footer.md.css +12 -0
  353. package/dist/collection/components/grid/grid.css +12 -0
  354. package/dist/collection/components/grid/grid.js +9 -5
  355. package/dist/collection/components/header/header.ionic.css +97 -0
  356. package/dist/collection/components/header/header.ios.css +25 -10
  357. package/dist/collection/components/header/header.js +50 -19
  358. package/dist/collection/components/header/header.md.css +23 -8
  359. package/dist/collection/components/header/header.utils.js +5 -5
  360. package/dist/collection/components/img/img.js +8 -2
  361. package/dist/collection/components/infinite-scroll/infinite-scroll.js +100 -5
  362. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.ios.css +12 -0
  363. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +16 -10
  364. package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.md.css +12 -0
  365. package/dist/collection/components/input/input.ionic.css +885 -0
  366. package/dist/collection/components/input/input.ios.css +223 -140
  367. package/dist/collection/components/input/input.js +149 -38
  368. package/dist/collection/components/input/input.md.css +193 -212
  369. package/dist/collection/components/input-otp/input-otp.ionic.css +369 -0
  370. package/dist/collection/components/input-otp/input-otp.ios.css +102 -60
  371. package/dist/collection/components/input-otp/input-otp.js +7 -5
  372. package/dist/collection/components/input-otp/input-otp.md.css +102 -60
  373. package/dist/collection/components/input-password-toggle/input-password-toggle.ionic.css +78 -0
  374. package/dist/collection/components/input-password-toggle/input-password-toggle.js +48 -12
  375. package/dist/collection/components/input-password-toggle/input-password-toggle.native.css +61 -0
  376. package/dist/collection/components/item/item.ionic.css +508 -0
  377. package/dist/collection/components/item/item.ios.css +109 -69
  378. package/dist/collection/components/item/item.js +51 -20
  379. package/dist/collection/components/item/item.md.css +120 -68
  380. package/dist/collection/components/item-divider/item-divider.ios.css +18 -0
  381. package/dist/collection/components/item-divider/item-divider.js +11 -8
  382. package/dist/collection/components/item-divider/item-divider.md.css +18 -0
  383. package/dist/collection/components/item-group/item-group.ios.css +12 -0
  384. package/dist/collection/components/item-group/item-group.js +13 -7
  385. package/dist/collection/components/item-group/item-group.md.css +12 -0
  386. package/dist/collection/components/item-option/item-option.ionic.css +278 -0
  387. package/dist/collection/components/item-option/item-option.ios.css +136 -29
  388. package/dist/collection/components/item-option/item-option.js +73 -9
  389. package/dist/collection/components/item-option/item-option.md.css +136 -29
  390. package/dist/collection/components/item-options/item-options.ionic.css +221 -0
  391. package/dist/collection/components/item-options/item-options.ios.css +77 -34
  392. package/dist/collection/components/item-options/item-options.js +13 -7
  393. package/dist/collection/components/item-options/item-options.md.css +77 -34
  394. package/dist/collection/components/item-sliding/item-sliding.css +6 -0
  395. package/dist/collection/components/item-sliding/item-sliding.js +8 -4
  396. package/dist/collection/components/label/label.ios.css +18 -0
  397. package/dist/collection/components/label/label.js +11 -8
  398. package/dist/collection/components/label/label.md.css +18 -0
  399. package/dist/collection/components/list/list.ionic.css +212 -0
  400. package/dist/collection/components/list/list.ios.css +54 -14
  401. package/dist/collection/components/list/list.js +48 -9
  402. package/dist/collection/components/list/list.md.css +56 -16
  403. package/dist/collection/components/list-header/list-header.ionic.css +190 -0
  404. package/dist/collection/components/list-header/list-header.ios.css +82 -38
  405. package/dist/collection/components/list-header/list-header.js +11 -8
  406. package/dist/collection/components/list-header/list-header.md.css +82 -38
  407. package/dist/collection/components/loading/loading.ios.css +13 -1
  408. package/dist/collection/components/loading/loading.js +14 -11
  409. package/dist/collection/components/loading/loading.md.css +13 -1
  410. package/dist/collection/components/menu/menu.ios.css +15 -3
  411. package/dist/collection/components/menu/menu.js +12 -7
  412. package/dist/collection/components/menu/menu.md.css +15 -3
  413. package/dist/collection/components/menu-button/menu-button.ionic.css +236 -0
  414. package/dist/collection/components/menu-button/menu-button.ios.css +48 -14
  415. package/dist/collection/components/menu-button/menu-button.js +26 -10
  416. package/dist/collection/components/menu-button/menu-button.md.css +49 -15
  417. package/dist/collection/components/menu-toggle/menu-toggle.js +8 -5
  418. package/dist/collection/components/modal/animations/sheet.js +8 -2
  419. package/dist/collection/components/modal/gestures/sheet.js +10 -6
  420. package/dist/collection/components/modal/modal.ionic.css +247 -0
  421. package/dist/collection/components/modal/modal.ios.css +174 -70
  422. package/dist/collection/components/modal/modal.js +48 -11
  423. package/dist/collection/components/modal/modal.md.css +174 -70
  424. package/dist/collection/components/nav/nav.css +7 -1
  425. package/dist/collection/components/nav/nav.js +11 -5
  426. package/dist/collection/components/nav-link/nav-link.js +5 -1
  427. package/dist/collection/components/note/note.ios.css +12 -0
  428. package/dist/collection/components/note/note.js +11 -8
  429. package/dist/collection/components/note/note.md.css +12 -0
  430. package/dist/collection/components/picker/picker.ios.css +15 -3
  431. package/dist/collection/components/picker/picker.js +8 -5
  432. package/dist/collection/components/picker/picker.md.css +15 -3
  433. package/dist/collection/components/picker-column/picker-column.css +9 -2
  434. package/dist/collection/components/picker-column/picker-column.js +8 -7
  435. package/dist/collection/components/picker-column-option/picker-column-option.ios.css +6 -0
  436. package/dist/collection/components/picker-column-option/picker-column-option.js +13 -7
  437. package/dist/collection/components/picker-column-option/picker-column-option.md.css +6 -0
  438. package/dist/collection/components/picker-legacy/picker.ios.css +13 -1
  439. package/dist/collection/components/picker-legacy/picker.js +7 -6
  440. package/dist/collection/components/picker-legacy/picker.md.css +13 -1
  441. package/dist/collection/components/picker-legacy-column/picker-column.ios.css +12 -0
  442. package/dist/collection/components/picker-legacy-column/picker-column.js +4 -4
  443. package/dist/collection/components/picker-legacy-column/picker-column.md.css +12 -0
  444. package/dist/collection/components/popover/popover.ios.css +13 -1
  445. package/dist/collection/components/popover/popover.js +17 -14
  446. package/dist/collection/components/popover/popover.md.css +13 -1
  447. package/dist/collection/components/progress-bar/progress-bar.ionic.css +287 -0
  448. package/dist/collection/components/progress-bar/progress-bar.ios.css +48 -17
  449. package/dist/collection/components/progress-bar/progress-bar.js +43 -7
  450. package/dist/collection/components/progress-bar/progress-bar.md.css +48 -17
  451. package/dist/collection/components/radio/radio.ionic.css +422 -0
  452. package/dist/collection/components/radio/radio.ios.css +134 -91
  453. package/dist/collection/components/radio/radio.js +12 -9
  454. package/dist/collection/components/radio/radio.md.css +134 -91
  455. package/dist/collection/components/radio-group/radio-group.ionic.css +119 -0
  456. package/dist/collection/components/radio-group/radio-group.ios.css +43 -23
  457. package/dist/collection/components/radio-group/radio-group.js +21 -6
  458. package/dist/collection/components/radio-group/radio-group.md.css +43 -23
  459. package/dist/collection/components/range/range.ionic.css +563 -0
  460. package/dist/collection/components/range/range.ios.css +128 -85
  461. package/dist/collection/components/range/range.js +12 -9
  462. package/dist/collection/components/range/range.md.css +128 -85
  463. package/dist/collection/components/refresher/refresher.ios.css +14 -1
  464. package/dist/collection/components/refresher/refresher.js +11 -8
  465. package/dist/collection/components/refresher/refresher.md.css +15 -2
  466. package/dist/collection/components/refresher-content/refresher-content.js +28 -7
  467. package/dist/collection/components/reorder/reorder.ios.css +6 -0
  468. package/dist/collection/components/reorder/reorder.js +33 -6
  469. package/dist/collection/components/reorder/reorder.md.css +6 -0
  470. package/dist/collection/components/reorder-group/reorder-group.css +6 -0
  471. package/dist/collection/components/reorder-group/reorder-group.js +8 -4
  472. package/dist/collection/components/ripple-effect/{ripple-effect.css → ripple-effect.common.css} +7 -1
  473. package/dist/collection/components/ripple-effect/ripple-effect.ionic.css +215 -0
  474. package/dist/collection/components/ripple-effect/ripple-effect.js +14 -6
  475. package/dist/collection/components/route/route.js +4 -0
  476. package/dist/collection/components/router/router.js +4 -0
  477. package/dist/collection/components/router-link/router-link.css +8 -2
  478. package/dist/collection/components/router-link/router-link.js +9 -5
  479. package/dist/collection/components/router-outlet/router-outlet.css +7 -1
  480. package/dist/collection/components/router-outlet/router-outlet.js +6 -3
  481. package/dist/collection/components/row/row.css +16 -0
  482. package/dist/collection/components/row/row.js +9 -2
  483. package/dist/collection/components/searchbar/searchbar.ionic.css +626 -0
  484. package/dist/collection/components/searchbar/searchbar.ios.css +56 -18
  485. package/dist/collection/components/searchbar/searchbar.js +181 -34
  486. package/dist/collection/components/searchbar/searchbar.md.css +56 -18
  487. package/dist/collection/components/segment/segment.ionic.css +115 -0
  488. package/dist/collection/components/segment/segment.ios.css +45 -2
  489. package/dist/collection/components/segment/segment.js +11 -8
  490. package/dist/collection/components/segment/segment.md.css +45 -2
  491. package/dist/collection/components/segment-button/segment-button.ionic.css +353 -0
  492. package/dist/collection/components/segment-button/segment-button.ios.css +146 -105
  493. package/dist/collection/components/segment-button/segment-button.js +11 -8
  494. package/dist/collection/components/segment-button/segment-button.md.css +148 -107
  495. package/dist/collection/components/segment-content/segment-content.js +1 -1
  496. package/dist/collection/components/segment-view/segment-view.ios.css +6 -0
  497. package/dist/collection/components/segment-view/segment-view.js +6 -4
  498. package/dist/collection/components/segment-view/segment-view.md.css +6 -0
  499. package/dist/collection/components/select/select.ionic.css +777 -0
  500. package/dist/collection/components/select/select.ios.css +315 -176
  501. package/dist/collection/components/select/select.js +156 -53
  502. package/dist/collection/components/select/select.md.css +331 -178
  503. package/dist/collection/components/select-modal/select-modal.ionic.css +130 -0
  504. package/dist/collection/components/select-modal/select-modal.ios.css +18 -0
  505. package/dist/collection/components/select-modal/select-modal.js +11 -4
  506. package/dist/collection/components/select-modal/select-modal.md.css +7 -3
  507. package/dist/collection/components/select-option/select-option.js +9 -2
  508. package/dist/collection/components/select-popover/select-popover.ios.css +18 -0
  509. package/dist/collection/components/select-popover/select-popover.js +12 -4
  510. package/dist/collection/components/select-popover/select-popover.md.css +18 -0
  511. package/dist/collection/components/skeleton-text/skeleton-text.css +6 -0
  512. package/dist/collection/components/skeleton-text/skeleton-text.js +9 -5
  513. package/dist/collection/components/spinner/{spinner.css → spinner.ionic.css} +77 -10
  514. package/dist/collection/components/spinner/spinner.js +47 -6
  515. package/dist/collection/components/spinner/spinner.native.css +198 -0
  516. package/dist/collection/components/split-pane/split-pane.ios.css +20 -2
  517. package/dist/collection/components/split-pane/split-pane.js +14 -8
  518. package/dist/collection/components/split-pane/split-pane.md.css +20 -2
  519. package/dist/collection/components/tab/tab.js +6 -2
  520. package/dist/collection/components/tab-bar/tab-bar.ionic.css +201 -0
  521. package/dist/collection/components/tab-bar/tab-bar.ios.css +71 -43
  522. package/dist/collection/components/tab-bar/tab-bar.js +78 -11
  523. package/dist/collection/components/tab-bar/tab-bar.md.css +71 -43
  524. package/dist/collection/components/tab-button/tab-button.ionic.css +337 -0
  525. package/dist/collection/components/tab-button/tab-button.ios.css +171 -95
  526. package/dist/collection/components/tab-button/tab-button.js +54 -9
  527. package/dist/collection/components/tab-button/tab-button.md.css +137 -93
  528. package/dist/collection/components/tabs/tabs.css +7 -1
  529. package/dist/collection/components/tabs/tabs.js +4 -1
  530. package/dist/collection/components/text/text.css +6 -0
  531. package/dist/collection/components/text/text.js +7 -6
  532. package/dist/collection/components/textarea/textarea.ionic.css +890 -0
  533. package/dist/collection/components/textarea/textarea.ios.css +283 -142
  534. package/dist/collection/components/textarea/textarea.js +146 -24
  535. package/dist/collection/components/textarea/textarea.md.css +297 -143
  536. package/dist/collection/components/thumbnail/thumbnail.css +6 -0
  537. package/dist/collection/components/thumbnail/thumbnail.js +9 -2
  538. package/dist/collection/components/title/title.ionic.css +127 -0
  539. package/dist/collection/components/title/title.ios.css +32 -4
  540. package/dist/collection/components/title/title.js +13 -7
  541. package/dist/collection/components/title/title.md.css +32 -4
  542. package/dist/collection/components/toast/animations/utils.js +1 -1
  543. package/dist/collection/components/toast/toast.ionic.css +394 -0
  544. package/dist/collection/components/toast/toast.ios.css +84 -45
  545. package/dist/collection/components/toast/toast.js +75 -12
  546. package/dist/collection/components/toast/toast.md.css +84 -45
  547. package/dist/collection/components/toggle/toggle.ionic.css +508 -0
  548. package/dist/collection/components/toggle/toggle.ios.css +247 -131
  549. package/dist/collection/components/toggle/toggle.js +73 -18
  550. package/dist/collection/components/toggle/toggle.md.css +244 -131
  551. package/dist/collection/components/toolbar/test/image.svg +1 -0
  552. package/dist/collection/components/toolbar/toolbar.ionic.css +241 -0
  553. package/dist/collection/components/toolbar/toolbar.ios.css +90 -47
  554. package/dist/collection/components/toolbar/toolbar.js +157 -13
  555. package/dist/collection/components/toolbar/toolbar.md.css +90 -47
  556. package/dist/collection/global/ionic-global.js +228 -13
  557. package/dist/collection/utils/focus-trap.js +13 -2
  558. package/dist/collection/utils/focus-visible.js +22 -0
  559. package/dist/collection/utils/forms/validity.js +31 -0
  560. package/dist/collection/utils/framework-delegate.js +3 -1
  561. package/dist/collection/utils/helpers.js +57 -3
  562. package/dist/collection/utils/keyboard/keyboard-controller.js +3 -1
  563. package/dist/collection/utils/menu-controller/animations/overlay.js +3 -3
  564. package/dist/collection/utils/menu-controller/animations/push.js +2 -1
  565. package/dist/collection/utils/menu-controller/animations/reveal.js +2 -1
  566. package/dist/collection/utils/overlays.js +82 -1
  567. package/dist/collection/utils/test/playwright/generator.js +48 -23
  568. package/dist/collection/utils/test/playwright/page/utils/goto.js +14 -5
  569. package/dist/collection/utils/test/playwright/page/utils/set-content.js +26 -3
  570. package/dist/collection/utils/transition/ios.transition.js +1 -0
  571. package/dist/docs.json +8263 -377
  572. package/dist/esm/{animation-Dt8bGnA-.js → animation-DR5OwIG7.js} +2 -2
  573. package/dist/esm/{app-globals-BDSf8fOA.js → app-globals-tUwaabUU.js} +1 -1
  574. package/dist/esm/{button-active-L570Swow.js → button-active-CegK1Ga3.js} +2 -2
  575. package/dist/esm/{capacitor-CFERIeaU.js → capacitor-Ap5mZl6I.js} +1 -1
  576. package/dist/esm/caret-down-D1t981Ih.js +6 -0
  577. package/dist/esm/caret-left-fIOYmaqA.js +6 -0
  578. package/dist/esm/caret-right-BYSs-jZz.js +6 -0
  579. package/dist/esm/{config-mCdtaoPe.js → config-DK9FWNvn.js} +1 -1
  580. package/dist/esm/{data-DCORV9FH.js → data-B5lRlGxI.js} +6 -6
  581. package/dist/esm/{focus-visible-BmVRXR1y.js → focus-visible-vXpMhGrs.js} +23 -1
  582. package/dist/esm/{framework-delegate-BYawdMXj.js → framework-delegate-Dx6tn-_w.js} +4 -2
  583. package/dist/esm/{haptic-DzAMWJuk.js → haptic-hXtWLcs-.js} +1 -1
  584. package/dist/esm/{helpers-DEn3pfjm.js → helpers-6l6yFg3S.js} +57 -4
  585. package/dist/esm/{index-r2D9DEro.js → index-BVnPBHWX.js} +4 -4
  586. package/dist/esm/{index-ceb5RaMT.js → index-CAS79tvr.js} +4 -3
  587. package/dist/esm/{index-CvDIirVx.js → index-CH4BJAR9.js} +11 -11
  588. package/dist/esm/{index-DV3sJJW8.js → index-COG0_eom.js} +1 -1
  589. package/dist/esm/{index-Bs3kT4bc.js → index-CXCvNx5X.js} +2 -2
  590. package/dist/esm/{index-C8IsBmNU.js → index-gD7P82jx.js} +41 -4
  591. package/dist/esm/index.js +12 -13
  592. package/dist/esm/{input-shims-DyOpfTg6.js → input-shims-DFQmNfaZ.js} +7 -6
  593. package/dist/esm/{input.utils-DrvTa8gz.js → input.utils-85zOntcN.js} +3 -3
  594. package/dist/esm/ion-accordion_2.entry.js +57 -28
  595. package/dist/esm/ion-action-sheet.entry.js +24 -21
  596. package/dist/esm/ion-alert.entry.js +24 -22
  597. package/dist/esm/ion-app_8.entry.js +250 -151
  598. package/dist/esm/ion-avatar_3.entry.js +125 -13
  599. package/dist/esm/ion-back-button.entry.js +30 -21
  600. package/dist/esm/ion-backdrop.entry.js +10 -7
  601. package/dist/esm/ion-breadcrumb_2.entry.js +53 -17
  602. package/dist/esm/ion-button_2.entry.js +44 -12
  603. package/dist/esm/ion-card_5.entry.js +54 -30
  604. package/dist/esm/ion-checkbox.entry.js +33 -15
  605. package/dist/esm/ion-chip.entry.js +49 -8
  606. package/dist/esm/ion-col_3.entry.js +54 -57
  607. package/dist/esm/ion-datetime-button.entry.js +12 -8
  608. package/dist/esm/ion-datetime_3.entry.js +115 -40
  609. package/dist/esm/ion-divider.entry.js +49 -0
  610. package/dist/esm/ion-fab_3.entry.js +43 -27
  611. package/dist/esm/ion-img.entry.js +8 -4
  612. package/dist/esm/ion-infinite-scroll_2.entry.js +91 -16
  613. package/dist/esm/ion-input-otp.entry.js +12 -8
  614. package/dist/esm/ion-input-password-toggle.entry.js +52 -14
  615. package/dist/esm/ion-input.entry.js +123 -33
  616. package/dist/esm/ion-item-option_3.entry.js +49 -20
  617. package/dist/esm/ion-item_8.entry.js +115 -48
  618. package/dist/esm/ion-loading.entry.js +19 -17
  619. package/dist/esm/ion-menu_3.entry.js +46 -28
  620. package/dist/esm/ion-modal.entry.js +57 -30
  621. package/dist/esm/ion-nav_2.entry.js +14 -11
  622. package/dist/esm/ion-picker-column-option.entry.js +11 -7
  623. package/dist/esm/ion-picker-column.entry.js +12 -12
  624. package/dist/esm/ion-picker.entry.js +10 -6
  625. package/dist/esm/ion-popover.entry.js +19 -17
  626. package/dist/esm/ion-progress-bar.entry.js +26 -8
  627. package/dist/esm/ion-radio_2.entry.js +26 -16
  628. package/dist/esm/ion-range.entry.js +15 -11
  629. package/dist/esm/ion-refresher_2.entry.js +39 -21
  630. package/dist/esm/ion-reorder_2.entry.js +38 -14
  631. package/dist/esm/ion-ripple-effect.entry.js +15 -7
  632. package/dist/esm/ion-route_4.entry.js +9 -8
  633. package/dist/esm/ion-searchbar.entry.js +137 -24
  634. package/dist/esm/ion-segment-content.entry.js +2 -2
  635. package/dist/esm/ion-segment-view.entry.js +6 -3
  636. package/dist/esm/ion-segment_2.entry.js +22 -15
  637. package/dist/esm/ion-select-modal.entry.js +17 -11
  638. package/dist/esm/ion-select_3.entry.js +132 -41
  639. package/dist/esm/ion-spinner.entry.js +29 -7
  640. package/dist/esm/ion-split-pane.entry.js +12 -9
  641. package/dist/esm/ion-tab-bar_2.entry.js +76 -22
  642. package/dist/esm/ion-tab_2.entry.js +8 -7
  643. package/dist/esm/ion-text.entry.js +6 -6
  644. package/dist/esm/ion-textarea.entry.js +117 -22
  645. package/dist/esm/ion-toast.entry.js +42 -19
  646. package/dist/esm/ion-toggle.entry.js +81 -24
  647. package/dist/esm/ionic-global-C2dfEr5R.js +480 -0
  648. package/dist/esm/ionic.js +5 -5
  649. package/dist/esm/{ios.transition-BDzw0_Hm.js → ios.transition-mZDQgHke.js} +7 -5
  650. package/dist/esm/{keyboard-ywgs5efA.js → keyboard-BBx8cd5K.js} +4 -3
  651. package/dist/esm/{keyboard-CUw4ekVy.js → keyboard-NoPSnHZy.js} +1 -1
  652. package/dist/esm/{keyboard-controller-BaaVITYt.js → keyboard-controller-D5zoL0pZ.js} +5 -3
  653. package/dist/esm/list-Dhi5xtNS.js +6 -0
  654. package/dist/esm/loader.js +5 -5
  655. package/dist/esm/{md.transition-BzDYi3qq.js → md.transition-DOqTLNQU.js} +6 -5
  656. package/dist/esm/{notch-controller-BwelN_JM.js → notch-controller-C7UVCCo4.js} +2 -2
  657. package/dist/esm/{overlays-DCabi1dI.js → overlays-DvZf7QU-.js} +99 -9
  658. package/dist/esm/{status-tap-5DQ7Fc4V.js → status-tap-BAJGCN-1.js} +4 -3
  659. package/dist/esm/{swipe-back-BKw2CAHc.js → swipe-back-bZ7qcCmT.js} +3 -2
  660. package/dist/esm/validity-BjW8SOqw.js +48 -0
  661. package/dist/esm/x-BDqjX7Z_.js +6 -0
  662. package/dist/html.html-data.json +2530 -224
  663. package/dist/ionic/index.esm.js +1 -1
  664. package/dist/ionic/ionic.esm.js +1 -1
  665. package/dist/ionic/p-01ebb298.entry.js +4 -0
  666. package/dist/ionic/p-058204d8.entry.js +4 -0
  667. package/dist/ionic/p-074b3070.entry.js +4 -0
  668. package/dist/ionic/p-0ac03d31.entry.js +4 -0
  669. package/dist/ionic/p-1552f206.entry.js +4 -0
  670. package/dist/ionic/p-2eeb3efe.entry.js +4 -0
  671. package/dist/ionic/p-35214276.entry.js +4 -0
  672. package/dist/ionic/p-354515ed.entry.js +4 -0
  673. package/dist/ionic/p-3ec68103.entry.js +4 -0
  674. package/dist/ionic/p-427c1ad4.entry.js +4 -0
  675. package/dist/ionic/p-453a5dda.entry.js +4 -0
  676. package/dist/ionic/p-45551cea.entry.js +4 -0
  677. package/dist/ionic/p-484549da.entry.js +4 -0
  678. package/dist/ionic/p-505435ca.entry.js +4 -0
  679. package/dist/ionic/p-50c72200.entry.js +4 -0
  680. package/dist/ionic/p-5189dd57.entry.js +4 -0
  681. package/dist/ionic/p-52d0d65d.entry.js +4 -0
  682. package/dist/ionic/p-59279168.entry.js +4 -0
  683. package/dist/ionic/p-59482460.entry.js +4 -0
  684. package/dist/ionic/p-5cad7882.entry.js +4 -0
  685. package/dist/ionic/p-5d4f0f1d.entry.js +4 -0
  686. package/dist/ionic/p-5fcd7b49.entry.js +4 -0
  687. package/dist/ionic/p-6760dd1e.entry.js +4 -0
  688. package/dist/ionic/p-69465c18.entry.js +4 -0
  689. package/dist/ionic/p-6c4559a0.entry.js +4 -0
  690. package/dist/ionic/p-76734290.entry.js +4 -0
  691. package/dist/ionic/p-7d15135e.entry.js +4 -0
  692. package/dist/ionic/p-80d247b1.entry.js +4 -0
  693. package/dist/ionic/p-8396abe1.entry.js +4 -0
  694. package/dist/ionic/p-86a947c1.entry.js +4 -0
  695. package/dist/ionic/p-879ce6f2.entry.js +4 -0
  696. package/dist/ionic/p-8e97391b.entry.js +4 -0
  697. package/dist/ionic/p-984df948.entry.js +4 -0
  698. package/dist/ionic/p-9a00aac8.entry.js +4 -0
  699. package/dist/ionic/p-9b5b0e6d.entry.js +4 -0
  700. package/dist/ionic/p-B9cWjC5a.js +4 -0
  701. package/dist/ionic/p-BDhPZwpV.js +4 -0
  702. package/dist/ionic/p-BDqjX7Z_.js +4 -0
  703. package/dist/ionic/p-BI1KkP1o.js +4 -0
  704. package/dist/ionic/p-BYSs-jZz.js +4 -0
  705. package/dist/ionic/p-BYnmISwy.js +4 -0
  706. package/dist/ionic/p-BjW8SOqw.js +4 -0
  707. package/dist/ionic/{p-Dc45iWE4.js → p-Bmh46Fz0.js} +1 -1
  708. package/dist/ionic/{p-BYEqWnSg.js → p-BsbREiiN.js} +1 -1
  709. package/dist/ionic/p-CCy93Kdo.js +4 -0
  710. package/dist/ionic/{p-D0dMcSkw.js → p-CDRncjej.js} +1 -1
  711. package/dist/ionic/{p-CJxh_yLS.js → p-CH8-5k8b.js} +1 -1
  712. package/dist/ionic/{p-DV3sJJW8.js → p-COG0_eom.js} +1 -1
  713. package/dist/ionic/p-CSbvB5z5.js +4 -0
  714. package/dist/ionic/p-CVI6Uwrk.js +4 -0
  715. package/dist/ionic/{p-CwgG81ZD.js → p-CYW7idR0.js} +1 -1
  716. package/dist/ionic/p-CZG8whz6.js +4 -0
  717. package/dist/ionic/p-Cq6IwwGB.js +4 -0
  718. package/dist/ionic/p-Ct1oJEVo.js +4 -0
  719. package/dist/ionic/p-CtS5hTli.js +4 -0
  720. package/dist/ionic/{p-DbQ5QkTP.js → p-Cv5jk_TK.js} +1 -1
  721. package/dist/ionic/p-D1t981Ih.js +4 -0
  722. package/dist/ionic/p-D2EO-8IE.js +4 -0
  723. package/dist/ionic/p-DIzp9O64.js +4 -0
  724. package/dist/ionic/{p-D13Eaw-8.js → p-DMo2WKG5.js} +1 -1
  725. package/dist/ionic/p-DUdm2h77.js +4 -0
  726. package/dist/ionic/p-Dhi5xtNS.js +4 -0
  727. package/dist/ionic/p-DkXYG789.js +4 -0
  728. package/dist/ionic/p-We-0jbXn.js +4 -0
  729. package/dist/ionic/p-a4282459.entry.js +4 -0
  730. package/dist/ionic/p-b9ec8be1.entry.js +4 -0
  731. package/dist/ionic/p-bf2ac6e0.entry.js +4 -0
  732. package/dist/ionic/p-c12298f5.entry.js +4 -0
  733. package/dist/ionic/p-c1562e8b.entry.js +4 -0
  734. package/dist/ionic/p-c7df4ca1.entry.js +4 -0
  735. package/dist/ionic/p-cb1f3e0c.entry.js +4 -0
  736. package/dist/ionic/p-d12a71be.entry.js +4 -0
  737. package/dist/ionic/p-d249f019.entry.js +4 -0
  738. package/dist/ionic/p-de2418c7.entry.js +4 -0
  739. package/dist/ionic/p-df036563.entry.js +4 -0
  740. package/dist/ionic/p-e174f8a8.entry.js +4 -0
  741. package/dist/ionic/p-e67abd5f.entry.js +4 -0
  742. package/dist/ionic/p-e937a89a.entry.js +4 -0
  743. package/dist/ionic/p-f01c1e73.entry.js +4 -0
  744. package/dist/ionic/p-f2ba465e.entry.js +4 -0
  745. package/dist/ionic/p-f5be9d83.entry.js +4 -0
  746. package/dist/ionic/p-fIOYmaqA.js +4 -0
  747. package/dist/ionic/p-fb3b3444.entry.js +4 -0
  748. package/dist/ionic/p-gD7P82jx.js +5 -0
  749. package/dist/ionic/p-hPTD29t1.js +4 -0
  750. package/dist/ionic/{p-CKvCXMs9.js → p-qNBpc0Qq.js} +1 -1
  751. package/dist/ionic/p-vXpMhGrs.js +4 -0
  752. package/dist/types/components/accordion/accordion.d.ts +5 -3
  753. package/dist/types/components/accordion-group/accordion-group.d.ts +12 -1
  754. package/dist/types/components/action-sheet/action-sheet-interface.d.ts +3 -7
  755. package/dist/types/components/action-sheet/action-sheet.d.ts +3 -2
  756. package/dist/types/components/alert/alert-interface.d.ts +3 -7
  757. package/dist/types/components/alert/alert.d.ts +3 -2
  758. package/dist/types/components/app/app.d.ts +4 -2
  759. package/dist/types/components/avatar/avatar.d.ts +32 -0
  760. package/dist/types/components/back-button/back-button.d.ts +2 -1
  761. package/dist/types/components/backdrop/backdrop.d.ts +4 -0
  762. package/dist/types/components/badge/badge.d.ts +34 -1
  763. package/dist/types/components/breadcrumb/breadcrumb.d.ts +4 -1
  764. package/dist/types/components/breadcrumbs/breadcrumbs.d.ts +2 -2
  765. package/dist/types/components/button/button.d.ts +19 -6
  766. package/dist/types/components/buttons/buttons.d.ts +5 -1
  767. package/dist/types/components/card/card.d.ts +8 -1
  768. package/dist/types/components/card-content/card-content.d.ts +2 -1
  769. package/dist/types/components/card-header/card-header.d.ts +3 -2
  770. package/dist/types/components/card-subtitle/card-subtitle.d.ts +2 -1
  771. package/dist/types/components/card-title/card-title.d.ts +2 -1
  772. package/dist/types/components/checkbox/checkbox.d.ts +14 -4
  773. package/dist/types/components/chip/chip.d.ts +26 -1
  774. package/dist/types/components/col/col.d.ts +52 -5
  775. package/dist/types/components/content/content.d.ts +3 -0
  776. package/dist/types/components/datetime/datetime.d.ts +26 -1
  777. package/dist/types/components/datetime/utils/data.d.ts +5 -5
  778. package/dist/types/components/datetime-button/datetime-button.d.ts +2 -1
  779. package/dist/types/components/divider/divider.d.ts +20 -0
  780. package/dist/types/components/fab/fab.d.ts +4 -0
  781. package/dist/types/components/fab-button/fab-button.d.ts +5 -3
  782. package/dist/types/components/fab-list/fab-list.d.ts +4 -0
  783. package/dist/types/components/footer/footer.d.ts +4 -3
  784. package/dist/types/components/grid/grid.d.ts +4 -0
  785. package/dist/types/components/header/header.d.ts +9 -3
  786. package/dist/types/components/header/header.utils.d.ts +3 -3
  787. package/dist/types/components/img/img.d.ts +3 -0
  788. package/dist/types/components/infinite-scroll/infinite-scroll.d.ts +21 -0
  789. package/dist/types/components/infinite-scroll-content/infinite-scroll-content.d.ts +4 -0
  790. package/dist/types/components/input/input.d.ts +31 -5
  791. package/dist/types/components/input-password-toggle/input-password-toggle.d.ts +2 -0
  792. package/dist/types/components/item/item.d.ts +11 -4
  793. package/dist/types/components/item-divider/item-divider.d.ts +2 -1
  794. package/dist/types/components/item-group/item-group.d.ts +4 -0
  795. package/dist/types/components/item-option/item-option.d.ts +18 -1
  796. package/dist/types/components/item-options/item-options.d.ts +4 -0
  797. package/dist/types/components/item-sliding/item-sliding.d.ts +4 -0
  798. package/dist/types/components/label/label.d.ts +2 -1
  799. package/dist/types/components/list/list.d.ts +15 -1
  800. package/dist/types/components/list-header/list-header.d.ts +2 -1
  801. package/dist/types/components/loading/loading-interface.d.ts +2 -7
  802. package/dist/types/components/loading/loading.d.ts +3 -2
  803. package/dist/types/components/menu/menu.d.ts +3 -0
  804. package/dist/types/components/menu-button/menu-button.d.ts +3 -1
  805. package/dist/types/components/menu-toggle/menu-toggle.d.ts +3 -0
  806. package/dist/types/components/modal/gestures/sheet.d.ts +1 -1
  807. package/dist/types/components/modal/modal-interface.d.ts +4 -7
  808. package/dist/types/components/modal/modal.d.ts +11 -1
  809. package/dist/types/components/nav/nav-interface.d.ts +9 -1
  810. package/dist/types/components/nav/nav.d.ts +5 -1
  811. package/dist/types/components/nav-link/nav-link.d.ts +4 -0
  812. package/dist/types/components/note/note.d.ts +2 -1
  813. package/dist/types/components/picker/picker.d.ts +2 -1
  814. package/dist/types/components/picker-column/picker-column.d.ts +2 -1
  815. package/dist/types/components/picker-column-option/picker-column-option.d.ts +4 -0
  816. package/dist/types/components/picker-legacy/picker.d.ts +2 -1
  817. package/dist/types/components/popover/popover-interface.d.ts +3 -6
  818. package/dist/types/components/popover/popover.d.ts +6 -5
  819. package/dist/types/components/progress-bar/progress-bar.d.ts +10 -1
  820. package/dist/types/components/radio/radio.d.ts +2 -1
  821. package/dist/types/components/radio-group/radio-group.d.ts +8 -0
  822. package/dist/types/components/range/range.d.ts +2 -1
  823. package/dist/types/components/refresher/refresher.d.ts +2 -1
  824. package/dist/types/components/refresher-content/refresher-content.d.ts +4 -0
  825. package/dist/types/components/reorder/reorder.d.ts +9 -0
  826. package/dist/types/components/reorder-group/reorder-group.d.ts +4 -0
  827. package/dist/types/components/ripple-effect/ripple-effect.d.ts +4 -0
  828. package/dist/types/components/route/route.d.ts +4 -0
  829. package/dist/types/components/router/router.d.ts +4 -0
  830. package/dist/types/components/router-link/router-link.d.ts +4 -0
  831. package/dist/types/components/router-outlet/router-outlet.d.ts +4 -1
  832. package/dist/types/components/row/row.d.ts +4 -0
  833. package/dist/types/components/searchbar/searchbar.d.ts +51 -9
  834. package/dist/types/components/segment/segment.d.ts +2 -1
  835. package/dist/types/components/segment-button/segment-button.d.ts +2 -1
  836. package/dist/types/components/select/select.d.ts +41 -13
  837. package/dist/types/components/select-modal/select-modal.d.ts +1 -0
  838. package/dist/types/components/select-option/select-option.d.ts +4 -0
  839. package/dist/types/components/select-popover/select-popover.d.ts +3 -0
  840. package/dist/types/components/skeleton-text/skeleton-text.d.ts +4 -0
  841. package/dist/types/components/spinner/spinner.d.ts +15 -0
  842. package/dist/types/components/split-pane/split-pane.d.ts +4 -0
  843. package/dist/types/components/tab/tab.d.ts +4 -0
  844. package/dist/types/components/tab-bar/tab-bar.d.ts +22 -2
  845. package/dist/types/components/tab-button/tab-button.d.ts +12 -1
  846. package/dist/types/components/tabs/tabs.d.ts +3 -0
  847. package/dist/types/components/text/text.d.ts +2 -1
  848. package/dist/types/components/textarea/textarea.d.ts +42 -4
  849. package/dist/types/components/thumbnail/thumbnail.d.ts +4 -0
  850. package/dist/types/components/title/title.d.ts +4 -0
  851. package/dist/types/components/toast/animations/utils.d.ts +2 -2
  852. package/dist/types/components/toast/toast-interface.d.ts +3 -7
  853. package/dist/types/components/toast/toast.d.ts +19 -2
  854. package/dist/types/components/toggle/toggle.d.ts +15 -1
  855. package/dist/types/components/toolbar/toolbar.d.ts +20 -3
  856. package/dist/types/components.d.ts +1593 -196
  857. package/dist/types/global/ionic-global.d.ts +27 -2
  858. package/dist/types/interface.d.ts +3 -0
  859. package/dist/types/utils/config.d.ts +106 -2
  860. package/dist/types/utils/focus-trap.d.ts +1 -1
  861. package/dist/types/utils/focus-visible.d.ts +13 -0
  862. package/dist/types/utils/forms/validity.d.ts +7 -0
  863. package/dist/types/utils/helpers.d.ts +11 -0
  864. package/dist/types/utils/overlays-interface.d.ts +31 -1
  865. package/dist/types/utils/test/playwright/generator.d.ts +31 -2
  866. package/hydrate/index.js +3099 -964
  867. package/hydrate/index.mjs +3099 -964
  868. package/package.json +12 -8
  869. package/components/hardware-back-button.js +0 -115
  870. package/components/index9.js +0 -7
  871. package/dist/cjs/hardware-back-button-VCK4V3mG.js +0 -121
  872. package/dist/cjs/index-DkNv4J_i.js +0 -10
  873. package/dist/cjs/ionic-global-HMVqOFGO.js +0 -151
  874. package/dist/cjs/validity-BpS37YFM.js +0 -19
  875. package/dist/esm/hardware-back-button-CPLxO-Ev.js +0 -115
  876. package/dist/esm/index-ZjP4CjeZ.js +0 -7
  877. package/dist/esm/ionic-global-CDrldh-5.js +0 -146
  878. package/dist/esm/validity-DJztqcrH.js +0 -17
  879. package/dist/ionic/p-020af078.entry.js +0 -4
  880. package/dist/ionic/p-074839fc.entry.js +0 -4
  881. package/dist/ionic/p-07753df3.entry.js +0 -4
  882. package/dist/ionic/p-0abeb0fc.entry.js +0 -4
  883. package/dist/ionic/p-0bf76d0f.entry.js +0 -4
  884. package/dist/ionic/p-0dfa5a37.entry.js +0 -4
  885. package/dist/ionic/p-11518b31.entry.js +0 -4
  886. package/dist/ionic/p-1647c46c.entry.js +0 -4
  887. package/dist/ionic/p-2a939845.entry.js +0 -4
  888. package/dist/ionic/p-316c0420.entry.js +0 -4
  889. package/dist/ionic/p-31f7095f.entry.js +0 -4
  890. package/dist/ionic/p-370e4237.entry.js +0 -4
  891. package/dist/ionic/p-3a6caca9.entry.js +0 -4
  892. package/dist/ionic/p-40c261a3.entry.js +0 -4
  893. package/dist/ionic/p-43ed1ef5.entry.js +0 -4
  894. package/dist/ionic/p-46d74291.entry.js +0 -4
  895. package/dist/ionic/p-49d06882.entry.js +0 -4
  896. package/dist/ionic/p-4b658a7c.entry.js +0 -4
  897. package/dist/ionic/p-4e41ea20.entry.js +0 -4
  898. package/dist/ionic/p-51a60e0f.entry.js +0 -4
  899. package/dist/ionic/p-576e0965.entry.js +0 -4
  900. package/dist/ionic/p-582824c5.entry.js +0 -4
  901. package/dist/ionic/p-6241ce47.entry.js +0 -4
  902. package/dist/ionic/p-639dd543.entry.js +0 -4
  903. package/dist/ionic/p-6444c606.entry.js +0 -4
  904. package/dist/ionic/p-675b1a31.entry.js +0 -4
  905. package/dist/ionic/p-6d070558.entry.js +0 -4
  906. package/dist/ionic/p-7268efa5.entry.js +0 -4
  907. package/dist/ionic/p-72c38b88.entry.js +0 -4
  908. package/dist/ionic/p-75ae4733.entry.js +0 -4
  909. package/dist/ionic/p-79bd78f9.entry.js +0 -4
  910. package/dist/ionic/p-86f53961.entry.js +0 -4
  911. package/dist/ionic/p-94de5cfa.entry.js +0 -4
  912. package/dist/ionic/p-9575b654.entry.js +0 -4
  913. package/dist/ionic/p-9eeaBrnk.js +0 -4
  914. package/dist/ionic/p-B0q1YL7N.js +0 -4
  915. package/dist/ionic/p-BFvmZNyx.js +0 -4
  916. package/dist/ionic/p-BKc55Xev.js +0 -4
  917. package/dist/ionic/p-BOVrCkpJ.js +0 -4
  918. package/dist/ionic/p-BmVRXR1y.js +0 -4
  919. package/dist/ionic/p-Bmgaetn_.js +0 -4
  920. package/dist/ionic/p-C6F4hat2.js +0 -4
  921. package/dist/ionic/p-C7hRNDhM.js +0 -4
  922. package/dist/ionic/p-C8IsBmNU.js +0 -5
  923. package/dist/ionic/p-CIGNaXM1.js +0 -4
  924. package/dist/ionic/p-CTfR9YZG.js +0 -4
  925. package/dist/ionic/p-CtWGkNnJ.js +0 -4
  926. package/dist/ionic/p-D-eFFUkA.js +0 -4
  927. package/dist/ionic/p-DCv9sLH2.js +0 -4
  928. package/dist/ionic/p-DDb5r57F.js +0 -4
  929. package/dist/ionic/p-DJztqcrH.js +0 -4
  930. package/dist/ionic/p-DNcfiJwE.js +0 -4
  931. package/dist/ionic/p-DUt5fQmA.js +0 -4
  932. package/dist/ionic/p-DZRJwG4S.js +0 -4
  933. package/dist/ionic/p-QHYY4sjU.js +0 -4
  934. package/dist/ionic/p-ZjP4CjeZ.js +0 -4
  935. package/dist/ionic/p-a127bee2.entry.js +0 -4
  936. package/dist/ionic/p-a8ed848b.entry.js +0 -4
  937. package/dist/ionic/p-ac4eb91d.entry.js +0 -4
  938. package/dist/ionic/p-b0a7585c.entry.js +0 -4
  939. package/dist/ionic/p-b57c6d3e.entry.js +0 -4
  940. package/dist/ionic/p-c19f63d0.entry.js +0 -4
  941. package/dist/ionic/p-c85a2127.entry.js +0 -4
  942. package/dist/ionic/p-cc45bcbc.entry.js +0 -4
  943. package/dist/ionic/p-cebb0328.entry.js +0 -4
  944. package/dist/ionic/p-d0a2a1ab.entry.js +0 -4
  945. package/dist/ionic/p-d126e8d3.entry.js +0 -4
  946. package/dist/ionic/p-d1f54e28.entry.js +0 -4
  947. package/dist/ionic/p-d3014190.entry.js +0 -4
  948. package/dist/ionic/p-da7d04cc.entry.js +0 -4
  949. package/dist/ionic/p-dbbe606a.entry.js +0 -4
  950. package/dist/ionic/p-ea509e3c.entry.js +0 -4
  951. package/dist/ionic/p-ec654c42.entry.js +0 -4
  952. package/dist/ionic/p-f8f22cc0.entry.js +0 -4
  953. /package/dist/collection/components/{input-password-toggle/input-password-toggle.css → refresher-content/refresher-content.css} +0 -0
@@ -1 +1 @@
1
- {"version":3,"sourceRoot":"","sources":["../src/css/padding.scss","../src/themes/ionic.mixins.scss","../src/css/float-elements.scss","../src/css/text-alignment.scss","../src/css/text-transformation.scss","../src/css/flex-utils.scss","../src/css/display.scss"],"names":[],"mappings":"AAeA,gBACE,mBACA,iBACA,iBACA,oBCsTE,aDpTe,ECqTf,cDrTe,ECyUjB,YDzUiB,EC0UjB,eD1UiB,EAGnB,aACE,0CACA,wCACA,wCACA,2CCiTE,sBDpUM,yBCqUN,qBDrUM,yBCsUN,oBDtUM,yBCuUN,mBDvUM,yBCqVR,YDrVQ,yBCsVR,eDtVQ,yBAwBV,iBACE,wCC4TA,YDrVQ,yBA8BV,mBACE,0CCqSE,sBDpUM,yBCqUN,qBDrUM,yBAoCV,iBACE,wCCiSE,oBDtUM,yBCuUN,mBDvUM,yBA0CV,oBACE,2CC2SA,eDtVQ,yBAgDV,sBACE,wCACA,2CCmSA,YDrVQ,yBCsVR,eDtVQ,yBAuDV,wBACE,0CACA,wCC2QE,sBDpUM,yBCqUN,qBDrUM,yBCsUN,oBDtUM,yBCuUN,mBDvUM,yBAkEV,eACE,kBACA,gBACA,gBACA,mBC0PE,YDxPc,ECyPd,aDzPc,EC6QhB,WD7QgB,EC8QhB,cD9QgB,EAGlB,YACE,wCACA,sCACA,sCACA,yCCqPE,qBDnUK,wBCoUL,oBDpUK,wBCqUL,mBDrUK,wBCsUL,kBDtUK,wBCoVP,WDpVO,wBCqVP,cDrVO,wBAmFT,gBACE,sCCgQA,WDpVO,wBAyFT,kBACE,wCCyOE,qBDnUK,wBCoUL,oBDpUK,wBA+FT,gBACE,sCCqOE,mBDrUK,wBCsUL,kBDtUK,wBAqGT,mBACE,yCC+OA,cDrVO,wBA2GT,qBACE,sCACA,yCCuOA,WDpVO,wBCqVP,cDrVO,wBAkHT,uBACE,wCACA,sCC+ME,qBDnUK,wBCoUL,oBDpUK,wBCqUL,mBDrUK,wBCsUL,kBDtUK,wBEGL,gBD2dE,sBCvdF,iBDudE,uBCndF,iBDqcE,sBAzNO,0CA4NP,uBArNO,2BAqNP,uBA/MJ,8BAcW,0BAiMP,wBCpcF,eDwcE,uBAhOO,wCAmOP,sBA5NO,yBA4NP,sBAtNJ,8BAcW,wBAwMP,uBAnUF,yBCpJA,mBD2dE,sBCvdF,oBDudE,uBCndF,oBDqcE,sBAzNO,6CA4NP,uBArNO,8BAqNP,uBA/MJ,8BAcW,6BAiMP,wBCpcF,kBDwcE,uBAhOO,2CAmOP,sBA5NO,4BA4NP,sBAtNJ,8BAcW,2BAwMP,wBAnUF,yBCpJA,mBD2dE,sBCvdF,oBDudE,uBCndF,oBDqcE,sBAzNO,6CA4NP,uBArNO,8BAqNP,uBA/MJ,8BAcW,6BAiMP,wBCpcF,kBDwcE,uBAhOO,2CAmOP,sBA5NO,4BA4NP,sBAtNJ,8BAcW,2BAwMP,wBAnUF,yBCpJA,mBD2dE,sBCvdF,oBDudE,uBCndF,oBDqcE,sBAzNO,6CA4NP,uBArNO,8BAqNP,uBA/MJ,8BAcW,6BAiMP,wBCpcF,kBDwcE,uBAhOO,2CAmOP,sBA5NO,4BA4NP,sBAtNJ,8BAcW,2BAwMP,wBAnUF,0BCpJA,mBD2dE,sBCvdF,oBDudE,uBCndF,oBDqcE,sBAzNO,6CA4NP,uBArNO,8BAqNP,uBA/MJ,8BAcW,6BAiMP,wBCpcF,kBDwcE,uBAhOO,2CAmOP,sBA5NO,4BA4NP,sBAtNJ,8BAcW,2BAwMP,wBEvdF,iBACE,6BAGF,kBACE,8BAGF,gBACE,4BAGF,cACE,0BAGF,eACE,2BAGF,gBACE,4BAGF,iBACE,8BAGF,eACE,8BFuHF,yBEpJA,oBACE,6BAGF,qBACE,8BAGF,mBACE,4BAGF,iBACE,0BAGF,kBACE,2BAGF,mBACE,4BAGF,oBACE,8BAGF,kBACE,+BFuHF,yBEpJA,oBACE,6BAGF,qBACE,8BAGF,mBACE,4BAGF,iBACE,0BAGF,kBACE,2BAGF,mBACE,4BAGF,oBACE,8BAGF,kBACE,+BFuHF,yBEpJA,oBACE,6BAGF,qBACE,8BAGF,mBACE,4BAGF,iBACE,0BAGF,kBACE,2BAGF,mBACE,4BAGF,oBACE,8BAGF,kBACE,+BFuHF,0BEpJA,oBACE,6BAGF,qBACE,8BAGF,mBACE,4BAGF,iBACE,0BAGF,kBACE,2BAGF,mBACE,4BAGF,oBACE,8BAGF,kBACE,+BC7BF,oBAEE,oCAGF,oBAEE,oCAGF,qBAEE,qCHwIF,yBGpJA,uBAEE,oCAGF,uBAEE,oCAGF,wBAEE,sCHwIF,yBGpJA,uBAEE,oCAGF,uBAEE,oCAGF,wBAEE,sCHwIF,yBGpJA,uBAEE,oCAGF,uBAEE,oCAGF,wBAEE,sCHwIF,0BGpJA,uBAEE,oCAGF,uBAEE,oCAGF,wBAEE,sCCCA,yBACE,oCADF,uBACE,kCADF,0BACE,gCADF,2BACE,uCADF,0BACE,sCADF,2BACE,iCJsIJ,yBIvIE,4BACE,oCADF,0BACE,kCADF,6BACE,gCADF,8BACE,uCADF,6BACE,sCADF,8BACE,kCJsIJ,yBIvIE,4BACE,oCADF,0BACE,kCADF,6BACE,gCADF,8BACE,uCADF,6BACE,sCADF,8BACE,kCJsIJ,yBIvIE,4BACE,oCADF,0BACE,kCADF,6BACE,gCADF,8BACE,uCADF,6BACE,sCADF,8BACE,kCJsIJ,0BIvIE,4BACE,oCADF,0BACE,kCADF,6BACE,gCADF,8BACE,uCADF,6BACE,sCADF,8BACE,kCAqBF,uBACE,6BADF,qBACE,2BADF,wBACE,8BADF,yBACE,+BADF,0BACE,gCJgHJ,yBIjHE,0BACE,6BADF,wBACE,2BADF,2BACE,8BADF,4BACE,+BADF,6BACE,iCJgHJ,yBIjHE,0BACE,6BADF,wBACE,2BADF,2BACE,8BADF,4BACE,+BADF,6BACE,iCJgHJ,yBIjHE,0BACE,6BADF,wBACE,2BADF,2BACE,8BADF,4BACE,+BADF,6BACE,iCJgHJ,0BIjHE,0BACE,6BADF,wBACE,2BADF,2BACE,8BADF,4BACE,+BADF,6BACE,iCAsBF,sBACE,4BADF,oBACE,0BADF,uBACE,6BADF,wBACE,8BADF,yBACE,+BADF,qBACE,2BJyFJ,yBI1FE,yBACE,4BADF,uBACE,0BADF,0BACE,6BADF,2BACE,8BADF,4BACE,+BADF,wBACE,4BJyFJ,yBI1FE,yBACE,4BADF,uBACE,0BADF,0BACE,6BADF,2BACE,8BADF,4BACE,+BADF,wBACE,4BJyFJ,yBI1FE,yBACE,4BADF,uBACE,0BADF,0BACE,6BADF,2BACE,8BADF,4BACE,+BADF,wBACE,4BJyFJ,0BI1FE,yBACE,4BADF,uBACE,0BADF,0BACE,6BADF,2BACE,8BADF,4BACE,+BADF,wBACE,4BAsBF,2BACE,sCADF,yBACE,oCADF,4BACE,kCADF,6BACE,yCADF,4BACE,wCADF,4BACE,wCJkEJ,yBInEE,8BACE,sCADF,4BACE,oCADF,+BACE,kCADF,gCACE,yCADF,+BACE,wCADF,+BACE,yCJkEJ,yBInEE,8BACE,sCADF,4BACE,oCADF,+BACE,kCADF,gCACE,yCADF,+BACE,wCADF,+BACE,yCJkEJ,yBInEE,8BACE,sCADF,4BACE,oCADF,+BACE,kCADF,gCACE,yCADF,+BACE,wCADF,+BACE,yCJkEJ,0BInEE,8BACE,sCADF,4BACE,oCADF,+BACE,kCADF,gCACE,yCADF,+BACE,wCADF,+BACE,yCAoBF,cACE,8BADF,sBACE,sCADF,iBACE,iCADF,yBACE,yCJ6CJ,yBI9CE,iBACE,8BADF,yBACE,sCADF,oBACE,iCADF,4BACE,0CJ6CJ,yBI9CE,iBACE,8BADF,yBACE,sCADF,oBACE,iCADF,4BACE,0CJ6CJ,yBI9CE,iBACE,8BADF,yBACE,sCADF,oBACE,iCADF,4BACE,0CJ6CJ,0BI9CE,iBACE,8BADF,yBACE,sCADF,oBACE,iCADF,4BACE,0CAmBN,UACE,0BADF,YACE,4BADF,kBACE,kCAQE,eACE,0BADF,iBACE,4BADF,uBACE,kCJgBJ,yBIjBE,kBACE,0BADF,oBACE,4BADF,0BACE,mCJgBJ,yBIjBE,kBACE,0BADF,oBACE,4BADF,0BACE,mCJgBJ,yBIjBE,kBACE,0BADF,oBACE,4BADF,0BACE,mCJgBJ,0BIjBE,kBACE,0BADF,oBACE,4BADF,0BACE,mCAoBF,YACE,kBADF,eACE,qBADF,kBACE,wBADF,eACE,qBJLJ,yBIIE,eACE,kBADF,kBACE,qBADF,qBACE,wBADF,kBACE,sBJLJ,yBIIE,eACE,kBADF,kBACE,qBADF,qBACE,wBADF,kBACE,sBJLJ,yBIIE,eACE,kBADF,kBACE,qBADF,qBACE,wBADF,kBACE,sBJLJ,0BIIE,eACE,kBADF,kBACE,qBADF,qBACE,wBADF,kBACE,sBAYJ,iBACE,uBAGF,iBACE,uBAGF,mBACE,yBAGF,mBACE,yBJ9BF,yBIiBA,oBACE,uBAGF,oBACE,uBAGF,sBACE,yBAGF,sBACE,0BJ9BF,yBIiBA,oBACE,uBAGF,oBACE,uBAGF,sBACE,yBAGF,sBACE,0BJ9BF,yBIiBA,oBACE,uBAGF,oBACE,uBAGF,sBACE,yBAGF,sBACE,0BJ9BF,0BIiBA,oBACE,uBAGF,oBACE,uBAGF,sBACE,yBAGF,sBACE,0BAWF,qCAGE,saAGF,oCJ/CA,yBIyCA,wCAGE,6cAGF,wCJ/CA,yBIyCA,wCAGE,6cAGF,wCJ/CA,yBIyCA,wCAGE,6cAGF,wCJ/CA,0BIyCA,wCAGE,6cAGF,wCCpMJ,UACE,wBAUE,aACE,wBAOF,eACE,wBLiIF,yBK1IA,gBACE,yBLkLF,4BK3KA,kBACE,yBLiIF,yBK1IA,gBACE,yBLkLF,4BK3KA,kBACE,yBLiIF,yBK1IA,gBACE,yBLkLF,4BK3KA,kBACE,yBLiIF,0BK1IA,gBACE,yBLkLF,6BK3KA,kBACE,yBAwBA,kBACE,wBLwGJ,yBKzGE,qBACE,yBLwGJ,yBKzGE,qBACE,yBLwGJ,yBKzGE,qBACE,yBLwGJ,0BKzGE,qBACE,yBADF,oBACE,0BLwGJ,yBKzGE,uBACE,2BLwGJ,yBKzGE,uBACE,2BLwGJ,yBKzGE,uBACE,2BLwGJ,0BKzGE,uBACE,2BADF,0BACE,gCLwGJ,yBKzGE,6BACE,iCLwGJ,yBKzGE,6BACE,iCLwGJ,yBKzGE,6BACE,iCLwGJ,0BKzGE,6BACE,iCADF,mBACE,yBLwGJ,yBKzGE,sBACE,0BLwGJ,yBKzGE,sBACE,0BLwGJ,yBKzGE,sBACE,0BLwGJ,0BKzGE,sBACE,0BADF,kBACE,wBLwGJ,yBKzGE,qBACE,yBLwGJ,yBKzGE,qBACE,yBLwGJ,yBKzGE,qBACE,yBLwGJ,0BKzGE,qBACE,yBADF,yBACE,+BLwGJ,yBKzGE,4BACE,gCLwGJ,yBKzGE,4BACE,gCLwGJ,yBKzGE,4BACE,gCLwGJ,0BKzGE,4BACE,gCADF,kBACE,wBLwGJ,yBKzGE,qBACE,yBLwGJ,yBKzGE,qBACE,yBLwGJ,yBKzGE,qBACE,yBLwGJ,0BKzGE,qBACE,yBADF,yBACE,+BLwGJ,yBKzGE,4BACE,gCLwGJ,yBKzGE,4BACE,gCLwGJ,yBKzGE,4BACE,gCLwGJ,0BKzGE,4BACE,gCADF,mBACE,yBLwGJ,yBKzGE,sBACE,0BLwGJ,yBKzGE,sBACE,0BLwGJ,yBKzGE,sBACE,0BLwGJ,0BKzGE,sBACE,0BADF,wBACE,8BLwGJ,yBKzGE,2BACE,+BLwGJ,yBKzGE,2BACE,+BLwGJ,yBKzGE,2BACE,+BLwGJ,0BKzGE,2BACE,+BADF,uBACE,6BLwGJ,yBKzGE,0BACE,8BLwGJ,yBKzGE,0BACE,8BLwGJ,yBKzGE,0BACE,8BLwGJ,0BKzGE,0BACE","file":"utils.bundle.css","sourcesContent":["@import \"../themes/ionic.globals\";\n@import \"../themes/ionic.mixins\";\n\n\n// Element Space\n// --------------------------------------------------\n// Creates padding and margin attributes to be used on\n// any element\n\n$padding: var(--ion-padding, 16px);\n$margin: var(--ion-margin, 16px);\n\n// Padding\n// --------------------------------------------------\n\n.ion-no-padding {\n --padding-start: 0;\n --padding-end: 0;\n --padding-top: 0;\n --padding-bottom: 0;\n\n @include padding(0);\n}\n\n.ion-padding {\n --padding-start: #{$padding};\n --padding-end: #{$padding};\n --padding-top: #{$padding};\n --padding-bottom: #{$padding};\n\n @include padding($padding);\n}\n\n.ion-padding-top {\n --padding-top: #{$padding};\n\n @include padding($padding, null, null, null);\n}\n\n.ion-padding-start {\n --padding-start: #{$padding};\n\n @include padding-horizontal($padding, null);\n}\n\n.ion-padding-end {\n --padding-end: #{$padding};\n\n @include padding-horizontal(null, $padding);\n}\n\n.ion-padding-bottom {\n --padding-bottom: #{$padding};\n\n @include padding(null, null, $padding, null);\n}\n\n.ion-padding-vertical {\n --padding-top: #{$padding};\n --padding-bottom: #{$padding};\n\n @include padding($padding, null, $padding, null);\n}\n\n.ion-padding-horizontal {\n --padding-start: #{$padding};\n --padding-end: #{$padding};\n\n @include padding-horizontal($padding);\n}\n\n\n// Margin\n// --------------------------------------------------\n\n.ion-no-margin {\n --margin-start: 0;\n --margin-end: 0;\n --margin-top: 0;\n --margin-bottom: 0;\n\n @include margin(0);\n}\n\n.ion-margin {\n --margin-start: #{$margin};\n --margin-end: #{$margin};\n --margin-top: #{$margin};\n --margin-bottom: #{$margin};\n\n @include margin($margin);\n}\n\n.ion-margin-top {\n --margin-top: #{$margin};\n\n @include margin($margin, null, null, null);\n}\n\n.ion-margin-start {\n --margin-start: #{$margin};\n\n @include margin-horizontal($margin, null);\n}\n\n.ion-margin-end {\n --margin-end: #{$margin};\n\n @include margin-horizontal(null, $margin);\n}\n\n.ion-margin-bottom {\n --margin-bottom: #{$margin};\n\n @include margin(null, null, $margin, null);\n}\n\n.ion-margin-vertical {\n --margin-top: #{$margin};\n --margin-bottom: #{$margin};\n\n @include margin($margin, null, $margin, null);\n}\n\n.ion-margin-horizontal {\n --margin-start: #{$margin};\n --margin-end: #{$margin};\n\n @include margin-horizontal($margin);\n}\n","\n/**\n * A heuristic that applies CSS to tablet\n * viewports.\n *\n * Usage:\n * @include tablet-viewport() {\n * :host {\n * background-color: green;\n * }\n * }\n */\n@mixin tablet-viewport() {\n @media screen and (min-width: 768px) {\n @content;\n }\n}\n\n/**\n * A heuristic that applies CSS to mobile\n * viewports (i.e. phones, not tablets).\n *\n * Usage:\n * @include mobile-viewport() {\n * :host {\n * background-color: blue;\n * }\n * }\n */\n@mixin mobile-viewport() {\n @media screen and (max-width: 767px) {\n @content;\n }\n}\n\n@mixin input-cover() {\n @include position(0, null, null, 0);\n @include margin(0);\n\n position: absolute;\n\n width: 100%;\n height: 100%;\n\n border: 0;\n background: transparent;\n cursor: pointer;\n\n appearance: none;\n outline: none;\n\n &::-moz-focus-inner {\n border: 0;\n }\n}\n\n@mixin visually-hidden() {\n position: absolute;\n\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n\n width: 100%;\n height: 100%;\n\n margin: 0;\n padding: 0;\n\n border: 0;\n outline: 0;\n clip: rect(0 0 0 0);\n\n opacity: 0;\n overflow: hidden;\n\n -webkit-appearance: none;\n -moz-appearance: none;\n}\n\n@mixin text-inherit() {\n font-family: inherit;\n font-size: inherit;\n font-style: inherit;\n font-weight: inherit;\n letter-spacing: inherit;\n text-decoration: inherit;\n text-indent: inherit;\n text-overflow: inherit;\n text-transform: inherit;\n text-align: inherit;\n white-space: inherit;\n color: inherit;\n}\n\n@mixin button-state() {\n @include position(0, 0, 0, 0);\n\n position: absolute;\n\n content: \"\";\n\n opacity: 0;\n}\n\n// Font smoothing\n// --------------------------------------------------\n\n@mixin font-smoothing() {\n -moz-osx-font-smoothing: grayscale;\n -webkit-font-smoothing: antialiased;\n}\n\n// Get the key from a map based on the index\n@function index-to-key($map, $index) {\n $keys: map-keys($map);\n\n @return nth($keys, $index);\n}\n\n\n// Breakpoint Mixins\n// ---------------------------------------------------------------------------------\n\n// Breakpoint viewport sizes and media queries.\n//\n// Breakpoints are defined as a map of (name: minimum width), order from small to large:\n//\n// (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px)\n//\n// The map defined in the `$screen-breakpoints` global variable is used as the `$breakpoints` argument by default.\n\n// ---------------------------------------------------------------------------------\n\n// Minimum breakpoint width. Null for the smallest (first) breakpoint.\n//\n// >> breakpoint-min(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n// 576px\n@function breakpoint-min($name, $breakpoints: $screen-breakpoints) {\n $min: map-get($breakpoints, $name);\n\n @return if($name != index-to-key($breakpoints, 1), $min, null);\n}\n\n// Returns a blank string if smallest breakpoint, otherwise returns the name with a dash infront.\n// Useful for making responsive utilities.\n//\n// >> breakpoint-infix(xs, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n// \"\" (Returns a blank string)\n// >> breakpoint-infix(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n// \"-sm\"\n@function breakpoint-infix($name, $breakpoints: $screen-breakpoints) {\n @return if(breakpoint-min($name, $breakpoints) == null, \"\", \"-#{$name}\");\n}\n\n// Media of at least the minimum breakpoint width. No query for the smallest breakpoint.\n// Makes the @content apply to the given breakpoint and wider.\n@mixin media-breakpoint-up($name, $breakpoints: $screen-breakpoints) {\n $min: breakpoint-min($name, $breakpoints);\n @if $min {\n @media (min-width: $min) {\n @content;\n }\n } @else {\n @content;\n }\n}\n\n// Name of the next breakpoint, or null for the last breakpoint.\n//\n// >> breakpoint-next(sm)\n// md\n// >> breakpoint-next(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n// md\n// >> breakpoint-next(sm, $breakpoint-names: (xs sm md lg xl))\n// md\n@function breakpoint-next($name, $breakpoints: $screen-breakpoints, $breakpoint-names: map-keys($breakpoints)) {\n $n: index($breakpoint-names, $name);\n @return if($n < length($breakpoint-names), nth($breakpoint-names, $n + 1), null);\n}\n\n// Maximum breakpoint width. Null for the smallest (first) breakpoint.\n// The maximum value is reduced by 0.02px to work around the limitations of\n// `min-` and `max-` prefixes and viewports with fractional widths.\n//\n// See https://www.w3.org/TR/mediaqueries-4/#mq-min-max\n// Uses 0.02px rather than 0.01px to work around a current rounding bug in Safari.\t// Uses 0.02px rather than 0.01px to work around a current rounding bug in Safari.\n// See https://bugs.webkit.org/show_bug.cgi?id=178261\t// See https://bugs.webkit.org/show_bug.cgi?id=178261\n//\n// >> breakpoint-max(md, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n// 767.98px\n@function breakpoint-max($name, $breakpoints: $screen-breakpoints) {\n $max: map-get($breakpoints, $name);\n @return if($max and $max > 0, $max - .02, null);\n}\n\n// Media of at most the maximum breakpoint width. No query for the largest breakpoint.\n// Makes the @content apply to the given breakpoint and narrower.\n@mixin media-breakpoint-down($name, $breakpoints: $screen-breakpoints) {\n $max: breakpoint-max($name, $breakpoints);\n @if $max {\n @media (max-width: $max) {\n @content;\n }\n } @else {\n @content;\n }\n}\n\n\n// Text Direction - ltr / rtl\n//\n// CSS defaults to use the ltr css, and adds [dir=rtl] selectors\n// to override ltr defaults.\n// ----------------------------------------------------------\n\n@mixin multi-dir() {\n @content;\n\n // $root: #{&};\n // @at-root [dir] {\n // #{$root} {\n // @content;\n // }\n // }\n}\n\n@mixin rtl() {\n $root: #{&};\n\n $rootSplit: str-split($root, \",\");\n $selectors: #{add-root-selector($root, \"[dir=rtl]\")};\n $selectorsSplit: str-split($selectors, \",\");\n\n $hostContextSelectors: ();\n $restSelectors: ();\n $dirSelectors: ();\n\n // Selectors must be split into individual selectors in case the browser\n // doesn't support a specific selector.\n // For example, Firefox and Safari doesn't support `:host-context()`.\n // If an invalid selector is used, then the entire group of selectors\n // will be ignored.\n // @link https://www.w3.org/TR/selectors-3/#grouping\n @each $selector in $selectorsSplit {\n // Group the selectors back into a single selector to optimize the output.\n @if str-index($selector, \":host-context\") {\n $hostContextSelectors: append($hostContextSelectors, $selector, comma);\n } @else {\n // Group the selectors back into a single selector to optimize the output.\n $restSelectors: append($restSelectors, $selector, comma);\n }\n }\n\n // Supported by Chrome.\n @if length($hostContextSelectors) > 0 {\n @at-root #{$hostContextSelectors} {\n @content;\n }\n }\n\n // Supported by all browsers.\n @if length($restSelectors) > 0 {\n @at-root #{$restSelectors} {\n @content;\n }\n }\n\n // If browser can support `:dir()`, then add the `:dir()` selectors.\n @supports selector(:dir(rtl)) {\n // Adding :dir() in case the browser doesn't support `:host-context()` and does support `:dir()`.\n // `:host-context()` is added:\n // - through the `add-root-selector()` function.\n // - first so that it takes precedence over `:dir()`.\n // For example,\n // - Firefox doesn't support `:host-context()`, but does support `:dir()`.\n // - Safari doesn't support `:host-context()`, but Safari 16.4+ supports `:dir()`\n // @link https://webkit.org/blog/13966/webkit-features-in-safari-16-4/\n // -- However, there is a Webkit bug on v16 that prevents `:dir()` from working when\n // -- the app direction is changed dynamically. v17+ works fine.\n // -- @link https://bugs.webkit.org/show_bug.cgi?id=257133\n\n // Supported by Firefox.\n @at-root #{add-root-selector($root, \":dir(rtl)\", false)} {\n @content;\n }\n }\n}\n\n@mixin ltr() {\n @content;\n}\n\n\n// SVG Background Image Mixin\n// @param {string} $svg\n// ----------------------------------------------------------\n@mixin svg-background-image($svg, $flip-rtl: false) {\n $url: url-encode($svg);\n $viewBox: str-split(str-extract($svg, \"viewBox='\", \"'\"), \" \");\n\n @if $flip-rtl != true or $viewBox == null {\n @include multi-dir() {\n background-image: url(\"data:image/svg+xml;charset=utf-8,#{$url}\");\n }\n } @else {\n $transform: \"transform='translate(#{nth($viewBox, 3)}, 0) scale(-1, 1)'\";\n $flipped-url: $svg;\n $flipped-url: str-replace($flipped-url, \"<path\", \"<path #{$transform}\");\n $flipped-url: str-replace($flipped-url, \"<line\", \"<line #{$transform}\");\n $flipped-url: str-replace($flipped-url, \"<polygon\", \"<polygon #{$transform}\");\n $flipped-url: url-encode($flipped-url);\n\n @include ltr () {\n background-image: url(\"data:image/svg+xml;charset=utf-8,#{$url}\");\n }\n @include rtl() {\n background-image: url(\"data:image/svg+xml;charset=utf-8,#{$flipped-url}\");\n }\n }\n}\n\n// Add property horizontal\n// @param {string} $start\n// @param {string} $end\n// ----------------------------------------------------------\n@mixin property-horizontal($prop, $start, $end: $start) {\n @if $start == 0 and $end == 0 {\n #{$prop}-left: $start;\n #{$prop}-right: $end;\n\n } @else {\n -webkit-#{$prop}-start: $start;\n #{$prop}-inline-start: $start;\n -webkit-#{$prop}-end: $end;\n #{$prop}-inline-end: $end;\n }\n}\n\n// Add property for all directions\n// @param {string} $prop\n// @param {string} $top\n// @param {string} $end\n// @param {string} $bottom\n// @param {string} $start\n// @param {boolean} $content include content or use default\n// ----------------------------------------------------------\n@mixin property($prop, $top, $end: $top, $bottom: $top, $start: $end) {\n @include property-horizontal($prop, $start, $end);\n #{$prop}-top: $top;\n #{$prop}-bottom: $bottom;\n}\n\n// Add padding horizontal\n// @param {string} $start\n// @param {string} $end\n// ----------------------------------------------------------\n@mixin padding-horizontal($start, $end: $start) {\n @include property-horizontal(padding, $start, $end);\n}\n\n// Add padding for all directions\n// @param {string} $top\n// @param {string} $end\n// @param {string} $bottom\n// @param {string} $start\n// ----------------------------------------------------------\n@mixin padding($top, $end: $top, $bottom: $top, $start: $end) {\n @include property(padding, $top, $end, $bottom, $start);\n}\n\n// Add margin horizontal\n// @param {string} $start\n// @param {string} $end\n// ----------------------------------------------------------\n@mixin margin-horizontal($start, $end: $start) {\n @include property-horizontal(margin, $start, $end);\n}\n\n// Add margin for all directions\n// @param {string} $top\n// @param {string} $end\n// @param {string} $bottom\n// @param {string} $start\n// ----------------------------------------------------------\n@mixin margin($top, $end: $top, $bottom: $top, $start: $end) {\n @include property(margin, $top, $end, $bottom, $start);\n}\n\n// Add position horizontal\n// @param {string} $start - amount to position start\n// @param {string} $end - amount to left: 0; end\n// ----------------------------------------------------------\n@mixin position-horizontal($start: null, $end: null) {\n @if $start == $end {\n @include multi-dir() {\n left: $start;\n right: $end;\n }\n } @else {\n @at-root {\n & {\n inset-inline-start: $start;\n inset-inline-end: $end;\n }\n }\n }\n}\n\n// Add position for all directions\n// @param {string} $top\n// @param {string} $end\n// @param {string} $bottom\n// @param {string} $start\n// ----------------------------------------------------------\n@mixin position($top: null, $end: null, $bottom: null, $start: null) {\n @include position-horizontal($start, $end);\n top: $top;\n bottom: $bottom;\n}\n\n// Add border for all directions\n// @param {string} $top\n// @param {string} $end\n// @param {string} $bottom\n// @param {string} $start\n// ----------------------------------------------------------\n@mixin border($top, $end: $top, $bottom: $top, $start: $end) {\n @include property(border, $top, $end, $bottom, $start);\n}\n\n// Add border radius for all directions\n// @param {string} $top-start\n// @param {string} $top-end\n// @param {string} $bottom-end\n// @param {string} $bottom-start\n// ----------------------------------------------------------\n@mixin border-radius($top-start, $top-end: $top-start, $bottom-end: $top-start, $bottom-start: $top-end) {\n @if $top-start == $top-end and $top-start == $bottom-end and $top-start == $bottom-start {\n border-radius: $top-start;\n } @else {\n border-start-start-radius: $top-start;\n border-start-end-radius: $top-end;\n border-end-end-radius: $bottom-end;\n border-end-start-radius: $bottom-start;\n }\n}\n\n// Add direction for all directions\n// @param {string} $dir - Direction on LTR\n@mixin direction($dir) {\n $other-dir: null;\n\n @if $dir == ltr {\n $other-dir: rtl;\n } @else {\n $other-dir: ltr;\n }\n\n @include ltr() {\n direction: $dir;\n }\n @include rtl() {\n direction: $other-dir;\n }\n}\n\n// Add float for all directions\n// @param {string} $side\n// @param {string} $decorator - !important\n@mixin float($side, $decorator: null) {\n @if $side == start {\n @include ltr() {\n float: left $decorator;\n }\n @include rtl() {\n float: right $decorator;\n }\n } @else if $side == end {\n @include ltr() {\n float: right $decorator;\n }\n @include rtl() {\n float: left $decorator;\n }\n } @else {\n @include multi-dir() {\n float: $side $decorator;\n }\n }\n}\n\n@mixin background-position($horizontal, $horizontal-amount: null, $vertical: null, $vertical-amount: null) {\n @if $horizontal == start or $horizontal == end {\n $horizontal-ltr: null;\n $horizontal-rtl: null;\n @if $horizontal == start {\n $horizontal-ltr: left;\n $horizontal-rtl: right;\n } @else {\n $horizontal-ltr: right;\n $horizontal-rtl: left;\n }\n\n @include ltr() {\n background-position: $horizontal-ltr $horizontal-amount $vertical $vertical-amount;\n }\n @include rtl() {\n background-position: $horizontal-rtl $horizontal-amount $vertical $vertical-amount;\n }\n } @else {\n @include multi-dir() {\n background-position: $horizontal $horizontal-amount $vertical $vertical-amount;\n }\n }\n}\n\n@mixin transform-origin($x-axis, $y-axis: null) {\n @if $x-axis == start {\n @include ltr() {\n transform-origin: left $y-axis;\n }\n @include rtl() {\n transform-origin: right $y-axis;\n }\n } @else if $x-axis == end {\n @include ltr() {\n transform-origin: right $y-axis;\n }\n @include rtl() {\n transform-origin: left $y-axis;\n }\n } @else if $x-axis == left or $x-axis == right {\n @include multi-dir() {\n transform-origin: $x-axis $y-axis;\n }\n } @else {\n @include ltr() {\n transform-origin: $x-axis $y-axis;\n }\n @include rtl() {\n transform-origin: calc(100% - #{$x-axis}) $y-axis;\n }\n }\n}\n\n// Add transform for all directions\n// @param {string} $transforms - comma separated list of transforms\n@mixin transform($transforms...) {\n $extra: null;\n\n $x: null;\n $ltr-translate: null;\n $rtl-translate: null;\n\n @each $transform in $transforms {\n @if (str-index($transform, translate3d)) {\n $transform: str-replace($transform, 'translate3d(');\n $transform: str-replace($transform, ')');\n\n $coordinates: str-split($transform, ',');\n\n $x: nth($coordinates, 1);\n $y: nth($coordinates, 2);\n $z: nth($coordinates, 3);\n\n $ltr-translate: translate3d($x, $y, $z);\n $rtl-translate: translate3d(calc(-1 * #{$x}), $y, $z);\n } @else {\n @if $extra == null {\n $extra: $transform;\n } @else {\n $extra: $extra $transform;\n }\n }\n }\n\n @if $x == '0' or $x == null {\n @include multi-dir() {\n transform: $ltr-translate $extra;\n }\n } @else {\n @include ltr() {\n transform: $ltr-translate $extra;\n }\n\n @include rtl() {\n transform: $rtl-translate $extra;\n }\n }\n}\n","@import \"../themes/ionic.globals\";\n@import \"../themes/ionic.mixins\";\n\n// Float Elements\n// --------------------------------------------------\n// Creates float classes based on screen size\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n // Provide `.ion-float-{bp}-{side}` classes for floating the element based\n // on the breakpoint and side\n .ion-float#{$infix}-left {\n @include float(left, !important);\n }\n\n .ion-float#{$infix}-right {\n @include float(right, !important);\n }\n\n .ion-float#{$infix}-start {\n @include float(start, !important);\n }\n\n .ion-float#{$infix}-end {\n @include float(end, !important);\n }\n }\n}\n","@import \"../themes/ionic.globals\";\n@import \"../themes/ionic.mixins\";\n\n// Text Alignment\n// --------------------------------------------------\n// Creates text alignment attributes based on screen size\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n // Provide `.ion-text-{bp}` classes for aligning the text based\n // on the breakpoint\n .ion-text#{$infix}-center {\n text-align: center !important;\n }\n\n .ion-text#{$infix}-justify {\n text-align: justify !important;\n }\n\n .ion-text#{$infix}-start {\n text-align: start !important;\n }\n\n .ion-text#{$infix}-end {\n text-align: end !important;\n }\n\n .ion-text#{$infix}-left {\n text-align: left !important;\n }\n\n .ion-text#{$infix}-right {\n text-align: right !important;\n }\n\n .ion-text#{$infix}-nowrap {\n white-space: nowrap !important;\n }\n\n .ion-text#{$infix}-wrap {\n white-space: normal !important;\n }\n }\n}\n","@import \"../themes/ionic.globals\";\n@import \"../themes/ionic.mixins\";\n\n// Text Transformation\n// --------------------------------------------------\n// Creates text transform attributes based on screen size\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n // Provide `.ion-text-{bp}` classes for transforming the text based\n // on the breakpoint\n .ion-text#{$infix}-uppercase {\n /* stylelint-disable-next-line declaration-no-important */\n text-transform: uppercase !important;\n }\n\n .ion-text#{$infix}-lowercase {\n /* stylelint-disable-next-line declaration-no-important */\n text-transform: lowercase !important;\n }\n\n .ion-text#{$infix}-capitalize {\n /* stylelint-disable-next-line declaration-no-important */\n text-transform: capitalize !important;\n }\n }\n}\n","@import \"../themes/ionic.globals\";\n@import \"../themes/ionic.mixins\";\n\n// Flex Utilities\n// ------------------------------------------------------------------\n// Provides utility classes to control flexbox layout, alignment,\n// and sizing of elements. Includes responsive variants for managing\n// flex direction, alignment, justification, wrapping, growth,\n// shrinking, and ordering at different breakpoints.\n\n// Align Content\n// ------------------------------------------------------------------\n\n$align-content-values: (\n start: flex-start,\n end: flex-end,\n center: center,\n between: space-between,\n around: space-around,\n stretch: stretch\n);\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n @each $key, $value in $align-content-values {\n .ion-align-content#{$infix}-#{$key} {\n align-content: #{$value} !important;\n }\n }\n }\n}\n\n// Align Items\n// ------------------------------------------------------------------\n\n$align-items-values: (\n start,\n end,\n center,\n stretch,\n baseline\n);\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n @each $value in $align-items-values {\n .ion-align-items#{$infix}-#{$value} {\n align-items: #{$value} !important;\n }\n }\n }\n}\n\n// Align Self\n// ------------------------------------------------------------------\n\n$align-self-values: (\n start,\n end,\n center,\n stretch,\n baseline,\n auto\n);\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n @each $value in $align-self-values {\n .ion-align-self#{$infix}-#{$value} {\n align-self: #{$value} !important;\n }\n }\n }\n}\n\n// Justify Content\n// ------------------------------------------------------------------\n\n$justify-content-values: (\n start: flex-start,\n end: flex-end,\n center: center,\n between: space-between,\n around: space-around,\n evenly: space-evenly\n);\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n @each $key, $value in $justify-content-values {\n .ion-justify-content#{$infix}-#{$key} {\n justify-content: #{$value} !important;\n }\n }\n }\n}\n\n// Flex Direction\n// ------------------------------------------------------------------\n\n$flex-direction-values: (\n row,\n row-reverse,\n column,\n column-reverse\n);\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n @each $value in $flex-direction-values {\n .ion-flex#{$infix}-#{$value} {\n flex-direction: #{$value} !important;\n }\n }\n }\n}\n\n// Flex Wrap\n// ------------------------------------------------------------------\n\n$flex-wrap-values: (\n wrap,\n nowrap,\n wrap-reverse\n);\n\n@each $value in $flex-wrap-values {\n // TODO(FW-6697): remove ion-wrap, ion-nowrap, ion-wrap-reverse\n // in favor of the new ion-flex-wrap, ion-flex-nowrap, and\n // ion-flex-wrap-reverse classes\n .ion-#{$value} {\n flex-wrap: #{$value} !important;\n }\n}\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n @each $value in $flex-wrap-values {\n .ion-flex#{$infix}-#{$value} {\n flex-wrap: #{$value} !important;\n }\n }\n }\n}\n\n// Flex Fill\n// ------------------------------------------------------------------\n\n$flex-fill-values: (\n 1,\n auto,\n initial,\n none\n);\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n @each $value in $flex-fill-values {\n .ion-flex#{$infix}-#{$value} {\n flex: #{$value} !important;\n }\n }\n }\n}\n\n// Flex Grow and Shrink\n// ------------------------------------------------------------------\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n .ion-flex#{$infix}-grow-0 {\n flex-grow: 0 !important;\n }\n\n .ion-flex#{$infix}-grow-1 {\n flex-grow: 1 !important;\n }\n\n .ion-flex#{$infix}-shrink-0 {\n flex-shrink: 0 !important;\n }\n\n .ion-flex#{$infix}-shrink-1 {\n flex-shrink: 1 !important;\n }\n }\n}\n\n// Flex Order\n// ------------------------------------------------------------------\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n .ion-order#{$infix}-first { order: -1 !important; }\n\n @for $i from 0 through 12 {\n .ion-order#{$infix}-#{$i} { order: #{$i} !important; }\n }\n\n .ion-order#{$infix}-last { order: 13 !important; }\n }\n}\n","@import \"../themes/ionic.globals\";\n@import \"../themes/ionic.mixins\";\n\n// Display\n// ------------------------------------------------------------------\n// Provides utility classes to control the CSS display property\n// of elements. Includes responsive variants for toggling between\n// block, inline, flex, grid, and other display values at different\n// breakpoints.\n\n// TODO(FW-6697): remove ion-hide-* classes in favor of the new\n// ion-display-* classes\n.ion-hide {\n display: none !important;\n}\n\n// Adds hidden classes\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n // Provide `ion-hide-{bp}-up` classes for hiding the element based\n // on the breakpoint\n .ion-hide#{$infix}-up {\n display: none !important;\n }\n }\n\n @include media-breakpoint-down($breakpoint, $screen-breakpoints) {\n // Provide `ion-hide-{bp}-down` classes for hiding the element based\n // on the breakpoint\n .ion-hide#{$infix}-down {\n display: none !important;\n }\n }\n}\n\n$display-values: (\n none,\n inline,\n inline-block,\n block,\n flex,\n inline-flex,\n grid,\n inline-grid,\n table,\n table-cell,\n table-row\n);\n\n@each $display in $display-values {\n @each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n .ion-display#{$infix}-#{$display} {\n display: #{$display} !important;\n }\n }\n }\n}\n"]}
1
+ {"version":3,"sourceRoot":"","sources":["../src/css/padding.scss","../src/themes/mixins.scss","../src/css/float-elements.scss","../src/css/text-alignment.scss","../src/css/text-transformation.scss","../src/css/flex-utils.scss","../src/css/display.scss"],"names":[],"mappings":"AAcA,gBACE,mBACA,iBACA,iBACA,oBCmUE,aDjUe,ECkUf,cDlUe,ECqVjB,YDrViB,ECsVjB,eDtViB,EAGnB,aACE,0CACA,wCACA,wCACA,2CC6TE,sBDhVM,yBCiVN,qBDjVM,yBCkVN,oBDlVM,yBCmVN,mBDnVM,yBCiWR,YDjWQ,yBCkWR,eDlWQ,yBAwBV,iBACE,wCCwUA,YDjWQ,yBA8BV,mBACE,0CCiTE,sBDhVM,yBCiVN,qBDjVM,yBAoCV,iBACE,wCC6SE,oBDlVM,yBCmVN,mBDnVM,yBA0CV,oBACE,2CCuTA,eDlWQ,yBAgDV,sBACE,wCACA,2CC+SA,YDjWQ,yBCkWR,eDlWQ,yBAuDV,wBACE,0CACA,wCCuRE,sBDhVM,yBCiVN,qBDjVM,yBCkVN,oBDlVM,yBCmVN,mBDnVM,yBAiEV,eACE,kBACA,gBACA,gBACA,mBCwQE,YDtQc,ECuQd,aDvQc,EC0RhB,WD1RgB,EC2RhB,cD3RgB,EAGlB,YACE,wCACA,sCACA,sCACA,yCCkQE,qBD/UK,wBCgVL,oBDhVK,wBCiVL,mBDjVK,wBCkVL,kBDlVK,wBCgWP,WDhWO,wBCiWP,cDjWO,wBAkFT,gBACE,sCC6QA,WDhWO,wBAwFT,kBACE,wCCsPE,qBD/UK,wBCgVL,oBDhVK,wBA8FT,gBACE,sCCkPE,mBDjVK,wBCkVL,kBDlVK,wBAoGT,mBACE,yCC4PA,cDjWO,wBA0GT,qBACE,sCACA,yCCoPA,WDhWO,wBCiWP,cDjWO,wBAiHT,uBACE,wCACA,sCC4NE,qBD/UK,wBCgVL,oBDhVK,wBCiVL,mBDjVK,wBCkVL,kBDlVK,wBEIL,gBDyeE,sBCreF,iBDqeE,uBCjeF,iBDidE,sBAzNO,0CA6NP,uBAtNO,2BAsNP,uBAhNJ,8BAcW,0BAkMP,wBCjdF,eDqdE,uBAjOO,wCAqOP,sBA9NO,yBA8NP,sBAxNJ,8BAcW,wBA0MP,uBAvUF,yBC9JA,mBDyeE,sBCreF,oBDqeE,uBCjeF,oBDidE,sBAzNO,6CA6NP,uBAtNO,8BAsNP,uBAhNJ,8BAcW,6BAkMP,wBCjdF,kBDqdE,uBAjOO,2CAqOP,sBA9NO,4BA8NP,sBAxNJ,8BAcW,2BA0MP,wBAvUF,yBC9JA,mBDyeE,sBCreF,oBDqeE,uBCjeF,oBDidE,sBAzNO,6CA6NP,uBAtNO,8BAsNP,uBAhNJ,8BAcW,6BAkMP,wBCjdF,kBDqdE,uBAjOO,2CAqOP,sBA9NO,4BA8NP,sBAxNJ,8BAcW,2BA0MP,wBAvUF,yBC9JA,mBDyeE,sBCreF,oBDqeE,uBCjeF,oBDidE,sBAzNO,6CA6NP,uBAtNO,8BAsNP,uBAhNJ,8BAcW,6BAkMP,wBCjdF,kBDqdE,uBAjOO,2CAqOP,sBA9NO,4BA8NP,sBAxNJ,8BAcW,2BA0MP,wBAvUF,0BC9JA,mBDyeE,sBCreF,oBDqeE,uBCjeF,oBDidE,sBAzNO,6CA6NP,uBAtNO,8BAsNP,uBAhNJ,8BAcW,6BAkMP,wBCjdF,kBDqdE,uBAjOO,2CAqOP,sBA9NO,4BA8NP,sBAxNJ,8BAcW,2BA0MP,wBEreF,iBACE,6BAGF,kBACE,8BAGF,gBACE,4BAGF,cACE,0BAGF,eACE,2BAGF,gBACE,4BAGF,iBACE,8BAGF,eACE,8BFiIF,yBE9JA,oBACE,6BAGF,qBACE,8BAGF,mBACE,4BAGF,iBACE,0BAGF,kBACE,2BAGF,mBACE,4BAGF,oBACE,8BAGF,kBACE,+BFiIF,yBE9JA,oBACE,6BAGF,qBACE,8BAGF,mBACE,4BAGF,iBACE,0BAGF,kBACE,2BAGF,mBACE,4BAGF,oBACE,8BAGF,kBACE,+BFiIF,yBE9JA,oBACE,6BAGF,qBACE,8BAGF,mBACE,4BAGF,iBACE,0BAGF,kBACE,2BAGF,mBACE,4BAGF,oBACE,8BAGF,kBACE,+BFiIF,0BE9JA,oBACE,6BAGF,qBACE,8BAGF,mBACE,4BAGF,iBACE,0BAGF,kBACE,2BAGF,mBACE,4BAGF,oBACE,8BAGF,kBACE,+BC7BF,oBAEE,oCAGF,oBAEE,oCAGF,qBAEE,qCHkJF,yBG9JA,uBAEE,oCAGF,uBAEE,oCAGF,wBAEE,sCHkJF,yBG9JA,uBAEE,oCAGF,uBAEE,oCAGF,wBAEE,sCHkJF,yBG9JA,uBAEE,oCAGF,uBAEE,oCAGF,wBAEE,sCHkJF,0BG9JA,uBAEE,oCAGF,uBAEE,oCAGF,wBAEE,sCCCA,yBACE,oCADF,uBACE,kCADF,0BACE,gCADF,2BACE,uCADF,0BACE,sCADF,2BACE,iCJgJJ,yBIjJE,4BACE,oCADF,0BACE,kCADF,6BACE,gCADF,8BACE,uCADF,6BACE,sCADF,8BACE,kCJgJJ,yBIjJE,4BACE,oCADF,0BACE,kCADF,6BACE,gCADF,8BACE,uCADF,6BACE,sCADF,8BACE,kCJgJJ,yBIjJE,4BACE,oCADF,0BACE,kCADF,6BACE,gCADF,8BACE,uCADF,6BACE,sCADF,8BACE,kCJgJJ,0BIjJE,4BACE,oCADF,0BACE,kCADF,6BACE,gCADF,8BACE,uCADF,6BACE,sCADF,8BACE,kCAeF,uBACE,6BADF,qBACE,2BADF,wBACE,8BADF,yBACE,+BADF,0BACE,gCJgIJ,yBIjIE,0BACE,6BADF,wBACE,2BADF,2BACE,8BADF,4BACE,+BADF,6BACE,iCJgIJ,yBIjIE,0BACE,6BADF,wBACE,2BADF,2BACE,8BADF,4BACE,+BADF,6BACE,iCJgIJ,yBIjIE,0BACE,6BADF,wBACE,2BADF,2BACE,8BADF,4BACE,+BADF,6BACE,iCJgIJ,0BIjIE,0BACE,6BADF,wBACE,2BADF,2BACE,8BADF,4BACE,+BADF,6BACE,iCAeF,sBACE,4BADF,oBACE,0BADF,uBACE,6BADF,wBACE,8BADF,yBACE,+BADF,qBACE,2BJgHJ,yBIjHE,yBACE,4BADF,uBACE,0BADF,0BACE,6BADF,2BACE,8BADF,4BACE,+BADF,wBACE,4BJgHJ,yBIjHE,yBACE,4BADF,uBACE,0BADF,0BACE,6BADF,2BACE,8BADF,4BACE,+BADF,wBACE,4BJgHJ,yBIjHE,yBACE,4BADF,uBACE,0BADF,0BACE,6BADF,2BACE,8BADF,4BACE,+BADF,wBACE,4BJgHJ,0BIjHE,yBACE,4BADF,uBACE,0BADF,0BACE,6BADF,2BACE,8BADF,4BACE,+BADF,wBACE,4BAsBF,2BACE,sCADF,yBACE,oCADF,4BACE,kCADF,6BACE,yCADF,4BACE,wCADF,4BACE,wCJyFJ,yBI1FE,8BACE,sCADF,4BACE,oCADF,+BACE,kCADF,gCACE,yCADF,+BACE,wCADF,+BACE,yCJyFJ,yBI1FE,8BACE,sCADF,4BACE,oCADF,+BACE,kCADF,gCACE,yCADF,+BACE,wCADF,+BACE,yCJyFJ,yBI1FE,8BACE,sCADF,4BACE,oCADF,+BACE,kCADF,gCACE,yCADF,+BACE,wCADF,+BACE,yCJyFJ,0BI1FE,8BACE,sCADF,4BACE,oCADF,+BACE,kCADF,gCACE,yCADF,+BACE,wCADF,+BACE,yCAeF,cACE,8BADF,sBACE,sCADF,iBACE,iCADF,yBACE,yCJyEJ,yBI1EE,iBACE,8BADF,yBACE,sCADF,oBACE,iCADF,4BACE,0CJyEJ,yBI1EE,iBACE,8BADF,yBACE,sCADF,oBACE,iCADF,4BACE,0CJyEJ,yBI1EE,iBACE,8BADF,yBACE,sCADF,oBACE,iCADF,4BACE,0CJyEJ,0BI1EE,iBACE,8BADF,yBACE,sCADF,oBACE,iCADF,4BACE,0CAeN,UACE,0BADF,YACE,4BADF,kBACE,kCAQE,eACE,0BADF,iBACE,4BADF,uBACE,kCJgDJ,yBIjDE,kBACE,0BADF,oBACE,4BADF,0BACE,mCJgDJ,yBIjDE,kBACE,0BADF,oBACE,4BADF,0BACE,mCJgDJ,yBIjDE,kBACE,0BADF,oBACE,4BADF,0BACE,mCJgDJ,0BIjDE,kBACE,0BADF,oBACE,4BADF,0BACE,mCAeF,YACE,kBADF,eACE,qBADF,kBACE,wBADF,eACE,qBJgCJ,yBIjCE,eACE,kBADF,kBACE,qBADF,qBACE,wBADF,kBACE,sBJgCJ,yBIjCE,eACE,kBADF,kBACE,qBADF,qBACE,wBADF,kBACE,sBJgCJ,yBIjCE,eACE,kBADF,kBACE,qBADF,qBACE,wBADF,kBACE,sBJgCJ,0BIjCE,eACE,kBADF,kBACE,qBADF,qBACE,wBADF,kBACE,sBAYJ,iBACE,uBAGF,iBACE,uBAGF,mBACE,yBAGF,mBACE,yBJOF,yBIpBA,oBACE,uBAGF,oBACE,uBAGF,sBACE,yBAGF,sBACE,0BJOF,yBIpBA,oBACE,uBAGF,oBACE,uBAGF,sBACE,yBAGF,sBACE,0BJOF,yBIpBA,oBACE,uBAGF,oBACE,uBAGF,sBACE,yBAGF,sBACE,0BJOF,0BIpBA,oBACE,uBAGF,oBACE,uBAGF,sBACE,yBAGF,sBACE,0BAWF,iBACE,oBAIA,aACE,mBADF,aACE,mBADF,aACE,mBADF,aACE,mBADF,aACE,mBADF,aACE,mBADF,aACE,mBADF,aACE,mBADF,aACE,mBADF,aACE,mBADF,cACE,oBADF,cACE,oBADF,cACE,oBAIJ,gBACE,oBJfF,yBIIA,oBACE,oBAIA,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,iBACE,oBADF,iBACE,oBADF,iBACE,oBAIJ,mBACE,qBJfF,yBIIA,oBACE,oBAIA,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,iBACE,oBADF,iBACE,oBADF,iBACE,oBAIJ,mBACE,qBJfF,yBIIA,oBACE,oBAIA,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,iBACE,oBADF,iBACE,oBADF,iBACE,oBAIJ,mBACE,qBJfF,0BIIA,oBACE,oBAIA,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,gBACE,mBADF,iBACE,oBADF,iBACE,oBADF,iBACE,oBAIJ,mBACE,qBAON,2BACE,iCAGF,mCACE,yCAGF,wBACE,8BAGF,gCACE,sCAKF,YACE,kBCxMF,UACE,wBAUE,aACE,wBAOF,eACE,wBL2IF,yBKpJA,gBACE,yBL+LF,4BKxLA,kBACE,yBL2IF,yBKpJA,gBACE,yBL+LF,4BKxLA,kBACE,yBL2IF,yBKpJA,gBACE,yBL+LF,4BKxLA,kBACE,yBL2IF,0BKpJA,gBACE,yBL+LF,6BKxLA,kBACE,yBAyBA,kBACE,wBLiHJ,yBKlHE,qBACE,yBLiHJ,yBKlHE,qBACE,yBLiHJ,yBKlHE,qBACE,yBLiHJ,0BKlHE,qBACE,yBADF,sBACE,4BLiHJ,yBKlHE,yBACE,6BLiHJ,yBKlHE,yBACE,6BLiHJ,yBKlHE,yBACE,6BLiHJ,0BKlHE,yBACE,6BADF,oBACE,0BLiHJ,yBKlHE,uBACE,2BLiHJ,yBKlHE,uBACE,2BLiHJ,yBKlHE,uBACE,2BLiHJ,0BKlHE,uBACE,2BADF,0BACE,gCLiHJ,yBKlHE,6BACE,iCLiHJ,yBKlHE,6BACE,iCLiHJ,yBKlHE,6BACE,iCLiHJ,0BKlHE,6BACE,iCADF,mBACE,yBLiHJ,yBKlHE,sBACE,0BLiHJ,yBKlHE,sBACE,0BLiHJ,yBKlHE,sBACE,0BLiHJ,0BKlHE,sBACE,0BADF,kBACE,wBLiHJ,yBKlHE,qBACE,yBLiHJ,yBKlHE,qBACE,yBLiHJ,yBKlHE,qBACE,yBLiHJ,0BKlHE,qBACE,yBADF,yBACE,+BLiHJ,yBKlHE,4BACE,gCLiHJ,yBKlHE,4BACE,gCLiHJ,yBKlHE,4BACE,gCLiHJ,0BKlHE,4BACE,gCADF,kBACE,wBLiHJ,yBKlHE,qBACE,yBLiHJ,yBKlHE,qBACE,yBLiHJ,yBKlHE,qBACE,yBLiHJ,0BKlHE,qBACE,yBADF,yBACE,+BLiHJ,yBKlHE,4BACE,gCLiHJ,yBKlHE,4BACE,gCLiHJ,yBKlHE,4BACE,gCLiHJ,0BKlHE,4BACE,gCADF,mBACE,yBLiHJ,yBKlHE,sBACE,0BLiHJ,yBKlHE,sBACE,0BLiHJ,yBKlHE,sBACE,0BLiHJ,0BKlHE,sBACE,0BADF,wBACE,8BLiHJ,yBKlHE,2BACE,+BLiHJ,yBKlHE,2BACE,+BLiHJ,yBKlHE,2BACE,+BLiHJ,0BKlHE,2BACE,+BADF,uBACE,6BLiHJ,yBKlHE,0BACE,8BLiHJ,yBKlHE,0BACE,8BLiHJ,yBKlHE,0BACE,8BLiHJ,0BKlHE,0BACE,8BASR,iBACE,uBAGF,gBACE,sBAMF,uBACE,6BAGF,uBACE","file":"utils.bundle.css","sourcesContent":["@import \"../themes/native/native.globals\";\n@import \"../themes/mixins\";\n\n// Element Space\n// --------------------------------------------------\n// Creates padding and margin attributes to be used on\n// any element\n\n$padding: var(--ion-padding, 16px);\n$margin: var(--ion-margin, 16px);\n\n// Padding\n// --------------------------------------------------\n\n.ion-no-padding {\n --padding-start: 0;\n --padding-end: 0;\n --padding-top: 0;\n --padding-bottom: 0;\n\n @include padding(0);\n}\n\n.ion-padding {\n --padding-start: #{$padding};\n --padding-end: #{$padding};\n --padding-top: #{$padding};\n --padding-bottom: #{$padding};\n\n @include padding($padding);\n}\n\n.ion-padding-top {\n --padding-top: #{$padding};\n\n @include padding($padding, null, null, null);\n}\n\n.ion-padding-start {\n --padding-start: #{$padding};\n\n @include padding-horizontal($padding, null);\n}\n\n.ion-padding-end {\n --padding-end: #{$padding};\n\n @include padding-horizontal(null, $padding);\n}\n\n.ion-padding-bottom {\n --padding-bottom: #{$padding};\n\n @include padding(null, null, $padding, null);\n}\n\n.ion-padding-vertical {\n --padding-top: #{$padding};\n --padding-bottom: #{$padding};\n\n @include padding($padding, null, $padding, null);\n}\n\n.ion-padding-horizontal {\n --padding-start: #{$padding};\n --padding-end: #{$padding};\n\n @include padding-horizontal($padding);\n}\n\n// Margin\n// --------------------------------------------------\n\n.ion-no-margin {\n --margin-start: 0;\n --margin-end: 0;\n --margin-top: 0;\n --margin-bottom: 0;\n\n @include margin(0);\n}\n\n.ion-margin {\n --margin-start: #{$margin};\n --margin-end: #{$margin};\n --margin-top: #{$margin};\n --margin-bottom: #{$margin};\n\n @include margin($margin);\n}\n\n.ion-margin-top {\n --margin-top: #{$margin};\n\n @include margin($margin, null, null, null);\n}\n\n.ion-margin-start {\n --margin-start: #{$margin};\n\n @include margin-horizontal($margin, null);\n}\n\n.ion-margin-end {\n --margin-end: #{$margin};\n\n @include margin-horizontal(null, $margin);\n}\n\n.ion-margin-bottom {\n --margin-bottom: #{$margin};\n\n @include margin(null, null, $margin, null);\n}\n\n.ion-margin-vertical {\n --margin-top: #{$margin};\n --margin-bottom: #{$margin};\n\n @include margin($margin, null, $margin, null);\n}\n\n.ion-margin-horizontal {\n --margin-start: #{$margin};\n --margin-end: #{$margin};\n\n @include margin-horizontal($margin);\n}\n","@use \"./functions.string\" as string;\n\n/**\n * A heuristic that applies CSS to tablet\n * viewports.\n *\n * Usage:\n * @include tablet-viewport() {\n * :host {\n * background-color: green;\n * }\n * }\n */\n@mixin tablet-viewport() {\n @media screen and (min-width: 768px) {\n @content;\n }\n}\n\n/**\n * A heuristic that applies CSS to mobile\n * viewports (i.e. phones, not tablets).\n *\n * Usage:\n * @include mobile-viewport() {\n * :host {\n * background-color: blue;\n * }\n * }\n */\n@mixin mobile-viewport() {\n @media screen and (max-width: 767px) {\n @content;\n }\n}\n\n@mixin input-cover() {\n @include position(0, null, null, 0);\n @include margin(0);\n\n position: absolute;\n\n width: 100%;\n height: 100%;\n\n border: 0;\n\n outline: none;\n\n background: transparent;\n\n cursor: pointer;\n\n appearance: none;\n\n &::-moz-focus-inner {\n border: 0;\n }\n}\n\n@mixin visually-hidden() {\n position: absolute;\n\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n\n width: 100%;\n height: 100%;\n\n margin: 0;\n\n padding: 0;\n\n border: 0;\n\n outline: 0;\n\n opacity: 0;\n overflow: hidden;\n clip: rect(0 0 0 0);\n\n -webkit-appearance: none;\n -moz-appearance: none;\n}\n\n@mixin text-inherit() {\n color: inherit;\n\n font-family: inherit;\n font-size: inherit;\n font-style: inherit;\n font-weight: inherit;\n\n letter-spacing: inherit;\n\n text-align: inherit;\n text-decoration: inherit;\n text-indent: inherit;\n text-overflow: inherit;\n text-transform: inherit;\n\n white-space: inherit;\n}\n\n@mixin button-state() {\n @include position(0, 0, 0, 0);\n\n position: absolute;\n\n content: \"\";\n\n opacity: 0;\n}\n\n// Font smoothing\n// --------------------------------------------------\n\n@mixin font-smoothing() {\n -moz-osx-font-smoothing: grayscale;\n -webkit-font-smoothing: antialiased;\n}\n\n// Get the key from a map based on the index\n@function index-to-key($map, $index) {\n $keys: map-keys($map);\n\n @return nth($keys, $index);\n}\n\n// Breakpoint Mixins\n// ---------------------------------------------------------------------------------\n\n// Breakpoint viewport sizes and media queries.\n//\n// Breakpoints are defined as a map of (name: minimum width), order from small to large:\n//\n// (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px)\n//\n// The map defined in the `$screen-breakpoints` global variable is used as the `$breakpoints` argument by default.\n\n// ---------------------------------------------------------------------------------\n\n// Minimum breakpoint width. Null for the smallest (first) breakpoint.\n//\n// >> breakpoint-min(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n// 576px\n@function breakpoint-min($name, $breakpoints: $screen-breakpoints) {\n $min: map-get($breakpoints, $name);\n\n @return if($name != index-to-key($breakpoints, 1), $min, null);\n}\n\n// Returns a blank string if smallest breakpoint, otherwise returns the name with a dash infront.\n// Useful for making responsive utilities.\n//\n// >> breakpoint-infix(xs, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n// \"\" (Returns a blank string)\n// >> breakpoint-infix(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n// \"-sm\"\n@function breakpoint-infix($name, $breakpoints: $screen-breakpoints) {\n @return if(breakpoint-min($name, $breakpoints) == null, \"\", \"-#{$name}\");\n}\n\n// Media of at least the minimum breakpoint width. No query for the smallest breakpoint.\n// Makes the @content apply to the given breakpoint and wider.\n@mixin media-breakpoint-up($name, $breakpoints: $screen-breakpoints) {\n $min: breakpoint-min($name, $breakpoints);\n\n @if $min {\n @media (min-width: $min) {\n @content;\n }\n } @else {\n @content;\n }\n}\n\n// Name of the next breakpoint, or null for the last breakpoint.\n//\n// >> breakpoint-next(sm)\n// md\n// >> breakpoint-next(sm, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n// md\n// >> breakpoint-next(sm, $breakpoint-names: (xs sm md lg xl))\n// md\n@function breakpoint-next($name, $breakpoints: $screen-breakpoints, $breakpoint-names: map-keys($breakpoints)) {\n $n: index($breakpoint-names, $name);\n\n @return if($n < length($breakpoint-names), nth($breakpoint-names, $n + 1), null);\n}\n\n// Maximum breakpoint width. Null for the smallest (first) breakpoint.\n// The maximum value is reduced by 0.02px to work around the limitations of\n// `min-` and `max-` prefixes and viewports with fractional widths.\n//\n// See https://www.w3.org/TR/mediaqueries-4/#mq-min-max\n// Uses 0.02px rather than 0.01px to work around a current rounding bug in Safari.\t// Uses 0.02px rather than 0.01px to work around a current rounding bug in Safari.\n// See https://bugs.webkit.org/show_bug.cgi?id=178261\t// See https://bugs.webkit.org/show_bug.cgi?id=178261\n//\n// >> breakpoint-max(md, (xs: 0, sm: 576px, md: 768px, lg: 992px, xl: 1200px))\n// 767.98px\n@function breakpoint-max($name, $breakpoints: $screen-breakpoints) {\n $max: map-get($breakpoints, $name);\n\n @return if($max and $max > 0, $max - 0.02, null);\n}\n\n// Media of at most the maximum breakpoint width. No query for the largest breakpoint.\n// Makes the @content apply to the given breakpoint and narrower.\n@mixin media-breakpoint-down($name, $breakpoints: $screen-breakpoints) {\n $max: breakpoint-max($name, $breakpoints);\n\n @if $max {\n @media (max-width: $max) {\n @content;\n }\n } @else {\n @content;\n }\n}\n\n// Text Direction - ltr / rtl\n//\n// CSS defaults to use the ltr css, and adds [dir=rtl] selectors\n// to override ltr defaults.\n// ----------------------------------------------------------\n\n@mixin multi-dir() {\n @content;\n\n // $root: #{&};\n // @at-root [dir] {\n // #{$root} {\n // @content;\n // }\n // }\n}\n\n@mixin rtl() {\n $root: #{&};\n\n $rootSplit: string.str-split($root, \",\");\n $selectors: #{string.add-root-selector($root, \"[dir=rtl]\")};\n $selectorsSplit: string.str-split($selectors, \",\");\n\n $hostContextSelectors: ();\n $restSelectors: ();\n $dirSelectors: ();\n\n // Selectors must be split into individual selectors in case the browser\n // doesn't support a specific selector.\n // For example, Firefox and Safari doesn't support `:host-context()`.\n // If an invalid selector is used, then the entire group of selectors\n // will be ignored.\n // @link https://www.w3.org/TR/selectors-3/#grouping\n @each $selector in $selectorsSplit {\n // Group the selectors back into a single selector to optimize the output.\n @if str-index($selector, \":host-context\") {\n $hostContextSelectors: append($hostContextSelectors, $selector, comma);\n } @else {\n // Group the selectors back into a single selector to optimize the output.\n $restSelectors: append($restSelectors, $selector, comma);\n }\n }\n\n // Supported by Chrome.\n @if length($hostContextSelectors) > 0 {\n @at-root #{$hostContextSelectors} {\n @content;\n }\n }\n\n // Supported by all browsers.\n @if length($restSelectors) > 0 {\n @at-root #{$restSelectors} {\n @content;\n }\n }\n\n // If browser can support `:dir()`, then add the `:dir()` selectors.\n @supports selector(:dir(rtl)) {\n // Adding :dir() in case the browser doesn't support `:host-context()` and does support `:dir()`.\n // `:host-context()` is added:\n // - through the `add-root-selector()` function.\n // - first so that it takes precedence over `:dir()`.\n // For example,\n // - Firefox doesn't support `:host-context()`, but does support `:dir()`.\n // - Safari doesn't support `:host-context()`, but Safari 16.4+ supports `:dir()`\n // @link https://webkit.org/blog/13966/webkit-features-in-safari-16-4/\n // -- However, there is a Webkit bug on v16 that prevents `:dir()` from working when\n // -- the app direction is changed dynamically. v17+ works fine.\n // -- @link https://bugs.webkit.org/show_bug.cgi?id=257133\n\n // Supported by Firefox.\n @at-root #{string.add-root-selector($root, \":dir(rtl)\", false)} {\n @content;\n }\n }\n}\n\n@mixin ltr() {\n @content;\n}\n\n// SVG Background Image Mixin\n// @param {string} $svg\n// ----------------------------------------------------------\n@mixin svg-background-image($svg, $flip-rtl: false) {\n $url: url-encode($svg);\n $viewBox: string.str-split(string.str-extract($svg, \"viewBox='\", \"'\"), \" \");\n\n @if $flip-rtl != true or $viewBox == null {\n @include multi-dir() {\n background-image: url(\"data:image/svg+xml;charset=utf-8,#{$url}\");\n }\n } @else {\n $transform: \"transform='translate(#{nth($viewBox, 3)}, 0) scale(-1, 1)'\";\n $flipped-url: $svg;\n $flipped-url: string.str-replace($flipped-url, \"<path\", \"<path #{$transform}\");\n $flipped-url: string.str-replace($flipped-url, \"<line\", \"<line #{$transform}\");\n $flipped-url: string.str-replace($flipped-url, \"<polygon\", \"<polygon #{$transform}\");\n $flipped-url: url-encode($flipped-url);\n\n @include ltr() {\n background-image: url(\"data:image/svg+xml;charset=utf-8,#{$url}\");\n }\n\n @include rtl() {\n background-image: url(\"data:image/svg+xml;charset=utf-8,#{$flipped-url}\");\n }\n }\n}\n\n// Add property horizontal\n// @param {string} $start\n// @param {string} $end\n// ----------------------------------------------------------\n@mixin property-horizontal($prop, $start, $end: $start) {\n @if $start == 0 and $end == 0 {\n #{$prop}-left: $start;\n #{$prop}-right: $end;\n } @else {\n -webkit-#{$prop}-start: $start;\n #{$prop}-inline-start: $start;\n -webkit-#{$prop}-end: $end;\n #{$prop}-inline-end: $end;\n }\n}\n\n// Add property for all directions\n// @param {string} $prop\n// @param {string} $top\n// @param {string} $end\n// @param {string} $bottom\n// @param {string} $start\n// @param {boolean} $content include content or use default\n// ----------------------------------------------------------\n@mixin property($prop, $top, $end: $top, $bottom: $top, $start: $end) {\n @include property-horizontal($prop, $start, $end);\n #{$prop}-top: $top;\n #{$prop}-bottom: $bottom;\n}\n\n// Add padding horizontal\n// @param {string} $start\n// @param {string} $end\n// ----------------------------------------------------------\n@mixin padding-horizontal($start, $end: $start) {\n @include property-horizontal(padding, $start, $end);\n}\n\n// Add padding for all directions\n// @param {string} $top\n// @param {string} $end\n// @param {string} $bottom\n// @param {string} $start\n// ----------------------------------------------------------\n@mixin padding($top, $end: $top, $bottom: $top, $start: $end) {\n @include property(padding, $top, $end, $bottom, $start);\n}\n\n// Add margin horizontal\n// @param {string} $start\n// @param {string} $end\n// ----------------------------------------------------------\n@mixin margin-horizontal($start, $end: $start) {\n @include property-horizontal(margin, $start, $end);\n}\n\n// Add margin for all directions\n// @param {string} $top\n// @param {string} $end\n// @param {string} $bottom\n// @param {string} $start\n// ----------------------------------------------------------\n@mixin margin($top, $end: $top, $bottom: $top, $start: $end) {\n @include property(margin, $top, $end, $bottom, $start);\n}\n\n// Add position horizontal\n// @param {string} $start - amount to position start\n// @param {string} $end - amount to left: 0; end\n// ----------------------------------------------------------\n@mixin position-horizontal($start: null, $end: null) {\n @if $start == $end {\n @include multi-dir() {\n right: $end;\n left: $start;\n }\n } @else {\n @at-root {\n & {\n inset-inline-start: $start;\n inset-inline-end: $end;\n }\n }\n }\n}\n\n// Add position for all directions\n// @param {string} $top\n// @param {string} $end\n// @param {string} $bottom\n// @param {string} $start\n// ----------------------------------------------------------\n@mixin position($top: null, $end: null, $bottom: null, $start: null) {\n @include position-horizontal($start, $end);\n top: $top;\n bottom: $bottom;\n}\n\n// Add border for all directions\n// @param {string} $top\n// @param {string} $end\n// @param {string} $bottom\n// @param {string} $start\n// ----------------------------------------------------------\n@mixin border($top, $end: $top, $bottom: $top, $start: $end) {\n @include property(border, $top, $end, $bottom, $start);\n}\n\n// Add border radius for all directions\n// @param {string} $top-start\n// @param {string} $top-end\n// @param {string} $bottom-end\n// @param {string} $bottom-start\n// ----------------------------------------------------------\n@mixin border-radius($top-start, $top-end: $top-start, $bottom-end: $top-start, $bottom-start: $top-end) {\n @if $top-start == $top-end and $top-start == $bottom-end and $top-start == $bottom-start {\n border-radius: $top-start;\n } @else {\n border-start-start-radius: $top-start;\n border-start-end-radius: $top-end;\n border-end-end-radius: $bottom-end;\n border-end-start-radius: $bottom-start;\n }\n}\n\n// Add direction for all directions\n// @param {string} $dir - Direction on LTR\n@mixin direction($dir) {\n $other-dir: null;\n\n @if $dir == ltr {\n $other-dir: rtl;\n } @else {\n $other-dir: ltr;\n }\n\n @include ltr() {\n direction: $dir;\n }\n\n @include rtl() {\n direction: $other-dir;\n }\n}\n\n// Add float for all directions\n// @param {string} $side\n// @param {string} $decorator - !important\n@mixin float($side, $decorator: null) {\n @if $side == start {\n @include ltr() {\n float: left $decorator;\n }\n\n @include rtl() {\n float: right $decorator;\n }\n } @else if $side == end {\n @include ltr() {\n float: right $decorator;\n }\n\n @include rtl() {\n float: left $decorator;\n }\n } @else {\n @include multi-dir() {\n float: $side $decorator;\n }\n }\n}\n\n@mixin background-position($horizontal, $horizontal-amount: null, $vertical: null, $vertical-amount: null) {\n @if $horizontal == start or $horizontal == end {\n $horizontal-ltr: null;\n $horizontal-rtl: null;\n\n @if $horizontal == start {\n $horizontal-ltr: left;\n $horizontal-rtl: right;\n } @else {\n $horizontal-ltr: right;\n $horizontal-rtl: left;\n }\n\n @include ltr() {\n background-position: $horizontal-ltr $horizontal-amount $vertical $vertical-amount;\n }\n\n @include rtl() {\n background-position: $horizontal-rtl $horizontal-amount $vertical $vertical-amount;\n }\n } @else {\n @include multi-dir() {\n background-position: $horizontal $horizontal-amount $vertical $vertical-amount;\n }\n }\n}\n\n@mixin transform-origin($x-axis, $y-axis: null) {\n @if $x-axis == start {\n @include ltr() {\n transform-origin: left $y-axis;\n }\n\n @include rtl() {\n transform-origin: right $y-axis;\n }\n } @else if $x-axis == end {\n @include ltr() {\n transform-origin: right $y-axis;\n }\n\n @include rtl() {\n transform-origin: left $y-axis;\n }\n } @else if $x-axis == left or $x-axis == right {\n @include multi-dir() {\n transform-origin: $x-axis $y-axis;\n }\n } @else {\n @include ltr() {\n transform-origin: $x-axis $y-axis;\n }\n\n @include rtl() {\n transform-origin: calc(100% - #{$x-axis}) $y-axis;\n }\n }\n}\n\n// Add transform for all directions\n// @param {string} $transforms - comma separated list of transforms\n@mixin transform($transforms...) {\n $extra: null;\n\n $x: null;\n $ltr-translate: null;\n $rtl-translate: null;\n\n @each $transform in $transforms {\n @if (str-index($transform, translate3d)) {\n $transform: string.str-replace($transform, \"translate3d(\");\n $transform: string.str-replace($transform, \")\");\n\n $coordinates: string.str-split($transform, \",\");\n\n $x: nth($coordinates, 1);\n $y: nth($coordinates, 2);\n $z: nth($coordinates, 3);\n\n $ltr-translate: translate3d($x, $y, $z);\n $rtl-translate: translate3d(calc(-1 * #{$x}), $y, $z);\n } @else {\n @if $extra == null {\n $extra: $transform;\n } @else {\n $extra: $extra $transform;\n }\n }\n }\n\n @if $x == \"0\" or $x == null {\n @include multi-dir() {\n transform: $ltr-translate $extra;\n }\n } @else {\n @include ltr() {\n transform: $ltr-translate $extra;\n }\n\n @include rtl() {\n transform: $rtl-translate $extra;\n }\n }\n}\n","@import \"../themes/native/native.globals\";\n@import \"../themes/mixins\";\n\n// Float Elements\n// --------------------------------------------------\n// Creates float classes based on screen size\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n // Provide `.ion-float-{bp}-{side}` classes for floating the element based\n // on the breakpoint and side\n .ion-float#{$infix}-left {\n @include float(left, !important);\n }\n\n .ion-float#{$infix}-right {\n @include float(right, !important);\n }\n\n .ion-float#{$infix}-start {\n @include float(start, !important);\n }\n\n .ion-float#{$infix}-end {\n @include float(end, !important);\n }\n }\n}\n","@import \"../themes/native/native.globals\";\n@import \"../themes/mixins\";\n\n// Text Alignment\n// --------------------------------------------------\n// Creates text alignment attributes based on screen size\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n // Provide `.ion-text-{bp}` classes for aligning the text based\n // on the breakpoint\n .ion-text#{$infix}-center {\n text-align: center !important;\n }\n\n .ion-text#{$infix}-justify {\n text-align: justify !important;\n }\n\n .ion-text#{$infix}-start {\n text-align: start !important;\n }\n\n .ion-text#{$infix}-end {\n text-align: end !important;\n }\n\n .ion-text#{$infix}-left {\n text-align: left !important;\n }\n\n .ion-text#{$infix}-right {\n text-align: right !important;\n }\n\n .ion-text#{$infix}-nowrap {\n white-space: nowrap !important;\n }\n\n .ion-text#{$infix}-wrap {\n white-space: normal !important;\n }\n }\n}\n","@import \"../themes/native/native.globals\";\n@import \"../themes/mixins\";\n\n// Text Transformation\n// --------------------------------------------------\n// Creates text transform attributes based on screen size\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n // Provide `.ion-text-{bp}` classes for transforming the text based\n // on the breakpoint\n .ion-text#{$infix}-uppercase {\n /* stylelint-disable-next-line declaration-no-important */\n text-transform: uppercase !important;\n }\n\n .ion-text#{$infix}-lowercase {\n /* stylelint-disable-next-line declaration-no-important */\n text-transform: lowercase !important;\n }\n\n .ion-text#{$infix}-capitalize {\n /* stylelint-disable-next-line declaration-no-important */\n text-transform: capitalize !important;\n }\n }\n}\n","@import \"../themes/native/native.globals\";\n@import \"../themes/mixins\";\n\n// Flex Utilities\n// ------------------------------------------------------------------\n// Provides utility classes to control flexbox layout, alignment,\n// and sizing of elements. Includes responsive variants for managing\n// flex direction, alignment, justification, wrapping, growth,\n// shrinking, and ordering at different breakpoints.\n\n// Align Content\n// ------------------------------------------------------------------\n\n$align-content-values: (\n start: flex-start,\n end: flex-end,\n center: center,\n between: space-between,\n around: space-around,\n stretch: stretch,\n);\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n @each $key, $value in $align-content-values {\n .ion-align-content#{$infix}-#{$key} {\n align-content: #{$value} !important;\n }\n }\n }\n}\n\n// Align Items\n// ------------------------------------------------------------------\n\n$align-items-values: (start, end, center, stretch, baseline);\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n @each $value in $align-items-values {\n .ion-align-items#{$infix}-#{$value} {\n align-items: #{$value} !important;\n }\n }\n }\n}\n\n// Align Self\n// ------------------------------------------------------------------\n\n$align-self-values: (start, end, center, stretch, baseline, auto);\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n @each $value in $align-self-values {\n .ion-align-self#{$infix}-#{$value} {\n align-self: #{$value} !important;\n }\n }\n }\n}\n\n// Justify Content\n// ------------------------------------------------------------------\n\n$justify-content-values: (\n start: flex-start,\n end: flex-end,\n center: center,\n between: space-between,\n around: space-around,\n evenly: space-evenly,\n);\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n @each $key, $value in $justify-content-values {\n .ion-justify-content#{$infix}-#{$key} {\n justify-content: #{$value} !important;\n }\n }\n }\n}\n\n// Flex Direction\n// ------------------------------------------------------------------\n\n$flex-direction-values: (row, row-reverse, column, column-reverse);\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n @each $value in $flex-direction-values {\n .ion-flex#{$infix}-#{$value} {\n flex-direction: #{$value} !important;\n }\n }\n }\n}\n\n// Flex Wrap\n// ------------------------------------------------------------------\n\n$flex-wrap-values: (wrap, nowrap, wrap-reverse);\n\n@each $value in $flex-wrap-values {\n // TODO(FW-6697): remove ion-wrap, ion-nowrap, ion-wrap-reverse\n // in favor of the new ion-flex-wrap, ion-flex-nowrap, and\n // ion-flex-wrap-reverse classes\n .ion-#{$value} {\n flex-wrap: #{$value} !important;\n }\n}\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n @each $value in $flex-wrap-values {\n .ion-flex#{$infix}-#{$value} {\n flex-wrap: #{$value} !important;\n }\n }\n }\n}\n\n// Flex Fill\n// ------------------------------------------------------------------\n\n$flex-fill-values: (1, auto, initial, none);\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n @each $value in $flex-fill-values {\n .ion-flex#{$infix}-#{$value} {\n flex: #{$value} !important;\n }\n }\n }\n}\n\n// Flex Grow and Shrink\n// ------------------------------------------------------------------\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n .ion-flex#{$infix}-grow-0 {\n flex-grow: 0 !important;\n }\n\n .ion-flex#{$infix}-grow-1 {\n flex-grow: 1 !important;\n }\n\n .ion-flex#{$infix}-shrink-0 {\n flex-shrink: 0 !important;\n }\n\n .ion-flex#{$infix}-shrink-1 {\n flex-shrink: 1 !important;\n }\n }\n}\n\n// Flex Order\n// ------------------------------------------------------------------\n\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n .ion-order#{$infix}-first {\n order: -1 !important;\n }\n\n @for $i from 0 through 12 {\n .ion-order#{$infix}-#{$i} {\n order: #{$i} !important;\n }\n }\n\n .ion-order#{$infix}-last {\n order: 13 !important;\n }\n }\n}\n\n// Flex Direction\n// --------------------------------------------------\n.ion-flex-direction-column {\n flex-direction: column !important;\n}\n\n.ion-flex-direction-column-reverse {\n flex-direction: column-reverse !important;\n}\n\n.ion-flex-direction-row {\n flex-direction: row !important;\n}\n\n.ion-flex-direction-row-reverse {\n flex-direction: row-reverse !important;\n}\n\n// Flex Container\n// --------------------------------------------------\n.ion-flex-1 {\n flex: 1 !important;\n}\n","@import \"../themes/native/native.globals\";\n@import \"../themes/mixins\";\n\n// Display\n// ------------------------------------------------------------------\n// Provides utility classes to control the CSS display property\n// of elements. Includes responsive variants for toggling between\n// block, inline, flex, grid, and other display values at different\n// breakpoints.\n\n// TODO(FW-6697): remove ion-hide-* classes in favor of the new\n// ion-display-* classes\n.ion-hide {\n display: none !important;\n}\n\n// Adds hidden classes\n@each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n // Provide `ion-hide-{bp}-up` classes for hiding the element based\n // on the breakpoint\n .ion-hide#{$infix}-up {\n display: none !important;\n }\n }\n\n @include media-breakpoint-down($breakpoint, $screen-breakpoints) {\n // Provide `ion-hide-{bp}-down` classes for hiding the element based\n // on the breakpoint\n .ion-hide#{$infix}-down {\n display: none !important;\n }\n }\n}\n\n$display-values: (\n none,\n contents,\n inline,\n inline-block,\n block,\n flex,\n inline-flex,\n grid,\n inline-grid,\n table,\n table-cell,\n table-row\n);\n\n@each $display in $display-values {\n @each $breakpoint in map-keys($screen-breakpoints) {\n $infix: breakpoint-infix($breakpoint, $screen-breakpoints);\n\n @include media-breakpoint-up($breakpoint, $screen-breakpoints) {\n .ion-display#{$infix}-#{$display} {\n display: #{$display} !important;\n }\n }\n }\n}\n\n// Size\n// --------------------------------------------------\n\n.ion-full-height {\n height: 100% !important;\n}\n\n.ion-full-width {\n width: 100% !important;\n}\n\n// Position\n// --------------------------------------------------\n\n.ion-position-absolute {\n position: absolute !important;\n}\n\n.ion-position-relative {\n position: relative !important;\n}\n"]}
@@ -3,8 +3,8 @@
3
3
  */
4
4
  'use strict';
5
5
 
6
- var index = require('./index-D6Wc6v08.js');
7
- var index$1 = require('./index-DkNv4J_i.js');
6
+ var index = require('./index-DjlJwy91.js');
7
+ var ionicGlobal = require('./ionic-global-DlkD8-ZL.js');
8
8
 
9
9
  let animationPrefix;
10
10
  const getAnimationPrefix = (el) => {
@@ -67,7 +67,7 @@ const createAnimation = (animationId) => {
67
67
  const _afterAddWriteFunctions = [];
68
68
  const webAnimations = [];
69
69
  const supportsAnimationEffect = typeof AnimationEffect === 'function' ||
70
- (index$1.win !== undefined && typeof index$1.win.AnimationEffect === 'function');
70
+ (ionicGlobal.win !== undefined && typeof ionicGlobal.win.AnimationEffect === 'function');
71
71
  /**
72
72
  * This is a feature detection for Web Animations.
73
73
  *
@@ -3,7 +3,7 @@
3
3
  */
4
4
  'use strict';
5
5
 
6
- var ionicGlobal = require('./ionic-global-HMVqOFGO.js');
6
+ var ionicGlobal = require('./ionic-global-DlkD8-ZL.js');
7
7
 
8
8
  const globalScripts = ionicGlobal.initialize;
9
9
 
@@ -3,8 +3,8 @@
3
3
  */
4
4
  'use strict';
5
5
 
6
- var index$1 = require('./index-D6Wc6v08.js');
7
- var haptic = require('./haptic-ClPPQ_PS.js');
6
+ var index$1 = require('./index-DjlJwy91.js');
7
+ var haptic = require('./haptic-CYXFB5MG.js');
8
8
  var index = require('./index-CAvQ7Tka.js');
9
9
 
10
10
  const createButtonActiveGesture = (el, isButton) => {
@@ -3,11 +3,11 @@
3
3
  */
4
4
  'use strict';
5
5
 
6
- var index = require('./index-DkNv4J_i.js');
6
+ var ionicGlobal = require('./ionic-global-DlkD8-ZL.js');
7
7
 
8
8
  const getCapacitor = () => {
9
- if (index.win !== undefined) {
10
- return index.win.Capacitor;
9
+ if (ionicGlobal.win !== undefined) {
10
+ return ionicGlobal.win.Capacitor;
11
11
  }
12
12
  return undefined;
13
13
  };
@@ -0,0 +1,8 @@
1
+ /*!
2
+ * (C) Ionic http://ionicframework.com - MIT License
3
+ */
4
+ 'use strict';
5
+
6
+ const caretDownSvg = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyNTYgMjU2IiBmaWxsPSJjdXJyZW50Q29sb3IiPjxwYXRoIGQ9Ik0yMTMuNjYsMTAxLjY2bC04MCw4MGE4LDgsMCwwLDEtMTEuMzIsMGwtODAtODBBOCw4LDAsMCwxLDUzLjY2LDkwLjM0TDEyOCwxNjQuNjlsNzQuMzQtNzQuMzVhOCw4LDAsMCwxLDExLjMyLDExLjMyWiIvPjwvc3ZnPg==';
7
+
8
+ exports.caretDownSvg = caretDownSvg;
@@ -0,0 +1,8 @@
1
+ /*!
2
+ * (C) Ionic http://ionicframework.com - MIT License
3
+ */
4
+ 'use strict';
5
+
6
+ const caretLeftSvg = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyNTYgMjU2IiBmaWxsPSJjdXJyZW50Q29sb3IiPjxwYXRoIGQ9Ik0xNjUuNjYsMjAyLjM0YTgsOCwwLDAsMS0xMS4zMiwxMS4zMmwtODAtODBhOCw4LDAsMCwxLDAtMTEuMzJsODAtODBhOCw4LDAsMCwxLDExLjMyLDExLjMyTDkxLjMxLDEyOFoiLz48L3N2Zz4=';
7
+
8
+ exports.caretLeftSvg = caretLeftSvg;
@@ -0,0 +1,8 @@
1
+ /*!
2
+ * (C) Ionic http://ionicframework.com - MIT License
3
+ */
4
+ 'use strict';
5
+
6
+ const caretRightSvg = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyNTYgMjU2IiBmaWxsPSJjdXJyZW50Q29sb3IiPjxwYXRoIGQ9Ik0xODEuNjYsMTMzLjY2bC04MCw4MGE4LDgsMCwwLDEtMTEuMzItMTEuMzJMMTY0LjY5LDEyOCw5MC4zNCw1My42NmE4LDgsMCwwLDEsMTEuMzItMTEuMzJsODAsODBBOCw4LDAsMCwxLDE4MS42NiwxMzMuNjZaIi8+PC9zdmc+';
7
+
8
+ exports.caretRightSvg = caretRightSvg;
@@ -3,7 +3,7 @@
3
3
  */
4
4
  'use strict';
5
5
 
6
- var index = require('./index-D6Wc6v08.js');
6
+ var index = require('./index-DjlJwy91.js');
7
7
 
8
8
  /**
9
9
  * Does a simple sanitization of all elements
@@ -3,7 +3,7 @@
3
3
  */
4
4
  'use strict';
5
5
 
6
- var index = require('./index-D6Wc6v08.js');
6
+ var index = require('./index-DjlJwy91.js');
7
7
 
8
8
  /**
9
9
  * Returns true if the selected day is equal to the reference day
@@ -1152,20 +1152,20 @@ const hour23 = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18
1152
1152
  // h24 hour system uses 1-24. Midnight starts at 24:00.
1153
1153
  const hour24 = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 0];
1154
1154
  /**
1155
- * Given a locale and a mode,
1155
+ * Given a locale and a theme,
1156
1156
  * return an array with formatted days
1157
- * of the week. iOS should display days
1158
- * such as "Mon" or "Tue".
1157
+ * of the week. iOS and Ionic themes should
1158
+ * display days such as "Mon" or "Tue".
1159
1159
  * MD should display days such as "M"
1160
1160
  * or "T".
1161
1161
  */
1162
- const getDaysOfWeek = (locale, mode, firstDayOfWeek = 0) => {
1162
+ const getDaysOfWeek = (locale, theme, firstDayOfWeek = 0) => {
1163
1163
  /**
1164
1164
  * Nov 1st, 2020 starts on a Sunday.
1165
1165
  * ion-datetime assumes weeks start on Sunday,
1166
1166
  * but is configurable via `firstDayOfWeek`.
1167
1167
  */
1168
- const weekdayFormat = mode === 'ios' ? 'short' : 'narrow';
1168
+ const weekdayFormat = theme === 'md' ? 'narrow' : 'short';
1169
1169
  const intl = new Intl.DateTimeFormat(locale, { weekday: weekdayFormat });
1170
1170
  const startDate = new Date('11/01/2020');
1171
1171
  const daysOfWeek = [];
@@ -19,6 +19,28 @@ const FOCUS_KEYS = [
19
19
  'Home',
20
20
  'End',
21
21
  ];
22
+ let focusVisibleUtility = null;
23
+ const getOrInitFocusVisibleUtility = () => {
24
+ if (!focusVisibleUtility) {
25
+ focusVisibleUtility = startFocusVisible();
26
+ }
27
+ return focusVisibleUtility;
28
+ };
29
+ /**
30
+ * Used to set focus on an element that uses `ion-focusable`.
31
+ * Do not use this if focusing the element as a result of a keyboard
32
+ * event as the focus utility should handle this for us. This method
33
+ * should be used when we want to programmatically focus an element as
34
+ * a result of another user action. (Ex: We focus the first element
35
+ * inside of a popover when the user presents it, but the popover is not always
36
+ * presented as a result of keyboard action.)
37
+ *
38
+ * @param elements - The elements to set focus on.
39
+ */
40
+ const focusElements = (elements) => {
41
+ const focusVisible = getOrInitFocusVisibleUtility();
42
+ focusVisible.setFocus(elements);
43
+ };
22
44
  const startFocusVisible = (rootEl) => {
23
45
  let currentFocus = [];
24
46
  let keyboardMode = true;
@@ -74,4 +96,6 @@ const startFocusVisible = (rootEl) => {
74
96
  };
75
97
  };
76
98
 
99
+ exports.focusElements = focusElements;
100
+ exports.getOrInitFocusVisibleUtility = getOrInitFocusVisibleUtility;
77
101
  exports.startFocusVisible = startFocusVisible;
@@ -3,7 +3,8 @@
3
3
  */
4
4
  'use strict';
5
5
 
6
- var helpers = require('./helpers-DrTqNghc.js');
6
+ var index = require('./index-DjlJwy91.js');
7
+ var helpers = require('./helpers-DF1tCuxf.js');
7
8
 
8
9
  // TODO(FW-2832): types
9
10
  const attachComponent = async (delegate, container, component, cssClasses, componentProps, inline) => {
@@ -104,7 +105,8 @@ const CoreDelegate = () => {
104
105
  * Get the root of the app and
105
106
  * add the overlay there.
106
107
  */
107
- const app = document.querySelector('ion-app') || document.body;
108
+ const appRootSelector = index.config.get('appRootSelector', 'ion-app');
109
+ const app = document.querySelector(appRootSelector) || document.body;
108
110
  /**
109
111
  * Create a placeholder comment so that
110
112
  * we can return this component to where
@@ -3,7 +3,7 @@
3
3
  */
4
4
  'use strict';
5
5
 
6
- var capacitor = require('./capacitor-DmA66EwP.js');
6
+ var capacitor = require('./capacitor-G2rS2zAS.js');
7
7
 
8
8
  exports.ImpactStyle = void 0;
9
9
  (function (ImpactStyle) {
@@ -3,7 +3,8 @@
3
3
  */
4
4
  'use strict';
5
5
 
6
- var index = require('./index-D6Wc6v08.js');
6
+ var focusVisible = require('./focus-visible-BIj-I3-C.js');
7
+ var index = require('./index-DjlJwy91.js');
7
8
 
8
9
  const transitionEndAsync = (el, expectedDuration = 0) => {
9
10
  return new Promise((resolve) => {
@@ -203,6 +204,17 @@ const raf = (h) => {
203
204
  const hasShadowDom = (el) => {
204
205
  return !!el.shadowRoot && !!el.attachShadow;
205
206
  };
207
+ /**
208
+ * Focuses a given element while ensuring proper focus management
209
+ * within the Ionic framework. If the element is marked as `ion-focusable`,
210
+ * this function will delegate focus handling to `ion-app` or manually
211
+ * apply focus when a custom app root is used.
212
+ *
213
+ * This function helps maintain accessibility and expected focus behavior
214
+ * in both standard and custom root environments.
215
+ *
216
+ * @param el - The element to focus.
217
+ */
206
218
  const focusVisibleElement = (el) => {
207
219
  el.focus();
208
220
  /**
@@ -212,11 +224,52 @@ const focusVisibleElement = (el) => {
212
224
  * however, there are times when we need to manually control
213
225
  * this behavior so we call the `setFocus` method on ion-app
214
226
  * which will let us explicitly set the elements to focus.
227
+ *
228
+ * Note: The element passed to this function might be an inner
229
+ * focusable element (e.g., a native <button> inside ion-button's
230
+ * shadow root). If so, we need to find the host element that has
231
+ * the ion-focusable class to pass to setFocus.
215
232
  */
216
- if (el.classList.contains('ion-focusable')) {
217
- const app = el.closest('ion-app');
233
+ let elToFocus = el;
234
+ // If the element doesn't have ion-focusable, check if it's inside
235
+ // a shadow root and use the host element instead
236
+ if (!el.classList.contains('ion-focusable')) {
237
+ const rootNode = el.getRootNode();
238
+ if (rootNode instanceof ShadowRoot && rootNode.host instanceof HTMLElement) {
239
+ elToFocus = rootNode.host;
240
+ }
241
+ }
242
+ if (elToFocus.classList.contains('ion-focusable')) {
243
+ const appRootSelector = index.config.get('appRootSelector', 'ion-app');
244
+ const app = elToFocus.closest(appRootSelector);
218
245
  if (app) {
219
- app.setFocus([el]);
246
+ if (appRootSelector === 'ion-app') {
247
+ /**
248
+ * If the app root is the default, then it will be
249
+ * in charge of setting focus. This is because the
250
+ * focus-visible utility is attached to the app root
251
+ * and will handle setting focus on the correct element.
252
+ */
253
+ app.setFocus([elToFocus]);
254
+ }
255
+ else {
256
+ /**
257
+ * When using a custom app root selector, the focus-visible
258
+ * utility is not available to manage focus automatically.
259
+ * If we set focus immediately, the element may not be fully
260
+ * rendered or interactive, especially if it was just added
261
+ * to the DOM. Using requestAnimationFrame ensures that focus
262
+ * is applied on the next frame, allowing the DOM to settle
263
+ * before changing focus.
264
+ */
265
+ requestAnimationFrame(() => {
266
+ /**
267
+ * The focus-visible utility is used to set focus on an
268
+ * element that uses `ion-focusable`.
269
+ */
270
+ focusVisible.focusElements([elToFocus]);
271
+ });
272
+ }
220
273
  }
221
274
  }
222
275
  };
@@ -3,8 +3,8 @@
3
3
  */
4
4
  'use strict';
5
5
 
6
- var index = require('./index-D6Wc6v08.js');
7
- var helpers = require('./helpers-DrTqNghc.js');
6
+ var index = require('./index-DjlJwy91.js');
7
+ var helpers = require('./helpers-DF1tCuxf.js');
8
8
 
9
9
  const LIFECYCLE_WILL_ENTER = 'ionViewWillEnter';
10
10
  const LIFECYCLE_DID_ENTER = 'ionViewDidEnter';
@@ -120,8 +120,8 @@ const createFocusController = () => {
120
120
  };
121
121
  const LAST_FOCUS = 'ion-last-focus';
122
122
 
123
- const iosTransitionAnimation = () => Promise.resolve().then(function () { return require('./ios.transition-BOt_uW73.js'); });
124
- const mdTransitionAnimation = () => Promise.resolve().then(function () { return require('./md.transition-Dt968VXB.js'); });
123
+ const iosTransitionAnimation = () => Promise.resolve().then(function () { return require('./ios.transition-cjE5173V.js'); });
124
+ const mdTransitionAnimation = () => Promise.resolve().then(function () { return require('./md.transition-ChCLDEkm.js'); });
125
125
  const focusController = createFocusController();
126
126
  // TODO(FW-2832): types
127
127
  /**
@@ -3,12 +3,10 @@
3
3
  */
4
4
  'use strict';
5
5
 
6
- var index = require('./index-DkNv4J_i.js');
7
- var hardwareBackButton = require('./hardware-back-button-VCK4V3mG.js');
8
- var index$1 = require('./index-D6Wc6v08.js');
9
- var helpers = require('./helpers-DrTqNghc.js');
10
- var ionicGlobal = require('./ionic-global-HMVqOFGO.js');
11
- var animation = require('./animation-Bt3H9L1C.js');
6
+ var ionicGlobal = require('./ionic-global-DlkD8-ZL.js');
7
+ var index = require('./index-DjlJwy91.js');
8
+ var helpers = require('./helpers-DF1tCuxf.js');
9
+ var animation = require('./animation-BBT4oe7B.js');
12
10
 
13
11
  /**
14
12
  * baseAnimation
@@ -50,10 +48,10 @@ const menuOverlayAnimation = (menu) => {
50
48
  }
51
49
  menuAnimation.addElement(menu.menuInnerEl).fromTo('transform', `translateX(${closedX})`, `translateX(${openedX})`);
52
50
  const mode = ionicGlobal.getIonMode(menu);
53
- const isIos = mode === 'ios';
54
- const opacity = isIos ? 0.2 : 0.25;
51
+ const isIOS = mode === 'ios';
52
+ const opacity = isIOS ? 0.2 : 0.25;
55
53
  backdropAnimation.addElement(menu.backdropEl).fromTo('opacity', 0.01, opacity);
56
- return baseAnimation(isIos).addAnimation([menuAnimation, backdropAnimation]);
54
+ return baseAnimation(isIOS).addAnimation([menuAnimation, backdropAnimation]);
57
55
  };
58
56
 
59
57
  /**
@@ -66,6 +64,7 @@ const menuPushAnimation = (menu) => {
66
64
  let menuClosedX;
67
65
  const mode = ionicGlobal.getIonMode(menu);
68
66
  const width = menu.width;
67
+ const isIOS = mode === 'ios';
69
68
  if (menu.isEndSide) {
70
69
  contentOpenedX = -width + 'px';
71
70
  menuClosedX = width + 'px';
@@ -81,7 +80,7 @@ const menuPushAnimation = (menu) => {
81
80
  .addElement(menu.contentEl)
82
81
  .fromTo('transform', 'translateX(0px)', `translateX(${contentOpenedX})`);
83
82
  const backdropAnimation = animation.createAnimation().addElement(menu.backdropEl).fromTo('opacity', 0.01, 0.32);
84
- return baseAnimation(mode === 'ios').addAnimation([menuAnimation, contentAnimation, backdropAnimation]);
83
+ return baseAnimation(isIOS).addAnimation([menuAnimation, contentAnimation, backdropAnimation]);
85
84
  };
86
85
 
87
86
  /**
@@ -91,11 +90,12 @@ const menuPushAnimation = (menu) => {
91
90
  */
92
91
  const menuRevealAnimation = (menu) => {
93
92
  const mode = ionicGlobal.getIonMode(menu);
93
+ const isIOS = mode === 'ios';
94
94
  const openedX = menu.width * (menu.isEndSide ? -1 : 1) + 'px';
95
95
  const contentOpen = animation.createAnimation()
96
96
  .addElement(menu.contentEl) // REVIEW
97
97
  .fromTo('transform', 'translateX(0px)', `translateX(${openedX})`);
98
- return baseAnimation(mode === 'ios').addAnimation(contentOpen);
98
+ return baseAnimation(isIOS).addAnimation(contentOpen);
99
99
  };
100
100
 
101
101
  const createMenuController = () => {
@@ -170,7 +170,7 @@ const createMenuController = () => {
170
170
  const menuRefs = menus.filter((m) => m.side === menu && !m.disabled);
171
171
  if (menuRefs.length >= 1) {
172
172
  if (menuRefs.length > 1 && logOnMultipleSideMenus) {
173
- index$1.printIonWarning(`menuController queried for a menu on the "${menu}" side, but ${menuRefs.length} menus were found. The first menu reference will be used. If this is not the behavior you want then pass the ID of the menu instead of its side.`, menuRefs.map((m) => m.el));
173
+ index.printIonWarning(`menuController queried for a menu on the "${menu}" side, but ${menuRefs.length} menus were found. The first menu reference will be used. If this is not the behavior you want then pass the ID of the menu instead of its side.`, menuRefs.map((m) => m.el));
174
174
  }
175
175
  return menuRefs[0].el;
176
176
  }
@@ -179,7 +179,7 @@ const createMenuController = () => {
179
179
  const sideMenuRefs = menus.filter((m) => m.side === menu);
180
180
  if (sideMenuRefs.length >= 1) {
181
181
  if (sideMenuRefs.length > 1 && logOnMultipleSideMenus) {
182
- index$1.printIonWarning(`menuController queried for a menu on the "${menu}" side, but ${sideMenuRefs.length} menus were found. The first menu reference will be used. If this is not the behavior you want then pass the ID of the menu instead of its side.`, sideMenuRefs.map((m) => m.el));
182
+ index.printIonWarning(`menuController queried for a menu on the "${menu}" side, but ${sideMenuRefs.length} menus were found. The first menu reference will be used. If this is not the behavior you want then pass the ID of the menu instead of its side.`, sideMenuRefs.map((m) => m.el));
183
183
  }
184
184
  return sideMenuRefs[0].el;
185
185
  }
@@ -275,10 +275,10 @@ const createMenuController = () => {
275
275
  registerAnimation('reveal', menuRevealAnimation);
276
276
  registerAnimation('push', menuPushAnimation);
277
277
  registerAnimation('overlay', menuOverlayAnimation);
278
- index.doc === null || index.doc === void 0 ? void 0 : index.doc.addEventListener('ionBackButton', (ev) => {
278
+ ionicGlobal.doc === null || ionicGlobal.doc === void 0 ? void 0 : ionicGlobal.doc.addEventListener('ionBackButton', (ev) => {
279
279
  const openMenu = _getOpenSync();
280
280
  if (openMenu) {
281
- ev.detail.register(hardwareBackButton.MENU_BACK_BUTTON_PRIORITY, () => {
281
+ ev.detail.register(ionicGlobal.MENU_BACK_BUTTON_PRIORITY, () => {
282
282
  return openMenu.close();
283
283
  });
284
284
  }
@@ -3,8 +3,8 @@
3
3
  */
4
4
  'use strict';
5
5
 
6
- var helpers = require('./helpers-DrTqNghc.js');
7
- var index = require('./index-D6Wc6v08.js');
6
+ var helpers = require('./helpers-DF1tCuxf.js');
7
+ var index = require('./index-DjlJwy91.js');
8
8
 
9
9
  const ION_CONTENT_TAG_NAME = 'ION-CONTENT';
10
10
  const ION_CONTENT_ELEMENT_SELECTOR = 'ion-content';