@ionic/core 8.8.9-dev.11780414486.1df2bd72 → 8.8.9-dev.11780493937.17fe092d
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/index.js +1 -1
- package/components/ion-accordion-group.js +1 -1
- package/components/ion-accordion.js +1 -1
- package/components/ion-action-sheet.js +1 -1
- package/components/ion-alert.js +1 -1
- package/components/ion-app.js +1 -1
- package/components/ion-avatar.js +1 -1
- package/components/ion-back-button.js +1 -1
- package/components/ion-backdrop.js +1 -1
- package/components/ion-badge.js +1 -1
- package/components/ion-breadcrumb.js +1 -1
- package/components/ion-breadcrumbs.js +1 -1
- package/components/ion-button.js +1 -1
- package/components/ion-buttons.js +1 -1
- package/components/ion-card-content.js +1 -1
- package/components/ion-card-header.js +1 -1
- package/components/ion-card-subtitle.js +1 -1
- package/components/ion-card-title.js +1 -1
- package/components/ion-card.js +1 -1
- package/components/ion-checkbox.js +1 -1
- package/components/ion-chip.js +1 -1
- package/components/ion-col.js +1 -1
- package/components/ion-content.js +1 -1
- package/components/ion-datetime-button.js +1 -1
- package/components/ion-datetime.js +1 -1
- package/components/ion-divider.d.ts +11 -0
- package/components/ion-divider.js +4 -0
- package/components/ion-fab-button.js +1 -1
- package/components/ion-fab-list.js +1 -1
- package/components/ion-fab.js +1 -1
- package/components/ion-footer.js +1 -1
- package/components/ion-gallery.d.ts +11 -0
- package/components/ion-gallery.js +4 -0
- package/components/ion-grid.js +1 -1
- package/components/ion-header.js +1 -1
- package/components/ion-icon.js +1 -1
- package/components/ion-img.js +1 -1
- package/components/ion-infinite-scroll-content.js +1 -1
- package/components/ion-infinite-scroll.js +1 -1
- package/components/ion-input-otp.js +1 -1
- package/components/ion-input-password-toggle.js +1 -1
- package/components/ion-input.js +1 -1
- package/components/ion-item-divider.js +1 -1
- package/components/ion-item-group.js +1 -1
- package/components/ion-item-option.js +1 -1
- package/components/ion-item-options.js +1 -1
- package/components/ion-item-sliding.js +1 -1
- package/components/ion-item.js +1 -1
- package/components/ion-label.js +1 -1
- package/components/ion-list-header.js +1 -1
- package/components/ion-list.js +1 -1
- package/components/ion-loading.js +1 -1
- package/components/ion-menu-button.js +1 -1
- package/components/ion-menu-toggle.js +1 -1
- package/components/ion-menu.js +1 -1
- package/components/ion-modal.js +1 -1
- package/components/ion-nav-link.js +1 -1
- package/components/ion-nav.js +1 -1
- package/components/ion-note.js +1 -1
- package/components/ion-picker-column-option.js +1 -1
- package/components/ion-picker-column.js +1 -1
- package/components/ion-picker-legacy-column.d.ts +11 -0
- package/components/ion-picker-legacy-column.js +4 -0
- package/components/ion-picker-legacy.d.ts +11 -0
- package/components/ion-picker-legacy.js +4 -0
- package/components/ion-picker.js +1 -1
- package/components/ion-popover.js +1 -1
- package/components/ion-progress-bar.js +1 -1
- package/components/ion-radio-group.js +1 -1
- package/components/ion-radio.js +1 -1
- package/components/ion-range.js +1 -1
- package/components/ion-refresher-content.js +1 -1
- package/components/ion-refresher.js +1 -1
- package/components/ion-reorder-group.js +1 -1
- package/components/ion-reorder.js +1 -1
- package/components/ion-ripple-effect.js +1 -1
- package/components/ion-route-redirect.js +1 -1
- package/components/ion-route.js +1 -1
- package/components/ion-router-link.js +1 -1
- package/components/ion-router-outlet.js +1 -1
- package/components/ion-router.js +1 -1
- package/components/ion-row.js +1 -1
- package/components/ion-searchbar.js +1 -1
- package/components/ion-segment-button.js +1 -1
- package/components/ion-segment-content.js +1 -1
- package/components/ion-segment-view.js +1 -1
- package/components/ion-segment.js +1 -1
- package/components/ion-select-modal.js +1 -1
- package/components/ion-select-option.js +1 -1
- package/components/ion-select-popover.js +1 -1
- package/components/ion-select.js +1 -1
- package/components/ion-skeleton-text.js +1 -1
- package/components/ion-spinner.js +1 -1
- package/components/ion-split-pane.js +1 -1
- package/components/ion-tab-bar.js +1 -1
- package/components/ion-tab-button.js +1 -1
- package/components/ion-tab.js +1 -1
- package/components/ion-tabs.js +1 -1
- package/components/ion-text.js +1 -1
- package/components/ion-textarea.js +1 -1
- package/components/ion-thumbnail.js +1 -1
- package/components/ion-title.js +1 -1
- package/components/ion-toast.js +1 -1
- package/components/ion-toggle.js +1 -1
- package/components/ion-toolbar.js +1 -1
- package/components/p-3Ni1Z654.js +4 -0
- package/components/p-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-BF5oFX1I.js +4 -0
- package/components/p-BJzJdLry.js +4 -0
- package/components/p-BYSs-jZz.js +4 -0
- package/components/p-BZCB7f49.js +4 -0
- package/components/p-BaPtaYEC.js +4 -0
- package/components/{p-Sh0ICmPV.js → p-BcbmT6b3.js} +1 -1
- package/components/p-Bg30AtDZ.js +4 -0
- package/components/p-BhkGOA7t.js +4 -0
- package/components/p-BjW8SOqw.js +4 -0
- package/components/p-Bk9hTY4h.js +4 -0
- package/components/p-BqDiJgC_.js +4 -0
- package/components/p-BsNpz2u3.js +4 -0
- package/components/p-Bt0d89x3.js +4 -0
- package/components/p-BwKpO3Is.js +4 -0
- package/components/p-BwQOIWD7.js +4 -0
- package/components/{p-D5Ubpm7D.js → p-ByW0kK1F.js} +1 -1
- package/components/p-C0U8YqYW.js +4 -0
- package/components/p-C75FIZBC.js +4 -0
- package/components/p-C8kBejTT.js +4 -0
- package/components/p-CBS0sBAa.js +4 -0
- package/{dist/ionic/p-VAemlbDS.js → components/p-CDgDBcU9.js} +1 -1
- package/components/p-CPm7KgOP.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/{dist/ionic/p-DzWaWHGc.js → components/p-Cmql_g3_.js} +1 -1
- package/components/p-CpFORZud.js +4 -0
- 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-DAXhdEp5.js +4 -0
- package/components/p-DCS3n7Uq.js +4 -0
- package/components/p-DDw-NYxz.js +4 -0
- package/components/p-DN_scBC7.js +4 -0
- package/components/p-DVcs-2q3.js +4 -0
- package/components/{p-DNQI6d-L.js → p-DXehWlOr.js} +1 -1
- package/components/p-DaJxRxSQ.js +4 -0
- package/components/p-Dhi5xtNS.js +4 -0
- package/components/p-Do7NMUwR.js +4 -0
- package/components/p-Dp2x0MpA.js +4 -0
- package/components/p-GElQZ38c.js +4 -0
- package/components/p-GtzfsjJP.js +4 -0
- package/components/p-IYdTEyGb.js +4 -0
- package/components/p-Skz67GXZ.js +4 -0
- package/components/p-XegQjlzJ.js +4 -0
- package/components/p-d77Zk1DK.js +4 -0
- package/components/p-fIOYmaqA.js +4 -0
- package/components/p-hdGd8ben.js +4 -0
- package/components/p-hpwmNJ2Q.js +4 -0
- package/components/p-kKYBfhbe.js +4 -0
- package/components/p-lGSe6-vg.js +4 -0
- package/components/{p-BAYYcg3o.js → p-oF-CwZ0b.js} +1 -1
- package/components/p-pvh0bjpw.js +4 -0
- package/components/{p-cyNmxje6.js → p-re70ahxF.js} +1 -1
- package/components/p-sToA4Co7.js +4 -0
- package/components/p-vXpMhGrs.js +4 -0
- package/components/{p-ijF0iCrA.js → p-wCDzv5Q8.js} +1 -1
- package/components/{p-DqLB8yFQ.js → p-zWP0sUV_.js} +1 -1
- package/css/core.css +1 -1
- package/css/core.css.map +1 -1
- package/css/display.css +1 -1
- package/css/display.css.map +1 -1
- package/css/flex-utils.css +1 -1
- package/css/flex-utils.css.map +1 -1
- package/css/float-elements.css.map +1 -1
- package/css/global.bundle.css.map +1 -1
- package/css/ionic/bundle.ionic.css +1 -0
- package/css/ionic/bundle.ionic.css.map +1 -0
- package/css/ionic/core.ionic.css +1 -0
- package/css/ionic/core.ionic.css.map +1 -0
- package/css/ionic/global.bundle.ionic.css +1 -0
- package/css/ionic/global.bundle.ionic.css.map +1 -0
- package/css/ionic/ionic-swiper.ionic.css +1 -0
- package/css/ionic/ionic-swiper.ionic.css.map +1 -0
- package/css/ionic/link.ionic.css +1 -0
- package/css/ionic/link.ionic.css.map +1 -0
- package/css/ionic/structure.ionic.css +1 -0
- package/css/ionic/structure.ionic.css.map +1 -0
- package/css/ionic/typography.ionic.css +1 -0
- package/css/ionic/typography.ionic.css.map +1 -0
- package/css/ionic/utils.bundle.ionic.css +1 -0
- package/css/ionic/utils.bundle.ionic.css.map +1 -0
- package/css/ionic-swiper.css +1 -1
- package/css/ionic-swiper.css.map +1 -1
- package/css/ionic.bundle.css +1 -1
- package/css/ionic.bundle.css.map +1 -1
- package/css/normalize.css.map +1 -1
- package/css/padding.css.map +1 -1
- package/css/palettes/dark.always.css.map +1 -1
- package/css/palettes/dark.class.css.map +1 -1
- package/css/palettes/dark.system.css.map +1 -1
- package/css/palettes/high-contrast-dark.always.css.map +1 -1
- package/css/palettes/high-contrast-dark.class.css.map +1 -1
- package/css/palettes/high-contrast-dark.system.css.map +1 -1
- package/css/palettes/high-contrast.always.css.map +1 -1
- package/css/palettes/high-contrast.class.css.map +1 -1
- package/css/palettes/high-contrast.system.css.map +1 -1
- package/css/structure.css.map +1 -1
- package/css/text-alignment.css.map +1 -1
- package/css/text-transformation.css.map +1 -1
- package/css/typography.css.map +1 -1
- package/css/utils.bundle.css +1 -1
- package/css/utils.bundle.css.map +1 -1
- package/dist/cjs/{animation-BJq0kcy2.js → animation-BZJ2wKuM.js} +3 -3
- package/dist/cjs/{app-globals-BlqrqKTN.js → app-globals-C-d5fQ35.js} +1 -1
- package/dist/cjs/{button-active-0mPOKmV2.js → button-active-B_20Nxkv.js} +2 -2
- package/dist/cjs/{capacitor-DmA66EwP.js → capacitor-CXqhdZym.js} +3 -3
- package/dist/cjs/caret-down-vtVgfXIs.js +8 -0
- package/dist/cjs/caret-left-CxZXLRv5.js +8 -0
- package/dist/cjs/caret-right-CRCgv98E.js +8 -0
- package/dist/cjs/config-DWdFbSNK.js +35 -0
- package/dist/cjs/{data-DLTUw-KF.js → data-DuOuKG7I.js} +6 -6
- package/dist/cjs/{focus-visible-CCvKiLh3.js → focus-visible-BIj-I3-C.js} +24 -0
- package/dist/cjs/{framework-delegate-BtICZDHr.js → framework-delegate-Dx9FrqAC.js} +4 -2
- package/dist/cjs/{haptic-ClPPQ_PS.js → haptic-CQJGW58i.js} +1 -1
- package/dist/cjs/{helpers-Cv23MFHM.js → helpers-DJYxKN5U.js} +57 -4
- package/dist/cjs/{config-xninhj0J.js → index-BJlwOs11.js} +1 -31
- package/dist/cjs/{index-CIrkNXqJ.js → index-BJrpF9T3.js} +2 -2
- package/dist/cjs/{index-aC4x3Fk3.js → index-BekUBS8C.js} +15 -15
- package/dist/cjs/{index-DqmRDbxg.js → index-CgAbCW6L.js} +2 -0
- package/dist/cjs/{index-D81eLYUM.js → index-CwxYd6UD.js} +9 -8
- package/dist/cjs/{index-Ct7gcRif.js → index-CzcLEdQ5.js} +64 -71
- package/dist/cjs/{index-BERfRao3.js → index-DSNlrgfO.js} +4 -4
- package/dist/cjs/index.cjs.js +17 -16
- package/dist/cjs/{input-shims-CFLg7uzj.js → input-shims-VyZciSxi.js} +18 -17
- package/dist/cjs/{input.utils-DetjmtH2.js → input.utils-Ct5KzpYv.js} +5 -5
- package/dist/cjs/ion-accordion_2.cjs.entry.js +61 -29
- package/dist/cjs/ion-action-sheet.cjs.entry.js +41 -26
- package/dist/cjs/ion-alert.cjs.entry.js +62 -45
- package/dist/cjs/ion-app_8.cjs.entry.js +568 -189
- package/dist/cjs/ion-avatar_3.cjs.entry.js +125 -13
- package/dist/cjs/ion-back-button.cjs.entry.js +31 -22
- package/dist/cjs/ion-backdrop.cjs.entry.js +10 -7
- package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +54 -18
- package/dist/cjs/ion-button_2.cjs.entry.js +59 -22
- package/dist/cjs/ion-card_5.cjs.entry.js +55 -33
- package/dist/cjs/ion-checkbox.cjs.entry.js +34 -16
- package/dist/cjs/ion-chip.cjs.entry.js +50 -9
- package/dist/cjs/ion-col_3.cjs.entry.js +56 -57
- package/dist/cjs/ion-datetime-button.cjs.entry.js +13 -9
- package/dist/cjs/{ion-datetime.cjs.entry.js → ion-datetime_3.cjs.entry.js} +742 -29
- package/dist/cjs/ion-divider.cjs.entry.js +51 -0
- package/dist/cjs/ion-fab_3.cjs.entry.js +44 -28
- package/dist/cjs/ion-gallery.cjs.entry.js +510 -0
- package/dist/cjs/ion-img.cjs.entry.js +8 -4
- package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +93 -17
- package/dist/cjs/ion-input-otp.cjs.entry.js +74 -9
- package/dist/cjs/ion-input-password-toggle.cjs.entry.js +53 -15
- package/dist/cjs/ion-input.cjs.entry.js +125 -35
- package/dist/cjs/ion-item-option_3.cjs.entry.js +467 -52
- package/dist/cjs/ion-item_8.cjs.entry.js +116 -49
- package/dist/cjs/ion-loading.cjs.entry.js +22 -23
- package/dist/cjs/ion-menu_3.cjs.entry.js +47 -29
- package/dist/cjs/ion-modal.cjs.entry.js +262 -142
- package/dist/cjs/ion-nav_2.cjs.entry.js +14 -11
- package/dist/cjs/ion-picker-column-option.cjs.entry.js +12 -8
- package/dist/cjs/ion-picker-column.cjs.entry.js +14 -14
- package/dist/cjs/ion-picker.cjs.entry.js +10 -6
- package/dist/cjs/ion-popover.cjs.entry.js +21 -23
- package/dist/cjs/ion-progress-bar.cjs.entry.js +27 -9
- package/dist/cjs/ion-radio_2.cjs.entry.js +35 -17
- package/dist/cjs/ion-range.cjs.entry.js +20 -13
- package/dist/cjs/ion-refresher_2.cjs.entry.js +42 -23
- package/dist/cjs/ion-reorder_2.cjs.entry.js +39 -15
- package/dist/cjs/ion-ripple-effect.cjs.entry.js +15 -7
- package/dist/cjs/ion-route_4.cjs.entry.js +10 -9
- package/dist/cjs/ion-searchbar.cjs.entry.js +138 -25
- package/dist/cjs/ion-segment-content.cjs.entry.js +2 -2
- package/dist/cjs/ion-segment-view.cjs.entry.js +13 -3
- package/dist/cjs/ion-segment_2.cjs.entry.js +23 -16
- package/dist/cjs/ion-select-modal.cjs.entry.js +97 -40
- package/dist/cjs/ion-select_3.cjs.entry.js +453 -115
- package/dist/cjs/ion-spinner.cjs.entry.js +30 -8
- package/dist/cjs/ion-split-pane.cjs.entry.js +13 -9
- package/dist/cjs/ion-tab-bar_2.cjs.entry.js +147 -23
- package/dist/cjs/ion-tab_2.cjs.entry.js +8 -7
- package/dist/cjs/ion-text.cjs.entry.js +7 -7
- package/dist/cjs/ion-textarea.cjs.entry.js +137 -23
- package/dist/cjs/ion-toast.cjs.entry.js +71 -47
- package/dist/cjs/ion-toggle.cjs.entry.js +84 -27
- package/dist/cjs/ionic-global-BW5tRzrz.js +519 -0
- package/dist/cjs/ionic.cjs.js +5 -5
- package/dist/cjs/{ios.transition-BOSWOaiK.js → ios.transition-CyNNpj1i.js} +7 -5
- package/dist/cjs/{keyboard-hHzlEQpk.js → keyboard-CA6RtoWx.js} +4 -3
- package/dist/cjs/{keyboard-UuAS4D_9.js → keyboard-VLGMzWBE.js} +1 -1
- package/dist/cjs/{keyboard-controller-GXBiBRKS.js → keyboard-controller-CCTvHp9l.js} +11 -9
- package/dist/cjs/list-a-7GSA6K.js +8 -0
- package/dist/cjs/loader.cjs.js +4 -4
- package/dist/cjs/{md.transition-B8-wBZqt.js → md.transition-BEfrfWKW.js} +6 -5
- package/dist/cjs/{notch-controller-18PzRGXd.js → notch-controller-BTZCPOsd.js} +4 -4
- package/dist/cjs/{overlays-DSmSrd_4.js → overlays-BuMIwR8B.js} +117 -42
- package/dist/cjs/select-option-render-C7klBX2H.js +81 -0
- package/dist/cjs/{status-tap-BXX8H8_Y.js → status-tap-CTY2dMsZ.js} +4 -3
- package/dist/cjs/{swipe-back-C0GCB18x.js → swipe-back-jJFi5KCB.js} +3 -2
- package/dist/cjs/{theme-CeDs6Hcv.js → theme-IlOsGAz7.js} +25 -1
- package/dist/cjs/validity-QmuwEptc.js +51 -0
- package/dist/cjs/x-BTF99yFH.js +8 -0
- package/dist/collection/collection-manifest.json +13 -3
- 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 +834 -0
- package/dist/collection/components/action-sheet/action-sheet.ios.css +102 -6
- package/dist/collection/components/action-sheet/action-sheet.js +33 -18
- package/dist/collection/components/action-sheet/action-sheet.md.css +101 -5
- package/dist/collection/components/alert/alert.ionic.css +1165 -0
- package/dist/collection/components/alert/alert.ios.css +102 -1
- package/dist/collection/components/alert/alert.js +52 -35
- package/dist/collection/components/alert/alert.md.css +102 -1
- 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 +64 -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 +27 -2
- package/dist/collection/components/footer/footer.js +80 -28
- package/dist/collection/components/footer/footer.md.css +25 -0
- package/dist/collection/components/footer/footer.utils.js +9 -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 +172 -0
- package/dist/collection/components/header/header.ios.css +93 -3
- package/dist/collection/components/header/header.js +87 -26
- package/dist/collection/components/header/header.md.css +91 -1
- package/dist/collection/components/header/header.utils.js +14 -5
- package/dist/collection/components/img/img.js +8 -2
- package/dist/collection/components/infinite-scroll/infinite-scroll.js +100 -5
- package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.ios.css +12 -0
- package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +16 -10
- package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.md.css +12 -0
- package/dist/collection/components/input/input.ionic.css +889 -0
- package/dist/collection/components/input/input.ios.css +223 -135
- package/dist/collection/components/input/input.js +153 -42
- package/dist/collection/components/input/input.md.css +193 -207
- package/dist/collection/components/input-otp/input-otp.ionic.css +371 -0
- package/dist/collection/components/input-otp/input-otp.ios.css +105 -60
- package/dist/collection/components/input-otp/input-otp.js +73 -6
- package/dist/collection/components/input-otp/input-otp.md.css +105 -60
- package/dist/collection/components/input-password-toggle/input-password-toggle.ionic.css +78 -0
- package/dist/collection/components/input-password-toggle/input-password-toggle.js +48 -12
- package/dist/collection/components/input-password-toggle/input-password-toggle.native.css +61 -0
- package/dist/collection/components/item/item.ionic.css +508 -0
- package/dist/collection/components/item/item.ios.css +109 -69
- package/dist/collection/components/item/item.js +51 -20
- package/dist/collection/components/item/item.md.css +120 -68
- package/dist/collection/components/item-divider/item-divider.ios.css +18 -0
- package/dist/collection/components/item-divider/item-divider.js +11 -8
- package/dist/collection/components/item-divider/item-divider.md.css +18 -0
- package/dist/collection/components/item-group/item-group.ios.css +12 -0
- package/dist/collection/components/item-group/item-group.js +13 -7
- package/dist/collection/components/item-group/item-group.md.css +12 -0
- package/dist/collection/components/item-option/item-option.ionic.css +278 -0
- package/dist/collection/components/item-option/item-option.ios.css +136 -29
- package/dist/collection/components/item-option/item-option.js +73 -9
- package/dist/collection/components/item-option/item-option.md.css +136 -29
- package/dist/collection/components/item-options/item-options.ionic.css +221 -0
- package/dist/collection/components/item-options/item-options.ios.css +77 -34
- package/dist/collection/components/item-options/item-options.js +13 -7
- package/dist/collection/components/item-options/item-options.md.css +77 -34
- package/dist/collection/components/item-sliding/item-sliding.ionic.css +211 -0
- package/dist/collection/components/item-sliding/item-sliding.js +421 -35
- package/dist/collection/components/item-sliding/{item-sliding.css → item-sliding.native.css} +84 -9
- package/dist/collection/components/item-sliding/test/test.utils.js +13 -0
- package/dist/collection/components/label/label.ios.css +18 -0
- package/dist/collection/components/label/label.js +11 -8
- package/dist/collection/components/label/label.md.css +18 -0
- package/dist/collection/components/list/list.ionic.css +212 -0
- package/dist/collection/components/list/list.ios.css +54 -14
- package/dist/collection/components/list/list.js +48 -9
- package/dist/collection/components/list/list.md.css +56 -16
- package/dist/collection/components/list-header/list-header.ionic.css +190 -0
- package/dist/collection/components/list-header/list-header.ios.css +82 -38
- package/dist/collection/components/list-header/list-header.js +11 -8
- package/dist/collection/components/list-header/list-header.md.css +82 -38
- package/dist/collection/components/loading/loading.ios.css +13 -1
- package/dist/collection/components/loading/loading.js +15 -16
- package/dist/collection/components/loading/loading.md.css +13 -1
- package/dist/collection/components/menu/menu.ios.css +15 -3
- package/dist/collection/components/menu/menu.js +12 -7
- package/dist/collection/components/menu/menu.md.css +15 -3
- package/dist/collection/components/menu-button/menu-button.ionic.css +236 -0
- package/dist/collection/components/menu-button/menu-button.ios.css +48 -14
- package/dist/collection/components/menu-button/menu-button.js +26 -10
- package/dist/collection/components/menu-button/menu-button.md.css +49 -15
- package/dist/collection/components/menu-toggle/menu-toggle.js +8 -5
- package/dist/collection/components/modal/animations/ionic.enter.js +40 -0
- package/dist/collection/components/modal/animations/ionic.leave.js +28 -0
- package/dist/collection/components/modal/animations/sheet.js +8 -2
- package/dist/collection/components/modal/gestures/sheet.js +76 -10
- package/dist/collection/components/modal/modal.ionic.css +247 -0
- package/dist/collection/components/modal/modal.ios.css +178 -70
- package/dist/collection/components/modal/modal.js +51 -17
- package/dist/collection/components/modal/modal.md.css +178 -70
- package/dist/collection/components/nav/nav.css +7 -1
- package/dist/collection/components/nav/nav.js +11 -5
- package/dist/collection/components/nav-link/nav-link.js +5 -1
- package/dist/collection/components/note/note.ios.css +12 -0
- package/dist/collection/components/note/note.js +11 -8
- package/dist/collection/components/note/note.md.css +12 -0
- package/dist/collection/components/picker/picker.ios.css +15 -3
- package/dist/collection/components/picker/picker.js +8 -5
- package/dist/collection/components/picker/picker.md.css +15 -3
- package/dist/collection/components/picker-column/picker-column.css +9 -2
- package/dist/collection/components/picker-column/picker-column.js +8 -7
- package/dist/collection/components/picker-column-option/picker-column-option.ios.css +6 -0
- package/dist/collection/components/picker-column-option/picker-column-option.js +13 -7
- package/dist/collection/components/picker-column-option/picker-column-option.md.css +6 -0
- package/dist/collection/components/picker-legacy/animations/ios.enter.js +27 -0
- package/dist/collection/components/picker-legacy/animations/ios.leave.js +23 -0
- package/dist/collection/components/picker-legacy/picker-interface.js +1 -0
- package/dist/collection/components/picker-legacy/picker.ios.css +312 -0
- package/dist/collection/components/picker-legacy/picker.js +891 -0
- package/dist/collection/components/picker-legacy/picker.md.css +299 -0
- package/dist/collection/components/picker-legacy-column/picker-column.ios.css +243 -0
- package/dist/collection/components/picker-legacy-column/picker-column.js +422 -0
- package/dist/collection/components/picker-legacy-column/picker-column.md.css +234 -0
- package/dist/collection/components/picker-legacy-column/test/test.utils.js +43 -0
- package/dist/collection/components/popover/popover.ionic.css +290 -0
- package/dist/collection/components/popover/popover.ios.css +29 -1
- package/dist/collection/components/popover/popover.js +19 -20
- package/dist/collection/components/popover/popover.md.css +29 -1
- package/dist/collection/components/progress-bar/progress-bar.ionic.css +287 -0
- package/dist/collection/components/progress-bar/progress-bar.ios.css +48 -17
- package/dist/collection/components/progress-bar/progress-bar.js +43 -7
- package/dist/collection/components/progress-bar/progress-bar.md.css +48 -17
- package/dist/collection/components/radio/radio.ionic.css +422 -0
- package/dist/collection/components/radio/radio.ios.css +134 -91
- package/dist/collection/components/radio/radio.js +15 -10
- package/dist/collection/components/radio/radio.md.css +134 -91
- package/dist/collection/components/radio-group/radio-group.ionic.css +119 -0
- package/dist/collection/components/radio-group/radio-group.ios.css +43 -19
- package/dist/collection/components/radio-group/radio-group.js +48 -7
- package/dist/collection/components/radio-group/radio-group.md.css +43 -19
- package/dist/collection/components/range/range.ionic.css +567 -0
- package/dist/collection/components/range/range.ios.css +128 -85
- package/dist/collection/components/range/range.js +16 -10
- package/dist/collection/components/range/range.md.css +128 -85
- package/dist/collection/components/refresher/refresher.ios.css +14 -1
- package/dist/collection/components/refresher/refresher.js +11 -8
- package/dist/collection/components/refresher/refresher.md.css +15 -2
- package/dist/collection/components/refresher-content/refresher-content.js +28 -7
- package/dist/collection/components/reorder/reorder.ios.css +6 -0
- package/dist/collection/components/reorder/reorder.js +33 -6
- package/dist/collection/components/reorder/reorder.md.css +6 -0
- package/dist/collection/components/reorder-group/reorder-group.css +6 -0
- package/dist/collection/components/reorder-group/reorder-group.js +8 -4
- package/dist/collection/components/ripple-effect/{ripple-effect.css → ripple-effect.common.css} +7 -1
- package/dist/collection/components/ripple-effect/ripple-effect.ionic.css +215 -0
- package/dist/collection/components/ripple-effect/ripple-effect.js +14 -6
- package/dist/collection/components/route/route.js +4 -0
- package/dist/collection/components/router/router.js +4 -0
- package/dist/collection/components/router-link/router-link.css +8 -2
- package/dist/collection/components/router-link/router-link.js +9 -5
- package/dist/collection/components/router-outlet/router-outlet.css +7 -1
- package/dist/collection/components/router-outlet/router-outlet.js +10 -40
- package/dist/collection/components/row/row.css +16 -0
- package/dist/collection/components/row/row.js +9 -2
- package/dist/collection/components/searchbar/searchbar.ionic.css +626 -0
- package/dist/collection/components/searchbar/searchbar.ios.css +56 -18
- package/dist/collection/components/searchbar/searchbar.js +185 -38
- package/dist/collection/components/searchbar/searchbar.md.css +56 -18
- package/dist/collection/components/segment/segment.ionic.css +115 -0
- package/dist/collection/components/segment/segment.ios.css +45 -2
- package/dist/collection/components/segment/segment.js +11 -8
- package/dist/collection/components/segment/segment.md.css +45 -2
- package/dist/collection/components/segment-button/segment-button.ionic.css +353 -0
- package/dist/collection/components/segment-button/segment-button.ios.css +146 -105
- package/dist/collection/components/segment-button/segment-button.js +11 -8
- package/dist/collection/components/segment-button/segment-button.md.css +148 -107
- package/dist/collection/components/segment-content/segment-content.js +1 -1
- package/dist/collection/components/segment-view/segment-view.ios.css +6 -0
- package/dist/collection/components/segment-view/segment-view.js +13 -4
- package/dist/collection/components/segment-view/segment-view.md.css +6 -0
- package/dist/collection/components/select/select.ionic.css +810 -0
- package/dist/collection/components/select/select.ios.css +348 -176
- package/dist/collection/components/select/select.js +434 -97
- package/dist/collection/components/select/select.md.css +364 -178
- package/dist/collection/components/select-modal/select-modal.ionic.css +154 -0
- package/dist/collection/components/select-modal/select-modal.ios.css +95 -0
- package/dist/collection/components/select-modal/select-modal.js +109 -32
- package/dist/collection/components/select-modal/select-modal.md.css +83 -0
- package/dist/collection/components/select-option/select-option.js +32 -2
- package/dist/collection/components/select-popover/select-popover.ionic.css +499 -0
- package/dist/collection/components/select-popover/select-popover.ios.css +100 -0
- package/dist/collection/components/select-popover/select-popover.js +72 -31
- package/dist/collection/components/select-popover/select-popover.md.css +100 -0
- package/dist/collection/components/skeleton-text/skeleton-text.css +6 -0
- package/dist/collection/components/skeleton-text/skeleton-text.js +9 -5
- package/dist/collection/components/spinner/{spinner.css → spinner.ionic.css} +78 -10
- package/dist/collection/components/spinner/spinner.js +47 -6
- package/dist/collection/components/spinner/spinner.native.css +199 -0
- package/dist/collection/components/split-pane/split-pane.ios.css +20 -2
- package/dist/collection/components/split-pane/split-pane.js +16 -9
- package/dist/collection/components/split-pane/split-pane.md.css +20 -2
- package/dist/collection/components/tab/tab.js +6 -2
- package/dist/collection/components/tab-bar/tab-bar.ionic.css +227 -0
- package/dist/collection/components/tab-bar/tab-bar.ios.css +71 -43
- package/dist/collection/components/tab-bar/tab-bar.js +171 -13
- package/dist/collection/components/tab-bar/tab-bar.md.css +71 -43
- package/dist/collection/components/tab-button/tab-button.ionic.css +348 -0
- package/dist/collection/components/tab-button/tab-button.ios.css +171 -95
- package/dist/collection/components/tab-button/tab-button.js +54 -9
- package/dist/collection/components/tab-button/tab-button.md.css +137 -93
- package/dist/collection/components/tabs/tabs.css +7 -1
- package/dist/collection/components/tabs/tabs.js +4 -1
- package/dist/collection/components/text/text.css +6 -0
- package/dist/collection/components/text/text.js +7 -6
- package/dist/collection/components/textarea/textarea.ionic.css +898 -0
- package/dist/collection/components/textarea/textarea.ios.css +298 -158
- package/dist/collection/components/textarea/textarea.js +162 -24
- package/dist/collection/components/textarea/textarea.md.css +312 -159
- package/dist/collection/components/thumbnail/thumbnail.css +6 -0
- package/dist/collection/components/thumbnail/thumbnail.js +9 -2
- package/dist/collection/components/title/title.ionic.css +127 -0
- package/dist/collection/components/title/title.ios.css +32 -4
- package/dist/collection/components/title/title.js +13 -7
- package/dist/collection/components/title/title.md.css +32 -4
- package/dist/collection/components/toast/animations/utils.js +1 -1
- package/dist/collection/components/toast/toast.ionic.css +394 -0
- package/dist/collection/components/toast/toast.ios.css +84 -45
- package/dist/collection/components/toast/toast.js +76 -13
- package/dist/collection/components/toast/toast.md.css +84 -45
- package/dist/collection/components/toggle/toggle.ionic.css +508 -0
- package/dist/collection/components/toggle/toggle.ios.css +247 -131
- package/dist/collection/components/toggle/toggle.js +73 -18
- package/dist/collection/components/toggle/toggle.md.css +244 -131
- package/dist/collection/components/toolbar/test/image.svg +1 -0
- package/dist/collection/components/toolbar/toolbar.ionic.css +249 -0
- package/dist/collection/components/toolbar/toolbar.ios.css +90 -47
- package/dist/collection/components/toolbar/toolbar.js +218 -13
- package/dist/collection/components/toolbar/toolbar.md.css +90 -47
- package/dist/collection/global/ionic-global.js +241 -13
- package/dist/collection/index.js +1 -1
- package/dist/collection/utils/css-value-validation.js +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/on-scroll/collapse-hide.utils.js +168 -0
- package/dist/collection/utils/overlays.js +97 -31
- package/dist/collection/utils/select-option-render.js +76 -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 +10163 -690
- package/dist/esm/{animation-DLJpuoEz.js → animation-Cd1EA2ar.js} +2 -2
- package/dist/esm/{app-globals-D0C5S4hU.js → app-globals-9x_U7ofY.js} +1 -1
- package/dist/esm/{button-active-BSpTQmS9.js → button-active-B016u5N-.js} +2 -2
- package/dist/esm/{capacitor-CFERIeaU.js → capacitor-13SFuT1K.js} +1 -1
- package/dist/esm/caret-down-D1t981Ih.js +6 -0
- package/dist/esm/caret-left-fIOYmaqA.js +6 -0
- package/dist/esm/caret-right-BYSs-jZz.js +6 -0
- package/dist/esm/config-BwKpO3Is.js +31 -0
- package/dist/esm/{data-DZI70dKr.js → data-BNKYavC3.js} +6 -6
- package/dist/esm/{focus-visible-BmVRXR1y.js → focus-visible-vXpMhGrs.js} +23 -1
- package/dist/esm/{framework-delegate-FnPGymXL.js → framework-delegate-CjVwn_KZ.js} +4 -2
- package/dist/esm/{haptic-DzAMWJuk.js → haptic-CbnKC3go.js} +1 -1
- package/dist/esm/{helpers-HEqiOzXb.js → helpers-Do7zwvM1.js} +58 -5
- package/dist/esm/{index-B_dQk_WE.js → index-B2VWavcK.js} +4 -4
- package/dist/esm/{index-Q6UPU0Ay.js → index-BWMvrRiE.js} +11 -11
- package/dist/esm/{index-MEDq2S8l.js → index-BmkLokUL.js} +2 -2
- package/dist/esm/{index-AlrZKoWR.js → index-D2tu5BUg.js} +2 -1
- package/dist/esm/{index-BRHzoo00.js → index-D3WueHpT.js} +4 -3
- package/dist/esm/{config-DQCONYYp.js → index-D4ugF_sT.js} +2 -29
- package/dist/esm/{index-tcQvqkiX.js → index-Omi_TcwW.js} +64 -71
- package/dist/esm/index.js +14 -14
- package/dist/esm/{input-shims-D10mwcw1.js → input-shims-DU23z7Hg.js} +7 -6
- package/dist/esm/{input.utils-Y6NgW8bw.js → input.utils-C64RbLd_.js} +3 -3
- package/dist/esm/ion-accordion_2.entry.js +61 -29
- package/dist/esm/ion-action-sheet.entry.js +41 -26
- package/dist/esm/ion-alert.entry.js +61 -44
- package/dist/esm/ion-app_8.entry.js +568 -189
- package/dist/esm/ion-avatar_3.entry.js +125 -13
- package/dist/esm/ion-back-button.entry.js +31 -22
- package/dist/esm/ion-backdrop.entry.js +10 -7
- package/dist/esm/ion-breadcrumb_2.entry.js +54 -18
- package/dist/esm/ion-button_2.entry.js +59 -22
- package/dist/esm/ion-card_5.entry.js +55 -33
- package/dist/esm/ion-checkbox.entry.js +34 -16
- package/dist/esm/ion-chip.entry.js +50 -9
- package/dist/esm/ion-col_3.entry.js +56 -57
- package/dist/esm/ion-datetime-button.entry.js +13 -9
- package/dist/esm/{ion-datetime.entry.js → ion-datetime_3.entry.js} +741 -30
- package/dist/esm/ion-divider.entry.js +49 -0
- package/dist/esm/ion-fab_3.entry.js +44 -28
- package/dist/esm/ion-gallery.entry.js +508 -0
- package/dist/esm/ion-img.entry.js +8 -4
- package/dist/esm/ion-infinite-scroll_2.entry.js +92 -16
- package/dist/esm/ion-input-otp.entry.js +74 -9
- package/dist/esm/ion-input-password-toggle.entry.js +53 -15
- package/dist/esm/ion-input.entry.js +125 -35
- package/dist/esm/ion-item-option_3.entry.js +467 -52
- package/dist/esm/ion-item_8.entry.js +116 -49
- package/dist/esm/ion-loading.entry.js +21 -22
- package/dist/esm/ion-menu_3.entry.js +47 -29
- package/dist/esm/ion-modal.entry.js +215 -95
- package/dist/esm/ion-nav_2.entry.js +14 -11
- package/dist/esm/ion-picker-column-option.entry.js +12 -8
- package/dist/esm/ion-picker-column.entry.js +13 -13
- package/dist/esm/ion-picker.entry.js +10 -6
- package/dist/esm/ion-popover.entry.js +21 -23
- package/dist/esm/ion-progress-bar.entry.js +27 -9
- package/dist/esm/ion-radio_2.entry.js +35 -17
- package/dist/esm/ion-range.entry.js +20 -13
- package/dist/esm/ion-refresher_2.entry.js +40 -21
- package/dist/esm/ion-reorder_2.entry.js +39 -15
- package/dist/esm/ion-ripple-effect.entry.js +15 -7
- package/dist/esm/ion-route_4.entry.js +10 -9
- package/dist/esm/ion-searchbar.entry.js +138 -25
- package/dist/esm/ion-segment-content.entry.js +2 -2
- package/dist/esm/ion-segment-view.entry.js +13 -3
- package/dist/esm/ion-segment_2.entry.js +23 -16
- package/dist/esm/ion-select-modal.entry.js +97 -40
- package/dist/esm/ion-select_3.entry.js +454 -116
- package/dist/esm/ion-spinner.entry.js +30 -8
- package/dist/esm/ion-split-pane.entry.js +13 -9
- package/dist/esm/ion-tab-bar_2.entry.js +147 -23
- package/dist/esm/ion-tab_2.entry.js +8 -7
- package/dist/esm/ion-text.entry.js +7 -7
- package/dist/esm/ion-textarea.entry.js +137 -23
- package/dist/esm/ion-toast.entry.js +46 -22
- package/dist/esm/ion-toggle.entry.js +84 -27
- package/dist/esm/ionic-global--9mOmThr.js +508 -0
- package/dist/esm/ionic.js +6 -6
- package/dist/esm/{ios.transition-ClFrsIrS.js → ios.transition-DoQTN5Jk.js} +7 -5
- package/dist/esm/{keyboard-ywgs5efA.js → keyboard-Ca1zVCcH.js} +4 -3
- package/dist/esm/{keyboard-CUw4ekVy.js → keyboard-Dnno7-Ci.js} +1 -1
- package/dist/esm/{keyboard-controller-BaaVITYt.js → keyboard-controller-BpOdk6xN.js} +5 -3
- package/dist/esm/list-Dhi5xtNS.js +6 -0
- package/dist/esm/loader.js +5 -5
- package/dist/esm/{md.transition-D0msQmzI.js → md.transition-DZydrWwq.js} +6 -5
- package/dist/esm/{notch-controller-DKDjU_O7.js → notch-controller-klgNWpjJ.js} +2 -2
- package/dist/esm/{overlays-DLNOHWNc.js → overlays-CpQ6Df2g.js} +114 -39
- package/dist/esm/select-option-render-B2qc5ZP7.js +79 -0
- package/dist/esm/{status-tap-Kan2W7sh.js → status-tap-fYFdZg6z.js} +4 -3
- package/dist/esm/{swipe-back-DQ1q5MgD.js → swipe-back-BzGqTrrq.js} +3 -2
- package/dist/esm/{theme-DiVJyqlX.js → theme-DaJxRxSQ.js} +25 -1
- package/dist/esm/validity-BjW8SOqw.js +48 -0
- package/dist/esm/x-BDqjX7Z_.js +6 -0
- package/dist/html.html-data.json +2660 -145
- 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-031df892.entry.js +4 -0
- package/dist/ionic/p-04b5794c.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-40d9e029.entry.js +4 -0
- package/dist/ionic/p-44d483c2.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-52ed96a8.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-7186786e.entry.js +4 -0
- package/dist/ionic/p-7194f6fa.entry.js +4 -0
- package/dist/ionic/p-76c70824.entry.js +4 -0
- package/dist/ionic/p-7f294078.entry.js +4 -0
- package/dist/ionic/p-8458f1b6.entry.js +4 -0
- package/dist/ionic/p-88048796.entry.js +4 -0
- package/dist/ionic/p-88e7f52a.entry.js +4 -0
- package/dist/ionic/p-89eab395.entry.js +4 -0
- package/dist/ionic/p-93315d96.entry.js +4 -0
- package/dist/ionic/p-9ccfb733.entry.js +4 -0
- package/dist/ionic/p-9dfbe98d.entry.js +4 -0
- package/{components/p-BT_5jSqG.js → dist/ionic/p-B2-sg7NJ.js} +1 -1
- package/dist/ionic/p-B4ikoeaj.js +4 -0
- package/dist/ionic/p-BDqjX7Z_.js +4 -0
- package/dist/ionic/p-BFBCtvFI.js +4 -0
- package/dist/ionic/p-BQgCYKKG.js +4 -0
- package/dist/ionic/p-BYAxJDlE.js +4 -0
- package/dist/ionic/p-BYSs-jZz.js +4 -0
- package/dist/ionic/p-BjW8SOqw.js +4 -0
- package/dist/ionic/{p-CKvCXMs9.js → p-BmEwy3tY.js} +1 -1
- package/dist/ionic/p-BwKpO3Is.js +4 -0
- package/dist/ionic/{p-DAAFkPFT.js → p-C8IHbcuP.js} +1 -1
- package/dist/ionic/p-CDn0uNJA.js +4 -0
- package/dist/ionic/p-CFjI63GE.js +4 -0
- package/dist/ionic/p-CHE1xWbg.js +4 -0
- package/dist/ionic/p-CK179dBb.js +4 -0
- package/dist/ionic/p-CWJdc8f_.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-Wk5HzclC.js → p-DKWXAwlR.js} +1 -1
- package/dist/ionic/p-DNGqaUsl.js +4 -0
- package/dist/ionic/p-DaJxRxSQ.js +4 -0
- package/dist/ionic/p-DaknVxZR.js +4 -0
- package/dist/ionic/p-Dhi5xtNS.js +4 -0
- package/dist/ionic/p-DoyDJ2X5.js +4 -0
- package/dist/ionic/p-E1wtzfO0.js +4 -0
- package/dist/ionic/p-FvDKM4Ax.js +4 -0
- package/dist/ionic/p-IXZW3FBt.js +4 -0
- package/dist/ionic/p-Omi_TcwW.js +5 -0
- package/dist/ionic/p-PoSbs6oh.js +4 -0
- package/dist/ionic/p-VAJ_3beW.js +4 -0
- package/dist/ionic/p-a3f9be52.entry.js +4 -0
- package/dist/ionic/p-ad4d0138.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-bf0c5a8d.entry.js +4 -0
- package/dist/ionic/p-bsfLvRbd.js +4 -0
- package/dist/ionic/p-c0558552.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-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-f08edb25.entry.js +4 -0
- package/dist/ionic/p-f167c55c.entry.js +4 -0
- package/dist/ionic/p-f7ca50a5.entry.js +4 -0
- package/dist/ionic/p-fIOYmaqA.js +4 -0
- package/dist/ionic/p-fbdbdb3e.entry.js +4 -0
- package/dist/ionic/p-ff09d2a5.entry.js +4 -0
- package/dist/ionic/p-vXpMhGrs.js +4 -0
- package/dist/types/components/accordion/accordion.d.ts +6 -3
- package/dist/types/components/accordion-group/accordion-group.d.ts +12 -1
- package/dist/types/components/action-sheet/action-sheet-interface.d.ts +3 -7
- package/dist/types/components/action-sheet/action-sheet.d.ts +3 -2
- package/dist/types/components/alert/alert-interface.d.ts +3 -7
- package/dist/types/components/alert/alert.d.ts +3 -2
- package/dist/types/components/app/app.d.ts +4 -5
- package/dist/types/components/avatar/avatar.d.ts +32 -0
- package/dist/types/components/back-button/back-button.d.ts +2 -1
- package/dist/types/components/backdrop/backdrop.d.ts +4 -0
- package/dist/types/components/badge/badge.d.ts +34 -1
- package/dist/types/components/breadcrumb/breadcrumb.d.ts +4 -1
- package/dist/types/components/breadcrumbs/breadcrumbs.d.ts +2 -2
- package/dist/types/components/button/button.d.ts +23 -8
- package/dist/types/components/buttons/buttons.d.ts +5 -1
- package/dist/types/components/card/card.d.ts +8 -1
- package/dist/types/components/card-content/card-content.d.ts +2 -1
- package/dist/types/components/card-header/card-header.d.ts +3 -2
- package/dist/types/components/card-subtitle/card-subtitle.d.ts +2 -1
- package/dist/types/components/card-title/card-title.d.ts +2 -1
- package/dist/types/components/checkbox/checkbox.d.ts +14 -4
- package/dist/types/components/chip/chip.d.ts +26 -1
- package/dist/types/components/col/col.d.ts +52 -5
- package/dist/types/components/content/content.d.ts +3 -0
- package/dist/types/components/datetime/datetime.d.ts +26 -1
- package/dist/types/components/datetime/utils/data.d.ts +5 -5
- package/dist/types/components/datetime-button/datetime-button.d.ts +2 -1
- package/dist/types/components/divider/divider.d.ts +20 -0
- package/dist/types/components/fab/fab.d.ts +4 -0
- package/dist/types/components/fab-button/fab-button.d.ts +5 -3
- package/dist/types/components/fab-list/fab-list.d.ts +4 -0
- package/dist/types/components/footer/footer.d.ts +15 -4
- package/dist/types/components/footer/footer.utils.d.ts +1 -0
- 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 +18 -5
- package/dist/types/components/header/header.utils.d.ts +4 -3
- package/dist/types/components/img/img.d.ts +3 -0
- package/dist/types/components/infinite-scroll/infinite-scroll.d.ts +21 -0
- package/dist/types/components/infinite-scroll-content/infinite-scroll-content.d.ts +4 -0
- package/dist/types/components/input/input.d.ts +32 -6
- package/dist/types/components/input-otp/input-otp.d.ts +37 -0
- package/dist/types/components/input-password-toggle/input-password-toggle.d.ts +2 -0
- package/dist/types/components/item/item.d.ts +11 -4
- package/dist/types/components/item-divider/item-divider.d.ts +2 -1
- package/dist/types/components/item-group/item-group.d.ts +4 -0
- package/dist/types/components/item-option/item-option.d.ts +18 -1
- package/dist/types/components/item-options/item-options.d.ts +4 -0
- package/dist/types/components/item-sliding/item-sliding.d.ts +47 -1
- package/dist/types/components/item-sliding/test/test.utils.d.ts +13 -0
- package/dist/types/components/label/label.d.ts +2 -1
- package/dist/types/components/list/list.d.ts +15 -1
- package/dist/types/components/list-header/list-header.d.ts +2 -1
- package/dist/types/components/loading/loading-interface.d.ts +2 -7
- package/dist/types/components/loading/loading.d.ts +3 -2
- package/dist/types/components/menu/menu.d.ts +3 -0
- package/dist/types/components/menu-button/menu-button.d.ts +3 -1
- package/dist/types/components/menu-toggle/menu-toggle.d.ts +3 -0
- package/dist/types/components/modal/animations/ionic.enter.d.ts +6 -0
- package/dist/types/components/modal/animations/ionic.leave.d.ts +6 -0
- package/dist/types/components/modal/gestures/sheet.d.ts +1 -1
- package/dist/types/components/modal/modal-interface.d.ts +4 -7
- package/dist/types/components/modal/modal.d.ts +11 -1
- package/dist/types/components/nav/nav-interface.d.ts +9 -1
- package/dist/types/components/nav/nav.d.ts +5 -1
- package/dist/types/components/nav-link/nav-link.d.ts +4 -0
- package/dist/types/components/note/note.d.ts +2 -1
- package/dist/types/components/picker/picker.d.ts +2 -1
- package/dist/types/components/picker-column/picker-column.d.ts +2 -1
- package/dist/types/components/picker-column-option/picker-column-option.d.ts +4 -0
- package/dist/types/components/picker-legacy/animations/ios.enter.d.ts +5 -0
- package/dist/types/components/picker-legacy/animations/ios.leave.d.ts +5 -0
- package/dist/types/components/picker-legacy/picker-interface.d.ts +52 -0
- package/dist/types/components/picker-legacy/picker.d.ts +159 -0
- package/dist/types/components/picker-legacy-column/picker-column.d.ts +46 -0
- package/dist/types/components/picker-legacy-column/test/test.utils.d.ts +9 -0
- package/dist/types/components/popover/popover-interface.d.ts +3 -6
- package/dist/types/components/popover/popover.d.ts +6 -5
- package/dist/types/components/progress-bar/progress-bar.d.ts +10 -1
- package/dist/types/components/radio/radio.d.ts +2 -1
- package/dist/types/components/radio-group/radio-group.d.ts +12 -0
- package/dist/types/components/range/range.d.ts +2 -1
- package/dist/types/components/refresher/refresher.d.ts +2 -1
- package/dist/types/components/refresher-content/refresher-content.d.ts +4 -0
- package/dist/types/components/reorder/reorder.d.ts +9 -0
- package/dist/types/components/reorder-group/reorder-group.d.ts +4 -0
- package/dist/types/components/ripple-effect/ripple-effect.d.ts +4 -0
- package/dist/types/components/route/route.d.ts +4 -0
- package/dist/types/components/router/router.d.ts +4 -0
- package/dist/types/components/router-link/router-link.d.ts +4 -0
- package/dist/types/components/router-outlet/router-outlet.d.ts +4 -8
- package/dist/types/components/row/row.d.ts +4 -0
- package/dist/types/components/searchbar/searchbar.d.ts +52 -10
- package/dist/types/components/segment/segment.d.ts +2 -1
- package/dist/types/components/segment-button/segment-button.d.ts +2 -1
- package/dist/types/components/select/select-interface.d.ts +23 -0
- package/dist/types/components/select/select.d.ts +66 -14
- package/dist/types/components/select-modal/select-modal.d.ts +8 -0
- package/dist/types/components/select-option/select-option.d.ts +12 -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 +2126 -267
- package/dist/types/global/ionic-global.d.ts +28 -2
- package/dist/types/index.d.ts +1 -1
- package/dist/types/interface.d.ts +4 -0
- package/dist/types/stencil-public-runtime.d.ts +1 -4
- package/dist/types/utils/config.d.ts +114 -2
- package/dist/types/utils/css-value-validation.d.ts +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/on-scroll/collapse-hide.utils.d.ts +26 -0
- package/dist/types/utils/overlays-interface.d.ts +31 -1
- package/dist/types/utils/overlays.d.ts +10 -12
- 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 +6522 -2329
- package/hydrate/index.mjs +6522 -2329
- package/package.json +12 -40
- package/components/p--JUspHvy.js +0 -4
- package/components/p-B8U2xbtx.js +0 -4
- package/components/p-B9jFTlwE.js +0 -4
- package/components/p-BTPfOxsU.js +0 -4
- package/components/p-Baq1XyAy.js +0 -4
- package/components/p-BhmadOit.js +0 -4
- package/components/p-BirPFsRD.js +0 -4
- package/components/p-BjfgFSSR.js +0 -4
- package/components/p-BmVRXR1y.js +0 -4
- package/components/p-BnqQlm7c.js +0 -4
- package/components/p-BtVHN9Na.js +0 -4
- package/components/p-Bz0dSlXZ.js +0 -4
- package/components/p-C1aScSTo.js +0 -4
- package/components/p-C4t5ymfq.js +0 -4
- package/components/p-CHqRYvYm.js +0 -4
- package/components/p-CHzfYZbv.js +0 -4
- package/components/p-CI3ncNZm.js +0 -4
- package/components/p-CIGNaXM1.js +0 -4
- package/components/p-CO7fmmxt.js +0 -4
- package/components/p-CSZf8_j0.js +0 -4
- package/components/p-C_xFdyXe.js +0 -4
- package/components/p-Ciz1-FuE.js +0 -4
- package/components/p-Ck2wcXbv.js +0 -4
- package/components/p-CmR5uXej.js +0 -4
- package/components/p-CtWGkNnJ.js +0 -4
- package/components/p-CtukzcyX.js +0 -4
- package/components/p-D6Ynv7Xh.js +0 -4
- package/components/p-D7bSXQD3.js +0 -4
- package/components/p-DEBD4LvH.js +0 -4
- package/components/p-DH50pr9O.js +0 -4
- package/components/p-DIE4pXMl.js +0 -4
- package/components/p-DJztqcrH.js +0 -4
- package/components/p-DOFCbuQR.js +0 -4
- package/components/p-DhkITZ-y.js +0 -4
- package/components/p-DiVJyqlX.js +0 -4
- package/components/p-DmpBvltk.js +0 -4
- package/components/p-DnL1c9_X.js +0 -4
- package/components/p-DpV-p5Xs.js +0 -4
- package/components/p-DqZAXv2t.js +0 -4
- package/components/p-Dz74mwlk.js +0 -4
- package/components/p-W5nO8mX_.js +0 -4
- package/components/p-XJWMAP8m.js +0 -4
- package/components/p-ZjP4CjeZ.js +0 -4
- package/components/p-djQLE88P.js +0 -4
- package/components/p-j5IxBIan.js +0 -4
- package/components/p-k_E4tX5Z.js +0 -4
- package/components/p-lE_JGpHD.js +0 -4
- package/components/p-r0aq7dpt.js +0 -4
- package/components/p-ryqmO0B-.js +0 -4
- package/components/p-wk2QqrAo.js +0 -4
- package/dist/cjs/hardware-back-button-iUuF_76h.js +0 -121
- package/dist/cjs/index-DkNv4J_i.js +0 -10
- package/dist/cjs/ionic-global-B-cA6LkY.js +0 -151
- package/dist/cjs/validity-BpS37YFM.js +0 -19
- package/dist/esm/hardware-back-button-B93Gru0Y.js +0 -115
- package/dist/esm/index-ZjP4CjeZ.js +0 -7
- package/dist/esm/ionic-global-Cp_eT4sZ.js +0 -146
- package/dist/esm/validity-DJztqcrH.js +0 -17
- package/dist/ionic/p-03aa786d.entry.js +0 -4
- package/dist/ionic/p-06c232a4.entry.js +0 -4
- package/dist/ionic/p-11684553.entry.js +0 -4
- package/dist/ionic/p-1ae21e4c.entry.js +0 -4
- package/dist/ionic/p-20b1a044.entry.js +0 -4
- package/dist/ionic/p-259d0d98.entry.js +0 -4
- package/dist/ionic/p-2a6d6565.entry.js +0 -4
- package/dist/ionic/p-341032b3.entry.js +0 -4
- package/dist/ionic/p-3e91d32e.entry.js +0 -4
- package/dist/ionic/p-441fbb13.entry.js +0 -4
- package/dist/ionic/p-4502a274.entry.js +0 -4
- package/dist/ionic/p-4621c387.entry.js +0 -4
- package/dist/ionic/p-4bb3eb60.entry.js +0 -4
- package/dist/ionic/p-4e92a11f.entry.js +0 -4
- package/dist/ionic/p-50e1194a.entry.js +0 -4
- package/dist/ionic/p-51cd1643.entry.js +0 -4
- package/dist/ionic/p-5c3ec490.entry.js +0 -4
- package/dist/ionic/p-627fabd9.entry.js +0 -4
- package/dist/ionic/p-629e4703.entry.js +0 -4
- package/dist/ionic/p-76e92a84.entry.js +0 -4
- package/dist/ionic/p-7a37b3ce.entry.js +0 -4
- package/dist/ionic/p-7aed7726.entry.js +0 -4
- package/dist/ionic/p-7ebd980c.entry.js +0 -4
- package/dist/ionic/p-80b44b3c.entry.js +0 -4
- package/dist/ionic/p-81ea5652.entry.js +0 -4
- package/dist/ionic/p-8c8eee7d.entry.js +0 -4
- package/dist/ionic/p-8d624ee5.entry.js +0 -4
- package/dist/ionic/p-8d6fd502.entry.js +0 -4
- package/dist/ionic/p-9177f4ac.entry.js +0 -4
- package/dist/ionic/p-9c6a5a8d.entry.js +0 -4
- package/dist/ionic/p-9eeaBrnk.js +0 -4
- package/dist/ionic/p-AlrZKoWR.js +0 -4
- package/dist/ionic/p-BGqMS-oh.js +0 -4
- package/dist/ionic/p-BUFIpxKM.js +0 -4
- package/dist/ionic/p-BmVRXR1y.js +0 -4
- package/dist/ionic/p-CFlfIb2g.js +0 -4
- package/dist/ionic/p-CIGNaXM1.js +0 -4
- package/dist/ionic/p-Cg5-OQYy.js +0 -4
- package/dist/ionic/p-CtWGkNnJ.js +0 -4
- package/dist/ionic/p-Cx3IXROA.js +0 -4
- package/dist/ionic/p-D4uTWt4-.js +0 -4
- package/dist/ionic/p-DC3RagnA.js +0 -4
- package/dist/ionic/p-DIuEbVLu.js +0 -4
- package/dist/ionic/p-DJztqcrH.js +0 -4
- package/dist/ionic/p-DSG2s2Eb.js +0 -4
- package/dist/ionic/p-Dfbt-q2k.js +0 -4
- package/dist/ionic/p-DiVJyqlX.js +0 -4
- package/dist/ionic/p-DoJvtrbw.js +0 -4
- package/dist/ionic/p-KjNvRoEp.js +0 -4
- package/dist/ionic/p-Nqf6uvGh.js +0 -4
- package/dist/ionic/p-SNAkTDfm.js +0 -4
- package/dist/ionic/p-ZjP4CjeZ.js +0 -4
- package/dist/ionic/p-a2e51c5d.entry.js +0 -4
- package/dist/ionic/p-a3bdcae6.entry.js +0 -4
- package/dist/ionic/p-a44b7536.entry.js +0 -4
- package/dist/ionic/p-a5213260.entry.js +0 -4
- package/dist/ionic/p-a7628bc7.entry.js +0 -4
- package/dist/ionic/p-b1599fca.entry.js +0 -4
- package/dist/ionic/p-b16be471.entry.js +0 -4
- package/dist/ionic/p-b6a7397c.entry.js +0 -4
- package/dist/ionic/p-b9ac1fe0.entry.js +0 -4
- package/dist/ionic/p-c6e49f3f.entry.js +0 -4
- package/dist/ionic/p-c93553d2.entry.js +0 -4
- package/dist/ionic/p-d2c7f046.entry.js +0 -4
- package/dist/ionic/p-d8387b99.entry.js +0 -4
- package/dist/ionic/p-d8ac9eea.entry.js +0 -4
- package/dist/ionic/p-db1b6738.entry.js +0 -4
- package/dist/ionic/p-dfa8d673.entry.js +0 -4
- package/dist/ionic/p-ed797c72.entry.js +0 -4
- package/dist/ionic/p-ef93ca92.entry.js +0 -4
- package/dist/ionic/p-f09f9642.entry.js +0 -4
- package/dist/ionic/p-f1c06f82.entry.js +0 -4
- package/dist/ionic/p-f386f6ae.entry.js +0 -4
- package/dist/ionic/p-fe4aa1db.entry.js +0 -4
- package/dist/ionic/p-mjKAFv89.js +0 -4
- package/dist/ionic/p-tcQvqkiX.js +0 -5
- package/dist/ionic/p-viFHDgRs.js +0 -4
- package/dist/ionic/p-xWb6fgfq.js +0 -4
- /package/dist/collection/components/{input-password-toggle/input-password-toggle.css → refresher-content/refresher-content.css} +0 -0
|
@@ -0,0 +1,168 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* (C) Ionic http://ionicframework.com - MIT License
|
|
3
|
+
*/
|
|
4
|
+
import { readTask, writeTask } from "@stencil/core";
|
|
5
|
+
/** Cumulative downward delta before hiding (header or footer `collapse="hide"`). */
|
|
6
|
+
export const COLLAPSE_HIDE_THRESHOLD_PX = 24;
|
|
7
|
+
/**
|
|
8
|
+
* Cumulative upward delta before showing again after hide. Small bias
|
|
9
|
+
* (instead of "any upward delta") guards against inertial-scroll
|
|
10
|
+
* oscillation flicking the region back open during a downward gesture.
|
|
11
|
+
*/
|
|
12
|
+
export const COLLAPSE_SHOW_THRESHOLD_PX = 5;
|
|
13
|
+
const WHEEL_SCROLL_SUPPRESS_MS = 80;
|
|
14
|
+
const getContentHostFromScrollEl = (scrollEl) => {
|
|
15
|
+
const root = scrollEl.getRootNode();
|
|
16
|
+
if (root instanceof ShadowRoot && root.host instanceof HTMLElement) {
|
|
17
|
+
return root.host;
|
|
18
|
+
}
|
|
19
|
+
// Light-DOM fallback: the scroll element may live inside a non-shadow
|
|
20
|
+
// ion-content (e.g. custom scroll host). Walk up to the nearest ion-content.
|
|
21
|
+
return scrollEl.closest('ion-content');
|
|
22
|
+
};
|
|
23
|
+
const applySlideDistance = (regionEl, contentHost, slideCssVar, heightPx) => {
|
|
24
|
+
const value = `${Math.max(0, Math.ceil(heightPx))}px`;
|
|
25
|
+
regionEl.style.setProperty(slideCssVar, value);
|
|
26
|
+
contentHost === null || contentHost === void 0 ? void 0 : contentHost.style.setProperty(slideCssVar, value);
|
|
27
|
+
};
|
|
28
|
+
const clearSlideDistance = (regionEl, contentHost, slideCssVar) => {
|
|
29
|
+
regionEl.style.removeProperty(slideCssVar);
|
|
30
|
+
contentHost === null || contentHost === void 0 ? void 0 : contentHost.style.removeProperty(slideCssVar);
|
|
31
|
+
};
|
|
32
|
+
/**
|
|
33
|
+
* Scroll/wheel-driven hide/show for `collapse="hide"` on `ion-header` or `ion-footer`.
|
|
34
|
+
* Hide after {@link COLLAPSE_HIDE_THRESHOLD_PX}px cumulative downward delta; show after
|
|
35
|
+
* {@link COLLAPSE_SHOW_THRESHOLD_PX}px cumulative upward delta. Each direction drains
|
|
36
|
+
* (not resets) the opposing accumulator so inertial-scroll jitter doesn't stall either
|
|
37
|
+
* transition. Motion is defined in component SCSS and `content.scss`; this toggles
|
|
38
|
+
* classes and syncs the slide distance CSS var.
|
|
39
|
+
*/
|
|
40
|
+
export const createCollapseHideInteraction = ({ regionEl, scrollEl, slideCssVar, contentPartnerClass, contentHiddenClass, regionHiddenClass, }) => {
|
|
41
|
+
const contentHost = getContentHostFromScrollEl(scrollEl);
|
|
42
|
+
if (contentHost !== null) {
|
|
43
|
+
contentHost.classList.add(contentPartnerClass);
|
|
44
|
+
}
|
|
45
|
+
let resizeObserver;
|
|
46
|
+
let destroyed = false;
|
|
47
|
+
const syncSlideDistance = () => {
|
|
48
|
+
readTask(() => {
|
|
49
|
+
if (destroyed) {
|
|
50
|
+
return;
|
|
51
|
+
}
|
|
52
|
+
const heightPx = regionEl.offsetHeight;
|
|
53
|
+
writeTask(() => {
|
|
54
|
+
if (destroyed) {
|
|
55
|
+
return;
|
|
56
|
+
}
|
|
57
|
+
applySlideDistance(regionEl, contentHost, slideCssVar, heightPx);
|
|
58
|
+
});
|
|
59
|
+
});
|
|
60
|
+
};
|
|
61
|
+
if (typeof ResizeObserver !== 'undefined') {
|
|
62
|
+
resizeObserver = new ResizeObserver(() => {
|
|
63
|
+
syncSlideDistance();
|
|
64
|
+
});
|
|
65
|
+
resizeObserver.observe(regionEl);
|
|
66
|
+
}
|
|
67
|
+
syncSlideDistance();
|
|
68
|
+
requestAnimationFrame(() => {
|
|
69
|
+
if (!destroyed) {
|
|
70
|
+
syncSlideDistance();
|
|
71
|
+
}
|
|
72
|
+
});
|
|
73
|
+
let hidden = false;
|
|
74
|
+
let accDown = 0;
|
|
75
|
+
let accUp = 0;
|
|
76
|
+
let lastScrollTop = scrollEl.scrollTop;
|
|
77
|
+
let lastWheelTime = 0;
|
|
78
|
+
const setHidden = (next) => {
|
|
79
|
+
if (hidden === next || destroyed) {
|
|
80
|
+
return;
|
|
81
|
+
}
|
|
82
|
+
hidden = next;
|
|
83
|
+
// When transitioning to hidden, re-measure synchronously in case the
|
|
84
|
+
// initial layout reported offsetHeight === 0 (e.g. mid page transition).
|
|
85
|
+
// Without this the slide animates by 0px and only opacity fades.
|
|
86
|
+
if (hidden) {
|
|
87
|
+
const heightPx = regionEl.offsetHeight;
|
|
88
|
+
if (heightPx > 0) {
|
|
89
|
+
applySlideDistance(regionEl, contentHost, slideCssVar, heightPx);
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
writeTask(() => {
|
|
93
|
+
if (destroyed) {
|
|
94
|
+
return;
|
|
95
|
+
}
|
|
96
|
+
regionEl.classList.toggle(regionHiddenClass, hidden);
|
|
97
|
+
contentHost === null || contentHost === void 0 ? void 0 : contentHost.classList.toggle(contentHiddenClass, hidden);
|
|
98
|
+
if (hidden) {
|
|
99
|
+
// `inert` removes the subtree from the tab order and AT, AND moves
|
|
100
|
+
// focus out automatically in supporting browsers. `aria-hidden` is
|
|
101
|
+
// kept as a fallback for older engines without `inert` support.
|
|
102
|
+
regionEl.setAttribute('inert', '');
|
|
103
|
+
regionEl.setAttribute('aria-hidden', 'true');
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
regionEl.removeAttribute('inert');
|
|
107
|
+
regionEl.removeAttribute('aria-hidden');
|
|
108
|
+
}
|
|
109
|
+
});
|
|
110
|
+
};
|
|
111
|
+
// Accumulate cumulative movement in each direction. The OPPOSITE accumulator
|
|
112
|
+
// is drained (not reset) by each event, so brief inertial jitter does not
|
|
113
|
+
// wipe a sustained gesture's accumulation. Crossing a threshold resets both.
|
|
114
|
+
const processDelta = (delta) => {
|
|
115
|
+
if (delta > 0) {
|
|
116
|
+
accUp = Math.max(0, accUp - delta);
|
|
117
|
+
accDown += delta;
|
|
118
|
+
if (accDown >= COLLAPSE_HIDE_THRESHOLD_PX) {
|
|
119
|
+
setHidden(true);
|
|
120
|
+
accDown = 0;
|
|
121
|
+
accUp = 0;
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
else if (delta < 0) {
|
|
125
|
+
const mag = -delta;
|
|
126
|
+
accDown = Math.max(0, accDown - mag);
|
|
127
|
+
accUp += mag;
|
|
128
|
+
if (accUp >= COLLAPSE_SHOW_THRESHOLD_PX) {
|
|
129
|
+
setHidden(false);
|
|
130
|
+
accUp = 0;
|
|
131
|
+
accDown = 0;
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
};
|
|
135
|
+
const onWheel = (ev) => {
|
|
136
|
+
if (destroyed) {
|
|
137
|
+
return;
|
|
138
|
+
}
|
|
139
|
+
lastWheelTime = performance.now();
|
|
140
|
+
processDelta(ev.deltaY);
|
|
141
|
+
};
|
|
142
|
+
const onScroll = () => {
|
|
143
|
+
if (destroyed) {
|
|
144
|
+
return;
|
|
145
|
+
}
|
|
146
|
+
const st = scrollEl.scrollTop;
|
|
147
|
+
if (performance.now() - lastWheelTime < WHEEL_SCROLL_SUPPRESS_MS) {
|
|
148
|
+
lastScrollTop = st;
|
|
149
|
+
return;
|
|
150
|
+
}
|
|
151
|
+
const delta = st - lastScrollTop;
|
|
152
|
+
lastScrollTop = st;
|
|
153
|
+
processDelta(delta);
|
|
154
|
+
};
|
|
155
|
+
scrollEl.addEventListener('wheel', onWheel, { passive: true });
|
|
156
|
+
scrollEl.addEventListener('scroll', onScroll, { passive: true });
|
|
157
|
+
return () => {
|
|
158
|
+
destroyed = true;
|
|
159
|
+
resizeObserver === null || resizeObserver === void 0 ? void 0 : resizeObserver.disconnect();
|
|
160
|
+
scrollEl.removeEventListener('wheel', onWheel);
|
|
161
|
+
scrollEl.removeEventListener('scroll', onScroll);
|
|
162
|
+
regionEl.classList.remove(regionHiddenClass);
|
|
163
|
+
regionEl.removeAttribute('inert');
|
|
164
|
+
regionEl.removeAttribute('aria-hidden');
|
|
165
|
+
contentHost === null || contentHost === void 0 ? void 0 : contentHost.classList.remove(contentPartnerClass, contentHiddenClass);
|
|
166
|
+
clearSlideDistance(regionEl, contentHost, slideCssVar);
|
|
167
|
+
};
|
|
168
|
+
};
|
|
@@ -6,7 +6,7 @@ import { focusFirstDescendant, focusLastDescendant, focusableQueryString } from
|
|
|
6
6
|
import { shouldUseCloseWatcher } from "./hardware-back-button";
|
|
7
7
|
import { printIonError, printIonWarning } from "./logging/index";
|
|
8
8
|
import { config } from "../global/config";
|
|
9
|
-
import { getIonMode } from "../global/ionic-global";
|
|
9
|
+
import { getIonMode, getIonTheme } from "../global/ionic-global";
|
|
10
10
|
import { CoreDelegate } from "./framework-delegate";
|
|
11
11
|
import { BACKDROP_NO_SCROLL } from "./gesture/gesture-controller";
|
|
12
12
|
import { OVERLAY_BACK_BUTTON_PRIORITY } from "./hardware-back-button";
|
|
@@ -39,6 +39,10 @@ export const alertController = /*@__PURE__*/ createController('ion-alert');
|
|
|
39
39
|
export const actionSheetController = /*@__PURE__*/ createController('ion-action-sheet');
|
|
40
40
|
export const loadingController = /*@__PURE__*/ createController('ion-loading');
|
|
41
41
|
export const modalController = /*@__PURE__*/ createController('ion-modal');
|
|
42
|
+
/**
|
|
43
|
+
* @deprecated Use the inline ion-picker component instead.
|
|
44
|
+
*/
|
|
45
|
+
export const pickerController = /*@__PURE__*/ createController('ion-picker-legacy');
|
|
42
46
|
export const popoverController = /*@__PURE__*/ createController('ion-popover');
|
|
43
47
|
export const toastController = /*@__PURE__*/ createController('ion-toast');
|
|
44
48
|
/**
|
|
@@ -132,7 +136,7 @@ const focusElementInOverlay = (hostToFocus, overlay) => {
|
|
|
132
136
|
* Should NOT include: Toast
|
|
133
137
|
*/
|
|
134
138
|
const trapKeyboardFocus = (ev, doc) => {
|
|
135
|
-
const lastOverlay = getPresentedOverlay(doc, 'ion-alert,ion-action-sheet,ion-loading,ion-modal,ion-popover');
|
|
139
|
+
const lastOverlay = getPresentedOverlay(doc, 'ion-alert,ion-action-sheet,ion-loading,ion-modal,ion-picker-legacy,ion-popover');
|
|
136
140
|
const target = ev.target;
|
|
137
141
|
/**
|
|
138
142
|
* If no active overlay, ignore this event.
|
|
@@ -315,6 +319,86 @@ const connectListeners = (doc) => {
|
|
|
315
319
|
doc.addEventListener('focus', (ev) => {
|
|
316
320
|
trapKeyboardFocus(ev, doc);
|
|
317
321
|
}, true);
|
|
322
|
+
// Listen for keydown events to intercept Tab navigation.
|
|
323
|
+
// This is needed for Safari and Firefox which may skip focusable
|
|
324
|
+
// elements or allow focus to escape the overlay.
|
|
325
|
+
// It also ensures proper focus delegation for shadow DOM elements
|
|
326
|
+
// like ion-textarea.
|
|
327
|
+
doc.addEventListener('keydown', (ev) => {
|
|
328
|
+
var _a, _b, _c;
|
|
329
|
+
if (ev.key !== 'Tab' && ev.key !== 'Alt+Tab')
|
|
330
|
+
return;
|
|
331
|
+
const lastOverlay = getPresentedOverlay(doc, 'ion-alert,ion-action-sheet,ion-loading,ion-modal,ion-picker-legacy,ion-popover');
|
|
332
|
+
if (!lastOverlay || lastOverlay.classList.contains(FOCUS_TRAP_DISABLE_CLASS))
|
|
333
|
+
return;
|
|
334
|
+
const activeElement = doc.activeElement;
|
|
335
|
+
if (activeElement === lastOverlay) {
|
|
336
|
+
ev.preventDefault();
|
|
337
|
+
focusFirstDescendant(lastOverlay);
|
|
338
|
+
return;
|
|
339
|
+
}
|
|
340
|
+
// Check if activeElement is inside the overlay (including shadow DOM)
|
|
341
|
+
const isInsideOverlay = activeElement
|
|
342
|
+
? lastOverlay.contains(activeElement) ||
|
|
343
|
+
(activeElement.getRootNode() instanceof ShadowRoot &&
|
|
344
|
+
lastOverlay.contains(activeElement.getRootNode().host)) ||
|
|
345
|
+
((_b = (_a = lastOverlay.shadowRoot) === null || _a === void 0 ? void 0 : _a.contains(activeElement)) !== null && _b !== void 0 ? _b : false)
|
|
346
|
+
: false;
|
|
347
|
+
if (!isInsideOverlay)
|
|
348
|
+
return;
|
|
349
|
+
// Get all focusable elements from both light and shadow DOM
|
|
350
|
+
const allFocusable = [
|
|
351
|
+
...lastOverlay.querySelectorAll(focusableQueryString),
|
|
352
|
+
...(((_c = lastOverlay.shadowRoot) === null || _c === void 0 ? void 0 : _c.querySelectorAll(focusableQueryString)) || []),
|
|
353
|
+
];
|
|
354
|
+
if (allFocusable.length === 0) {
|
|
355
|
+
ev.preventDefault();
|
|
356
|
+
return;
|
|
357
|
+
}
|
|
358
|
+
// Find current element's index (accounting for shadow DOM)
|
|
359
|
+
const currentIndex = activeElement
|
|
360
|
+
? allFocusable.findIndex((el) => {
|
|
361
|
+
var _a;
|
|
362
|
+
if (el === activeElement)
|
|
363
|
+
return true;
|
|
364
|
+
if ((_a = el.shadowRoot) === null || _a === void 0 ? void 0 : _a.contains(activeElement))
|
|
365
|
+
return true;
|
|
366
|
+
const rootNode = activeElement.getRootNode();
|
|
367
|
+
return rootNode instanceof ShadowRoot && rootNode.host === el;
|
|
368
|
+
})
|
|
369
|
+
: -1;
|
|
370
|
+
ev.preventDefault();
|
|
371
|
+
// Helper to focus an element, handling shadow DOM properly
|
|
372
|
+
const focusElement = (element) => {
|
|
373
|
+
const shadowRoot = element.shadowRoot;
|
|
374
|
+
if (shadowRoot) {
|
|
375
|
+
const innerFocusable = shadowRoot.querySelector(focusableQueryString);
|
|
376
|
+
if (innerFocusable && typeof element.setFocus !== 'function') {
|
|
377
|
+
focusVisibleElement(innerFocusable);
|
|
378
|
+
return;
|
|
379
|
+
}
|
|
380
|
+
}
|
|
381
|
+
focusVisibleElement(element);
|
|
382
|
+
};
|
|
383
|
+
if (ev.shiftKey) {
|
|
384
|
+
// Shift+Tab: previous element, wrap to last if at first
|
|
385
|
+
if (currentIndex <= 0) {
|
|
386
|
+
focusLastDescendant(lastOverlay);
|
|
387
|
+
}
|
|
388
|
+
else {
|
|
389
|
+
focusElement(allFocusable[currentIndex - 1]);
|
|
390
|
+
}
|
|
391
|
+
}
|
|
392
|
+
else {
|
|
393
|
+
// Tab: next element, wrap to first if at last
|
|
394
|
+
if (currentIndex < 0 || currentIndex >= allFocusable.length - 1) {
|
|
395
|
+
focusFirstDescendant(lastOverlay);
|
|
396
|
+
}
|
|
397
|
+
else {
|
|
398
|
+
focusElement(allFocusable[currentIndex + 1]);
|
|
399
|
+
}
|
|
400
|
+
}
|
|
401
|
+
}, true);
|
|
318
402
|
// handle back-button click
|
|
319
403
|
doc.addEventListener('ionBackButton', (ev) => {
|
|
320
404
|
const lastOverlay = getPresentedOverlay(doc);
|
|
@@ -366,7 +450,7 @@ export const dismissOverlay = (doc, data, role, overlayTag, id) => {
|
|
|
366
450
|
*/
|
|
367
451
|
export const getOverlays = (doc, selector) => {
|
|
368
452
|
if (selector === undefined) {
|
|
369
|
-
selector = 'ion-alert,ion-action-sheet,ion-loading,ion-modal,ion-popover,ion-toast';
|
|
453
|
+
selector = 'ion-alert,ion-action-sheet,ion-loading,ion-modal,ion-picker-legacy,ion-popover,ion-toast';
|
|
370
454
|
}
|
|
371
455
|
return Array.from(doc.querySelectorAll(selector)).filter((c) => c.overlayIndex > 0);
|
|
372
456
|
};
|
|
@@ -428,30 +512,7 @@ export const setRootAriaHidden = (hidden = false) => {
|
|
|
428
512
|
viewContainer.removeAttribute('aria-hidden');
|
|
429
513
|
}
|
|
430
514
|
};
|
|
431
|
-
|
|
432
|
-
* Cleans up root `aria-hidden` and `backdrop-no-scroll` when
|
|
433
|
-
* an overlay is removed from the DOM without going through
|
|
434
|
-
* the `dismiss()` flow (e.g., when a framework unmounts the
|
|
435
|
-
* overlay during a route change).
|
|
436
|
-
*
|
|
437
|
-
* Should be called from an overlay's `disconnectedCallback`
|
|
438
|
-
* when the overlay was still presented at the time of removal.
|
|
439
|
-
*/
|
|
440
|
-
export const cleanupRootFocusTrapAccessibility = () => {
|
|
441
|
-
if (typeof document === 'undefined') {
|
|
442
|
-
return;
|
|
443
|
-
}
|
|
444
|
-
const remainingOverlays = getPresentedOverlays(document);
|
|
445
|
-
const hasRemainingLocking = remainingOverlays.some((o) => {
|
|
446
|
-
const el = o;
|
|
447
|
-
return el.tagName !== 'ION-TOAST' && el.focusTrap !== false && isBackdropAlwaysBlocking(el);
|
|
448
|
-
});
|
|
449
|
-
if (!hasRemainingLocking) {
|
|
450
|
-
setRootAriaHidden(false);
|
|
451
|
-
document.body.classList.remove(BACKDROP_NO_SCROLL);
|
|
452
|
-
}
|
|
453
|
-
};
|
|
454
|
-
export const present = async (overlay, name, iosEnterAnimation, mdEnterAnimation, opts) => {
|
|
515
|
+
export const present = async (overlay, name, iosEnterAnimation, mdEnterAnimation, ionicEnterAnimation, opts) => {
|
|
455
516
|
var _a, _b;
|
|
456
517
|
if (overlay.presented) {
|
|
457
518
|
return;
|
|
@@ -499,11 +560,15 @@ export const present = async (overlay, name, iosEnterAnimation, mdEnterAnimation
|
|
|
499
560
|
document.body.classList.add(BACKDROP_NO_SCROLL);
|
|
500
561
|
}
|
|
501
562
|
(_a = overlay.willPresentShorthand) === null || _a === void 0 ? void 0 : _a.emit();
|
|
563
|
+
const theme = getIonTheme(overlay);
|
|
502
564
|
const mode = getIonMode(overlay);
|
|
565
|
+
const selectedAnimation = mode === 'ios'
|
|
566
|
+
? iosEnterAnimation
|
|
567
|
+
: theme === 'ionic' && ionicEnterAnimation
|
|
568
|
+
? ionicEnterAnimation
|
|
569
|
+
: mdEnterAnimation;
|
|
503
570
|
// get the user's animation fn if one was provided
|
|
504
|
-
const animationBuilder = overlay.enterAnimation
|
|
505
|
-
? overlay.enterAnimation
|
|
506
|
-
: config.get(name, mode === 'ios' ? iosEnterAnimation : mdEnterAnimation);
|
|
571
|
+
const animationBuilder = overlay.enterAnimation ? overlay.enterAnimation : config.get(name, selectedAnimation);
|
|
507
572
|
const completed = await overlayAnimation(overlay, animationBuilder, overlay.el, opts);
|
|
508
573
|
if (completed) {
|
|
509
574
|
overlay.didPresent.emit();
|
|
@@ -658,7 +723,8 @@ export const dismiss = async (overlay, data, role, name, iosLeaveAnimation, mdLe
|
|
|
658
723
|
return true;
|
|
659
724
|
};
|
|
660
725
|
const getAppRoot = (doc) => {
|
|
661
|
-
|
|
726
|
+
const appRootSelector = config.get('appRootSelector', 'ion-app');
|
|
727
|
+
return doc.querySelector(appRootSelector) || doc.body;
|
|
662
728
|
};
|
|
663
729
|
const overlayAnimation = async (overlay, animationBuilder, baseEl, opts) => {
|
|
664
730
|
// Make overlay visible in case it's hidden
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* (C) Ionic http://ionicframework.com - MIT License
|
|
3
|
+
*/
|
|
4
|
+
import { h } from "@stencil/core";
|
|
5
|
+
import { sanitizeDOMString } from "./sanitization";
|
|
6
|
+
/**
|
|
7
|
+
* Cache that maps rendered span elements to the source HTMLElement
|
|
8
|
+
* they were cloned from. This prevents flickering when a user
|
|
9
|
+
* selects an option that has rich content, as the content will only be
|
|
10
|
+
* re-rendered if the source HTMLElement changes.
|
|
11
|
+
*/
|
|
12
|
+
const contentCache = new WeakMap();
|
|
13
|
+
/**
|
|
14
|
+
* Renders cloned DOM content into an element via a ref callback.
|
|
15
|
+
* The content is only cloned when the source element changes,
|
|
16
|
+
* preventing flicker caused by destroying and recreating web
|
|
17
|
+
* components (e.g., ion-avatar) on every re-render cycle.
|
|
18
|
+
*
|
|
19
|
+
* Span elements should be used when this content renders within buttons,
|
|
20
|
+
* depending on the select interface. Buttons can only have phrasing
|
|
21
|
+
* content to prevent accessibility issues.
|
|
22
|
+
*
|
|
23
|
+
* @param id - Unique identifier for generating stable virtual DOM keys.
|
|
24
|
+
* @param content - The HTMLElement container whose child nodes will be cloned.
|
|
25
|
+
* @param className - CSS class applied to the wrapper span.
|
|
26
|
+
* @param useSpan - Whether to use a span element instead of a div for the wrapper.
|
|
27
|
+
*/
|
|
28
|
+
const renderClonedContent = (id, content, className, useSpan = false) => {
|
|
29
|
+
const Tag = useSpan ? 'span' : 'div';
|
|
30
|
+
return (h(Tag, { class: className, key: `${className}-${id}`, ref: (el) => {
|
|
31
|
+
if (el) {
|
|
32
|
+
const cached = contentCache.get(el);
|
|
33
|
+
// Skip if this element already has clones from the same source
|
|
34
|
+
if (cached === content) {
|
|
35
|
+
return;
|
|
36
|
+
}
|
|
37
|
+
const sanitized = sanitizeDOMString(content.innerHTML);
|
|
38
|
+
el.innerHTML = sanitized !== null && sanitized !== void 0 ? sanitized : '';
|
|
39
|
+
contentCache.set(el, content);
|
|
40
|
+
}
|
|
41
|
+
} }));
|
|
42
|
+
};
|
|
43
|
+
/**
|
|
44
|
+
* Renders the label content for a select option within an overlay
|
|
45
|
+
* interface based on the presence of rich content.
|
|
46
|
+
*
|
|
47
|
+
* Span elements should be used when this content renders within buttons,
|
|
48
|
+
* depending on the select interface. Buttons can only have phrasing
|
|
49
|
+
* content to prevent accessibility issues.
|
|
50
|
+
*
|
|
51
|
+
* @param option - The content option data containing label, slots,
|
|
52
|
+
* and description.
|
|
53
|
+
* @param className - The base CSS class for the label element.
|
|
54
|
+
* @param useSpan - Whether to use a span element instead of a div for the label.
|
|
55
|
+
*/
|
|
56
|
+
export const renderOptionLabel = (option, className, useSpan = false) => {
|
|
57
|
+
const { id, label, startContent, endContent, description } = option;
|
|
58
|
+
const hasRichContent = !!startContent || !!endContent || !!description;
|
|
59
|
+
const Tag = useSpan ? 'span' : 'div';
|
|
60
|
+
// Render simple string label if there is no rich content to display
|
|
61
|
+
if (!hasRichContent && (typeof label === 'string' || !label)) {
|
|
62
|
+
return (h(Tag, { class: className, key: `${className}-${id}` }, label));
|
|
63
|
+
}
|
|
64
|
+
// Render the main label
|
|
65
|
+
const labelEl = typeof label === 'string' || !label ? (
|
|
66
|
+
// Label is a simple string or undefined
|
|
67
|
+
h(Tag, { key: `${className}-label-${id}` }, label)) : (
|
|
68
|
+
// Label is an HTMLElement with potential rich content
|
|
69
|
+
renderClonedContent(id, label, `${className}-text`, useSpan));
|
|
70
|
+
// No rich content, render just the label
|
|
71
|
+
if (!hasRichContent) {
|
|
72
|
+
return (h(Tag, { class: className, key: `${className}-${id}` }, labelEl));
|
|
73
|
+
}
|
|
74
|
+
// Render label with rich content (start, end, description)
|
|
75
|
+
return (h(Tag, { class: className, 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)));
|
|
76
|
+
};
|
|
@@ -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',
|