@ionic/core 8.8.9-dev.11781013468.1ed93da9 → 8.8.9-dev.11781024903.1e4268e5
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.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.d.ts +11 -0
- package/components/ion-picker-legacy-column.js +4 -0
- package/components/ion-picker-legacy.d.ts +11 -0
- package/components/ion-picker-legacy.js +4 -0
- 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-3Ni1Z654.js +4 -0
- package/components/p-7kL3tltU.js +4 -0
- package/components/p-B9MABkWm.js +4 -0
- package/components/p-BBu2n-9C.js +4 -0
- package/components/p-BDcohALy.js +4 -0
- package/components/p-BDqjX7Z_.js +4 -0
- package/components/p-BJzJdLry.js +4 -0
- package/components/p-BP_TU_4l.js +4 -0
- package/components/p-BYSs-jZz.js +4 -0
- package/components/p-BZCB7f49.js +4 -0
- package/components/p-BaPtaYEC.js +4 -0
- package/components/{p-Sh0ICmPV.js → p-BcbmT6b3.js} +1 -1
- package/components/p-Bg30AtDZ.js +4 -0
- package/components/p-BhkGOA7t.js +4 -0
- package/components/p-BjW8SOqw.js +4 -0
- package/components/p-Bk9hTY4h.js +4 -0
- package/components/p-BqDiJgC_.js +4 -0
- package/components/p-BqTwa6uT.js +4 -0
- package/components/p-BsNpz2u3.js +4 -0
- package/components/p-Bt0d89x3.js +4 -0
- package/components/p-BwKpO3Is.js +4 -0
- package/components/p-BwQOIWD7.js +4 -0
- package/components/p-Bxiu1dAN.js +4 -0
- package/components/{p-D5Ubpm7D.js → p-ByW0kK1F.js} +1 -1
- package/components/p-C75FIZBC.js +4 -0
- package/components/p-C8kBejTT.js +4 -0
- package/components/p-C91NnY87.js +4 -0
- package/components/p-CBS0sBAa.js +4 -0
- package/{dist/ionic/p-VAemlbDS.js → components/p-CDgDBcU9.js} +1 -1
- package/components/p-CODBQrPj.js +4 -0
- package/components/p-Cg-xpJhD.js +4 -0
- package/components/p-CgSn4J7d.js +4 -0
- package/components/p-CgZLVOCc.js +4 -0
- package/{dist/ionic/p-D13Eaw-8.js → components/p-Cllkut-B.js} +1 -1
- package/components/p-Cz4uz3Dy.js +4 -0
- package/components/p-CzC_ZSgb.js +4 -0
- package/components/p-D1t981Ih.js +4 -0
- package/components/p-D2mReIu8.js +4 -0
- package/components/p-D6g8ud1e.js +4 -0
- package/components/p-DDw-NYxz.js +4 -0
- package/components/p-DN_scBC7.js +4 -0
- package/components/p-DVcs-2q3.js +4 -0
- package/components/{p-DNQI6d-L.js → p-DXehWlOr.js} +1 -1
- package/components/p-DaJxRxSQ.js +4 -0
- package/components/p-Dhi5xtNS.js +4 -0
- package/components/p-Do7NMUwR.js +4 -0
- package/components/p-Dp2x0MpA.js +4 -0
- package/components/p-GElQZ38c.js +4 -0
- package/components/p-GtzfsjJP.js +4 -0
- package/components/p-LB-QPk3e.js +4 -0
- package/components/p-Skz67GXZ.js +4 -0
- package/components/p-WdrzoonY.js +4 -0
- package/components/p-XegQjlzJ.js +4 -0
- package/components/p-fIOYmaqA.js +4 -0
- package/components/p-h64_gZrH.js +4 -0
- package/components/p-hpwmNJ2Q.js +4 -0
- package/components/p-kKYBfhbe.js +4 -0
- package/components/p-lGSe6-vg.js +4 -0
- package/components/{p-BAYYcg3o.js → p-oF-CwZ0b.js} +1 -1
- package/components/p-pvh0bjpw.js +4 -0
- package/components/{p-cyNmxje6.js → p-re70ahxF.js} +1 -1
- package/components/p-sToA4Co7.js +4 -0
- package/components/p-sehKq5RI.js +4 -0
- package/components/p-vXpMhGrs.js +4 -0
- package/components/{p-ijF0iCrA.js → p-wCDzv5Q8.js} +1 -1
- package/components/{p-DqLB8yFQ.js → p-zWP0sUV_.js} +1 -1
- 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-BZJ2wKuM.js} +3 -3
- package/dist/cjs/{app-globals-BlqrqKTN.js → app-globals-C-d5fQ35.js} +1 -1
- package/dist/cjs/{button-active-0mPOKmV2.js → button-active-B_20Nxkv.js} +2 -2
- package/dist/cjs/{capacitor-DmA66EwP.js → capacitor-CXqhdZym.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-DuOuKG7I.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-Dx9FrqAC.js} +4 -2
- package/dist/cjs/{haptic-ClPPQ_PS.js → haptic-CQJGW58i.js} +1 -1
- package/dist/cjs/{helpers-Cv23MFHM.js → helpers-DJYxKN5U.js} +57 -4
- package/dist/cjs/{index-CIrkNXqJ.js → index-BJrpF9T3.js} +2 -2
- package/dist/cjs/{index-aC4x3Fk3.js → index-BekUBS8C.js} +15 -15
- package/dist/cjs/{index-DqmRDbxg.js → index-CgAbCW6L.js} +2 -0
- package/dist/cjs/{index-D81eLYUM.js → index-CwxYd6UD.js} +9 -8
- package/dist/cjs/{index-Ct7gcRif.js → index-CzcLEdQ5.js} +64 -71
- package/dist/cjs/{index-BERfRao3.js → index-DSNlrgfO.js} +4 -4
- package/dist/cjs/index-Dm4Dm7Vg.js +414 -0
- package/dist/cjs/index.cjs.js +17 -16
- package/dist/cjs/{input-shims-CFLg7uzj.js → input-shims-VyZciSxi.js} +18 -17
- package/dist/cjs/{input.utils-DetjmtH2.js → input.utils-Ct5KzpYv.js} +5 -5
- package/dist/cjs/ion-accordion_2.cjs.entry.js +61 -29
- package/dist/cjs/ion-action-sheet.cjs.entry.js +41 -26
- package/dist/cjs/ion-alert.cjs.entry.js +78 -45
- package/dist/cjs/ion-app_8.cjs.entry.js +296 -175
- 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 +34 -16
- 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.cjs.entry.js → ion-datetime_3.cjs.entry.js} +742 -29
- 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.cjs.entry.js +529 -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 +125 -35
- package/dist/cjs/ion-item-option_3.cjs.entry.js +467 -52
- package/dist/cjs/ion-item_8.cjs.entry.js +115 -49
- package/dist/cjs/ion-loading.cjs.entry.js +22 -23
- package/dist/cjs/ion-menu_3.cjs.entry.js +47 -29
- package/dist/cjs/ion-modal.cjs.entry.js +262 -145
- 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 -23
- 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 +39 -15
- package/dist/cjs/ion-ripple-effect.cjs.entry.js +15 -7
- package/dist/cjs/ion-route_4.cjs.entry.js +10 -9
- package/dist/cjs/ion-searchbar.cjs.entry.js +138 -25
- 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 +115 -38
- package/dist/cjs/ion-select_3.cjs.entry.js +510 -113
- 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 +71 -47
- package/dist/cjs/ion-toggle.cjs.entry.js +84 -27
- package/dist/cjs/ionic-global-BW5tRzrz.js +519 -0
- package/dist/cjs/ionic.cjs.js +5 -5
- package/dist/cjs/{ios.transition-BOSWOaiK.js → ios.transition-CyNNpj1i.js} +7 -5
- package/dist/cjs/{keyboard-hHzlEQpk.js → keyboard-CA6RtoWx.js} +4 -3
- package/dist/cjs/{keyboard-UuAS4D_9.js → keyboard-VLGMzWBE.js} +1 -1
- package/dist/cjs/{keyboard-controller-GXBiBRKS.js → keyboard-controller-CCTvHp9l.js} +11 -9
- 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-BEfrfWKW.js} +6 -5
- package/dist/cjs/{notch-controller-18PzRGXd.js → notch-controller-BTZCPOsd.js} +4 -4
- package/dist/cjs/overlay-control-label-DnRLQR1t.js +52 -0
- package/dist/cjs/{overlays-DSmSrd_4.js → overlays-BuMIwR8B.js} +117 -42
- package/dist/cjs/select-option-render-DQyZnlF5.js +116 -0
- package/dist/cjs/{status-tap-BXX8H8_Y.js → status-tap-CTY2dMsZ.js} +4 -3
- package/dist/cjs/{swipe-back-C0GCB18x.js → swipe-back-jJFi5KCB.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 +14 -4
- 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 +33 -18
- 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 +68 -35
- 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 +539 -0
- package/dist/collection/components/checkbox/checkbox.ios.css +161 -101
- package/dist/collection/components/checkbox/checkbox.js +70 -14
- package/dist/collection/components/checkbox/checkbox.md.css +162 -102
- 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 +100 -0
- package/dist/collection/components/gallery/gallery.js +600 -0
- package/dist/collection/components/gallery/test/utils.js +100 -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 +153 -42
- 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 +73 -6
- 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 +50 -20
- 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 +15 -16
- 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 +51 -20
- 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/animations/ios.enter.js +27 -0
- package/dist/collection/components/picker-legacy/animations/ios.leave.js +23 -0
- package/dist/collection/components/picker-legacy/picker-interface.js +1 -0
- package/dist/collection/components/picker-legacy/picker.ios.css +312 -0
- package/dist/collection/components/picker-legacy/picker.js +891 -0
- package/dist/collection/components/picker-legacy/picker.md.css +299 -0
- package/dist/collection/components/picker-legacy-column/picker-column.ios.css +243 -0
- package/dist/collection/components/picker-legacy-column/picker-column.js +422 -0
- package/dist/collection/components/picker-legacy-column/picker-column.md.css +234 -0
- package/dist/collection/components/picker-legacy-column/test/test.utils.js +43 -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 +19 -20
- 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 +15 -10
- 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 +10 -40
- 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 +185 -38
- 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 +474 -97
- package/dist/collection/components/select/select.md.css +364 -178
- package/dist/collection/components/select-modal/select-modal.ionic.css +264 -0
- package/dist/collection/components/select-modal/select-modal.ios.css +467 -0
- package/dist/collection/components/select-modal/select-modal.js +127 -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 +16 -9
- 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/index.js +1 -1
- 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 +57 -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 +97 -31
- 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 +10106 -575
- package/dist/esm/{animation-DLJpuoEz.js → animation-Cd1EA2ar.js} +2 -2
- package/dist/esm/{app-globals-D0C5S4hU.js → app-globals-9x_U7ofY.js} +1 -1
- package/dist/esm/{button-active-BSpTQmS9.js → button-active-B016u5N-.js} +2 -2
- package/dist/esm/{capacitor-CFERIeaU.js → capacitor-13SFuT1K.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-BNKYavC3.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-CjVwn_KZ.js} +4 -2
- package/dist/esm/{haptic-DzAMWJuk.js → haptic-CbnKC3go.js} +1 -1
- package/dist/esm/{helpers-HEqiOzXb.js → helpers-Do7zwvM1.js} +58 -5
- package/dist/esm/{index-B_dQk_WE.js → index-B2VWavcK.js} +4 -4
- package/dist/esm/{index-Q6UPU0Ay.js → index-BWMvrRiE.js} +11 -11
- package/dist/esm/{index-MEDq2S8l.js → index-BmkLokUL.js} +2 -2
- package/dist/esm/index-Bmyj8b0z.js +409 -0
- package/dist/esm/{index-AlrZKoWR.js → index-D2tu5BUg.js} +2 -1
- package/dist/esm/{index-BRHzoo00.js → index-D3WueHpT.js} +4 -3
- package/dist/esm/{index-tcQvqkiX.js → index-Omi_TcwW.js} +64 -71
- package/dist/esm/index.js +14 -14
- package/dist/esm/{input-shims-D10mwcw1.js → input-shims-DU23z7Hg.js} +7 -6
- package/dist/esm/{input.utils-Y6NgW8bw.js → input.utils-C64RbLd_.js} +3 -3
- package/dist/esm/ion-accordion_2.entry.js +61 -29
- package/dist/esm/ion-action-sheet.entry.js +41 -26
- package/dist/esm/ion-alert.entry.js +77 -44
- package/dist/esm/ion-app_8.entry.js +296 -175
- 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 +34 -16
- 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.entry.js → ion-datetime_3.entry.js} +741 -30
- package/dist/esm/ion-divider.entry.js +49 -0
- package/dist/esm/ion-fab_3.entry.js +44 -28
- package/dist/esm/ion-gallery.entry.js +527 -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 +125 -35
- package/dist/esm/ion-item-option_3.entry.js +467 -52
- package/dist/esm/ion-item_8.entry.js +115 -49
- package/dist/esm/ion-loading.entry.js +21 -22
- package/dist/esm/ion-menu_3.entry.js +47 -29
- package/dist/esm/ion-modal.entry.js +215 -98
- 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 -23
- 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 +39 -15
- package/dist/esm/ion-ripple-effect.entry.js +15 -7
- package/dist/esm/ion-route_4.entry.js +10 -9
- package/dist/esm/ion-searchbar.entry.js +138 -25
- 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 +115 -38
- package/dist/esm/ion-select_3.entry.js +511 -114
- 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 +46 -22
- package/dist/esm/ion-toggle.entry.js +84 -27
- package/dist/esm/ionic-global--9mOmThr.js +508 -0
- package/dist/esm/ionic.js +6 -6
- package/dist/esm/{ios.transition-ClFrsIrS.js → ios.transition-DoQTN5Jk.js} +7 -5
- package/dist/esm/{keyboard-ywgs5efA.js → keyboard-Ca1zVCcH.js} +4 -3
- package/dist/esm/{keyboard-CUw4ekVy.js → keyboard-Dnno7-Ci.js} +1 -1
- package/dist/esm/{keyboard-controller-BaaVITYt.js → keyboard-controller-BpOdk6xN.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-DZydrWwq.js} +6 -5
- package/dist/esm/{notch-controller-DKDjU_O7.js → notch-controller-klgNWpjJ.js} +2 -2
- package/dist/esm/overlay-control-label-CODBQrPj.js +49 -0
- package/dist/esm/{overlays-DLNOHWNc.js → overlays-CpQ6Df2g.js} +114 -39
- package/dist/esm/select-option-render-QGJ9tZHa.js +114 -0
- package/dist/esm/{status-tap-Kan2W7sh.js → status-tap-fYFdZg6z.js} +4 -3
- package/dist/esm/{swipe-back-DQ1q5MgD.js → swipe-back-BzGqTrrq.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 +2671 -135
- package/dist/ionic/index.esm.js +1 -1
- package/dist/ionic/ionic.esm.js +1 -1
- package/dist/ionic/p-0030507d.entry.js +4 -0
- package/dist/ionic/p-084c2623.entry.js +4 -0
- package/dist/ionic/p-09f8a57f.entry.js +4 -0
- package/dist/ionic/p-108c0f30.entry.js +4 -0
- package/dist/ionic/p-1439fecb.entry.js +4 -0
- package/dist/ionic/p-18ed37e3.entry.js +4 -0
- package/dist/ionic/p-199bffb3.entry.js +4 -0
- package/dist/ionic/p-19a1ff9a.entry.js +4 -0
- package/dist/ionic/p-1a026890.entry.js +4 -0
- package/dist/ionic/p-1ad16c09.entry.js +4 -0
- package/dist/ionic/p-2049aa81.entry.js +4 -0
- package/dist/ionic/p-290778c1.entry.js +4 -0
- package/dist/ionic/p-2aa7567e.entry.js +4 -0
- package/dist/ionic/p-2e7e3da1.entry.js +4 -0
- package/dist/ionic/p-3656314c.entry.js +4 -0
- package/dist/ionic/p-379cc989.entry.js +4 -0
- package/dist/ionic/p-3f18dfe9.entry.js +4 -0
- package/dist/ionic/p-40d9e029.entry.js +4 -0
- package/dist/ionic/p-456736d1.entry.js +4 -0
- package/dist/ionic/p-48e3cb9e.entry.js +4 -0
- package/dist/ionic/p-497f6391.entry.js +4 -0
- package/dist/ionic/p-64b4e6eb.entry.js +4 -0
- package/dist/ionic/p-66eb0193.entry.js +4 -0
- package/dist/ionic/p-67c2d349.entry.js +4 -0
- package/dist/ionic/p-7054a1b9.entry.js +4 -0
- package/dist/ionic/p-70ee89c9.entry.js +4 -0
- package/dist/ionic/p-7186786e.entry.js +4 -0
- package/dist/ionic/p-7194f6fa.entry.js +4 -0
- package/dist/ionic/p-76c70824.entry.js +4 -0
- package/dist/ionic/p-7f294078.entry.js +4 -0
- package/dist/ionic/p-8458f1b6.entry.js +4 -0
- package/dist/ionic/p-88e7f52a.entry.js +4 -0
- package/dist/ionic/p-89eab395.entry.js +4 -0
- package/dist/ionic/p-93315d96.entry.js +4 -0
- package/dist/ionic/p-9ccfb733.entry.js +4 -0
- package/dist/ionic/p-9dfbe98d.entry.js +4 -0
- package/{components/p-BT_5jSqG.js → dist/ionic/p-B2-sg7NJ.js} +1 -1
- package/dist/ionic/p-B4ikoeaj.js +4 -0
- package/dist/ionic/p-BDqjX7Z_.js +4 -0
- package/dist/ionic/p-BFBCtvFI.js +4 -0
- package/dist/ionic/p-BQgCYKKG.js +4 -0
- package/dist/ionic/p-BYAxJDlE.js +4 -0
- package/dist/ionic/p-BYSs-jZz.js +4 -0
- package/dist/ionic/p-BjW8SOqw.js +4 -0
- package/dist/ionic/{p-CKvCXMs9.js → p-BmEwy3tY.js} +1 -1
- package/dist/ionic/p-BwKpO3Is.js +4 -0
- package/dist/ionic/{p-DAAFkPFT.js → p-C8IHbcuP.js} +1 -1
- package/dist/ionic/p-CDn0uNJA.js +4 -0
- package/dist/ionic/p-CHE1xWbg.js +4 -0
- package/dist/ionic/p-CK179dBb.js +4 -0
- package/dist/ionic/p-CODBQrPj.js +4 -0
- package/dist/ionic/p-CYhXBSjd.js +4 -0
- package/{components/p-D13Eaw-8.js → dist/ionic/p-CuGhCBt7.js} +1 -1
- package/dist/ionic/p-CxRK9GyE.js +4 -0
- package/dist/ionic/p-D1t981Ih.js +4 -0
- package/dist/ionic/p-D2tu5BUg.js +4 -0
- package/dist/ionic/p-DDFhx1YX.js +4 -0
- package/dist/ionic/{p-Wk5HzclC.js → p-DKWXAwlR.js} +1 -1
- package/dist/ionic/p-DNGqaUsl.js +4 -0
- package/dist/ionic/p-DaJxRxSQ.js +4 -0
- package/dist/ionic/p-DaknVxZR.js +4 -0
- package/dist/ionic/p-Dhi5xtNS.js +4 -0
- package/dist/ionic/p-DoyDJ2X5.js +4 -0
- package/dist/ionic/p-E1wtzfO0.js +4 -0
- package/dist/ionic/p-FvDKM4Ax.js +4 -0
- package/dist/ionic/p-IXZW3FBt.js +4 -0
- package/dist/ionic/p-NqPMS7BP.js +4 -0
- package/dist/ionic/p-Omi_TcwW.js +5 -0
- package/dist/ionic/p-PoSbs6oh.js +4 -0
- package/dist/ionic/p-VAJ_3beW.js +4 -0
- package/dist/ionic/p-a3f9be52.entry.js +4 -0
- package/dist/ionic/p-b4fd91b8.entry.js +4 -0
- package/dist/ionic/p-b653f4c2.entry.js +4 -0
- package/dist/ionic/p-b69add0e.entry.js +4 -0
- package/dist/ionic/p-b7235e85.entry.js +4 -0
- package/dist/ionic/p-b847907d.entry.js +4 -0
- package/dist/ionic/p-bc317965.entry.js +4 -0
- package/dist/ionic/p-bc3d68ff.entry.js +4 -0
- package/dist/ionic/p-bsfLvRbd.js +4 -0
- package/dist/ionic/p-c684a3b6.entry.js +4 -0
- package/dist/ionic/p-c7139c41.entry.js +4 -0
- package/dist/ionic/p-c94fbdab.entry.js +4 -0
- package/dist/ionic/p-dac1d4de.entry.js +4 -0
- package/dist/ionic/p-dd2981d0.entry.js +4 -0
- package/dist/ionic/p-e89848b2.entry.js +4 -0
- package/dist/ionic/p-eTI_FbQJ.js +4 -0
- package/dist/ionic/p-f2f740aa.entry.js +4 -0
- package/dist/ionic/p-f52856cb.entry.js +4 -0
- package/dist/ionic/p-fIOYmaqA.js +4 -0
- package/dist/ionic/p-fbdbdb3e.entry.js +4 -0
- package/dist/ionic/p-ff09d2a5.entry.js +4 -0
- 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 +185 -0
- package/dist/types/components/gallery/test/utils.d.ts +2 -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 +32 -6
- 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/animations/ios.enter.d.ts +5 -0
- package/dist/types/components/picker-legacy/animations/ios.leave.d.ts +5 -0
- package/dist/types/components/picker-legacy/picker-interface.d.ts +52 -0
- package/dist/types/components/picker-legacy/picker.d.ts +159 -0
- package/dist/types/components/picker-legacy-column/picker-column.d.ts +46 -0
- package/dist/types/components/picker-legacy-column/test/test.utils.d.ts +9 -0
- 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 -8
- package/dist/types/components/row/row.d.ts +4 -0
- package/dist/types/components/searchbar/searchbar.d.ts +52 -10
- 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 -14
- 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 +2136 -259
- package/dist/types/global/ionic-global.d.ts +28 -2
- package/dist/types/index.d.ts +1 -1
- package/dist/types/interface.d.ts +4 -0
- package/dist/types/stencil-public-runtime.d.ts +1 -4
- package/dist/types/utils/config.d.ts +114 -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 +11 -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 +10 -12
- 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 +6668 -2303
- package/hydrate/index.mjs +6668 -2303
- package/package.json +12 -40
- package/components/p--JUspHvy.js +0 -4
- package/components/p-B8U2xbtx.js +0 -4
- package/components/p-B9jFTlwE.js +0 -4
- package/components/p-BTPfOxsU.js +0 -4
- package/components/p-Baq1XyAy.js +0 -4
- package/components/p-BhmadOit.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-BpCi7xHq.js +0 -4
- package/components/p-Bz0dSlXZ.js +0 -4
- package/components/p-C1aScSTo.js +0 -4
- package/components/p-C4t5ymfq.js +0 -4
- package/components/p-CHqRYvYm.js +0 -4
- package/components/p-CHzfYZbv.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-C_xFdyXe.js +0 -4
- package/components/p-Ciz1-FuE.js +0 -4
- package/components/p-Ck2wcXbv.js +0 -4
- package/components/p-CmR5uXej.js +0 -4
- package/components/p-CtWGkNnJ.js +0 -4
- package/components/p-CtukzcyX.js +0 -4
- package/components/p-D6Ynv7Xh.js +0 -4
- package/components/p-D7bSXQD3.js +0 -4
- package/components/p-DEBD4LvH.js +0 -4
- package/components/p-DH50pr9O.js +0 -4
- package/components/p-DIE4pXMl.js +0 -4
- package/components/p-DJztqcrH.js +0 -4
- package/components/p-DOFCbuQR.js +0 -4
- package/components/p-DhkITZ-y.js +0 -4
- package/components/p-DiVJyqlX.js +0 -4
- package/components/p-DmpBvltk.js +0 -4
- package/components/p-DnL1c9_X.js +0 -4
- package/components/p-DpV-p5Xs.js +0 -4
- package/components/p-DqZAXv2t.js +0 -4
- package/components/p-Dz74mwlk.js +0 -4
- package/components/p-W5nO8mX_.js +0 -4
- package/components/p-XJWMAP8m.js +0 -4
- package/components/p-ZjP4CjeZ.js +0 -4
- package/components/p-djQLE88P.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-r0aq7dpt.js +0 -4
- package/components/p-ryqmO0B-.js +0 -4
- package/components/p-wk2QqrAo.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-03aa786d.entry.js +0 -4
- package/dist/ionic/p-06c232a4.entry.js +0 -4
- package/dist/ionic/p-11684553.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-259d0d98.entry.js +0 -4
- package/dist/ionic/p-2a6d6565.entry.js +0 -4
- package/dist/ionic/p-341032b3.entry.js +0 -4
- package/dist/ionic/p-441fbb13.entry.js +0 -4
- package/dist/ionic/p-4502a274.entry.js +0 -4
- package/dist/ionic/p-4621c387.entry.js +0 -4
- package/dist/ionic/p-4bb3eb60.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-51cd1643.entry.js +0 -4
- package/dist/ionic/p-5c3ec490.entry.js +0 -4
- package/dist/ionic/p-627fabd9.entry.js +0 -4
- package/dist/ionic/p-629e4703.entry.js +0 -4
- package/dist/ionic/p-76e92a84.entry.js +0 -4
- package/dist/ionic/p-7a37b3ce.entry.js +0 -4
- package/dist/ionic/p-7aed7726.entry.js +0 -4
- package/dist/ionic/p-7ebd980c.entry.js +0 -4
- package/dist/ionic/p-80b44b3c.entry.js +0 -4
- package/dist/ionic/p-81ea5652.entry.js +0 -4
- package/dist/ionic/p-8c8eee7d.entry.js +0 -4
- package/dist/ionic/p-8d624ee5.entry.js +0 -4
- package/dist/ionic/p-8d6fd502.entry.js +0 -4
- package/dist/ionic/p-9177f4ac.entry.js +0 -4
- package/dist/ionic/p-944c8939.entry.js +0 -4
- package/dist/ionic/p-9c6a5a8d.entry.js +0 -4
- package/dist/ionic/p-9eeaBrnk.js +0 -4
- package/dist/ionic/p-AlrZKoWR.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-Cg5-OQYy.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-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-a2e51c5d.entry.js +0 -4
- package/dist/ionic/p-a3bdcae6.entry.js +0 -4
- package/dist/ionic/p-a44b7536.entry.js +0 -4
- package/dist/ionic/p-a5213260.entry.js +0 -4
- package/dist/ionic/p-a7628bc7.entry.js +0 -4
- package/dist/ionic/p-b1599fca.entry.js +0 -4
- package/dist/ionic/p-b16be471.entry.js +0 -4
- package/dist/ionic/p-b6a7397c.entry.js +0 -4
- package/dist/ionic/p-b9ac1fe0.entry.js +0 -4
- package/dist/ionic/p-c6e49f3f.entry.js +0 -4
- package/dist/ionic/p-c93553d2.entry.js +0 -4
- package/dist/ionic/p-d2c7f046.entry.js +0 -4
- package/dist/ionic/p-d8387b99.entry.js +0 -4
- package/dist/ionic/p-d8ac9eea.entry.js +0 -4
- package/dist/ionic/p-db1b6738.entry.js +0 -4
- package/dist/ionic/p-dfa8d673.entry.js +0 -4
- package/dist/ionic/p-ed797c72.entry.js +0 -4
- package/dist/ionic/p-ef93ca92.entry.js +0 -4
- package/dist/ionic/p-f09f9642.entry.js +0 -4
- package/dist/ionic/p-f1c06f82.entry.js +0 -4
- package/dist/ionic/p-f386f6ae.entry.js +0 -4
- package/dist/ionic/p-fe4aa1db.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-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,47 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* (C) Ionic http://ionicframework.com - MIT License
|
|
3
|
+
*/
|
|
4
|
+
// TODO(FW-6886, FW-6892, FW-6891): Remove this file in favor of the Modular Ionic component config. Each overlay will be able to select its own defaults for label placement and justify based on the interface and theme, so this utility will no longer be necessary.
|
|
5
|
+
/**
|
|
6
|
+
* Returns the default `labelPlacement` for a radio or checkbox option
|
|
7
|
+
* rendered inside an overlay. Defaults follow each theme's established
|
|
8
|
+
* option-row layout:
|
|
9
|
+
* - `ionic`: always `"start"`.
|
|
10
|
+
* - `ios`: `"start"` for radio in `alert` and `popover`. The `modal`
|
|
11
|
+
* interface flips iOS radio back to `"end"`. Checkbox is always
|
|
12
|
+
* `"end"` on iOS.
|
|
13
|
+
* - everything else (e.g. `md`): `"end"`.
|
|
14
|
+
*
|
|
15
|
+
* `interfaceType` is optional; only `"modal"` changes the result, so
|
|
16
|
+
* callers that aren't a modal can omit it.
|
|
17
|
+
*
|
|
18
|
+
* Used by `alert`, `select-popover`, and `select-modal` as the fallback
|
|
19
|
+
* when an option doesn't explicitly set `labelPlacement`.
|
|
20
|
+
*/
|
|
21
|
+
export const getOverlayLabelPlacement = (theme, control, interfaceType) => {
|
|
22
|
+
if (theme === 'ionic' || (theme === 'ios' && control === 'radio' && interfaceType !== 'modal')) {
|
|
23
|
+
return 'start';
|
|
24
|
+
}
|
|
25
|
+
return 'end';
|
|
26
|
+
};
|
|
27
|
+
/**
|
|
28
|
+
* Returns the default `justify` for a radio or checkbox option rendered
|
|
29
|
+
* inside an overlay. Defaults follow each theme's option-row layout:
|
|
30
|
+
* - `ionic`: always `"space-between"`.
|
|
31
|
+
* - `ios`: `"space-between"` for radio in `alert` and `popover`. The
|
|
32
|
+
* `modal` interface falls back to `"start"`. Checkbox is always `"start"`
|
|
33
|
+
* on iOS.
|
|
34
|
+
* - everything else (e.g. `md`): `"start"`.
|
|
35
|
+
*
|
|
36
|
+
* `interfaceType` is optional; only `"modal"` changes the result, so
|
|
37
|
+
* callers that aren't a modal can omit it.
|
|
38
|
+
*
|
|
39
|
+
* Used by `alert`, `select-popover`, and `select-modal` as the fallback when
|
|
40
|
+
* an option doesn't explicitly set `justify`.
|
|
41
|
+
*/
|
|
42
|
+
export const getOverlayLabelJustify = (theme, control, interfaceType) => {
|
|
43
|
+
if (theme === 'ionic' || (theme === 'ios' && control === 'radio' && interfaceType !== 'modal')) {
|
|
44
|
+
return 'space-between';
|
|
45
|
+
}
|
|
46
|
+
return 'start';
|
|
47
|
+
};
|
|
@@ -6,7 +6,7 @@ import { focusFirstDescendant, focusLastDescendant, focusableQueryString } from
|
|
|
6
6
|
import { shouldUseCloseWatcher } from "./hardware-back-button";
|
|
7
7
|
import { printIonError, printIonWarning } from "./logging/index";
|
|
8
8
|
import { config } from "../global/config";
|
|
9
|
-
import { getIonMode } from "../global/ionic-global";
|
|
9
|
+
import { getIonMode, getIonTheme } from "../global/ionic-global";
|
|
10
10
|
import { CoreDelegate } from "./framework-delegate";
|
|
11
11
|
import { BACKDROP_NO_SCROLL } from "./gesture/gesture-controller";
|
|
12
12
|
import { OVERLAY_BACK_BUTTON_PRIORITY } from "./hardware-back-button";
|
|
@@ -39,6 +39,10 @@ export const alertController = /*@__PURE__*/ createController('ion-alert');
|
|
|
39
39
|
export const actionSheetController = /*@__PURE__*/ createController('ion-action-sheet');
|
|
40
40
|
export const loadingController = /*@__PURE__*/ createController('ion-loading');
|
|
41
41
|
export const modalController = /*@__PURE__*/ createController('ion-modal');
|
|
42
|
+
/**
|
|
43
|
+
* @deprecated Use the inline ion-picker component instead.
|
|
44
|
+
*/
|
|
45
|
+
export const pickerController = /*@__PURE__*/ createController('ion-picker-legacy');
|
|
42
46
|
export const popoverController = /*@__PURE__*/ createController('ion-popover');
|
|
43
47
|
export const toastController = /*@__PURE__*/ createController('ion-toast');
|
|
44
48
|
/**
|
|
@@ -132,7 +136,7 @@ const focusElementInOverlay = (hostToFocus, overlay) => {
|
|
|
132
136
|
* Should NOT include: Toast
|
|
133
137
|
*/
|
|
134
138
|
const trapKeyboardFocus = (ev, doc) => {
|
|
135
|
-
const lastOverlay = getPresentedOverlay(doc, 'ion-alert,ion-action-sheet,ion-loading,ion-modal,ion-popover');
|
|
139
|
+
const lastOverlay = getPresentedOverlay(doc, 'ion-alert,ion-action-sheet,ion-loading,ion-modal,ion-picker-legacy,ion-popover');
|
|
136
140
|
const target = ev.target;
|
|
137
141
|
/**
|
|
138
142
|
* If no active overlay, ignore this event.
|
|
@@ -315,6 +319,86 @@ const connectListeners = (doc) => {
|
|
|
315
319
|
doc.addEventListener('focus', (ev) => {
|
|
316
320
|
trapKeyboardFocus(ev, doc);
|
|
317
321
|
}, true);
|
|
322
|
+
// Listen for keydown events to intercept Tab navigation.
|
|
323
|
+
// This is needed for Safari and Firefox which may skip focusable
|
|
324
|
+
// elements or allow focus to escape the overlay.
|
|
325
|
+
// It also ensures proper focus delegation for shadow DOM elements
|
|
326
|
+
// like ion-textarea.
|
|
327
|
+
doc.addEventListener('keydown', (ev) => {
|
|
328
|
+
var _a, _b, _c;
|
|
329
|
+
if (ev.key !== 'Tab' && ev.key !== 'Alt+Tab')
|
|
330
|
+
return;
|
|
331
|
+
const lastOverlay = getPresentedOverlay(doc, 'ion-alert,ion-action-sheet,ion-loading,ion-modal,ion-picker-legacy,ion-popover');
|
|
332
|
+
if (!lastOverlay || lastOverlay.classList.contains(FOCUS_TRAP_DISABLE_CLASS))
|
|
333
|
+
return;
|
|
334
|
+
const activeElement = doc.activeElement;
|
|
335
|
+
if (activeElement === lastOverlay) {
|
|
336
|
+
ev.preventDefault();
|
|
337
|
+
focusFirstDescendant(lastOverlay);
|
|
338
|
+
return;
|
|
339
|
+
}
|
|
340
|
+
// Check if activeElement is inside the overlay (including shadow DOM)
|
|
341
|
+
const isInsideOverlay = activeElement
|
|
342
|
+
? lastOverlay.contains(activeElement) ||
|
|
343
|
+
(activeElement.getRootNode() instanceof ShadowRoot &&
|
|
344
|
+
lastOverlay.contains(activeElement.getRootNode().host)) ||
|
|
345
|
+
((_b = (_a = lastOverlay.shadowRoot) === null || _a === void 0 ? void 0 : _a.contains(activeElement)) !== null && _b !== void 0 ? _b : false)
|
|
346
|
+
: false;
|
|
347
|
+
if (!isInsideOverlay)
|
|
348
|
+
return;
|
|
349
|
+
// Get all focusable elements from both light and shadow DOM
|
|
350
|
+
const allFocusable = [
|
|
351
|
+
...lastOverlay.querySelectorAll(focusableQueryString),
|
|
352
|
+
...(((_c = lastOverlay.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelectorAll(focusableQueryString)) || []),
|
|
353
|
+
];
|
|
354
|
+
if (allFocusable.length === 0) {
|
|
355
|
+
ev.preventDefault();
|
|
356
|
+
return;
|
|
357
|
+
}
|
|
358
|
+
// Find current element's index (accounting for shadow DOM)
|
|
359
|
+
const currentIndex = activeElement
|
|
360
|
+
? allFocusable.findIndex((el) => {
|
|
361
|
+
var _a;
|
|
362
|
+
if (el === activeElement)
|
|
363
|
+
return true;
|
|
364
|
+
if ((_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.contains(activeElement))
|
|
365
|
+
return true;
|
|
366
|
+
const rootNode = activeElement.getRootNode();
|
|
367
|
+
return rootNode instanceof ShadowRoot && rootNode.host === el;
|
|
368
|
+
})
|
|
369
|
+
: -1;
|
|
370
|
+
ev.preventDefault();
|
|
371
|
+
// Helper to focus an element, handling shadow DOM properly
|
|
372
|
+
const focusElement = (element) => {
|
|
373
|
+
const shadowRoot = element.shadowRoot;
|
|
374
|
+
if (shadowRoot) {
|
|
375
|
+
const innerFocusable = shadowRoot.querySelector(focusableQueryString);
|
|
376
|
+
if (innerFocusable && typeof element.setFocus !== 'function') {
|
|
377
|
+
focusVisibleElement(innerFocusable);
|
|
378
|
+
return;
|
|
379
|
+
}
|
|
380
|
+
}
|
|
381
|
+
focusVisibleElement(element);
|
|
382
|
+
};
|
|
383
|
+
if (ev.shiftKey) {
|
|
384
|
+
// Shift+Tab: previous element, wrap to last if at first
|
|
385
|
+
if (currentIndex <= 0) {
|
|
386
|
+
focusLastDescendant(lastOverlay);
|
|
387
|
+
}
|
|
388
|
+
else {
|
|
389
|
+
focusElement(allFocusable[currentIndex - 1]);
|
|
390
|
+
}
|
|
391
|
+
}
|
|
392
|
+
else {
|
|
393
|
+
// Tab: next element, wrap to first if at last
|
|
394
|
+
if (currentIndex < 0 || currentIndex >= allFocusable.length - 1) {
|
|
395
|
+
focusFirstDescendant(lastOverlay);
|
|
396
|
+
}
|
|
397
|
+
else {
|
|
398
|
+
focusElement(allFocusable[currentIndex + 1]);
|
|
399
|
+
}
|
|
400
|
+
}
|
|
401
|
+
}, true);
|
|
318
402
|
// handle back-button click
|
|
319
403
|
doc.addEventListener('ionBackButton', (ev) => {
|
|
320
404
|
const lastOverlay = getPresentedOverlay(doc);
|
|
@@ -366,7 +450,7 @@ export const dismissOverlay = (doc, data, role, overlayTag, id) => {
|
|
|
366
450
|
*/
|
|
367
451
|
export const getOverlays = (doc, selector) => {
|
|
368
452
|
if (selector === undefined) {
|
|
369
|
-
selector = 'ion-alert,ion-action-sheet,ion-loading,ion-modal,ion-popover,ion-toast';
|
|
453
|
+
selector = 'ion-alert,ion-action-sheet,ion-loading,ion-modal,ion-picker-legacy,ion-popover,ion-toast';
|
|
370
454
|
}
|
|
371
455
|
return Array.from(doc.querySelectorAll(selector)).filter((c) => c.overlayIndex > 0);
|
|
372
456
|
};
|
|
@@ -428,30 +512,7 @@ export const setRootAriaHidden = (hidden = false) => {
|
|
|
428
512
|
viewContainer.removeAttribute('aria-hidden');
|
|
429
513
|
}
|
|
430
514
|
};
|
|
431
|
-
|
|
432
|
-
* Cleans up root `aria-hidden` and `backdrop-no-scroll` when
|
|
433
|
-
* an overlay is removed from the DOM without going through
|
|
434
|
-
* the `dismiss()` flow (e.g., when a framework unmounts the
|
|
435
|
-
* overlay during a route change).
|
|
436
|
-
*
|
|
437
|
-
* Should be called from an overlay's `disconnectedCallback`
|
|
438
|
-
* when the overlay was still presented at the time of removal.
|
|
439
|
-
*/
|
|
440
|
-
export const cleanupRootFocusTrapAccessibility = () => {
|
|
441
|
-
if (typeof document === 'undefined') {
|
|
442
|
-
return;
|
|
443
|
-
}
|
|
444
|
-
const remainingOverlays = getPresentedOverlays(document);
|
|
445
|
-
const hasRemainingLocking = remainingOverlays.some((o) => {
|
|
446
|
-
const el = o;
|
|
447
|
-
return el.tagName !== 'ION-TOAST' && el.focusTrap !== false && isBackdropAlwaysBlocking(el);
|
|
448
|
-
});
|
|
449
|
-
if (!hasRemainingLocking) {
|
|
450
|
-
setRootAriaHidden(false);
|
|
451
|
-
document.body.classList.remove(BACKDROP_NO_SCROLL);
|
|
452
|
-
}
|
|
453
|
-
};
|
|
454
|
-
export const present = async (overlay, name, iosEnterAnimation, mdEnterAnimation, opts) => {
|
|
515
|
+
export const present = async (overlay, name, iosEnterAnimation, mdEnterAnimation, ionicEnterAnimation, opts) => {
|
|
455
516
|
var _a, _b;
|
|
456
517
|
if (overlay.presented) {
|
|
457
518
|
return;
|
|
@@ -499,11 +560,15 @@ export const present = async (overlay, name, iosEnterAnimation, mdEnterAnimation
|
|
|
499
560
|
document.body.classList.add(BACKDROP_NO_SCROLL);
|
|
500
561
|
}
|
|
501
562
|
(_a = overlay.willPresentShorthand) === null || _a === void 0 ? void 0 : _a.emit();
|
|
563
|
+
const theme = getIonTheme(overlay);
|
|
502
564
|
const mode = getIonMode(overlay);
|
|
565
|
+
const selectedAnimation = mode === 'ios'
|
|
566
|
+
? iosEnterAnimation
|
|
567
|
+
: theme === 'ionic' && ionicEnterAnimation
|
|
568
|
+
? ionicEnterAnimation
|
|
569
|
+
: mdEnterAnimation;
|
|
503
570
|
// get the user's animation fn if one was provided
|
|
504
|
-
const animationBuilder = overlay.enterAnimation
|
|
505
|
-
? overlay.enterAnimation
|
|
506
|
-
: config.get(name, mode === 'ios' ? iosEnterAnimation : mdEnterAnimation);
|
|
571
|
+
const animationBuilder = overlay.enterAnimation ? overlay.enterAnimation : config.get(name, selectedAnimation);
|
|
507
572
|
const completed = await overlayAnimation(overlay, animationBuilder, overlay.el, opts);
|
|
508
573
|
if (completed) {
|
|
509
574
|
overlay.didPresent.emit();
|
|
@@ -658,7 +723,8 @@ export const dismiss = async (overlay, data, role, name, iosLeaveAnimation, mdLe
|
|
|
658
723
|
return true;
|
|
659
724
|
};
|
|
660
725
|
const getAppRoot = (doc) => {
|
|
661
|
-
|
|
726
|
+
const appRootSelector = config.get('appRootSelector', 'ion-app');
|
|
727
|
+
return doc.querySelector(appRootSelector) || doc.body;
|
|
662
728
|
};
|
|
663
729
|
const overlayAnimation = async (overlay, animationBuilder, baseEl, opts) => {
|
|
664
730
|
// Make overlay visible in case it's hidden
|
|
@@ -3,8 +3,22 @@
|
|
|
3
3
|
*/
|
|
4
4
|
import { printIonError } from "../logging/index";
|
|
5
5
|
/**
|
|
6
|
-
*
|
|
7
|
-
*
|
|
6
|
+
* Sanitize an untrusted HTML string.
|
|
7
|
+
*
|
|
8
|
+
* Parses the string into a detached DOM, removes blocked tags, strips
|
|
9
|
+
* attributes outside the `allowedAttributes` list (refer `sanitizeElement`),
|
|
10
|
+
* and scrubs script-scheme URLs. Returns the sanitized HTML string.
|
|
11
|
+
*
|
|
12
|
+
* Use this when you have an HTML string from an unknown source and need to
|
|
13
|
+
* render it via `innerHTML`. Use `sanitizeDOMTree` instead when you already
|
|
14
|
+
* have a DOM tree and want to sanitize it in place without a string round
|
|
15
|
+
* trip; both apply the same attribute policy.
|
|
16
|
+
*
|
|
17
|
+
* @param untrustedString - The HTML string to sanitize. Pass an
|
|
18
|
+
* `IonicSafeString` to bypass sanitization, or `undefined` to short-circuit.
|
|
19
|
+
* @returns The sanitized HTML string, or `undefined` if the input was
|
|
20
|
+
* `undefined`. Returns `''` if sanitization fails or the input contains
|
|
21
|
+
* an inline `onload=` handler.
|
|
8
22
|
*/
|
|
9
23
|
export const sanitizeDOMString = (untrustedString) => {
|
|
10
24
|
try {
|
|
@@ -80,6 +94,36 @@ export const sanitizeDOMString = (untrustedString) => {
|
|
|
80
94
|
return '';
|
|
81
95
|
}
|
|
82
96
|
};
|
|
97
|
+
/**
|
|
98
|
+
* Sanitize an entire trusted DOM tree in place.
|
|
99
|
+
*
|
|
100
|
+
* Removes blocked tags (`script`, `iframe`, etc.) from the subtree and
|
|
101
|
+
* then sanitizes attributes on every remaining element using the same
|
|
102
|
+
* allowlist policy as `sanitizeDOMString` (refer `sanitizeElement`).
|
|
103
|
+
* Component presentational attributes (`size`, `color`, `shape`, inline
|
|
104
|
+
* SVG, `aria-*`, `data-*`) are preserved; `style`, event handlers (`on*`),
|
|
105
|
+
* form/navigation-hijack attributes, script-scheme URLs, and non-image
|
|
106
|
+
* `data:` URLs are stripped.
|
|
107
|
+
*
|
|
108
|
+
* Use this when you have a DOM tree the developer controls (e.g.
|
|
109
|
+
* cloned slot content from a component) and you need to render it
|
|
110
|
+
* elsewhere safely.
|
|
111
|
+
*
|
|
112
|
+
* @param root - The root element whose subtree will be sanitized in
|
|
113
|
+
* place. No-op when the sanitizer is disabled via `Ionic.config`.
|
|
114
|
+
*/
|
|
115
|
+
export const sanitizeDOMTree = (root) => {
|
|
116
|
+
if (!isSanitizerEnabled()) {
|
|
117
|
+
return;
|
|
118
|
+
}
|
|
119
|
+
blockedTags.forEach((tag) => {
|
|
120
|
+
const matches = root.querySelectorAll(tag);
|
|
121
|
+
for (let i = matches.length - 1; i >= 0; i--) {
|
|
122
|
+
matches[i].remove();
|
|
123
|
+
}
|
|
124
|
+
});
|
|
125
|
+
sanitizeElement(root);
|
|
126
|
+
};
|
|
83
127
|
/**
|
|
84
128
|
* Clean up current element based on allowed attributes
|
|
85
129
|
* and then recursively dig down into any child elements to
|
|
@@ -101,29 +145,60 @@ const sanitizeElement = (element) => {
|
|
|
101
145
|
element.remove();
|
|
102
146
|
return;
|
|
103
147
|
}
|
|
148
|
+
/**
|
|
149
|
+
* Always strip `style` (CSS injection, `background:url()` beaconing, UI
|
|
150
|
+
* spoofing). It is never on the allowlist, but it is removed explicitly
|
|
151
|
+
* here because some engines (e.g. jsdom) don't enumerate the CSSOM-backed
|
|
152
|
+
* `style` attribute in `element.attributes`, which would let the loop
|
|
153
|
+
* below skip over it.
|
|
154
|
+
*/
|
|
155
|
+
element.removeAttribute('style');
|
|
104
156
|
for (let i = element.attributes.length - 1; i >= 0; i--) {
|
|
105
157
|
const attribute = element.attributes.item(i);
|
|
106
158
|
const attributeName = attribute.name;
|
|
107
|
-
|
|
108
|
-
|
|
159
|
+
const lowerName = attributeName.toLowerCase();
|
|
160
|
+
/**
|
|
161
|
+
* Remove any attribute that is not on the allowlist. This drops event
|
|
162
|
+
* handlers (`on*`), `style`, the form/navigation-hijack attributes
|
|
163
|
+
* (`formaction`, `action`, `target`), namespaced attributes like
|
|
164
|
+
* `xlink:href`, and anything else not explicitly known to be safe.
|
|
165
|
+
*/
|
|
166
|
+
if (!isAttributeAllowed(lowerName)) {
|
|
109
167
|
element.removeAttribute(attributeName);
|
|
110
168
|
continue;
|
|
111
169
|
}
|
|
112
170
|
// clean up any allowed attribs
|
|
113
171
|
// that attempt to do any JS funny-business
|
|
114
172
|
const attributeValue = attribute.value;
|
|
173
|
+
if (attributeValue == null) {
|
|
174
|
+
continue;
|
|
175
|
+
}
|
|
115
176
|
/**
|
|
116
|
-
*
|
|
117
|
-
*
|
|
118
|
-
* such as
|
|
177
|
+
* Scrub dangerous schemes from the value. The value is normalized first
|
|
178
|
+
* (whitespace and ASCII control characters removed) so entity-obfuscated
|
|
179
|
+
* payloads such as `java	script:`, which the parser decodes to
|
|
180
|
+
* `java\tscript:`, are still caught. Normalizing the value also covers
|
|
181
|
+
* namespaced attributes, where the previous `element[attributeName]`
|
|
182
|
+
* property reflection returned `undefined` and let them slip through.
|
|
119
183
|
*/
|
|
120
|
-
const
|
|
121
|
-
|
|
122
|
-
if ((
|
|
123
|
-
|
|
184
|
+
const normalizedValue = attributeValue.replace(controlCharactersAndWhitespace, '').toLowerCase();
|
|
185
|
+
// Script schemes are never allowed, on any attribute.
|
|
186
|
+
if (normalizedValue.includes('javascript:') || normalizedValue.includes('vbscript:')) {
|
|
187
|
+
element.removeAttribute(attributeName);
|
|
188
|
+
continue;
|
|
189
|
+
}
|
|
190
|
+
/**
|
|
191
|
+
* For URL-bearing attributes, allow `data:` URIs only for raster
|
|
192
|
+
* images. Document-bearing types (`text/html`, `image/svg+xml`,
|
|
193
|
+
* `application/*`, etc.) can carry markup or script when navigated to
|
|
194
|
+
* or rendered, so they are stripped, while safe image types are kept so
|
|
195
|
+
* inline images keep working.
|
|
196
|
+
*/
|
|
197
|
+
if (urlAttributes.includes(lowerName) &&
|
|
198
|
+
normalizedValue.startsWith('data:') &&
|
|
199
|
+
!safeDataImageUri.test(normalizedValue)) {
|
|
124
200
|
element.removeAttribute(attributeName);
|
|
125
201
|
}
|
|
126
|
-
/* eslint-enable */
|
|
127
202
|
}
|
|
128
203
|
/**
|
|
129
204
|
* Sanitize any nested children
|
|
@@ -156,8 +231,174 @@ const isSanitizerEnabled = () => {
|
|
|
156
231
|
}
|
|
157
232
|
return true;
|
|
158
233
|
};
|
|
159
|
-
|
|
160
|
-
|
|
234
|
+
/**
|
|
235
|
+
* Mirror known custom-element DOM properties onto attributes so they
|
|
236
|
+
* survive `cloneNode`. Call this on a DOM subtree before cloning it for
|
|
237
|
+
* rendering elsewhere (e.g. cloning slotted option content into an
|
|
238
|
+
* overlay).
|
|
239
|
+
*
|
|
240
|
+
* Only sets the attribute when the property holds a non-empty string
|
|
241
|
+
* and the attribute isn't already present, so existing attributes
|
|
242
|
+
* take precedence.
|
|
243
|
+
*
|
|
244
|
+
* @param root - The root element whose subtree (and itself) will be
|
|
245
|
+
* inspected.
|
|
246
|
+
*/
|
|
247
|
+
export const reflectPropertiesToAttributes = (root) => {
|
|
248
|
+
const candidates = [];
|
|
249
|
+
if (root.tagName in elementPropsToReflect) {
|
|
250
|
+
candidates.push(root);
|
|
251
|
+
}
|
|
252
|
+
for (const tagName of Object.keys(elementPropsToReflect)) {
|
|
253
|
+
candidates.push(...Array.from(root.querySelectorAll(tagName.toLowerCase())));
|
|
254
|
+
}
|
|
255
|
+
for (const el of candidates) {
|
|
256
|
+
if (!(el.tagName in elementPropsToReflect)) {
|
|
257
|
+
continue;
|
|
258
|
+
}
|
|
259
|
+
const props = elementPropsToReflect[el.tagName];
|
|
260
|
+
for (const prop of props) {
|
|
261
|
+
const value = el[prop];
|
|
262
|
+
if (typeof value === 'string' && value.length > 0 && !el.hasAttribute(prop)) {
|
|
263
|
+
el.setAttribute(prop, value);
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
};
|
|
268
|
+
/**
|
|
269
|
+
* Attribute names that are always safe to keep. Covers global HTML
|
|
270
|
+
* attributes, the Ionic component presentational props that cloned rich
|
|
271
|
+
* content (e.g. `ion-select-option` markup) relies on, and the inert SVG
|
|
272
|
+
* presentation attributes used by inline icons.
|
|
273
|
+
*
|
|
274
|
+
* `aria-*` and `data-*` are allowed separately by prefix (refer
|
|
275
|
+
* `allowedAttributePrefixes`) since they are inert and not worth
|
|
276
|
+
* enumerating. URL-bearing names (`href`, `src`) are allowed here, but
|
|
277
|
+
* their values are still scrubbed for script schemes in `sanitizeElement`.
|
|
278
|
+
*
|
|
279
|
+
* Notably absent: `style`, event handlers (`on*`), and the
|
|
280
|
+
* form/navigation-hijack attributes (`formaction`, `action`, `target`),
|
|
281
|
+
* which are therefore stripped.
|
|
282
|
+
*/
|
|
283
|
+
const allowedAttributes = [
|
|
284
|
+
// Global / structural
|
|
285
|
+
'class',
|
|
286
|
+
'id',
|
|
287
|
+
'slot',
|
|
288
|
+
'name',
|
|
289
|
+
'title',
|
|
290
|
+
'alt',
|
|
291
|
+
'lang',
|
|
292
|
+
'dir',
|
|
293
|
+
'role',
|
|
294
|
+
'type',
|
|
295
|
+
'value',
|
|
296
|
+
'disabled',
|
|
297
|
+
'width',
|
|
298
|
+
'height',
|
|
299
|
+
'href',
|
|
300
|
+
'src',
|
|
301
|
+
// Ionic component presentational props
|
|
302
|
+
'color',
|
|
303
|
+
'size',
|
|
304
|
+
'shape',
|
|
305
|
+
'fill',
|
|
306
|
+
'expand',
|
|
307
|
+
'mode',
|
|
308
|
+
'theme',
|
|
309
|
+
'icon',
|
|
310
|
+
'label',
|
|
311
|
+
'label-placement',
|
|
312
|
+
'justify',
|
|
313
|
+
'inset',
|
|
314
|
+
'lines',
|
|
315
|
+
'ios',
|
|
316
|
+
'md',
|
|
317
|
+
// SVG presentation attributes (compared lowercased, e.g. `viewBox`)
|
|
318
|
+
'xmlns',
|
|
319
|
+
'viewbox',
|
|
320
|
+
'preserveaspectratio',
|
|
321
|
+
'stroke',
|
|
322
|
+
'stroke-width',
|
|
323
|
+
'stroke-linecap',
|
|
324
|
+
'stroke-linejoin',
|
|
325
|
+
'stroke-opacity',
|
|
326
|
+
'stroke-dasharray',
|
|
327
|
+
'fill-rule',
|
|
328
|
+
'fill-opacity',
|
|
329
|
+
'clip-rule',
|
|
330
|
+
'd',
|
|
331
|
+
'points',
|
|
332
|
+
'cx',
|
|
333
|
+
'cy',
|
|
334
|
+
'r',
|
|
335
|
+
'rx',
|
|
336
|
+
'ry',
|
|
337
|
+
'x',
|
|
338
|
+
'y',
|
|
339
|
+
'x1',
|
|
340
|
+
'y1',
|
|
341
|
+
'x2',
|
|
342
|
+
'y2',
|
|
343
|
+
'transform',
|
|
344
|
+
'opacity',
|
|
345
|
+
];
|
|
346
|
+
/**
|
|
347
|
+
* Attribute-name prefixes that are always safe to keep. `aria-*` and
|
|
348
|
+
* `data-*` attributes cannot execute script or load resources, so they are
|
|
349
|
+
* allowed wholesale rather than enumerated by name.
|
|
350
|
+
*/
|
|
351
|
+
const allowedAttributePrefixes = ['aria-', 'data-'];
|
|
352
|
+
/**
|
|
353
|
+
* Whether an attribute name (already lowercased) is safe to keep, by exact
|
|
354
|
+
* match or by an allowed prefix.
|
|
355
|
+
*/
|
|
356
|
+
const isAttributeAllowed = (lowerName) => {
|
|
357
|
+
if (allowedAttributes.includes(lowerName)) {
|
|
358
|
+
return true;
|
|
359
|
+
}
|
|
360
|
+
return allowedAttributePrefixes.some((prefix) => lowerName.startsWith(prefix));
|
|
361
|
+
};
|
|
362
|
+
/**
|
|
363
|
+
* Matches ASCII control characters and whitespace (including the
|
|
364
|
+
* non-breaking space). Used to normalize attribute values before matching
|
|
365
|
+
* a URL scheme so entity-obfuscated payloads such as `java	script:`
|
|
366
|
+
* (decoded by the parser to `java\tscript:`) can't smuggle a scheme past
|
|
367
|
+
* the check.
|
|
368
|
+
*/
|
|
369
|
+
// eslint-disable-next-line no-control-regex -- matching control characters is the point
|
|
370
|
+
const controlCharactersAndWhitespace = /[\u0000-\u0020\u007f-\u00a0]/g;
|
|
371
|
+
/**
|
|
372
|
+
* Attributes whose values are URLs. Their values are scheme-checked in
|
|
373
|
+
* `sanitizeElement` (e.g. `data:` filtering) beyond the script-scheme scrub
|
|
374
|
+
* applied to every attribute.
|
|
375
|
+
*/
|
|
376
|
+
const urlAttributes = ['href', 'src'];
|
|
377
|
+
/**
|
|
378
|
+
* Matches a `data:` URI for a raster image type that cannot carry script.
|
|
379
|
+
* `image/svg+xml` is deliberately excluded (SVG can execute script), as are
|
|
380
|
+
* document types like `text/html` and `application/*`. The value is already
|
|
381
|
+
* lowercased and whitespace-stripped before this is tested.
|
|
382
|
+
*/
|
|
383
|
+
const safeDataImageUri = /^data:image\/(?:png|jpe?g|gif|webp|bmp|avif|x-icon|vnd\.microsoft\.icon)[;,]/;
|
|
384
|
+
/**
|
|
385
|
+
* Tags removed entirely (with their subtree) before attribute sanitization.
|
|
386
|
+
* Exported so tests can assert the set without hardcoding it.
|
|
387
|
+
*/
|
|
388
|
+
export const blockedTags = ['script', 'style', 'iframe', 'meta', 'link', 'object', 'embed', 'base'];
|
|
389
|
+
/**
|
|
390
|
+
* Properties on custom elements that frameworks (Vue, Angular) often
|
|
391
|
+
* set as DOM properties rather than attributes. `cloneNode` only copies
|
|
392
|
+
* attributes, so these values are lost when slotted content is cloned
|
|
393
|
+
* into an overlay. For each known custom element, we mirror the listed
|
|
394
|
+
* properties onto attributes so the cloned copy still has the data it
|
|
395
|
+
* needs to render.
|
|
396
|
+
*
|
|
397
|
+
* Keyed by uppercased tagName so the lookup matches `Element.tagName`.
|
|
398
|
+
*/
|
|
399
|
+
const elementPropsToReflect = {
|
|
400
|
+
'ION-ICON': ['icon', 'name', 'src', 'ios', 'md'],
|
|
401
|
+
};
|
|
161
402
|
export class IonicSafeString {
|
|
162
403
|
constructor(value) {
|
|
163
404
|
this.value = value;
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* (C) Ionic http://ionicframework.com - MIT License
|
|
3
|
+
*/
|
|
4
|
+
import { h } from "@stencil/core";
|
|
5
|
+
import { sanitizeDOMTree } from "./sanitization/index";
|
|
6
|
+
/**
|
|
7
|
+
* Converts a DOM node into a Stencil VNode (or text string) so the
|
|
8
|
+
* resulting tree is rendered through the component's normal render
|
|
9
|
+
* path. Rendering through Stencil ensures that scoped CSS classes
|
|
10
|
+
* (e.g. `sc-ion-action-sheet-ionic`) are applied to every element.
|
|
11
|
+
*
|
|
12
|
+
* Highly recommended to pre-sanitize the source DOM (see
|
|
13
|
+
* `getOptionContent` in select.tsx). This function performs pure
|
|
14
|
+
* structural conversion — no security filtering.
|
|
15
|
+
*
|
|
16
|
+
* Preserves attributes only — properties set imperatively on the source
|
|
17
|
+
* element (e.g. `input.value` after a user types) won't carry through.
|
|
18
|
+
* In practice this isn't a concern: interactive controls shouldn't
|
|
19
|
+
* appear in select-option rich content since they'd nest inside the
|
|
20
|
+
* overlay's button/radio/checkbox wrapper, which is invalid HTML and
|
|
21
|
+
* an accessibility issue.
|
|
22
|
+
*
|
|
23
|
+
* @param node - The DOM node to convert. Text nodes become strings,
|
|
24
|
+
* element nodes become VNodes, and any other node types are skipped.
|
|
25
|
+
* @param keyPrefix - String prefix used to build a stable VNode key,
|
|
26
|
+
* so Stencil's diff can preserve elements across re-renders.
|
|
27
|
+
* @param index - Position of this node among its siblings. Combined
|
|
28
|
+
* with `keyPrefix` to form the final unique key.
|
|
29
|
+
* @returns The converted VNode, a text string, or `null` if the node
|
|
30
|
+
* type isn't supported.
|
|
31
|
+
*
|
|
32
|
+
* @internal Exported only so it can be unit tested; not part of the
|
|
33
|
+
* public API.
|
|
34
|
+
*/
|
|
35
|
+
export const cloneToVNode = (node, keyPrefix, index) => {
|
|
36
|
+
var _a;
|
|
37
|
+
if (node.nodeType === Node.TEXT_NODE) {
|
|
38
|
+
return (_a = node.textContent) !== null && _a !== void 0 ? _a : '';
|
|
39
|
+
}
|
|
40
|
+
if (node.nodeType !== Node.ELEMENT_NODE) {
|
|
41
|
+
return null;
|
|
42
|
+
}
|
|
43
|
+
const el = node;
|
|
44
|
+
const tag = el.tagName.toLowerCase();
|
|
45
|
+
const key = `${keyPrefix}-${index}`;
|
|
46
|
+
const attrs = { key };
|
|
47
|
+
for (let i = 0; i < el.attributes.length; i++) {
|
|
48
|
+
const attr = el.attributes.item(i);
|
|
49
|
+
attrs[attr.name] = attr.value;
|
|
50
|
+
}
|
|
51
|
+
const children = Array.from(el.childNodes)
|
|
52
|
+
.map((child, i) => cloneToVNode(child, key, i))
|
|
53
|
+
.filter((c) => c !== null);
|
|
54
|
+
return h(tag, attrs, children);
|
|
55
|
+
};
|
|
56
|
+
/**
|
|
57
|
+
* Renders cloned DOM content as Stencil JSX. Walking the source DOM
|
|
58
|
+
* into VNodes (rather than injecting it via innerHTML) keeps the
|
|
59
|
+
* content inside Stencil's render path, so scoped CSS classes are
|
|
60
|
+
* applied automatically and component attributes like `size` or
|
|
61
|
+
* `color` survive intact.
|
|
62
|
+
*
|
|
63
|
+
* Span elements should be used when this content renders within buttons,
|
|
64
|
+
* depending on the select interface. Buttons can only have phrasing
|
|
65
|
+
* content to prevent accessibility issues.
|
|
66
|
+
*
|
|
67
|
+
* @param id - Unique identifier for generating stable virtual DOM keys.
|
|
68
|
+
* @param content - The HTMLElement container whose child nodes will be cloned.
|
|
69
|
+
* @param className - CSS class applied to the wrapper element.
|
|
70
|
+
* @param useSpan - Whether to use a span element instead of a div for the wrapper.
|
|
71
|
+
*/
|
|
72
|
+
const renderClonedContent = (id, content, className, useSpan = false) => {
|
|
73
|
+
const Tag = useSpan ? 'span' : 'div';
|
|
74
|
+
const keyPrefix = `${className}-${id}`;
|
|
75
|
+
sanitizeDOMTree(content);
|
|
76
|
+
return (h(Tag, { class: className, key: keyPrefix }, Array.from(content.childNodes).map((child, i) => cloneToVNode(child, keyPrefix, i))));
|
|
77
|
+
};
|
|
78
|
+
/**
|
|
79
|
+
* Renders the label content for a select option within an overlay
|
|
80
|
+
* interface based on the presence of rich content.
|
|
81
|
+
*
|
|
82
|
+
* Span elements should be used when this content renders within buttons,
|
|
83
|
+
* depending on the select interface. Buttons can only have phrasing
|
|
84
|
+
* content to prevent accessibility issues.
|
|
85
|
+
*
|
|
86
|
+
* @param option - The content option data containing label, slots,
|
|
87
|
+
* and description.
|
|
88
|
+
* @param className - The base CSS class for the label element.
|
|
89
|
+
* @param useSpan - Whether to use a span element instead of a div for the label.
|
|
90
|
+
*/
|
|
91
|
+
export const renderOptionLabel = (option, className, useSpan = false) => {
|
|
92
|
+
const { id, label, startContent, endContent, description } = option;
|
|
93
|
+
const hasRichContent = !!startContent || !!endContent || !!description;
|
|
94
|
+
const Tag = useSpan ? 'span' : 'div';
|
|
95
|
+
// Render simple string label if there is no rich content to display
|
|
96
|
+
if (!hasRichContent && (typeof label === 'string' || !label)) {
|
|
97
|
+
return (h(Tag, { class: className, key: `${className}-${id}` }, label));
|
|
98
|
+
}
|
|
99
|
+
// Render the main label
|
|
100
|
+
const labelEl = typeof label === 'string' || !label ? (
|
|
101
|
+
// Label is a simple string or undefined
|
|
102
|
+
h(Tag, { key: `${className}-label-${id}` }, label)) : (
|
|
103
|
+
// Label is an HTMLElement with potential rich content
|
|
104
|
+
renderClonedContent(id, label, `${className}-text`, useSpan));
|
|
105
|
+
// No rich content, render just the label
|
|
106
|
+
if (!hasRichContent) {
|
|
107
|
+
return (h(Tag, { class: className, key: `${className}-${id}` }, labelEl));
|
|
108
|
+
}
|
|
109
|
+
// Render label with rich content (start, end, description)
|
|
110
|
+
return (h(Tag, { class: `${className} ${className}-has-rich-content`, key: `${className}-${id}` }, startContent && renderClonedContent(id, startContent, 'select-option-start', useSpan), h(Tag, { class: "select-option-content", key: `${className}-content-${id}` }, labelEl, description && (h(Tag, { class: "select-option-description", key: `${className}-desc-${id}` }, description))), endContent && renderClonedContent(id, endContent, 'select-option-end', useSpan)));
|
|
111
|
+
};
|