@ionic/core 8.8.11 → 8.8.12-dev.11781793379.156d3260
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/index.js +1 -1
- package/components/ion-accordion-group.js +1 -1
- package/components/ion-accordion.js +1 -1
- package/components/ion-action-sheet.js +1 -1
- package/components/ion-alert.js +1 -1
- package/components/ion-app.js +1 -1
- package/components/ion-avatar.js +1 -1
- package/components/ion-back-button.js +1 -1
- package/components/ion-backdrop.js +1 -1
- package/components/ion-badge.js +1 -1
- package/components/ion-breadcrumb.js +1 -1
- package/components/ion-breadcrumbs.js +1 -1
- package/components/ion-button.js +1 -1
- package/components/ion-buttons.js +1 -1
- package/components/ion-card-content.js +1 -1
- package/components/ion-card-header.js +1 -1
- package/components/ion-card-subtitle.js +1 -1
- package/components/ion-card-title.js +1 -1
- package/components/ion-card.js +1 -1
- package/components/ion-checkbox.js +1 -1
- package/components/ion-chip.js +1 -1
- package/components/ion-col.js +1 -1
- package/components/ion-content.js +1 -1
- package/components/ion-datetime-button.js +1 -1
- package/components/ion-datetime.js +1 -1
- package/components/ion-divider.d.ts +11 -0
- package/components/ion-divider.js +4 -0
- package/components/ion-fab-button.js +1 -1
- package/components/ion-fab-list.js +1 -1
- package/components/ion-fab.js +1 -1
- package/components/ion-footer.js +1 -1
- package/components/ion-gallery-item.d.ts +11 -0
- package/components/ion-gallery-item.js +4 -0
- package/components/ion-gallery.d.ts +11 -0
- package/components/ion-gallery.js +4 -0
- package/components/ion-grid.js +1 -1
- package/components/ion-header.js +1 -1
- package/components/ion-icon.js +1 -1
- package/components/ion-img.js +1 -1
- package/components/ion-infinite-scroll-content.js +1 -1
- package/components/ion-infinite-scroll.js +1 -1
- package/components/ion-input-otp.js +1 -1
- package/components/ion-input-password-toggle.js +1 -1
- package/components/ion-input.js +1 -1
- package/components/ion-item-divider.js +1 -1
- package/components/ion-item-group.js +1 -1
- package/components/ion-item-option.js +1 -1
- package/components/ion-item-options.js +1 -1
- package/components/ion-item-sliding.js +1 -1
- package/components/ion-item.js +1 -1
- package/components/ion-label.js +1 -1
- package/components/ion-list-header.js +1 -1
- package/components/ion-list.js +1 -1
- package/components/ion-loading.js +1 -1
- package/components/ion-menu-button.js +1 -1
- package/components/ion-menu-toggle.js +1 -1
- package/components/ion-menu.js +1 -1
- package/components/ion-modal.js +1 -1
- package/components/ion-nav-link.js +1 -1
- package/components/ion-nav.js +1 -1
- package/components/ion-note.js +1 -1
- package/components/ion-picker-column-option.js +1 -1
- package/components/ion-picker-column.js +1 -1
- package/components/ion-picker-legacy-column.js +1 -1
- package/components/ion-picker-legacy.js +1 -1
- package/components/ion-picker.js +1 -1
- package/components/ion-popover.js +1 -1
- package/components/ion-progress-bar.js +1 -1
- package/components/ion-radio-group.js +1 -1
- package/components/ion-radio.js +1 -1
- package/components/ion-range.js +1 -1
- package/components/ion-refresher-content.js +1 -1
- package/components/ion-refresher.js +1 -1
- package/components/ion-reorder-group.js +1 -1
- package/components/ion-reorder.js +1 -1
- package/components/ion-ripple-effect.js +1 -1
- package/components/ion-route-redirect.js +1 -1
- package/components/ion-route.js +1 -1
- package/components/ion-router-link.js +1 -1
- package/components/ion-router-outlet.js +1 -1
- package/components/ion-router.js +1 -1
- package/components/ion-row.js +1 -1
- package/components/ion-searchbar.js +1 -1
- package/components/ion-segment-button.js +1 -1
- package/components/ion-segment-content.js +1 -1
- package/components/ion-segment-view.js +1 -1
- package/components/ion-segment.js +1 -1
- package/components/ion-select-modal.js +1 -1
- package/components/ion-select-option.js +1 -1
- package/components/ion-select-popover.js +1 -1
- package/components/ion-select.js +1 -1
- package/components/ion-skeleton-text.js +1 -1
- package/components/ion-spinner.js +1 -1
- package/components/ion-split-pane.js +1 -1
- package/components/ion-tab-bar.js +1 -1
- package/components/ion-tab-button.js +1 -1
- package/components/ion-tab.js +1 -1
- package/components/ion-tabs.js +1 -1
- package/components/ion-text.js +1 -1
- package/components/ion-textarea.js +1 -1
- package/components/ion-thumbnail.js +1 -1
- package/components/ion-title.js +1 -1
- package/components/ion-toast.js +1 -1
- package/components/ion-toggle.js +1 -1
- package/components/ion-toolbar.js +1 -1
- package/components/p-B59jk20F.js +4 -0
- package/components/p-B8xhFBOE.js +4 -0
- package/components/p-BDqjX7Z_.js +4 -0
- package/components/p-BI03N_8J.js +4 -0
- package/components/p-BISCDmUD.js +4 -0
- package/components/{p-C4t5ymfq.js → p-BKSylJVh.js} +1 -1
- package/components/p-BKfkCIKU.js +4 -0
- package/components/p-BLlJA2Q9.js +4 -0
- package/components/p-BYSs-jZz.js +4 -0
- package/components/p-BYZR_5L4.js +4 -0
- package/components/p-BaPtaYEC.js +4 -0
- package/components/{p-BAYYcg3o.js → p-BbmXEfTR.js} +1 -1
- package/components/p-BiG3Zevl.js +4 -0
- package/components/p-BjW8SOqw.js +4 -0
- package/components/p-BoWc8hp0.js +4 -0
- package/components/p-BqRIq3ti.js +4 -0
- package/components/p-BskJOMNV.js +4 -0
- package/components/p-BwKpO3Is.js +4 -0
- package/components/p-BxA8Ha5k.js +4 -0
- package/components/p-BxnlgSC0.js +4 -0
- package/components/p-C9QYu-sR.js +4 -0
- package/components/p-CEY-R8M2.js +4 -0
- package/components/p-CEbQglhY.js +4 -0
- package/components/p-CGwI_XL6.js +4 -0
- package/components/p-CIdlZzoM.js +4 -0
- package/components/p-CODBQrPj.js +4 -0
- package/components/p-CWq1hA4y.js +4 -0
- package/components/p-CeL9Glto.js +4 -0
- package/components/p-Ck_9SoHZ.js +4 -0
- package/components/p-Cl94E1nn.js +4 -0
- package/components/p-CmnPD02Z.js +4 -0
- package/components/p-Cog60JgJ.js +4 -0
- package/components/p-CtaqMPhV.js +4 -0
- package/components/p-CyGaZ-Qb.js +4 -0
- package/components/p-CzFNvOq3.js +4 -0
- package/components/p-Czw29-II.js +4 -0
- package/components/p-D0Iqw6OZ.js +4 -0
- package/components/p-D1t981Ih.js +4 -0
- package/components/p-D4UIY4kz.js +4 -0
- package/components/p-D6oKOaRz.js +4 -0
- package/components/p-D6un2jDV.js +4 -0
- package/components/p-D9583Eo8.js +4 -0
- package/components/p-DABI8XVx.js +4 -0
- package/components/p-DBXSwfLt.js +4 -0
- package/components/p-DEZQwbtZ.js +4 -0
- package/components/p-DEnOtJ3m.js +4 -0
- package/components/p-DJw3WM2A.js +4 -0
- package/{dist/ionic/p-D13Eaw-8.js → components/p-DP96lPOT.js} +1 -1
- package/components/{p-DqLB8yFQ.js → p-DRnK3A-V.js} +1 -1
- package/components/p-DTmj4D2t.js +4 -0
- package/components/p-DaJxRxSQ.js +4 -0
- package/components/p-Daj5LWIm.js +4 -0
- package/components/p-Dg8OSVcP.js +4 -0
- package/components/p-Dhi5xtNS.js +4 -0
- package/components/p-DiKh2eQw.js +4 -0
- package/{dist/ionic/p-VAemlbDS.js → components/p-DmVUl5t4.js} +1 -1
- package/components/p-Dn77l_LX.js +4 -0
- package/components/{p-D5Ubpm7D.js → p-Dqgyr3aJ.js} +1 -1
- package/components/{p-cyNmxje6.js → p-Fagxa-Vi.js} +1 -1
- package/components/p-I0lsm6wZ.js +4 -0
- package/components/p-TaMIMwf5.js +4 -0
- package/components/p-ZOOvnqsf.js +4 -0
- package/components/p-ZWbVyMi6.js +4 -0
- package/components/p-_rgGxkzx.js +4 -0
- package/components/p-fIOYmaqA.js +4 -0
- package/components/p-vXpMhGrs.js +4 -0
- package/css/core.css +1 -1
- package/css/core.css.map +1 -1
- package/css/display.css +1 -1
- package/css/display.css.map +1 -1
- package/css/flex-utils.css +1 -1
- package/css/flex-utils.css.map +1 -1
- package/css/float-elements.css.map +1 -1
- package/css/global.bundle.css.map +1 -1
- package/css/ionic/bundle.ionic.css +1 -0
- package/css/ionic/bundle.ionic.css.map +1 -0
- package/css/ionic/core.ionic.css +1 -0
- package/css/ionic/core.ionic.css.map +1 -0
- package/css/ionic/global.bundle.ionic.css +1 -0
- package/css/ionic/global.bundle.ionic.css.map +1 -0
- package/css/ionic/ionic-swiper.ionic.css +1 -0
- package/css/ionic/ionic-swiper.ionic.css.map +1 -0
- package/css/ionic/link.ionic.css +1 -0
- package/css/ionic/link.ionic.css.map +1 -0
- package/css/ionic/structure.ionic.css +1 -0
- package/css/ionic/structure.ionic.css.map +1 -0
- package/css/ionic/typography.ionic.css +1 -0
- package/css/ionic/typography.ionic.css.map +1 -0
- package/css/ionic/utils.bundle.ionic.css +1 -0
- package/css/ionic/utils.bundle.ionic.css.map +1 -0
- package/css/ionic-swiper.css +1 -1
- package/css/ionic-swiper.css.map +1 -1
- package/css/ionic.bundle.css +1 -1
- package/css/ionic.bundle.css.map +1 -1
- package/css/normalize.css.map +1 -1
- package/css/padding.css.map +1 -1
- package/css/palettes/dark.always.css.map +1 -1
- package/css/palettes/dark.class.css.map +1 -1
- package/css/palettes/dark.system.css.map +1 -1
- package/css/palettes/high-contrast-dark.always.css.map +1 -1
- package/css/palettes/high-contrast-dark.class.css.map +1 -1
- package/css/palettes/high-contrast-dark.system.css.map +1 -1
- package/css/palettes/high-contrast.always.css.map +1 -1
- package/css/palettes/high-contrast.class.css.map +1 -1
- package/css/palettes/high-contrast.system.css.map +1 -1
- package/css/structure.css.map +1 -1
- package/css/text-alignment.css.map +1 -1
- package/css/text-transformation.css.map +1 -1
- package/css/typography.css.map +1 -1
- package/css/utils.bundle.css +1 -1
- package/css/utils.bundle.css.map +1 -1
- package/dist/cjs/{animation-BJq0kcy2.js → animation-B3xfVcDO.js} +3 -3
- package/dist/cjs/{app-globals-BlqrqKTN.js → app-globals-3ZoCVkn-.js} +1 -1
- package/dist/cjs/{button-active-0mPOKmV2.js → button-active-3tZKuPbT.js} +2 -2
- package/dist/cjs/{capacitor-DmA66EwP.js → capacitor-CQSg1uCo.js} +3 -3
- package/dist/cjs/caret-down-vtVgfXIs.js +8 -0
- package/dist/cjs/caret-left-CxZXLRv5.js +8 -0
- package/dist/cjs/caret-right-CRCgv98E.js +8 -0
- package/dist/cjs/config-DWdFbSNK.js +35 -0
- package/dist/cjs/{data-DLTUw-KF.js → data-DmCm0SEx.js} +6 -6
- package/dist/cjs/{focus-visible-CCvKiLh3.js → focus-visible-BIj-I3-C.js} +24 -0
- package/dist/cjs/{framework-delegate-BtICZDHr.js → framework-delegate-DC5nq_NN.js} +4 -2
- package/dist/cjs/{haptic-ClPPQ_PS.js → haptic-eix26ESE.js} +1 -1
- package/dist/cjs/{helpers-Cv23MFHM.js → helpers-DiOgV5hw.js} +71 -4
- package/dist/cjs/{index-BERfRao3.js → index-BaJ7_YbC.js} +4 -4
- package/dist/cjs/{index-CIrkNXqJ.js → index-BxEZd5IE.js} +2 -2
- package/dist/cjs/{index-DqmRDbxg.js → index-CgAbCW6L.js} +2 -0
- package/dist/cjs/index-CzFol6Yk.js +414 -0
- package/dist/cjs/{index-aC4x3Fk3.js → index-DYRcC3bw.js} +15 -15
- package/dist/cjs/{index-Ct7gcRif.js → index-GZU9YrFc.js} +41 -4
- package/dist/cjs/{index-D81eLYUM.js → index-bX3nz2vw.js} +9 -8
- package/dist/cjs/index.cjs.js +16 -16
- package/dist/cjs/{input-shims-CFLg7uzj.js → input-shims-BSEBw22J.js} +18 -17
- package/dist/cjs/{input.utils-DetjmtH2.js → input.utils-D68wgI2Y.js} +5 -5
- package/dist/cjs/ion-accordion_2.cjs.entry.js +61 -29
- package/dist/cjs/ion-action-sheet.cjs.entry.js +41 -22
- package/dist/cjs/ion-alert.cjs.entry.js +78 -41
- package/dist/cjs/ion-app_8.cjs.entry.js +292 -157
- package/dist/cjs/ion-avatar_3.cjs.entry.js +125 -13
- package/dist/cjs/ion-back-button.cjs.entry.js +31 -22
- package/dist/cjs/ion-backdrop.cjs.entry.js +10 -7
- package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +54 -18
- package/dist/cjs/ion-button_2.cjs.entry.js +59 -22
- package/dist/cjs/ion-card_5.cjs.entry.js +55 -33
- package/dist/cjs/ion-checkbox.cjs.entry.js +37 -17
- package/dist/cjs/ion-chip.cjs.entry.js +50 -9
- package/dist/cjs/ion-col_3.cjs.entry.js +56 -57
- package/dist/cjs/ion-datetime-button.cjs.entry.js +13 -9
- package/dist/cjs/ion-datetime_3.cjs.entry.js +116 -41
- package/dist/cjs/ion-divider.cjs.entry.js +51 -0
- package/dist/cjs/ion-fab_3.cjs.entry.js +44 -28
- package/dist/cjs/ion-gallery-item.cjs.entry.js +59 -0
- package/dist/cjs/ion-gallery.cjs.entry.js +607 -0
- package/dist/cjs/ion-img.cjs.entry.js +8 -4
- package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +93 -17
- package/dist/cjs/ion-input-otp.cjs.entry.js +74 -9
- package/dist/cjs/ion-input-password-toggle.cjs.entry.js +53 -15
- package/dist/cjs/ion-input.cjs.entry.js +124 -34
- package/dist/cjs/ion-item-option_3.cjs.entry.js +467 -52
- package/dist/cjs/ion-item_8.cjs.entry.js +121 -50
- package/dist/cjs/ion-loading.cjs.entry.js +22 -19
- package/dist/cjs/ion-menu_3.cjs.entry.js +47 -29
- package/dist/cjs/ion-modal.cjs.entry.js +262 -138
- package/dist/cjs/ion-nav_2.cjs.entry.js +14 -11
- package/dist/cjs/ion-picker-column-option.cjs.entry.js +12 -8
- package/dist/cjs/ion-picker-column.cjs.entry.js +14 -14
- package/dist/cjs/ion-picker.cjs.entry.js +10 -6
- package/dist/cjs/ion-popover.cjs.entry.js +21 -19
- package/dist/cjs/ion-progress-bar.cjs.entry.js +27 -9
- package/dist/cjs/ion-radio_2.cjs.entry.js +35 -17
- package/dist/cjs/ion-range.cjs.entry.js +20 -13
- package/dist/cjs/ion-refresher_2.cjs.entry.js +42 -23
- package/dist/cjs/ion-reorder_2.cjs.entry.js +38 -14
- package/dist/cjs/ion-ripple-effect.cjs.entry.js +15 -7
- package/dist/cjs/ion-route_4.cjs.entry.js +11 -10
- package/dist/cjs/ion-searchbar.cjs.entry.js +137 -24
- package/dist/cjs/ion-segment-content.cjs.entry.js +2 -2
- package/dist/cjs/ion-segment-view.cjs.entry.js +13 -3
- package/dist/cjs/ion-segment_2.cjs.entry.js +23 -16
- package/dist/cjs/ion-select-modal.cjs.entry.js +114 -38
- package/dist/cjs/ion-select_3.cjs.entry.js +556 -107
- package/dist/cjs/ion-spinner.cjs.entry.js +30 -8
- package/dist/cjs/ion-split-pane.cjs.entry.js +13 -9
- package/dist/cjs/ion-tab-bar_2.cjs.entry.js +147 -23
- package/dist/cjs/ion-tab_2.cjs.entry.js +8 -7
- package/dist/cjs/ion-text.cjs.entry.js +7 -7
- package/dist/cjs/ion-textarea.cjs.entry.js +137 -23
- package/dist/cjs/ion-toast.cjs.entry.js +70 -46
- package/dist/cjs/ion-toggle.cjs.entry.js +82 -25
- package/dist/cjs/ionic-global-QoUqobrQ.js +519 -0
- package/dist/cjs/ionic.cjs.js +4 -4
- package/dist/cjs/{ios.transition-BOSWOaiK.js → ios.transition-DpFQfFfT.js} +7 -5
- package/dist/cjs/{keyboard-UuAS4D_9.js → keyboard-Bn0Ppim6.js} +1 -1
- package/dist/cjs/{keyboard-controller-GXBiBRKS.js → keyboard-controller-CefyW9lm.js} +11 -9
- package/dist/cjs/{keyboard-hHzlEQpk.js → keyboard-faZBQysj.js} +4 -3
- package/dist/cjs/list-a-7GSA6K.js +8 -0
- package/dist/cjs/loader.cjs.js +4 -4
- package/dist/cjs/{md.transition-B8-wBZqt.js → md.transition-ChJcoZUH.js} +6 -5
- package/dist/cjs/{notch-controller-18PzRGXd.js → notch-controller-BO0UGB4F.js} +4 -4
- package/dist/cjs/overlay-control-label-DnRLQR1t.js +52 -0
- package/dist/cjs/{overlays-TbKsuC-K.js → overlays-xkzfBAc_.js} +309 -18
- package/dist/cjs/select-option-render-8XQ4CgCm.js +116 -0
- package/dist/cjs/{status-tap-BXX8H8_Y.js → status-tap-x2qDo5QR.js} +4 -3
- package/dist/cjs/{swipe-back-C0GCB18x.js → swipe-back-CvZt_4YX.js} +3 -2
- package/dist/cjs/{theme-CeDs6Hcv.js → theme-IlOsGAz7.js} +25 -1
- package/dist/cjs/validity-QmuwEptc.js +51 -0
- package/dist/cjs/x-BTF99yFH.js +8 -0
- package/dist/collection/collection-manifest.json +9 -1
- package/dist/collection/components/accordion/accordion.ionic.css +201 -0
- package/dist/collection/components/accordion/accordion.ios.css +73 -58
- package/dist/collection/components/accordion/accordion.js +41 -27
- package/dist/collection/components/accordion/accordion.md.css +67 -59
- package/dist/collection/components/accordion-group/accordion-group.ionic.css +93 -0
- package/dist/collection/components/accordion-group/accordion-group.ios.css +16 -4
- package/dist/collection/components/accordion-group/accordion-group.js +44 -8
- package/dist/collection/components/accordion-group/accordion-group.md.css +22 -4
- package/dist/collection/components/action-sheet/action-sheet.ionic.css +491 -0
- package/dist/collection/components/action-sheet/action-sheet.ios.css +368 -11
- package/dist/collection/components/action-sheet/action-sheet.js +32 -13
- package/dist/collection/components/action-sheet/action-sheet.md.css +307 -10
- package/dist/collection/components/alert/alert.ionic.css +784 -0
- package/dist/collection/components/alert/alert.ios.css +482 -19
- package/dist/collection/components/alert/alert.js +67 -30
- package/dist/collection/components/alert/alert.md.css +465 -29
- package/dist/collection/components/app/app.js +15 -83
- package/dist/collection/components/avatar/avatar.ionic.css +391 -0
- package/dist/collection/components/avatar/avatar.ios.css +7 -33
- package/dist/collection/components/avatar/avatar.js +120 -4
- package/dist/collection/components/avatar/avatar.md.css +51 -0
- package/dist/collection/components/back-button/back-button.ios.css +60 -48
- package/dist/collection/components/back-button/back-button.js +27 -19
- package/dist/collection/components/back-button/back-button.md.css +60 -48
- package/dist/collection/components/backdrop/backdrop.ionic.css +109 -0
- package/dist/collection/components/backdrop/backdrop.ios.css +56 -19
- package/dist/collection/components/backdrop/backdrop.js +12 -6
- package/dist/collection/components/backdrop/backdrop.md.css +56 -19
- package/dist/collection/components/badge/badge.ionic.css +275 -0
- package/dist/collection/components/badge/badge.ios.css +139 -12
- package/dist/collection/components/badge/badge.js +145 -9
- package/dist/collection/components/badge/badge.md.css +123 -12
- package/dist/collection/components/breadcrumb/breadcrumb.ios.css +20 -8
- package/dist/collection/components/breadcrumb/breadcrumb.js +43 -11
- package/dist/collection/components/breadcrumb/breadcrumb.md.css +20 -8
- package/dist/collection/components/breadcrumbs/breadcrumbs.ios.css +6 -0
- package/dist/collection/components/breadcrumbs/breadcrumbs.js +11 -9
- package/dist/collection/components/breadcrumbs/breadcrumbs.md.css +6 -0
- package/dist/collection/components/button/button.ionic.css +646 -0
- package/dist/collection/components/button/button.ios.css +154 -46
- package/dist/collection/components/button/button.js +63 -27
- package/dist/collection/components/button/button.md.css +150 -50
- package/dist/collection/components/buttons/buttons.ionic.css +97 -0
- package/dist/collection/components/buttons/buttons.ios.css +59 -7
- package/dist/collection/components/buttons/buttons.js +15 -9
- package/dist/collection/components/buttons/buttons.md.css +55 -3
- package/dist/collection/components/card/card.ionic.css +144 -0
- package/dist/collection/components/card/card.ios.css +65 -14
- package/dist/collection/components/card/card.js +41 -10
- package/dist/collection/components/card/card.md.css +65 -14
- package/dist/collection/components/card-content/card-content.ionic.css +89 -0
- package/dist/collection/components/card-content/card-content.ios.css +20 -35
- package/dist/collection/components/card-content/card-content.js +12 -10
- package/dist/collection/components/card-content/card-content.md.css +20 -35
- package/dist/collection/components/card-header/card-header.ionic.css +85 -0
- package/dist/collection/components/card-header/card-header.ios.css +27 -15
- package/dist/collection/components/card-header/card-header.js +13 -10
- package/dist/collection/components/card-header/card-header.md.css +27 -15
- package/dist/collection/components/card-subtitle/card-subtitle.ionic.css +144 -0
- package/dist/collection/components/card-subtitle/card-subtitle.ios.css +12 -0
- package/dist/collection/components/card-subtitle/card-subtitle.js +11 -8
- package/dist/collection/components/card-subtitle/card-subtitle.md.css +12 -0
- package/dist/collection/components/card-title/card-title.ios.css +73 -0
- package/dist/collection/components/card-title/card-title.js +11 -8
- package/dist/collection/components/card-title/card-title.md.css +73 -0
- package/dist/collection/components/checkbox/checkbox.ionic.css +543 -0
- package/dist/collection/components/checkbox/checkbox.ios.css +163 -99
- package/dist/collection/components/checkbox/checkbox.js +73 -15
- package/dist/collection/components/checkbox/checkbox.md.css +164 -100
- package/dist/collection/components/chip/chip.ionic.css +217 -0
- package/dist/collection/components/chip/chip.ios.css +67 -14
- package/dist/collection/components/chip/chip.js +108 -8
- package/dist/collection/components/chip/chip.md.css +67 -14
- package/dist/collection/components/col/col.css +192 -4
- package/dist/collection/components/col/col.js +211 -61
- package/dist/collection/components/content/content.css +8 -2
- package/dist/collection/components/content/content.js +16 -11
- package/dist/collection/components/datetime/datetime.ionic.css +703 -0
- package/dist/collection/components/datetime/datetime.ios.css +302 -106
- package/dist/collection/components/datetime/datetime.js +98 -20
- package/dist/collection/components/datetime/datetime.md.css +293 -96
- package/dist/collection/components/datetime/utils/data.js +5 -5
- package/dist/collection/components/datetime-button/datetime-button.ios.css +6 -0
- package/dist/collection/components/datetime-button/datetime-button.js +11 -8
- package/dist/collection/components/datetime-button/datetime-button.md.css +6 -0
- package/dist/collection/components/divider/divider.ionic.css +148 -0
- package/dist/collection/components/divider/divider.ios.css +87 -0
- package/dist/collection/components/divider/divider.js +94 -0
- package/dist/collection/components/divider/divider.md.css +87 -0
- package/dist/collection/components/fab/fab.css +25 -1
- package/dist/collection/components/fab/fab.js +9 -5
- package/dist/collection/components/fab-button/fab-button.ios.css +18 -6
- package/dist/collection/components/fab-button/fab-button.js +36 -21
- package/dist/collection/components/fab-button/fab-button.md.css +20 -8
- package/dist/collection/components/fab-list/fab-list.css +12 -0
- package/dist/collection/components/fab-list/fab-list.js +9 -5
- package/dist/collection/components/footer/footer.ios.css +14 -2
- package/dist/collection/components/footer/footer.js +21 -16
- package/dist/collection/components/footer/footer.md.css +12 -0
- package/dist/collection/components/gallery/gallery-constants.js +12 -0
- package/dist/collection/components/gallery/gallery-interface.js +1 -0
- package/dist/collection/components/gallery/gallery.css +15 -0
- package/dist/collection/components/gallery/gallery.js +679 -0
- package/dist/collection/components/gallery/test/utils.js +100 -0
- package/dist/collection/components/gallery-item/gallery-item.css +49 -0
- package/dist/collection/components/gallery-item/gallery-item.js +99 -0
- package/dist/collection/components/grid/grid.css +12 -0
- package/dist/collection/components/grid/grid.js +9 -5
- package/dist/collection/components/header/header.ionic.css +97 -0
- package/dist/collection/components/header/header.ios.css +25 -10
- package/dist/collection/components/header/header.js +50 -19
- package/dist/collection/components/header/header.md.css +23 -8
- package/dist/collection/components/header/header.utils.js +5 -5
- package/dist/collection/components/img/img.js +8 -2
- package/dist/collection/components/infinite-scroll/infinite-scroll.js +100 -5
- package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.ios.css +12 -0
- package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +16 -10
- package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.md.css +12 -0
- package/dist/collection/components/input/input.ionic.css +889 -0
- package/dist/collection/components/input/input.ios.css +223 -135
- package/dist/collection/components/input/input.js +148 -37
- package/dist/collection/components/input/input.md.css +193 -207
- package/dist/collection/components/input-otp/input-otp.ionic.css +371 -0
- package/dist/collection/components/input-otp/input-otp.ios.css +105 -60
- package/dist/collection/components/input-otp/input-otp.js +74 -7
- package/dist/collection/components/input-otp/input-otp.md.css +105 -60
- package/dist/collection/components/input-password-toggle/input-password-toggle.ionic.css +78 -0
- package/dist/collection/components/input-password-toggle/input-password-toggle.js +48 -12
- package/dist/collection/components/input-password-toggle/input-password-toggle.native.css +61 -0
- package/dist/collection/components/item/item.ionic.css +496 -0
- package/dist/collection/components/item/item.ios.css +109 -69
- package/dist/collection/components/item/item.js +56 -21
- package/dist/collection/components/item/item.md.css +120 -68
- package/dist/collection/components/item-divider/item-divider.ios.css +18 -0
- package/dist/collection/components/item-divider/item-divider.js +11 -8
- package/dist/collection/components/item-divider/item-divider.md.css +18 -0
- package/dist/collection/components/item-group/item-group.ios.css +12 -0
- package/dist/collection/components/item-group/item-group.js +13 -7
- package/dist/collection/components/item-group/item-group.md.css +12 -0
- package/dist/collection/components/item-option/item-option.ionic.css +278 -0
- package/dist/collection/components/item-option/item-option.ios.css +136 -29
- package/dist/collection/components/item-option/item-option.js +73 -9
- package/dist/collection/components/item-option/item-option.md.css +136 -29
- package/dist/collection/components/item-options/item-options.ionic.css +221 -0
- package/dist/collection/components/item-options/item-options.ios.css +77 -34
- package/dist/collection/components/item-options/item-options.js +13 -7
- package/dist/collection/components/item-options/item-options.md.css +77 -34
- package/dist/collection/components/item-sliding/item-sliding.ionic.css +211 -0
- package/dist/collection/components/item-sliding/item-sliding.js +421 -35
- package/dist/collection/components/item-sliding/{item-sliding.css → item-sliding.native.css} +84 -9
- package/dist/collection/components/item-sliding/test/test.utils.js +13 -0
- package/dist/collection/components/label/label.ios.css +18 -0
- package/dist/collection/components/label/label.js +11 -8
- package/dist/collection/components/label/label.md.css +18 -0
- package/dist/collection/components/list/list.ionic.css +212 -0
- package/dist/collection/components/list/list.ios.css +54 -14
- package/dist/collection/components/list/list.js +48 -9
- package/dist/collection/components/list/list.md.css +56 -16
- package/dist/collection/components/list-header/list-header.ionic.css +190 -0
- package/dist/collection/components/list-header/list-header.ios.css +82 -38
- package/dist/collection/components/list-header/list-header.js +11 -8
- package/dist/collection/components/list-header/list-header.md.css +82 -38
- package/dist/collection/components/loading/loading.ios.css +13 -1
- package/dist/collection/components/loading/loading.js +14 -11
- package/dist/collection/components/loading/loading.md.css +13 -1
- package/dist/collection/components/menu/menu.ios.css +15 -3
- package/dist/collection/components/menu/menu.js +12 -7
- package/dist/collection/components/menu/menu.md.css +15 -3
- package/dist/collection/components/menu-button/menu-button.ionic.css +236 -0
- package/dist/collection/components/menu-button/menu-button.ios.css +48 -14
- package/dist/collection/components/menu-button/menu-button.js +26 -10
- package/dist/collection/components/menu-button/menu-button.md.css +49 -15
- package/dist/collection/components/menu-toggle/menu-toggle.js +8 -5
- package/dist/collection/components/modal/animations/ionic.enter.js +40 -0
- package/dist/collection/components/modal/animations/ionic.leave.js +28 -0
- package/dist/collection/components/modal/animations/sheet.js +8 -2
- package/dist/collection/components/modal/gestures/sheet.js +76 -10
- package/dist/collection/components/modal/modal.ionic.css +247 -0
- package/dist/collection/components/modal/modal.ios.css +178 -70
- package/dist/collection/components/modal/modal.js +50 -12
- package/dist/collection/components/modal/modal.md.css +178 -70
- package/dist/collection/components/nav/nav.css +7 -1
- package/dist/collection/components/nav/nav.js +11 -5
- package/dist/collection/components/nav-link/nav-link.js +5 -1
- package/dist/collection/components/note/note.ios.css +12 -0
- package/dist/collection/components/note/note.js +11 -8
- package/dist/collection/components/note/note.md.css +12 -0
- package/dist/collection/components/picker/picker.ios.css +15 -3
- package/dist/collection/components/picker/picker.js +8 -5
- package/dist/collection/components/picker/picker.md.css +15 -3
- package/dist/collection/components/picker-column/picker-column.css +9 -2
- package/dist/collection/components/picker-column/picker-column.js +8 -7
- package/dist/collection/components/picker-column-option/picker-column-option.ios.css +6 -0
- package/dist/collection/components/picker-column-option/picker-column-option.js +13 -7
- package/dist/collection/components/picker-column-option/picker-column-option.md.css +6 -0
- package/dist/collection/components/picker-legacy/picker.ios.css +13 -1
- package/dist/collection/components/picker-legacy/picker.js +7 -6
- package/dist/collection/components/picker-legacy/picker.md.css +13 -1
- package/dist/collection/components/picker-legacy-column/picker-column.ios.css +12 -0
- package/dist/collection/components/picker-legacy-column/picker-column.js +4 -4
- package/dist/collection/components/picker-legacy-column/picker-column.md.css +12 -0
- package/dist/collection/components/popover/popover.ionic.css +290 -0
- package/dist/collection/components/popover/popover.ios.css +29 -1
- package/dist/collection/components/popover/popover.js +18 -15
- package/dist/collection/components/popover/popover.md.css +29 -1
- package/dist/collection/components/progress-bar/progress-bar.ionic.css +287 -0
- package/dist/collection/components/progress-bar/progress-bar.ios.css +48 -17
- package/dist/collection/components/progress-bar/progress-bar.js +43 -7
- package/dist/collection/components/progress-bar/progress-bar.md.css +48 -17
- package/dist/collection/components/radio/radio.ionic.css +422 -0
- package/dist/collection/components/radio/radio.ios.css +134 -91
- package/dist/collection/components/radio/radio.js +14 -9
- package/dist/collection/components/radio/radio.md.css +134 -91
- package/dist/collection/components/radio-group/radio-group.ionic.css +119 -0
- package/dist/collection/components/radio-group/radio-group.ios.css +43 -19
- package/dist/collection/components/radio-group/radio-group.js +48 -7
- package/dist/collection/components/radio-group/radio-group.md.css +43 -19
- package/dist/collection/components/range/range.ionic.css +567 -0
- package/dist/collection/components/range/range.ios.css +128 -85
- package/dist/collection/components/range/range.js +16 -10
- package/dist/collection/components/range/range.md.css +128 -85
- package/dist/collection/components/refresher/refresher.ios.css +14 -1
- package/dist/collection/components/refresher/refresher.js +11 -8
- package/dist/collection/components/refresher/refresher.md.css +15 -2
- package/dist/collection/components/refresher-content/refresher-content.js +28 -7
- package/dist/collection/components/reorder/reorder.ios.css +6 -0
- package/dist/collection/components/reorder/reorder.js +33 -6
- package/dist/collection/components/reorder/reorder.md.css +6 -0
- package/dist/collection/components/reorder-group/reorder-group.css +6 -0
- package/dist/collection/components/reorder-group/reorder-group.js +8 -4
- package/dist/collection/components/ripple-effect/{ripple-effect.css → ripple-effect.common.css} +7 -1
- package/dist/collection/components/ripple-effect/ripple-effect.ionic.css +215 -0
- package/dist/collection/components/ripple-effect/ripple-effect.js +14 -6
- package/dist/collection/components/route/route.js +4 -0
- package/dist/collection/components/router/router.js +4 -0
- package/dist/collection/components/router-link/router-link.css +8 -2
- package/dist/collection/components/router-link/router-link.js +9 -5
- package/dist/collection/components/router-outlet/router-outlet.css +7 -1
- package/dist/collection/components/router-outlet/router-outlet.js +6 -3
- package/dist/collection/components/row/row.css +16 -0
- package/dist/collection/components/row/row.js +9 -2
- package/dist/collection/components/searchbar/searchbar.ionic.css +626 -0
- package/dist/collection/components/searchbar/searchbar.ios.css +56 -18
- package/dist/collection/components/searchbar/searchbar.js +180 -33
- package/dist/collection/components/searchbar/searchbar.md.css +56 -18
- package/dist/collection/components/segment/segment.ionic.css +115 -0
- package/dist/collection/components/segment/segment.ios.css +45 -2
- package/dist/collection/components/segment/segment.js +11 -8
- package/dist/collection/components/segment/segment.md.css +45 -2
- package/dist/collection/components/segment-button/segment-button.ionic.css +353 -0
- package/dist/collection/components/segment-button/segment-button.ios.css +146 -105
- package/dist/collection/components/segment-button/segment-button.js +11 -8
- package/dist/collection/components/segment-button/segment-button.md.css +148 -107
- package/dist/collection/components/segment-content/segment-content.js +1 -1
- package/dist/collection/components/segment-view/segment-view.ios.css +6 -0
- package/dist/collection/components/segment-view/segment-view.js +13 -4
- package/dist/collection/components/segment-view/segment-view.md.css +6 -0
- package/dist/collection/components/select/select.ionic.css +810 -0
- package/dist/collection/components/select/select.ios.css +348 -176
- package/dist/collection/components/select/select.js +521 -92
- package/dist/collection/components/select/select.md.css +364 -178
- package/dist/collection/components/select-modal/select-modal.ionic.css +254 -0
- package/dist/collection/components/select-modal/select-modal.ios.css +467 -0
- package/dist/collection/components/select-modal/select-modal.js +126 -30
- package/dist/collection/components/select-modal/select-modal.md.css +395 -0
- package/dist/collection/components/select-option/select-option.js +70 -2
- package/dist/collection/components/select-popover/select-popover.ionic.css +252 -0
- package/dist/collection/components/select-popover/select-popover.ios.css +303 -20
- package/dist/collection/components/select-popover/select-popover.js +89 -29
- package/dist/collection/components/select-popover/select-popover.md.css +346 -0
- package/dist/collection/components/skeleton-text/skeleton-text.css +6 -0
- package/dist/collection/components/skeleton-text/skeleton-text.js +9 -5
- package/dist/collection/components/spinner/{spinner.css → spinner.ionic.css} +78 -10
- package/dist/collection/components/spinner/spinner.js +47 -6
- package/dist/collection/components/spinner/spinner.native.css +199 -0
- package/dist/collection/components/split-pane/split-pane.ios.css +20 -2
- package/dist/collection/components/split-pane/split-pane.js +15 -8
- package/dist/collection/components/split-pane/split-pane.md.css +20 -2
- package/dist/collection/components/tab/tab.js +6 -2
- package/dist/collection/components/tab-bar/tab-bar.ionic.css +227 -0
- package/dist/collection/components/tab-bar/tab-bar.ios.css +71 -43
- package/dist/collection/components/tab-bar/tab-bar.js +171 -13
- package/dist/collection/components/tab-bar/tab-bar.md.css +71 -43
- package/dist/collection/components/tab-button/tab-button.ionic.css +348 -0
- package/dist/collection/components/tab-button/tab-button.ios.css +171 -95
- package/dist/collection/components/tab-button/tab-button.js +54 -9
- package/dist/collection/components/tab-button/tab-button.md.css +137 -93
- package/dist/collection/components/tabs/tabs.css +7 -1
- package/dist/collection/components/tabs/tabs.js +4 -1
- package/dist/collection/components/text/text.css +6 -0
- package/dist/collection/components/text/text.js +7 -6
- package/dist/collection/components/textarea/textarea.ionic.css +898 -0
- package/dist/collection/components/textarea/textarea.ios.css +298 -158
- package/dist/collection/components/textarea/textarea.js +162 -24
- package/dist/collection/components/textarea/textarea.md.css +312 -159
- package/dist/collection/components/thumbnail/thumbnail.css +6 -0
- package/dist/collection/components/thumbnail/thumbnail.js +9 -2
- package/dist/collection/components/title/title.ionic.css +127 -0
- package/dist/collection/components/title/title.ios.css +32 -4
- package/dist/collection/components/title/title.js +13 -7
- package/dist/collection/components/title/title.md.css +32 -4
- package/dist/collection/components/toast/animations/utils.js +1 -1
- package/dist/collection/components/toast/toast.ionic.css +394 -0
- package/dist/collection/components/toast/toast.ios.css +84 -45
- package/dist/collection/components/toast/toast.js +76 -13
- package/dist/collection/components/toast/toast.md.css +84 -45
- package/dist/collection/components/toggle/toggle.ionic.css +508 -0
- package/dist/collection/components/toggle/toggle.ios.css +247 -131
- package/dist/collection/components/toggle/toggle.js +73 -18
- package/dist/collection/components/toggle/toggle.md.css +244 -131
- package/dist/collection/components/toolbar/test/image.svg +1 -0
- package/dist/collection/components/toolbar/toolbar.ionic.css +249 -0
- package/dist/collection/components/toolbar/toolbar.ios.css +90 -47
- package/dist/collection/components/toolbar/toolbar.js +218 -13
- package/dist/collection/components/toolbar/toolbar.md.css +90 -47
- package/dist/collection/global/ionic-global.js +241 -13
- package/dist/collection/utils/css-value-validation.js +39 -0
- package/dist/collection/utils/focus-trap.js +13 -2
- package/dist/collection/utils/focus-visible.js +22 -0
- package/dist/collection/utils/forms/validity.js +31 -0
- package/dist/collection/utils/framework-delegate.js +3 -1
- package/dist/collection/utils/hardware-back-button.js +15 -0
- package/dist/collection/utils/helpers.js +70 -3
- package/dist/collection/utils/keyboard/keyboard-controller.js +3 -1
- package/dist/collection/utils/media.js +1 -0
- package/dist/collection/utils/menu-controller/animations/overlay.js +3 -3
- package/dist/collection/utils/menu-controller/animations/push.js +2 -1
- package/dist/collection/utils/menu-controller/animations/reveal.js +2 -1
- package/dist/collection/utils/overlay-control-label.js +47 -0
- package/dist/collection/utils/overlays.js +290 -8
- package/dist/collection/utils/sanitization/index.js +255 -14
- package/dist/collection/utils/select-option-render.js +111 -0
- package/dist/collection/utils/test/playwright/drag-element.js +32 -9
- package/dist/collection/utils/test/playwright/generator.js +48 -23
- package/dist/collection/utils/test/playwright/page/utils/goto.js +14 -5
- package/dist/collection/utils/test/playwright/page/utils/set-content.js +26 -3
- package/dist/collection/utils/theme.js +25 -1
- package/dist/collection/utils/transition/ios.transition.js +1 -0
- package/dist/docs.json +8975 -283
- package/dist/esm/{animation-DLJpuoEz.js → animation-B2qdQ_ou.js} +2 -2
- package/dist/esm/{app-globals-D0C5S4hU.js → app-globals-DZ-iIjxA.js} +1 -1
- package/dist/esm/{button-active-BSpTQmS9.js → button-active-BmajAby6.js} +2 -2
- package/dist/esm/{capacitor-CFERIeaU.js → capacitor-CtQSWUU0.js} +1 -1
- package/dist/esm/caret-down-D1t981Ih.js +6 -0
- package/dist/esm/caret-left-fIOYmaqA.js +6 -0
- package/dist/esm/caret-right-BYSs-jZz.js +6 -0
- package/dist/esm/config-BwKpO3Is.js +31 -0
- package/dist/esm/{data-DZI70dKr.js → data-CPP_AdEM.js} +6 -6
- package/dist/esm/{focus-visible-BmVRXR1y.js → focus-visible-vXpMhGrs.js} +23 -1
- package/dist/esm/{framework-delegate-FnPGymXL.js → framework-delegate-DO2QXccA.js} +4 -2
- package/dist/esm/{haptic-DzAMWJuk.js → haptic-DFgKNCce.js} +1 -1
- package/dist/esm/{helpers-HEqiOzXb.js → helpers-DfF5_wJc.js} +71 -5
- package/dist/esm/{index-B_dQk_WE.js → index-BIUWGRUl.js} +4 -4
- package/dist/esm/index-BUyahZJ4.js +409 -0
- package/dist/esm/{index-BRHzoo00.js → index-BjaaZqVY.js} +4 -3
- package/dist/esm/{index-tcQvqkiX.js → index-C0EQceqV.js} +41 -4
- package/dist/esm/{index-DV3sJJW8.js → index-D2tu5BUg.js} +2 -1
- package/dist/esm/{index-Q6UPU0Ay.js → index-Di034G4O.js} +11 -11
- package/dist/esm/{index-MEDq2S8l.js → index-KxK0gcRp.js} +2 -2
- package/dist/esm/index.js +14 -14
- package/dist/esm/{input-shims-D10mwcw1.js → input-shims-DvNNw70a.js} +7 -6
- package/dist/esm/{input.utils-Y6NgW8bw.js → input.utils-_LkBfBWt.js} +3 -3
- package/dist/esm/ion-accordion_2.entry.js +61 -29
- package/dist/esm/ion-action-sheet.entry.js +41 -22
- package/dist/esm/ion-alert.entry.js +77 -40
- package/dist/esm/ion-app_8.entry.js +292 -157
- package/dist/esm/ion-avatar_3.entry.js +125 -13
- package/dist/esm/ion-back-button.entry.js +31 -22
- package/dist/esm/ion-backdrop.entry.js +10 -7
- package/dist/esm/ion-breadcrumb_2.entry.js +54 -18
- package/dist/esm/ion-button_2.entry.js +59 -22
- package/dist/esm/ion-card_5.entry.js +55 -33
- package/dist/esm/ion-checkbox.entry.js +37 -17
- package/dist/esm/ion-chip.entry.js +50 -9
- package/dist/esm/ion-col_3.entry.js +56 -57
- package/dist/esm/ion-datetime-button.entry.js +13 -9
- package/dist/esm/ion-datetime_3.entry.js +116 -41
- package/dist/esm/ion-divider.entry.js +49 -0
- package/dist/esm/ion-fab_3.entry.js +44 -28
- package/dist/esm/ion-gallery-item.entry.js +57 -0
- package/dist/esm/ion-gallery.entry.js +605 -0
- package/dist/esm/ion-img.entry.js +8 -4
- package/dist/esm/ion-infinite-scroll_2.entry.js +92 -16
- package/dist/esm/ion-input-otp.entry.js +74 -9
- package/dist/esm/ion-input-password-toggle.entry.js +53 -15
- package/dist/esm/ion-input.entry.js +124 -34
- package/dist/esm/ion-item-option_3.entry.js +467 -52
- package/dist/esm/ion-item_8.entry.js +121 -50
- package/dist/esm/ion-loading.entry.js +21 -18
- package/dist/esm/ion-menu_3.entry.js +47 -29
- package/dist/esm/ion-modal.entry.js +215 -91
- package/dist/esm/ion-nav_2.entry.js +14 -11
- package/dist/esm/ion-picker-column-option.entry.js +12 -8
- package/dist/esm/ion-picker-column.entry.js +13 -13
- package/dist/esm/ion-picker.entry.js +10 -6
- package/dist/esm/ion-popover.entry.js +21 -19
- package/dist/esm/ion-progress-bar.entry.js +27 -9
- package/dist/esm/ion-radio_2.entry.js +35 -17
- package/dist/esm/ion-range.entry.js +20 -13
- package/dist/esm/ion-refresher_2.entry.js +40 -21
- package/dist/esm/ion-reorder_2.entry.js +38 -14
- package/dist/esm/ion-ripple-effect.entry.js +15 -7
- package/dist/esm/ion-route_4.entry.js +11 -10
- package/dist/esm/ion-searchbar.entry.js +137 -24
- package/dist/esm/ion-segment-content.entry.js +2 -2
- package/dist/esm/ion-segment-view.entry.js +13 -3
- package/dist/esm/ion-segment_2.entry.js +23 -16
- package/dist/esm/ion-select-modal.entry.js +114 -38
- package/dist/esm/ion-select_3.entry.js +556 -107
- package/dist/esm/ion-spinner.entry.js +30 -8
- package/dist/esm/ion-split-pane.entry.js +13 -9
- package/dist/esm/ion-tab-bar_2.entry.js +147 -23
- package/dist/esm/ion-tab_2.entry.js +8 -7
- package/dist/esm/ion-text.entry.js +7 -7
- package/dist/esm/ion-textarea.entry.js +137 -23
- package/dist/esm/ion-toast.entry.js +45 -21
- package/dist/esm/ion-toggle.entry.js +82 -25
- package/dist/esm/ionic-global-BpkTponr.js +508 -0
- package/dist/esm/ionic.js +5 -5
- package/dist/esm/{ios.transition-ClFrsIrS.js → ios.transition-CgScDbsb.js} +7 -5
- package/dist/esm/{keyboard-CUw4ekVy.js → keyboard-CyyguLDw.js} +1 -1
- package/dist/esm/{keyboard-ywgs5efA.js → keyboard-WJix-wcz.js} +4 -3
- package/dist/esm/{keyboard-controller-BaaVITYt.js → keyboard-controller-BFwRdk2T.js} +5 -3
- package/dist/esm/list-Dhi5xtNS.js +6 -0
- package/dist/esm/loader.js +5 -5
- package/dist/esm/{md.transition-D0msQmzI.js → md.transition-DThqYazt.js} +6 -5
- package/dist/esm/{notch-controller-DKDjU_O7.js → notch-controller-MTblRxjD.js} +2 -2
- package/dist/esm/overlay-control-label-CODBQrPj.js +49 -0
- package/dist/esm/{overlays-TbiM4mdr.js → overlays-Dnhc5m_r.js} +306 -15
- package/dist/esm/select-option-render-qQ99XSVh.js +114 -0
- package/dist/esm/{status-tap-Kan2W7sh.js → status-tap-CoPI1M2q.js} +4 -3
- package/dist/esm/{swipe-back-DQ1q5MgD.js → swipe-back-qmvTRnSq.js} +3 -2
- package/dist/esm/{theme-DiVJyqlX.js → theme-DaJxRxSQ.js} +25 -1
- package/dist/esm/validity-BjW8SOqw.js +48 -0
- package/dist/esm/x-BDqjX7Z_.js +6 -0
- package/dist/html.html-data.json +2653 -146
- package/dist/ionic/index.esm.js +1 -1
- package/dist/ionic/ionic.esm.js +1 -1
- package/dist/ionic/p-05ce9821.entry.js +4 -0
- package/dist/ionic/p-066c290a.entry.js +4 -0
- package/dist/ionic/p-085b8cdf.entry.js +4 -0
- package/dist/ionic/p-0ef6bfc4.entry.js +4 -0
- package/dist/ionic/p-18969b6d.entry.js +4 -0
- package/dist/ionic/p-18bc4f2d.entry.js +4 -0
- package/dist/ionic/p-1b6e3914.entry.js +4 -0
- package/dist/ionic/p-25b51635.entry.js +4 -0
- package/dist/ionic/p-2740db6e.entry.js +4 -0
- package/dist/ionic/p-274a829d.entry.js +4 -0
- package/dist/ionic/p-2a1abbb1.entry.js +4 -0
- package/dist/ionic/p-3b4c5cb5.entry.js +4 -0
- package/dist/ionic/p-3cfb4ff2.entry.js +4 -0
- package/dist/ionic/p-43b00c5b.entry.js +4 -0
- package/dist/ionic/p-4827557b.entry.js +4 -0
- package/dist/ionic/p-4a97918d.entry.js +4 -0
- package/dist/ionic/p-52b3aedb.entry.js +4 -0
- package/dist/ionic/p-53d4ce5e.entry.js +4 -0
- package/dist/ionic/p-56224b93.entry.js +4 -0
- package/dist/ionic/p-5732396e.entry.js +4 -0
- package/dist/ionic/p-58d8877d.entry.js +4 -0
- package/dist/ionic/p-5d079dc1.entry.js +4 -0
- package/dist/ionic/p-5e9665dd.entry.js +4 -0
- package/dist/ionic/p-5fee5cc1.entry.js +4 -0
- package/dist/ionic/p-602cf876.entry.js +4 -0
- package/dist/ionic/p-678ee14a.entry.js +4 -0
- package/dist/ionic/p-68ea8ed1.entry.js +4 -0
- package/dist/ionic/p-6916fea6.entry.js +4 -0
- package/dist/ionic/p-6e1ec775.entry.js +4 -0
- package/dist/ionic/p-745d6b2b.entry.js +4 -0
- package/dist/ionic/p-7ce56473.entry.js +4 -0
- package/dist/ionic/p-83acfa2d.entry.js +4 -0
- package/dist/ionic/p-849b1759.entry.js +4 -0
- package/dist/ionic/p-8cb23f27.entry.js +4 -0
- package/dist/ionic/p-8d5fd199.entry.js +4 -0
- package/dist/ionic/p-8f2f8f6d.entry.js +4 -0
- package/dist/ionic/p-BDSH5ckF.js +4 -0
- package/dist/ionic/p-BDqjX7Z_.js +4 -0
- package/dist/ionic/p-BFe7BoXu.js +4 -0
- package/dist/ionic/p-BFy_BK46.js +4 -0
- package/dist/ionic/p-BYSs-jZz.js +4 -0
- package/dist/ionic/p-BjW8SOqw.js +4 -0
- package/{components/p-CtukzcyX.js → dist/ionic/p-BlZo7Gy-.js} +1 -1
- package/dist/ionic/p-Bq8S4vhI.js +4 -0
- package/dist/ionic/p-BwKpO3Is.js +4 -0
- package/dist/ionic/p-C0EQceqV.js +5 -0
- package/dist/ionic/p-C8i6xYLf.js +4 -0
- package/dist/ionic/p-CB91Gr9M.js +4 -0
- package/dist/ionic/p-CEkwLb3L.js +4 -0
- package/dist/ionic/p-CJsJQPQD.js +4 -0
- package/dist/ionic/p-CODBQrPj.js +4 -0
- package/dist/ionic/p-Ch7MBNn_.js +4 -0
- package/{components/p-BT_5jSqG.js → dist/ionic/p-Cm20lBQw.js} +1 -1
- package/dist/ionic/p-CnAWnbNK.js +4 -0
- package/dist/ionic/p-D1t981Ih.js +4 -0
- package/dist/ionic/p-D2tu5BUg.js +4 -0
- package/dist/ionic/p-D4MT1z4_.js +4 -0
- package/dist/ionic/p-D4veLKCq.js +4 -0
- package/dist/ionic/{p-DAAFkPFT.js → p-DDVaMUQI.js} +1 -1
- package/dist/ionic/p-DF7ubVci.js +4 -0
- package/dist/ionic/p-DMaSfupH.js +4 -0
- package/{components/p-D13Eaw-8.js → dist/ionic/p-DQDmksdT.js} +1 -1
- package/dist/ionic/p-DTsDGZPd.js +4 -0
- package/dist/ionic/p-DaJxRxSQ.js +4 -0
- package/dist/ionic/p-DdCaKRle.js +4 -0
- package/dist/ionic/p-Dhi5xtNS.js +4 -0
- package/dist/ionic/p-MqqcZQSB.js +4 -0
- package/dist/ionic/{p-CKvCXMs9.js → p-OkgYzj-7.js} +1 -1
- package/dist/ionic/p-WHzwm7OM.js +4 -0
- package/dist/ionic/p-a6a9a840.entry.js +4 -0
- package/dist/ionic/p-b7327160.entry.js +4 -0
- package/dist/ionic/p-ba447506.entry.js +4 -0
- package/dist/ionic/p-c04429f2.entry.js +4 -0
- package/dist/ionic/p-c25a2a9b.entry.js +4 -0
- package/dist/ionic/p-c414ac3a.entry.js +4 -0
- package/dist/ionic/p-ca3a07b5.entry.js +4 -0
- package/dist/ionic/p-ced3cda1.entry.js +4 -0
- package/dist/ionic/p-cf22e991.entry.js +4 -0
- package/dist/ionic/p-d0d42da6.entry.js +4 -0
- package/dist/ionic/p-d33dfc12.entry.js +4 -0
- package/dist/ionic/p-d34bfb61.entry.js +4 -0
- package/dist/ionic/p-ddde8df3.entry.js +4 -0
- package/dist/ionic/p-df642ef5.entry.js +4 -0
- package/dist/ionic/p-e04d63e1.entry.js +4 -0
- package/dist/ionic/p-e516b509.entry.js +4 -0
- package/dist/ionic/p-f18969f0.entry.js +4 -0
- package/dist/ionic/p-fIOYmaqA.js +4 -0
- package/dist/ionic/p-fc6d26ff.entry.js +4 -0
- package/dist/ionic/p-fce05eae.entry.js +4 -0
- package/dist/ionic/p-im8OkZlj.js +4 -0
- package/dist/ionic/p-lMb_45ax.js +4 -0
- package/dist/ionic/{p-Wk5HzclC.js → p-oUgyLDGL.js} +1 -1
- package/dist/ionic/p-vXpMhGrs.js +4 -0
- package/dist/types/components/accordion/accordion.d.ts +6 -3
- package/dist/types/components/accordion-group/accordion-group.d.ts +12 -1
- package/dist/types/components/action-sheet/action-sheet-interface.d.ts +3 -7
- package/dist/types/components/action-sheet/action-sheet.d.ts +3 -2
- package/dist/types/components/alert/alert-interface.d.ts +3 -7
- package/dist/types/components/alert/alert.d.ts +3 -2
- package/dist/types/components/app/app.d.ts +4 -5
- package/dist/types/components/avatar/avatar.d.ts +32 -0
- package/dist/types/components/back-button/back-button.d.ts +2 -1
- package/dist/types/components/backdrop/backdrop.d.ts +4 -0
- package/dist/types/components/badge/badge.d.ts +34 -1
- package/dist/types/components/breadcrumb/breadcrumb.d.ts +4 -1
- package/dist/types/components/breadcrumbs/breadcrumbs.d.ts +2 -2
- package/dist/types/components/button/button.d.ts +23 -8
- package/dist/types/components/buttons/buttons.d.ts +5 -1
- package/dist/types/components/card/card.d.ts +8 -1
- package/dist/types/components/card-content/card-content.d.ts +2 -1
- package/dist/types/components/card-header/card-header.d.ts +3 -2
- package/dist/types/components/card-subtitle/card-subtitle.d.ts +2 -1
- package/dist/types/components/card-title/card-title.d.ts +2 -1
- package/dist/types/components/checkbox/checkbox.d.ts +14 -4
- package/dist/types/components/chip/chip.d.ts +26 -1
- package/dist/types/components/col/col.d.ts +52 -5
- package/dist/types/components/content/content.d.ts +3 -0
- package/dist/types/components/datetime/datetime.d.ts +26 -1
- package/dist/types/components/datetime/utils/data.d.ts +5 -5
- package/dist/types/components/datetime-button/datetime-button.d.ts +2 -1
- package/dist/types/components/divider/divider.d.ts +20 -0
- package/dist/types/components/fab/fab.d.ts +4 -0
- package/dist/types/components/fab-button/fab-button.d.ts +5 -3
- package/dist/types/components/fab-list/fab-list.d.ts +4 -0
- package/dist/types/components/footer/footer.d.ts +4 -3
- package/dist/types/components/gallery/gallery-constants.d.ts +9 -0
- package/dist/types/components/gallery/gallery-interface.d.ts +10 -0
- package/dist/types/components/gallery/gallery.d.ts +218 -0
- package/dist/types/components/gallery/test/utils.d.ts +3 -0
- package/dist/types/components/gallery-item/gallery-item.d.ts +33 -0
- package/dist/types/components/grid/grid.d.ts +4 -0
- package/dist/types/components/header/header.d.ts +9 -3
- package/dist/types/components/header/header.utils.d.ts +3 -3
- package/dist/types/components/img/img.d.ts +3 -0
- package/dist/types/components/infinite-scroll/infinite-scroll.d.ts +21 -0
- package/dist/types/components/infinite-scroll-content/infinite-scroll-content.d.ts +4 -0
- package/dist/types/components/input/input.d.ts +31 -5
- package/dist/types/components/input-otp/input-otp.d.ts +37 -0
- package/dist/types/components/input-password-toggle/input-password-toggle.d.ts +2 -0
- package/dist/types/components/item/item.d.ts +11 -4
- package/dist/types/components/item-divider/item-divider.d.ts +2 -1
- package/dist/types/components/item-group/item-group.d.ts +4 -0
- package/dist/types/components/item-option/item-option.d.ts +18 -1
- package/dist/types/components/item-options/item-options.d.ts +4 -0
- package/dist/types/components/item-sliding/item-sliding.d.ts +47 -1
- package/dist/types/components/item-sliding/test/test.utils.d.ts +13 -0
- package/dist/types/components/label/label.d.ts +2 -1
- package/dist/types/components/list/list.d.ts +15 -1
- package/dist/types/components/list-header/list-header.d.ts +2 -1
- package/dist/types/components/loading/loading-interface.d.ts +2 -7
- package/dist/types/components/loading/loading.d.ts +3 -2
- package/dist/types/components/menu/menu.d.ts +3 -0
- package/dist/types/components/menu-button/menu-button.d.ts +3 -1
- package/dist/types/components/menu-toggle/menu-toggle.d.ts +3 -0
- package/dist/types/components/modal/animations/ionic.enter.d.ts +6 -0
- package/dist/types/components/modal/animations/ionic.leave.d.ts +6 -0
- package/dist/types/components/modal/gestures/sheet.d.ts +1 -1
- package/dist/types/components/modal/modal-interface.d.ts +4 -7
- package/dist/types/components/modal/modal.d.ts +11 -1
- package/dist/types/components/nav/nav-interface.d.ts +9 -1
- package/dist/types/components/nav/nav.d.ts +5 -1
- package/dist/types/components/nav-link/nav-link.d.ts +4 -0
- package/dist/types/components/note/note.d.ts +2 -1
- package/dist/types/components/picker/picker.d.ts +2 -1
- package/dist/types/components/picker-column/picker-column.d.ts +2 -1
- package/dist/types/components/picker-column-option/picker-column-option.d.ts +4 -0
- package/dist/types/components/picker-legacy/picker.d.ts +2 -1
- package/dist/types/components/popover/popover-interface.d.ts +3 -6
- package/dist/types/components/popover/popover.d.ts +6 -5
- package/dist/types/components/progress-bar/progress-bar.d.ts +10 -1
- package/dist/types/components/radio/radio.d.ts +2 -1
- package/dist/types/components/radio-group/radio-group.d.ts +12 -0
- package/dist/types/components/range/range.d.ts +2 -1
- package/dist/types/components/refresher/refresher.d.ts +2 -1
- package/dist/types/components/refresher-content/refresher-content.d.ts +4 -0
- package/dist/types/components/reorder/reorder.d.ts +9 -0
- package/dist/types/components/reorder-group/reorder-group.d.ts +4 -0
- package/dist/types/components/ripple-effect/ripple-effect.d.ts +4 -0
- package/dist/types/components/route/route.d.ts +4 -0
- package/dist/types/components/router/router.d.ts +4 -0
- package/dist/types/components/router-link/router-link.d.ts +4 -0
- package/dist/types/components/router-outlet/router-outlet.d.ts +4 -1
- package/dist/types/components/row/row.d.ts +4 -0
- package/dist/types/components/searchbar/searchbar.d.ts +51 -9
- package/dist/types/components/segment/segment.d.ts +2 -1
- package/dist/types/components/segment-button/segment-button.d.ts +2 -1
- package/dist/types/components/select/select-interface.d.ts +31 -0
- package/dist/types/components/select/select.d.ts +66 -13
- package/dist/types/components/select-modal/select-modal.d.ts +8 -0
- package/dist/types/components/select-option/select-option.d.ts +44 -0
- package/dist/types/components/select-popover/select-popover.d.ts +3 -0
- package/dist/types/components/skeleton-text/skeleton-text.d.ts +4 -0
- package/dist/types/components/spinner/spinner.d.ts +15 -0
- package/dist/types/components/split-pane/split-pane.d.ts +4 -0
- package/dist/types/components/tab/tab.d.ts +4 -0
- package/dist/types/components/tab-bar/tab-bar.d.ts +37 -2
- package/dist/types/components/tab-button/tab-button.d.ts +12 -1
- package/dist/types/components/tabs/tabs.d.ts +3 -0
- package/dist/types/components/text/text.d.ts +2 -1
- package/dist/types/components/textarea/textarea.d.ts +53 -4
- package/dist/types/components/thumbnail/thumbnail.d.ts +4 -0
- package/dist/types/components/title/title.d.ts +4 -0
- package/dist/types/components/toast/animations/utils.d.ts +2 -2
- package/dist/types/components/toast/toast-interface.d.ts +3 -7
- package/dist/types/components/toast/toast.d.ts +19 -2
- package/dist/types/components/toggle/toggle.d.ts +15 -1
- package/dist/types/components/toolbar/toolbar.d.ts +43 -3
- package/dist/types/components.d.ts +1852 -205
- package/dist/types/global/ionic-global.d.ts +28 -2
- package/dist/types/interface.d.ts +3 -0
- package/dist/types/utils/config.d.ts +106 -2
- package/dist/types/utils/css-value-validation.d.ts +21 -0
- package/dist/types/utils/focus-trap.d.ts +1 -1
- package/dist/types/utils/focus-visible.d.ts +13 -0
- package/dist/types/utils/forms/validity.d.ts +7 -0
- package/dist/types/utils/helpers.d.ts +22 -0
- package/dist/types/utils/overlay-control-label.d.ts +34 -0
- package/dist/types/utils/overlays-interface.d.ts +31 -1
- package/dist/types/utils/overlays.d.ts +1 -1
- package/dist/types/utils/sanitization/index.d.ts +54 -2
- package/dist/types/utils/select-option-render.d.ts +53 -0
- package/dist/types/utils/test/playwright/drag-element.d.ts +16 -3
- package/dist/types/utils/test/playwright/generator.d.ts +31 -2
- package/dist/types/utils/theme.d.ts +9 -0
- package/hydrate/index.js +5982 -1347
- package/hydrate/index.mjs +5982 -1347
- package/package.json +9 -5
- package/components/p--JUspHvy.js +0 -4
- package/components/p-0NRupjzW.js +0 -4
- package/components/p-5bE_Wz4Y.js +0 -4
- package/components/p-B60hm8Qv.js +0 -4
- package/components/p-B9jFTlwE.js +0 -4
- package/components/p-BLmJ0zRm.js +0 -4
- package/components/p-BSEgsdFI.js +0 -4
- package/components/p-BTPfOxsU.js +0 -4
- package/components/p-Baq1XyAy.js +0 -4
- package/components/p-BirPFsRD.js +0 -4
- package/components/p-BjfgFSSR.js +0 -4
- package/components/p-BmVRXR1y.js +0 -4
- package/components/p-BnqQlm7c.js +0 -4
- package/components/p-BsPelv04.js +0 -4
- package/components/p-Bth-EzJ0.js +0 -4
- package/components/p-Bz0dSlXZ.js +0 -4
- package/components/p-C1aScSTo.js +0 -4
- package/components/p-C2lKgrXx.js +0 -4
- package/components/p-CHqRYvYm.js +0 -4
- package/components/p-CI3ncNZm.js +0 -4
- package/components/p-CIGNaXM1.js +0 -4
- package/components/p-CO7fmmxt.js +0 -4
- package/components/p-CSZf8_j0.js +0 -4
- package/components/p-CU5rbWAW.js +0 -4
- package/components/p-C_xFdyXe.js +0 -4
- package/components/p-Cfx4M1Bn.js +0 -4
- package/components/p-Ciz1-FuE.js +0 -4
- package/components/p-CmR5uXej.js +0 -4
- package/components/p-CtWGkNnJ.js +0 -4
- package/components/p-D6Ynv7Xh.js +0 -4
- package/components/p-D7bSXQD3.js +0 -4
- package/components/p-DDWp95gH.js +0 -4
- package/components/p-DIE4pXMl.js +0 -4
- package/components/p-DJztqcrH.js +0 -4
- package/components/p-DNQI6d-L.js +0 -4
- package/components/p-DOFCbuQR.js +0 -4
- package/components/p-DiVJyqlX.js +0 -4
- package/components/p-DnL1c9_X.js +0 -4
- package/components/p-DqZAXv2t.js +0 -4
- package/components/p-Sh0ICmPV.js +0 -4
- package/components/p-W5nO8mX_.js +0 -4
- package/components/p-W9CZ2mWX.js +0 -4
- package/components/p-ZjP4CjeZ.js +0 -4
- package/components/p-dhLYXa7A.js +0 -4
- package/components/p-ijF0iCrA.js +0 -4
- package/components/p-j5IxBIan.js +0 -4
- package/components/p-k_E4tX5Z.js +0 -4
- package/components/p-lE_JGpHD.js +0 -4
- package/components/p-nQi4oKcG.js +0 -4
- package/components/p-rCa2eL0j.js +0 -4
- package/components/p-ryqmO0B-.js +0 -4
- package/components/p-uVRyUM3z.js +0 -4
- package/dist/cjs/config-xninhj0J.js +0 -201
- package/dist/cjs/hardware-back-button-iUuF_76h.js +0 -121
- package/dist/cjs/index-DkNv4J_i.js +0 -10
- package/dist/cjs/ionic-global-B-cA6LkY.js +0 -151
- package/dist/cjs/validity-BpS37YFM.js +0 -19
- package/dist/esm/config-DQCONYYp.js +0 -195
- package/dist/esm/hardware-back-button-B93Gru0Y.js +0 -115
- package/dist/esm/index-ZjP4CjeZ.js +0 -7
- package/dist/esm/ionic-global-Cp_eT4sZ.js +0 -146
- package/dist/esm/validity-DJztqcrH.js +0 -17
- package/dist/ionic/p-00dbb17e.entry.js +0 -4
- package/dist/ionic/p-01f81ea5.entry.js +0 -4
- package/dist/ionic/p-06c232a4.entry.js +0 -4
- package/dist/ionic/p-0d005398.entry.js +0 -4
- package/dist/ionic/p-0fa9c382.entry.js +0 -4
- package/dist/ionic/p-1ae21e4c.entry.js +0 -4
- package/dist/ionic/p-20b1a044.entry.js +0 -4
- package/dist/ionic/p-21eb76d5.entry.js +0 -4
- package/dist/ionic/p-27d30585.entry.js +0 -4
- package/dist/ionic/p-2bb2cb18.entry.js +0 -4
- package/dist/ionic/p-2f55dc1a.entry.js +0 -4
- package/dist/ionic/p-30bf9737.entry.js +0 -4
- package/dist/ionic/p-3353c229.entry.js +0 -4
- package/dist/ionic/p-37e720da.entry.js +0 -4
- package/dist/ionic/p-390ca786.entry.js +0 -4
- package/dist/ionic/p-3a126bca.entry.js +0 -4
- package/dist/ionic/p-3a541154.entry.js +0 -4
- package/dist/ionic/p-3a7d1e91.entry.js +0 -4
- package/dist/ionic/p-3ae5f277.entry.js +0 -4
- package/dist/ionic/p-4745f534.entry.js +0 -4
- package/dist/ionic/p-4858af1f.entry.js +0 -4
- package/dist/ionic/p-485fda23.entry.js +0 -4
- package/dist/ionic/p-4baa5b82.entry.js +0 -4
- package/dist/ionic/p-4dc1c33c.entry.js +0 -4
- package/dist/ionic/p-4e92a11f.entry.js +0 -4
- package/dist/ionic/p-50e1194a.entry.js +0 -4
- package/dist/ionic/p-5d1da0a2.entry.js +0 -4
- package/dist/ionic/p-5fc7e542.entry.js +0 -4
- package/dist/ionic/p-75dc25ba.entry.js +0 -4
- package/dist/ionic/p-81ea5652.entry.js +0 -4
- package/dist/ionic/p-84d5ce05.entry.js +0 -4
- package/dist/ionic/p-874b4bd8.entry.js +0 -4
- package/dist/ionic/p-8c8eee7d.entry.js +0 -4
- package/dist/ionic/p-8eb8ee76.entry.js +0 -4
- package/dist/ionic/p-8fce95d5.entry.js +0 -4
- package/dist/ionic/p-94f2a736.entry.js +0 -4
- package/dist/ionic/p-9a65ac7f.entry.js +0 -4
- package/dist/ionic/p-9eeaBrnk.js +0 -4
- package/dist/ionic/p-9f1103ce.entry.js +0 -4
- package/dist/ionic/p-BGqMS-oh.js +0 -4
- package/dist/ionic/p-BUFIpxKM.js +0 -4
- package/dist/ionic/p-BmVRXR1y.js +0 -4
- package/dist/ionic/p-CFlfIb2g.js +0 -4
- package/dist/ionic/p-CIGNaXM1.js +0 -4
- package/dist/ionic/p-CtWGkNnJ.js +0 -4
- package/dist/ionic/p-Cx3IXROA.js +0 -4
- package/dist/ionic/p-D4uTWt4-.js +0 -4
- package/dist/ionic/p-DC3RagnA.js +0 -4
- package/dist/ionic/p-DIuEbVLu.js +0 -4
- package/dist/ionic/p-DJztqcrH.js +0 -4
- package/dist/ionic/p-DSG2s2Eb.js +0 -4
- package/dist/ionic/p-DV3sJJW8.js +0 -4
- package/dist/ionic/p-Dfbt-q2k.js +0 -4
- package/dist/ionic/p-DiVJyqlX.js +0 -4
- package/dist/ionic/p-DoJvtrbw.js +0 -4
- package/dist/ionic/p-DzWaWHGc.js +0 -4
- package/dist/ionic/p-KjNvRoEp.js +0 -4
- package/dist/ionic/p-Nqf6uvGh.js +0 -4
- package/dist/ionic/p-SNAkTDfm.js +0 -4
- package/dist/ionic/p-ZjP4CjeZ.js +0 -4
- package/dist/ionic/p-a21add2f.entry.js +0 -4
- package/dist/ionic/p-a3bdcae6.entry.js +0 -4
- package/dist/ionic/p-aa5d6b8f.entry.js +0 -4
- package/dist/ionic/p-b6a7397c.entry.js +0 -4
- package/dist/ionic/p-c0fb8edd.entry.js +0 -4
- package/dist/ionic/p-c4d8641b.entry.js +0 -4
- package/dist/ionic/p-c6e49f3f.entry.js +0 -4
- package/dist/ionic/p-dfa8d673.entry.js +0 -4
- package/dist/ionic/p-e0be05c5.entry.js +0 -4
- package/dist/ionic/p-e847a888.entry.js +0 -4
- package/dist/ionic/p-ec090e0a.entry.js +0 -4
- package/dist/ionic/p-ef4c3bee.entry.js +0 -4
- package/dist/ionic/p-f386f6ae.entry.js +0 -4
- package/dist/ionic/p-fabcce6c.entry.js +0 -4
- package/dist/ionic/p-mjKAFv89.js +0 -4
- package/dist/ionic/p-tcQvqkiX.js +0 -5
- package/dist/ionic/p-viFHDgRs.js +0 -4
- package/dist/ionic/p-xOfi7-Zn.js +0 -4
- package/dist/ionic/p-xWb6fgfq.js +0 -4
- /package/dist/collection/components/{input-password-toggle/input-password-toggle.css → refresher-content/refresher-content.css} +0 -0
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* (C) Ionic http://ionicframework.com - MIT License
|
|
3
|
+
*/
|
|
4
|
+
// TODO(FW-6886, FW-6892, FW-6891): Remove this file in favor of the Modular Ionic component config. Each overlay will be able to select its own defaults for label placement and justify based on the interface and theme, so this utility will no longer be necessary.
|
|
5
|
+
/**
|
|
6
|
+
* Returns the default `labelPlacement` for a radio or checkbox option
|
|
7
|
+
* rendered inside an overlay. Defaults follow each theme's established
|
|
8
|
+
* option-row layout:
|
|
9
|
+
* - `ionic`: always `"start"`.
|
|
10
|
+
* - `ios`: `"start"` for radio in `alert` and `popover`. The `modal`
|
|
11
|
+
* interface flips iOS radio back to `"end"`. Checkbox is always
|
|
12
|
+
* `"end"` on iOS.
|
|
13
|
+
* - everything else (e.g. `md`): `"end"`.
|
|
14
|
+
*
|
|
15
|
+
* `interfaceType` is optional; only `"modal"` changes the result, so
|
|
16
|
+
* callers that aren't a modal can omit it.
|
|
17
|
+
*
|
|
18
|
+
* Used by `alert`, `select-popover`, and `select-modal` as the fallback
|
|
19
|
+
* when an option doesn't explicitly set `labelPlacement`.
|
|
20
|
+
*/
|
|
21
|
+
const getOverlayLabelPlacement = (theme, control, interfaceType) => {
|
|
22
|
+
if (theme === 'ionic' || (theme === 'ios' && control === 'radio' && interfaceType !== 'modal')) {
|
|
23
|
+
return 'start';
|
|
24
|
+
}
|
|
25
|
+
return 'end';
|
|
26
|
+
};
|
|
27
|
+
/**
|
|
28
|
+
* Returns the default `justify` for a radio or checkbox option rendered
|
|
29
|
+
* inside an overlay. Defaults follow each theme's option-row layout:
|
|
30
|
+
* - `ionic`: always `"space-between"`.
|
|
31
|
+
* - `ios`: `"space-between"` for radio in `alert` and `popover`. The
|
|
32
|
+
* `modal` interface falls back to `"start"`. Checkbox is always `"start"`
|
|
33
|
+
* on iOS.
|
|
34
|
+
* - everything else (e.g. `md`): `"start"`.
|
|
35
|
+
*
|
|
36
|
+
* `interfaceType` is optional; only `"modal"` changes the result, so
|
|
37
|
+
* callers that aren't a modal can omit it.
|
|
38
|
+
*
|
|
39
|
+
* Used by `alert`, `select-popover`, and `select-modal` as the fallback when
|
|
40
|
+
* an option doesn't explicitly set `justify`.
|
|
41
|
+
*/
|
|
42
|
+
const getOverlayLabelJustify = (theme, control, interfaceType) => {
|
|
43
|
+
if (theme === 'ionic' || (theme === 'ios' && control === 'radio' && interfaceType !== 'modal')) {
|
|
44
|
+
return 'space-between';
|
|
45
|
+
}
|
|
46
|
+
return 'start';
|
|
47
|
+
};
|
|
48
|
+
|
|
49
|
+
export { getOverlayLabelPlacement as a, getOverlayLabelJustify as g };
|
|
@@ -1,12 +1,10 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* (C) Ionic http://ionicframework.com - MIT License
|
|
3
3
|
*/
|
|
4
|
-
import { d as doc } from './
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
8
|
-
import { b as getIonMode } from './ionic-global-Cp_eT4sZ.js';
|
|
9
|
-
import { C as CoreDelegate } from './framework-delegate-FnPGymXL.js';
|
|
4
|
+
import { c as getIonTheme, b as getIonMode, d as doc, O as OVERLAY_BACK_BUTTON_PRIORITY, s as shouldUseCloseWatcher } from './ionic-global-BpkTponr.js';
|
|
5
|
+
import { o as focusVisibleElement, c as componentOnReady, f as addEventListener, m as removeEventListener, g as getElementRoot } from './helpers-DfF5_wJc.js';
|
|
6
|
+
import { e as config, j as printIonError, f as printIonWarning } from './index-C0EQceqV.js';
|
|
7
|
+
import { C as CoreDelegate } from './framework-delegate-DO2QXccA.js';
|
|
10
8
|
import { B as BACKDROP_NO_SCROLL } from './gesture-controller-BTEOs1at.js';
|
|
11
9
|
|
|
12
10
|
/**
|
|
@@ -21,7 +19,7 @@ import { B as BACKDROP_NO_SCROLL } from './gesture-controller-BTEOs1at.js';
|
|
|
21
19
|
* Note: We need this distinction because `disabled="false"` is
|
|
22
20
|
* valid usage for the disabled property on ion-button.
|
|
23
21
|
*/
|
|
24
|
-
const focusableQueryString = '[tabindex]:not([tabindex^="-"]):not([hidden]):not([disabled]), input:not([type=hidden]):not([tabindex^="-"]):not([hidden]):not([disabled]), textarea:not([tabindex^="-"]):not([hidden]):not([disabled]), button:not([tabindex^="-"]):not([hidden]):not([disabled]), select:not([tabindex^="-"]):not([hidden]):not([disabled]), ion-checkbox:not([tabindex^="-"]):not([hidden]):not([disabled]), ion-radio:not([tabindex^="-"]):not([hidden]):not([disabled]), .ion-focusable:not([tabindex^="-"]):not([hidden]):not([disabled]), .ion-focusable[disabled="false"]:not([tabindex^="-"]):not([hidden])';
|
|
22
|
+
const focusableQueryString = '[tabindex]:not([tabindex^="-"]):not([hidden]):not([disabled]), input:not([type=hidden]):not([tabindex^="-"]):not([hidden]):not([disabled]), textarea:not([tabindex^="-"]):not([hidden]):not([disabled]), button:not([tabindex^="-"]):not([hidden]):not([disabled]), select:not([tabindex^="-"]):not([hidden]):not([disabled]), ion-checkbox:not([tabindex^="-"]):not([hidden]):not([disabled]), ion-radio:not([tabindex^="-"]):not([hidden]):not([disabled]), ion-textarea:not([tabindex^="-"]):not([hidden]):not([disabled]), .ion-focusable:not([tabindex^="-"]):not([hidden]):not([disabled]), .ion-focusable[disabled="false"]:not([tabindex^="-"]):not([hidden])';
|
|
25
23
|
/**
|
|
26
24
|
* Focuses the first descendant in a context
|
|
27
25
|
* that can receive focus. If none exists,
|
|
@@ -73,7 +71,18 @@ const focusElementInContext = (hostToFocus, fallbackElement) => {
|
|
|
73
71
|
const shadowRoot = hostToFocus === null || hostToFocus === void 0 ? void 0 : hostToFocus.shadowRoot;
|
|
74
72
|
if (shadowRoot) {
|
|
75
73
|
// If there are no inner focusable elements, just focus the host element.
|
|
76
|
-
|
|
74
|
+
const innerFocusable = shadowRoot.querySelector(focusableQueryString);
|
|
75
|
+
// If the host has a setFocus() method, use it to delegate focus properly.
|
|
76
|
+
// This is needed for shadow DOM components like ion-textarea that override
|
|
77
|
+
// focus() to delegate to their inner native elements.
|
|
78
|
+
const hasSetFocus = typeof hostToFocus.setFocus === 'function';
|
|
79
|
+
if (innerFocusable && hasSetFocus) {
|
|
80
|
+
// Keep the host element so we can call setFocus() on it
|
|
81
|
+
elementToFocus = hostToFocus;
|
|
82
|
+
}
|
|
83
|
+
else {
|
|
84
|
+
elementToFocus = innerFocusable || hostToFocus;
|
|
85
|
+
}
|
|
77
86
|
}
|
|
78
87
|
if (elementToFocus) {
|
|
79
88
|
const radioGroup = elementToFocus.closest('ion-radio-group');
|
|
@@ -93,8 +102,115 @@ const focusElementInContext = (hostToFocus, fallbackElement) => {
|
|
|
93
102
|
let lastOverlayIndex = 0;
|
|
94
103
|
let lastId = 0;
|
|
95
104
|
const activeAnimations = new WeakMap();
|
|
105
|
+
const OVERLAY_FOCUS_TRAP_SELECTOR = 'ion-alert,ion-action-sheet,ion-loading,ion-modal,ion-picker-legacy,ion-popover';
|
|
96
106
|
/**
|
|
97
|
-
*
|
|
107
|
+
* The focus trap is generic and knows nothing about which components are
|
|
108
|
+
* inside an overlay. Components mark their elements with these `data-*`
|
|
109
|
+
* attributes, which the trap reads, to control how Tab moves through them.
|
|
110
|
+
* This keeps private component class names (e.g. `.modal-handle`,
|
|
111
|
+
* `.action-sheet-button`) out of the trap, so changing a component does
|
|
112
|
+
* not silently break Tab order.
|
|
113
|
+
*
|
|
114
|
+
* - `data-focus-ignore`: skip this element as a tab stop.
|
|
115
|
+
* - `data-focus-order`: explicit numeric placement in the tab sequence.
|
|
116
|
+
* - `data-roving-focus`: a container whose focusable descendants share a
|
|
117
|
+
* single tab stop via a roving tabindex.
|
|
118
|
+
*/
|
|
119
|
+
const FOCUS_IGNORE_SELECTOR = '[data-focus-ignore]';
|
|
120
|
+
const FOCUS_ORDER_SELECTOR = '[data-focus-order]';
|
|
121
|
+
const ROVING_FOCUS_SELECTOR = '[data-roving-focus]';
|
|
122
|
+
/**
|
|
123
|
+
* Returns the roving-focus group an element belongs to, or `null`.
|
|
124
|
+
* A member is a descendant of a `[data-roving-focus]` container. The
|
|
125
|
+
* container itself is not a member. Members share a single tab stop.
|
|
126
|
+
*/
|
|
127
|
+
const getRovingFocusGroup = (el) => {
|
|
128
|
+
const group = el.closest(ROVING_FOCUS_SELECTOR);
|
|
129
|
+
return group !== null && group !== el ? group : null;
|
|
130
|
+
};
|
|
131
|
+
/**
|
|
132
|
+
* Whether an element participates in a roving-focus group.
|
|
133
|
+
*/
|
|
134
|
+
const isRovingFocusItem = (el) => getRovingFocusGroup(el) !== null;
|
|
135
|
+
/**
|
|
136
|
+
* Returns the currently focused element for keyboard focus checks.
|
|
137
|
+
*
|
|
138
|
+
* Starts from `document.activeElement` (non-shadow / light DOM focus).
|
|
139
|
+
* If focus is inside one or more open shadow roots
|
|
140
|
+
* (e.g. native control inside `ion-radio`), walks through nested
|
|
141
|
+
* `shadowRoot.activeElement` values until the innermost focused node is reached.
|
|
142
|
+
*/
|
|
143
|
+
const getActiveElement = (ownerDoc) => {
|
|
144
|
+
var _a;
|
|
145
|
+
let active = ownerDoc.activeElement;
|
|
146
|
+
if (!active) {
|
|
147
|
+
return null;
|
|
148
|
+
}
|
|
149
|
+
while ((_a = active.shadowRoot) === null || _a === void 0 ? void 0 : _a.activeElement) {
|
|
150
|
+
active = active.shadowRoot.activeElement;
|
|
151
|
+
}
|
|
152
|
+
return active;
|
|
153
|
+
};
|
|
154
|
+
/**
|
|
155
|
+
* Walks from a focused node (possibly deep inside shadow roots) up to
|
|
156
|
+
* the nearest roving-focus host (e.g. `ion-radio` inside an
|
|
157
|
+
* `ion-radio-group`, or an action sheet `<button role="radio">`).
|
|
158
|
+
*/
|
|
159
|
+
const getRovingFocusHost = (active) => {
|
|
160
|
+
let n = active;
|
|
161
|
+
while (n) {
|
|
162
|
+
if (isRovingFocusItem(n)) {
|
|
163
|
+
return n;
|
|
164
|
+
}
|
|
165
|
+
const root = n.getRootNode();
|
|
166
|
+
if (root instanceof ShadowRoot && root.host instanceof HTMLElement) {
|
|
167
|
+
n = root.host;
|
|
168
|
+
}
|
|
169
|
+
else {
|
|
170
|
+
return null;
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
return null;
|
|
174
|
+
};
|
|
175
|
+
/**
|
|
176
|
+
* Reorders focusables for components that declare an explicit tab order
|
|
177
|
+
* via `data-focus-order`. Elements without the attribute keep their
|
|
178
|
+
* visual order and are visited first. Elements with it are appended
|
|
179
|
+
* afterwards, sorted by ascending numeric value.
|
|
180
|
+
*
|
|
181
|
+
* Example (sheet modal): the options have no order and are visited
|
|
182
|
+
* first in visual order, then the drag handle (`data-focus-order="1"`),
|
|
183
|
+
* then the header Cancel button (`data-focus-order="2"`).
|
|
184
|
+
*/
|
|
185
|
+
const applyFocusOrder = (elements) => {
|
|
186
|
+
const sortByVisualPosition = (els) => [...els].sort((a, b) => {
|
|
187
|
+
const ra = a.getBoundingClientRect();
|
|
188
|
+
const rb = b.getBoundingClientRect();
|
|
189
|
+
const topDiff = ra.top - rb.top;
|
|
190
|
+
if (Math.abs(topDiff) > 1) {
|
|
191
|
+
return topDiff;
|
|
192
|
+
}
|
|
193
|
+
return ra.left - rb.left;
|
|
194
|
+
});
|
|
195
|
+
const unordered = elements.filter((el) => !el.matches(FOCUS_ORDER_SELECTOR));
|
|
196
|
+
const ordered = elements
|
|
197
|
+
.filter((el) => el.matches(FOCUS_ORDER_SELECTOR))
|
|
198
|
+
.sort((a, b) => Number(a.getAttribute('data-focus-order')) - Number(b.getAttribute('data-focus-order')));
|
|
199
|
+
return [...sortByVisualPosition(unordered), ...ordered];
|
|
200
|
+
};
|
|
201
|
+
/**
|
|
202
|
+
* Roving-focus members use a tabindex pattern where only one member is
|
|
203
|
+
* tabbable (`tabIndex="0"`) while the others are not (`tabIndex="-1"`).
|
|
204
|
+
* This returns the index of the current tabbable member.
|
|
205
|
+
*/
|
|
206
|
+
const getTabbableRovingFocusIndex = (elements, overlay) => {
|
|
207
|
+
return elements.findIndex((el) => {
|
|
208
|
+
return overlay.contains(el) && isRovingFocusItem(el) && el.tabIndex >= 0;
|
|
209
|
+
});
|
|
210
|
+
};
|
|
211
|
+
/**
|
|
212
|
+
* Determines if the overlay's backdrop is always blocking
|
|
213
|
+
* (no background interaction).
|
|
98
214
|
* Returns false if showBackdrop=false or backdropBreakpoint > 0.
|
|
99
215
|
*/
|
|
100
216
|
const isBackdropAlwaysBlocking = (el) => {
|
|
@@ -215,7 +331,7 @@ const focusElementInOverlay = (hostToFocus, overlay) => {
|
|
|
215
331
|
* Should NOT include: Toast
|
|
216
332
|
*/
|
|
217
333
|
const trapKeyboardFocus = (ev, doc) => {
|
|
218
|
-
const lastOverlay = getPresentedOverlay(doc,
|
|
334
|
+
const lastOverlay = getPresentedOverlay(doc, OVERLAY_FOCUS_TRAP_SELECTOR);
|
|
219
335
|
const target = ev.target;
|
|
220
336
|
/**
|
|
221
337
|
* If no active overlay, ignore this event.
|
|
@@ -398,6 +514,176 @@ const connectListeners = (doc) => {
|
|
|
398
514
|
doc.addEventListener('focus', (ev) => {
|
|
399
515
|
trapKeyboardFocus(ev, doc);
|
|
400
516
|
}, true);
|
|
517
|
+
/**
|
|
518
|
+
* Remember which roving-focus member last received focus
|
|
519
|
+
* (arrows, click, or Tab). A roving group keeps `tabIndex=0` on a
|
|
520
|
+
* single member (e.g. the checked/first radio), so the Tab trap
|
|
521
|
+
* uses this when wrapping back into the group or focusing its slot.
|
|
522
|
+
*/
|
|
523
|
+
doc.addEventListener('focusin', (ev) => {
|
|
524
|
+
const lastOverlay = getPresentedOverlay(doc, OVERLAY_FOCUS_TRAP_SELECTOR);
|
|
525
|
+
if (!lastOverlay || lastOverlay.classList.contains(FOCUS_TRAP_DISABLE_CLASS)) {
|
|
526
|
+
return;
|
|
527
|
+
}
|
|
528
|
+
const target = ev.target;
|
|
529
|
+
if (!(target instanceof HTMLElement)) {
|
|
530
|
+
return;
|
|
531
|
+
}
|
|
532
|
+
const rovingHost = getRovingFocusHost(target);
|
|
533
|
+
if (rovingHost && lastOverlay.contains(rovingHost)) {
|
|
534
|
+
lastOverlay.trapLastRovingFocus = rovingHost;
|
|
535
|
+
}
|
|
536
|
+
}, true);
|
|
537
|
+
// Listen for keydown events to intercept Tab navigation.
|
|
538
|
+
// This is needed for Safari and Firefox which may skip focusable
|
|
539
|
+
// elements or allow focus to escape the overlay.
|
|
540
|
+
// It also ensures proper focus delegation for shadow DOM elements
|
|
541
|
+
// like ion-textarea.
|
|
542
|
+
doc.addEventListener('keydown', (ev) => {
|
|
543
|
+
var _a, _b, _c;
|
|
544
|
+
if (ev.key !== 'Tab' && ev.key !== 'Alt+Tab')
|
|
545
|
+
return;
|
|
546
|
+
const lastOverlay = getPresentedOverlay(doc, OVERLAY_FOCUS_TRAP_SELECTOR);
|
|
547
|
+
if (!lastOverlay || lastOverlay.classList.contains(FOCUS_TRAP_DISABLE_CLASS))
|
|
548
|
+
return;
|
|
549
|
+
const activeElement = getActiveElement(doc);
|
|
550
|
+
if (activeElement === lastOverlay) {
|
|
551
|
+
ev.preventDefault();
|
|
552
|
+
focusFirstDescendant(lastOverlay);
|
|
553
|
+
return;
|
|
554
|
+
}
|
|
555
|
+
// Check if activeElement is inside the overlay (including shadow DOM)
|
|
556
|
+
const isInsideOverlay = activeElement
|
|
557
|
+
? lastOverlay.contains(activeElement) ||
|
|
558
|
+
(activeElement.getRootNode() instanceof ShadowRoot &&
|
|
559
|
+
lastOverlay.contains(activeElement.getRootNode().host)) ||
|
|
560
|
+
((_b = (_a = lastOverlay.shadowRoot) === null || _a === void 0 ? void 0 : _a.contains(activeElement)) !== null && _b !== void 0 ? _b : false)
|
|
561
|
+
: false;
|
|
562
|
+
if (!isInsideOverlay)
|
|
563
|
+
return;
|
|
564
|
+
// Get all focusable elements from both light and shadow DOM
|
|
565
|
+
let allFocusable = [
|
|
566
|
+
...lastOverlay.querySelectorAll(focusableQueryString),
|
|
567
|
+
...(((_c = lastOverlay.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelectorAll(focusableQueryString)) || []),
|
|
568
|
+
];
|
|
569
|
+
/**
|
|
570
|
+
* Some elements match `focusableQueryString` but are not
|
|
571
|
+
* intended tab stops (e.g. the `ion-item` wrappers a select
|
|
572
|
+
* modal renders around its options). Components opt these out
|
|
573
|
+
* with `data-focus-ignore` so Tab can move between the real
|
|
574
|
+
* controls.
|
|
575
|
+
*/
|
|
576
|
+
allFocusable = allFocusable.filter((el) => !el.matches(FOCUS_IGNORE_SELECTOR));
|
|
577
|
+
/**
|
|
578
|
+
* A roving-focus group is a single tab stop: only its currently
|
|
579
|
+
* tabbable member (`tabIndex >= 0`) participates. Other
|
|
580
|
+
* focusables inside the group are not independent tab stops —
|
|
581
|
+
* this includes inactive members and focusable wrappers such as
|
|
582
|
+
* the `ion-item` that carries `ion-focusable` on behalf of a
|
|
583
|
+
* radio. Drop them so Tab moves between the group and the
|
|
584
|
+
* surrounding controls (e.g. the handle), not into the wrappers.
|
|
585
|
+
*/
|
|
586
|
+
allFocusable = allFocusable.filter((el) => !isRovingFocusItem(el) || el.tabIndex >= 0);
|
|
587
|
+
/**
|
|
588
|
+
* When a component declares an explicit tab order via
|
|
589
|
+
* `data-focus-order` (e.g. a sheet modal's handle and Cancel
|
|
590
|
+
* button), reorder accordingly. Overlays that declare no order
|
|
591
|
+
* keep their DOM order.
|
|
592
|
+
*/
|
|
593
|
+
if (allFocusable.some((el) => el.matches(FOCUS_ORDER_SELECTOR))) {
|
|
594
|
+
allFocusable = applyFocusOrder(allFocusable);
|
|
595
|
+
}
|
|
596
|
+
if (allFocusable.length === 0) {
|
|
597
|
+
ev.preventDefault();
|
|
598
|
+
return;
|
|
599
|
+
}
|
|
600
|
+
// Find current element's index (accounting for shadow DOM)
|
|
601
|
+
let currentIndex = activeElement
|
|
602
|
+
? allFocusable.findIndex((el) => {
|
|
603
|
+
var _a;
|
|
604
|
+
if (el === activeElement)
|
|
605
|
+
return true;
|
|
606
|
+
if ((_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.contains(activeElement))
|
|
607
|
+
return true;
|
|
608
|
+
const rootNode = activeElement.getRootNode();
|
|
609
|
+
return rootNode instanceof ShadowRoot && rootNode.host === el;
|
|
610
|
+
})
|
|
611
|
+
: -1;
|
|
612
|
+
/**
|
|
613
|
+
* A roving-focus group keeps `tabIndex=0` on a single member
|
|
614
|
+
* while the others are `-1`. Arrow keys can move focus onto a
|
|
615
|
+
* `tabIndex=-1` member, which `focusableQueryString` excludes,
|
|
616
|
+
* so `findIndex` yields -1 and Tab would wrap to
|
|
617
|
+
* `allFocusable[0]`. Treat focus on any group member as the
|
|
618
|
+
* group's tabbable slot so Tab goes to the next control (e.g.
|
|
619
|
+
* handle → Cancel), not back to the first member.
|
|
620
|
+
*/
|
|
621
|
+
if (currentIndex < 0 && activeElement) {
|
|
622
|
+
const rovingHost = getRovingFocusHost(activeElement);
|
|
623
|
+
if (rovingHost && lastOverlay.contains(rovingHost)) {
|
|
624
|
+
const directIndex = allFocusable.indexOf(rovingHost);
|
|
625
|
+
if (directIndex >= 0) {
|
|
626
|
+
currentIndex = directIndex;
|
|
627
|
+
}
|
|
628
|
+
else {
|
|
629
|
+
const tabbableIndex = getTabbableRovingFocusIndex(allFocusable, lastOverlay);
|
|
630
|
+
if (tabbableIndex >= 0) {
|
|
631
|
+
currentIndex = tabbableIndex;
|
|
632
|
+
}
|
|
633
|
+
}
|
|
634
|
+
}
|
|
635
|
+
}
|
|
636
|
+
ev.preventDefault();
|
|
637
|
+
// Helper to focus an element, handling shadow DOM properly
|
|
638
|
+
const focusElement = (element) => {
|
|
639
|
+
const shadowRoot = element.shadowRoot;
|
|
640
|
+
if (shadowRoot) {
|
|
641
|
+
const innerFocusable = shadowRoot.querySelector(focusableQueryString);
|
|
642
|
+
if (innerFocusable && typeof element.setFocus !== 'function') {
|
|
643
|
+
focusVisibleElement(innerFocusable);
|
|
644
|
+
return;
|
|
645
|
+
}
|
|
646
|
+
}
|
|
647
|
+
focusVisibleElement(element);
|
|
648
|
+
};
|
|
649
|
+
let nextIndex;
|
|
650
|
+
if (ev.shiftKey) {
|
|
651
|
+
// Shift+Tab: previous element, wrap to last if at first
|
|
652
|
+
if (currentIndex <= 0) {
|
|
653
|
+
nextIndex = allFocusable.length - 1;
|
|
654
|
+
}
|
|
655
|
+
else {
|
|
656
|
+
nextIndex = currentIndex - 1;
|
|
657
|
+
}
|
|
658
|
+
}
|
|
659
|
+
else {
|
|
660
|
+
// Tab: next element, wrap to first if at last
|
|
661
|
+
if (currentIndex < 0 || currentIndex >= allFocusable.length - 1) {
|
|
662
|
+
nextIndex = 0;
|
|
663
|
+
}
|
|
664
|
+
else {
|
|
665
|
+
nextIndex = currentIndex + 1;
|
|
666
|
+
}
|
|
667
|
+
}
|
|
668
|
+
const nextEl = allFocusable[nextIndex];
|
|
669
|
+
const overlayTrap = lastOverlay;
|
|
670
|
+
const tabbableRovingIndex = getTabbableRovingFocusIndex(allFocusable, lastOverlay);
|
|
671
|
+
/**
|
|
672
|
+
* The trap list only includes one tabbable member of a roving
|
|
673
|
+
* group (`tabIndex >= 0`), usually the checked/first radio.
|
|
674
|
+
* `focusin` tracks the real last-focused member. Use it whenever
|
|
675
|
+
* Tab would focus that slot (wrap from Cancel, Shift+Tab from
|
|
676
|
+
* handle, etc.).
|
|
677
|
+
*/
|
|
678
|
+
let focusTarget = nextEl;
|
|
679
|
+
if (tabbableRovingIndex >= 0 && nextIndex === tabbableRovingIndex) {
|
|
680
|
+
const saved = overlayTrap.trapLastRovingFocus;
|
|
681
|
+
if ((saved === null || saved === void 0 ? void 0 : saved.isConnected) && lastOverlay.contains(saved) && saved !== nextEl) {
|
|
682
|
+
focusTarget = saved;
|
|
683
|
+
}
|
|
684
|
+
}
|
|
685
|
+
focusElement(focusTarget);
|
|
686
|
+
}, true);
|
|
401
687
|
// handle back-button click
|
|
402
688
|
doc.addEventListener('ionBackButton', (ev) => {
|
|
403
689
|
const lastOverlay = getPresentedOverlay(doc);
|
|
@@ -511,7 +797,7 @@ const setRootAriaHidden = (hidden = false) => {
|
|
|
511
797
|
viewContainer.removeAttribute('aria-hidden');
|
|
512
798
|
}
|
|
513
799
|
};
|
|
514
|
-
const present = async (overlay, name, iosEnterAnimation, mdEnterAnimation, opts) => {
|
|
800
|
+
const present = async (overlay, name, iosEnterAnimation, mdEnterAnimation, ionicEnterAnimation, opts) => {
|
|
515
801
|
var _a, _b;
|
|
516
802
|
if (overlay.presented) {
|
|
517
803
|
return;
|
|
@@ -559,11 +845,15 @@ const present = async (overlay, name, iosEnterAnimation, mdEnterAnimation, opts)
|
|
|
559
845
|
document.body.classList.add(BACKDROP_NO_SCROLL);
|
|
560
846
|
}
|
|
561
847
|
(_a = overlay.willPresentShorthand) === null || _a === void 0 ? void 0 : _a.emit();
|
|
848
|
+
const theme = getIonTheme(overlay);
|
|
562
849
|
const mode = getIonMode(overlay);
|
|
850
|
+
const selectedAnimation = mode === 'ios'
|
|
851
|
+
? iosEnterAnimation
|
|
852
|
+
: theme === 'ionic' && ionicEnterAnimation
|
|
853
|
+
? ionicEnterAnimation
|
|
854
|
+
: mdEnterAnimation;
|
|
563
855
|
// get the user's animation fn if one was provided
|
|
564
|
-
const animationBuilder = overlay.enterAnimation
|
|
565
|
-
? overlay.enterAnimation
|
|
566
|
-
: config.get(name, mode === 'ios' ? iosEnterAnimation : mdEnterAnimation);
|
|
856
|
+
const animationBuilder = overlay.enterAnimation ? overlay.enterAnimation : config.get(name, selectedAnimation);
|
|
567
857
|
const completed = await overlayAnimation(overlay, animationBuilder, overlay.el, opts);
|
|
568
858
|
if (completed) {
|
|
569
859
|
overlay.didPresent.emit();
|
|
@@ -718,7 +1008,8 @@ const dismiss = async (overlay, data, role, name, iosLeaveAnimation, mdLeaveAnim
|
|
|
718
1008
|
return true;
|
|
719
1009
|
};
|
|
720
1010
|
const getAppRoot = (doc) => {
|
|
721
|
-
|
|
1011
|
+
const appRootSelector = config.get('appRootSelector', 'ion-app');
|
|
1012
|
+
return doc.querySelector(appRootSelector) || doc.body;
|
|
722
1013
|
};
|
|
723
1014
|
const overlayAnimation = async (overlay, animationBuilder, baseEl, opts) => {
|
|
724
1015
|
// Make overlay visible in case it's hidden
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* (C) Ionic http://ionicframework.com - MIT License
|
|
3
|
+
*/
|
|
4
|
+
import { h } from './index-C0EQceqV.js';
|
|
5
|
+
import { a as sanitizeDOMTree } from './index-BUyahZJ4.js';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Converts a DOM node into a Stencil VNode (or text string) so the
|
|
9
|
+
* resulting tree is rendered through the component's normal render
|
|
10
|
+
* path. Rendering through Stencil ensures that scoped CSS classes
|
|
11
|
+
* (e.g. `sc-ion-action-sheet-ionic`) are applied to every element.
|
|
12
|
+
*
|
|
13
|
+
* Highly recommended to pre-sanitize the source DOM (see
|
|
14
|
+
* `getOptionContent` in select.tsx). This function performs pure
|
|
15
|
+
* structural conversion — no security filtering.
|
|
16
|
+
*
|
|
17
|
+
* Preserves attributes only — properties set imperatively on the source
|
|
18
|
+
* element (e.g. `input.value` after a user types) won't carry through.
|
|
19
|
+
* In practice this isn't a concern: interactive controls shouldn't
|
|
20
|
+
* appear in select-option rich content since they'd nest inside the
|
|
21
|
+
* overlay's button/radio/checkbox wrapper, which is invalid HTML and
|
|
22
|
+
* an accessibility issue.
|
|
23
|
+
*
|
|
24
|
+
* @param node - The DOM node to convert. Text nodes become strings,
|
|
25
|
+
* element nodes become VNodes, and any other node types are skipped.
|
|
26
|
+
* @param keyPrefix - String prefix used to build a stable VNode key,
|
|
27
|
+
* so Stencil's diff can preserve elements across re-renders.
|
|
28
|
+
* @param index - Position of this node among its siblings. Combined
|
|
29
|
+
* with `keyPrefix` to form the final unique key.
|
|
30
|
+
* @returns The converted VNode, a text string, or `null` if the node
|
|
31
|
+
* type isn't supported.
|
|
32
|
+
*
|
|
33
|
+
* @internal Exported only so it can be unit tested; not part of the
|
|
34
|
+
* public API.
|
|
35
|
+
*/
|
|
36
|
+
const cloneToVNode = (node, keyPrefix, index) => {
|
|
37
|
+
var _a;
|
|
38
|
+
if (node.nodeType === Node.TEXT_NODE) {
|
|
39
|
+
return (_a = node.textContent) !== null && _a !== void 0 ? _a : '';
|
|
40
|
+
}
|
|
41
|
+
if (node.nodeType !== Node.ELEMENT_NODE) {
|
|
42
|
+
return null;
|
|
43
|
+
}
|
|
44
|
+
const el = node;
|
|
45
|
+
const tag = el.tagName.toLowerCase();
|
|
46
|
+
const key = `${keyPrefix}-${index}`;
|
|
47
|
+
const attrs = { key };
|
|
48
|
+
for (let i = 0; i < el.attributes.length; i++) {
|
|
49
|
+
const attr = el.attributes.item(i);
|
|
50
|
+
attrs[attr.name] = attr.value;
|
|
51
|
+
}
|
|
52
|
+
const children = Array.from(el.childNodes)
|
|
53
|
+
.map((child, i) => cloneToVNode(child, key, i))
|
|
54
|
+
.filter((c) => c !== null);
|
|
55
|
+
return h(tag, attrs, children);
|
|
56
|
+
};
|
|
57
|
+
/**
|
|
58
|
+
* Renders cloned DOM content as Stencil JSX. Walking the source DOM
|
|
59
|
+
* into VNodes (rather than injecting it via innerHTML) keeps the
|
|
60
|
+
* content inside Stencil's render path, so scoped CSS classes are
|
|
61
|
+
* applied automatically and component attributes like `size` or
|
|
62
|
+
* `color` survive intact.
|
|
63
|
+
*
|
|
64
|
+
* Span elements should be used when this content renders within buttons,
|
|
65
|
+
* depending on the select interface. Buttons can only have phrasing
|
|
66
|
+
* content to prevent accessibility issues.
|
|
67
|
+
*
|
|
68
|
+
* @param id - Unique identifier for generating stable virtual DOM keys.
|
|
69
|
+
* @param content - The HTMLElement container whose child nodes will be cloned.
|
|
70
|
+
* @param className - CSS class applied to the wrapper element.
|
|
71
|
+
* @param useSpan - Whether to use a span element instead of a div for the wrapper.
|
|
72
|
+
*/
|
|
73
|
+
const renderClonedContent = (id, content, className, useSpan = false) => {
|
|
74
|
+
const Tag = useSpan ? 'span' : 'div';
|
|
75
|
+
const keyPrefix = `${className}-${id}`;
|
|
76
|
+
sanitizeDOMTree(content);
|
|
77
|
+
return (h(Tag, { class: className, key: keyPrefix }, Array.from(content.childNodes).map((child, i) => cloneToVNode(child, keyPrefix, i))));
|
|
78
|
+
};
|
|
79
|
+
/**
|
|
80
|
+
* Renders the label content for a select option within an overlay
|
|
81
|
+
* interface based on the presence of rich content.
|
|
82
|
+
*
|
|
83
|
+
* Span elements should be used when this content renders within buttons,
|
|
84
|
+
* depending on the select interface. Buttons can only have phrasing
|
|
85
|
+
* content to prevent accessibility issues.
|
|
86
|
+
*
|
|
87
|
+
* @param option - The content option data containing label, slots,
|
|
88
|
+
* and description.
|
|
89
|
+
* @param className - The base CSS class for the label element.
|
|
90
|
+
* @param useSpan - Whether to use a span element instead of a div for the label.
|
|
91
|
+
*/
|
|
92
|
+
const renderOptionLabel = (option, className, useSpan = false) => {
|
|
93
|
+
const { id, label, startContent, endContent, description } = option;
|
|
94
|
+
const hasRichContent = !!startContent || !!endContent || !!description;
|
|
95
|
+
const Tag = useSpan ? 'span' : 'div';
|
|
96
|
+
// Render simple string label if there is no rich content to display
|
|
97
|
+
if (!hasRichContent && (typeof label === 'string' || !label)) {
|
|
98
|
+
return (h(Tag, { class: className, key: `${className}-${id}` }, label));
|
|
99
|
+
}
|
|
100
|
+
// Render the main label
|
|
101
|
+
const labelEl = typeof label === 'string' || !label ? (
|
|
102
|
+
// Label is a simple string or undefined
|
|
103
|
+
h(Tag, { key: `${className}-label-${id}` }, label)) : (
|
|
104
|
+
// Label is an HTMLElement with potential rich content
|
|
105
|
+
renderClonedContent(id, label, `${className}-text`, useSpan));
|
|
106
|
+
// No rich content, render just the label
|
|
107
|
+
if (!hasRichContent) {
|
|
108
|
+
return (h(Tag, { class: className, key: `${className}-${id}` }, labelEl));
|
|
109
|
+
}
|
|
110
|
+
// Render label with rich content (start, end, description)
|
|
111
|
+
return (h(Tag, { class: `${className} ${className}-has-rich-content`, key: `${className}-${id}` }, startContent && renderClonedContent(id, startContent, 'select-option-start', useSpan), h(Tag, { class: "select-option-content", key: `${className}-content-${id}` }, labelEl, description && (h(Tag, { class: "select-option-description", key: `${className}-desc-${id}` }, description))), endContent && renderClonedContent(id, endContent, 'select-option-end', useSpan)));
|
|
112
|
+
};
|
|
113
|
+
|
|
114
|
+
export { renderOptionLabel as r };
|
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* (C) Ionic http://ionicframework.com - MIT License
|
|
3
3
|
*/
|
|
4
|
-
import { a as readTask, w as writeTask } from './index-
|
|
5
|
-
import { f as findClosestIonContent, s as scrollToTop } from './index-
|
|
6
|
-
import { c as componentOnReady } from './helpers-
|
|
4
|
+
import { a as readTask, w as writeTask } from './index-C0EQceqV.js';
|
|
5
|
+
import { f as findClosestIonContent, s as scrollToTop } from './index-KxK0gcRp.js';
|
|
6
|
+
import { c as componentOnReady } from './helpers-DfF5_wJc.js';
|
|
7
|
+
import './focus-visible-vXpMhGrs.js';
|
|
7
8
|
|
|
8
9
|
const startStatusTap = () => {
|
|
9
10
|
const win = window;
|
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* (C) Ionic http://ionicframework.com - MIT License
|
|
3
3
|
*/
|
|
4
|
-
import { e as clamp } from './helpers-
|
|
4
|
+
import { e as clamp } from './helpers-DfF5_wJc.js';
|
|
5
5
|
import { i as isRTL } from './dir-C53feagD.js';
|
|
6
6
|
import { createGesture } from './index-CfgBF1SE.js';
|
|
7
|
-
import './
|
|
7
|
+
import './focus-visible-vXpMhGrs.js';
|
|
8
|
+
import './index-C0EQceqV.js';
|
|
8
9
|
import './gesture-controller-BTEOs1at.js';
|
|
9
10
|
|
|
10
11
|
const createSwipeBackGesture = (el, canStartHandler, onStartHandler, onMoveHandler, onEndHandler) => {
|
|
@@ -1,8 +1,32 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* (C) Ionic http://ionicframework.com - MIT License
|
|
3
3
|
*/
|
|
4
|
+
/**
|
|
5
|
+
* Checks if an element has a parent matching the specified selector.
|
|
6
|
+
* This handles an element in both light DOM and shadow DOM contexts.
|
|
7
|
+
* @param selector The parent selector to check for (e.g., 'ion-datetime'
|
|
8
|
+
* or 'ion-toolbar[color]').
|
|
9
|
+
* @param el The element to check.
|
|
10
|
+
* @returns `true` if the element has a parent matching the specified selector,
|
|
11
|
+
* `false` otherwise.
|
|
12
|
+
*/
|
|
4
13
|
const hostContext = (selector, el) => {
|
|
5
|
-
|
|
14
|
+
// Check the light DOM first
|
|
15
|
+
if (el.closest(selector) !== null) {
|
|
16
|
+
return true;
|
|
17
|
+
}
|
|
18
|
+
// For attribute or class selectors (e.g., 'ion-toolbar[color]' or
|
|
19
|
+
// 'ion-toolbar.ion-color') we can only check light DOM since tagName
|
|
20
|
+
// doesn't include attributes or classes.
|
|
21
|
+
if (selector.includes('[') || selector.includes('.')) {
|
|
22
|
+
return false;
|
|
23
|
+
}
|
|
24
|
+
// Check the shadow DOM by looking at the shadow root host and
|
|
25
|
+
// converting the selector to uppercase to compare with tagName
|
|
26
|
+
const upperCaseTagName = selector.toUpperCase();
|
|
27
|
+
const rootNode = el.getRootNode();
|
|
28
|
+
const shadowHost = rootNode instanceof ShadowRoot ? rootNode.host : null;
|
|
29
|
+
return (shadowHost === null || shadowHost === void 0 ? void 0 : shadowHost.tagName) === upperCaseTagName;
|
|
6
30
|
};
|
|
7
31
|
/**
|
|
8
32
|
* Create the mode and color classes for the component based on the classes passed in
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* (C) Ionic http://ionicframework.com - MIT License
|
|
3
|
+
*/
|
|
4
|
+
/**
|
|
5
|
+
* Checks if the form element is in an invalid state based on
|
|
6
|
+
* Ionic validation classes.
|
|
7
|
+
*
|
|
8
|
+
* @param el The form element to check.
|
|
9
|
+
* @returns `true` if the element is invalid, `false` otherwise.
|
|
10
|
+
*/
|
|
11
|
+
const checkInvalidState = (el) => {
|
|
12
|
+
const hasIonTouched = el.classList.contains('ion-touched');
|
|
13
|
+
const hasIonInvalid = el.classList.contains('ion-invalid');
|
|
14
|
+
return hasIonTouched && hasIonInvalid;
|
|
15
|
+
};
|
|
16
|
+
const getValidityFlags = (validity) => {
|
|
17
|
+
return {
|
|
18
|
+
badInput: validity.badInput,
|
|
19
|
+
customError: validity.customError,
|
|
20
|
+
patternMismatch: validity.patternMismatch,
|
|
21
|
+
rangeOverflow: validity.rangeOverflow,
|
|
22
|
+
rangeUnderflow: validity.rangeUnderflow,
|
|
23
|
+
stepMismatch: validity.stepMismatch,
|
|
24
|
+
tooLong: validity.tooLong,
|
|
25
|
+
tooShort: validity.tooShort,
|
|
26
|
+
typeMismatch: validity.typeMismatch,
|
|
27
|
+
valueMissing: validity.valueMissing,
|
|
28
|
+
};
|
|
29
|
+
};
|
|
30
|
+
/**
|
|
31
|
+
* Reports the validity state of a native form element to ElementInternals.
|
|
32
|
+
* This delegates to the native element's built-in validation, which automatically
|
|
33
|
+
* handles required, minlength, maxlength, and other constraints.
|
|
34
|
+
*/
|
|
35
|
+
const reportValidityToElementInternals = (nativeElement, internals) => {
|
|
36
|
+
if (!(nativeElement === null || nativeElement === void 0 ? void 0 : nativeElement.validity)) {
|
|
37
|
+
return;
|
|
38
|
+
}
|
|
39
|
+
if (nativeElement.validity.valid) {
|
|
40
|
+
internals.setValidity({});
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
const validityFlags = getValidityFlags(nativeElement.validity);
|
|
44
|
+
internals.setValidity(validityFlags, nativeElement.validationMessage, nativeElement);
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
export { checkInvalidState as c, reportValidityToElementInternals as r };
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* (C) Ionic http://ionicframework.com - MIT License
|
|
3
|
+
*/
|
|
4
|
+
const xSvg = 'data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZpZXdCb3g9IjAgMCAyNTYgMjU2IiBmaWxsPSJjdXJyZW50Q29sb3IiPjxwYXRoIGQ9Ik0yMDUuNjYsMTk0LjM0YTgsOCwwLDAsMS0xMS4zMiwxMS4zMkwxMjgsMTM5LjMxLDYxLjY2LDIwNS42NmE4LDgsMCwwLDEtMTEuMzItMTEuMzJMMTE2LjY5LDEyOCw1MC4zNCw2MS42NkE4LDgsMCwwLDEsNjEuNjYsNTAuMzRMMTI4LDExNi42OWw2Ni4zNC02Ni4zNWE4LDgsMCwwLDEsMTEuMzIsMTEuMzJMMTM5LjMxLDEyOFoiLz48L3N2Zz4=';
|
|
5
|
+
|
|
6
|
+
export { xSvg as x };
|