@ionic/core 8.8.9-dev.11780414486.1df2bd72 → 8.8.9-dev.11780493937.17fe092d
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/index.js +1 -1
- package/components/ion-accordion-group.js +1 -1
- package/components/ion-accordion.js +1 -1
- package/components/ion-action-sheet.js +1 -1
- package/components/ion-alert.js +1 -1
- package/components/ion-app.js +1 -1
- package/components/ion-avatar.js +1 -1
- package/components/ion-back-button.js +1 -1
- package/components/ion-backdrop.js +1 -1
- package/components/ion-badge.js +1 -1
- package/components/ion-breadcrumb.js +1 -1
- package/components/ion-breadcrumbs.js +1 -1
- package/components/ion-button.js +1 -1
- package/components/ion-buttons.js +1 -1
- package/components/ion-card-content.js +1 -1
- package/components/ion-card-header.js +1 -1
- package/components/ion-card-subtitle.js +1 -1
- package/components/ion-card-title.js +1 -1
- package/components/ion-card.js +1 -1
- package/components/ion-checkbox.js +1 -1
- package/components/ion-chip.js +1 -1
- package/components/ion-col.js +1 -1
- package/components/ion-content.js +1 -1
- package/components/ion-datetime-button.js +1 -1
- package/components/ion-datetime.js +1 -1
- package/components/ion-divider.d.ts +11 -0
- package/components/ion-divider.js +4 -0
- package/components/ion-fab-button.js +1 -1
- package/components/ion-fab-list.js +1 -1
- package/components/ion-fab.js +1 -1
- package/components/ion-footer.js +1 -1
- package/components/ion-gallery.d.ts +11 -0
- package/components/ion-gallery.js +4 -0
- package/components/ion-grid.js +1 -1
- package/components/ion-header.js +1 -1
- package/components/ion-icon.js +1 -1
- package/components/ion-img.js +1 -1
- package/components/ion-infinite-scroll-content.js +1 -1
- package/components/ion-infinite-scroll.js +1 -1
- package/components/ion-input-otp.js +1 -1
- package/components/ion-input-password-toggle.js +1 -1
- package/components/ion-input.js +1 -1
- package/components/ion-item-divider.js +1 -1
- package/components/ion-item-group.js +1 -1
- package/components/ion-item-option.js +1 -1
- package/components/ion-item-options.js +1 -1
- package/components/ion-item-sliding.js +1 -1
- package/components/ion-item.js +1 -1
- package/components/ion-label.js +1 -1
- package/components/ion-list-header.js +1 -1
- package/components/ion-list.js +1 -1
- package/components/ion-loading.js +1 -1
- package/components/ion-menu-button.js +1 -1
- package/components/ion-menu-toggle.js +1 -1
- package/components/ion-menu.js +1 -1
- package/components/ion-modal.js +1 -1
- package/components/ion-nav-link.js +1 -1
- package/components/ion-nav.js +1 -1
- package/components/ion-note.js +1 -1
- package/components/ion-picker-column-option.js +1 -1
- package/components/ion-picker-column.js +1 -1
- package/components/ion-picker-legacy-column.d.ts +11 -0
- package/components/ion-picker-legacy-column.js +4 -0
- package/components/ion-picker-legacy.d.ts +11 -0
- package/components/ion-picker-legacy.js +4 -0
- package/components/ion-picker.js +1 -1
- package/components/ion-popover.js +1 -1
- package/components/ion-progress-bar.js +1 -1
- package/components/ion-radio-group.js +1 -1
- package/components/ion-radio.js +1 -1
- package/components/ion-range.js +1 -1
- package/components/ion-refresher-content.js +1 -1
- package/components/ion-refresher.js +1 -1
- package/components/ion-reorder-group.js +1 -1
- package/components/ion-reorder.js +1 -1
- package/components/ion-ripple-effect.js +1 -1
- package/components/ion-route-redirect.js +1 -1
- package/components/ion-route.js +1 -1
- package/components/ion-router-link.js +1 -1
- package/components/ion-router-outlet.js +1 -1
- package/components/ion-router.js +1 -1
- package/components/ion-row.js +1 -1
- package/components/ion-searchbar.js +1 -1
- package/components/ion-segment-button.js +1 -1
- package/components/ion-segment-content.js +1 -1
- package/components/ion-segment-view.js +1 -1
- package/components/ion-segment.js +1 -1
- package/components/ion-select-modal.js +1 -1
- package/components/ion-select-option.js +1 -1
- package/components/ion-select-popover.js +1 -1
- package/components/ion-select.js +1 -1
- package/components/ion-skeleton-text.js +1 -1
- package/components/ion-spinner.js +1 -1
- package/components/ion-split-pane.js +1 -1
- package/components/ion-tab-bar.js +1 -1
- package/components/ion-tab-button.js +1 -1
- package/components/ion-tab.js +1 -1
- package/components/ion-tabs.js +1 -1
- package/components/ion-text.js +1 -1
- package/components/ion-textarea.js +1 -1
- package/components/ion-thumbnail.js +1 -1
- package/components/ion-title.js +1 -1
- package/components/ion-toast.js +1 -1
- package/components/ion-toggle.js +1 -1
- package/components/ion-toolbar.js +1 -1
- package/components/p-3Ni1Z654.js +4 -0
- package/components/p-B9MABkWm.js +4 -0
- package/components/p-BBu2n-9C.js +4 -0
- package/components/p-BDcohALy.js +4 -0
- package/components/p-BDqjX7Z_.js +4 -0
- package/components/p-BF5oFX1I.js +4 -0
- package/components/p-BJzJdLry.js +4 -0
- package/components/p-BYSs-jZz.js +4 -0
- package/components/p-BZCB7f49.js +4 -0
- package/components/p-BaPtaYEC.js +4 -0
- package/components/{p-Sh0ICmPV.js → p-BcbmT6b3.js} +1 -1
- package/components/p-Bg30AtDZ.js +4 -0
- package/components/p-BhkGOA7t.js +4 -0
- package/components/p-BjW8SOqw.js +4 -0
- package/components/p-Bk9hTY4h.js +4 -0
- package/components/p-BqDiJgC_.js +4 -0
- package/components/p-BsNpz2u3.js +4 -0
- package/components/p-Bt0d89x3.js +4 -0
- package/components/p-BwKpO3Is.js +4 -0
- package/components/p-BwQOIWD7.js +4 -0
- package/components/{p-D5Ubpm7D.js → p-ByW0kK1F.js} +1 -1
- package/components/p-C0U8YqYW.js +4 -0
- package/components/p-C75FIZBC.js +4 -0
- package/components/p-C8kBejTT.js +4 -0
- package/components/p-CBS0sBAa.js +4 -0
- package/{dist/ionic/p-VAemlbDS.js → components/p-CDgDBcU9.js} +1 -1
- package/components/p-CPm7KgOP.js +4 -0
- package/components/p-Cg-xpJhD.js +4 -0
- package/components/p-CgSn4J7d.js +4 -0
- package/components/p-CgZLVOCc.js +4 -0
- package/{dist/ionic/p-D13Eaw-8.js → components/p-Cllkut-B.js} +1 -1
- package/{dist/ionic/p-DzWaWHGc.js → components/p-Cmql_g3_.js} +1 -1
- package/components/p-CpFORZud.js +4 -0
- package/components/p-Cz4uz3Dy.js +4 -0
- package/components/p-CzC_ZSgb.js +4 -0
- package/components/p-D1t981Ih.js +4 -0
- package/components/p-D2mReIu8.js +4 -0
- package/components/p-D6g8ud1e.js +4 -0
- package/components/p-DAXhdEp5.js +4 -0
- package/components/p-DCS3n7Uq.js +4 -0
- package/components/p-DDw-NYxz.js +4 -0
- package/components/p-DN_scBC7.js +4 -0
- package/components/p-DVcs-2q3.js +4 -0
- package/components/{p-DNQI6d-L.js → p-DXehWlOr.js} +1 -1
- package/components/p-DaJxRxSQ.js +4 -0
- package/components/p-Dhi5xtNS.js +4 -0
- package/components/p-Do7NMUwR.js +4 -0
- package/components/p-Dp2x0MpA.js +4 -0
- package/components/p-GElQZ38c.js +4 -0
- package/components/p-GtzfsjJP.js +4 -0
- package/components/p-IYdTEyGb.js +4 -0
- package/components/p-Skz67GXZ.js +4 -0
- package/components/p-XegQjlzJ.js +4 -0
- package/components/p-d77Zk1DK.js +4 -0
- package/components/p-fIOYmaqA.js +4 -0
- package/components/p-hdGd8ben.js +4 -0
- package/components/p-hpwmNJ2Q.js +4 -0
- package/components/p-kKYBfhbe.js +4 -0
- package/components/p-lGSe6-vg.js +4 -0
- package/components/{p-BAYYcg3o.js → p-oF-CwZ0b.js} +1 -1
- package/components/p-pvh0bjpw.js +4 -0
- package/components/{p-cyNmxje6.js → p-re70ahxF.js} +1 -1
- package/components/p-sToA4Co7.js +4 -0
- package/components/p-vXpMhGrs.js +4 -0
- package/components/{p-ijF0iCrA.js → p-wCDzv5Q8.js} +1 -1
- package/components/{p-DqLB8yFQ.js → p-zWP0sUV_.js} +1 -1
- package/css/core.css +1 -1
- package/css/core.css.map +1 -1
- package/css/display.css +1 -1
- package/css/display.css.map +1 -1
- package/css/flex-utils.css +1 -1
- package/css/flex-utils.css.map +1 -1
- package/css/float-elements.css.map +1 -1
- package/css/global.bundle.css.map +1 -1
- package/css/ionic/bundle.ionic.css +1 -0
- package/css/ionic/bundle.ionic.css.map +1 -0
- package/css/ionic/core.ionic.css +1 -0
- package/css/ionic/core.ionic.css.map +1 -0
- package/css/ionic/global.bundle.ionic.css +1 -0
- package/css/ionic/global.bundle.ionic.css.map +1 -0
- package/css/ionic/ionic-swiper.ionic.css +1 -0
- package/css/ionic/ionic-swiper.ionic.css.map +1 -0
- package/css/ionic/link.ionic.css +1 -0
- package/css/ionic/link.ionic.css.map +1 -0
- package/css/ionic/structure.ionic.css +1 -0
- package/css/ionic/structure.ionic.css.map +1 -0
- package/css/ionic/typography.ionic.css +1 -0
- package/css/ionic/typography.ionic.css.map +1 -0
- package/css/ionic/utils.bundle.ionic.css +1 -0
- package/css/ionic/utils.bundle.ionic.css.map +1 -0
- package/css/ionic-swiper.css +1 -1
- package/css/ionic-swiper.css.map +1 -1
- package/css/ionic.bundle.css +1 -1
- package/css/ionic.bundle.css.map +1 -1
- package/css/normalize.css.map +1 -1
- package/css/padding.css.map +1 -1
- package/css/palettes/dark.always.css.map +1 -1
- package/css/palettes/dark.class.css.map +1 -1
- package/css/palettes/dark.system.css.map +1 -1
- package/css/palettes/high-contrast-dark.always.css.map +1 -1
- package/css/palettes/high-contrast-dark.class.css.map +1 -1
- package/css/palettes/high-contrast-dark.system.css.map +1 -1
- package/css/palettes/high-contrast.always.css.map +1 -1
- package/css/palettes/high-contrast.class.css.map +1 -1
- package/css/palettes/high-contrast.system.css.map +1 -1
- package/css/structure.css.map +1 -1
- package/css/text-alignment.css.map +1 -1
- package/css/text-transformation.css.map +1 -1
- package/css/typography.css.map +1 -1
- package/css/utils.bundle.css +1 -1
- package/css/utils.bundle.css.map +1 -1
- package/dist/cjs/{animation-BJq0kcy2.js → animation-BZJ2wKuM.js} +3 -3
- package/dist/cjs/{app-globals-BlqrqKTN.js → app-globals-C-d5fQ35.js} +1 -1
- package/dist/cjs/{button-active-0mPOKmV2.js → button-active-B_20Nxkv.js} +2 -2
- package/dist/cjs/{capacitor-DmA66EwP.js → capacitor-CXqhdZym.js} +3 -3
- package/dist/cjs/caret-down-vtVgfXIs.js +8 -0
- package/dist/cjs/caret-left-CxZXLRv5.js +8 -0
- package/dist/cjs/caret-right-CRCgv98E.js +8 -0
- package/dist/cjs/config-DWdFbSNK.js +35 -0
- package/dist/cjs/{data-DLTUw-KF.js → data-DuOuKG7I.js} +6 -6
- package/dist/cjs/{focus-visible-CCvKiLh3.js → focus-visible-BIj-I3-C.js} +24 -0
- package/dist/cjs/{framework-delegate-BtICZDHr.js → framework-delegate-Dx9FrqAC.js} +4 -2
- package/dist/cjs/{haptic-ClPPQ_PS.js → haptic-CQJGW58i.js} +1 -1
- package/dist/cjs/{helpers-Cv23MFHM.js → helpers-DJYxKN5U.js} +57 -4
- package/dist/cjs/{config-xninhj0J.js → index-BJlwOs11.js} +1 -31
- package/dist/cjs/{index-CIrkNXqJ.js → index-BJrpF9T3.js} +2 -2
- package/dist/cjs/{index-aC4x3Fk3.js → index-BekUBS8C.js} +15 -15
- package/dist/cjs/{index-DqmRDbxg.js → index-CgAbCW6L.js} +2 -0
- package/dist/cjs/{index-D81eLYUM.js → index-CwxYd6UD.js} +9 -8
- package/dist/cjs/{index-Ct7gcRif.js → index-CzcLEdQ5.js} +64 -71
- package/dist/cjs/{index-BERfRao3.js → index-DSNlrgfO.js} +4 -4
- package/dist/cjs/index.cjs.js +17 -16
- package/dist/cjs/{input-shims-CFLg7uzj.js → input-shims-VyZciSxi.js} +18 -17
- package/dist/cjs/{input.utils-DetjmtH2.js → input.utils-Ct5KzpYv.js} +5 -5
- package/dist/cjs/ion-accordion_2.cjs.entry.js +61 -29
- package/dist/cjs/ion-action-sheet.cjs.entry.js +41 -26
- package/dist/cjs/ion-alert.cjs.entry.js +62 -45
- package/dist/cjs/ion-app_8.cjs.entry.js +568 -189
- package/dist/cjs/ion-avatar_3.cjs.entry.js +125 -13
- package/dist/cjs/ion-back-button.cjs.entry.js +31 -22
- package/dist/cjs/ion-backdrop.cjs.entry.js +10 -7
- package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +54 -18
- package/dist/cjs/ion-button_2.cjs.entry.js +59 -22
- package/dist/cjs/ion-card_5.cjs.entry.js +55 -33
- package/dist/cjs/ion-checkbox.cjs.entry.js +34 -16
- package/dist/cjs/ion-chip.cjs.entry.js +50 -9
- package/dist/cjs/ion-col_3.cjs.entry.js +56 -57
- package/dist/cjs/ion-datetime-button.cjs.entry.js +13 -9
- package/dist/cjs/{ion-datetime.cjs.entry.js → ion-datetime_3.cjs.entry.js} +742 -29
- package/dist/cjs/ion-divider.cjs.entry.js +51 -0
- package/dist/cjs/ion-fab_3.cjs.entry.js +44 -28
- package/dist/cjs/ion-gallery.cjs.entry.js +510 -0
- package/dist/cjs/ion-img.cjs.entry.js +8 -4
- package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +93 -17
- package/dist/cjs/ion-input-otp.cjs.entry.js +74 -9
- package/dist/cjs/ion-input-password-toggle.cjs.entry.js +53 -15
- package/dist/cjs/ion-input.cjs.entry.js +125 -35
- package/dist/cjs/ion-item-option_3.cjs.entry.js +467 -52
- package/dist/cjs/ion-item_8.cjs.entry.js +116 -49
- package/dist/cjs/ion-loading.cjs.entry.js +22 -23
- package/dist/cjs/ion-menu_3.cjs.entry.js +47 -29
- package/dist/cjs/ion-modal.cjs.entry.js +262 -142
- package/dist/cjs/ion-nav_2.cjs.entry.js +14 -11
- package/dist/cjs/ion-picker-column-option.cjs.entry.js +12 -8
- package/dist/cjs/ion-picker-column.cjs.entry.js +14 -14
- package/dist/cjs/ion-picker.cjs.entry.js +10 -6
- package/dist/cjs/ion-popover.cjs.entry.js +21 -23
- package/dist/cjs/ion-progress-bar.cjs.entry.js +27 -9
- package/dist/cjs/ion-radio_2.cjs.entry.js +35 -17
- package/dist/cjs/ion-range.cjs.entry.js +20 -13
- package/dist/cjs/ion-refresher_2.cjs.entry.js +42 -23
- package/dist/cjs/ion-reorder_2.cjs.entry.js +39 -15
- package/dist/cjs/ion-ripple-effect.cjs.entry.js +15 -7
- package/dist/cjs/ion-route_4.cjs.entry.js +10 -9
- package/dist/cjs/ion-searchbar.cjs.entry.js +138 -25
- package/dist/cjs/ion-segment-content.cjs.entry.js +2 -2
- package/dist/cjs/ion-segment-view.cjs.entry.js +13 -3
- package/dist/cjs/ion-segment_2.cjs.entry.js +23 -16
- package/dist/cjs/ion-select-modal.cjs.entry.js +97 -40
- package/dist/cjs/ion-select_3.cjs.entry.js +453 -115
- package/dist/cjs/ion-spinner.cjs.entry.js +30 -8
- package/dist/cjs/ion-split-pane.cjs.entry.js +13 -9
- package/dist/cjs/ion-tab-bar_2.cjs.entry.js +147 -23
- package/dist/cjs/ion-tab_2.cjs.entry.js +8 -7
- package/dist/cjs/ion-text.cjs.entry.js +7 -7
- package/dist/cjs/ion-textarea.cjs.entry.js +137 -23
- package/dist/cjs/ion-toast.cjs.entry.js +71 -47
- package/dist/cjs/ion-toggle.cjs.entry.js +84 -27
- package/dist/cjs/ionic-global-BW5tRzrz.js +519 -0
- package/dist/cjs/ionic.cjs.js +5 -5
- package/dist/cjs/{ios.transition-BOSWOaiK.js → ios.transition-CyNNpj1i.js} +7 -5
- package/dist/cjs/{keyboard-hHzlEQpk.js → keyboard-CA6RtoWx.js} +4 -3
- package/dist/cjs/{keyboard-UuAS4D_9.js → keyboard-VLGMzWBE.js} +1 -1
- package/dist/cjs/{keyboard-controller-GXBiBRKS.js → keyboard-controller-CCTvHp9l.js} +11 -9
- package/dist/cjs/list-a-7GSA6K.js +8 -0
- package/dist/cjs/loader.cjs.js +4 -4
- package/dist/cjs/{md.transition-B8-wBZqt.js → md.transition-BEfrfWKW.js} +6 -5
- package/dist/cjs/{notch-controller-18PzRGXd.js → notch-controller-BTZCPOsd.js} +4 -4
- package/dist/cjs/{overlays-DSmSrd_4.js → overlays-BuMIwR8B.js} +117 -42
- package/dist/cjs/select-option-render-C7klBX2H.js +81 -0
- package/dist/cjs/{status-tap-BXX8H8_Y.js → status-tap-CTY2dMsZ.js} +4 -3
- package/dist/cjs/{swipe-back-C0GCB18x.js → swipe-back-jJFi5KCB.js} +3 -2
- package/dist/cjs/{theme-CeDs6Hcv.js → theme-IlOsGAz7.js} +25 -1
- package/dist/cjs/validity-QmuwEptc.js +51 -0
- package/dist/cjs/x-BTF99yFH.js +8 -0
- package/dist/collection/collection-manifest.json +13 -3
- package/dist/collection/components/accordion/accordion.ionic.css +201 -0
- package/dist/collection/components/accordion/accordion.ios.css +73 -58
- package/dist/collection/components/accordion/accordion.js +41 -27
- package/dist/collection/components/accordion/accordion.md.css +67 -59
- package/dist/collection/components/accordion-group/accordion-group.ionic.css +93 -0
- package/dist/collection/components/accordion-group/accordion-group.ios.css +16 -4
- package/dist/collection/components/accordion-group/accordion-group.js +44 -8
- package/dist/collection/components/accordion-group/accordion-group.md.css +22 -4
- package/dist/collection/components/action-sheet/action-sheet.ionic.css +834 -0
- package/dist/collection/components/action-sheet/action-sheet.ios.css +102 -6
- package/dist/collection/components/action-sheet/action-sheet.js +33 -18
- package/dist/collection/components/action-sheet/action-sheet.md.css +101 -5
- package/dist/collection/components/alert/alert.ionic.css +1165 -0
- package/dist/collection/components/alert/alert.ios.css +102 -1
- package/dist/collection/components/alert/alert.js +52 -35
- package/dist/collection/components/alert/alert.md.css +102 -1
- package/dist/collection/components/app/app.js +15 -83
- package/dist/collection/components/avatar/avatar.ionic.css +391 -0
- package/dist/collection/components/avatar/avatar.ios.css +7 -33
- package/dist/collection/components/avatar/avatar.js +120 -4
- package/dist/collection/components/avatar/avatar.md.css +51 -0
- package/dist/collection/components/back-button/back-button.ios.css +60 -48
- package/dist/collection/components/back-button/back-button.js +27 -19
- package/dist/collection/components/back-button/back-button.md.css +60 -48
- package/dist/collection/components/backdrop/backdrop.ionic.css +109 -0
- package/dist/collection/components/backdrop/backdrop.ios.css +56 -19
- package/dist/collection/components/backdrop/backdrop.js +12 -6
- package/dist/collection/components/backdrop/backdrop.md.css +56 -19
- package/dist/collection/components/badge/badge.ionic.css +275 -0
- package/dist/collection/components/badge/badge.ios.css +139 -12
- package/dist/collection/components/badge/badge.js +145 -9
- package/dist/collection/components/badge/badge.md.css +123 -12
- package/dist/collection/components/breadcrumb/breadcrumb.ios.css +20 -8
- package/dist/collection/components/breadcrumb/breadcrumb.js +43 -11
- package/dist/collection/components/breadcrumb/breadcrumb.md.css +20 -8
- package/dist/collection/components/breadcrumbs/breadcrumbs.ios.css +6 -0
- package/dist/collection/components/breadcrumbs/breadcrumbs.js +11 -9
- package/dist/collection/components/breadcrumbs/breadcrumbs.md.css +6 -0
- package/dist/collection/components/button/button.ionic.css +646 -0
- package/dist/collection/components/button/button.ios.css +154 -46
- package/dist/collection/components/button/button.js +63 -27
- package/dist/collection/components/button/button.md.css +150 -50
- package/dist/collection/components/buttons/buttons.ionic.css +97 -0
- package/dist/collection/components/buttons/buttons.ios.css +59 -7
- package/dist/collection/components/buttons/buttons.js +15 -9
- package/dist/collection/components/buttons/buttons.md.css +55 -3
- package/dist/collection/components/card/card.ionic.css +144 -0
- package/dist/collection/components/card/card.ios.css +65 -14
- package/dist/collection/components/card/card.js +41 -10
- package/dist/collection/components/card/card.md.css +65 -14
- package/dist/collection/components/card-content/card-content.ionic.css +89 -0
- package/dist/collection/components/card-content/card-content.ios.css +20 -35
- package/dist/collection/components/card-content/card-content.js +12 -10
- package/dist/collection/components/card-content/card-content.md.css +20 -35
- package/dist/collection/components/card-header/card-header.ionic.css +85 -0
- package/dist/collection/components/card-header/card-header.ios.css +27 -15
- package/dist/collection/components/card-header/card-header.js +13 -10
- package/dist/collection/components/card-header/card-header.md.css +27 -15
- package/dist/collection/components/card-subtitle/card-subtitle.ionic.css +144 -0
- package/dist/collection/components/card-subtitle/card-subtitle.ios.css +12 -0
- package/dist/collection/components/card-subtitle/card-subtitle.js +11 -8
- package/dist/collection/components/card-subtitle/card-subtitle.md.css +12 -0
- package/dist/collection/components/card-title/card-title.ios.css +73 -0
- package/dist/collection/components/card-title/card-title.js +11 -8
- package/dist/collection/components/card-title/card-title.md.css +73 -0
- package/dist/collection/components/checkbox/checkbox.ionic.css +539 -0
- package/dist/collection/components/checkbox/checkbox.ios.css +161 -101
- package/dist/collection/components/checkbox/checkbox.js +70 -14
- package/dist/collection/components/checkbox/checkbox.md.css +162 -102
- package/dist/collection/components/chip/chip.ionic.css +217 -0
- package/dist/collection/components/chip/chip.ios.css +67 -14
- package/dist/collection/components/chip/chip.js +108 -8
- package/dist/collection/components/chip/chip.md.css +67 -14
- package/dist/collection/components/col/col.css +192 -4
- package/dist/collection/components/col/col.js +211 -61
- package/dist/collection/components/content/content.css +64 -2
- package/dist/collection/components/content/content.js +16 -11
- package/dist/collection/components/datetime/datetime.ionic.css +703 -0
- package/dist/collection/components/datetime/datetime.ios.css +302 -106
- package/dist/collection/components/datetime/datetime.js +98 -20
- package/dist/collection/components/datetime/datetime.md.css +293 -96
- package/dist/collection/components/datetime/utils/data.js +5 -5
- package/dist/collection/components/datetime-button/datetime-button.ios.css +6 -0
- package/dist/collection/components/datetime-button/datetime-button.js +11 -8
- package/dist/collection/components/datetime-button/datetime-button.md.css +6 -0
- package/dist/collection/components/divider/divider.ionic.css +148 -0
- package/dist/collection/components/divider/divider.ios.css +87 -0
- package/dist/collection/components/divider/divider.js +94 -0
- package/dist/collection/components/divider/divider.md.css +87 -0
- package/dist/collection/components/fab/fab.css +25 -1
- package/dist/collection/components/fab/fab.js +9 -5
- package/dist/collection/components/fab-button/fab-button.ios.css +18 -6
- package/dist/collection/components/fab-button/fab-button.js +36 -21
- package/dist/collection/components/fab-button/fab-button.md.css +20 -8
- package/dist/collection/components/fab-list/fab-list.css +12 -0
- package/dist/collection/components/fab-list/fab-list.js +9 -5
- package/dist/collection/components/footer/footer.ios.css +27 -2
- package/dist/collection/components/footer/footer.js +80 -28
- package/dist/collection/components/footer/footer.md.css +25 -0
- package/dist/collection/components/footer/footer.utils.js +9 -0
- package/dist/collection/components/gallery/gallery-constants.js +12 -0
- package/dist/collection/components/gallery/gallery-interface.js +1 -0
- package/dist/collection/components/gallery/gallery.css +100 -0
- package/dist/collection/components/gallery/gallery.js +595 -0
- package/dist/collection/components/gallery/test/utils.js +100 -0
- package/dist/collection/components/grid/grid.css +12 -0
- package/dist/collection/components/grid/grid.js +9 -5
- package/dist/collection/components/header/header.ionic.css +172 -0
- package/dist/collection/components/header/header.ios.css +93 -3
- package/dist/collection/components/header/header.js +87 -26
- package/dist/collection/components/header/header.md.css +91 -1
- package/dist/collection/components/header/header.utils.js +14 -5
- package/dist/collection/components/img/img.js +8 -2
- package/dist/collection/components/infinite-scroll/infinite-scroll.js +100 -5
- package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.ios.css +12 -0
- package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +16 -10
- package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.md.css +12 -0
- package/dist/collection/components/input/input.ionic.css +889 -0
- package/dist/collection/components/input/input.ios.css +223 -135
- package/dist/collection/components/input/input.js +153 -42
- package/dist/collection/components/input/input.md.css +193 -207
- package/dist/collection/components/input-otp/input-otp.ionic.css +371 -0
- package/dist/collection/components/input-otp/input-otp.ios.css +105 -60
- package/dist/collection/components/input-otp/input-otp.js +73 -6
- package/dist/collection/components/input-otp/input-otp.md.css +105 -60
- package/dist/collection/components/input-password-toggle/input-password-toggle.ionic.css +78 -0
- package/dist/collection/components/input-password-toggle/input-password-toggle.js +48 -12
- package/dist/collection/components/input-password-toggle/input-password-toggle.native.css +61 -0
- package/dist/collection/components/item/item.ionic.css +508 -0
- package/dist/collection/components/item/item.ios.css +109 -69
- package/dist/collection/components/item/item.js +51 -20
- package/dist/collection/components/item/item.md.css +120 -68
- package/dist/collection/components/item-divider/item-divider.ios.css +18 -0
- package/dist/collection/components/item-divider/item-divider.js +11 -8
- package/dist/collection/components/item-divider/item-divider.md.css +18 -0
- package/dist/collection/components/item-group/item-group.ios.css +12 -0
- package/dist/collection/components/item-group/item-group.js +13 -7
- package/dist/collection/components/item-group/item-group.md.css +12 -0
- package/dist/collection/components/item-option/item-option.ionic.css +278 -0
- package/dist/collection/components/item-option/item-option.ios.css +136 -29
- package/dist/collection/components/item-option/item-option.js +73 -9
- package/dist/collection/components/item-option/item-option.md.css +136 -29
- package/dist/collection/components/item-options/item-options.ionic.css +221 -0
- package/dist/collection/components/item-options/item-options.ios.css +77 -34
- package/dist/collection/components/item-options/item-options.js +13 -7
- package/dist/collection/components/item-options/item-options.md.css +77 -34
- package/dist/collection/components/item-sliding/item-sliding.ionic.css +211 -0
- package/dist/collection/components/item-sliding/item-sliding.js +421 -35
- package/dist/collection/components/item-sliding/{item-sliding.css → item-sliding.native.css} +84 -9
- package/dist/collection/components/item-sliding/test/test.utils.js +13 -0
- package/dist/collection/components/label/label.ios.css +18 -0
- package/dist/collection/components/label/label.js +11 -8
- package/dist/collection/components/label/label.md.css +18 -0
- package/dist/collection/components/list/list.ionic.css +212 -0
- package/dist/collection/components/list/list.ios.css +54 -14
- package/dist/collection/components/list/list.js +48 -9
- package/dist/collection/components/list/list.md.css +56 -16
- package/dist/collection/components/list-header/list-header.ionic.css +190 -0
- package/dist/collection/components/list-header/list-header.ios.css +82 -38
- package/dist/collection/components/list-header/list-header.js +11 -8
- package/dist/collection/components/list-header/list-header.md.css +82 -38
- package/dist/collection/components/loading/loading.ios.css +13 -1
- package/dist/collection/components/loading/loading.js +15 -16
- package/dist/collection/components/loading/loading.md.css +13 -1
- package/dist/collection/components/menu/menu.ios.css +15 -3
- package/dist/collection/components/menu/menu.js +12 -7
- package/dist/collection/components/menu/menu.md.css +15 -3
- package/dist/collection/components/menu-button/menu-button.ionic.css +236 -0
- package/dist/collection/components/menu-button/menu-button.ios.css +48 -14
- package/dist/collection/components/menu-button/menu-button.js +26 -10
- package/dist/collection/components/menu-button/menu-button.md.css +49 -15
- package/dist/collection/components/menu-toggle/menu-toggle.js +8 -5
- package/dist/collection/components/modal/animations/ionic.enter.js +40 -0
- package/dist/collection/components/modal/animations/ionic.leave.js +28 -0
- package/dist/collection/components/modal/animations/sheet.js +8 -2
- package/dist/collection/components/modal/gestures/sheet.js +76 -10
- package/dist/collection/components/modal/modal.ionic.css +247 -0
- package/dist/collection/components/modal/modal.ios.css +178 -70
- package/dist/collection/components/modal/modal.js +51 -17
- package/dist/collection/components/modal/modal.md.css +178 -70
- package/dist/collection/components/nav/nav.css +7 -1
- package/dist/collection/components/nav/nav.js +11 -5
- package/dist/collection/components/nav-link/nav-link.js +5 -1
- package/dist/collection/components/note/note.ios.css +12 -0
- package/dist/collection/components/note/note.js +11 -8
- package/dist/collection/components/note/note.md.css +12 -0
- package/dist/collection/components/picker/picker.ios.css +15 -3
- package/dist/collection/components/picker/picker.js +8 -5
- package/dist/collection/components/picker/picker.md.css +15 -3
- package/dist/collection/components/picker-column/picker-column.css +9 -2
- package/dist/collection/components/picker-column/picker-column.js +8 -7
- package/dist/collection/components/picker-column-option/picker-column-option.ios.css +6 -0
- package/dist/collection/components/picker-column-option/picker-column-option.js +13 -7
- package/dist/collection/components/picker-column-option/picker-column-option.md.css +6 -0
- package/dist/collection/components/picker-legacy/animations/ios.enter.js +27 -0
- package/dist/collection/components/picker-legacy/animations/ios.leave.js +23 -0
- package/dist/collection/components/picker-legacy/picker-interface.js +1 -0
- package/dist/collection/components/picker-legacy/picker.ios.css +312 -0
- package/dist/collection/components/picker-legacy/picker.js +891 -0
- package/dist/collection/components/picker-legacy/picker.md.css +299 -0
- package/dist/collection/components/picker-legacy-column/picker-column.ios.css +243 -0
- package/dist/collection/components/picker-legacy-column/picker-column.js +422 -0
- package/dist/collection/components/picker-legacy-column/picker-column.md.css +234 -0
- package/dist/collection/components/picker-legacy-column/test/test.utils.js +43 -0
- package/dist/collection/components/popover/popover.ionic.css +290 -0
- package/dist/collection/components/popover/popover.ios.css +29 -1
- package/dist/collection/components/popover/popover.js +19 -20
- package/dist/collection/components/popover/popover.md.css +29 -1
- package/dist/collection/components/progress-bar/progress-bar.ionic.css +287 -0
- package/dist/collection/components/progress-bar/progress-bar.ios.css +48 -17
- package/dist/collection/components/progress-bar/progress-bar.js +43 -7
- package/dist/collection/components/progress-bar/progress-bar.md.css +48 -17
- package/dist/collection/components/radio/radio.ionic.css +422 -0
- package/dist/collection/components/radio/radio.ios.css +134 -91
- package/dist/collection/components/radio/radio.js +15 -10
- package/dist/collection/components/radio/radio.md.css +134 -91
- package/dist/collection/components/radio-group/radio-group.ionic.css +119 -0
- package/dist/collection/components/radio-group/radio-group.ios.css +43 -19
- package/dist/collection/components/radio-group/radio-group.js +48 -7
- package/dist/collection/components/radio-group/radio-group.md.css +43 -19
- package/dist/collection/components/range/range.ionic.css +567 -0
- package/dist/collection/components/range/range.ios.css +128 -85
- package/dist/collection/components/range/range.js +16 -10
- package/dist/collection/components/range/range.md.css +128 -85
- package/dist/collection/components/refresher/refresher.ios.css +14 -1
- package/dist/collection/components/refresher/refresher.js +11 -8
- package/dist/collection/components/refresher/refresher.md.css +15 -2
- package/dist/collection/components/refresher-content/refresher-content.js +28 -7
- package/dist/collection/components/reorder/reorder.ios.css +6 -0
- package/dist/collection/components/reorder/reorder.js +33 -6
- package/dist/collection/components/reorder/reorder.md.css +6 -0
- package/dist/collection/components/reorder-group/reorder-group.css +6 -0
- package/dist/collection/components/reorder-group/reorder-group.js +8 -4
- package/dist/collection/components/ripple-effect/{ripple-effect.css → ripple-effect.common.css} +7 -1
- package/dist/collection/components/ripple-effect/ripple-effect.ionic.css +215 -0
- package/dist/collection/components/ripple-effect/ripple-effect.js +14 -6
- package/dist/collection/components/route/route.js +4 -0
- package/dist/collection/components/router/router.js +4 -0
- package/dist/collection/components/router-link/router-link.css +8 -2
- package/dist/collection/components/router-link/router-link.js +9 -5
- package/dist/collection/components/router-outlet/router-outlet.css +7 -1
- package/dist/collection/components/router-outlet/router-outlet.js +10 -40
- package/dist/collection/components/row/row.css +16 -0
- package/dist/collection/components/row/row.js +9 -2
- package/dist/collection/components/searchbar/searchbar.ionic.css +626 -0
- package/dist/collection/components/searchbar/searchbar.ios.css +56 -18
- package/dist/collection/components/searchbar/searchbar.js +185 -38
- package/dist/collection/components/searchbar/searchbar.md.css +56 -18
- package/dist/collection/components/segment/segment.ionic.css +115 -0
- package/dist/collection/components/segment/segment.ios.css +45 -2
- package/dist/collection/components/segment/segment.js +11 -8
- package/dist/collection/components/segment/segment.md.css +45 -2
- package/dist/collection/components/segment-button/segment-button.ionic.css +353 -0
- package/dist/collection/components/segment-button/segment-button.ios.css +146 -105
- package/dist/collection/components/segment-button/segment-button.js +11 -8
- package/dist/collection/components/segment-button/segment-button.md.css +148 -107
- package/dist/collection/components/segment-content/segment-content.js +1 -1
- package/dist/collection/components/segment-view/segment-view.ios.css +6 -0
- package/dist/collection/components/segment-view/segment-view.js +13 -4
- package/dist/collection/components/segment-view/segment-view.md.css +6 -0
- package/dist/collection/components/select/select.ionic.css +810 -0
- package/dist/collection/components/select/select.ios.css +348 -176
- package/dist/collection/components/select/select.js +434 -97
- package/dist/collection/components/select/select.md.css +364 -178
- package/dist/collection/components/select-modal/select-modal.ionic.css +154 -0
- package/dist/collection/components/select-modal/select-modal.ios.css +95 -0
- package/dist/collection/components/select-modal/select-modal.js +109 -32
- package/dist/collection/components/select-modal/select-modal.md.css +83 -0
- package/dist/collection/components/select-option/select-option.js +32 -2
- package/dist/collection/components/select-popover/select-popover.ionic.css +499 -0
- package/dist/collection/components/select-popover/select-popover.ios.css +100 -0
- package/dist/collection/components/select-popover/select-popover.js +72 -31
- package/dist/collection/components/select-popover/select-popover.md.css +100 -0
- package/dist/collection/components/skeleton-text/skeleton-text.css +6 -0
- package/dist/collection/components/skeleton-text/skeleton-text.js +9 -5
- package/dist/collection/components/spinner/{spinner.css → spinner.ionic.css} +78 -10
- package/dist/collection/components/spinner/spinner.js +47 -6
- package/dist/collection/components/spinner/spinner.native.css +199 -0
- package/dist/collection/components/split-pane/split-pane.ios.css +20 -2
- package/dist/collection/components/split-pane/split-pane.js +16 -9
- package/dist/collection/components/split-pane/split-pane.md.css +20 -2
- package/dist/collection/components/tab/tab.js +6 -2
- package/dist/collection/components/tab-bar/tab-bar.ionic.css +227 -0
- package/dist/collection/components/tab-bar/tab-bar.ios.css +71 -43
- package/dist/collection/components/tab-bar/tab-bar.js +171 -13
- package/dist/collection/components/tab-bar/tab-bar.md.css +71 -43
- package/dist/collection/components/tab-button/tab-button.ionic.css +348 -0
- package/dist/collection/components/tab-button/tab-button.ios.css +171 -95
- package/dist/collection/components/tab-button/tab-button.js +54 -9
- package/dist/collection/components/tab-button/tab-button.md.css +137 -93
- package/dist/collection/components/tabs/tabs.css +7 -1
- package/dist/collection/components/tabs/tabs.js +4 -1
- package/dist/collection/components/text/text.css +6 -0
- package/dist/collection/components/text/text.js +7 -6
- package/dist/collection/components/textarea/textarea.ionic.css +898 -0
- package/dist/collection/components/textarea/textarea.ios.css +298 -158
- package/dist/collection/components/textarea/textarea.js +162 -24
- package/dist/collection/components/textarea/textarea.md.css +312 -159
- package/dist/collection/components/thumbnail/thumbnail.css +6 -0
- package/dist/collection/components/thumbnail/thumbnail.js +9 -2
- package/dist/collection/components/title/title.ionic.css +127 -0
- package/dist/collection/components/title/title.ios.css +32 -4
- package/dist/collection/components/title/title.js +13 -7
- package/dist/collection/components/title/title.md.css +32 -4
- package/dist/collection/components/toast/animations/utils.js +1 -1
- package/dist/collection/components/toast/toast.ionic.css +394 -0
- package/dist/collection/components/toast/toast.ios.css +84 -45
- package/dist/collection/components/toast/toast.js +76 -13
- package/dist/collection/components/toast/toast.md.css +84 -45
- package/dist/collection/components/toggle/toggle.ionic.css +508 -0
- package/dist/collection/components/toggle/toggle.ios.css +247 -131
- package/dist/collection/components/toggle/toggle.js +73 -18
- package/dist/collection/components/toggle/toggle.md.css +244 -131
- package/dist/collection/components/toolbar/test/image.svg +1 -0
- package/dist/collection/components/toolbar/toolbar.ionic.css +249 -0
- package/dist/collection/components/toolbar/toolbar.ios.css +90 -47
- package/dist/collection/components/toolbar/toolbar.js +218 -13
- package/dist/collection/components/toolbar/toolbar.md.css +90 -47
- package/dist/collection/global/ionic-global.js +241 -13
- package/dist/collection/index.js +1 -1
- package/dist/collection/utils/css-value-validation.js +25 -0
- package/dist/collection/utils/focus-trap.js +13 -2
- package/dist/collection/utils/focus-visible.js +22 -0
- package/dist/collection/utils/forms/validity.js +31 -0
- package/dist/collection/utils/framework-delegate.js +3 -1
- package/dist/collection/utils/hardware-back-button.js +15 -0
- package/dist/collection/utils/helpers.js +57 -3
- package/dist/collection/utils/keyboard/keyboard-controller.js +3 -1
- package/dist/collection/utils/media.js +1 -0
- package/dist/collection/utils/menu-controller/animations/overlay.js +3 -3
- package/dist/collection/utils/menu-controller/animations/push.js +2 -1
- package/dist/collection/utils/menu-controller/animations/reveal.js +2 -1
- package/dist/collection/utils/on-scroll/collapse-hide.utils.js +168 -0
- package/dist/collection/utils/overlays.js +97 -31
- package/dist/collection/utils/select-option-render.js +76 -0
- package/dist/collection/utils/test/playwright/drag-element.js +32 -9
- package/dist/collection/utils/test/playwright/generator.js +48 -23
- package/dist/collection/utils/test/playwright/page/utils/goto.js +14 -5
- package/dist/collection/utils/test/playwright/page/utils/set-content.js +26 -3
- package/dist/collection/utils/theme.js +25 -1
- package/dist/collection/utils/transition/ios.transition.js +1 -0
- package/dist/docs.json +10163 -690
- package/dist/esm/{animation-DLJpuoEz.js → animation-Cd1EA2ar.js} +2 -2
- package/dist/esm/{app-globals-D0C5S4hU.js → app-globals-9x_U7ofY.js} +1 -1
- package/dist/esm/{button-active-BSpTQmS9.js → button-active-B016u5N-.js} +2 -2
- package/dist/esm/{capacitor-CFERIeaU.js → capacitor-13SFuT1K.js} +1 -1
- package/dist/esm/caret-down-D1t981Ih.js +6 -0
- package/dist/esm/caret-left-fIOYmaqA.js +6 -0
- package/dist/esm/caret-right-BYSs-jZz.js +6 -0
- package/dist/esm/config-BwKpO3Is.js +31 -0
- package/dist/esm/{data-DZI70dKr.js → data-BNKYavC3.js} +6 -6
- package/dist/esm/{focus-visible-BmVRXR1y.js → focus-visible-vXpMhGrs.js} +23 -1
- package/dist/esm/{framework-delegate-FnPGymXL.js → framework-delegate-CjVwn_KZ.js} +4 -2
- package/dist/esm/{haptic-DzAMWJuk.js → haptic-CbnKC3go.js} +1 -1
- package/dist/esm/{helpers-HEqiOzXb.js → helpers-Do7zwvM1.js} +58 -5
- package/dist/esm/{index-B_dQk_WE.js → index-B2VWavcK.js} +4 -4
- package/dist/esm/{index-Q6UPU0Ay.js → index-BWMvrRiE.js} +11 -11
- package/dist/esm/{index-MEDq2S8l.js → index-BmkLokUL.js} +2 -2
- package/dist/esm/{index-AlrZKoWR.js → index-D2tu5BUg.js} +2 -1
- package/dist/esm/{index-BRHzoo00.js → index-D3WueHpT.js} +4 -3
- package/dist/esm/{config-DQCONYYp.js → index-D4ugF_sT.js} +2 -29
- package/dist/esm/{index-tcQvqkiX.js → index-Omi_TcwW.js} +64 -71
- package/dist/esm/index.js +14 -14
- package/dist/esm/{input-shims-D10mwcw1.js → input-shims-DU23z7Hg.js} +7 -6
- package/dist/esm/{input.utils-Y6NgW8bw.js → input.utils-C64RbLd_.js} +3 -3
- package/dist/esm/ion-accordion_2.entry.js +61 -29
- package/dist/esm/ion-action-sheet.entry.js +41 -26
- package/dist/esm/ion-alert.entry.js +61 -44
- package/dist/esm/ion-app_8.entry.js +568 -189
- package/dist/esm/ion-avatar_3.entry.js +125 -13
- package/dist/esm/ion-back-button.entry.js +31 -22
- package/dist/esm/ion-backdrop.entry.js +10 -7
- package/dist/esm/ion-breadcrumb_2.entry.js +54 -18
- package/dist/esm/ion-button_2.entry.js +59 -22
- package/dist/esm/ion-card_5.entry.js +55 -33
- package/dist/esm/ion-checkbox.entry.js +34 -16
- package/dist/esm/ion-chip.entry.js +50 -9
- package/dist/esm/ion-col_3.entry.js +56 -57
- package/dist/esm/ion-datetime-button.entry.js +13 -9
- package/dist/esm/{ion-datetime.entry.js → ion-datetime_3.entry.js} +741 -30
- package/dist/esm/ion-divider.entry.js +49 -0
- package/dist/esm/ion-fab_3.entry.js +44 -28
- package/dist/esm/ion-gallery.entry.js +508 -0
- package/dist/esm/ion-img.entry.js +8 -4
- package/dist/esm/ion-infinite-scroll_2.entry.js +92 -16
- package/dist/esm/ion-input-otp.entry.js +74 -9
- package/dist/esm/ion-input-password-toggle.entry.js +53 -15
- package/dist/esm/ion-input.entry.js +125 -35
- package/dist/esm/ion-item-option_3.entry.js +467 -52
- package/dist/esm/ion-item_8.entry.js +116 -49
- package/dist/esm/ion-loading.entry.js +21 -22
- package/dist/esm/ion-menu_3.entry.js +47 -29
- package/dist/esm/ion-modal.entry.js +215 -95
- package/dist/esm/ion-nav_2.entry.js +14 -11
- package/dist/esm/ion-picker-column-option.entry.js +12 -8
- package/dist/esm/ion-picker-column.entry.js +13 -13
- package/dist/esm/ion-picker.entry.js +10 -6
- package/dist/esm/ion-popover.entry.js +21 -23
- package/dist/esm/ion-progress-bar.entry.js +27 -9
- package/dist/esm/ion-radio_2.entry.js +35 -17
- package/dist/esm/ion-range.entry.js +20 -13
- package/dist/esm/ion-refresher_2.entry.js +40 -21
- package/dist/esm/ion-reorder_2.entry.js +39 -15
- package/dist/esm/ion-ripple-effect.entry.js +15 -7
- package/dist/esm/ion-route_4.entry.js +10 -9
- package/dist/esm/ion-searchbar.entry.js +138 -25
- package/dist/esm/ion-segment-content.entry.js +2 -2
- package/dist/esm/ion-segment-view.entry.js +13 -3
- package/dist/esm/ion-segment_2.entry.js +23 -16
- package/dist/esm/ion-select-modal.entry.js +97 -40
- package/dist/esm/ion-select_3.entry.js +454 -116
- package/dist/esm/ion-spinner.entry.js +30 -8
- package/dist/esm/ion-split-pane.entry.js +13 -9
- package/dist/esm/ion-tab-bar_2.entry.js +147 -23
- package/dist/esm/ion-tab_2.entry.js +8 -7
- package/dist/esm/ion-text.entry.js +7 -7
- package/dist/esm/ion-textarea.entry.js +137 -23
- package/dist/esm/ion-toast.entry.js +46 -22
- package/dist/esm/ion-toggle.entry.js +84 -27
- package/dist/esm/ionic-global--9mOmThr.js +508 -0
- package/dist/esm/ionic.js +6 -6
- package/dist/esm/{ios.transition-ClFrsIrS.js → ios.transition-DoQTN5Jk.js} +7 -5
- package/dist/esm/{keyboard-ywgs5efA.js → keyboard-Ca1zVCcH.js} +4 -3
- package/dist/esm/{keyboard-CUw4ekVy.js → keyboard-Dnno7-Ci.js} +1 -1
- package/dist/esm/{keyboard-controller-BaaVITYt.js → keyboard-controller-BpOdk6xN.js} +5 -3
- package/dist/esm/list-Dhi5xtNS.js +6 -0
- package/dist/esm/loader.js +5 -5
- package/dist/esm/{md.transition-D0msQmzI.js → md.transition-DZydrWwq.js} +6 -5
- package/dist/esm/{notch-controller-DKDjU_O7.js → notch-controller-klgNWpjJ.js} +2 -2
- package/dist/esm/{overlays-DLNOHWNc.js → overlays-CpQ6Df2g.js} +114 -39
- package/dist/esm/select-option-render-B2qc5ZP7.js +79 -0
- package/dist/esm/{status-tap-Kan2W7sh.js → status-tap-fYFdZg6z.js} +4 -3
- package/dist/esm/{swipe-back-DQ1q5MgD.js → swipe-back-BzGqTrrq.js} +3 -2
- package/dist/esm/{theme-DiVJyqlX.js → theme-DaJxRxSQ.js} +25 -1
- package/dist/esm/validity-BjW8SOqw.js +48 -0
- package/dist/esm/x-BDqjX7Z_.js +6 -0
- package/dist/html.html-data.json +2660 -145
- package/dist/ionic/index.esm.js +1 -1
- package/dist/ionic/ionic.esm.js +1 -1
- package/dist/ionic/p-0030507d.entry.js +4 -0
- package/dist/ionic/p-031df892.entry.js +4 -0
- package/dist/ionic/p-04b5794c.entry.js +4 -0
- package/dist/ionic/p-084c2623.entry.js +4 -0
- package/dist/ionic/p-09f8a57f.entry.js +4 -0
- package/dist/ionic/p-108c0f30.entry.js +4 -0
- package/dist/ionic/p-1439fecb.entry.js +4 -0
- package/dist/ionic/p-199bffb3.entry.js +4 -0
- package/dist/ionic/p-19a1ff9a.entry.js +4 -0
- package/dist/ionic/p-1a026890.entry.js +4 -0
- package/dist/ionic/p-1ad16c09.entry.js +4 -0
- package/dist/ionic/p-2aa7567e.entry.js +4 -0
- package/dist/ionic/p-3656314c.entry.js +4 -0
- package/dist/ionic/p-379cc989.entry.js +4 -0
- package/dist/ionic/p-3f18dfe9.entry.js +4 -0
- package/dist/ionic/p-40d9e029.entry.js +4 -0
- package/dist/ionic/p-44d483c2.entry.js +4 -0
- package/dist/ionic/p-456736d1.entry.js +4 -0
- package/dist/ionic/p-48e3cb9e.entry.js +4 -0
- package/dist/ionic/p-497f6391.entry.js +4 -0
- package/dist/ionic/p-52ed96a8.entry.js +4 -0
- package/dist/ionic/p-64b4e6eb.entry.js +4 -0
- package/dist/ionic/p-66eb0193.entry.js +4 -0
- package/dist/ionic/p-67c2d349.entry.js +4 -0
- package/dist/ionic/p-7054a1b9.entry.js +4 -0
- package/dist/ionic/p-7186786e.entry.js +4 -0
- package/dist/ionic/p-7194f6fa.entry.js +4 -0
- package/dist/ionic/p-76c70824.entry.js +4 -0
- package/dist/ionic/p-7f294078.entry.js +4 -0
- package/dist/ionic/p-8458f1b6.entry.js +4 -0
- package/dist/ionic/p-88048796.entry.js +4 -0
- package/dist/ionic/p-88e7f52a.entry.js +4 -0
- package/dist/ionic/p-89eab395.entry.js +4 -0
- package/dist/ionic/p-93315d96.entry.js +4 -0
- package/dist/ionic/p-9ccfb733.entry.js +4 -0
- package/dist/ionic/p-9dfbe98d.entry.js +4 -0
- package/{components/p-BT_5jSqG.js → dist/ionic/p-B2-sg7NJ.js} +1 -1
- package/dist/ionic/p-B4ikoeaj.js +4 -0
- package/dist/ionic/p-BDqjX7Z_.js +4 -0
- package/dist/ionic/p-BFBCtvFI.js +4 -0
- package/dist/ionic/p-BQgCYKKG.js +4 -0
- package/dist/ionic/p-BYAxJDlE.js +4 -0
- package/dist/ionic/p-BYSs-jZz.js +4 -0
- package/dist/ionic/p-BjW8SOqw.js +4 -0
- package/dist/ionic/{p-CKvCXMs9.js → p-BmEwy3tY.js} +1 -1
- package/dist/ionic/p-BwKpO3Is.js +4 -0
- package/dist/ionic/{p-DAAFkPFT.js → p-C8IHbcuP.js} +1 -1
- package/dist/ionic/p-CDn0uNJA.js +4 -0
- package/dist/ionic/p-CFjI63GE.js +4 -0
- package/dist/ionic/p-CHE1xWbg.js +4 -0
- package/dist/ionic/p-CK179dBb.js +4 -0
- package/dist/ionic/p-CWJdc8f_.js +4 -0
- package/dist/ionic/p-CYhXBSjd.js +4 -0
- package/{components/p-D13Eaw-8.js → dist/ionic/p-CuGhCBt7.js} +1 -1
- package/dist/ionic/p-D1t981Ih.js +4 -0
- package/dist/ionic/p-D2tu5BUg.js +4 -0
- package/dist/ionic/p-DDFhx1YX.js +4 -0
- package/dist/ionic/{p-Wk5HzclC.js → p-DKWXAwlR.js} +1 -1
- package/dist/ionic/p-DNGqaUsl.js +4 -0
- package/dist/ionic/p-DaJxRxSQ.js +4 -0
- package/dist/ionic/p-DaknVxZR.js +4 -0
- package/dist/ionic/p-Dhi5xtNS.js +4 -0
- package/dist/ionic/p-DoyDJ2X5.js +4 -0
- package/dist/ionic/p-E1wtzfO0.js +4 -0
- package/dist/ionic/p-FvDKM4Ax.js +4 -0
- package/dist/ionic/p-IXZW3FBt.js +4 -0
- package/dist/ionic/p-Omi_TcwW.js +5 -0
- package/dist/ionic/p-PoSbs6oh.js +4 -0
- package/dist/ionic/p-VAJ_3beW.js +4 -0
- package/dist/ionic/p-a3f9be52.entry.js +4 -0
- package/dist/ionic/p-ad4d0138.entry.js +4 -0
- package/dist/ionic/p-b4fd91b8.entry.js +4 -0
- package/dist/ionic/p-b653f4c2.entry.js +4 -0
- package/dist/ionic/p-b69add0e.entry.js +4 -0
- package/dist/ionic/p-b7235e85.entry.js +4 -0
- package/dist/ionic/p-bc317965.entry.js +4 -0
- package/dist/ionic/p-bf0c5a8d.entry.js +4 -0
- package/dist/ionic/p-bsfLvRbd.js +4 -0
- package/dist/ionic/p-c0558552.entry.js +4 -0
- package/dist/ionic/p-c684a3b6.entry.js +4 -0
- package/dist/ionic/p-c7139c41.entry.js +4 -0
- package/dist/ionic/p-dac1d4de.entry.js +4 -0
- package/dist/ionic/p-dd2981d0.entry.js +4 -0
- package/dist/ionic/p-eTI_FbQJ.js +4 -0
- package/dist/ionic/p-f08edb25.entry.js +4 -0
- package/dist/ionic/p-f167c55c.entry.js +4 -0
- package/dist/ionic/p-f7ca50a5.entry.js +4 -0
- package/dist/ionic/p-fIOYmaqA.js +4 -0
- package/dist/ionic/p-fbdbdb3e.entry.js +4 -0
- package/dist/ionic/p-ff09d2a5.entry.js +4 -0
- package/dist/ionic/p-vXpMhGrs.js +4 -0
- package/dist/types/components/accordion/accordion.d.ts +6 -3
- package/dist/types/components/accordion-group/accordion-group.d.ts +12 -1
- package/dist/types/components/action-sheet/action-sheet-interface.d.ts +3 -7
- package/dist/types/components/action-sheet/action-sheet.d.ts +3 -2
- package/dist/types/components/alert/alert-interface.d.ts +3 -7
- package/dist/types/components/alert/alert.d.ts +3 -2
- package/dist/types/components/app/app.d.ts +4 -5
- package/dist/types/components/avatar/avatar.d.ts +32 -0
- package/dist/types/components/back-button/back-button.d.ts +2 -1
- package/dist/types/components/backdrop/backdrop.d.ts +4 -0
- package/dist/types/components/badge/badge.d.ts +34 -1
- package/dist/types/components/breadcrumb/breadcrumb.d.ts +4 -1
- package/dist/types/components/breadcrumbs/breadcrumbs.d.ts +2 -2
- package/dist/types/components/button/button.d.ts +23 -8
- package/dist/types/components/buttons/buttons.d.ts +5 -1
- package/dist/types/components/card/card.d.ts +8 -1
- package/dist/types/components/card-content/card-content.d.ts +2 -1
- package/dist/types/components/card-header/card-header.d.ts +3 -2
- package/dist/types/components/card-subtitle/card-subtitle.d.ts +2 -1
- package/dist/types/components/card-title/card-title.d.ts +2 -1
- package/dist/types/components/checkbox/checkbox.d.ts +14 -4
- package/dist/types/components/chip/chip.d.ts +26 -1
- package/dist/types/components/col/col.d.ts +52 -5
- package/dist/types/components/content/content.d.ts +3 -0
- package/dist/types/components/datetime/datetime.d.ts +26 -1
- package/dist/types/components/datetime/utils/data.d.ts +5 -5
- package/dist/types/components/datetime-button/datetime-button.d.ts +2 -1
- package/dist/types/components/divider/divider.d.ts +20 -0
- package/dist/types/components/fab/fab.d.ts +4 -0
- package/dist/types/components/fab-button/fab-button.d.ts +5 -3
- package/dist/types/components/fab-list/fab-list.d.ts +4 -0
- package/dist/types/components/footer/footer.d.ts +15 -4
- package/dist/types/components/footer/footer.utils.d.ts +1 -0
- package/dist/types/components/gallery/gallery-constants.d.ts +9 -0
- package/dist/types/components/gallery/gallery-interface.d.ts +10 -0
- package/dist/types/components/gallery/gallery.d.ts +183 -0
- package/dist/types/components/gallery/test/utils.d.ts +2 -0
- package/dist/types/components/grid/grid.d.ts +4 -0
- package/dist/types/components/header/header.d.ts +18 -5
- package/dist/types/components/header/header.utils.d.ts +4 -3
- package/dist/types/components/img/img.d.ts +3 -0
- package/dist/types/components/infinite-scroll/infinite-scroll.d.ts +21 -0
- package/dist/types/components/infinite-scroll-content/infinite-scroll-content.d.ts +4 -0
- package/dist/types/components/input/input.d.ts +32 -6
- package/dist/types/components/input-otp/input-otp.d.ts +37 -0
- package/dist/types/components/input-password-toggle/input-password-toggle.d.ts +2 -0
- package/dist/types/components/item/item.d.ts +11 -4
- package/dist/types/components/item-divider/item-divider.d.ts +2 -1
- package/dist/types/components/item-group/item-group.d.ts +4 -0
- package/dist/types/components/item-option/item-option.d.ts +18 -1
- package/dist/types/components/item-options/item-options.d.ts +4 -0
- package/dist/types/components/item-sliding/item-sliding.d.ts +47 -1
- package/dist/types/components/item-sliding/test/test.utils.d.ts +13 -0
- package/dist/types/components/label/label.d.ts +2 -1
- package/dist/types/components/list/list.d.ts +15 -1
- package/dist/types/components/list-header/list-header.d.ts +2 -1
- package/dist/types/components/loading/loading-interface.d.ts +2 -7
- package/dist/types/components/loading/loading.d.ts +3 -2
- package/dist/types/components/menu/menu.d.ts +3 -0
- package/dist/types/components/menu-button/menu-button.d.ts +3 -1
- package/dist/types/components/menu-toggle/menu-toggle.d.ts +3 -0
- package/dist/types/components/modal/animations/ionic.enter.d.ts +6 -0
- package/dist/types/components/modal/animations/ionic.leave.d.ts +6 -0
- package/dist/types/components/modal/gestures/sheet.d.ts +1 -1
- package/dist/types/components/modal/modal-interface.d.ts +4 -7
- package/dist/types/components/modal/modal.d.ts +11 -1
- package/dist/types/components/nav/nav-interface.d.ts +9 -1
- package/dist/types/components/nav/nav.d.ts +5 -1
- package/dist/types/components/nav-link/nav-link.d.ts +4 -0
- package/dist/types/components/note/note.d.ts +2 -1
- package/dist/types/components/picker/picker.d.ts +2 -1
- package/dist/types/components/picker-column/picker-column.d.ts +2 -1
- package/dist/types/components/picker-column-option/picker-column-option.d.ts +4 -0
- package/dist/types/components/picker-legacy/animations/ios.enter.d.ts +5 -0
- package/dist/types/components/picker-legacy/animations/ios.leave.d.ts +5 -0
- package/dist/types/components/picker-legacy/picker-interface.d.ts +52 -0
- package/dist/types/components/picker-legacy/picker.d.ts +159 -0
- package/dist/types/components/picker-legacy-column/picker-column.d.ts +46 -0
- package/dist/types/components/picker-legacy-column/test/test.utils.d.ts +9 -0
- package/dist/types/components/popover/popover-interface.d.ts +3 -6
- package/dist/types/components/popover/popover.d.ts +6 -5
- package/dist/types/components/progress-bar/progress-bar.d.ts +10 -1
- package/dist/types/components/radio/radio.d.ts +2 -1
- package/dist/types/components/radio-group/radio-group.d.ts +12 -0
- package/dist/types/components/range/range.d.ts +2 -1
- package/dist/types/components/refresher/refresher.d.ts +2 -1
- package/dist/types/components/refresher-content/refresher-content.d.ts +4 -0
- package/dist/types/components/reorder/reorder.d.ts +9 -0
- package/dist/types/components/reorder-group/reorder-group.d.ts +4 -0
- package/dist/types/components/ripple-effect/ripple-effect.d.ts +4 -0
- package/dist/types/components/route/route.d.ts +4 -0
- package/dist/types/components/router/router.d.ts +4 -0
- package/dist/types/components/router-link/router-link.d.ts +4 -0
- package/dist/types/components/router-outlet/router-outlet.d.ts +4 -8
- package/dist/types/components/row/row.d.ts +4 -0
- package/dist/types/components/searchbar/searchbar.d.ts +52 -10
- package/dist/types/components/segment/segment.d.ts +2 -1
- package/dist/types/components/segment-button/segment-button.d.ts +2 -1
- package/dist/types/components/select/select-interface.d.ts +23 -0
- package/dist/types/components/select/select.d.ts +66 -14
- package/dist/types/components/select-modal/select-modal.d.ts +8 -0
- package/dist/types/components/select-option/select-option.d.ts +12 -0
- package/dist/types/components/select-popover/select-popover.d.ts +3 -0
- package/dist/types/components/skeleton-text/skeleton-text.d.ts +4 -0
- package/dist/types/components/spinner/spinner.d.ts +15 -0
- package/dist/types/components/split-pane/split-pane.d.ts +4 -0
- package/dist/types/components/tab/tab.d.ts +4 -0
- package/dist/types/components/tab-bar/tab-bar.d.ts +37 -2
- package/dist/types/components/tab-button/tab-button.d.ts +12 -1
- package/dist/types/components/tabs/tabs.d.ts +3 -0
- package/dist/types/components/text/text.d.ts +2 -1
- package/dist/types/components/textarea/textarea.d.ts +53 -4
- package/dist/types/components/thumbnail/thumbnail.d.ts +4 -0
- package/dist/types/components/title/title.d.ts +4 -0
- package/dist/types/components/toast/animations/utils.d.ts +2 -2
- package/dist/types/components/toast/toast-interface.d.ts +3 -7
- package/dist/types/components/toast/toast.d.ts +19 -2
- package/dist/types/components/toggle/toggle.d.ts +15 -1
- package/dist/types/components/toolbar/toolbar.d.ts +43 -3
- package/dist/types/components.d.ts +2126 -267
- package/dist/types/global/ionic-global.d.ts +28 -2
- package/dist/types/index.d.ts +1 -1
- package/dist/types/interface.d.ts +4 -0
- package/dist/types/stencil-public-runtime.d.ts +1 -4
- package/dist/types/utils/config.d.ts +114 -2
- package/dist/types/utils/css-value-validation.d.ts +12 -0
- package/dist/types/utils/focus-trap.d.ts +1 -1
- package/dist/types/utils/focus-visible.d.ts +13 -0
- package/dist/types/utils/forms/validity.d.ts +7 -0
- package/dist/types/utils/helpers.d.ts +11 -0
- package/dist/types/utils/on-scroll/collapse-hide.utils.d.ts +26 -0
- package/dist/types/utils/overlays-interface.d.ts +31 -1
- package/dist/types/utils/overlays.d.ts +10 -12
- package/dist/types/utils/select-option-render.d.ts +22 -0
- package/dist/types/utils/test/playwright/drag-element.d.ts +16 -3
- package/dist/types/utils/test/playwright/generator.d.ts +31 -2
- package/dist/types/utils/theme.d.ts +9 -0
- package/hydrate/index.js +6522 -2329
- package/hydrate/index.mjs +6522 -2329
- package/package.json +12 -40
- package/components/p--JUspHvy.js +0 -4
- package/components/p-B8U2xbtx.js +0 -4
- package/components/p-B9jFTlwE.js +0 -4
- package/components/p-BTPfOxsU.js +0 -4
- package/components/p-Baq1XyAy.js +0 -4
- package/components/p-BhmadOit.js +0 -4
- package/components/p-BirPFsRD.js +0 -4
- package/components/p-BjfgFSSR.js +0 -4
- package/components/p-BmVRXR1y.js +0 -4
- package/components/p-BnqQlm7c.js +0 -4
- package/components/p-BtVHN9Na.js +0 -4
- package/components/p-Bz0dSlXZ.js +0 -4
- package/components/p-C1aScSTo.js +0 -4
- package/components/p-C4t5ymfq.js +0 -4
- package/components/p-CHqRYvYm.js +0 -4
- package/components/p-CHzfYZbv.js +0 -4
- package/components/p-CI3ncNZm.js +0 -4
- package/components/p-CIGNaXM1.js +0 -4
- package/components/p-CO7fmmxt.js +0 -4
- package/components/p-CSZf8_j0.js +0 -4
- package/components/p-C_xFdyXe.js +0 -4
- package/components/p-Ciz1-FuE.js +0 -4
- package/components/p-Ck2wcXbv.js +0 -4
- package/components/p-CmR5uXej.js +0 -4
- package/components/p-CtWGkNnJ.js +0 -4
- package/components/p-CtukzcyX.js +0 -4
- package/components/p-D6Ynv7Xh.js +0 -4
- package/components/p-D7bSXQD3.js +0 -4
- package/components/p-DEBD4LvH.js +0 -4
- package/components/p-DH50pr9O.js +0 -4
- package/components/p-DIE4pXMl.js +0 -4
- package/components/p-DJztqcrH.js +0 -4
- package/components/p-DOFCbuQR.js +0 -4
- package/components/p-DhkITZ-y.js +0 -4
- package/components/p-DiVJyqlX.js +0 -4
- package/components/p-DmpBvltk.js +0 -4
- package/components/p-DnL1c9_X.js +0 -4
- package/components/p-DpV-p5Xs.js +0 -4
- package/components/p-DqZAXv2t.js +0 -4
- package/components/p-Dz74mwlk.js +0 -4
- package/components/p-W5nO8mX_.js +0 -4
- package/components/p-XJWMAP8m.js +0 -4
- package/components/p-ZjP4CjeZ.js +0 -4
- package/components/p-djQLE88P.js +0 -4
- package/components/p-j5IxBIan.js +0 -4
- package/components/p-k_E4tX5Z.js +0 -4
- package/components/p-lE_JGpHD.js +0 -4
- package/components/p-r0aq7dpt.js +0 -4
- package/components/p-ryqmO0B-.js +0 -4
- package/components/p-wk2QqrAo.js +0 -4
- package/dist/cjs/hardware-back-button-iUuF_76h.js +0 -121
- package/dist/cjs/index-DkNv4J_i.js +0 -10
- package/dist/cjs/ionic-global-B-cA6LkY.js +0 -151
- package/dist/cjs/validity-BpS37YFM.js +0 -19
- package/dist/esm/hardware-back-button-B93Gru0Y.js +0 -115
- package/dist/esm/index-ZjP4CjeZ.js +0 -7
- package/dist/esm/ionic-global-Cp_eT4sZ.js +0 -146
- package/dist/esm/validity-DJztqcrH.js +0 -17
- package/dist/ionic/p-03aa786d.entry.js +0 -4
- package/dist/ionic/p-06c232a4.entry.js +0 -4
- package/dist/ionic/p-11684553.entry.js +0 -4
- package/dist/ionic/p-1ae21e4c.entry.js +0 -4
- package/dist/ionic/p-20b1a044.entry.js +0 -4
- package/dist/ionic/p-259d0d98.entry.js +0 -4
- package/dist/ionic/p-2a6d6565.entry.js +0 -4
- package/dist/ionic/p-341032b3.entry.js +0 -4
- package/dist/ionic/p-3e91d32e.entry.js +0 -4
- package/dist/ionic/p-441fbb13.entry.js +0 -4
- package/dist/ionic/p-4502a274.entry.js +0 -4
- package/dist/ionic/p-4621c387.entry.js +0 -4
- package/dist/ionic/p-4bb3eb60.entry.js +0 -4
- package/dist/ionic/p-4e92a11f.entry.js +0 -4
- package/dist/ionic/p-50e1194a.entry.js +0 -4
- package/dist/ionic/p-51cd1643.entry.js +0 -4
- package/dist/ionic/p-5c3ec490.entry.js +0 -4
- package/dist/ionic/p-627fabd9.entry.js +0 -4
- package/dist/ionic/p-629e4703.entry.js +0 -4
- package/dist/ionic/p-76e92a84.entry.js +0 -4
- package/dist/ionic/p-7a37b3ce.entry.js +0 -4
- package/dist/ionic/p-7aed7726.entry.js +0 -4
- package/dist/ionic/p-7ebd980c.entry.js +0 -4
- package/dist/ionic/p-80b44b3c.entry.js +0 -4
- package/dist/ionic/p-81ea5652.entry.js +0 -4
- package/dist/ionic/p-8c8eee7d.entry.js +0 -4
- package/dist/ionic/p-8d624ee5.entry.js +0 -4
- package/dist/ionic/p-8d6fd502.entry.js +0 -4
- package/dist/ionic/p-9177f4ac.entry.js +0 -4
- package/dist/ionic/p-9c6a5a8d.entry.js +0 -4
- package/dist/ionic/p-9eeaBrnk.js +0 -4
- package/dist/ionic/p-AlrZKoWR.js +0 -4
- package/dist/ionic/p-BGqMS-oh.js +0 -4
- package/dist/ionic/p-BUFIpxKM.js +0 -4
- package/dist/ionic/p-BmVRXR1y.js +0 -4
- package/dist/ionic/p-CFlfIb2g.js +0 -4
- package/dist/ionic/p-CIGNaXM1.js +0 -4
- package/dist/ionic/p-Cg5-OQYy.js +0 -4
- package/dist/ionic/p-CtWGkNnJ.js +0 -4
- package/dist/ionic/p-Cx3IXROA.js +0 -4
- package/dist/ionic/p-D4uTWt4-.js +0 -4
- package/dist/ionic/p-DC3RagnA.js +0 -4
- package/dist/ionic/p-DIuEbVLu.js +0 -4
- package/dist/ionic/p-DJztqcrH.js +0 -4
- package/dist/ionic/p-DSG2s2Eb.js +0 -4
- package/dist/ionic/p-Dfbt-q2k.js +0 -4
- package/dist/ionic/p-DiVJyqlX.js +0 -4
- package/dist/ionic/p-DoJvtrbw.js +0 -4
- package/dist/ionic/p-KjNvRoEp.js +0 -4
- package/dist/ionic/p-Nqf6uvGh.js +0 -4
- package/dist/ionic/p-SNAkTDfm.js +0 -4
- package/dist/ionic/p-ZjP4CjeZ.js +0 -4
- package/dist/ionic/p-a2e51c5d.entry.js +0 -4
- package/dist/ionic/p-a3bdcae6.entry.js +0 -4
- package/dist/ionic/p-a44b7536.entry.js +0 -4
- package/dist/ionic/p-a5213260.entry.js +0 -4
- package/dist/ionic/p-a7628bc7.entry.js +0 -4
- package/dist/ionic/p-b1599fca.entry.js +0 -4
- package/dist/ionic/p-b16be471.entry.js +0 -4
- package/dist/ionic/p-b6a7397c.entry.js +0 -4
- package/dist/ionic/p-b9ac1fe0.entry.js +0 -4
- package/dist/ionic/p-c6e49f3f.entry.js +0 -4
- package/dist/ionic/p-c93553d2.entry.js +0 -4
- package/dist/ionic/p-d2c7f046.entry.js +0 -4
- package/dist/ionic/p-d8387b99.entry.js +0 -4
- package/dist/ionic/p-d8ac9eea.entry.js +0 -4
- package/dist/ionic/p-db1b6738.entry.js +0 -4
- package/dist/ionic/p-dfa8d673.entry.js +0 -4
- package/dist/ionic/p-ed797c72.entry.js +0 -4
- package/dist/ionic/p-ef93ca92.entry.js +0 -4
- package/dist/ionic/p-f09f9642.entry.js +0 -4
- package/dist/ionic/p-f1c06f82.entry.js +0 -4
- package/dist/ionic/p-f386f6ae.entry.js +0 -4
- package/dist/ionic/p-fe4aa1db.entry.js +0 -4
- package/dist/ionic/p-mjKAFv89.js +0 -4
- package/dist/ionic/p-tcQvqkiX.js +0 -5
- package/dist/ionic/p-viFHDgRs.js +0 -4
- package/dist/ionic/p-xWb6fgfq.js +0 -4
- /package/dist/collection/components/{input-password-toggle/input-password-toggle.css → refresher-content/refresher-content.css} +0 -0
|
@@ -3,19 +3,23 @@
|
|
|
3
3
|
*/
|
|
4
4
|
'use strict';
|
|
5
5
|
|
|
6
|
-
var index = require('./index-
|
|
7
|
-
var
|
|
8
|
-
var
|
|
9
|
-
var
|
|
6
|
+
var index = require('./index-CzcLEdQ5.js');
|
|
7
|
+
var caretLeft = require('./caret-left-CxZXLRv5.js');
|
|
8
|
+
var caretRight = require('./caret-right-CRCgv98E.js');
|
|
9
|
+
var focusVisible = require('./focus-visible-BIj-I3-C.js');
|
|
10
|
+
var helpers = require('./helpers-DJYxKN5U.js');
|
|
11
|
+
var overlays = require('./overlays-BuMIwR8B.js');
|
|
10
12
|
var dir = require('./dir-Cn0z1rJH.js');
|
|
11
|
-
var theme = require('./theme-
|
|
12
|
-
var index$1 = require('./index-
|
|
13
|
-
var ionicGlobal = require('./ionic-global-
|
|
14
|
-
var data = require('./data-
|
|
15
|
-
require('./
|
|
16
|
-
require('./
|
|
17
|
-
require('./
|
|
13
|
+
var theme = require('./theme-IlOsGAz7.js');
|
|
14
|
+
var index$1 = require('./index-CgAbCW6L.js');
|
|
15
|
+
var ionicGlobal = require('./ionic-global-BW5tRzrz.js');
|
|
16
|
+
var data = require('./data-DuOuKG7I.js');
|
|
17
|
+
var lockController = require('./lock-controller-aDB9wrEf.js');
|
|
18
|
+
var animation = require('./animation-BZJ2wKuM.js');
|
|
19
|
+
var haptic = require('./haptic-CQJGW58i.js');
|
|
20
|
+
require('./framework-delegate-Dx9FrqAC.js');
|
|
18
21
|
require('./gesture-controller-dtqlP_q4.js');
|
|
22
|
+
require('./capacitor-CXqhdZym.js');
|
|
19
23
|
|
|
20
24
|
const isYearDisabled = (refYear, minParts, maxParts) => {
|
|
21
25
|
if (minParts && minParts.year > refYear) {
|
|
@@ -227,9 +231,11 @@ const checkForPresentationFormatMismatch = (el, presentation, formatOptions) =>
|
|
|
227
231
|
}
|
|
228
232
|
};
|
|
229
233
|
|
|
230
|
-
const datetimeIosCss = () => `:host{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;background:var(--background);overflow:hidden}:host(.datetime-size-fixed){width:auto;height:auto}:host(.datetime-size-fixed:not(.datetime-prefer-wheel)){max-width:350px}:host(.datetime-size-fixed.datetime-prefer-wheel){min-width:350px;max-width:-webkit-max-content;max-width:-moz-max-content;max-width:max-content}:host(.datetime-size-cover){width:100%}:host .calendar-body,:host .datetime-year{opacity:0}:host(:not(.datetime-ready)) .datetime-year{position:absolute;pointer-events:none}:host(.datetime-ready) .calendar-body{opacity:1}:host(.datetime-ready) .datetime-year{display:none;opacity:1}:host .wheel-order-year-first .day-column{-ms-flex-order:3;order:3;text-align:end}:host .wheel-order-year-first .month-column{-ms-flex-order:2;order:2;text-align:end}:host .wheel-order-year-first .year-column{-ms-flex-order:1;order:1;text-align:start}:host .datetime-calendar,:host .datetime-year{display:-ms-flexbox;display:flex;-ms-flex:1 1 auto;flex:1 1 auto;-ms-flex-flow:column;flex-flow:column}:host(.show-month-and-year) .datetime-year{display:-ms-flexbox;display:flex}:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{display:none}:host(.month-year-picker-open) .datetime-footer{display:none}:host(.datetime-disabled){pointer-events:none}:host(.datetime-disabled) .calendar-days-of-week,:host(.datetime-disabled) .datetime-time{opacity:0.4}:host(.datetime-readonly){pointer-events:none;}:host(.datetime-readonly) .calendar-action-buttons,:host(.datetime-readonly) .calendar-body,:host(.datetime-readonly) .datetime-year{pointer-events:initial}:host(.datetime-readonly) .calendar-day[disabled]:not(.calendar-day-constrained),:host(.datetime-readonly) .datetime-action-buttons ion-button[disabled]{opacity:1}:host .datetime-header .datetime-title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}:host .datetime-action-buttons.has-clear-button{width:100%}:host .datetime-action-buttons ion-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}.datetime-action-buttons .datetime-action-buttons-container{display:-ms-flexbox;display:flex}:host .calendar-action-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host .calendar-action-buttons ion-button{--background:transparent}:host .calendar-days-of-week{display:grid;grid-template-columns:repeat(7, 1fr);text-align:center}.calendar-days-of-week .day-of-week{-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto;margin-top:0;margin-bottom:0}:host .calendar-body{display:-ms-flexbox;display:flex;-ms-flex-positive:1;flex-grow:1;-webkit-scroll-snap-type:x mandatory;-ms-scroll-snap-type:x mandatory;scroll-snap-type:x mandatory;overflow-x:scroll;overflow-y:hidden;scrollbar-width:none;outline:none}:host .calendar-body .calendar-month{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;scroll-snap-align:start;scroll-snap-stop:always;-ms-flex-negative:0;flex-shrink:0;width:100%}:host .calendar-body .calendar-month-disabled{scroll-snap-align:none}:host .calendar-body::-webkit-scrollbar{display:none}:host .calendar-body .calendar-month-grid{display:grid;grid-template-columns:repeat(7, 1fr)}:host .calendar-day-wrapper{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;min-width:0;min-height:0;overflow:visible}.calendar-day{border-radius:50%;-webkit-padding-start:0px;padding-inline-start:0px;-webkit-padding-end:0px;padding-inline-end:0px;padding-top:0px;padding-bottom:0px;-webkit-margin-start:0px;margin-inline-start:0px;-webkit-margin-end:0px;margin-inline-end:0px;margin-top:0px;margin-bottom:0px;display:-ms-flexbox;display:flex;position:relative;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;border:none;outline:none;background:none;color:currentColor;font-family:var(--ion-font-family, inherit);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;z-index:0}:host .calendar-day[disabled]{pointer-events:none;opacity:0.4}.calendar-day:not(.calendar-day-adjacent-day):focus{background:rgba(var(--ion-color-base-rgb), 0.2);-webkit-box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2);box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2)}:host .datetime-time{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host(.datetime-presentation-time) .datetime-time{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0}:host ion-popover{--height:200px}:host .time-header{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}:host .time-body{border-radius:8px;-webkit-padding-start:12px;padding-inline-start:12px;-webkit-padding-end:12px;padding-inline-end:12px;padding-top:6px;padding-bottom:6px;display:-ms-flexbox;display:flex;border:none;background:var(--ion-color-step-300, var(--ion-background-color-step-300, #edeef0));color:var(--ion-text-color, #000);font-family:inherit;font-size:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}:host .time-body-active{color:var(--ion-color-base)}:host(.in-item){position:static}:host(.show-month-and-year) .calendar-action-buttons .calendar-month-year-toggle{color:var(--ion-color-base)}.calendar-month-year{min-width:0}.calendar-month-year-toggle{font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;text-align:inherit;white-space:inherit;color:inherit;position:relative;border:0;outline:none;background:transparent;cursor:pointer;z-index:1}.calendar-month-year-toggle::after{left:0;right:0;top:0;bottom:0;position:absolute;content:"";opacity:0;-webkit-transition:opacity 15ms linear, background-color 15ms linear;transition:opacity 15ms linear, background-color 15ms linear;z-index:-1}.calendar-month-year-toggle.ion-focused::after{background:currentColor}.calendar-month-year-toggle:disabled{opacity:0.3;pointer-events:none}.calendar-month-year-toggle ion-icon{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:0;padding-inline-end:0;padding-top:0;padding-bottom:0;-ms-flex-negative:0;flex-shrink:0}.calendar-month-year-toggle #toggle-wrapper{display:-ms-inline-flexbox;display:inline-flex;-ms-flex-align:center;align-items:center}ion-picker{--highlight-background:var(--wheel-highlight-background);--highlight-border-radius:var(--wheel-highlight-border-radius);--fade-background-rgb:var(--wheel-fade-background-rgb)}:host{--background:var(--ion-color-light, #f4f5f8);--background-rgb:var(--ion-color-light-rgb, 244, 245, 248);--title-color:var(--ion-color-step-600, var(--ion-text-color-step-400, #666666))}:host(.datetime-presentation-date-time:not(.datetime-prefer-wheel)),:host(.datetime-presentation-time-date:not(.datetime-prefer-wheel)),:host(.datetime-presentation-date:not(.datetime-prefer-wheel)){min-height:350px}:host .datetime-header{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:16px;padding-bottom:16px;border-bottom:0.55px solid var(--ion-color-step-200, var(--ion-background-color-step-200, #cccccc));font-size:min(0.875rem, 22.4px)}:host .datetime-header .datetime-title{color:var(--title-color)}:host .datetime-header .datetime-selected-date{margin-top:10px}.calendar-month-year-toggle{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:0px;padding-bottom:0px;min-height:44px;font-size:min(1rem, 25.6px);font-weight:600}.calendar-month-year-toggle.ion-focused::after{opacity:0.15}.calendar-month-year-toggle #toggle-wrapper{-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:8px;margin-inline-end:8px;margin-top:10px;margin-bottom:10px}:host .calendar-action-buttons .calendar-month-year-toggle ion-icon,:host .calendar-action-buttons ion-buttons ion-button{color:var(--ion-color-base)}:host .calendar-action-buttons ion-buttons{-ms-flex-align:stretch;align-items:stretch;height:100%}:host .calendar-action-buttons ion-buttons ion-button{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}:host .calendar-days-of-week{-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px;padding-top:0;padding-bottom:0;color:var(--ion-color-step-300, var(--ion-text-color-step-700, #b3b3b3));font-size:min(0.75rem, 19.2px);font-weight:600;line-height:24px;text-transform:uppercase}@supports (border-radius: mod(1px, 1px)){.calendar-days-of-week .day-of-week{width:clamp(20px, calc(mod(min(1rem, 24px), 24px) * 10), 100%);height:24px;overflow:hidden}.calendar-day{border-radius:max(8px, mod(min(1rem, 24px), 24px) * 10)}}@supports ((border-radius: mod(1px, 1px)) and (background: -webkit-named-image(apple-pay-logo-black)) and (not (contain-intrinsic-size: none))) or (not (border-radius: mod(1px, 1px))){.calendar-days-of-week .day-of-week{width:auto;height:auto;overflow:initial}.calendar-day{border-radius:32px}}:host .calendar-body .calendar-month .calendar-month-grid{-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px;padding-top:8px;padding-bottom:8px;-ms-flex-align:center;align-items:center;height:calc(100% - 16px)}:host .calendar-day-wrapper{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:4px;padding-inline-end:4px;padding-top:4px;padding-bottom:4px;height:0;min-height:1rem}:host .calendar-day{width:40px;min-width:40px;height:40px;font-size:min(1.25rem, 32px)}.calendar-day.calendar-day-active{background:rgba(var(--ion-color-base-rgb), 0.2);font-size:min(1.375rem, 35.2px)}:host .calendar-day.calendar-day-today{color:var(--ion-color-base)}:host .calendar-day.calendar-day-active,:host .calendar-day.calendar-day-adjacent-day.calendar-day-active{color:var(--ion-color-base);font-weight:600}:host .calendar-day.calendar-day-today.calendar-day-active{background:var(--ion-color-base);color:var(--ion-color-contrast)}:host .calendar-day.calendar-day-adjacent-day{color:var(--ion-color-step-300, var(--ion-text-color-step-700, #b3b3b3))}:host .datetime-time{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:8px;padding-bottom:16px;font-size:min(1rem, 25.6px)}:host .datetime-time .time-header{font-weight:600}:host .datetime-buttons{-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px;padding-top:8px;padding-bottom:8px;border-top:0.55px solid var(--ion-color-step-200, var(--ion-background-color-step-200, #cccccc))}:host .datetime-buttons ::slotted(ion-buttons),:host .datetime-buttons ion-buttons{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:justify;justify-content:space-between}:host .datetime-action-buttons{width:100%}`;
|
|
234
|
+
const datetimeIonicCss = () => `:host{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;background:var(--background);overflow:hidden}:host(.datetime-size-fixed){width:auto;height:auto}:host(.datetime-size-cover){width:100%}:host(:not(.datetime-ready)) .datetime-year{position:absolute;pointer-events:none}:host(.datetime-ready) .datetime-year{display:none}:host .wheel-order-year-first .day-column{-ms-flex-order:3;order:3;text-align:end}:host .wheel-order-year-first .month-column{-ms-flex-order:2;order:2;text-align:end}:host .wheel-order-year-first .year-column{-ms-flex-order:1;order:1;text-align:start}:host .datetime-calendar,:host .datetime-year{display:-ms-flexbox;display:flex;-ms-flex:1 1 auto;flex:1 1 auto;-ms-flex-flow:column;flex-flow:column}:host(.show-month-and-year) .datetime-year{display:-ms-flexbox;display:flex}:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{display:none}:host(.month-year-picker-open) .datetime-footer{display:none}:host(.datetime-disabled){pointer-events:none}:host(.datetime-disabled) .calendar-days-of-week,:host(.datetime-disabled) .datetime-time{opacity:0.4}:host(.datetime-readonly){pointer-events:none;}:host(.datetime-readonly) .calendar-action-buttons,:host(.datetime-readonly) .calendar-body,:host(.datetime-readonly) .datetime-year{pointer-events:initial}:host(.datetime-readonly) .calendar-day[disabled]:not(.calendar-day-constrained),:host(.datetime-readonly) .datetime-action-buttons ion-button[disabled]{opacity:1}:host .datetime-header .datetime-title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}:host .datetime-action-buttons.has-clear-button{width:100%}:host .datetime-action-buttons,::slotted([slot=buttons]),.datetime-action-buttons .datetime-action-buttons-container{display:-ms-flexbox;display:flex}:host .calendar-action-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host .calendar-days-of-week{display:grid;grid-template-columns:repeat(7, 1fr);text-align:center}.calendar-days-of-week .day-of-week{-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto;margin-top:0;margin-bottom:0}:host .calendar-body{display:-ms-flexbox;display:flex;-ms-flex-positive:1;flex-grow:1;-webkit-scroll-snap-type:x mandatory;-ms-scroll-snap-type:x mandatory;scroll-snap-type:x mandatory;overflow-x:scroll;overflow-y:hidden;scrollbar-width:none;outline:none}:host .calendar-body .calendar-month{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;scroll-snap-align:start;scroll-snap-stop:always;-ms-flex-negative:0;flex-shrink:0;width:100%}:host .calendar-body .calendar-month-disabled{scroll-snap-align:none}:host .calendar-body::-webkit-scrollbar{display:none}:host .calendar-body .calendar-month-grid{display:grid;grid-template-columns:repeat(7, 1fr)}:host .calendar-day-wrapper{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;min-width:0;min-height:0;overflow:visible}.calendar-day{-webkit-padding-start:0px;padding-inline-start:0px;-webkit-padding-end:0px;padding-inline-end:0px;padding-top:0px;padding-bottom:0px;-webkit-margin-start:0px;margin-inline-start:0px;-webkit-margin-end:0px;margin-inline-end:0px;margin-top:0px;margin-bottom:0px;display:-ms-flexbox;display:flex;position:relative;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;border:none;outline:none;background:none;color:currentColor;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;z-index:0}.calendar-day[disabled]{pointer-events:none}:host .datetime-time{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host .time-header{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}:host .time-body{display:-ms-flexbox;display:flex;border:none;font-family:inherit;font-size:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}:host(.in-item){position:static}.calendar-month-year{min-width:0}.calendar-month-year-toggle{color:inherit;font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-align:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;white-space:inherit;position:relative;border:0;outline:none;background:transparent;cursor:pointer;z-index:1}.calendar-month-year-toggle ion-icon{-ms-flex-negative:0;flex-shrink:0}.calendar-month-year-toggle #toggle-wrapper{display:-ms-inline-flexbox;display:inline-flex;-ms-flex-align:center;align-items:center}:host{--background:var(--token-bg-surface-default, var(--token-primitives-base-white, #ffffff));--focus-ring-color:var(--token-border-focus-default, var(--token-primitives-blue-400, #b5c0f7));--focus-ring-width:var(--token-border-radius-025, var(--token-scale-050, 2px));--body-opacity:0;--year-opacity:0}:host .calendar-body{opacity:var(--body-opacity)}:host .datetime-year{opacity:var(--year-opacity)}:host(.datetime-ready) .calendar-body{--body-opacity:1}:host(.datetime-ready) .datetime-year{--year-opacity:1}:host .datetime-header{-webkit-padding-start:var(--token-space-400, var(--token-scale-400, 16px));padding-inline-start:var(--token-space-400, var(--token-scale-400, 16px));-webkit-padding-end:var(--token-space-400, var(--token-scale-400, 16px));padding-inline-end:var(--token-space-400, var(--token-scale-400, 16px));padding-top:var(--token-space-200, var(--token-scale-200, 8px));padding-bottom:var(--token-space-400, var(--token-scale-400, 16px));display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;-ms-flex-align:start;align-items:start;-ms-flex-pack:justify;justify-content:space-between;height:var(--token-scale-1400, 56px);margin-bottom:var(--token-space-200, var(--token-scale-200, 8px));border-bottom:var(--token-border-style-solid, solid) var(--token-border-size-025, var(--token-scale-025, 1px)) var(--token-primitives-neutral-400, #d5d5d5)}:host .datetime-header .datetime-title{font-size:var(--token-font-size-450, 1.125rem);font-weight:var(--token-font-weight-medium, 500);letter-spacing:var(--token-font-letter-spacing-0, 0%);line-height:var(--token-font-line-height-700, var(--token-scale-700, 28px));text-decoration:none;text-transform:none;color:var(--token-primitives-neutral-800, #626262)}:host .datetime-header .datetime-selected-date{font-size:var(--token-font-size-350, 0.875rem);font-weight:var(--token-font-weight-regular, 400);letter-spacing:var(--token-font-letter-spacing-0, 0%);line-height:var(--token-font-line-height-600, var(--token-scale-600, 24px));text-decoration:none;text-transform:none;color:var(--token-primitives-neutral-1000, #3b3b3b)}.calendar-action-buttons{padding-top:var(--token-space-200, var(--token-scale-200, 8px));padding-bottom:var(--token-space-200, var(--token-scale-200, 8px));-ms-flex-align:center;align-items:center;height:var(--token-scale-1400, 56px);-webkit-box-sizing:border-box;box-sizing:border-box}.calendar-month-year{-ms-flex:1 0 0px;flex:1 0 0}.calendar-month-year-toggle{border-radius:var(--token-border-radius-full, 999px);font-size:var(--token-font-size-400, 1rem);font-weight:var(--token-font-weight-medium, 500);letter-spacing:var(--token-font-letter-spacing-1, 1%);line-height:var(--token-font-line-height-600, var(--token-scale-600, 24px));text-decoration:none;text-transform:none;-webkit-padding-start:var(--token-space-400, var(--token-scale-400, 16px));padding-inline-start:var(--token-space-400, var(--token-scale-400, 16px));-webkit-padding-end:var(--token-space-400, var(--token-scale-400, 16px));padding-inline-end:var(--token-space-400, var(--token-scale-400, 16px));padding-top:var(--token-space-200, var(--token-scale-200, 8px));padding-bottom:var(--token-space-200, var(--token-scale-200, 8px));min-width:var(--token-scale-1600, 64px);min-height:var(--token-scale-1000, 40px);border:var(--focus-ring-width) var(--token-border-style-solid, solid) transparent;color:var(--token-semantics-primary-base, var(--token-semantics-primary-700, var(--token-primitives-blue-700, #105cef)))}@media (any-hover: hover){.calendar-month-year-toggle:hover{background:var(--token-primitives-neutral-200, #eae9e9)}}.calendar-month-year-toggle.ion-focused{border-color:var(--focus-ring-color)}.calendar-month-year-toggle.ion-activated{background:var(--token-primitives-neutral-200, #eae9e9)}.calendar-next-prev ion-button.button-has-icon-only{--color:var(--token-primitives-neutral-1000, #3b3b3b);--background-activated:var(--token-primitives-neutral-200, #eae9e9);--background-hover:var(--token-primitives-neutral-200, #eae9e9);--background-hover-opacity:1;min-height:var(--token-scale-1000, 40px)}.calendar-next-prev ion-button.button-has-icon-only.ion-focused::part(native){border:var(--token-border-size-050, var(--token-scale-050, 2px)) var(--token-border-style-solid, solid) var(--token-border-focus-default, var(--token-primitives-blue-400, #b5c0f7));outline:none}.calendar-days-of-week{font-size:var(--token-font-size-300, 0.75rem);font-weight:var(--token-font-weight-medium, 500);letter-spacing:var(--token-font-letter-spacing-2, 1.5%);line-height:var(--token-font-line-height-500, var(--token-scale-500, 20px));text-decoration:none;text-transform:uppercase;-ms-flex-line-pack:center;align-content:center;height:var(--token-scale-1200, 48px);color:var(--token-primitives-neutral-800, #626262)}.calendar-day{border-radius:var(--token-border-radius-full, 999px);-webkit-padding-start:var(--token-space-100, var(--token-scale-100, 4px));padding-inline-start:var(--token-space-100, var(--token-scale-100, 4px));-webkit-padding-end:var(--token-space-100, var(--token-scale-100, 4px));padding-inline-end:var(--token-space-100, var(--token-scale-100, 4px));padding-top:var(--token-space-100, var(--token-scale-100, 4px));padding-bottom:var(--token-space-100, var(--token-scale-100, 4px));font-size:var(--token-font-size-350, 0.875rem);font-weight:var(--token-font-weight-medium, 500);letter-spacing:var(--token-font-letter-spacing-1, 1%);line-height:var(--token-font-line-height-500, var(--token-scale-500, 20px));text-decoration:none;text-transform:none;width:var(--token-scale-1200, 48px);min-width:var(--token-scale-1200, 48px);height:var(--token-scale-1200, 48px);color:var(--token-text-default, var(--token-primitives-neutral-1200, #242424))}.calendar-day[disabled]:not(.calendar-day-constrained){color:var(--token-primitives-neutral-500, #a2a2a2)}.calendar-day.calendar-day-today{color:var(--token-semantics-primary-base, var(--token-semantics-primary-700, var(--token-primitives-blue-700, #105cef)))}.calendar-day.calendar-day-active,.calendar-day.calendar-day-active.calendar-day-adjacent-day{background:var(--token-semantics-primary-100, var(--token-primitives-blue-100, #e9ecfc))}.calendar-day:focus-visible{border:var(--focus-ring-width) var(--token-border-style-solid, solid) var(--focus-ring-color)}@media (any-hover: hover){.calendar-day:not([disabled]):not(:active):hover{background:var(--token-semantics-primary-200, var(--token-primitives-blue-200, #e4e8ff))}}.calendar-day:active,.calendar-day.calendar-day-adjacent-day:active{background:var(--token-bg-primary-subtle-press, var(--token-semantics-primary-300, var(--token-primitives-blue-300, #d0d7fa)))}.calendar-day.calendar-day-adjacent-day{color:var(--token-text-subtlest, var(--token-primitives-neutral-800, #626262))}.calendar-day.calendar-day-active.calendar-day-adjacent-day{color:var(--token-text-default, var(--token-primitives-neutral-1200, #242424))}:host .datetime-time{-webkit-padding-start:var(--token-space-400, var(--token-scale-400, 16px));padding-inline-start:var(--token-space-400, var(--token-scale-400, 16px));-webkit-padding-end:var(--token-space-400, var(--token-scale-400, 16px));padding-inline-end:var(--token-space-400, var(--token-scale-400, 16px));padding-top:var(--token-space-100, var(--token-scale-100, 4px));padding-bottom:var(--token-space-100, var(--token-scale-100, 4px))}:host .datetime-time .time-header{font-size:var(--token-font-size-400, 1rem);font-weight:var(--token-font-weight-medium, 500);letter-spacing:var(--token-font-letter-spacing-1, 1%);line-height:var(--token-font-line-height-600, var(--token-scale-600, 24px));text-decoration:none;text-transform:none;color:var(--token-primitives-neutral-800, #626262)}:host .datetime-time button{-webkit-padding-start:var(--token-space-200, var(--token-scale-200, 8px));padding-inline-start:var(--token-space-200, var(--token-scale-200, 8px));-webkit-padding-end:var(--token-space-200, var(--token-scale-200, 8px));padding-inline-end:var(--token-space-200, var(--token-scale-200, 8px));padding-top:var(--token-space-0, var(--token-scale-0, 0px));padding-bottom:var(--token-space-0, var(--token-scale-0, 0px));font-size:var(--token-font-size-350, 0.875rem);font-weight:var(--token-font-weight-medium, 500);letter-spacing:var(--token-font-letter-spacing-0, 0%);line-height:var(--token-font-line-height-600, var(--token-scale-600, 24px));text-decoration:none;text-transform:none;border-radius:var(--token-border-radius-full, 999px);display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;height:var(--token-scale-800, 32px);background-color:var(--token-primitives-neutral-100, #f3f3f3);color:var(--token-text-default, var(--token-primitives-neutral-1200, #242424))}:host .datetime-footer{padding-left:0;padding-right:0;padding-top:var(--token-space-200, var(--token-scale-200, 8px));padding-bottom:0;margin-left:0;margin-right:0;margin-top:var(--token-space-200, var(--token-scale-200, 8px));margin-bottom:0;border-left:0;border-right:0;border-top:var(--token-border-style-solid, solid) var(--token-border-size-025, var(--token-scale-025, 1px)) var(--token-primitives-neutral-400, #d5d5d5);border-bottom:0}:host .datetime-buttons .datetime-action-buttons,.datetime-action-buttons .datetime-action-buttons-container,::slotted([slot=buttons]){-ms-flex-flow:column;flex-flow:column;-ms-flex-align:stretch;align-items:stretch;gap:var(--token-space-200, var(--token-scale-200, 8px))}`;
|
|
231
235
|
|
|
232
|
-
const datetimeMdCss = () => `:host{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;background:var(--background);overflow:hidden}:host(.datetime-size-fixed){width:auto;height:auto}:host(.datetime-size-fixed:not(.datetime-prefer-wheel)){max-width:350px}:host(.datetime-size-fixed.datetime-prefer-wheel){min-width:350px;max-width:-webkit-max-content;max-width:-moz-max-content;max-width:max-content}:host(.datetime-size-cover){width:100%}:host .calendar-body,:host .datetime-year{opacity:0}:host(:not(.datetime-ready)) .datetime-year{position:absolute;pointer-events:none}:host(.datetime-ready) .calendar-body{opacity:1}:host(.datetime-ready) .datetime-year{display:none;opacity:1}:host .wheel-order-year-first .day-column{-ms-flex-order:3;order:3;text-align:end}:host .wheel-order-year-first .month-column{-ms-flex-order:2;order:2;text-align:end}:host .wheel-order-year-first .year-column{-ms-flex-order:1;order:1;text-align:start}:host .datetime-calendar,:host .datetime-year{display:-ms-flexbox;display:flex;-ms-flex:1 1 auto;flex:1 1 auto;-ms-flex-flow:column;flex-flow:column}:host(.show-month-and-year) .datetime-year{display:-ms-flexbox;display:flex}:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{display:none}:host(.month-year-picker-open) .datetime-footer{display:none}:host(.datetime-disabled){pointer-events:none}:host(.datetime-disabled) .calendar-days-of-week,:host(.datetime-disabled) .datetime-time{opacity:0.4}:host(.datetime-readonly){pointer-events:none;}:host(.datetime-readonly) .calendar-action-buttons,:host(.datetime-readonly) .calendar-body,:host(.datetime-readonly) .datetime-year{pointer-events:initial}:host(.datetime-readonly) .calendar-day[disabled]:not(.calendar-day-constrained),:host(.datetime-readonly) .datetime-action-buttons ion-button[disabled]{opacity:1}:host .datetime-header .datetime-title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}:host .datetime-action-buttons.has-clear-button{width:100%}:host .datetime-action-buttons ion-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}.datetime-action-buttons .datetime-action-buttons-container{display:-ms-flexbox;display:flex}:host .calendar-action-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host .calendar-action-buttons ion-button{--background:transparent}:host .calendar-days-of-week{display:grid;grid-template-columns:repeat(7, 1fr);text-align:center}.calendar-days-of-week .day-of-week{-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto;margin-top:0;margin-bottom:0}:host .calendar-body{display:-ms-flexbox;display:flex;-ms-flex-positive:1;flex-grow:1;-webkit-scroll-snap-type:x mandatory;-ms-scroll-snap-type:x mandatory;scroll-snap-type:x mandatory;overflow-x:scroll;overflow-y:hidden;scrollbar-width:none;outline:none}:host .calendar-body .calendar-month{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;scroll-snap-align:start;scroll-snap-stop:always;-ms-flex-negative:0;flex-shrink:0;width:100%}:host .calendar-body .calendar-month-disabled{scroll-snap-align:none}:host .calendar-body::-webkit-scrollbar{display:none}:host .calendar-body .calendar-month-grid{display:grid;grid-template-columns:repeat(7, 1fr)}:host .calendar-day-wrapper{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;min-width:0;min-height:0;overflow:visible}.calendar-day{border-radius:50%;-webkit-padding-start:0px;padding-inline-start:0px;-webkit-padding-end:0px;padding-inline-end:0px;padding-top:0px;padding-bottom:0px;-webkit-margin-start:0px;margin-inline-start:0px;-webkit-margin-end:0px;margin-inline-end:0px;margin-top:0px;margin-bottom:0px;display:-ms-flexbox;display:flex;position:relative;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;border:none;outline:none;background:none;color:currentColor;font-family:var(--ion-font-family, inherit);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;z-index:0}:host .calendar-day[disabled]{pointer-events:none;opacity:0.4}.calendar-day:not(.calendar-day-adjacent-day):focus{background:rgba(var(--ion-color-base-rgb), 0.2);-webkit-box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2);box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2)}:host .datetime-time{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host(.datetime-presentation-time) .datetime-time{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0}:host ion-popover{--height:200px}:host .time-header{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}:host .time-body{border-radius:8px;-webkit-padding-start:12px;padding-inline-start:12px;-webkit-padding-end:12px;padding-inline-end:12px;padding-top:6px;padding-bottom:6px;display:-ms-flexbox;display:flex;border:none;background:var(--ion-color-step-300, var(--ion-background-color-step-300, #edeef0));color:var(--ion-text-color, #000);font-family:inherit;font-size:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}:host .time-body-active{color:var(--ion-color-base)}:host(.in-item){position:static}:host(.show-month-and-year) .calendar-action-buttons .calendar-month-year-toggle{color:var(--ion-color-base)}.calendar-month-year{min-width:0}.calendar-month-year-toggle{font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;text-align:inherit;white-space:inherit;color:inherit;position:relative;border:0;outline:none;background:transparent;cursor:pointer;z-index:1}.calendar-month-year-toggle::after{left:0;right:0;top:0;bottom:0;position:absolute;content:"";opacity:0;-webkit-transition:opacity 15ms linear, background-color 15ms linear;transition:opacity 15ms linear, background-color 15ms linear;z-index:-1}.calendar-month-year-toggle.ion-focused::after{background:currentColor}.calendar-month-year-toggle:disabled{opacity:0.3;pointer-events:none}.calendar-month-year-toggle ion-icon{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:0;padding-inline-end:0;padding-top:0;padding-bottom:0;-ms-flex-negative:0;flex-shrink:0}.calendar-month-year-toggle #toggle-wrapper{display:-ms-inline-flexbox;display:inline-flex;-ms-flex-align:center;align-items:center}ion-picker{--highlight-background:var(--wheel-highlight-background);--highlight-border-radius:var(--wheel-highlight-border-radius);--fade-background-rgb:var(--wheel-fade-background-rgb)}:host{--background:var(--ion-color-step-100, var(--ion-background-color-step-100, #ffffff));--title-color:var(--ion-color-contrast)}:host .datetime-header{-webkit-padding-start:20px;padding-inline-start:20px;-webkit-padding-end:20px;padding-inline-end:20px;padding-top:20px;padding-bottom:20px;background:var(--ion-color-base);color:var(--title-color)}:host .datetime-header .datetime-title{font-size:0.75rem;text-transform:uppercase}:host .datetime-header .datetime-selected-date{margin-top:30px;font-size:2.125rem}:host .calendar-action-buttons ion-button{--color:var(--ion-color-step-650, var(--ion-text-color-step-350, #595959))}.calendar-month-year-toggle{-webkit-padding-start:20px;padding-inline-start:20px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:12px;padding-bottom:12px;min-height:48px;background:transparent;color:var(--ion-color-step-650, var(--ion-text-color-step-350, #595959));z-index:1}.calendar-month-year-toggle.ion-focused::after{opacity:0.04}.calendar-month-year-toggle ion-ripple-effect{color:currentColor}@media (any-hover: hover){.calendar-month-year-toggle.ion-activatable:not(.ion-focused):hover::after{background:currentColor;opacity:0.04}}:host .calendar-days-of-week{-webkit-padding-start:10px;padding-inline-start:10px;-webkit-padding-end:10px;padding-inline-end:10px;padding-top:0px;padding-bottom:0px;color:var(--ion-color-step-500, var(--ion-text-color-step-500, gray));font-size:0.875rem;line-height:36px}:host .calendar-body .calendar-month .calendar-month-grid{-webkit-padding-start:10px;padding-inline-start:10px;-webkit-padding-end:10px;padding-inline-end:10px;padding-top:4px;padding-bottom:4px;grid-template-rows:repeat(6, 1fr)}:host .calendar-day{width:42px;min-width:42px;height:42px;font-size:0.875rem}:host .calendar-day.calendar-day-today{border:1px solid var(--ion-color-base);color:var(--ion-color-base)}:host .calendar-day.calendar-day-active,:host .calendar-day.calendar-day-adjacent-day.calendar-day-active{color:var(--ion-color-contrast)}.calendar-day.calendar-day-active,.calendar-day.calendar-day-active:focus{border:1px solid var(--ion-color-base);background:var(--ion-color-base)}:host .calendar-day.calendar-day-adjacent-day{color:var(--ion-color-step-500, var(--ion-text-color-step-500, gray))}:host .datetime-time{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:8px;padding-bottom:8px}:host .time-header{color:var(--ion-color-step-650, var(--ion-text-color-step-350, #595959))}:host(.datetime-presentation-month) .datetime-year,:host(.datetime-presentation-year) .datetime-year,:host(.datetime-presentation-month-year) .datetime-year{margin-top:20px;margin-bottom:20px}:host .datetime-buttons{-webkit-padding-start:10px;padding-inline-start:10px;-webkit-padding-end:10px;padding-inline-end:10px;padding-top:10px;padding-bottom:10px;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:end;justify-content:flex-end}`;
|
|
236
|
+
const datetimeIosCss = () => `:host{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;background:var(--background);overflow:hidden}:host(.datetime-size-fixed){width:auto;height:auto}:host(.datetime-size-cover){width:100%}:host(:not(.datetime-ready)) .datetime-year{position:absolute;pointer-events:none}:host(.datetime-ready) .datetime-year{display:none}:host .wheel-order-year-first .day-column{-ms-flex-order:3;order:3;text-align:end}:host .wheel-order-year-first .month-column{-ms-flex-order:2;order:2;text-align:end}:host .wheel-order-year-first .year-column{-ms-flex-order:1;order:1;text-align:start}:host .datetime-calendar,:host .datetime-year{display:-ms-flexbox;display:flex;-ms-flex:1 1 auto;flex:1 1 auto;-ms-flex-flow:column;flex-flow:column}:host(.show-month-and-year) .datetime-year{display:-ms-flexbox;display:flex}:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{display:none}:host(.month-year-picker-open) .datetime-footer{display:none}:host(.datetime-disabled){pointer-events:none}:host(.datetime-disabled) .calendar-days-of-week,:host(.datetime-disabled) .datetime-time{opacity:0.4}:host(.datetime-readonly){pointer-events:none;}:host(.datetime-readonly) .calendar-action-buttons,:host(.datetime-readonly) .calendar-body,:host(.datetime-readonly) .datetime-year{pointer-events:initial}:host(.datetime-readonly) .calendar-day[disabled]:not(.calendar-day-constrained),:host(.datetime-readonly) .datetime-action-buttons ion-button[disabled]{opacity:1}:host .datetime-header .datetime-title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}:host .datetime-action-buttons.has-clear-button{width:100%}:host .datetime-action-buttons,::slotted([slot=buttons]),.datetime-action-buttons .datetime-action-buttons-container{display:-ms-flexbox;display:flex}:host .calendar-action-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host .calendar-days-of-week{display:grid;grid-template-columns:repeat(7, 1fr);text-align:center}.calendar-days-of-week .day-of-week{-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto;margin-top:0;margin-bottom:0}:host .calendar-body{display:-ms-flexbox;display:flex;-ms-flex-positive:1;flex-grow:1;-webkit-scroll-snap-type:x mandatory;-ms-scroll-snap-type:x mandatory;scroll-snap-type:x mandatory;overflow-x:scroll;overflow-y:hidden;scrollbar-width:none;outline:none}:host .calendar-body .calendar-month{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;scroll-snap-align:start;scroll-snap-stop:always;-ms-flex-negative:0;flex-shrink:0;width:100%}:host .calendar-body .calendar-month-disabled{scroll-snap-align:none}:host .calendar-body::-webkit-scrollbar{display:none}:host .calendar-body .calendar-month-grid{display:grid;grid-template-columns:repeat(7, 1fr)}:host .calendar-day-wrapper{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;min-width:0;min-height:0;overflow:visible}.calendar-day{-webkit-padding-start:0px;padding-inline-start:0px;-webkit-padding-end:0px;padding-inline-end:0px;padding-top:0px;padding-bottom:0px;-webkit-margin-start:0px;margin-inline-start:0px;-webkit-margin-end:0px;margin-inline-end:0px;margin-top:0px;margin-bottom:0px;display:-ms-flexbox;display:flex;position:relative;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;border:none;outline:none;background:none;color:currentColor;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;z-index:0}.calendar-day[disabled]{pointer-events:none}:host .datetime-time{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host .time-header{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}:host .time-body{display:-ms-flexbox;display:flex;border:none;font-family:inherit;font-size:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}:host(.in-item){position:static}.calendar-month-year{min-width:0}.calendar-month-year-toggle{color:inherit;font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-align:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;white-space:inherit;position:relative;border:0;outline:none;background:transparent;cursor:pointer;z-index:1}.calendar-month-year-toggle ion-icon{-ms-flex-negative:0;flex-shrink:0}.calendar-month-year-toggle #toggle-wrapper{display:-ms-inline-flexbox;display:inline-flex;-ms-flex-align:center;align-items:center}:host{}:host(.datetime-size-fixed:not(.datetime-prefer-wheel)){max-width:350px}:host .calendar-body,:host .datetime-year{opacity:0}:host(.datetime-ready) .calendar-body,:host(.datetime-ready) .datetime-year{opacity:1}:host(.datetime-size-fixed.datetime-prefer-wheel){min-width:350px;max-width:-webkit-max-content;max-width:-moz-max-content;max-width:max-content}:host .calendar-action-buttons ion-button{--background:transparent}.calendar-day{border-radius:50%;font-family:var(--ion-font-family, inherit)}:host .calendar-day[disabled]{opacity:0.4}.calendar-day:not(.calendar-day-adjacent-day):focus{background:current-color(base, 0.2);-webkit-box-shadow:0px 0px 0px 4px current-color(base, 0.2);box-shadow:0px 0px 0px 4px current-color(base, 0.2)}.calendar-day:focus{background:rgba(var(--ion-color-base-rgb), 0.2);-webkit-box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2);box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2)}:host .calendar-next-prev{display:-ms-flexbox;display:flex;-ms-flex-align:start;align-items:start}.calendar-next-prev ion-button ion-icon[slot=icon-only]{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}:host(.datetime-presentation-time) .datetime-time{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0}:host ion-popover{--height:200px}:host .time-body{border-radius:8px;-webkit-padding-start:12px;padding-inline-start:12px;-webkit-padding-end:12px;padding-inline-end:12px;padding-top:6px;padding-bottom:6px;background:var(--ion-color-step-300, var(--ion-background-color-step-300, #edeef0));color:var(--ion-text-color, #000)}:host .time-body-active{color:var(--ion-color-base)}:host(.show-month-and-year) .calendar-action-buttons .calendar-month-year-toggle{color:var(--ion-color-base)}.calendar-month-year-toggle::after{right:0;left:0;top:0;bottom:0;position:absolute;content:"";opacity:0;-webkit-transition:opacity 15ms linear, background-color 15ms linear;transition:opacity 15ms linear, background-color 15ms linear;z-index:-1}.calendar-month-year-toggle.ion-focused::after{background:currentColor}.calendar-month-year-toggle:disabled{opacity:0.3;pointer-events:none}.calendar-month-year-toggle ion-icon{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:0;padding-inline-end:0;padding-top:0;padding-bottom:0}ion-picker{--highlight-background:var(--wheel-highlight-background);--highlight-border-radius:var(--wheel-highlight-border-radius);--fade-background-rgb:var(--wheel-fade-background-rgb)}:host .datetime-action-buttons{-ms-flex-pack:justify;justify-content:space-between}:host{--background:var(--ion-color-light, #f4f5f8);--background-rgb:var(--ion-color-light-rgb, 244, 245, 248);--title-color:var(--ion-color-step-600, var(--ion-text-color-step-400, #666666))}:host(.datetime-presentation-date-time:not(.datetime-prefer-wheel)),:host(.datetime-presentation-time-date:not(.datetime-prefer-wheel)),:host(.datetime-presentation-date:not(.datetime-prefer-wheel)){min-height:350px}:host .datetime-header{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:16px;padding-bottom:16px;border-bottom:0.55px solid var(--ion-color-step-200, var(--ion-background-color-step-200, #cccccc));font-size:min(0.875rem, 22.4px)}:host .datetime-header .datetime-title{color:var(--title-color)}:host .datetime-header .datetime-selected-date{margin-top:10px}.calendar-month-year-toggle{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:0px;padding-bottom:0px;min-height:44px;font-size:min(1rem, 25.6px);font-weight:600}.calendar-month-year-toggle.ion-focused::after{opacity:0.15}.calendar-month-year-toggle #toggle-wrapper{-webkit-margin-start:0;margin-inline-start:0;-webkit-margin-end:8px;margin-inline-end:8px;margin-top:10px;margin-bottom:10px}:host .calendar-action-buttons .calendar-month-year-toggle ion-icon,:host .calendar-action-buttons ion-button{color:var(--ion-color-base)}:host .calendar-action-buttons ion-button{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}:host .calendar-action-buttons .calendar-next-prev{-ms-flex-align:stretch;align-items:stretch}.calendar-next-prev ion-button{--padding-top:0;--padding-bottom:0;--padding-start:5px;--padding-end:5px;-webkit-margin-start:2px;margin-inline-start:2px;-webkit-margin-end:2px;margin-inline-end:2px;min-height:32px}.calendar-next-prev ion-button ion-icon[slot=icon-only]{font-size:1.65em;line-height:0.67}:host .calendar-days-of-week{-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px;padding-top:0;padding-bottom:0;color:var(--ion-color-step-300, var(--ion-text-color-step-700, #b3b3b3));font-size:min(0.75rem, 19.2px);font-weight:600;line-height:24px;text-transform:uppercase}@supports (border-radius: mod(1px, 1px)){.calendar-days-of-week .day-of-week{width:clamp(20px, calc(mod(min(1rem, 24px), 24px) * 10), 100%);height:24px;overflow:hidden}.calendar-day{border-radius:max(8px, mod(min(1rem, 24px), 24px) * 10)}}@supports ((border-radius: mod(1px, 1px)) and (background: -webkit-named-image(apple-pay-logo-black)) and (not (contain-intrinsic-size: none))) or (not (border-radius: mod(1px, 1px))){.calendar-days-of-week .day-of-week{width:auto;height:auto;overflow:initial}.calendar-day{border-radius:32px}}:host .calendar-body .calendar-month .calendar-month-grid{-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px;padding-top:8px;padding-bottom:8px;-ms-flex-align:center;align-items:center;height:calc(100% - 16px)}:host .calendar-day-wrapper{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:4px;padding-inline-end:4px;padding-top:4px;padding-bottom:4px;height:0;min-height:1rem}:host .calendar-day{width:40px;min-width:40px;height:40px;font-size:min(1.25rem, 32px)}.calendar-day.calendar-day-active{background:rgba(var(--ion-color-base-rgb), 0.2);font-size:min(1.375rem, 35.2px)}:host .calendar-day.calendar-day-today{color:var(--ion-color-base)}:host .calendar-day.calendar-day-active,:host .calendar-day.calendar-day-adjacent-day.calendar-day-active{color:var(--ion-color-base);font-weight:600}:host .calendar-day.calendar-day-today.calendar-day-active{background:var(--ion-color-base);color:var(--ion-color-contrast)}:host .calendar-day.calendar-day-adjacent-day{color:var(--ion-color-step-300, var(--ion-text-color-step-700, #b3b3b3))}:host .datetime-time{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:8px;padding-bottom:16px;font-size:min(1rem, 25.6px)}:host .datetime-time .time-header{font-weight:600}:host .datetime-buttons{-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px;padding-top:8px;padding-bottom:8px;border-top:0.55px solid var(--ion-color-step-200, var(--ion-background-color-step-200, #cccccc))}:host .datetime-buttons,::slotted([slot=buttons]){display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:justify;justify-content:space-between}:host .datetime-action-buttons,::slotted([slot=buttons]){width:100%}`;
|
|
237
|
+
|
|
238
|
+
const datetimeMdCss = () => `:host{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;background:var(--background);overflow:hidden}:host(.datetime-size-fixed){width:auto;height:auto}:host(.datetime-size-cover){width:100%}:host(:not(.datetime-ready)) .datetime-year{position:absolute;pointer-events:none}:host(.datetime-ready) .datetime-year{display:none}:host .wheel-order-year-first .day-column{-ms-flex-order:3;order:3;text-align:end}:host .wheel-order-year-first .month-column{-ms-flex-order:2;order:2;text-align:end}:host .wheel-order-year-first .year-column{-ms-flex-order:1;order:1;text-align:start}:host .datetime-calendar,:host .datetime-year{display:-ms-flexbox;display:flex;-ms-flex:1 1 auto;flex:1 1 auto;-ms-flex-flow:column;flex-flow:column}:host(.show-month-and-year) .datetime-year{display:-ms-flexbox;display:flex}:host(.show-month-and-year) .calendar-next-prev,:host(.show-month-and-year) .calendar-days-of-week,:host(.show-month-and-year) .calendar-body,:host(.show-month-and-year) .datetime-time{display:none}:host(.month-year-picker-open) .datetime-footer{display:none}:host(.datetime-disabled){pointer-events:none}:host(.datetime-disabled) .calendar-days-of-week,:host(.datetime-disabled) .datetime-time{opacity:0.4}:host(.datetime-readonly){pointer-events:none;}:host(.datetime-readonly) .calendar-action-buttons,:host(.datetime-readonly) .calendar-body,:host(.datetime-readonly) .datetime-year{pointer-events:initial}:host(.datetime-readonly) .calendar-day[disabled]:not(.calendar-day-constrained),:host(.datetime-readonly) .datetime-action-buttons ion-button[disabled]{opacity:1}:host .datetime-header .datetime-title{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}:host .datetime-action-buttons.has-clear-button{width:100%}:host .datetime-action-buttons,::slotted([slot=buttons]),.datetime-action-buttons .datetime-action-buttons-container{display:-ms-flexbox;display:flex}:host .calendar-action-buttons{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host .calendar-days-of-week{display:grid;grid-template-columns:repeat(7, 1fr);text-align:center}.calendar-days-of-week .day-of-week{-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto;margin-top:0;margin-bottom:0}:host .calendar-body{display:-ms-flexbox;display:flex;-ms-flex-positive:1;flex-grow:1;-webkit-scroll-snap-type:x mandatory;-ms-scroll-snap-type:x mandatory;scroll-snap-type:x mandatory;overflow-x:scroll;overflow-y:hidden;scrollbar-width:none;outline:none}:host .calendar-body .calendar-month{display:-ms-flexbox;display:flex;-ms-flex-flow:column;flex-flow:column;scroll-snap-align:start;scroll-snap-stop:always;-ms-flex-negative:0;flex-shrink:0;width:100%}:host .calendar-body .calendar-month-disabled{scroll-snap-align:none}:host .calendar-body::-webkit-scrollbar{display:none}:host .calendar-body .calendar-month-grid{display:grid;grid-template-columns:repeat(7, 1fr)}:host .calendar-day-wrapper{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;min-width:0;min-height:0;overflow:visible}.calendar-day{-webkit-padding-start:0px;padding-inline-start:0px;-webkit-padding-end:0px;padding-inline-end:0px;padding-top:0px;padding-bottom:0px;-webkit-margin-start:0px;margin-inline-start:0px;-webkit-margin-end:0px;margin-inline-end:0px;margin-top:0px;margin-bottom:0px;display:-ms-flexbox;display:flex;position:relative;-ms-flex-align:center;align-items:center;-ms-flex-pack:center;justify-content:center;border:none;outline:none;background:none;color:currentColor;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;z-index:0}.calendar-day[disabled]{pointer-events:none}:host .datetime-time{display:-ms-flexbox;display:flex;-ms-flex-pack:justify;justify-content:space-between}:host .time-header{display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center}:host .time-body{display:-ms-flexbox;display:flex;border:none;font-family:inherit;font-size:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}:host(.in-item){position:static}.calendar-month-year{min-width:0}.calendar-month-year-toggle{color:inherit;font-family:inherit;font-size:inherit;font-style:inherit;font-weight:inherit;letter-spacing:inherit;text-align:inherit;text-decoration:inherit;text-indent:inherit;text-overflow:inherit;text-transform:inherit;white-space:inherit;position:relative;border:0;outline:none;background:transparent;cursor:pointer;z-index:1}.calendar-month-year-toggle ion-icon{-ms-flex-negative:0;flex-shrink:0}.calendar-month-year-toggle #toggle-wrapper{display:-ms-inline-flexbox;display:inline-flex;-ms-flex-align:center;align-items:center}:host{}:host(.datetime-size-fixed:not(.datetime-prefer-wheel)){max-width:350px}:host .calendar-body,:host .datetime-year{opacity:0}:host(.datetime-ready) .calendar-body,:host(.datetime-ready) .datetime-year{opacity:1}:host(.datetime-size-fixed.datetime-prefer-wheel){min-width:350px;max-width:-webkit-max-content;max-width:-moz-max-content;max-width:max-content}:host .calendar-action-buttons ion-button{--background:transparent}.calendar-day{border-radius:50%;font-family:var(--ion-font-family, inherit)}:host .calendar-day[disabled]{opacity:0.4}.calendar-day:not(.calendar-day-adjacent-day):focus{background:current-color(base, 0.2);-webkit-box-shadow:0px 0px 0px 4px current-color(base, 0.2);box-shadow:0px 0px 0px 4px current-color(base, 0.2)}.calendar-day:focus{background:rgba(var(--ion-color-base-rgb), 0.2);-webkit-box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2);box-shadow:0px 0px 0px 4px rgba(var(--ion-color-base-rgb), 0.2)}:host .calendar-next-prev{display:-ms-flexbox;display:flex;-ms-flex-align:start;align-items:start}.calendar-next-prev ion-button ion-icon[slot=icon-only]{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0}:host(.datetime-presentation-time) .datetime-time{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0}:host ion-popover{--height:200px}:host .time-body{border-radius:8px;-webkit-padding-start:12px;padding-inline-start:12px;-webkit-padding-end:12px;padding-inline-end:12px;padding-top:6px;padding-bottom:6px;background:var(--ion-color-step-300, var(--ion-background-color-step-300, #edeef0));color:var(--ion-text-color, #000)}:host .time-body-active{color:var(--ion-color-base)}:host(.show-month-and-year) .calendar-action-buttons .calendar-month-year-toggle{color:var(--ion-color-base)}.calendar-month-year-toggle::after{right:0;left:0;top:0;bottom:0;position:absolute;content:"";opacity:0;-webkit-transition:opacity 15ms linear, background-color 15ms linear;transition:opacity 15ms linear, background-color 15ms linear;z-index:-1}.calendar-month-year-toggle.ion-focused::after{background:currentColor}.calendar-month-year-toggle:disabled{opacity:0.3;pointer-events:none}.calendar-month-year-toggle ion-icon{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:0;padding-inline-end:0;padding-top:0;padding-bottom:0}ion-picker{--highlight-background:var(--wheel-highlight-background);--highlight-border-radius:var(--wheel-highlight-border-radius);--fade-background-rgb:var(--wheel-fade-background-rgb)}:host .datetime-action-buttons{-ms-flex-pack:justify;justify-content:space-between}:host{--background:var(--ion-color-step-100, var(--ion-background-color-step-100, #ffffff));--title-color:var(--ion-color-contrast)}:host .datetime-header{-webkit-padding-start:20px;padding-inline-start:20px;-webkit-padding-end:20px;padding-inline-end:20px;padding-top:20px;padding-bottom:20px;background:var(--ion-color-base);color:var(--title-color)}:host .datetime-header .datetime-title{font-size:0.75rem;text-transform:uppercase}:host .datetime-header .datetime-selected-date{margin-top:30px;font-size:2.125rem}:host .calendar-action-buttons ion-button{--color:var(--ion-color-step-650, var(--ion-text-color-step-350, #595959))}.calendar-next-prev ion-button{--padding-top:12px;--padding-end:12px;--padding-bottom:12px;--padding-start:12px;--border-radius:50%;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;width:3rem;height:3rem}.calendar-next-prev ion-button ion-icon[slot=icon-only]{font-size:1.8em}.calendar-month-year-toggle{-webkit-padding-start:20px;padding-inline-start:20px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:12px;padding-bottom:12px;min-height:48px;background:transparent;color:var(--ion-color-step-650, var(--ion-text-color-step-350, #595959));z-index:1}.calendar-month-year-toggle.ion-focused::after{opacity:0.04}.calendar-month-year-toggle ion-ripple-effect{color:currentColor}@media (any-hover: hover){.calendar-month-year-toggle.ion-activatable:not(.ion-focused):hover::after{background:currentColor;opacity:0.04}}:host .calendar-days-of-week{-webkit-padding-start:10px;padding-inline-start:10px;-webkit-padding-end:10px;padding-inline-end:10px;padding-top:0px;padding-bottom:0px;color:var(--ion-color-step-500, var(--ion-text-color-step-500, gray));font-size:0.875rem;line-height:36px}:host .calendar-body .calendar-month .calendar-month-grid{-webkit-padding-start:10px;padding-inline-start:10px;-webkit-padding-end:10px;padding-inline-end:10px;padding-top:4px;padding-bottom:4px;grid-template-rows:repeat(6, 1fr)}:host .calendar-day{width:42px;min-width:42px;height:42px;font-size:0.875rem}:host .calendar-day.calendar-day-today{border:1px solid var(--ion-color-base);color:var(--ion-color-base)}:host .calendar-day.calendar-day-active,:host .calendar-day.calendar-day-adjacent-day.calendar-day-active{color:var(--ion-color-contrast)}.calendar-day.calendar-day-active,.calendar-day.calendar-day-active:focus{border:1px solid var(--ion-color-base);background:var(--ion-color-base)}:host .calendar-day.calendar-day-adjacent-day{color:var(--ion-color-step-500, var(--ion-text-color-step-500, gray))}:host .datetime-time{-webkit-padding-start:16px;padding-inline-start:16px;-webkit-padding-end:16px;padding-inline-end:16px;padding-top:8px;padding-bottom:8px}:host .time-header{color:var(--ion-color-step-650, var(--ion-text-color-step-350, #595959))}:host(.datetime-presentation-month) .datetime-year,:host(.datetime-presentation-year) .datetime-year,:host(.datetime-presentation-month-year) .datetime-year{margin-top:20px;margin-bottom:20px}:host .datetime-buttons{-webkit-padding-start:10px;padding-inline-start:10px;-webkit-padding-end:10px;padding-inline-end:10px;padding-top:10px;padding-bottom:10px;display:-ms-flexbox;display:flex;-ms-flex-align:center;align-items:center;-ms-flex-pack:end;justify-content:flex-end}`;
|
|
233
239
|
|
|
234
240
|
const Datetime = class {
|
|
235
241
|
constructor(hostRef) {
|
|
@@ -1322,6 +1328,7 @@ const Datetime = class {
|
|
|
1322
1328
|
* are rendered independently of presentation.
|
|
1323
1329
|
*/
|
|
1324
1330
|
renderFooter() {
|
|
1331
|
+
const theme = ionicGlobal.getIonTheme(this);
|
|
1325
1332
|
const { disabled, readonly, showDefaultButtons, showClearButton } = this;
|
|
1326
1333
|
/**
|
|
1327
1334
|
* The cancel, clear, and confirm buttons
|
|
@@ -1329,6 +1336,7 @@ const Datetime = class {
|
|
|
1329
1336
|
* is disabled or readonly.
|
|
1330
1337
|
*/
|
|
1331
1338
|
const isButtonDisabled = disabled || readonly;
|
|
1339
|
+
const confirmFill = theme === 'ionic' ? 'solid' : undefined;
|
|
1332
1340
|
const hasSlottedButtons = this.el.querySelector('[slot="buttons"]') !== null;
|
|
1333
1341
|
if (!hasSlottedButtons && !showDefaultButtons && !showClearButton) {
|
|
1334
1342
|
return;
|
|
@@ -1347,7 +1355,7 @@ const Datetime = class {
|
|
|
1347
1355
|
return (index.h("div", { class: "datetime-footer" }, index.h("div", { class: "datetime-buttons" }, index.h("div", { class: {
|
|
1348
1356
|
['datetime-action-buttons']: true,
|
|
1349
1357
|
['has-clear-button']: this.showClearButton,
|
|
1350
|
-
} }, index.h("slot", { name: "buttons" },
|
|
1358
|
+
} }, index.h("slot", { name: "buttons" }, showDefaultButtons && (index.h("ion-button", { id: "cancel-button", color: this.color, onClick: () => this.cancel(true), disabled: isButtonDisabled }, this.cancelText)), index.h("div", { class: "datetime-action-buttons-container" }, showClearButton && (index.h("ion-button", { id: "clear-button", color: this.color, onClick: () => clearButtonClick(), disabled: isButtonDisabled }, this.clearText)), showDefaultButtons && (index.h("ion-button", { id: "confirm-button", fill: confirmFill, color: this.color, onClick: () => this.confirm(true), disabled: isButtonDisabled }, this.doneText))))))));
|
|
1351
1359
|
}
|
|
1352
1360
|
/**
|
|
1353
1361
|
* Wheel picker render methods
|
|
@@ -1598,10 +1606,8 @@ const Datetime = class {
|
|
|
1598
1606
|
/**
|
|
1599
1607
|
* Grid Render Methods
|
|
1600
1608
|
*/
|
|
1601
|
-
renderCalendarHeader(
|
|
1602
|
-
const { disabled } = this;
|
|
1603
|
-
const expandedIcon = mode === 'ios' ? index$1.chevronDown : index$1.caretUpSharp;
|
|
1604
|
-
const collapsedIcon = mode === 'ios' ? index$1.chevronForward : index$1.caretDownSharp;
|
|
1609
|
+
renderCalendarHeader(theme) {
|
|
1610
|
+
const { disabled, datetimeNextIcon, datetimePreviousIcon, datetimeCollapsedIcon, datetimeExpandedIcon } = this;
|
|
1605
1611
|
const prevMonthDisabled = disabled || isPrevMonthDisabled(this.workingParts, this.minParts, this.maxParts);
|
|
1606
1612
|
const nextMonthDisabled = disabled || isNextMonthDisabled(this.workingParts, this.maxParts);
|
|
1607
1613
|
// don't use the inheritAttributes util because it removes dir from the host, and we still need that
|
|
@@ -1610,7 +1616,7 @@ const Datetime = class {
|
|
|
1610
1616
|
'calendar-month-year-toggle': true,
|
|
1611
1617
|
'ion-activatable': true,
|
|
1612
1618
|
'ion-focusable': true,
|
|
1613
|
-
}, part: "month-year-button", disabled: disabled, "aria-label": this.showMonthAndYear ? 'Hide year picker' : 'Show year picker', onClick: () => this.toggleMonthAndYearView() }, index.h("span", { id: "toggle-wrapper" }, data.getMonthAndYear(this.locale, this.workingParts), index.h("ion-icon", { "aria-hidden": "true", icon: this.showMonthAndYear ?
|
|
1619
|
+
}, part: "month-year-button", disabled: disabled, "aria-label": this.showMonthAndYear ? 'Hide year picker' : 'Show year picker', onClick: () => this.toggleMonthAndYearView() }, index.h("span", { id: "toggle-wrapper" }, data.getMonthAndYear(this.locale, this.workingParts), theme !== 'ionic' && (index.h("ion-icon", { "aria-hidden": "true", icon: this.showMonthAndYear ? datetimeExpandedIcon : datetimeCollapsedIcon, lazy: false, flipRtl: true }))), theme === 'md' && index.h("ion-ripple-effect", null))), index.h("div", { class: "calendar-next-prev" }, index.h("ion-button", { "aria-label": "Previous month", disabled: prevMonthDisabled, onClick: () => this.prevMonth(), part: "navigation-button previous-button" }, index.h("ion-icon", { dir: hostDir, "aria-hidden": "true", slot: "icon-only", icon: datetimePreviousIcon, lazy: false, flipRtl: true })), index.h("ion-button", { "aria-label": "Next month", disabled: nextMonthDisabled, onClick: () => this.nextMonth(), part: "navigation-button next-button" }, index.h("ion-icon", { dir: hostDir, "aria-hidden": "true", slot: "icon-only", icon: datetimeNextIcon, lazy: false, flipRtl: true })))), index.h("div", { class: "calendar-days-of-week", "aria-hidden": "true", part: "calendar-days-of-week" }, data.getDaysOfWeek(this.locale, theme, this.firstDayOfWeek % 7).map((d) => {
|
|
1614
1620
|
return index.h("div", { class: "day-of-week" }, d);
|
|
1615
1621
|
}))));
|
|
1616
1622
|
}
|
|
@@ -1762,8 +1768,8 @@ const Datetime = class {
|
|
|
1762
1768
|
return this.renderMonth(month, year);
|
|
1763
1769
|
})));
|
|
1764
1770
|
}
|
|
1765
|
-
renderCalendar(
|
|
1766
|
-
return (index.h("div", { class: "datetime-calendar", key: "datetime-calendar" }, this.renderCalendarHeader(
|
|
1771
|
+
renderCalendar(theme) {
|
|
1772
|
+
return (index.h("div", { class: "datetime-calendar", key: "datetime-calendar" }, this.renderCalendarHeader(theme), this.renderCalendarBody()));
|
|
1767
1773
|
}
|
|
1768
1774
|
renderTimeLabel() {
|
|
1769
1775
|
const hasSlottedTimeLabel = this.el.querySelector('[slot="time-label"]') !== null;
|
|
@@ -1871,7 +1877,7 @@ const Datetime = class {
|
|
|
1871
1877
|
* Render entry point
|
|
1872
1878
|
* All presentation types are rendered from here.
|
|
1873
1879
|
*/
|
|
1874
|
-
renderDatetime(
|
|
1880
|
+
renderDatetime(theme) {
|
|
1875
1881
|
const { presentation, preferWheel } = this;
|
|
1876
1882
|
/**
|
|
1877
1883
|
* Certain presentation types have separate grid and wheel displays.
|
|
@@ -1885,7 +1891,7 @@ const Datetime = class {
|
|
|
1885
1891
|
case 'date-time':
|
|
1886
1892
|
return [
|
|
1887
1893
|
this.renderHeader(),
|
|
1888
|
-
this.renderCalendar(
|
|
1894
|
+
this.renderCalendar(theme),
|
|
1889
1895
|
this.renderCalendarViewMonthYearPicker(),
|
|
1890
1896
|
this.renderTime(),
|
|
1891
1897
|
this.renderFooter(),
|
|
@@ -1894,7 +1900,7 @@ const Datetime = class {
|
|
|
1894
1900
|
return [
|
|
1895
1901
|
this.renderHeader(),
|
|
1896
1902
|
this.renderTime(),
|
|
1897
|
-
this.renderCalendar(
|
|
1903
|
+
this.renderCalendar(theme),
|
|
1898
1904
|
this.renderCalendarViewMonthYearPicker(),
|
|
1899
1905
|
this.renderFooter(),
|
|
1900
1906
|
];
|
|
@@ -1907,23 +1913,95 @@ const Datetime = class {
|
|
|
1907
1913
|
default:
|
|
1908
1914
|
return [
|
|
1909
1915
|
this.renderHeader(),
|
|
1910
|
-
this.renderCalendar(
|
|
1916
|
+
this.renderCalendar(theme),
|
|
1911
1917
|
this.renderCalendarViewMonthYearPicker(),
|
|
1912
1918
|
this.renderFooter(),
|
|
1913
1919
|
];
|
|
1914
1920
|
}
|
|
1915
1921
|
}
|
|
1922
|
+
/**
|
|
1923
|
+
* Get the icon to use for the next icon.
|
|
1924
|
+
* Otherwise, use the icon set in the config.
|
|
1925
|
+
* If no icon is set in the config, use the default icon.
|
|
1926
|
+
*/
|
|
1927
|
+
get datetimeNextIcon() {
|
|
1928
|
+
// Determine the theme and map to default icons
|
|
1929
|
+
const theme = ionicGlobal.getIonTheme(this);
|
|
1930
|
+
const defaultIcons = {
|
|
1931
|
+
ios: index$1.chevronForward,
|
|
1932
|
+
ionic: caretRight.caretRightSvg,
|
|
1933
|
+
md: index$1.chevronForward,
|
|
1934
|
+
};
|
|
1935
|
+
// Get the default icon based on the theme, falling back to 'md' icon if necessary
|
|
1936
|
+
const defaultIcon = defaultIcons[theme] || defaultIcons.md;
|
|
1937
|
+
// Return the configured datetime next icon or the default icon
|
|
1938
|
+
return index.config.get('datetimeNextIcon', defaultIcon);
|
|
1939
|
+
}
|
|
1940
|
+
/**
|
|
1941
|
+
* Get the icon to use for the previous icon.
|
|
1942
|
+
* Otherwise, use the icon set in the config.
|
|
1943
|
+
* If no icon is set in the config, use the default icon.
|
|
1944
|
+
*/
|
|
1945
|
+
get datetimePreviousIcon() {
|
|
1946
|
+
// Determine the theme and map to default icons
|
|
1947
|
+
const theme = ionicGlobal.getIonTheme(this);
|
|
1948
|
+
const defaultIcons = {
|
|
1949
|
+
ios: index$1.chevronBack,
|
|
1950
|
+
ionic: caretLeft.caretLeftSvg,
|
|
1951
|
+
md: index$1.chevronBack,
|
|
1952
|
+
};
|
|
1953
|
+
// Get the default icon based on the theme, falling back to 'md' icon if necessary
|
|
1954
|
+
const defaultIcon = defaultIcons[theme] || defaultIcons.md;
|
|
1955
|
+
// Return the configured datetime previous icon or the default icon
|
|
1956
|
+
return index.config.get('datetimePreviousIcon', defaultIcon);
|
|
1957
|
+
}
|
|
1958
|
+
/**
|
|
1959
|
+
* Get the icon to use for the show month and year icon.
|
|
1960
|
+
* Otherwise, use the icon set in the config.
|
|
1961
|
+
* If no icon is set in the config, use the default icon.
|
|
1962
|
+
*/
|
|
1963
|
+
get datetimeCollapsedIcon() {
|
|
1964
|
+
// Determine the theme and map to default icons
|
|
1965
|
+
const theme = ionicGlobal.getIonTheme(this);
|
|
1966
|
+
const defaultIcons = {
|
|
1967
|
+
ios: index$1.chevronForward,
|
|
1968
|
+
ionic: undefined,
|
|
1969
|
+
md: index$1.caretDownSharp,
|
|
1970
|
+
};
|
|
1971
|
+
// Get the default icon based on the theme, falling back to 'md' icon if necessary
|
|
1972
|
+
const defaultIcon = defaultIcons[theme] || defaultIcons.md;
|
|
1973
|
+
// Return the configured datetime show month and year icon or the default icon
|
|
1974
|
+
return index.config.get('datetimeCollapsedIcon', defaultIcon);
|
|
1975
|
+
}
|
|
1976
|
+
/**
|
|
1977
|
+
* Get the icon to use for the hide month and year icon.
|
|
1978
|
+
* Otherwise, use the icon set in the config.
|
|
1979
|
+
* If no icon is set in the config, use the default icon.
|
|
1980
|
+
*/
|
|
1981
|
+
get datetimeExpandedIcon() {
|
|
1982
|
+
// Determine the theme and map to default icons
|
|
1983
|
+
const theme = ionicGlobal.getIonTheme(this);
|
|
1984
|
+
const defaultIcons = {
|
|
1985
|
+
ios: index$1.chevronDown,
|
|
1986
|
+
ionic: undefined,
|
|
1987
|
+
md: index$1.caretUpSharp,
|
|
1988
|
+
};
|
|
1989
|
+
// Get the default icon based on the theme, falling back to 'md' icon if necessary
|
|
1990
|
+
const defaultIcon = defaultIcons[theme] || defaultIcons.md;
|
|
1991
|
+
// Return the configured datetime hide month and year icon or the default icon
|
|
1992
|
+
return index.config.get('datetimeExpandedIcon', defaultIcon);
|
|
1993
|
+
}
|
|
1916
1994
|
render() {
|
|
1917
1995
|
const { name, value, disabled, el, color, readonly, showMonthAndYear, preferWheel, presentation, size, isGridStyle, } = this;
|
|
1918
|
-
const
|
|
1996
|
+
const theme$1 = ionicGlobal.getIonTheme(this);
|
|
1919
1997
|
const isMonthAndYearPresentation = presentation === 'year' || presentation === 'month' || presentation === 'month-year';
|
|
1920
1998
|
const shouldShowMonthAndYear = showMonthAndYear || isMonthAndYearPresentation;
|
|
1921
1999
|
const monthYearPickerOpen = showMonthAndYear && !isMonthAndYearPresentation;
|
|
1922
2000
|
const hasDatePresentation = presentation === 'date' || presentation === 'date-time' || presentation === 'time-date';
|
|
1923
2001
|
const hasWheelVariant = hasDatePresentation && preferWheel;
|
|
1924
2002
|
helpers.renderHiddenInput(true, el, name, data.formatValue(value), disabled);
|
|
1925
|
-
return (index.h(index.Host, { key: '
|
|
1926
|
-
[
|
|
2003
|
+
return (index.h(index.Host, { key: 'd8b5c304ed0aa6e2145ef278daae3413f2e845b3', "aria-disabled": disabled ? 'true' : null, onFocus: this.onFocus, onBlur: this.onBlur, class: Object.assign({}, theme.createColorClasses(color, {
|
|
2004
|
+
[theme$1]: true,
|
|
1927
2005
|
['datetime-readonly']: readonly,
|
|
1928
2006
|
['datetime-disabled']: disabled,
|
|
1929
2007
|
'show-month-and-year': shouldShowMonthAndYear,
|
|
@@ -1932,7 +2010,7 @@ const Datetime = class {
|
|
|
1932
2010
|
[`datetime-size-${size}`]: true,
|
|
1933
2011
|
[`datetime-prefer-wheel`]: hasWheelVariant,
|
|
1934
2012
|
[`datetime-grid`]: isGridStyle,
|
|
1935
|
-
})) }, index.h("div", { key: '
|
|
2013
|
+
})) }, index.h("div", { key: 'ba2bcf3b9e9406bc4f5afb49f02e91fd96f3fc17', class: "intersection-tracker", ref: (el) => (this.intersectionTrackerRef = el) }), this.renderDatetime(theme$1)));
|
|
1936
2014
|
}
|
|
1937
2015
|
get el() { return index.getElement(this); }
|
|
1938
2016
|
static get watchers() { return {
|
|
@@ -1978,8 +2056,643 @@ const WHEEL_PART = 'wheel';
|
|
|
1978
2056
|
const WHEEL_ITEM_PART = 'wheel-item';
|
|
1979
2057
|
const WHEEL_ITEM_ACTIVE_PART = `active`;
|
|
1980
2058
|
Datetime.style = {
|
|
2059
|
+
ionic: datetimeIonicCss(),
|
|
1981
2060
|
ios: datetimeIosCss(),
|
|
1982
2061
|
md: datetimeMdCss()
|
|
1983
2062
|
};
|
|
1984
2063
|
|
|
2064
|
+
/**
|
|
2065
|
+
* iOS Picker Enter Animation
|
|
2066
|
+
*/
|
|
2067
|
+
const iosEnterAnimation = (baseEl) => {
|
|
2068
|
+
const baseAnimation = animation.createAnimation();
|
|
2069
|
+
const backdropAnimation = animation.createAnimation();
|
|
2070
|
+
const wrapperAnimation = animation.createAnimation();
|
|
2071
|
+
backdropAnimation
|
|
2072
|
+
.addElement(baseEl.querySelector('ion-backdrop'))
|
|
2073
|
+
.fromTo('opacity', 0.01, 'var(--backdrop-opacity)')
|
|
2074
|
+
.beforeStyles({
|
|
2075
|
+
'pointer-events': 'none',
|
|
2076
|
+
})
|
|
2077
|
+
.afterClearStyles(['pointer-events']);
|
|
2078
|
+
wrapperAnimation
|
|
2079
|
+
.addElement(baseEl.querySelector('.picker-wrapper'))
|
|
2080
|
+
.fromTo('transform', 'translateY(100%)', 'translateY(0%)');
|
|
2081
|
+
return baseAnimation
|
|
2082
|
+
.addElement(baseEl)
|
|
2083
|
+
.easing('cubic-bezier(.36,.66,.04,1)')
|
|
2084
|
+
.duration(400)
|
|
2085
|
+
.addAnimation([backdropAnimation, wrapperAnimation]);
|
|
2086
|
+
};
|
|
2087
|
+
|
|
2088
|
+
/**
|
|
2089
|
+
* iOS Picker Leave Animation
|
|
2090
|
+
*/
|
|
2091
|
+
const iosLeaveAnimation = (baseEl) => {
|
|
2092
|
+
const baseAnimation = animation.createAnimation();
|
|
2093
|
+
const backdropAnimation = animation.createAnimation();
|
|
2094
|
+
const wrapperAnimation = animation.createAnimation();
|
|
2095
|
+
backdropAnimation
|
|
2096
|
+
.addElement(baseEl.querySelector('ion-backdrop'))
|
|
2097
|
+
.fromTo('opacity', 'var(--backdrop-opacity)', 0.01);
|
|
2098
|
+
wrapperAnimation
|
|
2099
|
+
.addElement(baseEl.querySelector('.picker-wrapper'))
|
|
2100
|
+
.fromTo('transform', 'translateY(0%)', 'translateY(100%)');
|
|
2101
|
+
return baseAnimation
|
|
2102
|
+
.addElement(baseEl)
|
|
2103
|
+
.easing('cubic-bezier(.36,.66,.04,1)')
|
|
2104
|
+
.duration(400)
|
|
2105
|
+
.addAnimation([backdropAnimation, wrapperAnimation]);
|
|
2106
|
+
};
|
|
2107
|
+
|
|
2108
|
+
const pickerIosCss = () => `.sc-ion-picker-legacy-ios-h{--border-radius:0;--border-style:solid;--min-width:auto;--width:100%;--max-width:500px;--min-height:auto;--max-height:auto;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;top:0;display:block;position:absolute;width:100%;height:100%;outline:none;font-family:var(--ion-font-family, inherit);contain:strict;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;z-index:1001}.sc-ion-picker-legacy-ios-h{inset-inline-start:0}.overlay-hidden.sc-ion-picker-legacy-ios-h{display:none}.picker-wrapper.sc-ion-picker-legacy-ios{border-radius:var(--border-radius);right:0;left:0;bottom:0;-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto;margin-top:auto;margin-bottom:auto;-webkit-transform:translate3d(0, 100%, 0);transform:translate3d(0, 100%, 0);display:-ms-flexbox;display:flex;position:absolute;-ms-flex-direction:column;flex-direction:column;width:var(--width);min-width:var(--min-width);max-width:var(--max-width);height:var(--height);min-height:var(--min-height);max-height:var(--max-height);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);background:var(--background);contain:strict;overflow:hidden;z-index:10}.picker-toolbar.sc-ion-picker-legacy-ios{width:100%;background:transparent;contain:strict;z-index:1}.picker-button.sc-ion-picker-legacy-ios{border:0;font-family:inherit}.picker-button.sc-ion-picker-legacy-ios:active,.picker-button.sc-ion-picker-legacy-ios:focus{outline:none}.picker-columns.sc-ion-picker-legacy-ios{display:-ms-flexbox;display:flex;position:relative;-ms-flex-pack:center;justify-content:center;margin-bottom:var(--ion-safe-area-bottom, 0);contain:strict;overflow:hidden}.picker-above-highlight.sc-ion-picker-legacy-ios,.picker-below-highlight.sc-ion-picker-legacy-ios{display:none;pointer-events:none}.sc-ion-picker-legacy-ios-h{--background:var(--ion-background-color, #fff);--border-width:1px 0 0;--border-color:var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-250, var(--ion-background-color-step-250, #c8c7cc))));--height:260px;--backdrop-opacity:var(--ion-backdrop-opacity, 0.26);color:var(--ion-item-color, var(--ion-text-color, #000))}.picker-toolbar.sc-ion-picker-legacy-ios{display:-ms-flexbox;display:flex;height:44px;border-bottom:0.55px solid var(--border-color)}.picker-toolbar-button.sc-ion-picker-legacy-ios{-ms-flex:1;flex:1;text-align:end}.picker-toolbar-button.sc-ion-picker-legacy-ios:last-child .picker-button.sc-ion-picker-legacy-ios{font-weight:600}.picker-toolbar-button.sc-ion-picker-legacy-ios:first-child{font-weight:normal;text-align:start}.picker-button.sc-ion-picker-legacy-ios,.picker-button.ion-activated.sc-ion-picker-legacy-ios{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;-webkit-padding-start:1em;padding-inline-start:1em;-webkit-padding-end:1em;padding-inline-end:1em;padding-top:0;padding-bottom:0;height:44px;background:transparent;color:var(--ion-color-primary, #0054e9);font-size:16px}.picker-columns.sc-ion-picker-legacy-ios{height:215px;-webkit-perspective:1000px;perspective:1000px}.picker-above-highlight.sc-ion-picker-legacy-ios{top:0;-webkit-transform:translate3d(0, 0, 90px);transform:translate3d(0, 0, 90px);display:block;position:absolute;width:100%;height:81px;border-bottom:1px solid var(--border-color);background:-webkit-gradient(linear, left top, left bottom, color-stop(20%, var(--background, var(--ion-background-color, #fff))), to(rgba(var(--background-rgb, var(--ion-background-color-rgb, 255, 255, 255)), 0.8)));background:linear-gradient(to bottom, var(--background, var(--ion-background-color, #fff)) 20%, rgba(var(--background-rgb, var(--ion-background-color-rgb, 255, 255, 255)), 0.8) 100%);z-index:10}.picker-above-highlight.sc-ion-picker-legacy-ios{inset-inline-start:0}.picker-below-highlight.sc-ion-picker-legacy-ios{top:115px;-webkit-transform:translate3d(0, 0, 90px);transform:translate3d(0, 0, 90px);display:block;position:absolute;width:100%;height:119px;border-top:1px solid var(--border-color);background:-webkit-gradient(linear, left bottom, left top, color-stop(30%, var(--background, var(--ion-background-color, #fff))), to(rgba(var(--background-rgb, var(--ion-background-color-rgb, 255, 255, 255)), 0.8)));background:linear-gradient(to top, var(--background, var(--ion-background-color, #fff)) 30%, rgba(var(--background-rgb, var(--ion-background-color-rgb, 255, 255, 255)), 0.8) 100%);z-index:11}.picker-below-highlight.sc-ion-picker-legacy-ios{inset-inline-start:0}`;
|
|
2109
|
+
|
|
2110
|
+
const pickerMdCss = () => `.sc-ion-picker-legacy-md-h{--border-radius:0;--border-style:solid;--min-width:auto;--width:100%;--max-width:500px;--min-height:auto;--max-height:auto;-moz-osx-font-smoothing:grayscale;-webkit-font-smoothing:antialiased;top:0;display:block;position:absolute;width:100%;height:100%;outline:none;font-family:var(--ion-font-family, inherit);contain:strict;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;z-index:1001}.sc-ion-picker-legacy-md-h{inset-inline-start:0}.overlay-hidden.sc-ion-picker-legacy-md-h{display:none}.picker-wrapper.sc-ion-picker-legacy-md{border-radius:var(--border-radius);right:0;left:0;bottom:0;-webkit-margin-start:auto;margin-inline-start:auto;-webkit-margin-end:auto;margin-inline-end:auto;margin-top:auto;margin-bottom:auto;-webkit-transform:translate3d(0, 100%, 0);transform:translate3d(0, 100%, 0);display:-ms-flexbox;display:flex;position:absolute;-ms-flex-direction:column;flex-direction:column;width:var(--width);min-width:var(--min-width);max-width:var(--max-width);height:var(--height);min-height:var(--min-height);max-height:var(--max-height);border-width:var(--border-width);border-style:var(--border-style);border-color:var(--border-color);background:var(--background);contain:strict;overflow:hidden;z-index:10}.picker-toolbar.sc-ion-picker-legacy-md{width:100%;background:transparent;contain:strict;z-index:1}.picker-button.sc-ion-picker-legacy-md{border:0;font-family:inherit}.picker-button.sc-ion-picker-legacy-md:active,.picker-button.sc-ion-picker-legacy-md:focus{outline:none}.picker-columns.sc-ion-picker-legacy-md{display:-ms-flexbox;display:flex;position:relative;-ms-flex-pack:center;justify-content:center;margin-bottom:var(--ion-safe-area-bottom, 0);contain:strict;overflow:hidden}.picker-above-highlight.sc-ion-picker-legacy-md,.picker-below-highlight.sc-ion-picker-legacy-md{display:none;pointer-events:none}.sc-ion-picker-legacy-md-h{--background:var(--ion-background-color, #fff);--border-width:0.55px 0 0;--border-color:var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-150, var(--ion-background-color-step-150, rgba(0, 0, 0, 0.13)))));--height:260px;--backdrop-opacity:var(--ion-backdrop-opacity, 0.26);color:var(--ion-item-color, var(--ion-text-color, #000))}.picker-toolbar.sc-ion-picker-legacy-md{display:-ms-flexbox;display:flex;-ms-flex-pack:end;justify-content:flex-end;height:44px}.picker-button.sc-ion-picker-legacy-md,.picker-button.ion-activated.sc-ion-picker-legacy-md{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;-webkit-padding-start:1.1em;padding-inline-start:1.1em;-webkit-padding-end:1.1em;padding-inline-end:1.1em;padding-top:0;padding-bottom:0;height:44px;background:transparent;color:var(--ion-color-primary, #0054e9);font-size:14px;font-weight:500;text-transform:uppercase;-webkit-box-shadow:none;box-shadow:none}.picker-columns.sc-ion-picker-legacy-md{height:216px;-webkit-perspective:1800px;perspective:1800px}.picker-above-highlight.sc-ion-picker-legacy-md{top:0;-webkit-transform:translate3d(0, 0, 90px);transform:translate3d(0, 0, 90px);position:absolute;width:100%;height:81px;border-bottom:1px solid var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-150, var(--ion-background-color-step-150, rgba(0, 0, 0, 0.13)))));background:-webkit-gradient(linear, left top, left bottom, color-stop(20%, var(--ion-background-color, #fff)), to(rgba(var(--ion-background-color-rgb, 255, 255, 255), 0.8)));background:linear-gradient(to bottom, var(--ion-background-color, #fff) 20%, rgba(var(--ion-background-color-rgb, 255, 255, 255), 0.8) 100%);z-index:10}.picker-above-highlight.sc-ion-picker-legacy-md{inset-inline-start:0}.picker-below-highlight.sc-ion-picker-legacy-md{top:115px;-webkit-transform:translate3d(0, 0, 90px);transform:translate3d(0, 0, 90px);position:absolute;width:100%;height:119px;border-top:1px solid var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-150, var(--ion-background-color-step-150, rgba(0, 0, 0, 0.13)))));background:-webkit-gradient(linear, left bottom, left top, color-stop(30%, var(--ion-background-color, #fff)), to(rgba(var(--ion-background-color-rgb, 255, 255, 255), 0.8)));background:linear-gradient(to top, var(--ion-background-color, #fff) 30%, rgba(var(--ion-background-color-rgb, 255, 255, 255), 0.8) 100%);z-index:11}.picker-below-highlight.sc-ion-picker-legacy-md{inset-inline-start:0}`;
|
|
2111
|
+
|
|
2112
|
+
const Picker = class {
|
|
2113
|
+
constructor(hostRef) {
|
|
2114
|
+
index.registerInstance(this, hostRef);
|
|
2115
|
+
this.didPresent = index.createEvent(this, "ionPickerDidPresent", 7);
|
|
2116
|
+
this.willPresent = index.createEvent(this, "ionPickerWillPresent", 7);
|
|
2117
|
+
this.willDismiss = index.createEvent(this, "ionPickerWillDismiss", 7);
|
|
2118
|
+
this.didDismiss = index.createEvent(this, "ionPickerDidDismiss", 7);
|
|
2119
|
+
this.didPresentShorthand = index.createEvent(this, "didPresent", 7);
|
|
2120
|
+
this.willPresentShorthand = index.createEvent(this, "willPresent", 7);
|
|
2121
|
+
this.willDismissShorthand = index.createEvent(this, "willDismiss", 7);
|
|
2122
|
+
this.didDismissShorthand = index.createEvent(this, "didDismiss", 7);
|
|
2123
|
+
this.delegateController = overlays.createDelegateController(this);
|
|
2124
|
+
this.lockController = lockController.createLockController();
|
|
2125
|
+
this.triggerController = overlays.createTriggerController();
|
|
2126
|
+
this.presented = false;
|
|
2127
|
+
/** @internal */
|
|
2128
|
+
this.hasController = false;
|
|
2129
|
+
/**
|
|
2130
|
+
* If `true`, the keyboard will be automatically dismissed when the overlay is presented.
|
|
2131
|
+
*/
|
|
2132
|
+
this.keyboardClose = true;
|
|
2133
|
+
/**
|
|
2134
|
+
* Array of buttons to be displayed at the top of the picker.
|
|
2135
|
+
*/
|
|
2136
|
+
this.buttons = [];
|
|
2137
|
+
/**
|
|
2138
|
+
* Array of columns to be displayed in the picker.
|
|
2139
|
+
*/
|
|
2140
|
+
this.columns = [];
|
|
2141
|
+
/**
|
|
2142
|
+
* Number of milliseconds to wait before dismissing the picker.
|
|
2143
|
+
*/
|
|
2144
|
+
this.duration = 0;
|
|
2145
|
+
/**
|
|
2146
|
+
* If `true`, a backdrop will be displayed behind the picker.
|
|
2147
|
+
*/
|
|
2148
|
+
this.showBackdrop = true;
|
|
2149
|
+
/**
|
|
2150
|
+
* If `true`, the picker will be dismissed when the backdrop is clicked.
|
|
2151
|
+
*/
|
|
2152
|
+
this.backdropDismiss = true;
|
|
2153
|
+
/**
|
|
2154
|
+
* If `true`, the picker will animate.
|
|
2155
|
+
*/
|
|
2156
|
+
this.animated = true;
|
|
2157
|
+
/**
|
|
2158
|
+
* If `true`, the picker will open. If `false`, the picker will close.
|
|
2159
|
+
* Use this if you need finer grained control over presentation, otherwise
|
|
2160
|
+
* just use the pickerController or the `trigger` property.
|
|
2161
|
+
* Note: `isOpen` will not automatically be set back to `false` when
|
|
2162
|
+
* the picker dismisses. You will need to do that in your code.
|
|
2163
|
+
*/
|
|
2164
|
+
this.isOpen = false;
|
|
2165
|
+
this.onBackdropTap = () => {
|
|
2166
|
+
this.dismiss(undefined, overlays.BACKDROP);
|
|
2167
|
+
};
|
|
2168
|
+
this.dispatchCancelHandler = (ev) => {
|
|
2169
|
+
const role = ev.detail.role;
|
|
2170
|
+
if (overlays.isCancel(role)) {
|
|
2171
|
+
const cancelButton = this.buttons.find((b) => b.role === 'cancel');
|
|
2172
|
+
this.callButtonHandler(cancelButton);
|
|
2173
|
+
}
|
|
2174
|
+
};
|
|
2175
|
+
}
|
|
2176
|
+
onIsOpenChange(newValue, oldValue) {
|
|
2177
|
+
if (newValue === true && oldValue === false) {
|
|
2178
|
+
this.present();
|
|
2179
|
+
}
|
|
2180
|
+
else if (newValue === false && oldValue === true) {
|
|
2181
|
+
this.dismiss();
|
|
2182
|
+
}
|
|
2183
|
+
}
|
|
2184
|
+
triggerChanged() {
|
|
2185
|
+
const { trigger, el, triggerController } = this;
|
|
2186
|
+
if (trigger) {
|
|
2187
|
+
triggerController.addClickListener(el, trigger);
|
|
2188
|
+
}
|
|
2189
|
+
}
|
|
2190
|
+
connectedCallback() {
|
|
2191
|
+
overlays.prepareOverlay(this.el);
|
|
2192
|
+
this.triggerChanged();
|
|
2193
|
+
}
|
|
2194
|
+
disconnectedCallback() {
|
|
2195
|
+
this.triggerController.removeClickListener();
|
|
2196
|
+
}
|
|
2197
|
+
componentWillLoad() {
|
|
2198
|
+
var _a;
|
|
2199
|
+
if (!((_a = this.htmlAttributes) === null || _a === void 0 ? void 0 : _a.id)) {
|
|
2200
|
+
overlays.setOverlayId(this.el);
|
|
2201
|
+
}
|
|
2202
|
+
}
|
|
2203
|
+
componentDidLoad() {
|
|
2204
|
+
index.printIonWarning('[ion-picker-legacy] - ion-picker-legacy and ion-picker-legacy-column have been deprecated in favor of new versions of the ion-picker and ion-picker-column components. These new components display inline with your page content allowing for more presentation flexibility than before.', this.el);
|
|
2205
|
+
/**
|
|
2206
|
+
* If picker was rendered with isOpen="true"
|
|
2207
|
+
* then we should open picker immediately.
|
|
2208
|
+
*/
|
|
2209
|
+
if (this.isOpen === true) {
|
|
2210
|
+
helpers.raf(() => this.present());
|
|
2211
|
+
}
|
|
2212
|
+
/**
|
|
2213
|
+
* When binding values in frameworks such as Angular
|
|
2214
|
+
* it is possible for the value to be set after the Web Component
|
|
2215
|
+
* initializes but before the value watcher is set up in Stencil.
|
|
2216
|
+
* As a result, the watcher callback may not be fired.
|
|
2217
|
+
* We work around this by manually calling the watcher
|
|
2218
|
+
* callback when the component has loaded and the watcher
|
|
2219
|
+
* is configured.
|
|
2220
|
+
*/
|
|
2221
|
+
this.triggerChanged();
|
|
2222
|
+
}
|
|
2223
|
+
/**
|
|
2224
|
+
* Present the picker overlay after it has been created.
|
|
2225
|
+
*/
|
|
2226
|
+
async present() {
|
|
2227
|
+
const unlock = await this.lockController.lock();
|
|
2228
|
+
await this.delegateController.attachViewToDom();
|
|
2229
|
+
await overlays.present(this, 'pickerEnter', iosEnterAnimation, iosEnterAnimation, undefined);
|
|
2230
|
+
if (this.duration > 0) {
|
|
2231
|
+
this.durationTimeout = setTimeout(() => this.dismiss(), this.duration);
|
|
2232
|
+
}
|
|
2233
|
+
unlock();
|
|
2234
|
+
}
|
|
2235
|
+
/**
|
|
2236
|
+
* Dismiss the picker overlay after it has been presented.
|
|
2237
|
+
*
|
|
2238
|
+
* @param data Any data to emit in the dismiss events.
|
|
2239
|
+
* @param role The role of the element that is dismissing the picker.
|
|
2240
|
+
* This can be useful in a button handler for determining which button was
|
|
2241
|
+
* clicked to dismiss the picker.
|
|
2242
|
+
* Some examples include: ``"cancel"`, `"destructive"`, "selected"`, and `"backdrop"`.
|
|
2243
|
+
*/
|
|
2244
|
+
async dismiss(data, role) {
|
|
2245
|
+
const unlock = await this.lockController.lock();
|
|
2246
|
+
if (this.durationTimeout) {
|
|
2247
|
+
clearTimeout(this.durationTimeout);
|
|
2248
|
+
}
|
|
2249
|
+
const dismissed = await overlays.dismiss(this, data, role, 'pickerLeave', iosLeaveAnimation, iosLeaveAnimation);
|
|
2250
|
+
if (dismissed) {
|
|
2251
|
+
this.delegateController.removeViewFromDom();
|
|
2252
|
+
}
|
|
2253
|
+
unlock();
|
|
2254
|
+
return dismissed;
|
|
2255
|
+
}
|
|
2256
|
+
/**
|
|
2257
|
+
* Returns a promise that resolves when the picker did dismiss.
|
|
2258
|
+
*/
|
|
2259
|
+
onDidDismiss() {
|
|
2260
|
+
return overlays.eventMethod(this.el, 'ionPickerDidDismiss');
|
|
2261
|
+
}
|
|
2262
|
+
/**
|
|
2263
|
+
* Returns a promise that resolves when the picker will dismiss.
|
|
2264
|
+
*/
|
|
2265
|
+
onWillDismiss() {
|
|
2266
|
+
return overlays.eventMethod(this.el, 'ionPickerWillDismiss');
|
|
2267
|
+
}
|
|
2268
|
+
/**
|
|
2269
|
+
* Get the column that matches the specified name.
|
|
2270
|
+
*
|
|
2271
|
+
* @param name The name of the column.
|
|
2272
|
+
*/
|
|
2273
|
+
getColumn(name) {
|
|
2274
|
+
return Promise.resolve(this.columns.find((column) => column.name === name));
|
|
2275
|
+
}
|
|
2276
|
+
async buttonClick(button) {
|
|
2277
|
+
const role = button.role;
|
|
2278
|
+
if (overlays.isCancel(role)) {
|
|
2279
|
+
return this.dismiss(undefined, role);
|
|
2280
|
+
}
|
|
2281
|
+
const shouldDismiss = await this.callButtonHandler(button);
|
|
2282
|
+
if (shouldDismiss) {
|
|
2283
|
+
return this.dismiss(this.getSelected(), button.role);
|
|
2284
|
+
}
|
|
2285
|
+
return Promise.resolve();
|
|
2286
|
+
}
|
|
2287
|
+
async callButtonHandler(button) {
|
|
2288
|
+
if (button) {
|
|
2289
|
+
// a handler has been provided, execute it
|
|
2290
|
+
// pass the handler the values from the inputs
|
|
2291
|
+
const rtn = await overlays.safeCall(button.handler, this.getSelected());
|
|
2292
|
+
if (rtn === false) {
|
|
2293
|
+
// if the return value of the handler is false then do not dismiss
|
|
2294
|
+
return false;
|
|
2295
|
+
}
|
|
2296
|
+
}
|
|
2297
|
+
return true;
|
|
2298
|
+
}
|
|
2299
|
+
getSelected() {
|
|
2300
|
+
const selected = {};
|
|
2301
|
+
this.columns.forEach((col, index) => {
|
|
2302
|
+
const selectedColumn = col.selectedIndex !== undefined ? col.options[col.selectedIndex] : undefined;
|
|
2303
|
+
selected[col.name] = {
|
|
2304
|
+
text: selectedColumn ? selectedColumn.text : undefined,
|
|
2305
|
+
value: selectedColumn ? selectedColumn.value : undefined,
|
|
2306
|
+
columnIndex: index,
|
|
2307
|
+
};
|
|
2308
|
+
});
|
|
2309
|
+
return selected;
|
|
2310
|
+
}
|
|
2311
|
+
render() {
|
|
2312
|
+
const { htmlAttributes } = this;
|
|
2313
|
+
const theme$1 = ionicGlobal.getIonTheme(this);
|
|
2314
|
+
return (index.h(index.Host, Object.assign({ key: 'b0c1fc8eee284f03c696f0c8aaa29f4a6d7be0be', "aria-modal": "true", tabindex: "-1" }, htmlAttributes, { style: {
|
|
2315
|
+
zIndex: `${20000 + this.overlayIndex}`,
|
|
2316
|
+
}, class: Object.assign({ [theme$1]: true,
|
|
2317
|
+
// Used internally for styling
|
|
2318
|
+
[`picker-${theme$1}`]: true, 'overlay-hidden': true }, theme.getClassMap(this.cssClass)), onIonBackdropTap: this.onBackdropTap, onIonPickerWillDismiss: this.dispatchCancelHandler }), index.h("ion-backdrop", { key: 'b56a9f94c7a95efc047d7be95e76ba3a2284801d', visible: this.showBackdrop, tappable: this.backdropDismiss }), index.h("div", { key: 'f134d49a3afcfd2a809147b55949cea43fc34462', tabindex: "0", "aria-hidden": "true" }), index.h("div", { key: '9ae98dc10164e182a13eaef2105894a717a03cc4', class: "picker-wrapper ion-overlay-wrapper", role: "dialog" }, index.h("div", { key: '96acad60c1214e13098282182fa855b19f0a386c', class: "picker-toolbar" }, this.buttons.map((b) => (index.h("div", { class: buttonWrapperClass(b) }, index.h("button", { type: "button", onClick: () => this.buttonClick(b), class: buttonClass(b) }, b.text))))), index.h("div", { key: 'af26cd644ed9bb50c22f06624da3726e7e60426f', class: "picker-columns" }, index.h("div", { key: 'c0d8bf724f7dc081c314bef61fa08894a75c657b', class: "picker-above-highlight" }), this.presented && this.columns.map((c) => index.h("ion-picker-legacy-column", { col: c })), index.h("div", { key: '7315333742b5b0c9533f30e5ce3dfc6ec9112dc1', class: "picker-below-highlight" }))), index.h("div", { key: '454546aaf27319ae7973e74063c0a026cfc88834', tabindex: "0", "aria-hidden": "true" })));
|
|
2319
|
+
}
|
|
2320
|
+
get el() { return index.getElement(this); }
|
|
2321
|
+
static get watchers() { return {
|
|
2322
|
+
"isOpen": [{
|
|
2323
|
+
"onIsOpenChange": 0
|
|
2324
|
+
}],
|
|
2325
|
+
"trigger": [{
|
|
2326
|
+
"triggerChanged": 0
|
|
2327
|
+
}]
|
|
2328
|
+
}; }
|
|
2329
|
+
};
|
|
2330
|
+
const buttonWrapperClass = (button) => {
|
|
2331
|
+
return {
|
|
2332
|
+
[`picker-toolbar-${button.role}`]: button.role !== undefined,
|
|
2333
|
+
'picker-toolbar-button': true,
|
|
2334
|
+
};
|
|
2335
|
+
};
|
|
2336
|
+
const buttonClass = (button) => {
|
|
2337
|
+
return Object.assign({ 'picker-button': true, 'ion-activatable': true }, theme.getClassMap(button.cssClass));
|
|
2338
|
+
};
|
|
2339
|
+
Picker.style = {
|
|
2340
|
+
ios: pickerIosCss(),
|
|
2341
|
+
md: pickerMdCss()
|
|
2342
|
+
};
|
|
2343
|
+
|
|
2344
|
+
const pickerColumnIosCss = () => `.picker-col{display:-ms-flexbox;display:flex;position:relative;-ms-flex:1;flex:1;-ms-flex-pack:center;justify-content:center;height:100%;-webkit-box-sizing:content-box;box-sizing:content-box;contain:content}.picker-opts{position:relative;-ms-flex:1;flex:1;max-width:100%}.picker-opt{top:0;display:block;position:absolute;width:100%;border:0;text-align:center;text-overflow:ellipsis;white-space:nowrap;contain:strict;overflow:hidden;will-change:transform}.picker-opt{inset-inline-start:0}.picker-opt.picker-opt-disabled{pointer-events:none}.picker-opt-disabled{opacity:0}.picker-opts-left{-ms-flex-pack:start;justify-content:flex-start}.picker-opts-right{-ms-flex-pack:end;justify-content:flex-end}.picker-opt:active,.picker-opt:focus{outline:none}.picker-prefix{position:relative;-ms-flex:1;flex:1;text-align:end;white-space:nowrap}.picker-suffix{position:relative;-ms-flex:1;flex:1;text-align:start;white-space:nowrap}.picker-col{-webkit-padding-start:4px;padding-inline-start:4px;-webkit-padding-end:4px;padding-inline-end:4px;padding-top:0;padding-bottom:0;-webkit-transform-style:preserve-3d;transform-style:preserve-3d}.picker-prefix,.picker-suffix,.picker-opts{top:77px;-webkit-transform-style:preserve-3d;transform-style:preserve-3d;color:inherit;font-size:20px;line-height:42px;pointer-events:none}.picker-opt{padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;-webkit-transform-origin:center center;transform-origin:center center;height:46px;-webkit-transform-style:preserve-3d;transform-style:preserve-3d;-webkit-transition-timing-function:ease-out;transition-timing-function:ease-out;background:transparent;color:inherit;font-size:20px;line-height:42px;-webkit-backface-visibility:hidden;backface-visibility:hidden;pointer-events:auto}:host-context([dir=rtl]) .picker-opt{-webkit-transform-origin:calc(100% - center) center;transform-origin:calc(100% - center) center}[dir=rtl] .picker-opt{-webkit-transform-origin:calc(100% - center) center;transform-origin:calc(100% - center) center}@supports selector(:dir(rtl)){.picker-opt:dir(rtl){-webkit-transform-origin:calc(100% - center) center;transform-origin:calc(100% - center) center}}`;
|
|
2345
|
+
|
|
2346
|
+
const pickerColumnMdCss = () => `.picker-col{display:-ms-flexbox;display:flex;position:relative;-ms-flex:1;flex:1;-ms-flex-pack:center;justify-content:center;height:100%;-webkit-box-sizing:content-box;box-sizing:content-box;contain:content}.picker-opts{position:relative;-ms-flex:1;flex:1;max-width:100%}.picker-opt{top:0;display:block;position:absolute;width:100%;border:0;text-align:center;text-overflow:ellipsis;white-space:nowrap;contain:strict;overflow:hidden;will-change:transform}.picker-opt{inset-inline-start:0}.picker-opt.picker-opt-disabled{pointer-events:none}.picker-opt-disabled{opacity:0}.picker-opts-left{-ms-flex-pack:start;justify-content:flex-start}.picker-opts-right{-ms-flex-pack:end;justify-content:flex-end}.picker-opt:active,.picker-opt:focus{outline:none}.picker-prefix{position:relative;-ms-flex:1;flex:1;text-align:end;white-space:nowrap}.picker-suffix{position:relative;-ms-flex:1;flex:1;text-align:start;white-space:nowrap}.picker-col{-webkit-padding-start:8px;padding-inline-start:8px;-webkit-padding-end:8px;padding-inline-end:8px;padding-top:0;padding-bottom:0;-webkit-transform-style:preserve-3d;transform-style:preserve-3d}.picker-prefix,.picker-suffix,.picker-opts{top:77px;-webkit-transform-style:preserve-3d;transform-style:preserve-3d;color:inherit;font-size:22px;line-height:42px;pointer-events:none}.picker-opt{margin-left:0;margin-right:0;margin-top:0;margin-bottom:0;padding-left:0;padding-right:0;padding-top:0;padding-bottom:0;height:43px;-webkit-transition-timing-function:ease-out;transition-timing-function:ease-out;background:transparent;color:inherit;font-size:22px;line-height:42px;-webkit-backface-visibility:hidden;backface-visibility:hidden;pointer-events:auto}.picker-prefix,.picker-suffix,.picker-opt.picker-opt-selected{color:var(--ion-color-primary, #0054e9)}`;
|
|
2347
|
+
|
|
2348
|
+
const PickerColumnCmp = class {
|
|
2349
|
+
constructor(hostRef) {
|
|
2350
|
+
index.registerInstance(this, hostRef);
|
|
2351
|
+
this.ionPickerColChange = index.createEvent(this, "ionPickerColChange", 7);
|
|
2352
|
+
this.optHeight = 0;
|
|
2353
|
+
this.rotateFactor = 0;
|
|
2354
|
+
this.scaleFactor = 1;
|
|
2355
|
+
this.velocity = 0;
|
|
2356
|
+
this.y = 0;
|
|
2357
|
+
this.noAnimate = true;
|
|
2358
|
+
// `colDidChange` is a flag that gets set when the column is changed
|
|
2359
|
+
// dynamically. When this flag is set, the column will refresh
|
|
2360
|
+
// after the component re-renders to incorporate the new column data.
|
|
2361
|
+
// This is necessary because `this.refresh` queries for the option elements,
|
|
2362
|
+
// so it needs to wait for the latest elements to be available in the DOM.
|
|
2363
|
+
// Ex: column is created with 3 options. User updates the column data
|
|
2364
|
+
// to have 5 options. The column will still think it only has 3 options.
|
|
2365
|
+
this.colDidChange = false;
|
|
2366
|
+
}
|
|
2367
|
+
colChanged() {
|
|
2368
|
+
this.colDidChange = true;
|
|
2369
|
+
}
|
|
2370
|
+
async connectedCallback() {
|
|
2371
|
+
let pickerRotateFactor = 0;
|
|
2372
|
+
let pickerScaleFactor = 0.81;
|
|
2373
|
+
const mode = ionicGlobal.getIonMode(this);
|
|
2374
|
+
if (mode === 'ios') {
|
|
2375
|
+
pickerRotateFactor = -0.46;
|
|
2376
|
+
pickerScaleFactor = 1;
|
|
2377
|
+
}
|
|
2378
|
+
this.rotateFactor = pickerRotateFactor;
|
|
2379
|
+
this.scaleFactor = pickerScaleFactor;
|
|
2380
|
+
this.gesture = (await Promise.resolve().then(function () { return require('./index-CAvQ7Tka.js'); })).createGesture({
|
|
2381
|
+
el: this.el,
|
|
2382
|
+
gestureName: 'picker-swipe',
|
|
2383
|
+
gesturePriority: 100,
|
|
2384
|
+
threshold: 0,
|
|
2385
|
+
passive: false,
|
|
2386
|
+
onStart: (ev) => this.onStart(ev),
|
|
2387
|
+
onMove: (ev) => this.onMove(ev),
|
|
2388
|
+
onEnd: (ev) => this.onEnd(ev),
|
|
2389
|
+
});
|
|
2390
|
+
this.gesture.enable();
|
|
2391
|
+
// Options have not been initialized yet
|
|
2392
|
+
// Animation must be disabled through the `noAnimate` flag
|
|
2393
|
+
// Otherwise, the options will render
|
|
2394
|
+
// at the top of the column and transition down
|
|
2395
|
+
this.tmrId = setTimeout(() => {
|
|
2396
|
+
this.noAnimate = false;
|
|
2397
|
+
// After initialization, `refresh()` will be called
|
|
2398
|
+
// At this point, animation will be enabled. The options will
|
|
2399
|
+
// animate as they are being selected.
|
|
2400
|
+
this.refresh(true);
|
|
2401
|
+
}, 250);
|
|
2402
|
+
}
|
|
2403
|
+
componentDidLoad() {
|
|
2404
|
+
this.onDomChange();
|
|
2405
|
+
}
|
|
2406
|
+
componentDidUpdate() {
|
|
2407
|
+
// Options may have changed since last update.
|
|
2408
|
+
if (this.colDidChange) {
|
|
2409
|
+
// Animation must be disabled through the `onDomChange` parameter.
|
|
2410
|
+
// Otherwise, the recently added options will render
|
|
2411
|
+
// at the top of the column and transition down
|
|
2412
|
+
this.onDomChange(true, false);
|
|
2413
|
+
this.colDidChange = false;
|
|
2414
|
+
}
|
|
2415
|
+
}
|
|
2416
|
+
disconnectedCallback() {
|
|
2417
|
+
if (this.rafId !== undefined)
|
|
2418
|
+
cancelAnimationFrame(this.rafId);
|
|
2419
|
+
if (this.tmrId)
|
|
2420
|
+
clearTimeout(this.tmrId);
|
|
2421
|
+
if (this.gesture) {
|
|
2422
|
+
this.gesture.destroy();
|
|
2423
|
+
this.gesture = undefined;
|
|
2424
|
+
}
|
|
2425
|
+
}
|
|
2426
|
+
emitColChange() {
|
|
2427
|
+
this.ionPickerColChange.emit(this.col);
|
|
2428
|
+
}
|
|
2429
|
+
setSelected(selectedIndex, duration) {
|
|
2430
|
+
// if there is a selected index, then figure out it's y position
|
|
2431
|
+
// if there isn't a selected index, then just use the top y position
|
|
2432
|
+
const y = selectedIndex > -1 ? -(selectedIndex * this.optHeight) : 0;
|
|
2433
|
+
this.velocity = 0;
|
|
2434
|
+
// set what y position we're at
|
|
2435
|
+
if (this.rafId !== undefined)
|
|
2436
|
+
cancelAnimationFrame(this.rafId);
|
|
2437
|
+
this.update(y, duration, true);
|
|
2438
|
+
this.emitColChange();
|
|
2439
|
+
}
|
|
2440
|
+
update(y, duration, saveY) {
|
|
2441
|
+
if (!this.optsEl) {
|
|
2442
|
+
return;
|
|
2443
|
+
}
|
|
2444
|
+
// ensure we've got a good round number :)
|
|
2445
|
+
let translateY = 0;
|
|
2446
|
+
let translateZ = 0;
|
|
2447
|
+
const { col, rotateFactor } = this;
|
|
2448
|
+
const prevSelected = col.selectedIndex;
|
|
2449
|
+
const selectedIndex = (col.selectedIndex = this.indexForY(-y));
|
|
2450
|
+
const durationStr = duration === 0 ? '' : duration + 'ms';
|
|
2451
|
+
const scaleStr = `scale(${this.scaleFactor})`;
|
|
2452
|
+
const children = this.optsEl.children;
|
|
2453
|
+
for (let i = 0; i < children.length; i++) {
|
|
2454
|
+
const button = children[i];
|
|
2455
|
+
const opt = col.options[i];
|
|
2456
|
+
const optOffset = i * this.optHeight + y;
|
|
2457
|
+
let transform = '';
|
|
2458
|
+
if (rotateFactor !== 0) {
|
|
2459
|
+
const rotateX = optOffset * rotateFactor;
|
|
2460
|
+
if (Math.abs(rotateX) <= 90) {
|
|
2461
|
+
translateY = 0;
|
|
2462
|
+
translateZ = 90;
|
|
2463
|
+
transform = `rotateX(${rotateX}deg) `;
|
|
2464
|
+
}
|
|
2465
|
+
else {
|
|
2466
|
+
translateY = -9999;
|
|
2467
|
+
}
|
|
2468
|
+
}
|
|
2469
|
+
else {
|
|
2470
|
+
translateZ = 0;
|
|
2471
|
+
translateY = optOffset;
|
|
2472
|
+
}
|
|
2473
|
+
const selected = selectedIndex === i;
|
|
2474
|
+
transform += `translate3d(0px,${translateY}px,${translateZ}px) `;
|
|
2475
|
+
if (this.scaleFactor !== 1 && !selected) {
|
|
2476
|
+
transform += scaleStr;
|
|
2477
|
+
}
|
|
2478
|
+
// Update transition duration
|
|
2479
|
+
if (this.noAnimate) {
|
|
2480
|
+
opt.duration = 0;
|
|
2481
|
+
button.style.transitionDuration = '';
|
|
2482
|
+
}
|
|
2483
|
+
else if (duration !== opt.duration) {
|
|
2484
|
+
opt.duration = duration;
|
|
2485
|
+
button.style.transitionDuration = durationStr;
|
|
2486
|
+
}
|
|
2487
|
+
// Update transform
|
|
2488
|
+
if (transform !== opt.transform) {
|
|
2489
|
+
opt.transform = transform;
|
|
2490
|
+
}
|
|
2491
|
+
button.style.transform = transform;
|
|
2492
|
+
/**
|
|
2493
|
+
* Ensure that the select column
|
|
2494
|
+
* item has the selected class
|
|
2495
|
+
*/
|
|
2496
|
+
opt.selected = selected;
|
|
2497
|
+
if (selected) {
|
|
2498
|
+
button.classList.add(PICKER_OPT_SELECTED);
|
|
2499
|
+
}
|
|
2500
|
+
else {
|
|
2501
|
+
button.classList.remove(PICKER_OPT_SELECTED);
|
|
2502
|
+
}
|
|
2503
|
+
}
|
|
2504
|
+
this.col.prevSelected = prevSelected;
|
|
2505
|
+
if (saveY) {
|
|
2506
|
+
this.y = y;
|
|
2507
|
+
}
|
|
2508
|
+
if (this.lastIndex !== selectedIndex) {
|
|
2509
|
+
// have not set a last index yet
|
|
2510
|
+
haptic.hapticSelectionChanged();
|
|
2511
|
+
this.lastIndex = selectedIndex;
|
|
2512
|
+
}
|
|
2513
|
+
}
|
|
2514
|
+
decelerate() {
|
|
2515
|
+
if (this.velocity !== 0) {
|
|
2516
|
+
// still decelerating
|
|
2517
|
+
this.velocity *= DECELERATION_FRICTION;
|
|
2518
|
+
// do not let it go slower than a velocity of 1
|
|
2519
|
+
this.velocity = this.velocity > 0 ? Math.max(this.velocity, 1) : Math.min(this.velocity, -1);
|
|
2520
|
+
let y = this.y + this.velocity;
|
|
2521
|
+
if (y > this.minY) {
|
|
2522
|
+
// whoops, it's trying to scroll up farther than the options we have!
|
|
2523
|
+
y = this.minY;
|
|
2524
|
+
this.velocity = 0;
|
|
2525
|
+
}
|
|
2526
|
+
else if (y < this.maxY) {
|
|
2527
|
+
// gahh, it's trying to scroll down farther than we can!
|
|
2528
|
+
y = this.maxY;
|
|
2529
|
+
this.velocity = 0;
|
|
2530
|
+
}
|
|
2531
|
+
this.update(y, 0, true);
|
|
2532
|
+
const notLockedIn = Math.round(y) % this.optHeight !== 0 || Math.abs(this.velocity) > 1;
|
|
2533
|
+
if (notLockedIn) {
|
|
2534
|
+
// isn't locked in yet, keep decelerating until it is
|
|
2535
|
+
this.rafId = requestAnimationFrame(() => this.decelerate());
|
|
2536
|
+
}
|
|
2537
|
+
else {
|
|
2538
|
+
this.velocity = 0;
|
|
2539
|
+
this.emitColChange();
|
|
2540
|
+
haptic.hapticSelectionEnd();
|
|
2541
|
+
}
|
|
2542
|
+
}
|
|
2543
|
+
else if (this.y % this.optHeight !== 0) {
|
|
2544
|
+
// needs to still get locked into a position so options line up
|
|
2545
|
+
const currentPos = Math.abs(this.y % this.optHeight);
|
|
2546
|
+
// create a velocity in the direction it needs to scroll
|
|
2547
|
+
this.velocity = currentPos > this.optHeight / 2 ? 1 : -1;
|
|
2548
|
+
this.decelerate();
|
|
2549
|
+
}
|
|
2550
|
+
}
|
|
2551
|
+
indexForY(y) {
|
|
2552
|
+
return Math.min(Math.max(Math.abs(Math.round(y / this.optHeight)), 0), this.col.options.length - 1);
|
|
2553
|
+
}
|
|
2554
|
+
onStart(detail) {
|
|
2555
|
+
// We have to prevent default in order to block scrolling under the picker
|
|
2556
|
+
// but we DO NOT have to stop propagation, since we still want
|
|
2557
|
+
// some "click" events to capture
|
|
2558
|
+
if (detail.event.cancelable) {
|
|
2559
|
+
detail.event.preventDefault();
|
|
2560
|
+
}
|
|
2561
|
+
detail.event.stopPropagation();
|
|
2562
|
+
haptic.hapticSelectionStart();
|
|
2563
|
+
// reset everything
|
|
2564
|
+
if (this.rafId !== undefined)
|
|
2565
|
+
cancelAnimationFrame(this.rafId);
|
|
2566
|
+
const options = this.col.options;
|
|
2567
|
+
let minY = options.length - 1;
|
|
2568
|
+
let maxY = 0;
|
|
2569
|
+
for (let i = 0; i < options.length; i++) {
|
|
2570
|
+
if (!options[i].disabled) {
|
|
2571
|
+
minY = Math.min(minY, i);
|
|
2572
|
+
maxY = Math.max(maxY, i);
|
|
2573
|
+
}
|
|
2574
|
+
}
|
|
2575
|
+
this.minY = -(minY * this.optHeight);
|
|
2576
|
+
this.maxY = -(maxY * this.optHeight);
|
|
2577
|
+
}
|
|
2578
|
+
onMove(detail) {
|
|
2579
|
+
if (detail.event.cancelable) {
|
|
2580
|
+
detail.event.preventDefault();
|
|
2581
|
+
}
|
|
2582
|
+
detail.event.stopPropagation();
|
|
2583
|
+
// update the scroll position relative to pointer start position
|
|
2584
|
+
let y = this.y + detail.deltaY;
|
|
2585
|
+
if (y > this.minY) {
|
|
2586
|
+
// scrolling up higher than scroll area
|
|
2587
|
+
y = Math.pow(y, 0.8);
|
|
2588
|
+
this.bounceFrom = y;
|
|
2589
|
+
}
|
|
2590
|
+
else if (y < this.maxY) {
|
|
2591
|
+
// scrolling down below scroll area
|
|
2592
|
+
y += Math.pow(this.maxY - y, 0.9);
|
|
2593
|
+
this.bounceFrom = y;
|
|
2594
|
+
}
|
|
2595
|
+
else {
|
|
2596
|
+
this.bounceFrom = 0;
|
|
2597
|
+
}
|
|
2598
|
+
this.update(y, 0, false);
|
|
2599
|
+
}
|
|
2600
|
+
onEnd(detail) {
|
|
2601
|
+
if (this.bounceFrom > 0) {
|
|
2602
|
+
// bounce back up
|
|
2603
|
+
this.update(this.minY, 100, true);
|
|
2604
|
+
this.emitColChange();
|
|
2605
|
+
return;
|
|
2606
|
+
}
|
|
2607
|
+
else if (this.bounceFrom < 0) {
|
|
2608
|
+
// bounce back down
|
|
2609
|
+
this.update(this.maxY, 100, true);
|
|
2610
|
+
this.emitColChange();
|
|
2611
|
+
return;
|
|
2612
|
+
}
|
|
2613
|
+
this.velocity = helpers.clamp(-90, detail.velocityY * 23, MAX_PICKER_SPEED);
|
|
2614
|
+
if (this.velocity === 0 && detail.deltaY === 0) {
|
|
2615
|
+
const opt = detail.event.target.closest('.picker-opt');
|
|
2616
|
+
if (opt === null || opt === void 0 ? void 0 : opt.hasAttribute('opt-index')) {
|
|
2617
|
+
this.setSelected(parseInt(opt.getAttribute('opt-index'), 10), TRANSITION_DURATION);
|
|
2618
|
+
}
|
|
2619
|
+
}
|
|
2620
|
+
else {
|
|
2621
|
+
this.y += detail.deltaY;
|
|
2622
|
+
if (Math.abs(detail.velocityY) < 0.05) {
|
|
2623
|
+
const isScrollingUp = detail.deltaY > 0;
|
|
2624
|
+
const optHeightFraction = (Math.abs(this.y) % this.optHeight) / this.optHeight;
|
|
2625
|
+
if (isScrollingUp && optHeightFraction > 0.5) {
|
|
2626
|
+
this.velocity = Math.abs(this.velocity) * -1;
|
|
2627
|
+
}
|
|
2628
|
+
else if (!isScrollingUp && optHeightFraction <= 0.5) {
|
|
2629
|
+
this.velocity = Math.abs(this.velocity);
|
|
2630
|
+
}
|
|
2631
|
+
}
|
|
2632
|
+
this.decelerate();
|
|
2633
|
+
}
|
|
2634
|
+
}
|
|
2635
|
+
refresh(forceRefresh, animated) {
|
|
2636
|
+
var _a;
|
|
2637
|
+
let min = this.col.options.length - 1;
|
|
2638
|
+
let max = 0;
|
|
2639
|
+
const options = this.col.options;
|
|
2640
|
+
for (let i = 0; i < options.length; i++) {
|
|
2641
|
+
if (!options[i].disabled) {
|
|
2642
|
+
min = Math.min(min, i);
|
|
2643
|
+
max = Math.max(max, i);
|
|
2644
|
+
}
|
|
2645
|
+
}
|
|
2646
|
+
/**
|
|
2647
|
+
* Only update selected value if column has a
|
|
2648
|
+
* velocity of 0. If it does not, then the
|
|
2649
|
+
* column is animating might land on
|
|
2650
|
+
* a value different than the value at
|
|
2651
|
+
* selectedIndex
|
|
2652
|
+
*/
|
|
2653
|
+
if (this.velocity !== 0) {
|
|
2654
|
+
return;
|
|
2655
|
+
}
|
|
2656
|
+
const selectedIndex = helpers.clamp(min, (_a = this.col.selectedIndex) !== null && _a !== void 0 ? _a : 0, max);
|
|
2657
|
+
if (this.col.prevSelected !== selectedIndex || forceRefresh) {
|
|
2658
|
+
const y = selectedIndex * this.optHeight * -1;
|
|
2659
|
+
const duration = animated ? TRANSITION_DURATION : 0;
|
|
2660
|
+
this.velocity = 0;
|
|
2661
|
+
this.update(y, duration, true);
|
|
2662
|
+
}
|
|
2663
|
+
}
|
|
2664
|
+
onDomChange(forceRefresh, animated) {
|
|
2665
|
+
const colEl = this.optsEl;
|
|
2666
|
+
if (colEl) {
|
|
2667
|
+
// DOM READ
|
|
2668
|
+
// We perfom a DOM read over a rendered item, this needs to happen after the first render or after the column has changed
|
|
2669
|
+
this.optHeight = colEl.firstElementChild ? colEl.firstElementChild.clientHeight : 0;
|
|
2670
|
+
}
|
|
2671
|
+
this.refresh(forceRefresh, animated);
|
|
2672
|
+
}
|
|
2673
|
+
render() {
|
|
2674
|
+
const col = this.col;
|
|
2675
|
+
const theme$1 = ionicGlobal.getIonTheme(this);
|
|
2676
|
+
return (index.h(index.Host, { key: '5751788e3b7ecd2fe269c096db883b0681646270', class: Object.assign({ [theme$1]: true, 'picker-col': true, 'picker-opts-left': this.col.align === 'left', 'picker-opts-right': this.col.align === 'right' }, theme.getClassMap(col.cssClass)), style: {
|
|
2677
|
+
'max-width': this.col.columnWidth,
|
|
2678
|
+
} }, col.prefix && (index.h("div", { key: '833f3309c8c77e1faa773f7eaa066516dfd51067', class: "picker-prefix", style: { width: col.prefixWidth } }, col.prefix)), index.h("div", { key: 'a39f38e60938e70425e4d7674f5e481885b6b548', class: "picker-opts", style: { maxWidth: col.optionsWidth }, ref: (el) => (this.optsEl = el) }, col.options.map((o, index$1) => (index.h("button", { "aria-label": o.ariaLabel, class: { 'picker-opt': true, 'picker-opt-disabled': !!o.disabled }, "opt-index": index$1 }, o.text)))), col.suffix && (index.h("div", { key: 'a2f1e0eab834c85e84cee0a716eb1083aa6c7741', class: "picker-suffix", style: { width: col.suffixWidth } }, col.suffix))));
|
|
2679
|
+
}
|
|
2680
|
+
get el() { return index.getElement(this); }
|
|
2681
|
+
static get watchers() { return {
|
|
2682
|
+
"col": [{
|
|
2683
|
+
"colChanged": 0
|
|
2684
|
+
}]
|
|
2685
|
+
}; }
|
|
2686
|
+
};
|
|
2687
|
+
const PICKER_OPT_SELECTED = 'picker-opt-selected';
|
|
2688
|
+
const DECELERATION_FRICTION = 0.97;
|
|
2689
|
+
const MAX_PICKER_SPEED = 90;
|
|
2690
|
+
const TRANSITION_DURATION = 150;
|
|
2691
|
+
PickerColumnCmp.style = {
|
|
2692
|
+
ios: pickerColumnIosCss(),
|
|
2693
|
+
md: pickerColumnMdCss()
|
|
2694
|
+
};
|
|
2695
|
+
|
|
1985
2696
|
exports.ion_datetime = Datetime;
|
|
2697
|
+
exports.ion_picker_legacy = Picker;
|
|
2698
|
+
exports.ion_picker_legacy_column = PickerColumnCmp;
|