@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,52 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* (C) Ionic http://ionicframework.com - MIT License
|
|
3
|
+
*/
|
|
4
|
+
'use strict';
|
|
5
|
+
|
|
6
|
+
// 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.
|
|
7
|
+
/**
|
|
8
|
+
* Returns the default `labelPlacement` for a radio or checkbox option
|
|
9
|
+
* rendered inside an overlay. Defaults follow each theme's established
|
|
10
|
+
* option-row layout:
|
|
11
|
+
* - `ionic`: always `"start"`.
|
|
12
|
+
* - `ios`: `"start"` for radio in `alert` and `popover`. The `modal`
|
|
13
|
+
* interface flips iOS radio back to `"end"`. Checkbox is always
|
|
14
|
+
* `"end"` on iOS.
|
|
15
|
+
* - everything else (e.g. `md`): `"end"`.
|
|
16
|
+
*
|
|
17
|
+
* `interfaceType` is optional; only `"modal"` changes the result, so
|
|
18
|
+
* callers that aren't a modal can omit it.
|
|
19
|
+
*
|
|
20
|
+
* Used by `alert`, `select-popover`, and `select-modal` as the fallback
|
|
21
|
+
* when an option doesn't explicitly set `labelPlacement`.
|
|
22
|
+
*/
|
|
23
|
+
const getOverlayLabelPlacement = (theme, control, interfaceType) => {
|
|
24
|
+
if (theme === 'ionic' || (theme === 'ios' && control === 'radio' && interfaceType !== 'modal')) {
|
|
25
|
+
return 'start';
|
|
26
|
+
}
|
|
27
|
+
return 'end';
|
|
28
|
+
};
|
|
29
|
+
/**
|
|
30
|
+
* Returns the default `justify` for a radio or checkbox option rendered
|
|
31
|
+
* inside an overlay. Defaults follow each theme's option-row layout:
|
|
32
|
+
* - `ionic`: always `"space-between"`.
|
|
33
|
+
* - `ios`: `"space-between"` for radio in `alert` and `popover`. The
|
|
34
|
+
* `modal` interface falls back to `"start"`. Checkbox is always `"start"`
|
|
35
|
+
* on iOS.
|
|
36
|
+
* - everything else (e.g. `md`): `"start"`.
|
|
37
|
+
*
|
|
38
|
+
* `interfaceType` is optional; only `"modal"` changes the result, so
|
|
39
|
+
* callers that aren't a modal can omit it.
|
|
40
|
+
*
|
|
41
|
+
* Used by `alert`, `select-popover`, and `select-modal` as the fallback when
|
|
42
|
+
* an option doesn't explicitly set `justify`.
|
|
43
|
+
*/
|
|
44
|
+
const getOverlayLabelJustify = (theme, control, interfaceType) => {
|
|
45
|
+
if (theme === 'ionic' || (theme === 'ios' && control === 'radio' && interfaceType !== 'modal')) {
|
|
46
|
+
return 'space-between';
|
|
47
|
+
}
|
|
48
|
+
return 'start';
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
exports.getOverlayLabelJustify = getOverlayLabelJustify;
|
|
52
|
+
exports.getOverlayLabelPlacement = getOverlayLabelPlacement;
|
|
@@ -3,12 +3,10 @@
|
|
|
3
3
|
*/
|
|
4
4
|
'use strict';
|
|
5
5
|
|
|
6
|
-
var
|
|
7
|
-
var helpers = require('./helpers-
|
|
8
|
-
var
|
|
9
|
-
var
|
|
10
|
-
var ionicGlobal = require('./ionic-global-B-cA6LkY.js');
|
|
11
|
-
var frameworkDelegate = require('./framework-delegate-BtICZDHr.js');
|
|
6
|
+
var ionicGlobal = require('./ionic-global-QoUqobrQ.js');
|
|
7
|
+
var helpers = require('./helpers-DiOgV5hw.js');
|
|
8
|
+
var index = require('./index-GZU9YrFc.js');
|
|
9
|
+
var frameworkDelegate = require('./framework-delegate-DC5nq_NN.js');
|
|
12
10
|
var gestureController = require('./gesture-controller-dtqlP_q4.js');
|
|
13
11
|
|
|
14
12
|
/**
|
|
@@ -23,7 +21,7 @@ var gestureController = require('./gesture-controller-dtqlP_q4.js');
|
|
|
23
21
|
* Note: We need this distinction because `disabled="false"` is
|
|
24
22
|
* valid usage for the disabled property on ion-button.
|
|
25
23
|
*/
|
|
26
|
-
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])';
|
|
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-textarea:not([tabindex^="-"]):not([hidden]):not([disabled]), .ion-focusable:not([tabindex^="-"]):not([hidden]):not([disabled]), .ion-focusable[disabled="false"]:not([tabindex^="-"]):not([hidden])';
|
|
27
25
|
/**
|
|
28
26
|
* Focuses the first descendant in a context
|
|
29
27
|
* that can receive focus. If none exists,
|
|
@@ -75,7 +73,18 @@ const focusElementInContext = (hostToFocus, fallbackElement) => {
|
|
|
75
73
|
const shadowRoot = hostToFocus === null || hostToFocus === void 0 ? void 0 : hostToFocus.shadowRoot;
|
|
76
74
|
if (shadowRoot) {
|
|
77
75
|
// If there are no inner focusable elements, just focus the host element.
|
|
78
|
-
|
|
76
|
+
const innerFocusable = shadowRoot.querySelector(focusableQueryString);
|
|
77
|
+
// If the host has a setFocus() method, use it to delegate focus properly.
|
|
78
|
+
// This is needed for shadow DOM components like ion-textarea that override
|
|
79
|
+
// focus() to delegate to their inner native elements.
|
|
80
|
+
const hasSetFocus = typeof hostToFocus.setFocus === 'function';
|
|
81
|
+
if (innerFocusable && hasSetFocus) {
|
|
82
|
+
// Keep the host element so we can call setFocus() on it
|
|
83
|
+
elementToFocus = hostToFocus;
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
elementToFocus = innerFocusable || hostToFocus;
|
|
87
|
+
}
|
|
79
88
|
}
|
|
80
89
|
if (elementToFocus) {
|
|
81
90
|
const radioGroup = elementToFocus.closest('ion-radio-group');
|
|
@@ -95,8 +104,115 @@ const focusElementInContext = (hostToFocus, fallbackElement) => {
|
|
|
95
104
|
let lastOverlayIndex = 0;
|
|
96
105
|
let lastId = 0;
|
|
97
106
|
const activeAnimations = new WeakMap();
|
|
107
|
+
const OVERLAY_FOCUS_TRAP_SELECTOR = 'ion-alert,ion-action-sheet,ion-loading,ion-modal,ion-picker-legacy,ion-popover';
|
|
98
108
|
/**
|
|
99
|
-
*
|
|
109
|
+
* The focus trap is generic and knows nothing about which components are
|
|
110
|
+
* inside an overlay. Components mark their elements with these `data-*`
|
|
111
|
+
* attributes, which the trap reads, to control how Tab moves through them.
|
|
112
|
+
* This keeps private component class names (e.g. `.modal-handle`,
|
|
113
|
+
* `.action-sheet-button`) out of the trap, so changing a component does
|
|
114
|
+
* not silently break Tab order.
|
|
115
|
+
*
|
|
116
|
+
* - `data-focus-ignore`: skip this element as a tab stop.
|
|
117
|
+
* - `data-focus-order`: explicit numeric placement in the tab sequence.
|
|
118
|
+
* - `data-roving-focus`: a container whose focusable descendants share a
|
|
119
|
+
* single tab stop via a roving tabindex.
|
|
120
|
+
*/
|
|
121
|
+
const FOCUS_IGNORE_SELECTOR = '[data-focus-ignore]';
|
|
122
|
+
const FOCUS_ORDER_SELECTOR = '[data-focus-order]';
|
|
123
|
+
const ROVING_FOCUS_SELECTOR = '[data-roving-focus]';
|
|
124
|
+
/**
|
|
125
|
+
* Returns the roving-focus group an element belongs to, or `null`.
|
|
126
|
+
* A member is a descendant of a `[data-roving-focus]` container. The
|
|
127
|
+
* container itself is not a member. Members share a single tab stop.
|
|
128
|
+
*/
|
|
129
|
+
const getRovingFocusGroup = (el) => {
|
|
130
|
+
const group = el.closest(ROVING_FOCUS_SELECTOR);
|
|
131
|
+
return group !== null && group !== el ? group : null;
|
|
132
|
+
};
|
|
133
|
+
/**
|
|
134
|
+
* Whether an element participates in a roving-focus group.
|
|
135
|
+
*/
|
|
136
|
+
const isRovingFocusItem = (el) => getRovingFocusGroup(el) !== null;
|
|
137
|
+
/**
|
|
138
|
+
* Returns the currently focused element for keyboard focus checks.
|
|
139
|
+
*
|
|
140
|
+
* Starts from `document.activeElement` (non-shadow / light DOM focus).
|
|
141
|
+
* If focus is inside one or more open shadow roots
|
|
142
|
+
* (e.g. native control inside `ion-radio`), walks through nested
|
|
143
|
+
* `shadowRoot.activeElement` values until the innermost focused node is reached.
|
|
144
|
+
*/
|
|
145
|
+
const getActiveElement = (ownerDoc) => {
|
|
146
|
+
var _a;
|
|
147
|
+
let active = ownerDoc.activeElement;
|
|
148
|
+
if (!active) {
|
|
149
|
+
return null;
|
|
150
|
+
}
|
|
151
|
+
while ((_a = active.shadowRoot) === null || _a === void 0 ? void 0 : _a.activeElement) {
|
|
152
|
+
active = active.shadowRoot.activeElement;
|
|
153
|
+
}
|
|
154
|
+
return active;
|
|
155
|
+
};
|
|
156
|
+
/**
|
|
157
|
+
* Walks from a focused node (possibly deep inside shadow roots) up to
|
|
158
|
+
* the nearest roving-focus host (e.g. `ion-radio` inside an
|
|
159
|
+
* `ion-radio-group`, or an action sheet `<button role="radio">`).
|
|
160
|
+
*/
|
|
161
|
+
const getRovingFocusHost = (active) => {
|
|
162
|
+
let n = active;
|
|
163
|
+
while (n) {
|
|
164
|
+
if (isRovingFocusItem(n)) {
|
|
165
|
+
return n;
|
|
166
|
+
}
|
|
167
|
+
const root = n.getRootNode();
|
|
168
|
+
if (root instanceof ShadowRoot && root.host instanceof HTMLElement) {
|
|
169
|
+
n = root.host;
|
|
170
|
+
}
|
|
171
|
+
else {
|
|
172
|
+
return null;
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
return null;
|
|
176
|
+
};
|
|
177
|
+
/**
|
|
178
|
+
* Reorders focusables for components that declare an explicit tab order
|
|
179
|
+
* via `data-focus-order`. Elements without the attribute keep their
|
|
180
|
+
* visual order and are visited first. Elements with it are appended
|
|
181
|
+
* afterwards, sorted by ascending numeric value.
|
|
182
|
+
*
|
|
183
|
+
* Example (sheet modal): the options have no order and are visited
|
|
184
|
+
* first in visual order, then the drag handle (`data-focus-order="1"`),
|
|
185
|
+
* then the header Cancel button (`data-focus-order="2"`).
|
|
186
|
+
*/
|
|
187
|
+
const applyFocusOrder = (elements) => {
|
|
188
|
+
const sortByVisualPosition = (els) => [...els].sort((a, b) => {
|
|
189
|
+
const ra = a.getBoundingClientRect();
|
|
190
|
+
const rb = b.getBoundingClientRect();
|
|
191
|
+
const topDiff = ra.top - rb.top;
|
|
192
|
+
if (Math.abs(topDiff) > 1) {
|
|
193
|
+
return topDiff;
|
|
194
|
+
}
|
|
195
|
+
return ra.left - rb.left;
|
|
196
|
+
});
|
|
197
|
+
const unordered = elements.filter((el) => !el.matches(FOCUS_ORDER_SELECTOR));
|
|
198
|
+
const ordered = elements
|
|
199
|
+
.filter((el) => el.matches(FOCUS_ORDER_SELECTOR))
|
|
200
|
+
.sort((a, b) => Number(a.getAttribute('data-focus-order')) - Number(b.getAttribute('data-focus-order')));
|
|
201
|
+
return [...sortByVisualPosition(unordered), ...ordered];
|
|
202
|
+
};
|
|
203
|
+
/**
|
|
204
|
+
* Roving-focus members use a tabindex pattern where only one member is
|
|
205
|
+
* tabbable (`tabIndex="0"`) while the others are not (`tabIndex="-1"`).
|
|
206
|
+
* This returns the index of the current tabbable member.
|
|
207
|
+
*/
|
|
208
|
+
const getTabbableRovingFocusIndex = (elements, overlay) => {
|
|
209
|
+
return elements.findIndex((el) => {
|
|
210
|
+
return overlay.contains(el) && isRovingFocusItem(el) && el.tabIndex >= 0;
|
|
211
|
+
});
|
|
212
|
+
};
|
|
213
|
+
/**
|
|
214
|
+
* Determines if the overlay's backdrop is always blocking
|
|
215
|
+
* (no background interaction).
|
|
100
216
|
* Returns false if showBackdrop=false or backdropBreakpoint > 0.
|
|
101
217
|
*/
|
|
102
218
|
const isBackdropAlwaysBlocking = (el) => {
|
|
@@ -217,7 +333,7 @@ const focusElementInOverlay = (hostToFocus, overlay) => {
|
|
|
217
333
|
* Should NOT include: Toast
|
|
218
334
|
*/
|
|
219
335
|
const trapKeyboardFocus = (ev, doc) => {
|
|
220
|
-
const lastOverlay = getPresentedOverlay(doc,
|
|
336
|
+
const lastOverlay = getPresentedOverlay(doc, OVERLAY_FOCUS_TRAP_SELECTOR);
|
|
221
337
|
const target = ev.target;
|
|
222
338
|
/**
|
|
223
339
|
* If no active overlay, ignore this event.
|
|
@@ -400,11 +516,181 @@ const connectListeners = (doc) => {
|
|
|
400
516
|
doc.addEventListener('focus', (ev) => {
|
|
401
517
|
trapKeyboardFocus(ev, doc);
|
|
402
518
|
}, true);
|
|
519
|
+
/**
|
|
520
|
+
* Remember which roving-focus member last received focus
|
|
521
|
+
* (arrows, click, or Tab). A roving group keeps `tabIndex=0` on a
|
|
522
|
+
* single member (e.g. the checked/first radio), so the Tab trap
|
|
523
|
+
* uses this when wrapping back into the group or focusing its slot.
|
|
524
|
+
*/
|
|
525
|
+
doc.addEventListener('focusin', (ev) => {
|
|
526
|
+
const lastOverlay = getPresentedOverlay(doc, OVERLAY_FOCUS_TRAP_SELECTOR);
|
|
527
|
+
if (!lastOverlay || lastOverlay.classList.contains(FOCUS_TRAP_DISABLE_CLASS)) {
|
|
528
|
+
return;
|
|
529
|
+
}
|
|
530
|
+
const target = ev.target;
|
|
531
|
+
if (!(target instanceof HTMLElement)) {
|
|
532
|
+
return;
|
|
533
|
+
}
|
|
534
|
+
const rovingHost = getRovingFocusHost(target);
|
|
535
|
+
if (rovingHost && lastOverlay.contains(rovingHost)) {
|
|
536
|
+
lastOverlay.trapLastRovingFocus = rovingHost;
|
|
537
|
+
}
|
|
538
|
+
}, true);
|
|
539
|
+
// Listen for keydown events to intercept Tab navigation.
|
|
540
|
+
// This is needed for Safari and Firefox which may skip focusable
|
|
541
|
+
// elements or allow focus to escape the overlay.
|
|
542
|
+
// It also ensures proper focus delegation for shadow DOM elements
|
|
543
|
+
// like ion-textarea.
|
|
544
|
+
doc.addEventListener('keydown', (ev) => {
|
|
545
|
+
var _a, _b, _c;
|
|
546
|
+
if (ev.key !== 'Tab' && ev.key !== 'Alt+Tab')
|
|
547
|
+
return;
|
|
548
|
+
const lastOverlay = getPresentedOverlay(doc, OVERLAY_FOCUS_TRAP_SELECTOR);
|
|
549
|
+
if (!lastOverlay || lastOverlay.classList.contains(FOCUS_TRAP_DISABLE_CLASS))
|
|
550
|
+
return;
|
|
551
|
+
const activeElement = getActiveElement(doc);
|
|
552
|
+
if (activeElement === lastOverlay) {
|
|
553
|
+
ev.preventDefault();
|
|
554
|
+
focusFirstDescendant(lastOverlay);
|
|
555
|
+
return;
|
|
556
|
+
}
|
|
557
|
+
// Check if activeElement is inside the overlay (including shadow DOM)
|
|
558
|
+
const isInsideOverlay = activeElement
|
|
559
|
+
? lastOverlay.contains(activeElement) ||
|
|
560
|
+
(activeElement.getRootNode() instanceof ShadowRoot &&
|
|
561
|
+
lastOverlay.contains(activeElement.getRootNode().host)) ||
|
|
562
|
+
((_b = (_a = lastOverlay.shadowRoot) === null || _a === void 0 ? void 0 : _a.contains(activeElement)) !== null && _b !== void 0 ? _b : false)
|
|
563
|
+
: false;
|
|
564
|
+
if (!isInsideOverlay)
|
|
565
|
+
return;
|
|
566
|
+
// Get all focusable elements from both light and shadow DOM
|
|
567
|
+
let allFocusable = [
|
|
568
|
+
...lastOverlay.querySelectorAll(focusableQueryString),
|
|
569
|
+
...(((_c = lastOverlay.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelectorAll(focusableQueryString)) || []),
|
|
570
|
+
];
|
|
571
|
+
/**
|
|
572
|
+
* Some elements match `focusableQueryString` but are not
|
|
573
|
+
* intended tab stops (e.g. the `ion-item` wrappers a select
|
|
574
|
+
* modal renders around its options). Components opt these out
|
|
575
|
+
* with `data-focus-ignore` so Tab can move between the real
|
|
576
|
+
* controls.
|
|
577
|
+
*/
|
|
578
|
+
allFocusable = allFocusable.filter((el) => !el.matches(FOCUS_IGNORE_SELECTOR));
|
|
579
|
+
/**
|
|
580
|
+
* A roving-focus group is a single tab stop: only its currently
|
|
581
|
+
* tabbable member (`tabIndex >= 0`) participates. Other
|
|
582
|
+
* focusables inside the group are not independent tab stops —
|
|
583
|
+
* this includes inactive members and focusable wrappers such as
|
|
584
|
+
* the `ion-item` that carries `ion-focusable` on behalf of a
|
|
585
|
+
* radio. Drop them so Tab moves between the group and the
|
|
586
|
+
* surrounding controls (e.g. the handle), not into the wrappers.
|
|
587
|
+
*/
|
|
588
|
+
allFocusable = allFocusable.filter((el) => !isRovingFocusItem(el) || el.tabIndex >= 0);
|
|
589
|
+
/**
|
|
590
|
+
* When a component declares an explicit tab order via
|
|
591
|
+
* `data-focus-order` (e.g. a sheet modal's handle and Cancel
|
|
592
|
+
* button), reorder accordingly. Overlays that declare no order
|
|
593
|
+
* keep their DOM order.
|
|
594
|
+
*/
|
|
595
|
+
if (allFocusable.some((el) => el.matches(FOCUS_ORDER_SELECTOR))) {
|
|
596
|
+
allFocusable = applyFocusOrder(allFocusable);
|
|
597
|
+
}
|
|
598
|
+
if (allFocusable.length === 0) {
|
|
599
|
+
ev.preventDefault();
|
|
600
|
+
return;
|
|
601
|
+
}
|
|
602
|
+
// Find current element's index (accounting for shadow DOM)
|
|
603
|
+
let currentIndex = activeElement
|
|
604
|
+
? allFocusable.findIndex((el) => {
|
|
605
|
+
var _a;
|
|
606
|
+
if (el === activeElement)
|
|
607
|
+
return true;
|
|
608
|
+
if ((_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.contains(activeElement))
|
|
609
|
+
return true;
|
|
610
|
+
const rootNode = activeElement.getRootNode();
|
|
611
|
+
return rootNode instanceof ShadowRoot && rootNode.host === el;
|
|
612
|
+
})
|
|
613
|
+
: -1;
|
|
614
|
+
/**
|
|
615
|
+
* A roving-focus group keeps `tabIndex=0` on a single member
|
|
616
|
+
* while the others are `-1`. Arrow keys can move focus onto a
|
|
617
|
+
* `tabIndex=-1` member, which `focusableQueryString` excludes,
|
|
618
|
+
* so `findIndex` yields -1 and Tab would wrap to
|
|
619
|
+
* `allFocusable[0]`. Treat focus on any group member as the
|
|
620
|
+
* group's tabbable slot so Tab goes to the next control (e.g.
|
|
621
|
+
* handle → Cancel), not back to the first member.
|
|
622
|
+
*/
|
|
623
|
+
if (currentIndex < 0 && activeElement) {
|
|
624
|
+
const rovingHost = getRovingFocusHost(activeElement);
|
|
625
|
+
if (rovingHost && lastOverlay.contains(rovingHost)) {
|
|
626
|
+
const directIndex = allFocusable.indexOf(rovingHost);
|
|
627
|
+
if (directIndex >= 0) {
|
|
628
|
+
currentIndex = directIndex;
|
|
629
|
+
}
|
|
630
|
+
else {
|
|
631
|
+
const tabbableIndex = getTabbableRovingFocusIndex(allFocusable, lastOverlay);
|
|
632
|
+
if (tabbableIndex >= 0) {
|
|
633
|
+
currentIndex = tabbableIndex;
|
|
634
|
+
}
|
|
635
|
+
}
|
|
636
|
+
}
|
|
637
|
+
}
|
|
638
|
+
ev.preventDefault();
|
|
639
|
+
// Helper to focus an element, handling shadow DOM properly
|
|
640
|
+
const focusElement = (element) => {
|
|
641
|
+
const shadowRoot = element.shadowRoot;
|
|
642
|
+
if (shadowRoot) {
|
|
643
|
+
const innerFocusable = shadowRoot.querySelector(focusableQueryString);
|
|
644
|
+
if (innerFocusable && typeof element.setFocus !== 'function') {
|
|
645
|
+
helpers.focusVisibleElement(innerFocusable);
|
|
646
|
+
return;
|
|
647
|
+
}
|
|
648
|
+
}
|
|
649
|
+
helpers.focusVisibleElement(element);
|
|
650
|
+
};
|
|
651
|
+
let nextIndex;
|
|
652
|
+
if (ev.shiftKey) {
|
|
653
|
+
// Shift+Tab: previous element, wrap to last if at first
|
|
654
|
+
if (currentIndex <= 0) {
|
|
655
|
+
nextIndex = allFocusable.length - 1;
|
|
656
|
+
}
|
|
657
|
+
else {
|
|
658
|
+
nextIndex = currentIndex - 1;
|
|
659
|
+
}
|
|
660
|
+
}
|
|
661
|
+
else {
|
|
662
|
+
// Tab: next element, wrap to first if at last
|
|
663
|
+
if (currentIndex < 0 || currentIndex >= allFocusable.length - 1) {
|
|
664
|
+
nextIndex = 0;
|
|
665
|
+
}
|
|
666
|
+
else {
|
|
667
|
+
nextIndex = currentIndex + 1;
|
|
668
|
+
}
|
|
669
|
+
}
|
|
670
|
+
const nextEl = allFocusable[nextIndex];
|
|
671
|
+
const overlayTrap = lastOverlay;
|
|
672
|
+
const tabbableRovingIndex = getTabbableRovingFocusIndex(allFocusable, lastOverlay);
|
|
673
|
+
/**
|
|
674
|
+
* The trap list only includes one tabbable member of a roving
|
|
675
|
+
* group (`tabIndex >= 0`), usually the checked/first radio.
|
|
676
|
+
* `focusin` tracks the real last-focused member. Use it whenever
|
|
677
|
+
* Tab would focus that slot (wrap from Cancel, Shift+Tab from
|
|
678
|
+
* handle, etc.).
|
|
679
|
+
*/
|
|
680
|
+
let focusTarget = nextEl;
|
|
681
|
+
if (tabbableRovingIndex >= 0 && nextIndex === tabbableRovingIndex) {
|
|
682
|
+
const saved = overlayTrap.trapLastRovingFocus;
|
|
683
|
+
if ((saved === null || saved === void 0 ? void 0 : saved.isConnected) && lastOverlay.contains(saved) && saved !== nextEl) {
|
|
684
|
+
focusTarget = saved;
|
|
685
|
+
}
|
|
686
|
+
}
|
|
687
|
+
focusElement(focusTarget);
|
|
688
|
+
}, true);
|
|
403
689
|
// handle back-button click
|
|
404
690
|
doc.addEventListener('ionBackButton', (ev) => {
|
|
405
691
|
const lastOverlay = getPresentedOverlay(doc);
|
|
406
692
|
if (lastOverlay === null || lastOverlay === void 0 ? void 0 : lastOverlay.backdropDismiss) {
|
|
407
|
-
ev.detail.register(
|
|
693
|
+
ev.detail.register(ionicGlobal.OVERLAY_BACK_BUTTON_PRIORITY, () => {
|
|
408
694
|
/**
|
|
409
695
|
* Do not return this promise otherwise
|
|
410
696
|
* the hardware back button utility will
|
|
@@ -427,7 +713,7 @@ const connectListeners = (doc) => {
|
|
|
427
713
|
* this behavior will be handled via the ionBackButton
|
|
428
714
|
* event.
|
|
429
715
|
*/
|
|
430
|
-
if (!
|
|
716
|
+
if (!ionicGlobal.shouldUseCloseWatcher()) {
|
|
431
717
|
doc.addEventListener('keydown', (ev) => {
|
|
432
718
|
if (ev.key === 'Escape') {
|
|
433
719
|
const lastOverlay = getPresentedOverlay(doc);
|
|
@@ -513,7 +799,7 @@ const setRootAriaHidden = (hidden = false) => {
|
|
|
513
799
|
viewContainer.removeAttribute('aria-hidden');
|
|
514
800
|
}
|
|
515
801
|
};
|
|
516
|
-
const present = async (overlay, name, iosEnterAnimation, mdEnterAnimation, opts) => {
|
|
802
|
+
const present = async (overlay, name, iosEnterAnimation, mdEnterAnimation, ionicEnterAnimation, opts) => {
|
|
517
803
|
var _a, _b;
|
|
518
804
|
if (overlay.presented) {
|
|
519
805
|
return;
|
|
@@ -561,11 +847,15 @@ const present = async (overlay, name, iosEnterAnimation, mdEnterAnimation, opts)
|
|
|
561
847
|
document.body.classList.add(gestureController.BACKDROP_NO_SCROLL);
|
|
562
848
|
}
|
|
563
849
|
(_a = overlay.willPresentShorthand) === null || _a === void 0 ? void 0 : _a.emit();
|
|
850
|
+
const theme = ionicGlobal.getIonTheme(overlay);
|
|
564
851
|
const mode = ionicGlobal.getIonMode(overlay);
|
|
852
|
+
const selectedAnimation = mode === 'ios'
|
|
853
|
+
? iosEnterAnimation
|
|
854
|
+
: theme === 'ionic' && ionicEnterAnimation
|
|
855
|
+
? ionicEnterAnimation
|
|
856
|
+
: mdEnterAnimation;
|
|
565
857
|
// get the user's animation fn if one was provided
|
|
566
|
-
const animationBuilder = overlay.enterAnimation
|
|
567
|
-
? overlay.enterAnimation
|
|
568
|
-
: index.config.get(name, mode === 'ios' ? iosEnterAnimation : mdEnterAnimation);
|
|
858
|
+
const animationBuilder = overlay.enterAnimation ? overlay.enterAnimation : index.config.get(name, selectedAnimation);
|
|
569
859
|
const completed = await overlayAnimation(overlay, animationBuilder, overlay.el, opts);
|
|
570
860
|
if (completed) {
|
|
571
861
|
overlay.didPresent.emit();
|
|
@@ -651,7 +941,7 @@ const dismiss = async (overlay, data, role, name, iosLeaveAnimation, mdLeaveAnim
|
|
|
651
941
|
if (!overlay.presented) {
|
|
652
942
|
return false;
|
|
653
943
|
}
|
|
654
|
-
const presentedOverlays =
|
|
944
|
+
const presentedOverlays = ionicGlobal.doc !== undefined ? getPresentedOverlays(ionicGlobal.doc) : [];
|
|
655
945
|
/**
|
|
656
946
|
* For accessibility, toasts lack focus traps and don't receive
|
|
657
947
|
* `aria-hidden` on the root element when presented.
|
|
@@ -720,7 +1010,8 @@ const dismiss = async (overlay, data, role, name, iosLeaveAnimation, mdLeaveAnim
|
|
|
720
1010
|
return true;
|
|
721
1011
|
};
|
|
722
1012
|
const getAppRoot = (doc) => {
|
|
723
|
-
|
|
1013
|
+
const appRootSelector = index.config.get('appRootSelector', 'ion-app');
|
|
1014
|
+
return doc.querySelector(appRootSelector) || doc.body;
|
|
724
1015
|
};
|
|
725
1016
|
const overlayAnimation = async (overlay, animationBuilder, baseEl, opts) => {
|
|
726
1017
|
// Make overlay visible in case it's hidden
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* (C) Ionic http://ionicframework.com - MIT License
|
|
3
|
+
*/
|
|
4
|
+
'use strict';
|
|
5
|
+
|
|
6
|
+
var index = require('./index-GZU9YrFc.js');
|
|
7
|
+
var index$1 = require('./index-CzFol6Yk.js');
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Converts a DOM node into a Stencil VNode (or text string) so the
|
|
11
|
+
* resulting tree is rendered through the component's normal render
|
|
12
|
+
* path. Rendering through Stencil ensures that scoped CSS classes
|
|
13
|
+
* (e.g. `sc-ion-action-sheet-ionic`) are applied to every element.
|
|
14
|
+
*
|
|
15
|
+
* Highly recommended to pre-sanitize the source DOM (see
|
|
16
|
+
* `getOptionContent` in select.tsx). This function performs pure
|
|
17
|
+
* structural conversion — no security filtering.
|
|
18
|
+
*
|
|
19
|
+
* Preserves attributes only — properties set imperatively on the source
|
|
20
|
+
* element (e.g. `input.value` after a user types) won't carry through.
|
|
21
|
+
* In practice this isn't a concern: interactive controls shouldn't
|
|
22
|
+
* appear in select-option rich content since they'd nest inside the
|
|
23
|
+
* overlay's button/radio/checkbox wrapper, which is invalid HTML and
|
|
24
|
+
* an accessibility issue.
|
|
25
|
+
*
|
|
26
|
+
* @param node - The DOM node to convert. Text nodes become strings,
|
|
27
|
+
* element nodes become VNodes, and any other node types are skipped.
|
|
28
|
+
* @param keyPrefix - String prefix used to build a stable VNode key,
|
|
29
|
+
* so Stencil's diff can preserve elements across re-renders.
|
|
30
|
+
* @param index - Position of this node among its siblings. Combined
|
|
31
|
+
* with `keyPrefix` to form the final unique key.
|
|
32
|
+
* @returns The converted VNode, a text string, or `null` if the node
|
|
33
|
+
* type isn't supported.
|
|
34
|
+
*
|
|
35
|
+
* @internal Exported only so it can be unit tested; not part of the
|
|
36
|
+
* public API.
|
|
37
|
+
*/
|
|
38
|
+
const cloneToVNode = (node, keyPrefix, index$1) => {
|
|
39
|
+
var _a;
|
|
40
|
+
if (node.nodeType === Node.TEXT_NODE) {
|
|
41
|
+
return (_a = node.textContent) !== null && _a !== void 0 ? _a : '';
|
|
42
|
+
}
|
|
43
|
+
if (node.nodeType !== Node.ELEMENT_NODE) {
|
|
44
|
+
return null;
|
|
45
|
+
}
|
|
46
|
+
const el = node;
|
|
47
|
+
const tag = el.tagName.toLowerCase();
|
|
48
|
+
const key = `${keyPrefix}-${index$1}`;
|
|
49
|
+
const attrs = { key };
|
|
50
|
+
for (let i = 0; i < el.attributes.length; i++) {
|
|
51
|
+
const attr = el.attributes.item(i);
|
|
52
|
+
attrs[attr.name] = attr.value;
|
|
53
|
+
}
|
|
54
|
+
const children = Array.from(el.childNodes)
|
|
55
|
+
.map((child, i) => cloneToVNode(child, key, i))
|
|
56
|
+
.filter((c) => c !== null);
|
|
57
|
+
return index.h(tag, attrs, children);
|
|
58
|
+
};
|
|
59
|
+
/**
|
|
60
|
+
* Renders cloned DOM content as Stencil JSX. Walking the source DOM
|
|
61
|
+
* into VNodes (rather than injecting it via innerHTML) keeps the
|
|
62
|
+
* content inside Stencil's render path, so scoped CSS classes are
|
|
63
|
+
* applied automatically and component attributes like `size` or
|
|
64
|
+
* `color` survive intact.
|
|
65
|
+
*
|
|
66
|
+
* Span elements should be used when this content renders within buttons,
|
|
67
|
+
* depending on the select interface. Buttons can only have phrasing
|
|
68
|
+
* content to prevent accessibility issues.
|
|
69
|
+
*
|
|
70
|
+
* @param id - Unique identifier for generating stable virtual DOM keys.
|
|
71
|
+
* @param content - The HTMLElement container whose child nodes will be cloned.
|
|
72
|
+
* @param className - CSS class applied to the wrapper element.
|
|
73
|
+
* @param useSpan - Whether to use a span element instead of a div for the wrapper.
|
|
74
|
+
*/
|
|
75
|
+
const renderClonedContent = (id, content, className, useSpan = false) => {
|
|
76
|
+
const Tag = useSpan ? 'span' : 'div';
|
|
77
|
+
const keyPrefix = `${className}-${id}`;
|
|
78
|
+
index$1.sanitizeDOMTree(content);
|
|
79
|
+
return (index.h(Tag, { class: className, key: keyPrefix }, Array.from(content.childNodes).map((child, i) => cloneToVNode(child, keyPrefix, i))));
|
|
80
|
+
};
|
|
81
|
+
/**
|
|
82
|
+
* Renders the label content for a select option within an overlay
|
|
83
|
+
* interface based on the presence of rich content.
|
|
84
|
+
*
|
|
85
|
+
* Span elements should be used when this content renders within buttons,
|
|
86
|
+
* depending on the select interface. Buttons can only have phrasing
|
|
87
|
+
* content to prevent accessibility issues.
|
|
88
|
+
*
|
|
89
|
+
* @param option - The content option data containing label, slots,
|
|
90
|
+
* and description.
|
|
91
|
+
* @param className - The base CSS class for the label element.
|
|
92
|
+
* @param useSpan - Whether to use a span element instead of a div for the label.
|
|
93
|
+
*/
|
|
94
|
+
const renderOptionLabel = (option, className, useSpan = false) => {
|
|
95
|
+
const { id, label, startContent, endContent, description } = option;
|
|
96
|
+
const hasRichContent = !!startContent || !!endContent || !!description;
|
|
97
|
+
const Tag = useSpan ? 'span' : 'div';
|
|
98
|
+
// Render simple string label if there is no rich content to display
|
|
99
|
+
if (!hasRichContent && (typeof label === 'string' || !label)) {
|
|
100
|
+
return (index.h(Tag, { class: className, key: `${className}-${id}` }, label));
|
|
101
|
+
}
|
|
102
|
+
// Render the main label
|
|
103
|
+
const labelEl = typeof label === 'string' || !label ? (
|
|
104
|
+
// Label is a simple string or undefined
|
|
105
|
+
index.h(Tag, { key: `${className}-label-${id}` }, label)) : (
|
|
106
|
+
// Label is an HTMLElement with potential rich content
|
|
107
|
+
renderClonedContent(id, label, `${className}-text`, useSpan));
|
|
108
|
+
// No rich content, render just the label
|
|
109
|
+
if (!hasRichContent) {
|
|
110
|
+
return (index.h(Tag, { class: className, key: `${className}-${id}` }, labelEl));
|
|
111
|
+
}
|
|
112
|
+
// Render label with rich content (start, end, description)
|
|
113
|
+
return (index.h(Tag, { class: `${className} ${className}-has-rich-content`, key: `${className}-${id}` }, startContent && renderClonedContent(id, startContent, 'select-option-start', useSpan), index.h(Tag, { class: "select-option-content", key: `${className}-content-${id}` }, labelEl, description && (index.h(Tag, { class: "select-option-description", key: `${className}-desc-${id}` }, description))), endContent && renderClonedContent(id, endContent, 'select-option-end', useSpan)));
|
|
114
|
+
};
|
|
115
|
+
|
|
116
|
+
exports.renderOptionLabel = renderOptionLabel;
|
|
@@ -3,9 +3,10 @@
|
|
|
3
3
|
*/
|
|
4
4
|
'use strict';
|
|
5
5
|
|
|
6
|
-
var index = require('./index-
|
|
7
|
-
var index$1 = require('./index-
|
|
8
|
-
var helpers = require('./helpers-
|
|
6
|
+
var index = require('./index-GZU9YrFc.js');
|
|
7
|
+
var index$1 = require('./index-BxEZd5IE.js');
|
|
8
|
+
var helpers = require('./helpers-DiOgV5hw.js');
|
|
9
|
+
require('./focus-visible-BIj-I3-C.js');
|
|
9
10
|
|
|
10
11
|
const startStatusTap = () => {
|
|
11
12
|
const win = window;
|
|
@@ -3,10 +3,11 @@
|
|
|
3
3
|
*/
|
|
4
4
|
'use strict';
|
|
5
5
|
|
|
6
|
-
var helpers = require('./helpers-
|
|
6
|
+
var helpers = require('./helpers-DiOgV5hw.js');
|
|
7
7
|
var dir = require('./dir-Cn0z1rJH.js');
|
|
8
8
|
var index = require('./index-CAvQ7Tka.js');
|
|
9
|
-
require('./
|
|
9
|
+
require('./focus-visible-BIj-I3-C.js');
|
|
10
|
+
require('./index-GZU9YrFc.js');
|
|
10
11
|
require('./gesture-controller-dtqlP_q4.js');
|
|
11
12
|
|
|
12
13
|
const createSwipeBackGesture = (el, canStartHandler, onStartHandler, onMoveHandler, onEndHandler) => {
|
|
@@ -3,8 +3,32 @@
|
|
|
3
3
|
*/
|
|
4
4
|
'use strict';
|
|
5
5
|
|
|
6
|
+
/**
|
|
7
|
+
* Checks if an element has a parent matching the specified selector.
|
|
8
|
+
* This handles an element in both light DOM and shadow DOM contexts.
|
|
9
|
+
* @param selector The parent selector to check for (e.g., 'ion-datetime'
|
|
10
|
+
* or 'ion-toolbar[color]').
|
|
11
|
+
* @param el The element to check.
|
|
12
|
+
* @returns `true` if the element has a parent matching the specified selector,
|
|
13
|
+
* `false` otherwise.
|
|
14
|
+
*/
|
|
6
15
|
const hostContext = (selector, el) => {
|
|
7
|
-
|
|
16
|
+
// Check the light DOM first
|
|
17
|
+
if (el.closest(selector) !== null) {
|
|
18
|
+
return true;
|
|
19
|
+
}
|
|
20
|
+
// For attribute or class selectors (e.g., 'ion-toolbar[color]' or
|
|
21
|
+
// 'ion-toolbar.ion-color') we can only check light DOM since tagName
|
|
22
|
+
// doesn't include attributes or classes.
|
|
23
|
+
if (selector.includes('[') || selector.includes('.')) {
|
|
24
|
+
return false;
|
|
25
|
+
}
|
|
26
|
+
// Check the shadow DOM by looking at the shadow root host and
|
|
27
|
+
// converting the selector to uppercase to compare with tagName
|
|
28
|
+
const upperCaseTagName = selector.toUpperCase();
|
|
29
|
+
const rootNode = el.getRootNode();
|
|
30
|
+
const shadowHost = rootNode instanceof ShadowRoot ? rootNode.host : null;
|
|
31
|
+
return (shadowHost === null || shadowHost === void 0 ? void 0 : shadowHost.tagName) === upperCaseTagName;
|
|
8
32
|
};
|
|
9
33
|
/**
|
|
10
34
|
* Create the mode and color classes for the component based on the classes passed in
|