@ionic/core 8.8.8-nightly.20260520 → 8.8.9-dev.11779403760.13ea2a08
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.js +1 -1
- package/components/ion-picker-legacy.js +1 -1
- package/components/ion-picker.js +1 -1
- package/components/ion-popover.js +1 -1
- package/components/ion-progress-bar.js +1 -1
- package/components/ion-radio-group.js +1 -1
- package/components/ion-radio.js +1 -1
- package/components/ion-range.js +1 -1
- package/components/ion-refresher-content.js +1 -1
- package/components/ion-refresher.js +1 -1
- package/components/ion-reorder-group.js +1 -1
- package/components/ion-reorder.js +1 -1
- package/components/ion-ripple-effect.js +1 -1
- package/components/ion-route-redirect.js +1 -1
- package/components/ion-route.js +1 -1
- package/components/ion-router-link.js +1 -1
- package/components/ion-router-outlet.js +1 -1
- package/components/ion-router.js +1 -1
- package/components/ion-row.js +1 -1
- package/components/ion-searchbar.js +1 -1
- package/components/ion-segment-button.js +1 -1
- package/components/ion-segment-content.js +1 -1
- package/components/ion-segment-view.js +1 -1
- package/components/ion-segment.js +1 -1
- package/components/ion-select-modal.js +1 -1
- package/components/ion-select-option.js +1 -1
- package/components/ion-select-popover.js +1 -1
- package/components/ion-select.js +1 -1
- package/components/ion-skeleton-text.js +1 -1
- package/components/ion-spinner.js +1 -1
- package/components/ion-split-pane.js +1 -1
- package/components/ion-tab-bar.js +1 -1
- package/components/ion-tab-button.js +1 -1
- package/components/ion-tab.js +1 -1
- package/components/ion-tabs.js +1 -1
- package/components/ion-text.js +1 -1
- package/components/ion-textarea.js +1 -1
- package/components/ion-thumbnail.js +1 -1
- package/components/ion-title.js +1 -1
- package/components/ion-toast.js +1 -1
- package/components/ion-toggle.js +1 -1
- package/components/ion-toolbar.js +1 -1
- package/components/p-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-BYSs-jZz.js +4 -0
- package/components/{p-CU1SSH8_.js → p-BZCB7f49.js} +1 -1
- package/components/p-B_MdONwD.js +4 -0
- package/components/p-BaPtaYEC.js +4 -0
- package/components/p-BcbmT6b3.js +4 -0
- 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-BsNpz2u3.js +4 -0
- package/components/p-BsSTz5ia.js +4 -0
- package/{dist/ionic/p-BxIcPWoV.js → components/p-Bt0d89x3.js} +1 -1
- package/components/p-BwQOIWD7.js +4 -0
- package/components/{p-CEmXdzGo.js → p-ByW0kK1F.js} +1 -1
- package/components/p-C75FIZBC.js +4 -0
- package/components/p-C8kBejTT.js +4 -0
- package/components/p-CBS0sBAa.js +4 -0
- package/components/{p-9VcRUwdB.js → p-CDgDBcU9.js} +1 -1
- package/components/p-CUAgUmQC.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-DXehWlOr.js +4 -0
- package/components/p-DaJxRxSQ.js +4 -0
- package/components/p-DhXUGFNH.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-NVAi5HQQ.js +4 -0
- package/components/p-PzmQ86nh.js +4 -0
- package/components/p-Skz67GXZ.js +4 -0
- package/components/p-VVrXfwLZ.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-hpwmNJ2Q.js +4 -0
- package/components/p-kKYBfhbe.js +4 -0
- package/components/p-lGSe6-vg.js +4 -0
- package/{dist/ionic/p-BvFYtOdE.js → components/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-vXpMhGrs.js +4 -0
- package/components/p-wCDzv5Q8.js +4 -0
- package/components/{p-YLXPWgVj.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-Dg4yiuR2.js → animation-BZJ2wKuM.js} +3 -3
- package/dist/cjs/{app-globals-CLI8xCmk.js → app-globals-C-d5fQ35.js} +1 -1
- package/dist/cjs/{button-active-FscMI17-.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-BukYi_pW.js → config-BiqQSDrb.js} +60 -7
- package/dist/cjs/{data-BYlBjkMU.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-CRgp8o_p.js → framework-delegate-Dx9FrqAC.js} +4 -2
- package/dist/cjs/{haptic-ClPPQ_PS.js → haptic-CQJGW58i.js} +1 -1
- package/dist/cjs/{helpers-CxTYJdbT.js → helpers-DJYxKN5U.js} +57 -4
- package/dist/cjs/{index-MbaBbWXk.js → index-BJrpF9T3.js} +2 -2
- package/dist/cjs/{index-CFUwM5x_.js → index-BekUBS8C.js} +15 -15
- package/dist/cjs/{index-DqmRDbxg.js → index-CgAbCW6L.js} +2 -0
- package/dist/cjs/{index-YcSftOMz.js → index-CwxYd6UD.js} +9 -8
- package/dist/cjs/{index-CqT-2gKy.js → index-CzcLEdQ5.js} +41 -4
- package/dist/cjs/{index-C845Ti6K.js → index-DSNlrgfO.js} +4 -4
- package/dist/cjs/index.cjs.js +13 -14
- package/dist/cjs/{input-shims-CPL2J8F-.js → input-shims-VyZciSxi.js} +18 -17
- package/dist/cjs/{input.utils-DmeJ8dmo.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 +40 -22
- package/dist/cjs/ion-alert.cjs.entry.js +76 -40
- package/dist/cjs/ion-app_8.cjs.entry.js +292 -157
- package/dist/cjs/ion-avatar_3.cjs.entry.js +125 -13
- package/dist/cjs/ion-back-button.cjs.entry.js +31 -22
- package/dist/cjs/ion-backdrop.cjs.entry.js +10 -7
- package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +54 -18
- package/dist/cjs/ion-button_2.cjs.entry.js +59 -22
- package/dist/cjs/ion-card_5.cjs.entry.js +55 -33
- package/dist/cjs/ion-checkbox.cjs.entry.js +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_3.cjs.entry.js +116 -41
- package/dist/cjs/ion-divider.cjs.entry.js +51 -0
- package/dist/cjs/ion-fab_3.cjs.entry.js +44 -28
- package/dist/cjs/ion-gallery.cjs.entry.js +510 -0
- package/dist/cjs/ion-img.cjs.entry.js +8 -4
- package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +91 -16
- package/dist/cjs/ion-input-otp.cjs.entry.js +74 -9
- package/dist/cjs/ion-input-password-toggle.cjs.entry.js +53 -15
- package/dist/cjs/ion-input.cjs.entry.js +124 -34
- package/dist/cjs/ion-item-option_3.cjs.entry.js +467 -52
- package/dist/cjs/ion-item_8.cjs.entry.js +115 -49
- package/dist/cjs/ion-loading.cjs.entry.js +20 -18
- package/dist/cjs/ion-menu_3.cjs.entry.js +47 -29
- package/dist/cjs/ion-modal.cjs.entry.js +262 -138
- package/dist/cjs/ion-nav_2.cjs.entry.js +14 -11
- package/dist/cjs/ion-picker-column-option.cjs.entry.js +12 -8
- package/dist/cjs/ion-picker-column.cjs.entry.js +14 -14
- package/dist/cjs/ion-picker.cjs.entry.js +10 -6
- package/dist/cjs/ion-popover.cjs.entry.js +21 -19
- package/dist/cjs/ion-progress-bar.cjs.entry.js +27 -9
- package/dist/cjs/ion-radio_2.cjs.entry.js +35 -17
- package/dist/cjs/ion-range.cjs.entry.js +20 -13
- package/dist/cjs/ion-refresher_2.cjs.entry.js +39 -21
- package/dist/cjs/ion-reorder_2.cjs.entry.js +38 -14
- package/dist/cjs/ion-ripple-effect.cjs.entry.js +15 -7
- package/dist/cjs/ion-route_4.cjs.entry.js +10 -9
- package/dist/cjs/ion-searchbar.cjs.entry.js +137 -24
- package/dist/cjs/ion-segment-content.cjs.entry.js +2 -2
- package/dist/cjs/ion-segment-view.cjs.entry.js +13 -3
- package/dist/cjs/ion-segment_2.cjs.entry.js +23 -16
- package/dist/cjs/ion-select-modal.cjs.entry.js +119 -40
- package/dist/cjs/ion-select_3.cjs.entry.js +500 -84
- 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 +69 -46
- package/dist/cjs/ion-toggle.cjs.entry.js +82 -25
- package/dist/cjs/ionic-global-BW5tRzrz.js +519 -0
- package/dist/cjs/ionic.cjs.js +4 -4
- package/dist/cjs/{ios.transition-trBiC95R.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-CUQECuvD.js → md.transition-BEfrfWKW.js} +6 -5
- package/dist/cjs/{notch-controller-sD-lTpdc.js → notch-controller-BTZCPOsd.js} +4 -4
- package/dist/cjs/overlay-control-label-t9ZFhCtr.js +51 -0
- package/dist/cjs/{overlays-C2jiBSNQ.js → overlays-BuMIwR8B.js} +110 -16
- package/dist/cjs/select-option-render-C72N7OsO.js +111 -0
- package/dist/cjs/{status-tap-CCJk5VgT.js → status-tap-CTY2dMsZ.js} +4 -3
- package/dist/cjs/{swipe-back-BGhTQ1CU.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 +7 -0
- 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 +439 -0
- package/dist/collection/components/action-sheet/action-sheet.ios.css +155 -11
- package/dist/collection/components/action-sheet/action-sheet.js +32 -13
- package/dist/collection/components/action-sheet/action-sheet.md.css +155 -10
- package/dist/collection/components/alert/alert.ionic.css +726 -0
- package/dist/collection/components/alert/alert.ios.css +219 -19
- package/dist/collection/components/alert/alert.js +67 -30
- package/dist/collection/components/alert/alert.md.css +229 -15
- 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 +595 -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 +148 -37
- package/dist/collection/components/input/input.md.css +193 -207
- package/dist/collection/components/input-otp/input-otp.ionic.css +371 -0
- package/dist/collection/components/input-otp/input-otp.ios.css +105 -60
- package/dist/collection/components/input-otp/input-otp.js +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 +14 -11
- package/dist/collection/components/loading/loading.md.css +13 -1
- package/dist/collection/components/menu/menu.ios.css +15 -3
- package/dist/collection/components/menu/menu.js +12 -7
- package/dist/collection/components/menu/menu.md.css +15 -3
- package/dist/collection/components/menu-button/menu-button.ionic.css +236 -0
- package/dist/collection/components/menu-button/menu-button.ios.css +48 -14
- package/dist/collection/components/menu-button/menu-button.js +26 -10
- package/dist/collection/components/menu-button/menu-button.md.css +49 -15
- package/dist/collection/components/menu-toggle/menu-toggle.js +8 -5
- package/dist/collection/components/modal/animations/ionic.enter.js +40 -0
- package/dist/collection/components/modal/animations/ionic.leave.js +28 -0
- package/dist/collection/components/modal/animations/sheet.js +8 -2
- package/dist/collection/components/modal/gestures/sheet.js +76 -10
- package/dist/collection/components/modal/modal.ionic.css +247 -0
- package/dist/collection/components/modal/modal.ios.css +178 -70
- package/dist/collection/components/modal/modal.js +50 -12
- package/dist/collection/components/modal/modal.md.css +178 -70
- package/dist/collection/components/nav/nav.css +7 -1
- package/dist/collection/components/nav/nav.js +11 -5
- package/dist/collection/components/nav-link/nav-link.js +5 -1
- package/dist/collection/components/note/note.ios.css +12 -0
- package/dist/collection/components/note/note.js +11 -8
- package/dist/collection/components/note/note.md.css +12 -0
- package/dist/collection/components/picker/picker.ios.css +15 -3
- package/dist/collection/components/picker/picker.js +8 -5
- package/dist/collection/components/picker/picker.md.css +15 -3
- package/dist/collection/components/picker-column/picker-column.css +9 -2
- package/dist/collection/components/picker-column/picker-column.js +8 -7
- package/dist/collection/components/picker-column-option/picker-column-option.ios.css +6 -0
- package/dist/collection/components/picker-column-option/picker-column-option.js +13 -7
- package/dist/collection/components/picker-column-option/picker-column-option.md.css +6 -0
- package/dist/collection/components/picker-legacy/picker.ios.css +13 -1
- package/dist/collection/components/picker-legacy/picker.js +7 -6
- package/dist/collection/components/picker-legacy/picker.md.css +13 -1
- package/dist/collection/components/picker-legacy-column/picker-column.ios.css +12 -0
- package/dist/collection/components/picker-legacy-column/picker-column.js +4 -4
- package/dist/collection/components/picker-legacy-column/picker-column.md.css +12 -0
- package/dist/collection/components/popover/popover.ionic.css +290 -0
- package/dist/collection/components/popover/popover.ios.css +29 -1
- package/dist/collection/components/popover/popover.js +18 -15
- package/dist/collection/components/popover/popover.md.css +29 -1
- package/dist/collection/components/progress-bar/progress-bar.ionic.css +287 -0
- package/dist/collection/components/progress-bar/progress-bar.ios.css +48 -17
- package/dist/collection/components/progress-bar/progress-bar.js +43 -7
- package/dist/collection/components/progress-bar/progress-bar.md.css +48 -17
- package/dist/collection/components/radio/radio.ionic.css +422 -0
- package/dist/collection/components/radio/radio.ios.css +134 -91
- package/dist/collection/components/radio/radio.js +14 -9
- package/dist/collection/components/radio/radio.md.css +134 -91
- package/dist/collection/components/radio-group/radio-group.ionic.css +119 -0
- package/dist/collection/components/radio-group/radio-group.ios.css +43 -19
- package/dist/collection/components/radio-group/radio-group.js +48 -7
- package/dist/collection/components/radio-group/radio-group.md.css +43 -19
- package/dist/collection/components/range/range.ionic.css +567 -0
- package/dist/collection/components/range/range.ios.css +128 -85
- package/dist/collection/components/range/range.js +16 -10
- package/dist/collection/components/range/range.md.css +128 -85
- package/dist/collection/components/refresher/refresher.ios.css +14 -1
- package/dist/collection/components/refresher/refresher.js +11 -8
- package/dist/collection/components/refresher/refresher.md.css +15 -2
- package/dist/collection/components/refresher-content/refresher-content.js +28 -7
- package/dist/collection/components/reorder/reorder.ios.css +6 -0
- package/dist/collection/components/reorder/reorder.js +33 -6
- package/dist/collection/components/reorder/reorder.md.css +6 -0
- package/dist/collection/components/reorder-group/reorder-group.css +6 -0
- package/dist/collection/components/reorder-group/reorder-group.js +8 -4
- package/dist/collection/components/ripple-effect/{ripple-effect.css → ripple-effect.common.css} +7 -1
- package/dist/collection/components/ripple-effect/ripple-effect.ionic.css +215 -0
- package/dist/collection/components/ripple-effect/ripple-effect.js +14 -6
- package/dist/collection/components/route/route.js +4 -0
- package/dist/collection/components/router/router.js +4 -0
- package/dist/collection/components/router-link/router-link.css +8 -2
- package/dist/collection/components/router-link/router-link.js +9 -5
- package/dist/collection/components/router-outlet/router-outlet.css +7 -1
- package/dist/collection/components/router-outlet/router-outlet.js +6 -3
- package/dist/collection/components/row/row.css +16 -0
- package/dist/collection/components/row/row.js +9 -2
- package/dist/collection/components/searchbar/searchbar.ionic.css +626 -0
- package/dist/collection/components/searchbar/searchbar.ios.css +56 -18
- package/dist/collection/components/searchbar/searchbar.js +180 -33
- package/dist/collection/components/searchbar/searchbar.md.css +56 -18
- package/dist/collection/components/segment/segment.ionic.css +115 -0
- package/dist/collection/components/segment/segment.ios.css +45 -2
- package/dist/collection/components/segment/segment.js +11 -8
- package/dist/collection/components/segment/segment.md.css +45 -2
- package/dist/collection/components/segment-button/segment-button.ionic.css +353 -0
- package/dist/collection/components/segment-button/segment-button.ios.css +146 -105
- package/dist/collection/components/segment-button/segment-button.js +11 -8
- package/dist/collection/components/segment-button/segment-button.md.css +148 -107
- package/dist/collection/components/segment-content/segment-content.js +1 -1
- package/dist/collection/components/segment-view/segment-view.ios.css +6 -0
- package/dist/collection/components/segment-view/segment-view.js +13 -4
- package/dist/collection/components/segment-view/segment-view.md.css +6 -0
- package/dist/collection/components/select/select.ionic.css +810 -0
- package/dist/collection/components/select/select.ios.css +348 -176
- package/dist/collection/components/select/select.js +460 -66
- package/dist/collection/components/select/select.md.css +364 -178
- package/dist/collection/components/select-modal/select-modal.ionic.css +221 -0
- package/dist/collection/components/select-modal/select-modal.ios.css +156 -0
- package/dist/collection/components/select-modal/select-modal.js +132 -32
- package/dist/collection/components/select-modal/select-modal.md.css +139 -0
- package/dist/collection/components/select-option/select-option.js +70 -2
- package/dist/collection/components/select-popover/select-popover.ionic.css +220 -0
- package/dist/collection/components/select-popover/select-popover.ios.css +117 -23
- package/dist/collection/components/select-popover/select-popover.js +94 -31
- package/dist/collection/components/select-popover/select-popover.md.css +117 -22
- package/dist/collection/components/skeleton-text/skeleton-text.css +6 -0
- package/dist/collection/components/skeleton-text/skeleton-text.js +9 -5
- package/dist/collection/components/spinner/{spinner.css → spinner.ionic.css} +78 -10
- package/dist/collection/components/spinner/spinner.js +47 -6
- package/dist/collection/components/spinner/spinner.native.css +199 -0
- package/dist/collection/components/split-pane/split-pane.ios.css +20 -2
- package/dist/collection/components/split-pane/split-pane.js +15 -8
- package/dist/collection/components/split-pane/split-pane.md.css +20 -2
- package/dist/collection/components/tab/tab.js +6 -2
- package/dist/collection/components/tab-bar/tab-bar.ionic.css +227 -0
- package/dist/collection/components/tab-bar/tab-bar.ios.css +71 -43
- package/dist/collection/components/tab-bar/tab-bar.js +171 -13
- package/dist/collection/components/tab-bar/tab-bar.md.css +71 -43
- package/dist/collection/components/tab-button/tab-button.ionic.css +348 -0
- package/dist/collection/components/tab-button/tab-button.ios.css +171 -95
- package/dist/collection/components/tab-button/tab-button.js +54 -9
- package/dist/collection/components/tab-button/tab-button.md.css +137 -93
- package/dist/collection/components/tabs/tabs.css +7 -1
- package/dist/collection/components/tabs/tabs.js +4 -1
- package/dist/collection/components/text/text.css +6 -0
- package/dist/collection/components/text/text.js +7 -6
- package/dist/collection/components/textarea/textarea.ionic.css +898 -0
- package/dist/collection/components/textarea/textarea.ios.css +298 -158
- package/dist/collection/components/textarea/textarea.js +162 -24
- package/dist/collection/components/textarea/textarea.md.css +312 -159
- package/dist/collection/components/thumbnail/thumbnail.css +6 -0
- package/dist/collection/components/thumbnail/thumbnail.js +9 -2
- package/dist/collection/components/title/title.ionic.css +127 -0
- package/dist/collection/components/title/title.ios.css +32 -4
- package/dist/collection/components/title/title.js +13 -7
- package/dist/collection/components/title/title.md.css +32 -4
- package/dist/collection/components/toast/animations/utils.js +1 -1
- package/dist/collection/components/toast/toast.ionic.css +394 -0
- package/dist/collection/components/toast/toast.ios.css +84 -45
- package/dist/collection/components/toast/toast.js +76 -13
- package/dist/collection/components/toast/toast.md.css +84 -45
- package/dist/collection/components/toggle/toggle.ionic.css +508 -0
- package/dist/collection/components/toggle/toggle.ios.css +247 -131
- package/dist/collection/components/toggle/toggle.js +73 -18
- package/dist/collection/components/toggle/toggle.md.css +244 -131
- package/dist/collection/components/toolbar/test/image.svg +1 -0
- package/dist/collection/components/toolbar/toolbar.ionic.css +249 -0
- package/dist/collection/components/toolbar/toolbar.ios.css +90 -47
- package/dist/collection/components/toolbar/toolbar.js +218 -13
- package/dist/collection/components/toolbar/toolbar.md.css +90 -47
- package/dist/collection/global/ionic-global.js +241 -13
- package/dist/collection/utils/css-value-validation.js +25 -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 +46 -0
- package/dist/collection/utils/overlays.js +91 -6
- package/dist/collection/utils/sanitization/index.js +58 -6
- package/dist/collection/utils/select-option-render.js +106 -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 +8891 -283
- package/dist/esm/{animation-CnGMT4ji.js → animation-Cd1EA2ar.js} +2 -2
- package/dist/esm/{app-globals-DhZjtldk.js → app-globals-9x_U7ofY.js} +1 -1
- package/dist/esm/{button-active-BBx21brx.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-TO1rZH52.js → config-DLfuRiEz.js} +60 -8
- package/dist/esm/{data-B9iGR5YO.js → data-BNKYavC3.js} +6 -6
- package/dist/esm/{focus-visible-BmVRXR1y.js → focus-visible-vXpMhGrs.js} +23 -1
- package/dist/esm/{framework-delegate-CyxE1S_P.js → framework-delegate-CjVwn_KZ.js} +4 -2
- package/dist/esm/{haptic-DzAMWJuk.js → haptic-CbnKC3go.js} +1 -1
- package/dist/esm/{helpers-Tl8jw6S2.js → helpers-Do7zwvM1.js} +58 -5
- package/dist/esm/{index-B-hkiOUh.js → index-B2VWavcK.js} +4 -4
- package/dist/esm/{index-B2KwgBLx.js → index-BWMvrRiE.js} +11 -11
- package/dist/esm/{index-hW6eNZ3o.js → index-BmkLokUL.js} +2 -2
- package/dist/esm/{index-DV3sJJW8.js → index-D2tu5BUg.js} +2 -1
- package/dist/esm/{index-BtUdxPjv.js → index-D3WueHpT.js} +4 -3
- package/dist/esm/{index-IGIE5vDm.js → index-Omi_TcwW.js} +41 -4
- package/dist/esm/index.js +13 -14
- package/dist/esm/{input-shims-DbrgeeNb.js → input-shims-DU23z7Hg.js} +7 -6
- package/dist/esm/{input.utils-Bxa_DQ7-.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 +40 -22
- package/dist/esm/ion-alert.entry.js +76 -40
- package/dist/esm/ion-app_8.entry.js +292 -157
- package/dist/esm/ion-avatar_3.entry.js +125 -13
- package/dist/esm/ion-back-button.entry.js +31 -22
- package/dist/esm/ion-backdrop.entry.js +10 -7
- package/dist/esm/ion-breadcrumb_2.entry.js +54 -18
- package/dist/esm/ion-button_2.entry.js +59 -22
- package/dist/esm/ion-card_5.entry.js +55 -33
- package/dist/esm/ion-checkbox.entry.js +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_3.entry.js +116 -41
- package/dist/esm/ion-divider.entry.js +49 -0
- package/dist/esm/ion-fab_3.entry.js +44 -28
- package/dist/esm/ion-gallery.entry.js +508 -0
- package/dist/esm/ion-img.entry.js +8 -4
- package/dist/esm/ion-infinite-scroll_2.entry.js +91 -16
- package/dist/esm/ion-input-otp.entry.js +74 -9
- package/dist/esm/ion-input-password-toggle.entry.js +53 -15
- package/dist/esm/ion-input.entry.js +124 -34
- package/dist/esm/ion-item-option_3.entry.js +467 -52
- package/dist/esm/ion-item_8.entry.js +115 -49
- package/dist/esm/ion-loading.entry.js +20 -18
- package/dist/esm/ion-menu_3.entry.js +47 -29
- package/dist/esm/ion-modal.entry.js +215 -91
- package/dist/esm/ion-nav_2.entry.js +14 -11
- package/dist/esm/ion-picker-column-option.entry.js +12 -8
- package/dist/esm/ion-picker-column.entry.js +13 -13
- package/dist/esm/ion-picker.entry.js +10 -6
- package/dist/esm/ion-popover.entry.js +21 -19
- package/dist/esm/ion-progress-bar.entry.js +27 -9
- package/dist/esm/ion-radio_2.entry.js +35 -17
- package/dist/esm/ion-range.entry.js +20 -13
- package/dist/esm/ion-refresher_2.entry.js +39 -21
- package/dist/esm/ion-reorder_2.entry.js +38 -14
- package/dist/esm/ion-ripple-effect.entry.js +15 -7
- package/dist/esm/ion-route_4.entry.js +10 -9
- package/dist/esm/ion-searchbar.entry.js +137 -24
- package/dist/esm/ion-segment-content.entry.js +2 -2
- package/dist/esm/ion-segment-view.entry.js +13 -3
- package/dist/esm/ion-segment_2.entry.js +23 -16
- package/dist/esm/ion-select-modal.entry.js +119 -40
- package/dist/esm/ion-select_3.entry.js +500 -84
- 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 +44 -21
- package/dist/esm/ion-toggle.entry.js +82 -25
- package/dist/esm/ionic-global--9mOmThr.js +508 -0
- package/dist/esm/ionic.js +5 -5
- package/dist/esm/{ios.transition--aMF-pDH.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-BEVbfm8j.js → md.transition-DZydrWwq.js} +6 -5
- package/dist/esm/{notch-controller-DAcvKU57.js → notch-controller-klgNWpjJ.js} +2 -2
- package/dist/esm/overlay-control-label-PzmQ86nh.js +48 -0
- package/dist/esm/{overlays-F8GHPo-e.js → overlays-CpQ6Df2g.js} +107 -13
- package/dist/esm/select-option-render-y_4XoEqH.js +109 -0
- package/dist/esm/{status-tap-BfJqFSLF.js → status-tap-fYFdZg6z.js} +4 -3
- package/dist/esm/{swipe-back-BZBFwTQV.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 +2570 -105
- 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-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-2aa7567e.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-3f1dbb47.entry.js +4 -0
- package/dist/ionic/p-40d9e029.entry.js +4 -0
- package/dist/ionic/p-410d60c5.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-7e6112fc.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/dist/ionic/{p-DjriolRs.js → 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/{components/p-BS1TtEiJ.js → dist/ionic/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-CLHjFE18.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-D1t981Ih.js +4 -0
- package/dist/ionic/p-D2tu5BUg.js +4 -0
- package/dist/ionic/p-DDFhx1YX.js +4 -0
- package/dist/ionic/{p-B8xlpH8p.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-Omi_TcwW.js +5 -0
- package/dist/ionic/p-PoSbs6oh.js +4 -0
- package/dist/ionic/p-PzmQ86nh.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-ad4d0138.entry.js +4 -0
- package/dist/ionic/p-b4ba0050.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-bc317965.entry.js +4 -0
- package/dist/ionic/p-bsfLvRbd.js +4 -0
- package/dist/ionic/p-c21a780d.entry.js +4 -0
- package/dist/ionic/p-c5118189.entry.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-eTI_FbQJ.js +4 -0
- package/dist/ionic/p-f72200cc.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-fd519e2b.entry.js +4 -0
- package/dist/ionic/p-ff09d2a5.entry.js +4 -0
- package/dist/ionic/p-u6HLvq0g.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 +183 -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 +31 -5
- package/dist/types/components/input-otp/input-otp.d.ts +37 -0
- package/dist/types/components/input-password-toggle/input-password-toggle.d.ts +2 -0
- package/dist/types/components/item/item.d.ts +11 -4
- package/dist/types/components/item-divider/item-divider.d.ts +2 -1
- package/dist/types/components/item-group/item-group.d.ts +4 -0
- package/dist/types/components/item-option/item-option.d.ts +18 -1
- package/dist/types/components/item-options/item-options.d.ts +4 -0
- package/dist/types/components/item-sliding/item-sliding.d.ts +47 -1
- package/dist/types/components/item-sliding/test/test.utils.d.ts +13 -0
- package/dist/types/components/label/label.d.ts +2 -1
- package/dist/types/components/list/list.d.ts +15 -1
- package/dist/types/components/list-header/list-header.d.ts +2 -1
- package/dist/types/components/loading/loading-interface.d.ts +2 -7
- package/dist/types/components/loading/loading.d.ts +3 -2
- package/dist/types/components/menu/menu.d.ts +3 -0
- package/dist/types/components/menu-button/menu-button.d.ts +3 -1
- package/dist/types/components/menu-toggle/menu-toggle.d.ts +3 -0
- package/dist/types/components/modal/animations/ionic.enter.d.ts +6 -0
- package/dist/types/components/modal/animations/ionic.leave.d.ts +6 -0
- package/dist/types/components/modal/gestures/sheet.d.ts +1 -1
- package/dist/types/components/modal/modal-interface.d.ts +4 -7
- package/dist/types/components/modal/modal.d.ts +11 -1
- package/dist/types/components/nav/nav-interface.d.ts +9 -1
- package/dist/types/components/nav/nav.d.ts +5 -1
- package/dist/types/components/nav-link/nav-link.d.ts +4 -0
- package/dist/types/components/note/note.d.ts +2 -1
- package/dist/types/components/picker/picker.d.ts +2 -1
- package/dist/types/components/picker-column/picker-column.d.ts +2 -1
- package/dist/types/components/picker-column-option/picker-column-option.d.ts +4 -0
- package/dist/types/components/picker-legacy/picker.d.ts +2 -1
- package/dist/types/components/popover/popover-interface.d.ts +3 -6
- package/dist/types/components/popover/popover.d.ts +6 -5
- package/dist/types/components/progress-bar/progress-bar.d.ts +10 -1
- package/dist/types/components/radio/radio.d.ts +2 -1
- package/dist/types/components/radio-group/radio-group.d.ts +12 -0
- package/dist/types/components/range/range.d.ts +2 -1
- package/dist/types/components/refresher/refresher.d.ts +2 -1
- package/dist/types/components/refresher-content/refresher-content.d.ts +4 -0
- package/dist/types/components/reorder/reorder.d.ts +9 -0
- package/dist/types/components/reorder-group/reorder-group.d.ts +4 -0
- package/dist/types/components/ripple-effect/ripple-effect.d.ts +4 -0
- package/dist/types/components/route/route.d.ts +4 -0
- package/dist/types/components/router/router.d.ts +4 -0
- package/dist/types/components/router-link/router-link.d.ts +4 -0
- package/dist/types/components/router-outlet/router-outlet.d.ts +4 -1
- package/dist/types/components/row/row.d.ts +4 -0
- package/dist/types/components/searchbar/searchbar.d.ts +51 -9
- package/dist/types/components/segment/segment.d.ts +2 -1
- package/dist/types/components/segment-button/segment-button.d.ts +2 -1
- package/dist/types/components/select/select-interface.d.ts +31 -0
- package/dist/types/components/select/select.d.ts +66 -13
- package/dist/types/components/select-modal/select-modal.d.ts +8 -0
- package/dist/types/components/select-option/select-option.d.ts +44 -0
- package/dist/types/components/select-popover/select-popover.d.ts +3 -0
- package/dist/types/components/skeleton-text/skeleton-text.d.ts +4 -0
- package/dist/types/components/spinner/spinner.d.ts +15 -0
- package/dist/types/components/split-pane/split-pane.d.ts +4 -0
- package/dist/types/components/tab/tab.d.ts +4 -0
- package/dist/types/components/tab-bar/tab-bar.d.ts +37 -2
- package/dist/types/components/tab-button/tab-button.d.ts +12 -1
- package/dist/types/components/tabs/tabs.d.ts +3 -0
- package/dist/types/components/text/text.d.ts +2 -1
- package/dist/types/components/textarea/textarea.d.ts +53 -4
- package/dist/types/components/thumbnail/thumbnail.d.ts +4 -0
- package/dist/types/components/title/title.d.ts +4 -0
- package/dist/types/components/toast/animations/utils.d.ts +2 -2
- package/dist/types/components/toast/toast-interface.d.ts +3 -7
- package/dist/types/components/toast/toast.d.ts +19 -2
- package/dist/types/components/toggle/toggle.d.ts +15 -1
- package/dist/types/components/toolbar/toolbar.d.ts +43 -3
- package/dist/types/components.d.ts +1819 -205
- package/dist/types/global/ionic-global.d.ts +28 -2
- package/dist/types/interface.d.ts +3 -0
- package/dist/types/utils/config.d.ts +106 -2
- package/dist/types/utils/css-value-validation.d.ts +12 -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 +1 -1
- package/dist/types/utils/sanitization/index.d.ts +32 -2
- package/dist/types/utils/select-option-render.d.ts +22 -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 +5211 -1182
- package/hydrate/index.mjs +5211 -1182
- package/package.json +8 -4
- package/components/p-B6FQ0cKR.js +0 -4
- package/components/p-B6HaBl3o.js +0 -4
- package/components/p-B8b1Ukl9.js +0 -4
- package/components/p-BJoMtgfR.js +0 -4
- package/components/p-BNAG-aVv.js +0 -4
- package/components/p-BR3tZJmu.js +0 -4
- package/components/p-BSB38Tek.js +0 -4
- package/components/p-BTeL5HCK.js +0 -4
- package/components/p-BUbsoBOV.js +0 -4
- package/components/p-BYDc3hSE.js +0 -4
- package/components/p-BagjAGC0.js +0 -4
- package/components/p-BegtE7nr.js +0 -4
- package/components/p-BgwEQWW6.js +0 -4
- package/components/p-BmVRXR1y.js +0 -4
- package/components/p-BxwWvu-b.js +0 -4
- package/components/p-C4jPsTQa.js +0 -4
- package/components/p-C59ryAuS.js +0 -4
- package/components/p-CBzELu-H.js +0 -4
- package/components/p-CDfQnFrd.js +0 -4
- package/components/p-CIGNaXM1.js +0 -4
- package/components/p-CO7fmmxt.js +0 -4
- package/components/p-Cf6Z1pmL.js +0 -4
- package/components/p-CgfaEEem.js +0 -4
- package/components/p-CgqKJg96.js +0 -4
- package/components/p-CneGxKsZ.js +0 -4
- package/components/p-CoA-aqGF.js +0 -4
- package/components/p-Cq8cQ0NL.js +0 -4
- package/components/p-Csw8xuz4.js +0 -4
- package/components/p-CtWGkNnJ.js +0 -4
- package/components/p-Cy5XSfIk.js +0 -4
- package/components/p-Cyxa_4PV.js +0 -4
- package/components/p-Cz5nLPGT.js +0 -4
- package/components/p-D-cP12ZN.js +0 -4
- package/components/p-D6NJwNJN.js +0 -4
- package/components/p-D6Ynv7Xh.js +0 -4
- package/components/p-DHsZWn1l.js +0 -4
- package/components/p-DJMZehmW.js +0 -4
- package/components/p-DJztqcrH.js +0 -4
- package/components/p-DYdpXONG.js +0 -4
- package/components/p-DZhbcvo5.js +0 -4
- package/components/p-DgbT0exM.js +0 -4
- package/components/p-DiVJyqlX.js +0 -4
- package/components/p-DlgpdeOi.js +0 -4
- package/components/p-DvOO1fxp.js +0 -4
- package/components/p-FBcnjE5W.js +0 -4
- package/components/p-Q1-Xy3As.js +0 -4
- package/components/p-SBseW5KJ.js +0 -4
- package/components/p-ZjP4CjeZ.js +0 -4
- package/components/p-ZuZOauwD.js +0 -4
- package/components/p-ak_d-z48.js +0 -4
- package/components/p-fpbh6w3f.js +0 -4
- package/components/p-kvaDs24J.js +0 -4
- package/components/p-vEbVo2hO.js +0 -4
- package/dist/cjs/hardware-back-button-C4rMJ5uI.js +0 -121
- package/dist/cjs/index-DkNv4J_i.js +0 -10
- package/dist/cjs/ionic-global-Bc3kJi1Z.js +0 -151
- package/dist/cjs/validity-BpS37YFM.js +0 -19
- package/dist/esm/hardware-back-button-CTe4XmL7.js +0 -115
- package/dist/esm/index-ZjP4CjeZ.js +0 -7
- package/dist/esm/ionic-global-DfbeLwcV.js +0 -146
- package/dist/esm/validity-DJztqcrH.js +0 -17
- package/dist/ionic/p-031b76f7.entry.js +0 -4
- package/dist/ionic/p-045a6a42.entry.js +0 -4
- package/dist/ionic/p-07506134.entry.js +0 -4
- package/dist/ionic/p-078037da.entry.js +0 -4
- package/dist/ionic/p-084c25b2.entry.js +0 -4
- package/dist/ionic/p-0d8b5c38.entry.js +0 -4
- package/dist/ionic/p-16813ce7.entry.js +0 -4
- package/dist/ionic/p-1b169fb6.entry.js +0 -4
- package/dist/ionic/p-1ca9c36b.entry.js +0 -4
- package/dist/ionic/p-23ec35e4.entry.js +0 -4
- package/dist/ionic/p-23fac490.entry.js +0 -4
- package/dist/ionic/p-28a9e720.entry.js +0 -4
- package/dist/ionic/p-294f4bb5.entry.js +0 -4
- package/dist/ionic/p-2a68388b.entry.js +0 -4
- package/dist/ionic/p-2f5a8140.entry.js +0 -4
- package/dist/ionic/p-2fd110aa.entry.js +0 -4
- package/dist/ionic/p-301c43f8.entry.js +0 -4
- package/dist/ionic/p-370a60ee.entry.js +0 -4
- package/dist/ionic/p-53f750a5.entry.js +0 -4
- package/dist/ionic/p-6888a88b.entry.js +0 -4
- package/dist/ionic/p-6af16209.entry.js +0 -4
- package/dist/ionic/p-6b701daa.entry.js +0 -4
- package/dist/ionic/p-6b97f2a3.entry.js +0 -4
- package/dist/ionic/p-7620be24.entry.js +0 -4
- package/dist/ionic/p-771b27a5.entry.js +0 -4
- package/dist/ionic/p-7761ef65.entry.js +0 -4
- package/dist/ionic/p-7ca71c83.entry.js +0 -4
- package/dist/ionic/p-80cac7a2.entry.js +0 -4
- package/dist/ionic/p-87125490.entry.js +0 -4
- package/dist/ionic/p-8fda6a62.entry.js +0 -4
- package/dist/ionic/p-9833cf63.entry.js +0 -4
- package/dist/ionic/p-9cbc6f1f.entry.js +0 -4
- package/dist/ionic/p-9eeaBrnk.js +0 -4
- package/dist/ionic/p-BAt5H1ac.js +0 -4
- package/dist/ionic/p-BW_TRJm8.js +0 -4
- package/dist/ionic/p-BmVRXR1y.js +0 -4
- package/dist/ionic/p-Bum7H1fw.js +0 -4
- package/dist/ionic/p-C0JvVFMv.js +0 -4
- package/dist/ionic/p-CGmVTdWh.js +0 -4
- package/dist/ionic/p-CIGNaXM1.js +0 -4
- package/dist/ionic/p-CYbRmDdy.js +0 -4
- package/dist/ionic/p-CmFz1Mjc.js +0 -4
- package/dist/ionic/p-CtA-yJYy.js +0 -4
- package/dist/ionic/p-CtWGkNnJ.js +0 -4
- package/dist/ionic/p-D8HJQ1qq.js +0 -4
- package/dist/ionic/p-DB_iPQC-.js +0 -4
- package/dist/ionic/p-DJztqcrH.js +0 -4
- package/dist/ionic/p-DLbbmF9h.js +0 -4
- package/dist/ionic/p-DTPR1Wpn.js +0 -4
- package/dist/ionic/p-DV3sJJW8.js +0 -4
- package/dist/ionic/p-DcSNwXfb.js +0 -4
- package/dist/ionic/p-DiVJyqlX.js +0 -4
- package/dist/ionic/p-DtVZDHlS.js +0 -4
- package/dist/ionic/p-IGIE5vDm.js +0 -5
- package/dist/ionic/p-NFFyoJ4Q.js +0 -4
- package/dist/ionic/p-ZjP4CjeZ.js +0 -4
- package/dist/ionic/p-a805674e.entry.js +0 -4
- package/dist/ionic/p-a84f2d21.entry.js +0 -4
- package/dist/ionic/p-a893c61c.entry.js +0 -4
- package/dist/ionic/p-aa812c4b.entry.js +0 -4
- package/dist/ionic/p-b325a113.entry.js +0 -4
- package/dist/ionic/p-b6e0ff03.entry.js +0 -4
- package/dist/ionic/p-bcaa827e.entry.js +0 -4
- package/dist/ionic/p-c3cce9d8.entry.js +0 -4
- package/dist/ionic/p-ca31010f.entry.js +0 -4
- package/dist/ionic/p-cf8757a7.entry.js +0 -4
- package/dist/ionic/p-d4e8b473.entry.js +0 -4
- package/dist/ionic/p-e663bc5a.entry.js +0 -4
- package/dist/ionic/p-e6cedcd7.entry.js +0 -4
- package/dist/ionic/p-e863ffe8.entry.js +0 -4
- package/dist/ionic/p-f2deaceb.entry.js +0 -4
- package/dist/ionic/p-f3e7b155.entry.js +0 -4
- package/dist/ionic/p-f5dfb9a3.entry.js +0 -4
- package/dist/ionic/p-f69a5f71.entry.js +0 -4
- package/dist/ionic/p-f8186550.entry.js +0 -4
- package/dist/ionic/p-fdbc90d4.entry.js +0 -4
- package/dist/ionic/p-gbVXD275.js +0 -4
- package/dist/ionic/p-hNN3VvaC.js +0 -4
- /package/dist/collection/components/{input-password-toggle/input-password-toggle.css → refresher-content/refresher-content.css} +0 -0
|
@@ -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";
|
|
@@ -319,6 +319,86 @@ const connectListeners = (doc) => {
|
|
|
319
319
|
doc.addEventListener('focus', (ev) => {
|
|
320
320
|
trapKeyboardFocus(ev, doc);
|
|
321
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);
|
|
322
402
|
// handle back-button click
|
|
323
403
|
doc.addEventListener('ionBackButton', (ev) => {
|
|
324
404
|
const lastOverlay = getPresentedOverlay(doc);
|
|
@@ -432,7 +512,7 @@ export const setRootAriaHidden = (hidden = false) => {
|
|
|
432
512
|
viewContainer.removeAttribute('aria-hidden');
|
|
433
513
|
}
|
|
434
514
|
};
|
|
435
|
-
export const present = async (overlay, name, iosEnterAnimation, mdEnterAnimation, opts) => {
|
|
515
|
+
export const present = async (overlay, name, iosEnterAnimation, mdEnterAnimation, ionicEnterAnimation, opts) => {
|
|
436
516
|
var _a, _b;
|
|
437
517
|
if (overlay.presented) {
|
|
438
518
|
return;
|
|
@@ -480,11 +560,15 @@ export const present = async (overlay, name, iosEnterAnimation, mdEnterAnimation
|
|
|
480
560
|
document.body.classList.add(BACKDROP_NO_SCROLL);
|
|
481
561
|
}
|
|
482
562
|
(_a = overlay.willPresentShorthand) === null || _a === void 0 ? void 0 : _a.emit();
|
|
563
|
+
const theme = getIonTheme(overlay);
|
|
483
564
|
const mode = getIonMode(overlay);
|
|
565
|
+
const selectedAnimation = mode === 'ios'
|
|
566
|
+
? iosEnterAnimation
|
|
567
|
+
: theme === 'ionic' && ionicEnterAnimation
|
|
568
|
+
? ionicEnterAnimation
|
|
569
|
+
: mdEnterAnimation;
|
|
484
570
|
// get the user's animation fn if one was provided
|
|
485
|
-
const animationBuilder = overlay.enterAnimation
|
|
486
|
-
? overlay.enterAnimation
|
|
487
|
-
: config.get(name, mode === 'ios' ? iosEnterAnimation : mdEnterAnimation);
|
|
571
|
+
const animationBuilder = overlay.enterAnimation ? overlay.enterAnimation : config.get(name, selectedAnimation);
|
|
488
572
|
const completed = await overlayAnimation(overlay, animationBuilder, overlay.el, opts);
|
|
489
573
|
if (completed) {
|
|
490
574
|
overlay.didPresent.emit();
|
|
@@ -639,7 +723,8 @@ export const dismiss = async (overlay, data, role, name, iosLeaveAnimation, mdLe
|
|
|
639
723
|
return true;
|
|
640
724
|
};
|
|
641
725
|
const getAppRoot = (doc) => {
|
|
642
|
-
|
|
726
|
+
const appRootSelector = config.get('appRootSelector', 'ion-app');
|
|
727
|
+
return doc.querySelector(appRootSelector) || doc.body;
|
|
643
728
|
};
|
|
644
729
|
const overlayAnimation = async (overlay, animationBuilder, baseEl, opts) => {
|
|
645
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 strict `allowedAttributes` list, and scrubs
|
|
10
|
+
* `javascript:` URLs. Returns the sanitized HTML string.
|
|
11
|
+
*
|
|
12
|
+
* Use this when you have an HTML string from an unknown source and need
|
|
13
|
+
* to render it via `innerHTML`. Prefer `sanitizeDOMTree` when the source
|
|
14
|
+
* is author-controlled DOM that must keep its component attributes
|
|
15
|
+
* (`size`, `color`, `shape`, etc.).
|
|
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,13 +94,40 @@ export const sanitizeDOMString = (untrustedString) => {
|
|
|
80
94
|
return '';
|
|
81
95
|
}
|
|
82
96
|
};
|
|
97
|
+
/**
|
|
98
|
+
* Sanitize an entire author-controlled DOM tree in place.
|
|
99
|
+
*
|
|
100
|
+
* Removes blocked tags (`script`, `iframe`, etc.) from the subtree and
|
|
101
|
+
* then sanitizes attributes on every remaining element. Author-written
|
|
102
|
+
* attributes like `size`, `color`, and `shape` are preserved; event
|
|
103
|
+
* handlers (`on*`) and `javascript:` URLs are stripped.
|
|
104
|
+
*
|
|
105
|
+
* Use this when you have a DOM tree that the developer authored (e.g.
|
|
106
|
+
* cloned slot content from a component) and you need to render it
|
|
107
|
+
* elsewhere safely.
|
|
108
|
+
*
|
|
109
|
+
* @param root - The root element whose subtree will be sanitized in
|
|
110
|
+
* place. No-op when the sanitizer is disabled via `Ionic.config`.
|
|
111
|
+
*/
|
|
112
|
+
export const sanitizeDOMTree = (root) => {
|
|
113
|
+
if (!isSanitizerEnabled()) {
|
|
114
|
+
return;
|
|
115
|
+
}
|
|
116
|
+
blockedTags.forEach((tag) => {
|
|
117
|
+
const matches = root.querySelectorAll(tag);
|
|
118
|
+
for (let i = matches.length - 1; i >= 0; i--) {
|
|
119
|
+
matches[i].remove();
|
|
120
|
+
}
|
|
121
|
+
});
|
|
122
|
+
sanitizeElement(root, true);
|
|
123
|
+
};
|
|
83
124
|
/**
|
|
84
125
|
* Clean up current element based on allowed attributes
|
|
85
126
|
* and then recursively dig down into any child elements to
|
|
86
127
|
* clean those up as well
|
|
87
128
|
*/
|
|
88
129
|
// TODO(FW-2832): type (using Element triggers other type errors as well)
|
|
89
|
-
const sanitizeElement = (element) => {
|
|
130
|
+
const sanitizeElement = (element, allowSafeAuthorAttributes = false) => {
|
|
90
131
|
// IE uses childNodes, so ignore nodes that are not elements
|
|
91
132
|
if (element.nodeType && element.nodeType !== 1) {
|
|
92
133
|
return;
|
|
@@ -104,8 +145,15 @@ const sanitizeElement = (element) => {
|
|
|
104
145
|
for (let i = element.attributes.length - 1; i >= 0; i--) {
|
|
105
146
|
const attribute = element.attributes.item(i);
|
|
106
147
|
const attributeName = attribute.name;
|
|
148
|
+
const lowerName = attributeName.toLowerCase();
|
|
107
149
|
// remove non-allowed attribs
|
|
108
|
-
if (!allowedAttributes.includes(
|
|
150
|
+
if (!allowSafeAuthorAttributes && !allowedAttributes.includes(lowerName)) {
|
|
151
|
+
element.removeAttribute(attributeName);
|
|
152
|
+
continue;
|
|
153
|
+
}
|
|
154
|
+
// strip event-handler attributes (already removed by the allowlist
|
|
155
|
+
// when !allowSafeAuthorAttributes; this guards the permissive path)
|
|
156
|
+
if (lowerName.startsWith('on')) {
|
|
109
157
|
element.removeAttribute(attributeName);
|
|
110
158
|
continue;
|
|
111
159
|
}
|
|
@@ -118,9 +166,13 @@ const sanitizeElement = (element) => {
|
|
|
118
166
|
* such as 	 and still be valid (i.e. java	script)
|
|
119
167
|
*/
|
|
120
168
|
const propertyValue = element[attributeName];
|
|
169
|
+
// Only call .toLowerCase() when propertyValue is a string. Some DOM
|
|
170
|
+
// properties (e.g. `disabled`) are booleans and would throw.
|
|
121
171
|
/* eslint-disable */
|
|
122
172
|
if ((attributeValue != null && attributeValue.toLowerCase().includes('javascript:')) ||
|
|
123
|
-
(propertyValue != null &&
|
|
173
|
+
(propertyValue != null &&
|
|
174
|
+
typeof propertyValue === 'string' &&
|
|
175
|
+
propertyValue.toLowerCase().includes('javascript:'))) {
|
|
124
176
|
element.removeAttribute(attributeName);
|
|
125
177
|
}
|
|
126
178
|
/* eslint-enable */
|
|
@@ -131,7 +183,7 @@ const sanitizeElement = (element) => {
|
|
|
131
183
|
const childElements = getElementChildren(element);
|
|
132
184
|
/* eslint-disable-next-line */
|
|
133
185
|
for (let i = 0; i < childElements.length; i++) {
|
|
134
|
-
sanitizeElement(childElements[i]);
|
|
186
|
+
sanitizeElement(childElements[i], allowSafeAuthorAttributes);
|
|
135
187
|
}
|
|
136
188
|
};
|
|
137
189
|
/**
|
|
@@ -0,0 +1,106 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* (C) Ionic http://ionicframework.com - MIT License
|
|
3
|
+
*/
|
|
4
|
+
import { h } from "@stencil/core";
|
|
5
|
+
/**
|
|
6
|
+
* Converts a DOM node into a Stencil VNode (or text string) so the
|
|
7
|
+
* resulting tree is rendered through the component's normal render
|
|
8
|
+
* path. Rendering through Stencil ensures that scoped CSS classes
|
|
9
|
+
* (e.g. `sc-ion-action-sheet-ionic`) are applied to every element.
|
|
10
|
+
*
|
|
11
|
+
* Highly recommended to pre-sanitize the source DOM (see
|
|
12
|
+
* `getOptionContent` in select.tsx). This function performs pure
|
|
13
|
+
* structural conversion — no security filtering.
|
|
14
|
+
*
|
|
15
|
+
* Preserves attributes only — properties set imperatively on the source
|
|
16
|
+
* element (e.g. `input.value` after a user types) won't carry through.
|
|
17
|
+
* In practice this isn't a concern: interactive controls shouldn't
|
|
18
|
+
* appear in select-option rich content since they'd nest inside the
|
|
19
|
+
* overlay's button/radio/checkbox wrapper, which is invalid HTML and
|
|
20
|
+
* an accessibility issue.
|
|
21
|
+
*
|
|
22
|
+
* @param node - The DOM node to convert. Text nodes become strings,
|
|
23
|
+
* element nodes become VNodes, and any other node types are skipped.
|
|
24
|
+
* @param keyPrefix - String prefix used to build a stable VNode key,
|
|
25
|
+
* so Stencil's diff can preserve elements across re-renders.
|
|
26
|
+
* @param index - Position of this node among its siblings. Combined
|
|
27
|
+
* with `keyPrefix` to form the final unique key.
|
|
28
|
+
* @returns The converted VNode, a text string, or `null` if the node
|
|
29
|
+
* type isn't supported.
|
|
30
|
+
*/
|
|
31
|
+
const cloneToVNode = (node, keyPrefix, index) => {
|
|
32
|
+
var _a;
|
|
33
|
+
if (node.nodeType === Node.TEXT_NODE) {
|
|
34
|
+
return (_a = node.textContent) !== null && _a !== void 0 ? _a : '';
|
|
35
|
+
}
|
|
36
|
+
if (node.nodeType !== Node.ELEMENT_NODE) {
|
|
37
|
+
return null;
|
|
38
|
+
}
|
|
39
|
+
const el = node;
|
|
40
|
+
const tag = el.tagName.toLowerCase();
|
|
41
|
+
const key = `${keyPrefix}-${index}`;
|
|
42
|
+
const attrs = { key };
|
|
43
|
+
for (let i = 0; i < el.attributes.length; i++) {
|
|
44
|
+
const attr = el.attributes.item(i);
|
|
45
|
+
attrs[attr.name] = attr.value;
|
|
46
|
+
}
|
|
47
|
+
const children = Array.from(el.childNodes)
|
|
48
|
+
.map((child, i) => cloneToVNode(child, key, i))
|
|
49
|
+
.filter((c) => c !== null);
|
|
50
|
+
return h(tag, attrs, children);
|
|
51
|
+
};
|
|
52
|
+
/**
|
|
53
|
+
* Renders cloned DOM content as Stencil JSX. Walking the source DOM
|
|
54
|
+
* into VNodes (rather than injecting it via innerHTML) keeps the
|
|
55
|
+
* content inside Stencil's render path, so scoped CSS classes are
|
|
56
|
+
* applied automatically and component attributes like `size` or
|
|
57
|
+
* `color` survive intact.
|
|
58
|
+
*
|
|
59
|
+
* Span elements should be used when this content renders within buttons,
|
|
60
|
+
* depending on the select interface. Buttons can only have phrasing
|
|
61
|
+
* content to prevent accessibility issues.
|
|
62
|
+
*
|
|
63
|
+
* @param id - Unique identifier for generating stable virtual DOM keys.
|
|
64
|
+
* @param content - The HTMLElement container whose child nodes will be cloned.
|
|
65
|
+
* @param className - CSS class applied to the wrapper element.
|
|
66
|
+
* @param useSpan - Whether to use a span element instead of a div for the wrapper.
|
|
67
|
+
*/
|
|
68
|
+
const renderClonedContent = (id, content, className, useSpan = false) => {
|
|
69
|
+
const Tag = useSpan ? 'span' : 'div';
|
|
70
|
+
const keyPrefix = `${className}-${id}`;
|
|
71
|
+
return (h(Tag, { class: className, key: keyPrefix }, Array.from(content.childNodes).map((child, i) => cloneToVNode(child, keyPrefix, i))));
|
|
72
|
+
};
|
|
73
|
+
/**
|
|
74
|
+
* Renders the label content for a select option within an overlay
|
|
75
|
+
* interface based on the presence of rich content.
|
|
76
|
+
*
|
|
77
|
+
* Span elements should be used when this content renders within buttons,
|
|
78
|
+
* depending on the select interface. Buttons can only have phrasing
|
|
79
|
+
* content to prevent accessibility issues.
|
|
80
|
+
*
|
|
81
|
+
* @param option - The content option data containing label, slots,
|
|
82
|
+
* and description.
|
|
83
|
+
* @param className - The base CSS class for the label element.
|
|
84
|
+
* @param useSpan - Whether to use a span element instead of a div for the label.
|
|
85
|
+
*/
|
|
86
|
+
export const renderOptionLabel = (option, className, useSpan = false) => {
|
|
87
|
+
const { id, label, startContent, endContent, description } = option;
|
|
88
|
+
const hasRichContent = !!startContent || !!endContent || !!description;
|
|
89
|
+
const Tag = useSpan ? 'span' : 'div';
|
|
90
|
+
// Render simple string label if there is no rich content to display
|
|
91
|
+
if (!hasRichContent && (typeof label === 'string' || !label)) {
|
|
92
|
+
return (h(Tag, { class: className, key: `${className}-${id}` }, label));
|
|
93
|
+
}
|
|
94
|
+
// Render the main label
|
|
95
|
+
const labelEl = typeof label === 'string' || !label ? (
|
|
96
|
+
// Label is a simple string or undefined
|
|
97
|
+
h(Tag, { key: `${className}-label-${id}` }, label)) : (
|
|
98
|
+
// Label is an HTMLElement with potential rich content
|
|
99
|
+
renderClonedContent(id, label, `${className}-text`, useSpan));
|
|
100
|
+
// No rich content, render just the label
|
|
101
|
+
if (!hasRichContent) {
|
|
102
|
+
return (h(Tag, { class: className, key: `${className}-${id}` }, labelEl));
|
|
103
|
+
}
|
|
104
|
+
// Render label with rich content (start, end, description)
|
|
105
|
+
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)));
|
|
106
|
+
};
|
|
@@ -8,7 +8,19 @@
|
|
|
8
8
|
*
|
|
9
9
|
* See https://playwright.dev/docs/api/class-mouse#mouse-move for more information.
|
|
10
10
|
*/
|
|
11
|
-
|
|
11
|
+
/**
|
|
12
|
+
* Drags an element by the given number of pixels on the X and Y axes.
|
|
13
|
+
*
|
|
14
|
+
* @param el The element to drag.
|
|
15
|
+
* @param page The E2E Page object.
|
|
16
|
+
* @param dragByX The number of pixels to drag on the X axis. Negative values drag left, positive values drag right.
|
|
17
|
+
* @param dragByY The number of pixels to drag on the Y axis. Negative values drag up, positive values drag down.
|
|
18
|
+
* @param startXCoord The X coordinate to start the drag from. Defaults to the center of the element.
|
|
19
|
+
* @param startYCoord The Y coordinate to start the drag from. Defaults to the center of the element.
|
|
20
|
+
* @param releaseDrag Whether to release the drag at the end of the gesture. Defaults to `true`.
|
|
21
|
+
* @param steps The number of steps to divide the drag into. More steps reduce velocity; fewer steps increase it. Use this to control whether velocity-based thresholds (e.g. full-swipe) are triggered, particularly in Safari where gesture velocity is calculated relative to animation frames. Defaults to `10`.
|
|
22
|
+
*/
|
|
23
|
+
export const dragElementBy = async (el, page, dragByX = 0, dragByY = 0, startXCoord, startYCoord, releaseDrag = true, steps) => {
|
|
12
24
|
const boundingBox = await el.boundingBox();
|
|
13
25
|
if (!boundingBox) {
|
|
14
26
|
throw new Error('Cannot get a bounding box for an element that is not visible. See https://playwright.dev/docs/api/class-locator#locator-bounding-box for more information');
|
|
@@ -19,17 +31,18 @@ export const dragElementBy = async (el, page, dragByX = 0, dragByY = 0, startXCo
|
|
|
19
31
|
await page.mouse.move(startX, startY);
|
|
20
32
|
await page.mouse.down();
|
|
21
33
|
// Drag the element.
|
|
22
|
-
await moveElement(page, startX, startY, dragByX, dragByY);
|
|
34
|
+
await moveElement(page, startX, startY, dragByX, dragByY, steps);
|
|
23
35
|
if (releaseDrag) {
|
|
24
36
|
await page.mouse.up();
|
|
25
37
|
}
|
|
26
38
|
};
|
|
27
39
|
/**
|
|
28
40
|
* Drags an element by the given amount of pixels on the Y axis.
|
|
41
|
+
*
|
|
29
42
|
* @param el The element to drag.
|
|
30
43
|
* @param page The E2E Page object.
|
|
31
|
-
* @param dragByY The
|
|
32
|
-
* @param startYCoord The Y coordinate to start the drag
|
|
44
|
+
* @param dragByY The number of pixels to drag on the Y axis.
|
|
45
|
+
* @param startYCoord The Y coordinate to start the drag from. Defaults to the center of the element.
|
|
33
46
|
*/
|
|
34
47
|
export const dragElementByYAxis = async (el, page, dragByY, startYCoord) => {
|
|
35
48
|
const boundingBox = await el.boundingBox();
|
|
@@ -71,8 +84,7 @@ const validateDragByY = (startY, dragByY, viewportHeight) => {
|
|
|
71
84
|
throw new Error(`The element is being dragged past the top of the viewport. Update the dragByY value to prevent going out of bounds. A recommended value is ${recommendedDragByY}.`);
|
|
72
85
|
}
|
|
73
86
|
};
|
|
74
|
-
const moveElement = async (page, startX, startY, dragByX = 0, dragByY = 0) => {
|
|
75
|
-
const steps = 10;
|
|
87
|
+
const moveElement = async (page, startX, startY, dragByX = 0, dragByY = 0, steps = 10) => {
|
|
76
88
|
const browser = page.context().browser().browserType().name();
|
|
77
89
|
const viewport = page.viewportSize();
|
|
78
90
|
if (viewport === null) {
|
|
@@ -87,10 +99,21 @@ const moveElement = async (page, startX, startY, dragByX = 0, dragByY = 0) => {
|
|
|
87
99
|
const middleX = startX + (endX - startX) * (i / steps);
|
|
88
100
|
const middleY = startY + (endY - startY) * (i / steps);
|
|
89
101
|
await page.mouse.move(middleX, middleY);
|
|
90
|
-
|
|
102
|
+
/**
|
|
103
|
+
* In Safari, gesture velocity is calculated relative to animation
|
|
104
|
+
* frames, causing velocity to accumulate faster than in other
|
|
105
|
+
* browsers. Without waiting for a repaint, consecutive `mouse.move`
|
|
106
|
+
* events arrive with ~0ms time delta and velocity never accumulates,
|
|
107
|
+
* causing gesture
|
|
108
|
+
* detection to fail.
|
|
109
|
+
*/
|
|
91
110
|
if (browser === 'webkit' && i % 2 === 0) {
|
|
92
|
-
|
|
93
|
-
|
|
111
|
+
/**
|
|
112
|
+
* Repainting every 2 steps is enough to keep the drag gesture
|
|
113
|
+
* smooth. Repainting on every step makes the test slow, and
|
|
114
|
+
* repainting every 4+ steps means Safari does not see enough
|
|
115
|
+
* frames to track the gesture reliably.
|
|
116
|
+
*/
|
|
94
117
|
await page.evaluate(() => new Promise(requestAnimationFrame));
|
|
95
118
|
}
|
|
96
119
|
}
|
|
@@ -8,34 +8,56 @@
|
|
|
8
8
|
* each test title is unique.
|
|
9
9
|
*/
|
|
10
10
|
const generateTitle = (title, config) => {
|
|
11
|
-
const {
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
11
|
+
const { direction, palette, mode, theme } = config;
|
|
12
|
+
/**
|
|
13
|
+
* The iOS theme can only be used with the iOS mode,
|
|
14
|
+
* and the MD theme can only be used with the MD mode.
|
|
15
|
+
*
|
|
16
|
+
* This logic enables the fallback behavior for existing tests,
|
|
17
|
+
* where we only tested against a mode, which accounted for both
|
|
18
|
+
* the theme and mode.
|
|
19
|
+
*/
|
|
20
|
+
if (theme === 'ios' || theme === 'md') {
|
|
21
|
+
if (palette === 'light') {
|
|
22
|
+
/**
|
|
23
|
+
* Ionic has many existing tests that existed prior to
|
|
24
|
+
* the introduction of theme testing. To maintain backwards
|
|
25
|
+
* compatibility, we will not include the theme in the test
|
|
26
|
+
* title if the theme is set to light.
|
|
27
|
+
*/
|
|
28
|
+
return `${title} - ${mode}/${direction}`;
|
|
29
|
+
}
|
|
30
|
+
return `${title} - ${mode}/${direction}/${palette}`;
|
|
20
31
|
}
|
|
21
|
-
return `${title} - ${mode}/${direction}/${palette}`;
|
|
32
|
+
return `${title} - ${theme}/${mode}/${direction}/${palette}`;
|
|
22
33
|
};
|
|
23
34
|
/**
|
|
24
35
|
* Generates a unique filename based on a base filename
|
|
25
36
|
* and a test config.
|
|
26
37
|
*/
|
|
27
38
|
const generateScreenshotName = (fileName, config) => {
|
|
28
|
-
const {
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
39
|
+
const { direction, palette, mode, theme } = config;
|
|
40
|
+
/**
|
|
41
|
+
* The iOS theme can only be used with the iOS mode,
|
|
42
|
+
* and the MD theme can only be used with the MD mode.
|
|
43
|
+
*
|
|
44
|
+
* This logic enables the fallback behavior for existing tests,
|
|
45
|
+
* where we only tested against a mode, which accounted for both
|
|
46
|
+
* the theme and mode.
|
|
47
|
+
*/
|
|
48
|
+
if (theme === 'ios' || theme === 'md') {
|
|
49
|
+
if (palette === 'light') {
|
|
50
|
+
/**
|
|
51
|
+
* Ionic has many existing tests that existed prior to
|
|
52
|
+
* the introduction of theme testing. To maintain backwards
|
|
53
|
+
* compatibility, we will not include the theme in the screenshot
|
|
54
|
+
* name if the theme is set to light.
|
|
55
|
+
*/
|
|
56
|
+
return `${fileName}-${mode}-${direction}.png`;
|
|
57
|
+
}
|
|
58
|
+
return `${fileName}-${mode}-${direction}-${palette}.png`;
|
|
37
59
|
}
|
|
38
|
-
return `${fileName}-${mode}-${direction}-${palette}.png`;
|
|
60
|
+
return `${fileName}-${theme}-${mode}-${direction}-${palette}.png`;
|
|
39
61
|
};
|
|
40
62
|
/**
|
|
41
63
|
* Given a config generate an array of test variants.
|
|
@@ -48,13 +70,16 @@ export const configs = (testConfig = DEFAULT_TEST_CONFIG_OPTION) => {
|
|
|
48
70
|
* If certain options are not provided,
|
|
49
71
|
* fall back to the defaults.
|
|
50
72
|
*/
|
|
51
|
-
const
|
|
73
|
+
const processedModes = modes !== null && modes !== void 0 ? modes : DEFAULT_MODES;
|
|
52
74
|
const processedDirection = directions !== null && directions !== void 0 ? directions : DEFAULT_DIRECTIONS;
|
|
53
75
|
const processedPalette = (_a = testConfig.palettes) !== null && _a !== void 0 ? _a : DEFAULT_PALETTES;
|
|
54
|
-
|
|
76
|
+
processedModes.forEach((mode) => {
|
|
77
|
+
const [themeOrCombinedMode, modeName] = mode.split('-');
|
|
78
|
+
const parsedTheme = themeOrCombinedMode;
|
|
79
|
+
const parsedMode = modeName !== null && modeName !== void 0 ? modeName : themeOrCombinedMode;
|
|
55
80
|
processedDirection.forEach((direction) => {
|
|
56
81
|
processedPalette.forEach((palette) => {
|
|
57
|
-
configs.push({
|
|
82
|
+
configs.push({ direction, palette, mode: parsedMode, theme: parsedTheme });
|
|
58
83
|
});
|
|
59
84
|
});
|
|
60
85
|
});
|
|
@@ -9,7 +9,7 @@
|
|
|
9
9
|
* to be hydrated before proceeding with the test.
|
|
10
10
|
*/
|
|
11
11
|
export const goto = async (page, url, testInfo, originalFn, options) => {
|
|
12
|
-
var _a, _b, _c, _d;
|
|
12
|
+
var _a, _b, _c, _d, _e;
|
|
13
13
|
if (options === undefined && testInfo.project.metadata.mode === undefined) {
|
|
14
14
|
throw new Error(`
|
|
15
15
|
A config must be passed to page.goto to use a generator test:
|
|
@@ -21,15 +21,18 @@ configs().forEach(({ config, title }) => {
|
|
|
21
21
|
});`);
|
|
22
22
|
}
|
|
23
23
|
let mode;
|
|
24
|
+
let theme;
|
|
24
25
|
let direction;
|
|
25
26
|
let palette;
|
|
26
27
|
if (options == undefined) {
|
|
27
28
|
mode = testInfo.project.metadata.mode;
|
|
29
|
+
theme = testInfo.project.metadata.theme;
|
|
28
30
|
direction = testInfo.project.metadata.rtl ? 'rtl' : 'ltr';
|
|
29
31
|
palette = testInfo.project.metadata.palette;
|
|
30
32
|
}
|
|
31
33
|
else {
|
|
32
34
|
mode = options.mode;
|
|
35
|
+
theme = options.theme;
|
|
33
36
|
direction = options.direction;
|
|
34
37
|
palette = options.palette;
|
|
35
38
|
}
|
|
@@ -42,13 +45,15 @@ configs().forEach(({ config, title }) => {
|
|
|
42
45
|
*/
|
|
43
46
|
const urlToParams = new URLSearchParams(paramsString);
|
|
44
47
|
const formattedMode = (_a = urlToParams.get('ionic:mode')) !== null && _a !== void 0 ? _a : mode;
|
|
45
|
-
const
|
|
46
|
-
const
|
|
47
|
-
const
|
|
48
|
+
const formattedTheme = (_b = urlToParams.get('ionic:theme')) !== null && _b !== void 0 ? _b : theme;
|
|
49
|
+
const formattedRtl = (_c = urlToParams.get('rtl')) !== null && _c !== void 0 ? _c : rtlString;
|
|
50
|
+
const formattedPalette = (_d = urlToParams.get('palette')) !== null && _d !== void 0 ? _d : palette;
|
|
51
|
+
const ionicTesting = (_e = urlToParams.get('ionic:_testing')) !== null && _e !== void 0 ? _e : true;
|
|
48
52
|
/**
|
|
49
53
|
* Pass through other custom query params
|
|
50
54
|
*/
|
|
51
55
|
urlToParams.delete('ionic:mode');
|
|
56
|
+
urlToParams.delete('ionic:theme');
|
|
52
57
|
urlToParams.delete('rtl');
|
|
53
58
|
urlToParams.delete('palette');
|
|
54
59
|
urlToParams.delete('ionic:_testing');
|
|
@@ -59,11 +64,15 @@ configs().forEach(({ config, title }) => {
|
|
|
59
64
|
*/
|
|
60
65
|
const remainingQueryParams = decodeURIComponent(urlToParams.toString());
|
|
61
66
|
const remainingQueryParamsString = remainingQueryParams == '' ? '' : `&${remainingQueryParams}`;
|
|
62
|
-
const formattedUrl = `${splitUrl[0]}?ionic:_testing=${ionicTesting}&ionic:mode=${formattedMode}&rtl=${formattedRtl}&palette=${formattedPalette}${remainingQueryParamsString}`;
|
|
67
|
+
const formattedUrl = `${splitUrl[0]}?ionic:_testing=${ionicTesting}&ionic:mode=${formattedMode}&ionic:theme=${formattedTheme}&rtl=${formattedRtl}&palette=${formattedPalette}${remainingQueryParamsString}`;
|
|
63
68
|
testInfo.annotations.push({
|
|
64
69
|
type: 'mode',
|
|
65
70
|
description: formattedMode,
|
|
66
71
|
});
|
|
72
|
+
testInfo.annotations.push({
|
|
73
|
+
type: 'theme',
|
|
74
|
+
description: formattedTheme,
|
|
75
|
+
});
|
|
67
76
|
testInfo.annotations.push({
|
|
68
77
|
type: 'direction',
|
|
69
78
|
description: formattedRtl === 'true' ? 'rtl' : 'ltr',
|
|
@@ -18,29 +18,43 @@ export const setContent = async (page, html, testInfo, options) => {
|
|
|
18
18
|
}
|
|
19
19
|
let mode;
|
|
20
20
|
let direction;
|
|
21
|
+
let theme;
|
|
21
22
|
let palette;
|
|
22
23
|
if (options == undefined) {
|
|
23
24
|
mode = testInfo.project.metadata.mode;
|
|
24
25
|
direction = testInfo.project.metadata.rtl ? 'rtl' : 'ltr';
|
|
26
|
+
theme = testInfo.project.metadata.theme;
|
|
25
27
|
palette = testInfo.project.metadata.palette;
|
|
26
28
|
}
|
|
27
29
|
else {
|
|
28
30
|
mode = options.mode;
|
|
29
31
|
direction = options.direction;
|
|
32
|
+
theme = options.theme;
|
|
30
33
|
palette = options.palette;
|
|
31
34
|
}
|
|
32
35
|
const baseUrl = process.env.PLAYWRIGHT_TEST_BASE_URL;
|
|
33
36
|
// The Ionic bundle is included locally by default unless the test
|
|
34
37
|
// config passes in the importIonicFromCDN option. This is useful
|
|
35
38
|
// when testing with the CDN version of Ionic.
|
|
36
|
-
let ionicCSSImports =
|
|
39
|
+
let ionicCSSImports = theme === 'ionic'
|
|
40
|
+
? `
|
|
41
|
+
<link href="${baseUrl}/css/ionic/bundle.ionic.css" rel="stylesheet" />
|
|
42
|
+
<link href="${baseUrl}/css/utils.bundle.css" rel="stylesheet" />
|
|
43
|
+
`
|
|
44
|
+
: `
|
|
37
45
|
<link href="${baseUrl}/css/ionic.bundle.css" rel="stylesheet" />
|
|
38
46
|
`;
|
|
39
47
|
let ionicJSImports = `
|
|
40
48
|
<script type="module" src="${baseUrl}/dist/ionic/ionic.esm.js"></script>
|
|
41
49
|
`;
|
|
42
50
|
if (options === null || options === void 0 ? void 0 : options.importIonicFromCDN) {
|
|
43
|
-
ionicCSSImports =
|
|
51
|
+
ionicCSSImports =
|
|
52
|
+
theme === 'ionic'
|
|
53
|
+
? `
|
|
54
|
+
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@ionic/core/css/ionic/bundle.ionic.css" />
|
|
55
|
+
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@ionic/core/css/utils.bundle.css" />
|
|
56
|
+
`
|
|
57
|
+
: `
|
|
44
58
|
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@ionic/core/css/ionic.bundle.css" />
|
|
45
59
|
`;
|
|
46
60
|
ionicJSImports = `
|
|
@@ -63,7 +77,8 @@ export const setContent = async (page, html, testInfo, options) => {
|
|
|
63
77
|
<script>
|
|
64
78
|
window.Ionic = {
|
|
65
79
|
config: {
|
|
66
|
-
mode: '${mode}'
|
|
80
|
+
mode: '${mode}',
|
|
81
|
+
theme: '${theme}'
|
|
67
82
|
}
|
|
68
83
|
}
|
|
69
84
|
</script>
|
|
@@ -73,10 +88,18 @@ export const setContent = async (page, html, testInfo, options) => {
|
|
|
73
88
|
</body>
|
|
74
89
|
</html>
|
|
75
90
|
`;
|
|
91
|
+
testInfo.annotations.push({
|
|
92
|
+
type: 'mode',
|
|
93
|
+
description: mode,
|
|
94
|
+
});
|
|
76
95
|
testInfo.annotations.push({
|
|
77
96
|
type: 'palette',
|
|
78
97
|
description: palette,
|
|
79
98
|
});
|
|
99
|
+
testInfo.annotations.push({
|
|
100
|
+
type: 'theme',
|
|
101
|
+
description: theme,
|
|
102
|
+
});
|
|
80
103
|
if (baseUrl) {
|
|
81
104
|
await page.route(baseUrl, (route) => {
|
|
82
105
|
if (route.request().url() === `${baseUrl}/`) {
|