@ionic/core 8.8.9-dev.11779403760.13ea2a08 → 8.8.9-dev.11780086312.13aac420
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-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-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.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-CDgDBcU9.js → p-9VcRUwdB.js} +1 -1
- package/components/p-B6FQ0cKR.js +4 -0
- package/components/p-B6HaBl3o.js +4 -0
- package/components/p-B8b1Ukl9.js +4 -0
- package/components/p-BJoMtgfR.js +4 -0
- package/components/p-BJu4LSK8.js +4 -0
- package/components/p-BNAG-aVv.js +4 -0
- package/components/p-BR3tZJmu.js +4 -0
- package/{dist/ionic/p-C8IHbcuP.js → components/p-BS1TtEiJ.js} +1 -1
- package/components/p-BUbsoBOV.js +4 -0
- package/components/p-BWUpLAtP.js +4 -0
- package/components/p-BYDc3hSE.js +4 -0
- package/components/p-BagjAGC0.js +4 -0
- package/components/p-BeL7B3Bb.js +4 -0
- package/components/p-Bg7NsGS9.js +4 -0
- package/components/p-BgwEQWW6.js +4 -0
- package/components/p-BmVRXR1y.js +4 -0
- package/components/p-BxwWvu-b.js +4 -0
- package/components/p-C4jPsTQa.js +4 -0
- package/components/p-C59ryAuS.js +4 -0
- package/components/p-CBzELu-H.js +4 -0
- package/components/p-CDXBV7oG.js +4 -0
- package/components/p-CDfQnFrd.js +4 -0
- package/components/{p-ByW0kK1F.js → p-CEmXdzGo.js} +1 -1
- package/components/p-CIGNaXM1.js +4 -0
- package/components/p-CO7fmmxt.js +4 -0
- package/components/{p-BZCB7f49.js → p-CU1SSH8_.js} +1 -1
- package/components/p-CWpbvhwY.js +4 -0
- package/components/p-CgqKJg96.js +4 -0
- package/components/p-CneGxKsZ.js +4 -0
- package/components/p-CoA-aqGF.js +4 -0
- package/components/p-Csw8xuz4.js +4 -0
- package/components/p-CtWGkNnJ.js +4 -0
- package/components/p-Cy5XSfIk.js +4 -0
- package/components/p-Cz5nLPGT.js +4 -0
- package/{dist/ionic/p-CuGhCBt7.js → components/p-D13Eaw-8.js} +1 -1
- package/components/p-D6NJwNJN.js +4 -0
- package/components/p-D6Ynv7Xh.js +4 -0
- package/components/p-DJztqcrH.js +4 -0
- package/components/p-DL2W2mt3.js +4 -0
- package/components/p-DYdpXONG.js +4 -0
- package/components/p-DbISMmiI.js +4 -0
- package/components/p-DgbT0exM.js +4 -0
- package/components/p-DiVJyqlX.js +4 -0
- package/components/p-DrIm1s9R.js +4 -0
- package/components/p-DvOO1fxp.js +4 -0
- package/components/p-DxXmSp9Y.js +4 -0
- package/components/p-FBcnjE5W.js +4 -0
- package/components/p-GCtnx-UP.js +4 -0
- package/components/p-JQ4ZNN1D.js +4 -0
- package/components/p-OOMJP0jy.js +4 -0
- package/components/p-Q1-Xy3As.js +4 -0
- package/components/p-SBseW5KJ.js +4 -0
- package/components/{p-zWP0sUV_.js → p-YLXPWgVj.js} +1 -1
- package/components/p-ZjP4CjeZ.js +4 -0
- package/{dist/ionic/p-B2-sg7NJ.js → components/p-ak_d-z48.js} +1 -1
- package/components/{p-re70ahxF.js → p-cyNmxje6.js} +1 -1
- package/components/p-nPoOPlPt.js +4 -0
- package/components/p-vEbVo2hO.js +4 -0
- package/css/core.css +1 -1
- package/css/core.css.map +1 -1
- package/css/display.css +1 -1
- package/css/display.css.map +1 -1
- package/css/flex-utils.css +1 -1
- package/css/flex-utils.css.map +1 -1
- package/css/float-elements.css.map +1 -1
- package/css/global.bundle.css.map +1 -1
- package/css/ionic-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-BZJ2wKuM.js → animation-Dg4yiuR2.js} +3 -3
- package/dist/cjs/{app-globals-C-d5fQ35.js → app-globals-CLI8xCmk.js} +1 -1
- package/dist/cjs/{button-active-B_20Nxkv.js → button-active-FscMI17-.js} +2 -2
- package/dist/cjs/{capacitor-CXqhdZym.js → capacitor-DmA66EwP.js} +3 -3
- package/dist/cjs/{config-BiqQSDrb.js → config-BukYi_pW.js} +7 -60
- package/dist/cjs/{data-DuOuKG7I.js → data-BYlBjkMU.js} +6 -6
- package/dist/{esm/focus-visible-vXpMhGrs.js → cjs/focus-visible-CCvKiLh3.js} +3 -23
- package/dist/cjs/{framework-delegate-Dx9FrqAC.js → framework-delegate-CRgp8o_p.js} +2 -4
- package/dist/cjs/{haptic-CQJGW58i.js → haptic-ClPPQ_PS.js} +1 -1
- package/dist/cjs/hardware-back-button-C4rMJ5uI.js +121 -0
- package/dist/cjs/{helpers-DJYxKN5U.js → helpers-CxTYJdbT.js} +4 -57
- package/dist/cjs/{index-DSNlrgfO.js → index-C845Ti6K.js} +4 -4
- package/dist/cjs/{index-BekUBS8C.js → index-CFUwM5x_.js} +15 -15
- package/dist/cjs/{index-CzcLEdQ5.js → index-CqT-2gKy.js} +4 -41
- package/dist/cjs/index-DkNv4J_i.js +10 -0
- package/dist/cjs/{index-CgAbCW6L.js → index-DqmRDbxg.js} +0 -2
- package/dist/cjs/{index-BJrpF9T3.js → index-MbaBbWXk.js} +2 -2
- package/dist/cjs/{index-CwxYd6UD.js → index-YcSftOMz.js} +8 -9
- package/dist/cjs/index.cjs.js +14 -14
- package/dist/cjs/{input-shims-VyZciSxi.js → input-shims-CPL2J8F-.js} +17 -18
- package/dist/cjs/{input.utils-Ct5KzpYv.js → input.utils-DmeJ8dmo.js} +5 -5
- package/dist/cjs/ion-accordion_2.cjs.entry.js +29 -61
- package/dist/cjs/ion-action-sheet.cjs.entry.js +26 -40
- package/dist/cjs/ion-alert.cjs.entry.js +44 -76
- package/dist/cjs/ion-app_8.cjs.entry.js +175 -296
- package/dist/cjs/ion-avatar_3.cjs.entry.js +13 -125
- package/dist/cjs/ion-back-button.cjs.entry.js +22 -31
- package/dist/cjs/ion-backdrop.cjs.entry.js +7 -10
- package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +18 -54
- package/dist/cjs/ion-button_2.cjs.entry.js +22 -59
- package/dist/cjs/ion-card_5.cjs.entry.js +33 -55
- package/dist/cjs/ion-checkbox.cjs.entry.js +16 -34
- package/dist/cjs/ion-chip.cjs.entry.js +9 -50
- package/dist/cjs/ion-col_3.cjs.entry.js +57 -56
- package/dist/cjs/ion-datetime-button.cjs.entry.js +9 -13
- package/dist/cjs/{ion-datetime_3.cjs.entry.js → ion-datetime.cjs.entry.js} +29 -742
- package/dist/cjs/ion-fab_3.cjs.entry.js +28 -44
- package/dist/cjs/ion-img.cjs.entry.js +4 -8
- package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +16 -91
- package/dist/cjs/ion-input-otp.cjs.entry.js +9 -74
- package/dist/cjs/ion-input-password-toggle.cjs.entry.js +15 -53
- package/dist/cjs/ion-input.cjs.entry.js +34 -124
- package/dist/cjs/ion-item-option_3.cjs.entry.js +52 -467
- package/dist/cjs/ion-item_8.cjs.entry.js +49 -115
- package/dist/cjs/ion-loading.cjs.entry.js +22 -20
- package/dist/cjs/ion-menu_3.cjs.entry.js +29 -47
- package/dist/cjs/ion-modal.cjs.entry.js +142 -262
- package/dist/cjs/ion-nav_2.cjs.entry.js +11 -14
- package/dist/cjs/ion-picker-column-option.cjs.entry.js +8 -12
- package/dist/cjs/ion-picker-column.cjs.entry.js +14 -14
- package/dist/cjs/ion-picker.cjs.entry.js +6 -10
- package/dist/cjs/ion-popover.cjs.entry.js +23 -21
- package/dist/cjs/ion-progress-bar.cjs.entry.js +9 -27
- package/dist/cjs/ion-radio_2.cjs.entry.js +17 -35
- package/dist/cjs/ion-range.cjs.entry.js +13 -20
- package/dist/cjs/ion-refresher_2.cjs.entry.js +21 -39
- package/dist/cjs/ion-reorder_2.cjs.entry.js +14 -38
- package/dist/cjs/ion-ripple-effect.cjs.entry.js +7 -15
- package/dist/cjs/ion-route_4.cjs.entry.js +9 -10
- package/dist/cjs/ion-searchbar.cjs.entry.js +24 -137
- package/dist/cjs/ion-segment-content.cjs.entry.js +2 -2
- package/dist/cjs/ion-segment-view.cjs.entry.js +3 -13
- package/dist/cjs/ion-segment_2.cjs.entry.js +16 -23
- package/dist/cjs/ion-select-modal.cjs.entry.js +40 -119
- package/dist/cjs/ion-select_3.cjs.entry.js +115 -500
- package/dist/cjs/ion-spinner.cjs.entry.js +8 -30
- package/dist/cjs/ion-split-pane.cjs.entry.js +9 -13
- package/dist/cjs/ion-tab-bar_2.cjs.entry.js +23 -147
- package/dist/cjs/ion-tab_2.cjs.entry.js +7 -8
- package/dist/cjs/ion-text.cjs.entry.js +7 -7
- package/dist/cjs/ion-textarea.cjs.entry.js +23 -137
- package/dist/cjs/ion-toast.cjs.entry.js +46 -69
- package/dist/cjs/ion-toggle.cjs.entry.js +25 -82
- package/dist/cjs/ionic-global-Bc3kJi1Z.js +151 -0
- package/dist/cjs/ionic.cjs.js +4 -4
- package/dist/cjs/{ios.transition-CyNNpj1i.js → ios.transition-trBiC95R.js} +5 -7
- package/dist/cjs/{keyboard-VLGMzWBE.js → keyboard-UuAS4D_9.js} +1 -1
- package/dist/cjs/{keyboard-controller-CCTvHp9l.js → keyboard-controller-GXBiBRKS.js} +9 -11
- package/dist/cjs/{keyboard-CA6RtoWx.js → keyboard-hHzlEQpk.js} +3 -4
- package/dist/cjs/loader.cjs.js +4 -4
- package/dist/cjs/{md.transition-BEfrfWKW.js → md.transition-CUQECuvD.js} +5 -6
- package/dist/cjs/{notch-controller-BTZCPOsd.js → notch-controller-sD-lTpdc.js} +4 -4
- package/dist/cjs/{overlays-BuMIwR8B.js → overlays-DIfHxkst.js} +42 -117
- package/dist/cjs/{status-tap-CTY2dMsZ.js → status-tap-CCJk5VgT.js} +3 -4
- package/dist/cjs/{swipe-back-jJFi5KCB.js → swipe-back-BGhTQ1CU.js} +2 -3
- package/dist/cjs/{theme-IlOsGAz7.js → theme-CeDs6Hcv.js} +1 -25
- package/dist/cjs/validity-BpS37YFM.js +19 -0
- package/dist/collection/collection-manifest.json +1 -12
- package/dist/collection/components/accordion/accordion.ios.css +58 -73
- package/dist/collection/components/accordion/accordion.js +27 -41
- package/dist/collection/components/accordion/accordion.md.css +59 -67
- package/dist/collection/components/accordion-group/accordion-group.ios.css +4 -16
- package/dist/collection/components/accordion-group/accordion-group.js +8 -44
- package/dist/collection/components/accordion-group/accordion-group.md.css +4 -22
- package/dist/collection/components/action-sheet/action-sheet.ios.css +11 -155
- package/dist/collection/components/action-sheet/action-sheet.js +18 -33
- package/dist/collection/components/action-sheet/action-sheet.md.css +10 -155
- package/dist/collection/components/alert/alert.ios.css +19 -219
- package/dist/collection/components/alert/alert.js +35 -68
- package/dist/collection/components/alert/alert.md.css +15 -229
- package/dist/collection/components/app/app.js +83 -15
- package/dist/collection/components/avatar/avatar.ios.css +33 -7
- package/dist/collection/components/avatar/avatar.js +4 -120
- package/dist/collection/components/avatar/avatar.md.css +0 -51
- package/dist/collection/components/back-button/back-button.ios.css +48 -60
- package/dist/collection/components/back-button/back-button.js +19 -27
- package/dist/collection/components/back-button/back-button.md.css +48 -60
- package/dist/collection/components/backdrop/backdrop.ios.css +19 -56
- package/dist/collection/components/backdrop/backdrop.js +6 -12
- package/dist/collection/components/backdrop/backdrop.md.css +19 -56
- package/dist/collection/components/badge/badge.ios.css +12 -139
- package/dist/collection/components/badge/badge.js +9 -145
- package/dist/collection/components/badge/badge.md.css +12 -123
- package/dist/collection/components/breadcrumb/breadcrumb.ios.css +8 -20
- package/dist/collection/components/breadcrumb/breadcrumb.js +11 -43
- package/dist/collection/components/breadcrumb/breadcrumb.md.css +8 -20
- package/dist/collection/components/breadcrumbs/breadcrumbs.ios.css +0 -6
- package/dist/collection/components/breadcrumbs/breadcrumbs.js +9 -11
- package/dist/collection/components/breadcrumbs/breadcrumbs.md.css +0 -6
- package/dist/collection/components/button/button.ios.css +46 -154
- package/dist/collection/components/button/button.js +27 -63
- package/dist/collection/components/button/button.md.css +50 -150
- package/dist/collection/components/buttons/buttons.ios.css +7 -59
- package/dist/collection/components/buttons/buttons.js +9 -15
- package/dist/collection/components/buttons/buttons.md.css +3 -55
- package/dist/collection/components/card/card.ios.css +14 -65
- package/dist/collection/components/card/card.js +10 -41
- package/dist/collection/components/card/card.md.css +14 -65
- package/dist/collection/components/card-content/card-content.ios.css +35 -20
- package/dist/collection/components/card-content/card-content.js +10 -12
- package/dist/collection/components/card-content/card-content.md.css +35 -20
- package/dist/collection/components/card-header/card-header.ios.css +15 -27
- package/dist/collection/components/card-header/card-header.js +10 -13
- package/dist/collection/components/card-header/card-header.md.css +15 -27
- package/dist/collection/components/card-subtitle/card-subtitle.ios.css +0 -12
- package/dist/collection/components/card-subtitle/card-subtitle.js +8 -11
- package/dist/collection/components/card-subtitle/card-subtitle.md.css +0 -12
- package/dist/collection/components/card-title/card-title.ios.css +0 -73
- package/dist/collection/components/card-title/card-title.js +8 -11
- package/dist/collection/components/card-title/card-title.md.css +0 -73
- package/dist/collection/components/checkbox/checkbox.ios.css +101 -161
- package/dist/collection/components/checkbox/checkbox.js +14 -70
- package/dist/collection/components/checkbox/checkbox.md.css +102 -162
- package/dist/collection/components/chip/chip.ios.css +14 -67
- package/dist/collection/components/chip/chip.js +8 -108
- package/dist/collection/components/chip/chip.md.css +14 -67
- package/dist/collection/components/col/col.css +4 -192
- package/dist/collection/components/col/col.js +61 -211
- package/dist/collection/components/content/content.css +2 -8
- package/dist/collection/components/content/content.js +11 -16
- package/dist/collection/components/datetime/datetime.ios.css +106 -302
- package/dist/collection/components/datetime/datetime.js +20 -98
- package/dist/collection/components/datetime/datetime.md.css +96 -293
- package/dist/collection/components/datetime/utils/data.js +5 -5
- package/dist/collection/components/datetime-button/datetime-button.ios.css +0 -6
- package/dist/collection/components/datetime-button/datetime-button.js +8 -11
- package/dist/collection/components/datetime-button/datetime-button.md.css +0 -6
- package/dist/collection/components/fab/fab.css +1 -25
- package/dist/collection/components/fab/fab.js +5 -9
- package/dist/collection/components/fab-button/fab-button.ios.css +6 -18
- package/dist/collection/components/fab-button/fab-button.js +21 -36
- package/dist/collection/components/fab-button/fab-button.md.css +8 -20
- package/dist/collection/components/fab-list/fab-list.css +0 -12
- package/dist/collection/components/fab-list/fab-list.js +5 -9
- package/dist/collection/components/footer/footer.ios.css +2 -14
- package/dist/collection/components/footer/footer.js +16 -21
- package/dist/collection/components/footer/footer.md.css +0 -12
- package/dist/collection/components/grid/grid.css +0 -12
- package/dist/collection/components/grid/grid.js +5 -9
- package/dist/collection/components/header/header.ios.css +10 -25
- package/dist/collection/components/header/header.js +19 -50
- package/dist/collection/components/header/header.md.css +8 -23
- package/dist/collection/components/header/header.utils.js +5 -5
- package/dist/collection/components/img/img.js +2 -8
- package/dist/collection/components/infinite-scroll/infinite-scroll.js +5 -100
- package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.ios.css +0 -12
- package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +10 -16
- package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.md.css +0 -12
- package/dist/collection/components/input/input.ios.css +135 -223
- package/dist/collection/components/input/input.js +37 -148
- package/dist/collection/components/input/input.md.css +207 -193
- package/dist/collection/components/input-otp/input-otp.ios.css +60 -105
- package/dist/collection/components/input-otp/input-otp.js +6 -73
- package/dist/collection/components/input-otp/input-otp.md.css +60 -105
- package/dist/collection/components/input-password-toggle/input-password-toggle.js +12 -48
- package/dist/collection/components/item/item.ios.css +69 -109
- package/dist/collection/components/item/item.js +20 -50
- package/dist/collection/components/item/item.md.css +68 -120
- package/dist/collection/components/item-divider/item-divider.ios.css +0 -18
- package/dist/collection/components/item-divider/item-divider.js +8 -11
- package/dist/collection/components/item-divider/item-divider.md.css +0 -18
- package/dist/collection/components/item-group/item-group.ios.css +0 -12
- package/dist/collection/components/item-group/item-group.js +7 -13
- package/dist/collection/components/item-group/item-group.md.css +0 -12
- package/dist/collection/components/item-option/item-option.ios.css +29 -136
- package/dist/collection/components/item-option/item-option.js +9 -73
- package/dist/collection/components/item-option/item-option.md.css +29 -136
- package/dist/collection/components/item-options/item-options.ios.css +34 -77
- package/dist/collection/components/item-options/item-options.js +7 -13
- package/dist/collection/components/item-options/item-options.md.css +34 -77
- package/dist/collection/components/item-sliding/{item-sliding.native.css → item-sliding.css} +9 -84
- package/dist/collection/components/item-sliding/item-sliding.js +35 -421
- package/dist/collection/components/item-sliding/test/test.utils.js +0 -13
- package/dist/collection/components/label/label.ios.css +0 -18
- package/dist/collection/components/label/label.js +8 -11
- package/dist/collection/components/label/label.md.css +0 -18
- package/dist/collection/components/list/list.ios.css +14 -54
- package/dist/collection/components/list/list.js +9 -48
- package/dist/collection/components/list/list.md.css +16 -56
- package/dist/collection/components/list-header/list-header.ios.css +38 -82
- package/dist/collection/components/list-header/list-header.js +8 -11
- package/dist/collection/components/list-header/list-header.md.css +38 -82
- package/dist/collection/components/loading/loading.ios.css +1 -13
- package/dist/collection/components/loading/loading.js +16 -15
- package/dist/collection/components/loading/loading.md.css +1 -13
- package/dist/collection/components/menu/menu.ios.css +3 -15
- package/dist/collection/components/menu/menu.js +7 -12
- package/dist/collection/components/menu/menu.md.css +3 -15
- package/dist/collection/components/menu-button/menu-button.ios.css +14 -48
- package/dist/collection/components/menu-button/menu-button.js +10 -26
- package/dist/collection/components/menu-button/menu-button.md.css +15 -49
- package/dist/collection/components/menu-toggle/menu-toggle.js +5 -8
- package/dist/collection/components/modal/animations/sheet.js +2 -8
- package/dist/collection/components/modal/gestures/sheet.js +10 -76
- package/dist/collection/components/modal/modal.ios.css +70 -178
- package/dist/collection/components/modal/modal.js +17 -51
- package/dist/collection/components/modal/modal.md.css +70 -178
- package/dist/collection/components/nav/nav.css +1 -7
- package/dist/collection/components/nav/nav.js +5 -11
- package/dist/collection/components/nav-link/nav-link.js +1 -5
- package/dist/collection/components/note/note.ios.css +0 -12
- package/dist/collection/components/note/note.js +8 -11
- package/dist/collection/components/note/note.md.css +0 -12
- package/dist/collection/components/picker/picker.ios.css +3 -15
- package/dist/collection/components/picker/picker.js +5 -8
- package/dist/collection/components/picker/picker.md.css +3 -15
- package/dist/collection/components/picker-column/picker-column.css +2 -9
- package/dist/collection/components/picker-column/picker-column.js +7 -8
- package/dist/collection/components/picker-column-option/picker-column-option.ios.css +0 -6
- package/dist/collection/components/picker-column-option/picker-column-option.js +7 -13
- package/dist/collection/components/picker-column-option/picker-column-option.md.css +0 -6
- package/dist/collection/components/popover/popover.ios.css +1 -29
- package/dist/collection/components/popover/popover.js +20 -19
- package/dist/collection/components/popover/popover.md.css +1 -29
- package/dist/collection/components/progress-bar/progress-bar.ios.css +17 -48
- package/dist/collection/components/progress-bar/progress-bar.js +7 -43
- package/dist/collection/components/progress-bar/progress-bar.md.css +17 -48
- package/dist/collection/components/radio/radio.ios.css +91 -134
- package/dist/collection/components/radio/radio.js +10 -15
- package/dist/collection/components/radio/radio.md.css +91 -134
- package/dist/collection/components/radio-group/radio-group.ios.css +19 -43
- package/dist/collection/components/radio-group/radio-group.js +7 -48
- package/dist/collection/components/radio-group/radio-group.md.css +19 -43
- package/dist/collection/components/range/range.ios.css +85 -128
- package/dist/collection/components/range/range.js +10 -16
- package/dist/collection/components/range/range.md.css +85 -128
- package/dist/collection/components/refresher/refresher.ios.css +1 -14
- package/dist/collection/components/refresher/refresher.js +8 -11
- package/dist/collection/components/refresher/refresher.md.css +2 -15
- package/dist/collection/components/refresher-content/refresher-content.js +7 -28
- package/dist/collection/components/reorder/reorder.ios.css +0 -6
- package/dist/collection/components/reorder/reorder.js +6 -33
- package/dist/collection/components/reorder/reorder.md.css +0 -6
- package/dist/collection/components/reorder-group/reorder-group.css +0 -6
- package/dist/collection/components/reorder-group/reorder-group.js +4 -8
- package/dist/collection/components/ripple-effect/{ripple-effect.common.css → ripple-effect.css} +1 -7
- package/dist/collection/components/ripple-effect/ripple-effect.js +6 -14
- package/dist/collection/components/route/route.js +0 -4
- package/dist/collection/components/router/router.js +0 -4
- package/dist/collection/components/router-link/router-link.css +2 -8
- package/dist/collection/components/router-link/router-link.js +5 -9
- package/dist/collection/components/router-outlet/router-outlet.css +1 -7
- package/dist/collection/components/router-outlet/router-outlet.js +40 -10
- package/dist/collection/components/row/row.css +0 -16
- package/dist/collection/components/row/row.js +2 -9
- package/dist/collection/components/searchbar/searchbar.ios.css +18 -56
- package/dist/collection/components/searchbar/searchbar.js +33 -180
- package/dist/collection/components/searchbar/searchbar.md.css +18 -56
- package/dist/collection/components/segment/segment.ios.css +2 -45
- package/dist/collection/components/segment/segment.js +8 -11
- package/dist/collection/components/segment/segment.md.css +2 -45
- package/dist/collection/components/segment-button/segment-button.ios.css +105 -146
- package/dist/collection/components/segment-button/segment-button.js +8 -11
- package/dist/collection/components/segment-button/segment-button.md.css +107 -148
- package/dist/collection/components/segment-content/segment-content.js +1 -1
- package/dist/collection/components/segment-view/segment-view.ios.css +0 -6
- package/dist/collection/components/segment-view/segment-view.js +4 -13
- package/dist/collection/components/segment-view/segment-view.md.css +0 -6
- package/dist/collection/components/select/select.ios.css +176 -348
- package/dist/collection/components/select/select.js +97 -460
- package/dist/collection/components/select/select.md.css +178 -364
- package/dist/collection/components/select-modal/select-modal.ios.css +0 -156
- package/dist/collection/components/select-modal/select-modal.js +32 -132
- package/dist/collection/components/select-modal/select-modal.md.css +0 -139
- package/dist/collection/components/select-option/select-option.js +2 -70
- package/dist/collection/components/select-popover/select-popover.ios.css +23 -117
- package/dist/collection/components/select-popover/select-popover.js +31 -94
- package/dist/collection/components/select-popover/select-popover.md.css +22 -117
- package/dist/collection/components/skeleton-text/skeleton-text.css +0 -6
- package/dist/collection/components/skeleton-text/skeleton-text.js +5 -9
- package/dist/collection/components/spinner/{spinner.ionic.css → spinner.css} +10 -78
- package/dist/collection/components/spinner/spinner.js +6 -47
- package/dist/collection/components/split-pane/split-pane.ios.css +2 -20
- package/dist/collection/components/split-pane/split-pane.js +8 -15
- package/dist/collection/components/split-pane/split-pane.md.css +2 -20
- package/dist/collection/components/tab/tab.js +2 -6
- package/dist/collection/components/tab-bar/tab-bar.ios.css +43 -71
- package/dist/collection/components/tab-bar/tab-bar.js +13 -171
- package/dist/collection/components/tab-bar/tab-bar.md.css +43 -71
- package/dist/collection/components/tab-button/tab-button.ios.css +95 -171
- package/dist/collection/components/tab-button/tab-button.js +9 -54
- package/dist/collection/components/tab-button/tab-button.md.css +93 -137
- package/dist/collection/components/tabs/tabs.css +1 -7
- package/dist/collection/components/tabs/tabs.js +1 -4
- package/dist/collection/components/text/text.css +0 -6
- package/dist/collection/components/text/text.js +6 -7
- package/dist/collection/components/textarea/textarea.ios.css +158 -298
- package/dist/collection/components/textarea/textarea.js +24 -162
- package/dist/collection/components/textarea/textarea.md.css +159 -312
- package/dist/collection/components/thumbnail/thumbnail.css +0 -6
- package/dist/collection/components/thumbnail/thumbnail.js +2 -9
- package/dist/collection/components/title/title.ios.css +4 -32
- package/dist/collection/components/title/title.js +7 -13
- package/dist/collection/components/title/title.md.css +4 -32
- package/dist/collection/components/toast/animations/utils.js +1 -1
- package/dist/collection/components/toast/toast.ios.css +45 -84
- package/dist/collection/components/toast/toast.js +13 -76
- package/dist/collection/components/toast/toast.md.css +45 -84
- package/dist/collection/components/toggle/toggle.ios.css +131 -247
- package/dist/collection/components/toggle/toggle.js +18 -73
- package/dist/collection/components/toggle/toggle.md.css +131 -244
- package/dist/collection/components/toolbar/toolbar.ios.css +47 -90
- package/dist/collection/components/toolbar/toolbar.js +13 -218
- package/dist/collection/components/toolbar/toolbar.md.css +47 -90
- package/dist/collection/global/ionic-global.js +13 -241
- package/dist/collection/index.js +1 -1
- package/dist/collection/utils/focus-trap.js +2 -13
- package/dist/collection/utils/focus-visible.js +0 -22
- package/dist/collection/utils/forms/validity.js +0 -31
- package/dist/collection/utils/framework-delegate.js +1 -3
- package/dist/collection/utils/hardware-back-button.js +0 -15
- package/dist/collection/utils/helpers.js +3 -57
- package/dist/collection/utils/keyboard/keyboard-controller.js +1 -3
- package/dist/collection/utils/media.js +0 -1
- package/dist/collection/utils/menu-controller/animations/overlay.js +3 -3
- package/dist/collection/utils/menu-controller/animations/push.js +1 -2
- package/dist/collection/utils/menu-controller/animations/reveal.js +1 -2
- package/dist/collection/utils/overlays.js +31 -97
- package/dist/collection/utils/sanitization/index.js +6 -58
- package/dist/collection/utils/test/playwright/drag-element.js +9 -32
- package/dist/collection/utils/test/playwright/generator.js +23 -48
- package/dist/collection/utils/test/playwright/page/utils/goto.js +5 -14
- package/dist/collection/utils/test/playwright/page/utils/set-content.js +3 -26
- package/dist/collection/utils/theme.js +1 -25
- package/dist/collection/utils/transition/ios.transition.js +0 -1
- package/dist/docs.json +574 -10095
- package/dist/esm/{animation-Cd1EA2ar.js → animation-CnGMT4ji.js} +2 -2
- package/dist/esm/{app-globals-9x_U7ofY.js → app-globals-DhZjtldk.js} +1 -1
- package/dist/esm/{button-active-B016u5N-.js → button-active-BBx21brx.js} +2 -2
- package/dist/esm/{capacitor-13SFuT1K.js → capacitor-CFERIeaU.js} +1 -1
- package/dist/esm/{config-DLfuRiEz.js → config-TO1rZH52.js} +8 -60
- package/dist/esm/{data-BNKYavC3.js → data-B9iGR5YO.js} +6 -6
- package/dist/{cjs/focus-visible-BIj-I3-C.js → esm/focus-visible-BmVRXR1y.js} +1 -27
- package/dist/esm/{framework-delegate-CjVwn_KZ.js → framework-delegate-CyxE1S_P.js} +2 -4
- package/dist/esm/{haptic-CbnKC3go.js → haptic-DzAMWJuk.js} +1 -1
- package/dist/esm/hardware-back-button-CTe4XmL7.js +115 -0
- package/dist/esm/{helpers-Do7zwvM1.js → helpers-Tl8jw6S2.js} +5 -58
- package/dist/esm/{index-D2tu5BUg.js → index-AlrZKoWR.js} +1 -2
- package/dist/esm/{index-B2VWavcK.js → index-B-hkiOUh.js} +4 -4
- package/dist/esm/{index-BWMvrRiE.js → index-B2KwgBLx.js} +11 -11
- package/dist/esm/{index-D3WueHpT.js → index-BtUdxPjv.js} +3 -4
- package/dist/esm/{index-Omi_TcwW.js → index-IGIE5vDm.js} +4 -41
- package/dist/esm/index-ZjP4CjeZ.js +7 -0
- package/dist/esm/{index-BmkLokUL.js → index-hW6eNZ3o.js} +2 -2
- package/dist/esm/index.js +14 -13
- package/dist/esm/{input-shims-DU23z7Hg.js → input-shims-DbrgeeNb.js} +6 -7
- package/dist/esm/{input.utils-C64RbLd_.js → input.utils-Bxa_DQ7-.js} +3 -3
- package/dist/esm/ion-accordion_2.entry.js +29 -61
- package/dist/esm/ion-action-sheet.entry.js +26 -40
- package/dist/esm/ion-alert.entry.js +44 -76
- package/dist/esm/ion-app_8.entry.js +175 -296
- package/dist/esm/ion-avatar_3.entry.js +13 -125
- package/dist/esm/ion-back-button.entry.js +22 -31
- package/dist/esm/ion-backdrop.entry.js +7 -10
- package/dist/esm/ion-breadcrumb_2.entry.js +18 -54
- package/dist/esm/ion-button_2.entry.js +22 -59
- package/dist/esm/ion-card_5.entry.js +33 -55
- package/dist/esm/ion-checkbox.entry.js +16 -34
- package/dist/esm/ion-chip.entry.js +9 -50
- package/dist/esm/ion-col_3.entry.js +57 -56
- package/dist/esm/ion-datetime-button.entry.js +9 -13
- package/dist/esm/{ion-datetime_3.entry.js → ion-datetime.entry.js} +30 -741
- package/dist/esm/ion-fab_3.entry.js +28 -44
- package/dist/esm/ion-img.entry.js +4 -8
- package/dist/esm/ion-infinite-scroll_2.entry.js +16 -91
- package/dist/esm/ion-input-otp.entry.js +9 -74
- package/dist/esm/ion-input-password-toggle.entry.js +15 -53
- package/dist/esm/ion-input.entry.js +34 -124
- package/dist/esm/ion-item-option_3.entry.js +52 -467
- package/dist/esm/ion-item_8.entry.js +49 -115
- package/dist/esm/ion-loading.entry.js +22 -20
- package/dist/esm/ion-menu_3.entry.js +29 -47
- package/dist/esm/ion-modal.entry.js +95 -215
- package/dist/esm/ion-nav_2.entry.js +11 -14
- package/dist/esm/ion-picker-column-option.entry.js +8 -12
- package/dist/esm/ion-picker-column.entry.js +13 -13
- package/dist/esm/ion-picker.entry.js +6 -10
- package/dist/esm/ion-popover.entry.js +23 -21
- package/dist/esm/ion-progress-bar.entry.js +9 -27
- package/dist/esm/ion-radio_2.entry.js +17 -35
- package/dist/esm/ion-range.entry.js +13 -20
- package/dist/esm/ion-refresher_2.entry.js +21 -39
- package/dist/esm/ion-reorder_2.entry.js +14 -38
- package/dist/esm/ion-ripple-effect.entry.js +7 -15
- package/dist/esm/ion-route_4.entry.js +9 -10
- package/dist/esm/ion-searchbar.entry.js +24 -137
- package/dist/esm/ion-segment-content.entry.js +2 -2
- package/dist/esm/ion-segment-view.entry.js +3 -13
- package/dist/esm/ion-segment_2.entry.js +16 -23
- package/dist/esm/ion-select-modal.entry.js +40 -119
- package/dist/esm/ion-select_3.entry.js +116 -501
- package/dist/esm/ion-spinner.entry.js +8 -30
- package/dist/esm/ion-split-pane.entry.js +9 -13
- package/dist/esm/ion-tab-bar_2.entry.js +23 -147
- package/dist/esm/ion-tab_2.entry.js +7 -8
- package/dist/esm/ion-text.entry.js +7 -7
- package/dist/esm/ion-textarea.entry.js +23 -137
- package/dist/esm/ion-toast.entry.js +21 -44
- package/dist/esm/ion-toggle.entry.js +25 -82
- package/dist/esm/ionic-global-DfbeLwcV.js +146 -0
- package/dist/esm/ionic.js +5 -5
- package/dist/esm/{ios.transition-DoQTN5Jk.js → ios.transition--aMF-pDH.js} +5 -7
- package/dist/esm/{keyboard-Dnno7-Ci.js → keyboard-CUw4ekVy.js} +1 -1
- package/dist/esm/{keyboard-controller-BpOdk6xN.js → keyboard-controller-BaaVITYt.js} +3 -5
- package/dist/esm/{keyboard-Ca1zVCcH.js → keyboard-ywgs5efA.js} +3 -4
- package/dist/esm/loader.js +5 -5
- package/dist/esm/{md.transition-DZydrWwq.js → md.transition-BEVbfm8j.js} +5 -6
- package/dist/esm/{notch-controller-klgNWpjJ.js → notch-controller-DAcvKU57.js} +2 -2
- package/dist/esm/{overlays-CpQ6Df2g.js → overlays-BDGzTP3L.js} +39 -114
- package/dist/esm/{status-tap-fYFdZg6z.js → status-tap-BfJqFSLF.js} +3 -4
- package/dist/esm/{swipe-back-BzGqTrrq.js → swipe-back-BZBFwTQV.js} +2 -3
- package/dist/esm/{theme-DaJxRxSQ.js → theme-DiVJyqlX.js} +1 -25
- package/dist/esm/validity-DJztqcrH.js +17 -0
- package/dist/html.html-data.json +154 -2674
- package/dist/ionic/index.esm.js +1 -1
- package/dist/ionic/ionic.esm.js +1 -1
- package/dist/ionic/p-045a6a42.entry.js +4 -0
- package/dist/ionic/p-078037da.entry.js +4 -0
- package/dist/ionic/p-0ed06d90.entry.js +4 -0
- package/dist/ionic/p-18b5d5ff.entry.js +4 -0
- package/dist/ionic/p-19adf785.entry.js +4 -0
- package/dist/ionic/p-1d2163ad.entry.js +4 -0
- package/dist/ionic/p-23ec35e4.entry.js +4 -0
- package/dist/ionic/p-30f5ad9e.entry.js +4 -0
- package/dist/ionic/p-34b3a309.entry.js +4 -0
- package/dist/ionic/p-370a60ee.entry.js +4 -0
- package/dist/ionic/p-3b58996c.entry.js +4 -0
- package/dist/ionic/p-460fbe5b.entry.js +4 -0
- package/dist/ionic/p-4c8d8c55.entry.js +4 -0
- package/dist/ionic/p-4ea520a4.entry.js +4 -0
- package/dist/ionic/p-4ed63122.entry.js +4 -0
- package/dist/ionic/p-4f3a8ccf.entry.js +4 -0
- package/dist/ionic/p-528d4c1d.entry.js +4 -0
- package/dist/ionic/p-5430ae94.entry.js +4 -0
- package/dist/ionic/p-54ac6e6d.entry.js +4 -0
- package/dist/ionic/p-66494f9b.entry.js +4 -0
- package/dist/ionic/p-6a56880f.entry.js +4 -0
- package/dist/ionic/p-6af16209.entry.js +4 -0
- package/dist/ionic/p-6b97f2a3.entry.js +4 -0
- package/dist/ionic/p-6da572e7.entry.js +4 -0
- package/dist/ionic/p-6e99ae8d.entry.js +4 -0
- package/dist/ionic/p-7f269aff.entry.js +4 -0
- package/dist/ionic/p-7f9db51b.entry.js +4 -0
- package/dist/ionic/p-7fe42b71.entry.js +4 -0
- package/dist/ionic/p-823eccd3.entry.js +4 -0
- package/dist/ionic/p-87125490.entry.js +4 -0
- package/dist/ionic/p-898f9d11.entry.js +4 -0
- package/dist/ionic/p-8a3a936b.entry.js +4 -0
- package/dist/ionic/p-9833cf63.entry.js +4 -0
- package/dist/ionic/p-9eeaBrnk.js +4 -0
- package/dist/ionic/p-AlrZKoWR.js +4 -0
- package/dist/ionic/{p-DKWXAwlR.js → p-B8xlpH8p.js} +1 -1
- package/dist/ionic/p-BAt5H1ac.js +4 -0
- package/dist/ionic/p-BW_TRJm8.js +4 -0
- package/dist/ionic/p-BmVRXR1y.js +4 -0
- package/dist/ionic/p-Bum7H1fw.js +4 -0
- package/{components/p-oF-CwZ0b.js → dist/ionic/p-BvFYtOdE.js} +1 -1
- package/{components/p-Bt0d89x3.js → dist/ionic/p-BxIcPWoV.js} +1 -1
- package/dist/ionic/p-C0JvVFMv.js +4 -0
- package/dist/ionic/p-CGmVTdWh.js +4 -0
- package/dist/ionic/p-CIGNaXM1.js +4 -0
- package/dist/ionic/{p-BmEwy3tY.js → p-CKvCXMs9.js} +1 -1
- package/dist/ionic/p-CYbRmDdy.js +4 -0
- package/dist/ionic/p-CmFz1Mjc.js +4 -0
- package/dist/ionic/p-Csx_Ej2k.js +4 -0
- package/dist/ionic/p-CtA-yJYy.js +4 -0
- package/dist/ionic/p-CtWGkNnJ.js +4 -0
- package/{components/p-Cllkut-B.js → dist/ionic/p-D13Eaw-8.js} +1 -1
- package/dist/ionic/p-D8HJQ1qq.js +4 -0
- package/dist/ionic/p-DB_iPQC-.js +4 -0
- package/dist/ionic/p-DJztqcrH.js +4 -0
- package/dist/ionic/p-DLbbmF9h.js +4 -0
- package/dist/ionic/p-DcSNwXfb.js +4 -0
- package/dist/ionic/p-DiVJyqlX.js +4 -0
- package/dist/ionic/p-DjriolRs.js +4 -0
- package/dist/ionic/p-DtVZDHlS.js +4 -0
- package/dist/ionic/p-IGIE5vDm.js +5 -0
- package/dist/ionic/p-NFFyoJ4Q.js +4 -0
- package/dist/ionic/p-ZjP4CjeZ.js +4 -0
- package/dist/ionic/p-a39db980.entry.js +4 -0
- package/dist/ionic/p-a47ddfb2.entry.js +4 -0
- package/dist/ionic/p-a805674e.entry.js +4 -0
- package/dist/ionic/p-b553828c.entry.js +4 -0
- package/dist/ionic/p-b6e0ff03.entry.js +4 -0
- package/dist/ionic/p-b8f4a31c.entry.js +4 -0
- package/dist/ionic/p-ca31010f.entry.js +4 -0
- package/dist/ionic/p-cce0cd26.entry.js +4 -0
- package/dist/ionic/p-dc198c3a.entry.js +4 -0
- package/dist/ionic/p-e059750f.entry.js +4 -0
- package/dist/ionic/p-e0d788e9.entry.js +4 -0
- package/dist/ionic/p-e663bc5a.entry.js +4 -0
- package/dist/ionic/p-e6cedcd7.entry.js +4 -0
- package/dist/ionic/p-e9dd191b.entry.js +4 -0
- package/dist/ionic/p-ede28b71.entry.js +4 -0
- package/dist/ionic/p-f17d05e3.entry.js +4 -0
- package/dist/ionic/p-f5dfb9a3.entry.js +4 -0
- package/dist/ionic/p-f7762013.entry.js +4 -0
- package/dist/ionic/p-fed27c64.entry.js +4 -0
- package/dist/ionic/p-gbVXD275.js +4 -0
- package/dist/ionic/p-hNN3VvaC.js +4 -0
- package/dist/types/components/accordion/accordion.d.ts +3 -6
- package/dist/types/components/accordion-group/accordion-group.d.ts +1 -12
- package/dist/types/components/action-sheet/action-sheet-interface.d.ts +7 -3
- package/dist/types/components/action-sheet/action-sheet.d.ts +2 -3
- package/dist/types/components/alert/alert-interface.d.ts +7 -3
- package/dist/types/components/alert/alert.d.ts +2 -3
- package/dist/types/components/app/app.d.ts +5 -4
- package/dist/types/components/avatar/avatar.d.ts +0 -32
- package/dist/types/components/back-button/back-button.d.ts +1 -2
- package/dist/types/components/backdrop/backdrop.d.ts +0 -4
- package/dist/types/components/badge/badge.d.ts +1 -34
- package/dist/types/components/breadcrumb/breadcrumb.d.ts +1 -4
- package/dist/types/components/breadcrumbs/breadcrumbs.d.ts +2 -2
- package/dist/types/components/button/button.d.ts +8 -23
- package/dist/types/components/buttons/buttons.d.ts +1 -5
- package/dist/types/components/card/card.d.ts +1 -8
- package/dist/types/components/card-content/card-content.d.ts +1 -2
- package/dist/types/components/card-header/card-header.d.ts +2 -3
- package/dist/types/components/card-subtitle/card-subtitle.d.ts +1 -2
- package/dist/types/components/card-title/card-title.d.ts +1 -2
- package/dist/types/components/checkbox/checkbox.d.ts +4 -14
- package/dist/types/components/chip/chip.d.ts +1 -26
- package/dist/types/components/col/col.d.ts +5 -52
- package/dist/types/components/content/content.d.ts +0 -3
- package/dist/types/components/datetime/datetime.d.ts +1 -26
- package/dist/types/components/datetime/utils/data.d.ts +5 -5
- package/dist/types/components/datetime-button/datetime-button.d.ts +1 -2
- package/dist/types/components/fab/fab.d.ts +0 -4
- package/dist/types/components/fab-button/fab-button.d.ts +3 -5
- package/dist/types/components/fab-list/fab-list.d.ts +0 -4
- package/dist/types/components/footer/footer.d.ts +3 -4
- package/dist/types/components/grid/grid.d.ts +0 -4
- package/dist/types/components/header/header.d.ts +3 -9
- package/dist/types/components/header/header.utils.d.ts +3 -3
- package/dist/types/components/img/img.d.ts +0 -3
- package/dist/types/components/infinite-scroll/infinite-scroll.d.ts +0 -21
- package/dist/types/components/infinite-scroll-content/infinite-scroll-content.d.ts +0 -4
- package/dist/types/components/input/input.d.ts +5 -31
- package/dist/types/components/input-otp/input-otp.d.ts +0 -37
- package/dist/types/components/input-password-toggle/input-password-toggle.d.ts +0 -2
- package/dist/types/components/item/item.d.ts +4 -11
- package/dist/types/components/item-divider/item-divider.d.ts +1 -2
- package/dist/types/components/item-group/item-group.d.ts +0 -4
- package/dist/types/components/item-option/item-option.d.ts +1 -18
- package/dist/types/components/item-options/item-options.d.ts +0 -4
- package/dist/types/components/item-sliding/item-sliding.d.ts +1 -47
- package/dist/types/components/item-sliding/test/test.utils.d.ts +0 -13
- package/dist/types/components/label/label.d.ts +1 -2
- package/dist/types/components/list/list.d.ts +1 -15
- package/dist/types/components/list-header/list-header.d.ts +1 -2
- package/dist/types/components/loading/loading-interface.d.ts +7 -2
- package/dist/types/components/loading/loading.d.ts +2 -3
- package/dist/types/components/menu/menu.d.ts +0 -3
- package/dist/types/components/menu-button/menu-button.d.ts +1 -3
- package/dist/types/components/menu-toggle/menu-toggle.d.ts +0 -3
- package/dist/types/components/modal/gestures/sheet.d.ts +1 -1
- package/dist/types/components/modal/modal-interface.d.ts +7 -4
- package/dist/types/components/modal/modal.d.ts +1 -11
- package/dist/types/components/nav/nav-interface.d.ts +1 -9
- package/dist/types/components/nav/nav.d.ts +1 -5
- package/dist/types/components/nav-link/nav-link.d.ts +0 -4
- package/dist/types/components/note/note.d.ts +1 -2
- package/dist/types/components/picker/picker.d.ts +1 -2
- package/dist/types/components/picker-column/picker-column.d.ts +1 -2
- package/dist/types/components/picker-column-option/picker-column-option.d.ts +0 -4
- package/dist/types/components/popover/popover-interface.d.ts +6 -3
- package/dist/types/components/popover/popover.d.ts +5 -6
- package/dist/types/components/progress-bar/progress-bar.d.ts +1 -10
- package/dist/types/components/radio/radio.d.ts +1 -2
- package/dist/types/components/radio-group/radio-group.d.ts +0 -12
- package/dist/types/components/range/range.d.ts +1 -2
- package/dist/types/components/refresher/refresher.d.ts +1 -2
- package/dist/types/components/refresher-content/refresher-content.d.ts +0 -4
- package/dist/types/components/reorder/reorder.d.ts +0 -9
- package/dist/types/components/reorder-group/reorder-group.d.ts +0 -4
- package/dist/types/components/ripple-effect/ripple-effect.d.ts +0 -4
- package/dist/types/components/route/route.d.ts +0 -4
- package/dist/types/components/router/router.d.ts +0 -4
- package/dist/types/components/router-link/router-link.d.ts +0 -4
- package/dist/types/components/router-outlet/router-outlet.d.ts +8 -4
- package/dist/types/components/row/row.d.ts +0 -4
- package/dist/types/components/searchbar/searchbar.d.ts +9 -51
- package/dist/types/components/segment/segment.d.ts +1 -2
- package/dist/types/components/segment-button/segment-button.d.ts +1 -2
- package/dist/types/components/select/select-interface.d.ts +0 -31
- package/dist/types/components/select/select.d.ts +14 -66
- package/dist/types/components/select-modal/select-modal.d.ts +0 -8
- package/dist/types/components/select-option/select-option.d.ts +0 -44
- package/dist/types/components/select-popover/select-popover.d.ts +0 -3
- package/dist/types/components/skeleton-text/skeleton-text.d.ts +0 -4
- package/dist/types/components/spinner/spinner.d.ts +0 -15
- package/dist/types/components/split-pane/split-pane.d.ts +0 -4
- package/dist/types/components/tab/tab.d.ts +0 -4
- package/dist/types/components/tab-bar/tab-bar.d.ts +2 -37
- package/dist/types/components/tab-button/tab-button.d.ts +1 -12
- package/dist/types/components/tabs/tabs.d.ts +0 -3
- package/dist/types/components/text/text.d.ts +1 -2
- package/dist/types/components/textarea/textarea.d.ts +4 -53
- package/dist/types/components/thumbnail/thumbnail.d.ts +0 -4
- package/dist/types/components/title/title.d.ts +0 -4
- package/dist/types/components/toast/animations/utils.d.ts +2 -2
- package/dist/types/components/toast/toast-interface.d.ts +7 -3
- package/dist/types/components/toast/toast.d.ts +2 -19
- package/dist/types/components/toggle/toggle.d.ts +1 -15
- package/dist/types/components/toolbar/toolbar.d.ts +3 -43
- package/dist/types/components.d.ts +248 -2125
- package/dist/types/global/ionic-global.d.ts +2 -28
- package/dist/types/index.d.ts +1 -1
- package/dist/types/interface.d.ts +0 -4
- package/dist/types/utils/config.d.ts +2 -114
- package/dist/types/utils/focus-trap.d.ts +1 -1
- package/dist/types/utils/focus-visible.d.ts +0 -13
- package/dist/types/utils/forms/validity.d.ts +0 -7
- package/dist/types/utils/helpers.d.ts +0 -11
- package/dist/types/utils/overlays-interface.d.ts +1 -31
- package/dist/types/utils/overlays.d.ts +12 -10
- package/dist/types/utils/sanitization/index.d.ts +2 -32
- package/dist/types/utils/test/playwright/drag-element.d.ts +3 -16
- package/dist/types/utils/test/playwright/generator.d.ts +2 -31
- package/dist/types/utils/theme.d.ts +0 -9
- package/hydrate/index.js +1292 -5914
- package/hydrate/index.mjs +1292 -5914
- package/package.json +38 -10
- package/components/ion-divider.d.ts +0 -11
- package/components/ion-divider.js +0 -4
- package/components/ion-gallery.d.ts +0 -11
- package/components/ion-gallery.js +0 -4
- package/components/ion-picker-legacy-column.d.ts +0 -11
- package/components/ion-picker-legacy-column.js +0 -4
- package/components/ion-picker-legacy.d.ts +0 -11
- package/components/ion-picker-legacy.js +0 -4
- package/components/p-3Ni1Z654.js +0 -4
- package/components/p-7kL3tltU.js +0 -4
- package/components/p-B9MABkWm.js +0 -4
- package/components/p-BBu2n-9C.js +0 -4
- package/components/p-BDcohALy.js +0 -4
- package/components/p-BDqjX7Z_.js +0 -4
- package/components/p-BJzJdLry.js +0 -4
- package/components/p-BYSs-jZz.js +0 -4
- package/components/p-B_MdONwD.js +0 -4
- package/components/p-BaPtaYEC.js +0 -4
- package/components/p-BcbmT6b3.js +0 -4
- package/components/p-Bg30AtDZ.js +0 -4
- package/components/p-BhkGOA7t.js +0 -4
- package/components/p-BjW8SOqw.js +0 -4
- package/components/p-Bk9hTY4h.js +0 -4
- package/components/p-BqDiJgC_.js +0 -4
- package/components/p-BsNpz2u3.js +0 -4
- package/components/p-BsSTz5ia.js +0 -4
- package/components/p-BwQOIWD7.js +0 -4
- package/components/p-C75FIZBC.js +0 -4
- package/components/p-C8kBejTT.js +0 -4
- package/components/p-CBS0sBAa.js +0 -4
- package/components/p-CUAgUmQC.js +0 -4
- package/components/p-Cg-xpJhD.js +0 -4
- package/components/p-CgSn4J7d.js +0 -4
- package/components/p-CgZLVOCc.js +0 -4
- package/components/p-Cz4uz3Dy.js +0 -4
- package/components/p-CzC_ZSgb.js +0 -4
- package/components/p-D1t981Ih.js +0 -4
- package/components/p-D2mReIu8.js +0 -4
- package/components/p-D6g8ud1e.js +0 -4
- package/components/p-DDw-NYxz.js +0 -4
- package/components/p-DN_scBC7.js +0 -4
- package/components/p-DVcs-2q3.js +0 -4
- package/components/p-DXehWlOr.js +0 -4
- package/components/p-DaJxRxSQ.js +0 -4
- package/components/p-DhXUGFNH.js +0 -4
- package/components/p-Dhi5xtNS.js +0 -4
- package/components/p-Do7NMUwR.js +0 -4
- package/components/p-Dp2x0MpA.js +0 -4
- package/components/p-GElQZ38c.js +0 -4
- package/components/p-GtzfsjJP.js +0 -4
- package/components/p-LB-QPk3e.js +0 -4
- package/components/p-NVAi5HQQ.js +0 -4
- package/components/p-PzmQ86nh.js +0 -4
- package/components/p-Skz67GXZ.js +0 -4
- package/components/p-VVrXfwLZ.js +0 -4
- package/components/p-WdrzoonY.js +0 -4
- package/components/p-XegQjlzJ.js +0 -4
- package/components/p-fIOYmaqA.js +0 -4
- package/components/p-hpwmNJ2Q.js +0 -4
- package/components/p-kKYBfhbe.js +0 -4
- package/components/p-lGSe6-vg.js +0 -4
- package/components/p-pvh0bjpw.js +0 -4
- package/components/p-sToA4Co7.js +0 -4
- package/components/p-vXpMhGrs.js +0 -4
- package/components/p-wCDzv5Q8.js +0 -4
- package/css/ionic/bundle.ionic.css +0 -1
- package/css/ionic/bundle.ionic.css.map +0 -1
- package/css/ionic/core.ionic.css +0 -1
- package/css/ionic/core.ionic.css.map +0 -1
- package/css/ionic/global.bundle.ionic.css +0 -1
- package/css/ionic/global.bundle.ionic.css.map +0 -1
- package/css/ionic/ionic-swiper.ionic.css +0 -1
- package/css/ionic/ionic-swiper.ionic.css.map +0 -1
- package/css/ionic/link.ionic.css +0 -1
- package/css/ionic/link.ionic.css.map +0 -1
- package/css/ionic/structure.ionic.css +0 -1
- package/css/ionic/structure.ionic.css.map +0 -1
- package/css/ionic/typography.ionic.css +0 -1
- package/css/ionic/typography.ionic.css.map +0 -1
- package/css/ionic/utils.bundle.ionic.css +0 -1
- package/css/ionic/utils.bundle.ionic.css.map +0 -1
- package/dist/cjs/caret-down-vtVgfXIs.js +0 -8
- package/dist/cjs/caret-left-CxZXLRv5.js +0 -8
- package/dist/cjs/caret-right-CRCgv98E.js +0 -8
- package/dist/cjs/ion-divider.cjs.entry.js +0 -51
- package/dist/cjs/ion-gallery.cjs.entry.js +0 -510
- package/dist/cjs/ionic-global-BW5tRzrz.js +0 -519
- package/dist/cjs/list-a-7GSA6K.js +0 -8
- package/dist/cjs/overlay-control-label-t9ZFhCtr.js +0 -51
- package/dist/cjs/select-option-render-C72N7OsO.js +0 -111
- package/dist/cjs/validity-QmuwEptc.js +0 -51
- package/dist/cjs/x-BTF99yFH.js +0 -8
- package/dist/collection/components/accordion/accordion.ionic.css +0 -201
- package/dist/collection/components/accordion-group/accordion-group.ionic.css +0 -93
- package/dist/collection/components/action-sheet/action-sheet.ionic.css +0 -439
- package/dist/collection/components/alert/alert.ionic.css +0 -726
- package/dist/collection/components/avatar/avatar.ionic.css +0 -391
- package/dist/collection/components/backdrop/backdrop.ionic.css +0 -109
- package/dist/collection/components/badge/badge.ionic.css +0 -275
- package/dist/collection/components/button/button.ionic.css +0 -646
- package/dist/collection/components/buttons/buttons.ionic.css +0 -97
- package/dist/collection/components/card/card.ionic.css +0 -144
- package/dist/collection/components/card-content/card-content.ionic.css +0 -89
- package/dist/collection/components/card-header/card-header.ionic.css +0 -85
- package/dist/collection/components/card-subtitle/card-subtitle.ionic.css +0 -144
- package/dist/collection/components/checkbox/checkbox.ionic.css +0 -539
- package/dist/collection/components/chip/chip.ionic.css +0 -217
- package/dist/collection/components/datetime/datetime.ionic.css +0 -703
- package/dist/collection/components/divider/divider.ionic.css +0 -148
- package/dist/collection/components/divider/divider.ios.css +0 -87
- package/dist/collection/components/divider/divider.js +0 -94
- package/dist/collection/components/divider/divider.md.css +0 -87
- package/dist/collection/components/gallery/gallery-constants.js +0 -12
- package/dist/collection/components/gallery/gallery-interface.js +0 -1
- package/dist/collection/components/gallery/gallery.css +0 -100
- package/dist/collection/components/gallery/gallery.js +0 -595
- package/dist/collection/components/gallery/test/utils.js +0 -100
- package/dist/collection/components/header/header.ionic.css +0 -97
- package/dist/collection/components/input/input.ionic.css +0 -889
- package/dist/collection/components/input-otp/input-otp.ionic.css +0 -371
- package/dist/collection/components/input-password-toggle/input-password-toggle.ionic.css +0 -78
- package/dist/collection/components/input-password-toggle/input-password-toggle.native.css +0 -61
- package/dist/collection/components/item/item.ionic.css +0 -496
- package/dist/collection/components/item-option/item-option.ionic.css +0 -278
- package/dist/collection/components/item-options/item-options.ionic.css +0 -221
- package/dist/collection/components/item-sliding/item-sliding.ionic.css +0 -211
- package/dist/collection/components/list/list.ionic.css +0 -212
- package/dist/collection/components/list-header/list-header.ionic.css +0 -190
- package/dist/collection/components/menu-button/menu-button.ionic.css +0 -236
- package/dist/collection/components/modal/animations/ionic.enter.js +0 -40
- package/dist/collection/components/modal/animations/ionic.leave.js +0 -28
- package/dist/collection/components/modal/modal.ionic.css +0 -247
- package/dist/collection/components/picker-legacy/animations/ios.enter.js +0 -27
- package/dist/collection/components/picker-legacy/animations/ios.leave.js +0 -23
- package/dist/collection/components/picker-legacy/picker-interface.js +0 -1
- package/dist/collection/components/picker-legacy/picker.ios.css +0 -312
- package/dist/collection/components/picker-legacy/picker.js +0 -891
- package/dist/collection/components/picker-legacy/picker.md.css +0 -299
- package/dist/collection/components/picker-legacy-column/picker-column.ios.css +0 -243
- package/dist/collection/components/picker-legacy-column/picker-column.js +0 -422
- package/dist/collection/components/picker-legacy-column/picker-column.md.css +0 -234
- package/dist/collection/components/picker-legacy-column/test/test.utils.js +0 -43
- package/dist/collection/components/popover/popover.ionic.css +0 -290
- package/dist/collection/components/progress-bar/progress-bar.ionic.css +0 -287
- package/dist/collection/components/radio/radio.ionic.css +0 -422
- package/dist/collection/components/radio-group/radio-group.ionic.css +0 -119
- package/dist/collection/components/range/range.ionic.css +0 -567
- package/dist/collection/components/ripple-effect/ripple-effect.ionic.css +0 -215
- package/dist/collection/components/searchbar/searchbar.ionic.css +0 -626
- package/dist/collection/components/segment/segment.ionic.css +0 -115
- package/dist/collection/components/segment-button/segment-button.ionic.css +0 -353
- package/dist/collection/components/select/select.ionic.css +0 -810
- package/dist/collection/components/select-modal/select-modal.ionic.css +0 -221
- package/dist/collection/components/select-popover/select-popover.ionic.css +0 -220
- package/dist/collection/components/spinner/spinner.native.css +0 -199
- package/dist/collection/components/tab-bar/tab-bar.ionic.css +0 -227
- package/dist/collection/components/tab-button/tab-button.ionic.css +0 -348
- package/dist/collection/components/textarea/textarea.ionic.css +0 -898
- package/dist/collection/components/title/title.ionic.css +0 -127
- package/dist/collection/components/toast/toast.ionic.css +0 -394
- package/dist/collection/components/toggle/toggle.ionic.css +0 -508
- package/dist/collection/components/toolbar/test/image.svg +0 -1
- package/dist/collection/components/toolbar/toolbar.ionic.css +0 -249
- package/dist/collection/utils/css-value-validation.js +0 -25
- package/dist/collection/utils/overlay-control-label.js +0 -46
- package/dist/collection/utils/select-option-render.js +0 -106
- package/dist/esm/caret-down-D1t981Ih.js +0 -6
- package/dist/esm/caret-left-fIOYmaqA.js +0 -6
- package/dist/esm/caret-right-BYSs-jZz.js +0 -6
- package/dist/esm/ion-divider.entry.js +0 -49
- package/dist/esm/ion-gallery.entry.js +0 -508
- package/dist/esm/ionic-global--9mOmThr.js +0 -508
- package/dist/esm/list-Dhi5xtNS.js +0 -6
- package/dist/esm/overlay-control-label-PzmQ86nh.js +0 -48
- package/dist/esm/select-option-render-y_4XoEqH.js +0 -109
- package/dist/esm/validity-BjW8SOqw.js +0 -48
- package/dist/esm/x-BDqjX7Z_.js +0 -6
- package/dist/ionic/p-0030507d.entry.js +0 -4
- package/dist/ionic/p-084c2623.entry.js +0 -4
- package/dist/ionic/p-09f8a57f.entry.js +0 -4
- package/dist/ionic/p-108c0f30.entry.js +0 -4
- package/dist/ionic/p-1439fecb.entry.js +0 -4
- package/dist/ionic/p-199bffb3.entry.js +0 -4
- package/dist/ionic/p-19a1ff9a.entry.js +0 -4
- package/dist/ionic/p-1a026890.entry.js +0 -4
- package/dist/ionic/p-1ad16c09.entry.js +0 -4
- package/dist/ionic/p-2aa7567e.entry.js +0 -4
- package/dist/ionic/p-3656314c.entry.js +0 -4
- package/dist/ionic/p-379cc989.entry.js +0 -4
- package/dist/ionic/p-3f18dfe9.entry.js +0 -4
- package/dist/ionic/p-3f1dbb47.entry.js +0 -4
- package/dist/ionic/p-40d9e029.entry.js +0 -4
- package/dist/ionic/p-410d60c5.entry.js +0 -4
- package/dist/ionic/p-456736d1.entry.js +0 -4
- package/dist/ionic/p-48e3cb9e.entry.js +0 -4
- package/dist/ionic/p-497f6391.entry.js +0 -4
- package/dist/ionic/p-64b4e6eb.entry.js +0 -4
- package/dist/ionic/p-66eb0193.entry.js +0 -4
- package/dist/ionic/p-67c2d349.entry.js +0 -4
- package/dist/ionic/p-7054a1b9.entry.js +0 -4
- package/dist/ionic/p-70ee89c9.entry.js +0 -4
- package/dist/ionic/p-7186786e.entry.js +0 -4
- package/dist/ionic/p-7194f6fa.entry.js +0 -4
- package/dist/ionic/p-76c70824.entry.js +0 -4
- package/dist/ionic/p-7e6112fc.entry.js +0 -4
- package/dist/ionic/p-7f294078.entry.js +0 -4
- package/dist/ionic/p-8458f1b6.entry.js +0 -4
- package/dist/ionic/p-88e7f52a.entry.js +0 -4
- package/dist/ionic/p-89eab395.entry.js +0 -4
- package/dist/ionic/p-93315d96.entry.js +0 -4
- package/dist/ionic/p-9ccfb733.entry.js +0 -4
- package/dist/ionic/p-9dfbe98d.entry.js +0 -4
- package/dist/ionic/p-B4ikoeaj.js +0 -4
- package/dist/ionic/p-BDqjX7Z_.js +0 -4
- package/dist/ionic/p-BFBCtvFI.js +0 -4
- package/dist/ionic/p-BQgCYKKG.js +0 -4
- package/dist/ionic/p-BYAxJDlE.js +0 -4
- package/dist/ionic/p-BYSs-jZz.js +0 -4
- package/dist/ionic/p-BjW8SOqw.js +0 -4
- package/dist/ionic/p-CDn0uNJA.js +0 -4
- package/dist/ionic/p-CHE1xWbg.js +0 -4
- package/dist/ionic/p-CK179dBb.js +0 -4
- package/dist/ionic/p-CLHjFE18.js +0 -4
- package/dist/ionic/p-CYhXBSjd.js +0 -4
- package/dist/ionic/p-D1t981Ih.js +0 -4
- package/dist/ionic/p-D2tu5BUg.js +0 -4
- package/dist/ionic/p-DDFhx1YX.js +0 -4
- package/dist/ionic/p-DNGqaUsl.js +0 -4
- package/dist/ionic/p-DaJxRxSQ.js +0 -4
- package/dist/ionic/p-DaknVxZR.js +0 -4
- package/dist/ionic/p-Dhi5xtNS.js +0 -4
- package/dist/ionic/p-DoyDJ2X5.js +0 -4
- package/dist/ionic/p-E1wtzfO0.js +0 -4
- package/dist/ionic/p-FvDKM4Ax.js +0 -4
- package/dist/ionic/p-IXZW3FBt.js +0 -4
- package/dist/ionic/p-Omi_TcwW.js +0 -5
- package/dist/ionic/p-PoSbs6oh.js +0 -4
- package/dist/ionic/p-PzmQ86nh.js +0 -4
- package/dist/ionic/p-VAJ_3beW.js +0 -4
- package/dist/ionic/p-a3f9be52.entry.js +0 -4
- package/dist/ionic/p-ad4d0138.entry.js +0 -4
- package/dist/ionic/p-b4ba0050.entry.js +0 -4
- package/dist/ionic/p-b4fd91b8.entry.js +0 -4
- package/dist/ionic/p-b653f4c2.entry.js +0 -4
- package/dist/ionic/p-b69add0e.entry.js +0 -4
- package/dist/ionic/p-b7235e85.entry.js +0 -4
- package/dist/ionic/p-bc317965.entry.js +0 -4
- package/dist/ionic/p-bsfLvRbd.js +0 -4
- package/dist/ionic/p-c21a780d.entry.js +0 -4
- package/dist/ionic/p-c5118189.entry.js +0 -4
- package/dist/ionic/p-c684a3b6.entry.js +0 -4
- package/dist/ionic/p-c7139c41.entry.js +0 -4
- package/dist/ionic/p-c94fbdab.entry.js +0 -4
- package/dist/ionic/p-dac1d4de.entry.js +0 -4
- package/dist/ionic/p-dd2981d0.entry.js +0 -4
- package/dist/ionic/p-eTI_FbQJ.js +0 -4
- package/dist/ionic/p-f72200cc.entry.js +0 -4
- package/dist/ionic/p-fIOYmaqA.js +0 -4
- package/dist/ionic/p-fbdbdb3e.entry.js +0 -4
- package/dist/ionic/p-fd519e2b.entry.js +0 -4
- package/dist/ionic/p-ff09d2a5.entry.js +0 -4
- package/dist/ionic/p-u6HLvq0g.js +0 -4
- package/dist/ionic/p-vXpMhGrs.js +0 -4
- package/dist/types/components/divider/divider.d.ts +0 -20
- package/dist/types/components/gallery/gallery-constants.d.ts +0 -9
- package/dist/types/components/gallery/gallery-interface.d.ts +0 -10
- package/dist/types/components/gallery/gallery.d.ts +0 -183
- package/dist/types/components/gallery/test/utils.d.ts +0 -2
- package/dist/types/components/modal/animations/ionic.enter.d.ts +0 -6
- package/dist/types/components/modal/animations/ionic.leave.d.ts +0 -6
- package/dist/types/components/picker-legacy/animations/ios.enter.d.ts +0 -5
- package/dist/types/components/picker-legacy/animations/ios.leave.d.ts +0 -5
- package/dist/types/components/picker-legacy/picker-interface.d.ts +0 -52
- package/dist/types/components/picker-legacy/picker.d.ts +0 -159
- package/dist/types/components/picker-legacy-column/picker-column.d.ts +0 -46
- package/dist/types/components/picker-legacy-column/test/test.utils.d.ts +0 -9
- package/dist/types/utils/css-value-validation.d.ts +0 -12
- package/dist/types/utils/overlay-control-label.d.ts +0 -34
- package/dist/types/utils/select-option-render.d.ts +0 -22
- /package/dist/collection/components/{refresher-content/refresher-content.css → input-password-toggle/input-password-toggle.css} +0 -0
|
@@ -6,7 +6,7 @@ import { focusFirstDescendant, focusLastDescendant, focusableQueryString } from
|
|
|
6
6
|
import { shouldUseCloseWatcher } from "./hardware-back-button";
|
|
7
7
|
import { printIonError, printIonWarning } from "./logging/index";
|
|
8
8
|
import { config } from "../global/config";
|
|
9
|
-
import { getIonMode
|
|
9
|
+
import { getIonMode } 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,10 +39,6 @@ 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');
|
|
46
42
|
export const popoverController = /*@__PURE__*/ createController('ion-popover');
|
|
47
43
|
export const toastController = /*@__PURE__*/ createController('ion-toast');
|
|
48
44
|
/**
|
|
@@ -136,7 +132,7 @@ const focusElementInOverlay = (hostToFocus, overlay) => {
|
|
|
136
132
|
* Should NOT include: Toast
|
|
137
133
|
*/
|
|
138
134
|
const trapKeyboardFocus = (ev, doc) => {
|
|
139
|
-
const lastOverlay = getPresentedOverlay(doc, 'ion-alert,ion-action-sheet,ion-loading,ion-modal,ion-
|
|
135
|
+
const lastOverlay = getPresentedOverlay(doc, 'ion-alert,ion-action-sheet,ion-loading,ion-modal,ion-popover');
|
|
140
136
|
const target = ev.target;
|
|
141
137
|
/**
|
|
142
138
|
* If no active overlay, ignore this event.
|
|
@@ -319,86 +315,6 @@ const connectListeners = (doc) => {
|
|
|
319
315
|
doc.addEventListener('focus', (ev) => {
|
|
320
316
|
trapKeyboardFocus(ev, doc);
|
|
321
317
|
}, 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);
|
|
402
318
|
// handle back-button click
|
|
403
319
|
doc.addEventListener('ionBackButton', (ev) => {
|
|
404
320
|
const lastOverlay = getPresentedOverlay(doc);
|
|
@@ -450,7 +366,7 @@ export const dismissOverlay = (doc, data, role, overlayTag, id) => {
|
|
|
450
366
|
*/
|
|
451
367
|
export const getOverlays = (doc, selector) => {
|
|
452
368
|
if (selector === undefined) {
|
|
453
|
-
selector = 'ion-alert,ion-action-sheet,ion-loading,ion-modal,ion-
|
|
369
|
+
selector = 'ion-alert,ion-action-sheet,ion-loading,ion-modal,ion-popover,ion-toast';
|
|
454
370
|
}
|
|
455
371
|
return Array.from(doc.querySelectorAll(selector)).filter((c) => c.overlayIndex > 0);
|
|
456
372
|
};
|
|
@@ -512,7 +428,30 @@ export const setRootAriaHidden = (hidden = false) => {
|
|
|
512
428
|
viewContainer.removeAttribute('aria-hidden');
|
|
513
429
|
}
|
|
514
430
|
};
|
|
515
|
-
|
|
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) => {
|
|
516
455
|
var _a, _b;
|
|
517
456
|
if (overlay.presented) {
|
|
518
457
|
return;
|
|
@@ -560,15 +499,11 @@ export const present = async (overlay, name, iosEnterAnimation, mdEnterAnimation
|
|
|
560
499
|
document.body.classList.add(BACKDROP_NO_SCROLL);
|
|
561
500
|
}
|
|
562
501
|
(_a = overlay.willPresentShorthand) === null || _a === void 0 ? void 0 : _a.emit();
|
|
563
|
-
const theme = getIonTheme(overlay);
|
|
564
502
|
const mode = getIonMode(overlay);
|
|
565
|
-
const selectedAnimation = mode === 'ios'
|
|
566
|
-
? iosEnterAnimation
|
|
567
|
-
: theme === 'ionic' && ionicEnterAnimation
|
|
568
|
-
? ionicEnterAnimation
|
|
569
|
-
: mdEnterAnimation;
|
|
570
503
|
// get the user's animation fn if one was provided
|
|
571
|
-
const animationBuilder = overlay.enterAnimation
|
|
504
|
+
const animationBuilder = overlay.enterAnimation
|
|
505
|
+
? overlay.enterAnimation
|
|
506
|
+
: config.get(name, mode === 'ios' ? iosEnterAnimation : mdEnterAnimation);
|
|
572
507
|
const completed = await overlayAnimation(overlay, animationBuilder, overlay.el, opts);
|
|
573
508
|
if (completed) {
|
|
574
509
|
overlay.didPresent.emit();
|
|
@@ -723,8 +658,7 @@ export const dismiss = async (overlay, data, role, name, iosLeaveAnimation, mdLe
|
|
|
723
658
|
return true;
|
|
724
659
|
};
|
|
725
660
|
const getAppRoot = (doc) => {
|
|
726
|
-
|
|
727
|
-
return doc.querySelector(appRootSelector) || doc.body;
|
|
661
|
+
return doc.querySelector('ion-app') || doc.body;
|
|
728
662
|
};
|
|
729
663
|
const overlayAnimation = async (overlay, animationBuilder, baseEl, opts) => {
|
|
730
664
|
// Make overlay visible in case it's hidden
|
|
@@ -3,22 +3,8 @@
|
|
|
3
3
|
*/
|
|
4
4
|
import { printIonError } from "../logging/index";
|
|
5
5
|
/**
|
|
6
|
-
*
|
|
7
|
-
*
|
|
8
|
-
* Parses the string into a detached DOM, removes blocked tags, strips
|
|
9
|
-
* attributes outside the strict `allowedAttributes` list, and scrubs
|
|
10
|
-
* `javascript:` URLs. Returns the sanitized HTML string.
|
|
11
|
-
*
|
|
12
|
-
* Use this when you have an HTML string from an unknown source and need
|
|
13
|
-
* to render it via `innerHTML`. Prefer `sanitizeDOMTree` when the source
|
|
14
|
-
* is author-controlled DOM that must keep its component attributes
|
|
15
|
-
* (`size`, `color`, `shape`, etc.).
|
|
16
|
-
*
|
|
17
|
-
* @param untrustedString - The HTML string to sanitize. Pass an
|
|
18
|
-
* `IonicSafeString` to bypass sanitization, or `undefined` to short-circuit.
|
|
19
|
-
* @returns The sanitized HTML string, or `undefined` if the input was
|
|
20
|
-
* `undefined`. Returns `''` if sanitization fails or the input contains
|
|
21
|
-
* an inline `onload=` handler.
|
|
6
|
+
* Does a simple sanitization of all elements
|
|
7
|
+
* in an untrusted string
|
|
22
8
|
*/
|
|
23
9
|
export const sanitizeDOMString = (untrustedString) => {
|
|
24
10
|
try {
|
|
@@ -94,40 +80,13 @@ export const sanitizeDOMString = (untrustedString) => {
|
|
|
94
80
|
return '';
|
|
95
81
|
}
|
|
96
82
|
};
|
|
97
|
-
/**
|
|
98
|
-
* Sanitize an entire author-controlled DOM tree in place.
|
|
99
|
-
*
|
|
100
|
-
* Removes blocked tags (`script`, `iframe`, etc.) from the subtree and
|
|
101
|
-
* then sanitizes attributes on every remaining element. Author-written
|
|
102
|
-
* attributes like `size`, `color`, and `shape` are preserved; event
|
|
103
|
-
* handlers (`on*`) and `javascript:` URLs are stripped.
|
|
104
|
-
*
|
|
105
|
-
* Use this when you have a DOM tree that the developer authored (e.g.
|
|
106
|
-
* cloned slot content from a component) and you need to render it
|
|
107
|
-
* elsewhere safely.
|
|
108
|
-
*
|
|
109
|
-
* @param root - The root element whose subtree will be sanitized in
|
|
110
|
-
* place. No-op when the sanitizer is disabled via `Ionic.config`.
|
|
111
|
-
*/
|
|
112
|
-
export const sanitizeDOMTree = (root) => {
|
|
113
|
-
if (!isSanitizerEnabled()) {
|
|
114
|
-
return;
|
|
115
|
-
}
|
|
116
|
-
blockedTags.forEach((tag) => {
|
|
117
|
-
const matches = root.querySelectorAll(tag);
|
|
118
|
-
for (let i = matches.length - 1; i >= 0; i--) {
|
|
119
|
-
matches[i].remove();
|
|
120
|
-
}
|
|
121
|
-
});
|
|
122
|
-
sanitizeElement(root, true);
|
|
123
|
-
};
|
|
124
83
|
/**
|
|
125
84
|
* Clean up current element based on allowed attributes
|
|
126
85
|
* and then recursively dig down into any child elements to
|
|
127
86
|
* clean those up as well
|
|
128
87
|
*/
|
|
129
88
|
// TODO(FW-2832): type (using Element triggers other type errors as well)
|
|
130
|
-
const sanitizeElement = (element
|
|
89
|
+
const sanitizeElement = (element) => {
|
|
131
90
|
// IE uses childNodes, so ignore nodes that are not elements
|
|
132
91
|
if (element.nodeType && element.nodeType !== 1) {
|
|
133
92
|
return;
|
|
@@ -145,15 +104,8 @@ const sanitizeElement = (element, allowSafeAuthorAttributes = false) => {
|
|
|
145
104
|
for (let i = element.attributes.length - 1; i >= 0; i--) {
|
|
146
105
|
const attribute = element.attributes.item(i);
|
|
147
106
|
const attributeName = attribute.name;
|
|
148
|
-
const lowerName = attributeName.toLowerCase();
|
|
149
107
|
// remove non-allowed attribs
|
|
150
|
-
if (!
|
|
151
|
-
element.removeAttribute(attributeName);
|
|
152
|
-
continue;
|
|
153
|
-
}
|
|
154
|
-
// strip event-handler attributes (already removed by the allowlist
|
|
155
|
-
// when !allowSafeAuthorAttributes; this guards the permissive path)
|
|
156
|
-
if (lowerName.startsWith('on')) {
|
|
108
|
+
if (!allowedAttributes.includes(attributeName.toLowerCase())) {
|
|
157
109
|
element.removeAttribute(attributeName);
|
|
158
110
|
continue;
|
|
159
111
|
}
|
|
@@ -166,13 +118,9 @@ const sanitizeElement = (element, allowSafeAuthorAttributes = false) => {
|
|
|
166
118
|
* such as 	 and still be valid (i.e. java	script)
|
|
167
119
|
*/
|
|
168
120
|
const propertyValue = element[attributeName];
|
|
169
|
-
// Only call .toLowerCase() when propertyValue is a string. Some DOM
|
|
170
|
-
// properties (e.g. `disabled`) are booleans and would throw.
|
|
171
121
|
/* eslint-disable */
|
|
172
122
|
if ((attributeValue != null && attributeValue.toLowerCase().includes('javascript:')) ||
|
|
173
|
-
(propertyValue != null &&
|
|
174
|
-
typeof propertyValue === 'string' &&
|
|
175
|
-
propertyValue.toLowerCase().includes('javascript:'))) {
|
|
123
|
+
(propertyValue != null && propertyValue.toLowerCase().includes('javascript:'))) {
|
|
176
124
|
element.removeAttribute(attributeName);
|
|
177
125
|
}
|
|
178
126
|
/* eslint-enable */
|
|
@@ -183,7 +131,7 @@ const sanitizeElement = (element, allowSafeAuthorAttributes = false) => {
|
|
|
183
131
|
const childElements = getElementChildren(element);
|
|
184
132
|
/* eslint-disable-next-line */
|
|
185
133
|
for (let i = 0; i < childElements.length; i++) {
|
|
186
|
-
sanitizeElement(childElements[i]
|
|
134
|
+
sanitizeElement(childElements[i]);
|
|
187
135
|
}
|
|
188
136
|
};
|
|
189
137
|
/**
|
|
@@ -8,19 +8,7 @@
|
|
|
8
8
|
*
|
|
9
9
|
* See https://playwright.dev/docs/api/class-mouse#mouse-move for more information.
|
|
10
10
|
*/
|
|
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) => {
|
|
11
|
+
export const dragElementBy = async (el, page, dragByX = 0, dragByY = 0, startXCoord, startYCoord, releaseDrag = true) => {
|
|
24
12
|
const boundingBox = await el.boundingBox();
|
|
25
13
|
if (!boundingBox) {
|
|
26
14
|
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');
|
|
@@ -31,18 +19,17 @@ export const dragElementBy = async (el, page, dragByX = 0, dragByY = 0, startXCo
|
|
|
31
19
|
await page.mouse.move(startX, startY);
|
|
32
20
|
await page.mouse.down();
|
|
33
21
|
// Drag the element.
|
|
34
|
-
await moveElement(page, startX, startY, dragByX, dragByY
|
|
22
|
+
await moveElement(page, startX, startY, dragByX, dragByY);
|
|
35
23
|
if (releaseDrag) {
|
|
36
24
|
await page.mouse.up();
|
|
37
25
|
}
|
|
38
26
|
};
|
|
39
27
|
/**
|
|
40
28
|
* Drags an element by the given amount of pixels on the Y axis.
|
|
41
|
-
*
|
|
42
29
|
* @param el The element to drag.
|
|
43
30
|
* @param page The E2E Page object.
|
|
44
|
-
* @param dragByY The
|
|
45
|
-
* @param startYCoord The Y coordinate to start the drag
|
|
31
|
+
* @param dragByY The amount of pixels to drag the element by.
|
|
32
|
+
* @param startYCoord The Y coordinate to start the drag gesture at. Defaults to the center of the element.
|
|
46
33
|
*/
|
|
47
34
|
export const dragElementByYAxis = async (el, page, dragByY, startYCoord) => {
|
|
48
35
|
const boundingBox = await el.boundingBox();
|
|
@@ -84,7 +71,8 @@ const validateDragByY = (startY, dragByY, viewportHeight) => {
|
|
|
84
71
|
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}.`);
|
|
85
72
|
}
|
|
86
73
|
};
|
|
87
|
-
const moveElement = async (page, startX, startY, dragByX = 0, dragByY = 0
|
|
74
|
+
const moveElement = async (page, startX, startY, dragByX = 0, dragByY = 0) => {
|
|
75
|
+
const steps = 10;
|
|
88
76
|
const browser = page.context().browser().browserType().name();
|
|
89
77
|
const viewport = page.viewportSize();
|
|
90
78
|
if (viewport === null) {
|
|
@@ -99,21 +87,10 @@ const moveElement = async (page, startX, startY, dragByX = 0, dragByY = 0, steps
|
|
|
99
87
|
const middleX = startX + (endX - startX) * (i / steps);
|
|
100
88
|
const middleY = startY + (endY - startY) * (i / steps);
|
|
101
89
|
await page.mouse.move(middleX, middleY);
|
|
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
|
-
*/
|
|
90
|
+
// Safari needs to wait for a repaint to occur before moving the mouse again.
|
|
110
91
|
if (browser === 'webkit' && i % 2 === 0) {
|
|
111
|
-
|
|
112
|
-
|
|
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
|
-
*/
|
|
92
|
+
// Repainting every 2 steps is enough to keep the drag gesture smooth.
|
|
93
|
+
// Anything past 4 steps will cause the drag gesture to be flaky.
|
|
117
94
|
await page.evaluate(() => new Promise(requestAnimationFrame));
|
|
118
95
|
}
|
|
119
96
|
}
|
|
@@ -8,56 +8,34 @@
|
|
|
8
8
|
* each test title is unique.
|
|
9
9
|
*/
|
|
10
10
|
const generateTitle = (title, config) => {
|
|
11
|
-
const { direction, palette
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
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}`;
|
|
11
|
+
const { mode, direction, palette } = config;
|
|
12
|
+
if (palette === 'light') {
|
|
13
|
+
/**
|
|
14
|
+
* Ionic has many existing tests that existed prior to
|
|
15
|
+
* the introduction of palette testing. To maintain backwards
|
|
16
|
+
* compatibility, we will not include the palette in the test
|
|
17
|
+
* title if the palette is set to light.
|
|
18
|
+
*/
|
|
19
|
+
return `${title} - ${mode}/${direction}`;
|
|
31
20
|
}
|
|
32
|
-
return `${title} - ${
|
|
21
|
+
return `${title} - ${mode}/${direction}/${palette}`;
|
|
33
22
|
};
|
|
34
23
|
/**
|
|
35
24
|
* Generates a unique filename based on a base filename
|
|
36
25
|
* and a test config.
|
|
37
26
|
*/
|
|
38
27
|
const generateScreenshotName = (fileName, config) => {
|
|
39
|
-
const { direction, palette
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
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`;
|
|
28
|
+
const { mode, direction, palette } = config;
|
|
29
|
+
if (palette === 'light') {
|
|
30
|
+
/**
|
|
31
|
+
* Ionic has many existing tests that existed prior to
|
|
32
|
+
* the introduction of palette testing. To maintain backwards
|
|
33
|
+
* compatibility, we will not include the palette in the screenshot
|
|
34
|
+
* name if the palette is set to light.
|
|
35
|
+
*/
|
|
36
|
+
return `${fileName}-${mode}-${direction}.png`;
|
|
59
37
|
}
|
|
60
|
-
return `${fileName}-${
|
|
38
|
+
return `${fileName}-${mode}-${direction}-${palette}.png`;
|
|
61
39
|
};
|
|
62
40
|
/**
|
|
63
41
|
* Given a config generate an array of test variants.
|
|
@@ -70,16 +48,13 @@ export const configs = (testConfig = DEFAULT_TEST_CONFIG_OPTION) => {
|
|
|
70
48
|
* If certain options are not provided,
|
|
71
49
|
* fall back to the defaults.
|
|
72
50
|
*/
|
|
73
|
-
const
|
|
51
|
+
const processedMode = modes !== null && modes !== void 0 ? modes : DEFAULT_MODES;
|
|
74
52
|
const processedDirection = directions !== null && directions !== void 0 ? directions : DEFAULT_DIRECTIONS;
|
|
75
53
|
const processedPalette = (_a = testConfig.palettes) !== null && _a !== void 0 ? _a : DEFAULT_PALETTES;
|
|
76
|
-
|
|
77
|
-
const [themeOrCombinedMode, modeName] = mode.split('-');
|
|
78
|
-
const parsedTheme = themeOrCombinedMode;
|
|
79
|
-
const parsedMode = modeName !== null && modeName !== void 0 ? modeName : themeOrCombinedMode;
|
|
54
|
+
processedMode.forEach((mode) => {
|
|
80
55
|
processedDirection.forEach((direction) => {
|
|
81
56
|
processedPalette.forEach((palette) => {
|
|
82
|
-
configs.push({ direction, palette
|
|
57
|
+
configs.push({ mode, direction, palette });
|
|
83
58
|
});
|
|
84
59
|
});
|
|
85
60
|
});
|
|
@@ -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;
|
|
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,18 +21,15 @@ configs().forEach(({ config, title }) => {
|
|
|
21
21
|
});`);
|
|
22
22
|
}
|
|
23
23
|
let mode;
|
|
24
|
-
let theme;
|
|
25
24
|
let direction;
|
|
26
25
|
let palette;
|
|
27
26
|
if (options == undefined) {
|
|
28
27
|
mode = testInfo.project.metadata.mode;
|
|
29
|
-
theme = testInfo.project.metadata.theme;
|
|
30
28
|
direction = testInfo.project.metadata.rtl ? 'rtl' : 'ltr';
|
|
31
29
|
palette = testInfo.project.metadata.palette;
|
|
32
30
|
}
|
|
33
31
|
else {
|
|
34
32
|
mode = options.mode;
|
|
35
|
-
theme = options.theme;
|
|
36
33
|
direction = options.direction;
|
|
37
34
|
palette = options.palette;
|
|
38
35
|
}
|
|
@@ -45,15 +42,13 @@ configs().forEach(({ config, title }) => {
|
|
|
45
42
|
*/
|
|
46
43
|
const urlToParams = new URLSearchParams(paramsString);
|
|
47
44
|
const formattedMode = (_a = urlToParams.get('ionic:mode')) !== null && _a !== void 0 ? _a : mode;
|
|
48
|
-
const
|
|
49
|
-
const
|
|
50
|
-
const
|
|
51
|
-
const ionicTesting = (_e = urlToParams.get('ionic:_testing')) !== null && _e !== void 0 ? _e : true;
|
|
45
|
+
const formattedRtl = (_b = urlToParams.get('rtl')) !== null && _b !== void 0 ? _b : rtlString;
|
|
46
|
+
const formattedPalette = (_c = urlToParams.get('palette')) !== null && _c !== void 0 ? _c : palette;
|
|
47
|
+
const ionicTesting = (_d = urlToParams.get('ionic:_testing')) !== null && _d !== void 0 ? _d : true;
|
|
52
48
|
/**
|
|
53
49
|
* Pass through other custom query params
|
|
54
50
|
*/
|
|
55
51
|
urlToParams.delete('ionic:mode');
|
|
56
|
-
urlToParams.delete('ionic:theme');
|
|
57
52
|
urlToParams.delete('rtl');
|
|
58
53
|
urlToParams.delete('palette');
|
|
59
54
|
urlToParams.delete('ionic:_testing');
|
|
@@ -64,15 +59,11 @@ configs().forEach(({ config, title }) => {
|
|
|
64
59
|
*/
|
|
65
60
|
const remainingQueryParams = decodeURIComponent(urlToParams.toString());
|
|
66
61
|
const remainingQueryParamsString = remainingQueryParams == '' ? '' : `&${remainingQueryParams}`;
|
|
67
|
-
const formattedUrl = `${splitUrl[0]}?ionic:_testing=${ionicTesting}&ionic:mode=${formattedMode}&
|
|
62
|
+
const formattedUrl = `${splitUrl[0]}?ionic:_testing=${ionicTesting}&ionic:mode=${formattedMode}&rtl=${formattedRtl}&palette=${formattedPalette}${remainingQueryParamsString}`;
|
|
68
63
|
testInfo.annotations.push({
|
|
69
64
|
type: 'mode',
|
|
70
65
|
description: formattedMode,
|
|
71
66
|
});
|
|
72
|
-
testInfo.annotations.push({
|
|
73
|
-
type: 'theme',
|
|
74
|
-
description: formattedTheme,
|
|
75
|
-
});
|
|
76
67
|
testInfo.annotations.push({
|
|
77
68
|
type: 'direction',
|
|
78
69
|
description: formattedRtl === 'true' ? 'rtl' : 'ltr',
|
|
@@ -18,43 +18,29 @@ export const setContent = async (page, html, testInfo, options) => {
|
|
|
18
18
|
}
|
|
19
19
|
let mode;
|
|
20
20
|
let direction;
|
|
21
|
-
let theme;
|
|
22
21
|
let palette;
|
|
23
22
|
if (options == undefined) {
|
|
24
23
|
mode = testInfo.project.metadata.mode;
|
|
25
24
|
direction = testInfo.project.metadata.rtl ? 'rtl' : 'ltr';
|
|
26
|
-
theme = testInfo.project.metadata.theme;
|
|
27
25
|
palette = testInfo.project.metadata.palette;
|
|
28
26
|
}
|
|
29
27
|
else {
|
|
30
28
|
mode = options.mode;
|
|
31
29
|
direction = options.direction;
|
|
32
|
-
theme = options.theme;
|
|
33
30
|
palette = options.palette;
|
|
34
31
|
}
|
|
35
32
|
const baseUrl = process.env.PLAYWRIGHT_TEST_BASE_URL;
|
|
36
33
|
// The Ionic bundle is included locally by default unless the test
|
|
37
34
|
// config passes in the importIonicFromCDN option. This is useful
|
|
38
35
|
// when testing with the CDN version of Ionic.
|
|
39
|
-
let ionicCSSImports =
|
|
40
|
-
? `
|
|
41
|
-
<link href="${baseUrl}/css/ionic/bundle.ionic.css" rel="stylesheet" />
|
|
42
|
-
<link href="${baseUrl}/css/utils.bundle.css" rel="stylesheet" />
|
|
43
|
-
`
|
|
44
|
-
: `
|
|
36
|
+
let ionicCSSImports = `
|
|
45
37
|
<link href="${baseUrl}/css/ionic.bundle.css" rel="stylesheet" />
|
|
46
38
|
`;
|
|
47
39
|
let ionicJSImports = `
|
|
48
40
|
<script type="module" src="${baseUrl}/dist/ionic/ionic.esm.js"></script>
|
|
49
41
|
`;
|
|
50
42
|
if (options === null || options === void 0 ? void 0 : options.importIonicFromCDN) {
|
|
51
|
-
ionicCSSImports =
|
|
52
|
-
theme === 'ionic'
|
|
53
|
-
? `
|
|
54
|
-
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@ionic/core/css/ionic/bundle.ionic.css" />
|
|
55
|
-
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@ionic/core/css/utils.bundle.css" />
|
|
56
|
-
`
|
|
57
|
-
: `
|
|
43
|
+
ionicCSSImports = `
|
|
58
44
|
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@ionic/core/css/ionic.bundle.css" />
|
|
59
45
|
`;
|
|
60
46
|
ionicJSImports = `
|
|
@@ -77,8 +63,7 @@ export const setContent = async (page, html, testInfo, options) => {
|
|
|
77
63
|
<script>
|
|
78
64
|
window.Ionic = {
|
|
79
65
|
config: {
|
|
80
|
-
mode: '${mode}'
|
|
81
|
-
theme: '${theme}'
|
|
66
|
+
mode: '${mode}'
|
|
82
67
|
}
|
|
83
68
|
}
|
|
84
69
|
</script>
|
|
@@ -88,18 +73,10 @@ export const setContent = async (page, html, testInfo, options) => {
|
|
|
88
73
|
</body>
|
|
89
74
|
</html>
|
|
90
75
|
`;
|
|
91
|
-
testInfo.annotations.push({
|
|
92
|
-
type: 'mode',
|
|
93
|
-
description: mode,
|
|
94
|
-
});
|
|
95
76
|
testInfo.annotations.push({
|
|
96
77
|
type: 'palette',
|
|
97
78
|
description: palette,
|
|
98
79
|
});
|
|
99
|
-
testInfo.annotations.push({
|
|
100
|
-
type: 'theme',
|
|
101
|
-
description: theme,
|
|
102
|
-
});
|
|
103
80
|
if (baseUrl) {
|
|
104
81
|
await page.route(baseUrl, (route) => {
|
|
105
82
|
if (route.request().url() === `${baseUrl}/`) {
|
|
@@ -1,32 +1,8 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* (C) Ionic http://ionicframework.com - MIT License
|
|
3
3
|
*/
|
|
4
|
-
/**
|
|
5
|
-
* Checks if an element has a parent matching the specified selector.
|
|
6
|
-
* This handles an element in both light DOM and shadow DOM contexts.
|
|
7
|
-
* @param selector The parent selector to check for (e.g., 'ion-datetime'
|
|
8
|
-
* or 'ion-toolbar[color]').
|
|
9
|
-
* @param el The element to check.
|
|
10
|
-
* @returns `true` if the element has a parent matching the specified selector,
|
|
11
|
-
* `false` otherwise.
|
|
12
|
-
*/
|
|
13
4
|
export const hostContext = (selector, el) => {
|
|
14
|
-
|
|
15
|
-
if (el.closest(selector) !== null) {
|
|
16
|
-
return true;
|
|
17
|
-
}
|
|
18
|
-
// For attribute or class selectors (e.g., 'ion-toolbar[color]' or
|
|
19
|
-
// 'ion-toolbar.ion-color') we can only check light DOM since tagName
|
|
20
|
-
// doesn't include attributes or classes.
|
|
21
|
-
if (selector.includes('[') || selector.includes('.')) {
|
|
22
|
-
return false;
|
|
23
|
-
}
|
|
24
|
-
// Check the shadow DOM by looking at the shadow root host and
|
|
25
|
-
// converting the selector to uppercase to compare with tagName
|
|
26
|
-
const upperCaseTagName = selector.toUpperCase();
|
|
27
|
-
const rootNode = el.getRootNode();
|
|
28
|
-
const shadowHost = rootNode instanceof ShadowRoot ? rootNode.host : null;
|
|
29
|
-
return (shadowHost === null || shadowHost === void 0 ? void 0 : shadowHost.tagName) === upperCaseTagName;
|
|
5
|
+
return el.closest(selector) !== null;
|
|
30
6
|
};
|
|
31
7
|
/**
|
|
32
8
|
* Create the mode and color classes for the component based on the classes passed in
|
|
@@ -191,7 +191,6 @@ const animateBackButton = (rootAnimation, rtl, backDirection, backButtonEl, back
|
|
|
191
191
|
const clonedBackButtonIconEl = shadow(clonedBackButtonEl).querySelector('ion-icon');
|
|
192
192
|
clonedBackButtonEl.text = backButtonEl.text;
|
|
193
193
|
clonedBackButtonEl.mode = backButtonEl.mode;
|
|
194
|
-
clonedBackButtonEl.theme = backButtonEl.theme;
|
|
195
194
|
clonedBackButtonEl.icon = backButtonEl.icon;
|
|
196
195
|
clonedBackButtonEl.color = backButtonEl.color;
|
|
197
196
|
clonedBackButtonEl.disabled = backButtonEl.disabled;
|