@ionic/core 8.7.6-dev.11759524961.1cff6814 → 8.7.6-dev.11759752152.17f114d8
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/action-sheet.js +14 -10
- package/components/alert.js +15 -12
- package/components/animation.js +1 -1
- package/components/backdrop.js +10 -7
- package/components/button.js +42 -11
- package/components/buttons.js +12 -9
- package/components/capacitor.js +1 -1
- package/components/caret-down.js +6 -0
- package/components/caret-left.js +6 -0
- package/components/caret-right.js +6 -0
- package/components/checkbox.js +32 -13
- package/components/content.js +15 -13
- package/components/data.js +5 -5
- package/components/focus-visible.js +23 -1
- package/components/framework-delegate.js +3 -1
- package/components/header.js +29 -17
- package/components/helpers.js +42 -3
- package/components/icon.js +1 -1
- package/components/index2.js +3 -70
- package/components/index5.js +8 -8
- package/components/index6.js +1 -1
- package/components/index7.js +111 -150
- package/components/index8.js +150 -111
- package/components/input-shims.js +2 -2
- package/components/input.utils.js +1 -1
- package/components/ion-accordion-group.js +24 -6
- package/components/ion-accordion.js +33 -22
- package/components/ion-app.js +13 -78
- package/components/ion-avatar.js +58 -5
- package/components/ion-back-button.js +28 -20
- package/components/ion-badge.js +74 -10
- package/components/ion-breadcrumb.js +44 -11
- package/components/ion-breadcrumbs.js +9 -6
- package/components/ion-card-content.js +11 -8
- package/components/ion-card-header.js +10 -7
- package/components/ion-card-subtitle.js +9 -6
- package/components/ion-card-title.js +9 -6
- package/components/ion-card.js +22 -10
- package/components/ion-chip.js +54 -9
- package/components/ion-col.js +52 -51
- package/components/ion-datetime-button.js +9 -6
- package/components/ion-datetime.js +99 -22
- package/components/ion-divider.d.ts +11 -0
- package/components/ion-divider.js +70 -0
- package/components/ion-fab-button.js +32 -16
- package/components/ion-fab-list.js +6 -6
- package/components/ion-fab.js +7 -7
- package/components/ion-footer.js +19 -14
- package/components/ion-grid.js +6 -6
- package/components/ion-img.js +6 -3
- package/components/ion-infinite-scroll-content.js +12 -9
- package/components/ion-infinite-scroll.js +79 -7
- package/components/ion-input-otp.js +10 -7
- package/components/ion-input-password-toggle.js +52 -14
- package/components/ion-input.js +121 -29
- package/components/ion-item-divider.js +9 -6
- package/components/ion-item-group.js +9 -6
- package/components/ion-item-option.js +37 -10
- package/components/ion-item-options.js +11 -8
- package/components/ion-item-sliding.js +6 -6
- package/components/ion-loading.js +13 -10
- package/components/ion-menu-button.js +27 -11
- package/components/ion-menu-toggle.js +6 -6
- package/components/ion-menu.js +11 -9
- package/components/ion-nav-link.js +2 -2
- package/components/ion-nav.js +8 -6
- package/components/ion-note.js +9 -6
- package/components/ion-picker-legacy.js +8 -8
- package/components/ion-progress-bar.js +26 -8
- package/components/ion-range.js +13 -10
- package/components/ion-refresher-content.js +23 -8
- package/components/ion-refresher.js +11 -8
- package/components/ion-reorder-group.js +6 -6
- package/components/ion-reorder.js +31 -6
- package/components/ion-router-link.js +7 -7
- package/components/ion-router-outlet.js +5 -5
- package/components/ion-row.js +7 -4
- package/components/ion-searchbar.js +138 -24
- package/components/ion-segment-button.js +11 -8
- package/components/ion-segment-content.js +2 -2
- package/components/ion-segment-view.js +6 -3
- package/components/ion-segment.js +11 -8
- package/components/ion-select-option.js +6 -3
- package/components/ion-select.js +118 -34
- package/components/ion-skeleton-text.js +6 -6
- package/components/ion-split-pane.js +12 -9
- package/components/ion-tab-bar.js +40 -10
- package/components/ion-tab-button.js +26 -8
- package/components/ion-tab.js +3 -3
- package/components/ion-tabs.js +3 -3
- package/components/ion-text.js +6 -6
- package/components/ion-textarea.js +53 -12
- package/components/ion-thumbnail.js +6 -3
- package/components/ion-toast.js +38 -13
- package/components/ion-toggle.js +75 -18
- package/components/ionic-global.js +349 -15
- package/components/ios.transition.js +1 -0
- package/components/item.js +40 -15
- package/components/keyboard-controller.js +4 -2
- package/components/label.js +9 -6
- package/components/list-header.js +11 -8
- package/components/list.js +28 -7
- package/components/list2.js +6 -0
- package/components/modal.js +49 -21
- package/components/notch-controller.js +1 -1
- package/components/overlays.js +3 -4
- package/components/picker-column-option.js +9 -6
- package/components/picker-column.js +8 -9
- package/components/picker-column2.js +5 -5
- package/components/picker.js +8 -5
- package/components/popover.js +13 -10
- package/components/radio-group.js +11 -6
- package/components/radio.js +12 -9
- package/components/ripple-effect.js +15 -7
- package/components/select-modal.js +6 -6
- package/components/select-popover.js +10 -4
- package/components/spinner.js +31 -8
- package/components/status-tap.js +1 -1
- package/components/title.js +11 -8
- package/components/toolbar.js +154 -10
- package/components/x.js +6 -0
- package/css/core.css +1 -1
- package/css/core.css.map +1 -1
- package/css/display.css +1 -1
- package/css/display.css.map +1 -1
- package/css/flex-utils.css +1 -1
- package/css/flex-utils.css.map +1 -1
- package/css/float-elements.css.map +1 -1
- package/css/global.bundle.css.map +1 -1
- package/css/ionic/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-ZJ1lAkZD.js → animation-Bcz4qmJk.js} +2 -3
- package/dist/cjs/{button-active-BzZenWWH.js → button-active-1nO6qpCH.js} +2 -2
- package/dist/cjs/{capacitor-DmA66EwP.js → capacitor-CzFst28-.js} +1 -1
- 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-CKhELRRu.js → config-DGKt4XfG.js} +1 -1
- package/dist/cjs/{data-DW6ofvJ8.js → data-B3i-krcw.js} +6 -6
- package/dist/cjs/{focus-visible-CCvKiLh3.js → focus-visible-BIj-I3-C.js} +24 -0
- package/dist/cjs/{framework-delegate-WkyjrnCx.js → framework-delegate-DfEY5uyC.js} +4 -2
- package/dist/cjs/{haptic-ClPPQ_PS.js → haptic-DbqPcCc9.js} +1 -1
- package/dist/cjs/{helpers-DgwmcYAu.js → helpers-DmAvmm2T.js} +42 -3
- package/dist/cjs/{index-Cc5PNMyz.js → index-CaZ3uzAD.js} +2 -2
- package/dist/cjs/{index-DNh170BW.js → index-CmckMMX1.js} +659 -274
- package/dist/cjs/{index-D24wggHR.js → index-DcPe_YcG.js} +16 -17
- package/dist/cjs/{index--3s2Phef.js → index-DxVhwe3d.js} +7 -74
- package/dist/cjs/{index-bGpoPC4u.js → index-YEjC0pvJ.js} +3 -3
- package/dist/cjs/index.cjs.js +15 -17
- package/dist/cjs/{input-shims-CLI_OrmU.js → input-shims-BwdlNkON.js} +6 -6
- package/dist/cjs/{input.utils-B2hZ5tX6.js → input.utils-CfjyQhpu.js} +3 -4
- package/dist/cjs/ion-accordion_2.cjs.entry.js +55 -27
- package/dist/cjs/ion-action-sheet.cjs.entry.js +21 -19
- package/dist/cjs/ion-alert.cjs.entry.js +24 -23
- package/dist/cjs/ion-app_8.cjs.entry.js +245 -147
- package/dist/cjs/ion-avatar_3.cjs.entry.js +123 -12
- package/dist/cjs/ion-back-button.cjs.entry.js +28 -20
- package/dist/cjs/ion-backdrop.cjs.entry.js +9 -7
- package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +51 -16
- package/dist/cjs/ion-button_2.cjs.entry.js +44 -13
- package/dist/cjs/ion-card_5.cjs.entry.js +53 -30
- package/dist/cjs/ion-checkbox.cjs.entry.js +31 -14
- package/dist/cjs/ion-chip.cjs.entry.js +48 -8
- package/dist/cjs/ion-col_3.cjs.entry.js +53 -57
- package/dist/cjs/ion-datetime-button.cjs.entry.js +11 -8
- package/dist/cjs/ion-datetime_3.cjs.entry.js +115 -41
- package/dist/cjs/ion-divider.cjs.entry.js +50 -0
- package/dist/cjs/ion-fab_3.cjs.entry.js +41 -26
- package/dist/cjs/ion-img.cjs.entry.js +7 -4
- package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +90 -16
- package/dist/cjs/ion-input-otp.cjs.entry.js +12 -9
- package/dist/cjs/ion-input-password-toggle.cjs.entry.js +51 -14
- package/dist/cjs/ion-input.cjs.entry.js +120 -31
- package/dist/cjs/ion-item-option_3.cjs.entry.js +48 -20
- package/dist/cjs/ion-item_8.cjs.entry.js +105 -46
- package/dist/cjs/ion-loading.cjs.entry.js +18 -17
- package/dist/cjs/ion-menu_3.cjs.entry.js +47 -30
- package/dist/cjs/ion-modal.cjs.entry.js +83 -57
- package/dist/cjs/ion-nav_2.cjs.entry.js +14 -12
- package/dist/cjs/ion-picker-column-option.cjs.entry.js +10 -7
- package/dist/cjs/ion-picker-column.cjs.entry.js +14 -15
- package/dist/cjs/ion-picker.cjs.entry.js +10 -6
- package/dist/cjs/ion-popover.cjs.entry.js +19 -18
- package/dist/cjs/ion-progress-bar.cjs.entry.js +25 -8
- package/dist/cjs/ion-radio_2.cjs.entry.js +22 -14
- package/dist/cjs/ion-range.cjs.entry.js +14 -11
- package/dist/cjs/ion-refresher_2.cjs.entry.js +41 -24
- package/dist/cjs/ion-reorder_2.cjs.entry.js +36 -13
- package/dist/cjs/ion-ripple-effect.cjs.entry.js +14 -7
- package/dist/cjs/ion-route_4.cjs.entry.js +8 -8
- package/dist/cjs/ion-searchbar.cjs.entry.js +134 -22
- package/dist/cjs/ion-segment-content.cjs.entry.js +2 -2
- package/dist/cjs/ion-segment-view.cjs.entry.js +6 -3
- package/dist/cjs/ion-segment_2.cjs.entry.js +21 -15
- package/dist/cjs/ion-select-modal.cjs.entry.js +9 -11
- package/dist/cjs/ion-select_3.cjs.entry.js +130 -40
- package/dist/cjs/ion-spinner.cjs.entry.js +29 -8
- package/dist/cjs/ion-split-pane.cjs.entry.js +11 -9
- package/dist/cjs/ion-tab-bar_2.cjs.entry.js +65 -21
- package/dist/cjs/ion-tab_2.cjs.entry.js +8 -7
- package/dist/cjs/ion-text.cjs.entry.js +5 -6
- package/dist/cjs/ion-textarea.cjs.entry.js +55 -16
- package/dist/cjs/ion-toast.cjs.entry.js +65 -43
- package/dist/cjs/ion-toggle.cjs.entry.js +79 -23
- package/dist/cjs/ionic.cjs.js +4 -6
- package/dist/cjs/{ios.transition-B_rsAM9j.js → ios.transition-BMRClUxZ.js} +6 -5
- package/dist/cjs/{keyboard-UuAS4D_9.js → keyboard-Chl5cusY.js} +1 -1
- package/dist/cjs/{keyboard-controller-GXBiBRKS.js → keyboard-controller-yLvXRMuh.js} +4 -3
- package/dist/cjs/{keyboard-hHzlEQpk.js → keyboard-nXDIskl9.js} +3 -3
- package/dist/cjs/list-a-7GSA6K.js +8 -0
- package/dist/cjs/loader.cjs.js +3 -5
- package/dist/cjs/{md.transition-CQt0eBw-.js → md.transition-D2ZL4jgW.js} +5 -5
- package/dist/cjs/{notch-controller-Bf5Rr4R5.js → notch-controller-S50JyZJs.js} +2 -2
- package/dist/cjs/{overlays-czPyT6xP.js → overlays-XYRfwd6H.js} +10 -12
- package/dist/cjs/{status-tap-D9YPr62n.js → status-tap-DMaRrHIS.js} +4 -3
- package/dist/cjs/{swipe-back-C1wRtoww.js → swipe-back-CEVlQT7C.js} +3 -2
- package/dist/cjs/x-BTF99yFH.js +8 -0
- package/dist/collection/collection-manifest.json +2 -1
- package/dist/collection/components/accordion/accordion.ionic.css +196 -0
- package/dist/collection/components/accordion/accordion.ios.css +73 -58
- package/dist/collection/components/accordion/accordion.js +36 -26
- 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.ios.css +18 -6
- package/dist/collection/components/action-sheet/action-sheet.js +15 -11
- package/dist/collection/components/action-sheet/action-sheet.md.css +17 -5
- package/dist/collection/components/alert/alert.ios.css +19 -1
- package/dist/collection/components/alert/alert.js +16 -13
- package/dist/collection/components/alert/alert.md.css +19 -1
- package/dist/collection/components/app/app.js +15 -78
- 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 +620 -0
- package/dist/collection/components/button/button.ios.css +135 -46
- package/dist/collection/components/button/button.js +48 -17
- package/dist/collection/components/button/button.md.css +126 -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 +92 -0
- package/dist/collection/components/card-content/card-content.ios.css +16 -1
- package/dist/collection/components/card-content/card-content.js +11 -8
- package/dist/collection/components/card-content/card-content.md.css +16 -1
- 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 +228 -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 +210 -61
- package/dist/collection/components/content/content.css +8 -2
- package/dist/collection/components/content/content.js +16 -11
- package/dist/collection/components/datetime/datetime.ionic.css +697 -0
- package/dist/collection/components/datetime/datetime.ios.css +242 -86
- package/dist/collection/components/datetime/datetime.js +98 -20
- package/dist/collection/components/datetime/datetime.md.css +242 -86
- package/dist/collection/components/datetime/utils/data.js +5 -5
- package/dist/collection/components/datetime-button/datetime-button.ios.css +6 -0
- package/dist/collection/components/datetime-button/datetime-button.js +11 -8
- package/dist/collection/components/datetime-button/datetime-button.md.css +6 -0
- package/dist/collection/components/divider/divider.ionic.css +148 -0
- package/dist/collection/components/divider/divider.ios.css +87 -0
- package/dist/collection/components/divider/divider.js +94 -0
- package/dist/collection/components/divider/divider.md.css +87 -0
- package/dist/collection/components/fab/fab.css +25 -1
- package/dist/collection/components/fab/fab.js +9 -5
- package/dist/collection/components/fab-button/fab-button.ios.css +18 -6
- package/dist/collection/components/fab-button/fab-button.js +36 -21
- package/dist/collection/components/fab-button/fab-button.md.css +20 -8
- package/dist/collection/components/fab-list/fab-list.css +12 -0
- package/dist/collection/components/fab-list/fab-list.js +9 -5
- package/dist/collection/components/footer/footer.ios.css +14 -2
- package/dist/collection/components/footer/footer.js +21 -16
- package/dist/collection/components/footer/footer.md.css +12 -0
- package/dist/collection/components/grid/grid.css +12 -0
- package/dist/collection/components/grid/grid.js +9 -5
- package/dist/collection/components/header/header.ionic.css +98 -0
- package/dist/collection/components/header/header.ios.css +26 -37
- package/dist/collection/components/header/header.js +49 -18
- package/dist/collection/components/header/header.md.css +23 -8
- 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 +881 -0
- package/dist/collection/components/input/input.ios.css +223 -140
- package/dist/collection/components/input/input.js +149 -38
- package/dist/collection/components/input/input.md.css +193 -212
- package/dist/collection/components/input-otp/input-otp.ionic.css +369 -0
- package/dist/collection/components/input-otp/input-otp.ios.css +106 -60
- package/dist/collection/components/input-otp/input-otp.js +7 -5
- package/dist/collection/components/input-otp/input-otp.md.css +106 -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 +499 -0
- package/dist/collection/components/item/item.ios.css +109 -69
- package/dist/collection/components/item/item.js +43 -19
- 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.css +6 -0
- package/dist/collection/components/item-sliding/item-sliding.js +8 -4
- package/dist/collection/components/label/label.ios.css +18 -0
- package/dist/collection/components/label/label.js +11 -8
- package/dist/collection/components/label/label.md.css +18 -0
- package/dist/collection/components/list/list.ionic.css +212 -0
- package/dist/collection/components/list/list.ios.css +54 -14
- package/dist/collection/components/list/list.js +48 -9
- package/dist/collection/components/list/list.md.css +56 -16
- package/dist/collection/components/list-header/list-header.ionic.css +190 -0
- package/dist/collection/components/list-header/list-header.ios.css +82 -38
- package/dist/collection/components/list-header/list-header.js +11 -8
- package/dist/collection/components/list-header/list-header.md.css +82 -38
- package/dist/collection/components/loading/loading.ios.css +13 -1
- package/dist/collection/components/loading/loading.js +14 -11
- package/dist/collection/components/loading/loading.md.css +13 -1
- package/dist/collection/components/menu/menu.ios.css +15 -3
- package/dist/collection/components/menu/menu.js +12 -7
- package/dist/collection/components/menu/menu.md.css +15 -3
- package/dist/collection/components/menu-button/menu-button.ionic.css +236 -0
- package/dist/collection/components/menu-button/menu-button.ios.css +48 -14
- package/dist/collection/components/menu-button/menu-button.js +26 -10
- package/dist/collection/components/menu-button/menu-button.md.css +49 -15
- package/dist/collection/components/menu-toggle/menu-toggle.js +8 -5
- package/dist/collection/components/modal/animations/sheet.js +8 -2
- package/dist/collection/components/modal/gestures/sheet.js +10 -6
- package/dist/collection/components/modal/modal.ionic.css +241 -0
- package/dist/collection/components/modal/modal.ios.css +174 -70
- package/dist/collection/components/modal/modal.js +48 -11
- package/dist/collection/components/modal/modal.md.css +174 -70
- package/dist/collection/components/nav/nav.css +7 -1
- package/dist/collection/components/nav/nav.js +11 -5
- package/dist/collection/components/nav-link/nav-link.js +5 -1
- package/dist/collection/components/note/note.ios.css +12 -0
- package/dist/collection/components/note/note.js +11 -8
- package/dist/collection/components/note/note.md.css +12 -0
- package/dist/collection/components/picker/picker.ios.css +15 -3
- package/dist/collection/components/picker/picker.js +8 -5
- package/dist/collection/components/picker/picker.md.css +15 -3
- package/dist/collection/components/picker-column/picker-column.css +9 -2
- package/dist/collection/components/picker-column/picker-column.js +8 -7
- package/dist/collection/components/picker-column-option/picker-column-option.ios.css +6 -0
- package/dist/collection/components/picker-column-option/picker-column-option.js +13 -7
- package/dist/collection/components/picker-column-option/picker-column-option.md.css +6 -0
- package/dist/collection/components/picker-legacy/picker.ios.css +13 -1
- package/dist/collection/components/picker-legacy/picker.js +7 -6
- package/dist/collection/components/picker-legacy/picker.md.css +13 -1
- package/dist/collection/components/picker-legacy-column/picker-column.ios.css +12 -0
- package/dist/collection/components/picker-legacy-column/picker-column.js +4 -4
- package/dist/collection/components/picker-legacy-column/picker-column.md.css +12 -0
- package/dist/collection/components/popover/popover.ios.css +13 -1
- package/dist/collection/components/popover/popover.js +17 -14
- package/dist/collection/components/popover/popover.md.css +13 -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 +12 -9
- package/dist/collection/components/radio/radio.md.css +134 -91
- package/dist/collection/components/radio-group/radio-group.ionic.css +125 -0
- package/dist/collection/components/radio-group/radio-group.ios.css +42 -18
- package/dist/collection/components/radio-group/radio-group.js +13 -5
- package/dist/collection/components/radio-group/radio-group.md.css +42 -18
- package/dist/collection/components/range/range.ionic.css +563 -0
- package/dist/collection/components/range/range.ios.css +128 -85
- package/dist/collection/components/range/range.js +12 -9
- package/dist/collection/components/range/range.md.css +128 -85
- package/dist/collection/components/refresher/refresher.ios.css +14 -1
- package/dist/collection/components/refresher/refresher.js +11 -8
- package/dist/collection/components/refresher/refresher.md.css +15 -2
- package/dist/collection/components/refresher-content/refresher-content.js +28 -7
- package/dist/collection/components/reorder/reorder.ios.css +6 -0
- package/dist/collection/components/reorder/reorder.js +33 -6
- package/dist/collection/components/reorder/reorder.md.css +6 -0
- package/dist/collection/components/reorder-group/reorder-group.css +6 -0
- package/dist/collection/components/reorder-group/reorder-group.js +8 -4
- package/dist/collection/components/ripple-effect/{ripple-effect.css → ripple-effect.common.css} +7 -1
- package/dist/collection/components/ripple-effect/ripple-effect.ionic.css +215 -0
- package/dist/collection/components/ripple-effect/ripple-effect.js +14 -6
- package/dist/collection/components/route/route.js +4 -0
- package/dist/collection/components/router/router.js +4 -0
- package/dist/collection/components/router-link/router-link.css +8 -2
- package/dist/collection/components/router-link/router-link.js +9 -5
- package/dist/collection/components/router-outlet/router-outlet.css +7 -1
- package/dist/collection/components/router-outlet/router-outlet.js +6 -3
- package/dist/collection/components/row/row.css +16 -0
- package/dist/collection/components/row/row.js +9 -2
- package/dist/collection/components/searchbar/searchbar.ionic.css +626 -0
- package/dist/collection/components/searchbar/searchbar.ios.css +56 -18
- package/dist/collection/components/searchbar/searchbar.js +181 -34
- 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 +6 -4
- package/dist/collection/components/segment-view/segment-view.md.css +6 -0
- package/dist/collection/components/select/select.ionic.css +763 -0
- package/dist/collection/components/select/select.ios.css +315 -176
- package/dist/collection/components/select/select.js +157 -54
- package/dist/collection/components/select/select.md.css +331 -178
- package/dist/collection/components/select-modal/select-modal.ionic.css +123 -0
- package/dist/collection/components/select-modal/select-modal.ios.css +18 -0
- package/dist/collection/components/select-modal/select-modal.js +3 -3
- package/dist/collection/components/select-modal/select-modal.md.css +7 -3
- package/dist/collection/components/select-option/select-option.js +9 -2
- package/dist/collection/components/select-popover/select-popover.ios.css +18 -0
- package/dist/collection/components/select-popover/select-popover.js +12 -4
- package/dist/collection/components/select-popover/select-popover.md.css +18 -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} +77 -10
- package/dist/collection/components/spinner/spinner.js +47 -6
- package/dist/collection/components/spinner/spinner.native.css +198 -0
- package/dist/collection/components/split-pane/split-pane.ios.css +20 -2
- package/dist/collection/components/split-pane/split-pane.js +14 -8
- package/dist/collection/components/split-pane/split-pane.md.css +20 -2
- package/dist/collection/components/tab/tab.js +6 -2
- package/dist/collection/components/tab-bar/tab-bar.ionic.css +186 -0
- package/dist/collection/components/tab-bar/tab-bar.ios.css +71 -43
- package/dist/collection/components/tab-bar/tab-bar.js +78 -11
- package/dist/collection/components/tab-bar/tab-bar.md.css +71 -43
- package/dist/collection/components/tab-button/tab-button.ionic.css +336 -0
- package/dist/collection/components/tab-button/tab-button.ios.css +171 -95
- package/dist/collection/components/tab-button/tab-button.js +44 -8
- 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 +881 -0
- package/dist/collection/components/textarea/textarea.ios.css +275 -139
- package/dist/collection/components/textarea/textarea.js +76 -16
- package/dist/collection/components/textarea/textarea.md.css +288 -140
- 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 +75 -12
- package/dist/collection/components/toast/toast.md.css +84 -45
- package/dist/collection/components/toggle/toggle.ionic.css +509 -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 +241 -0
- package/dist/collection/components/toolbar/toolbar.ios.css +90 -47
- package/dist/collection/components/toolbar/toolbar.js +157 -13
- package/dist/collection/components/toolbar/toolbar.md.css +90 -47
- package/dist/collection/global/ionic-global.js +228 -13
- package/dist/collection/utils/focus-visible.js +22 -0
- package/dist/collection/utils/framework-delegate.js +3 -1
- package/dist/collection/utils/helpers.js +42 -2
- package/dist/collection/utils/keyboard/keyboard-controller.js +3 -1
- 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/overlays.js +2 -1
- 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 +24 -3
- package/dist/collection/utils/transition/index.js +3 -70
- package/dist/collection/utils/transition/ios.transition.js +1 -0
- package/dist/docs.json +8169 -373
- package/dist/esm/{animation-BvhAtgca.js → animation-Cgfm6Out.js} +1 -2
- package/dist/esm/{button-active-DBUPuLNw.js → button-active-DvzVF2u_.js} +2 -2
- package/dist/esm/{capacitor-CFERIeaU.js → capacitor-Dvc8Ydvg.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-Dx_6wPIJ.js → config-DwiPHIF5.js} +1 -1
- package/dist/esm/{data-CKHMWxfe.js → data-HHZs0eLV.js} +6 -6
- package/dist/esm/{focus-visible-BmVRXR1y.js → focus-visible-vXpMhGrs.js} +23 -1
- package/dist/esm/{framework-delegate-BLEBgH06.js → framework-delegate-B4Rily6A.js} +4 -2
- package/dist/esm/{haptic-DzAMWJuk.js → haptic-ZZTn7IWt.js} +1 -1
- package/dist/esm/{helpers-8KSQQGQy.js → helpers-D_90HVv6.js} +42 -3
- package/dist/esm/{index-4DxY6_gG.js → index-BBrR3goV.js} +649 -270
- package/dist/esm/{index-BQc4arca.js → index-BoSPzYKk.js} +7 -74
- package/dist/esm/{index-7UbSlv7N.js → index-ByqmqxGO.js} +2 -2
- package/dist/esm/{index-DV3sJJW8.js → index-COG0_eom.js} +1 -1
- package/dist/esm/{index-CXSTcaAW.js → index-D4D_NUAr.js} +10 -11
- package/dist/esm/{index-C6WeRr09.js → index-k4x4i7EL.js} +3 -3
- package/dist/esm/index.js +11 -13
- package/dist/esm/{input-shims-C4KDnhxb.js → input-shims-DEtEJcaS.js} +6 -6
- package/dist/esm/{input.utils-be4gBvVY.js → input.utils-DNE0LB5g.js} +2 -3
- package/dist/esm/ion-accordion_2.entry.js +56 -28
- package/dist/esm/ion-action-sheet.entry.js +21 -19
- package/dist/esm/ion-alert.entry.js +23 -22
- package/dist/esm/ion-app_8.entry.js +243 -145
- package/dist/esm/ion-avatar_3.entry.js +124 -13
- package/dist/esm/ion-back-button.entry.js +29 -21
- package/dist/esm/ion-backdrop.entry.js +9 -7
- package/dist/esm/ion-breadcrumb_2.entry.js +52 -17
- package/dist/esm/ion-button_2.entry.js +43 -12
- package/dist/esm/ion-card_5.entry.js +53 -30
- package/dist/esm/ion-checkbox.entry.js +31 -14
- package/dist/esm/ion-chip.entry.js +48 -8
- package/dist/esm/ion-col_3.entry.js +53 -57
- package/dist/esm/ion-datetime-button.entry.js +11 -8
- package/dist/esm/ion-datetime_3.entry.js +114 -40
- package/dist/esm/ion-divider.entry.js +48 -0
- package/dist/esm/ion-fab_3.entry.js +42 -27
- package/dist/esm/ion-img.entry.js +7 -4
- package/dist/esm/ion-infinite-scroll_2.entry.js +90 -16
- package/dist/esm/ion-input-otp.entry.js +11 -8
- package/dist/esm/ion-input-password-toggle.entry.js +51 -14
- package/dist/esm/ion-input.entry.js +121 -32
- package/dist/esm/ion-item-option_3.entry.js +48 -20
- package/dist/esm/ion-item_8.entry.js +106 -47
- package/dist/esm/ion-loading.entry.js +18 -17
- package/dist/esm/ion-menu_3.entry.js +45 -28
- package/dist/esm/ion-modal.entry.js +56 -30
- package/dist/esm/ion-nav_2.entry.js +13 -11
- package/dist/esm/ion-picker-column-option.entry.js +10 -7
- package/dist/esm/ion-picker-column.entry.js +11 -12
- package/dist/esm/ion-picker.entry.js +10 -6
- package/dist/esm/ion-popover.entry.js +18 -17
- package/dist/esm/ion-progress-bar.entry.js +25 -8
- package/dist/esm/ion-radio_2.entry.js +22 -14
- package/dist/esm/ion-range.entry.js +14 -11
- package/dist/esm/ion-refresher_2.entry.js +38 -21
- package/dist/esm/ion-reorder_2.entry.js +37 -14
- package/dist/esm/ion-ripple-effect.entry.js +14 -7
- package/dist/esm/ion-route_4.entry.js +8 -8
- package/dist/esm/ion-searchbar.entry.js +136 -24
- package/dist/esm/ion-segment-content.entry.js +2 -2
- package/dist/esm/ion-segment-view.entry.js +6 -3
- package/dist/esm/ion-segment_2.entry.js +21 -15
- package/dist/esm/ion-select-modal.entry.js +9 -11
- package/dist/esm/ion-select_3.entry.js +131 -41
- package/dist/esm/ion-spinner.entry.js +28 -7
- package/dist/esm/ion-split-pane.entry.js +11 -9
- package/dist/esm/ion-tab-bar_2.entry.js +65 -21
- package/dist/esm/ion-tab_2.entry.js +8 -7
- package/dist/esm/ion-text.entry.js +5 -6
- package/dist/esm/ion-textarea.entry.js +55 -16
- package/dist/esm/ion-toast.entry.js +41 -19
- package/dist/esm/ion-toggle.entry.js +79 -23
- package/dist/esm/ionic.js +4 -6
- package/dist/esm/{ios.transition-eOa-6o5F.js → ios.transition-C_-UP8wE.js} +6 -5
- package/dist/esm/{keyboard-ywgs5efA.js → keyboard-BsZp3qPH.js} +3 -3
- package/dist/esm/{keyboard-CUw4ekVy.js → keyboard-Cvigb3Rv.js} +1 -1
- package/dist/esm/{keyboard-controller-BaaVITYt.js → keyboard-controller-lts2Pswq.js} +4 -3
- package/dist/esm/list-Dhi5xtNS.js +6 -0
- package/dist/esm/loader.js +3 -5
- package/dist/esm/{md.transition-B99keElo.js → md.transition-BDWkLsNw.js} +5 -5
- package/dist/esm/{notch-controller-lb417-kU.js → notch-controller-ClKrf2l9.js} +2 -2
- package/dist/esm/{overlays-BYcYBCrx.js → overlays-C1ahtepl.js} +5 -7
- package/dist/esm/{status-tap-pATNXEtr.js → status-tap-DLatL9pG.js} +4 -3
- package/dist/esm/{swipe-back-B2YfOHRM.js → swipe-back-YYylMb0l.js} +3 -2
- package/dist/esm/x-BDqjX7Z_.js +6 -0
- package/dist/html.html-data.json +2532 -226
- package/dist/ionic/index.esm.js +1 -1
- package/dist/ionic/ionic.esm.js +1 -1
- package/dist/ionic/p-034ef39b.entry.js +4 -0
- package/dist/ionic/p-05030d1b.entry.js +4 -0
- package/dist/ionic/p-059ceab8.entry.js +4 -0
- package/dist/ionic/p-096b5789.entry.js +4 -0
- package/dist/ionic/p-09eaefc0.entry.js +4 -0
- package/dist/ionic/p-156bba30.entry.js +4 -0
- package/dist/ionic/p-238ad727.entry.js +4 -0
- package/dist/ionic/p-24803c39.entry.js +4 -0
- package/dist/ionic/p-2c28e54a.entry.js +4 -0
- package/dist/ionic/p-2c9459f5.entry.js +4 -0
- package/dist/ionic/p-2f1d100c.entry.js +4 -0
- package/dist/ionic/p-31331fc3.entry.js +4 -0
- package/dist/ionic/p-340e4f62.entry.js +4 -0
- package/dist/ionic/p-3bef3778.entry.js +4 -0
- package/dist/ionic/p-3c773ecd.entry.js +4 -0
- package/dist/ionic/p-47432157.entry.js +4 -0
- package/dist/ionic/p-52535bba.entry.js +4 -0
- package/dist/ionic/p-56e51161.entry.js +4 -0
- package/dist/ionic/p-5770869f.entry.js +4 -0
- package/dist/ionic/p-5af619ff.entry.js +4 -0
- package/dist/ionic/p-5b44ac3a.entry.js +4 -0
- package/dist/ionic/p-5ca4c3b8.entry.js +4 -0
- package/dist/ionic/p-649e2f92.entry.js +4 -0
- package/dist/ionic/p-6d38d3f3.entry.js +4 -0
- package/dist/ionic/p-6e6ce506.entry.js +4 -0
- package/dist/ionic/p-6ea34add.entry.js +4 -0
- package/dist/ionic/p-6f17f8ed.entry.js +4 -0
- package/dist/ionic/p-773f2ac5.entry.js +4 -0
- package/dist/ionic/p-80cc8511.entry.js +4 -0
- package/dist/ionic/p-82796bb0.entry.js +4 -0
- package/dist/ionic/p-8c3d3bca.entry.js +4 -0
- package/dist/ionic/p-9000bd9f.entry.js +4 -0
- package/dist/ionic/p-9cbab197.entry.js +4 -0
- package/dist/ionic/p-BDqjX7Z_.js +4 -0
- package/dist/ionic/p-BJ-EYogw.js +4 -0
- package/dist/ionic/p-BKDxK6_S.js +4 -0
- package/dist/ionic/p-BMPzyWDm.js +4 -0
- package/dist/ionic/p-BTqHM5hg.js +4 -0
- package/dist/ionic/p-BYSs-jZz.js +4 -0
- package/dist/ionic/p-BZR5I9yn.js +4 -0
- package/dist/ionic/p-BZSKvxFv.js +4 -0
- package/dist/ionic/p-BaAcx1TO.js +4 -0
- package/dist/ionic/p-BeJdFlAB.js +4 -0
- package/dist/ionic/{p-D13Eaw-8.js → p-Bi_aZreq.js} +1 -1
- package/dist/ionic/p-BpUl-Ubc.js +4 -0
- package/dist/ionic/{p-CKvCXMs9.js → p-BuAY53fC.js} +1 -1
- package/dist/ionic/{p-DV3sJJW8.js → p-COG0_eom.js} +1 -1
- package/dist/ionic/p-CnPZjTVf.js +4 -0
- package/dist/ionic/{p-DiZPU8BH.js → p-D-g7JYuH.js} +1 -1
- package/dist/ionic/p-D1t981Ih.js +4 -0
- package/dist/ionic/p-D6quDhlh.js +4 -0
- package/dist/ionic/{p-CWvl4RPO.js → p-DIZM2shZ.js} +1 -1
- package/dist/ionic/p-DJD59Sq4.js +4 -0
- package/dist/ionic/p-DZmL55Qn.js +4 -0
- package/dist/ionic/p-Dhi5xtNS.js +4 -0
- package/dist/ionic/p-DjxV6ul_.js +4 -0
- package/dist/ionic/p-DkXsr7m2.js +4 -0
- package/dist/ionic/p-DnNglnwY.js +4 -0
- package/dist/ionic/p-Dpa-63kX.js +4 -0
- package/dist/ionic/p-HOJ_eq4V.js +5 -0
- package/dist/ionic/p-MBiM0IFp.js +4 -0
- package/dist/ionic/p-a1af546a.entry.js +4 -0
- package/dist/ionic/p-a2218a8b.entry.js +4 -0
- package/dist/ionic/p-a22b46e4.entry.js +4 -0
- package/dist/ionic/p-ae10fb4c.entry.js +4 -0
- package/dist/ionic/p-c2122301.entry.js +4 -0
- package/dist/ionic/p-c428cbac.entry.js +4 -0
- package/dist/ionic/p-c565e353.entry.js +4 -0
- package/dist/ionic/p-c6301ef9.entry.js +4 -0
- package/dist/ionic/p-c83a1254.entry.js +4 -0
- package/dist/ionic/p-c9313bb8.entry.js +4 -0
- package/dist/ionic/p-cb6bb34f.entry.js +4 -0
- package/dist/ionic/p-d215bbdc.entry.js +4 -0
- package/dist/ionic/p-de6964a2.entry.js +4 -0
- package/dist/ionic/p-ded5613d.entry.js +4 -0
- package/dist/ionic/p-e0eae83d.entry.js +4 -0
- package/dist/ionic/p-e5005342.entry.js +4 -0
- package/dist/ionic/p-e7925263.entry.js +4 -0
- package/dist/ionic/p-eZzo_1L1.js +4 -0
- package/dist/ionic/p-eebf0420.entry.js +4 -0
- package/dist/ionic/p-f1bb4947.entry.js +4 -0
- package/dist/ionic/p-fIOYmaqA.js +4 -0
- package/dist/ionic/p-facf3c23.entry.js +4 -0
- package/dist/ionic/p-vXpMhGrs.js +4 -0
- package/dist/node_modules/ionicons/dist/collection/components/icon/icon.css +143 -0
- package/dist/types/components/accordion/accordion.d.ts +5 -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 -2
- 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 +19 -6
- package/dist/types/components/buttons/buttons.d.ts +5 -1
- package/dist/types/components/card/card.d.ts +8 -1
- package/dist/types/components/card-content/card-content.d.ts +2 -1
- package/dist/types/components/card-header/card-header.d.ts +3 -2
- package/dist/types/components/card-subtitle/card-subtitle.d.ts +2 -1
- package/dist/types/components/card-title/card-title.d.ts +2 -1
- package/dist/types/components/checkbox/checkbox.d.ts +14 -4
- package/dist/types/components/chip/chip.d.ts +26 -1
- package/dist/types/components/col/col.d.ts +52 -5
- package/dist/types/components/content/content.d.ts +3 -0
- package/dist/types/components/datetime/datetime.d.ts +26 -1
- package/dist/types/components/datetime/utils/data.d.ts +5 -5
- package/dist/types/components/datetime-button/datetime-button.d.ts +2 -1
- package/dist/types/components/divider/divider.d.ts +20 -0
- package/dist/types/components/fab/fab.d.ts +4 -0
- package/dist/types/components/fab-button/fab-button.d.ts +5 -3
- package/dist/types/components/fab-list/fab-list.d.ts +4 -0
- package/dist/types/components/footer/footer.d.ts +4 -3
- package/dist/types/components/grid/grid.d.ts +4 -0
- package/dist/types/components/header/header.d.ts +9 -3
- package/dist/types/components/img/img.d.ts +3 -0
- package/dist/types/components/infinite-scroll/infinite-scroll.d.ts +21 -0
- package/dist/types/components/infinite-scroll-content/infinite-scroll-content.d.ts +4 -0
- package/dist/types/components/input/input.d.ts +31 -5
- package/dist/types/components/input-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 +4 -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/gestures/sheet.d.ts +1 -1
- package/dist/types/components/modal/modal-interface.d.ts +4 -7
- package/dist/types/components/modal/modal.d.ts +11 -1
- package/dist/types/components/nav/nav-interface.d.ts +9 -1
- package/dist/types/components/nav/nav.d.ts +5 -1
- package/dist/types/components/nav-link/nav-link.d.ts +4 -0
- package/dist/types/components/note/note.d.ts +2 -1
- package/dist/types/components/picker/picker.d.ts +2 -1
- package/dist/types/components/picker-column/picker-column.d.ts +2 -1
- package/dist/types/components/picker-column-option/picker-column-option.d.ts +4 -0
- package/dist/types/components/picker-legacy/picker.d.ts +2 -1
- package/dist/types/components/popover/popover-interface.d.ts +3 -6
- package/dist/types/components/popover/popover.d.ts +6 -5
- package/dist/types/components/progress-bar/progress-bar.d.ts +10 -1
- package/dist/types/components/radio/radio.d.ts +2 -1
- package/dist/types/components/radio-group/radio-group.d.ts +4 -0
- package/dist/types/components/range/range.d.ts +2 -1
- package/dist/types/components/refresher/refresher.d.ts +2 -1
- package/dist/types/components/refresher-content/refresher-content.d.ts +4 -0
- package/dist/types/components/reorder/reorder.d.ts +9 -0
- package/dist/types/components/reorder-group/reorder-group.d.ts +4 -0
- package/dist/types/components/ripple-effect/ripple-effect.d.ts +4 -0
- package/dist/types/components/route/route.d.ts +4 -0
- package/dist/types/components/router/router.d.ts +4 -0
- package/dist/types/components/router-link/router-link.d.ts +4 -0
- package/dist/types/components/router-outlet/router-outlet.d.ts +4 -1
- package/dist/types/components/row/row.d.ts +4 -0
- package/dist/types/components/searchbar/searchbar.d.ts +51 -9
- package/dist/types/components/segment/segment.d.ts +2 -1
- package/dist/types/components/segment-button/segment-button.d.ts +2 -1
- package/dist/types/components/select/select.d.ts +41 -13
- package/dist/types/components/select-option/select-option.d.ts +4 -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 +22 -2
- package/dist/types/components/tab-button/tab-button.d.ts +11 -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 +17 -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 +20 -3
- package/dist/types/components.d.ts +1593 -196
- package/dist/types/global/ionic-global.d.ts +27 -2
- package/dist/types/interface.d.ts +3 -0
- package/dist/types/stencil-public-runtime.d.ts +5 -12
- package/dist/types/utils/config.d.ts +106 -2
- package/dist/types/utils/focus-visible.d.ts +13 -0
- package/dist/types/utils/helpers.d.ts +11 -0
- package/dist/types/utils/overlays-interface.d.ts +31 -1
- package/dist/types/utils/test/playwright/generator.d.ts +31 -2
- package/dist/types/utils/transition/index.d.ts +0 -9
- package/hydrate/index.js +3080 -1436
- package/hydrate/index.mjs +3080 -1436
- package/package.json +10 -5
- package/components/hardware-back-button.js +0 -115
- package/components/index9.js +0 -7
- package/dist/cjs/app-globals-77ZfuXXk.js +0 -10
- package/dist/cjs/hardware-back-button-BxdNu76F.js +0 -121
- package/dist/cjs/index-DkNv4J_i.js +0 -10
- package/dist/cjs/ionic-global-UI5YPSi-.js +0 -151
- package/dist/esm/app-globals-CvLYUxE9.js +0 -8
- package/dist/esm/hardware-back-button-Dhbd-23H.js +0 -115
- package/dist/esm/index-ZjP4CjeZ.js +0 -7
- package/dist/esm/ionic-global-CTSyufhF.js +0 -146
- package/dist/ionic/p-0793aea6.entry.js +0 -4
- package/dist/ionic/p-0831d492.entry.js +0 -4
- package/dist/ionic/p-0f396661.entry.js +0 -4
- package/dist/ionic/p-117e7a3f.entry.js +0 -4
- package/dist/ionic/p-1191a2d9.entry.js +0 -4
- package/dist/ionic/p-148bdf18.entry.js +0 -4
- package/dist/ionic/p-16116947.entry.js +0 -4
- package/dist/ionic/p-19f80390.entry.js +0 -4
- package/dist/ionic/p-1GR6N4h5.js +0 -4
- package/dist/ionic/p-1a91f317.entry.js +0 -4
- package/dist/ionic/p-1bbd0a23.entry.js +0 -4
- package/dist/ionic/p-1f68cb59.entry.js +0 -4
- package/dist/ionic/p-24159ff7.entry.js +0 -4
- package/dist/ionic/p-25e5e5cc.entry.js +0 -4
- package/dist/ionic/p-2cb0f39f.entry.js +0 -4
- package/dist/ionic/p-3392f558.entry.js +0 -4
- package/dist/ionic/p-349fc921.entry.js +0 -4
- package/dist/ionic/p-3624b640.entry.js +0 -4
- package/dist/ionic/p-36a54836.entry.js +0 -4
- package/dist/ionic/p-39ed3212.entry.js +0 -4
- package/dist/ionic/p-44e3b33a.entry.js +0 -4
- package/dist/ionic/p-4DxY6_gG.js +0 -5
- package/dist/ionic/p-528af4e6.entry.js +0 -4
- package/dist/ionic/p-54dec9b1.entry.js +0 -4
- package/dist/ionic/p-568efea2.entry.js +0 -4
- package/dist/ionic/p-5bf5bde8.entry.js +0 -4
- package/dist/ionic/p-5c976c00.entry.js +0 -4
- package/dist/ionic/p-6383afc2.entry.js +0 -4
- package/dist/ionic/p-63852736.entry.js +0 -4
- package/dist/ionic/p-746cd400.entry.js +0 -4
- package/dist/ionic/p-7a53f04c.entry.js +0 -4
- package/dist/ionic/p-7b12d853.entry.js +0 -4
- package/dist/ionic/p-7da05504.entry.js +0 -4
- package/dist/ionic/p-8888efe4.entry.js +0 -4
- package/dist/ionic/p-8cdb4ff5.entry.js +0 -4
- package/dist/ionic/p-90f4cc71.entry.js +0 -4
- package/dist/ionic/p-9ddf2620.entry.js +0 -4
- package/dist/ionic/p-9eeaBrnk.js +0 -4
- package/dist/ionic/p-B1xocg0A.js +0 -4
- package/dist/ionic/p-B5MDSrGg.js +0 -4
- package/dist/ionic/p-BHGXdud8.js +0 -4
- package/dist/ionic/p-BhNEp2QP.js +0 -4
- package/dist/ionic/p-BmVRXR1y.js +0 -4
- package/dist/ionic/p-Br3vSlYh.js +0 -4
- package/dist/ionic/p-C-Cct-6D.js +0 -4
- package/dist/ionic/p-C4I6B3uV.js +0 -4
- package/dist/ionic/p-C87oPMMF.js +0 -4
- package/dist/ionic/p-C8d2ebIg.js +0 -4
- package/dist/ionic/p-CIGNaXM1.js +0 -4
- package/dist/ionic/p-Cnh7O81W.js +0 -4
- package/dist/ionic/p-CtWGkNnJ.js +0 -4
- package/dist/ionic/p-CvaZMP6T.js +0 -4
- package/dist/ionic/p-D2fQU_qK.js +0 -4
- package/dist/ionic/p-DA3JEZwK.js +0 -4
- package/dist/ionic/p-DAfH9Iif.js +0 -4
- package/dist/ionic/p-DJKvq7vb.js +0 -4
- package/dist/ionic/p-DW5tZAde.js +0 -4
- package/dist/ionic/p-Dm_oBkW1.js +0 -4
- package/dist/ionic/p-EnaLTYYj.js +0 -4
- package/dist/ionic/p-ZjP4CjeZ.js +0 -4
- package/dist/ionic/p-a00ad0f2.entry.js +0 -4
- package/dist/ionic/p-a81be128.entry.js +0 -4
- package/dist/ionic/p-afeb9df6.entry.js +0 -4
- package/dist/ionic/p-b292804d.entry.js +0 -4
- package/dist/ionic/p-bc9f9032.entry.js +0 -4
- package/dist/ionic/p-bf81a468.entry.js +0 -4
- package/dist/ionic/p-c6d35cdd.entry.js +0 -4
- package/dist/ionic/p-cde6d39b.entry.js +0 -4
- package/dist/ionic/p-d04d66fc.entry.js +0 -4
- package/dist/ionic/p-d3df6032.entry.js +0 -4
- package/dist/ionic/p-dbba38cf.entry.js +0 -4
- package/dist/ionic/p-e6c3214c.entry.js +0 -4
- package/dist/ionic/p-e6c465ff.entry.js +0 -4
- package/dist/ionic/p-ec76fec4.entry.js +0 -4
- package/dist/ionic/p-ee2e35a6.entry.js +0 -4
- package/dist/ionic/p-f7db572a.entry.js +0 -4
- package/dist/ionic/p-f9eb54ee.entry.js +0 -4
- /package/dist/collection/components/{input-password-toggle/input-password-toggle.css → refresher-content/refresher-content.css} +0 -0
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* (C) Ionic http://ionicframework.com - MIT License
|
|
3
3
|
*/
|
|
4
|
+
import caretDownRegular from "@phosphor-icons/core/assets/regular/caret-down.svg";
|
|
4
5
|
import { Host, h, forceUpdate } from "@stencil/core";
|
|
5
6
|
import { compareOptions, createNotchController, isOptionSelected } from "../../utils/forms/index";
|
|
6
7
|
import { focusVisibleElement, renderHiddenInput, inheritAttributes } from "../../utils/helpers";
|
|
@@ -10,10 +11,12 @@ import { isRTL } from "../../utils/rtl/index";
|
|
|
10
11
|
import { createColorClasses, hostContext } from "../../utils/theme";
|
|
11
12
|
import { watchForOptions } from "../../utils/watch-options";
|
|
12
13
|
import { caretDownSharp, chevronExpand } from "ionicons/icons";
|
|
13
|
-
import {
|
|
14
|
+
import { config } from "../../global/config";
|
|
15
|
+
import { getIonTheme } from "../../global/ionic-global";
|
|
14
16
|
// TODO(FW-2832): types
|
|
15
17
|
/**
|
|
16
|
-
* @virtualProp {"ios" | "md"} mode - The mode determines
|
|
18
|
+
* @virtualProp {"ios" | "md"} mode - The mode determines the platform behaviors of the component.
|
|
19
|
+
* @virtualProp {"ios" | "md" | "ionic"} theme - The theme determines the visual appearance of the component.
|
|
17
20
|
*
|
|
18
21
|
* @slot label - The label text to associate with the select. Use the `labelPlacement` property to control where the label is placed relative to the select. Use this if you need to render a label with custom HTML.
|
|
19
22
|
* @slot start - Content to display at the leading edge of the select.
|
|
@@ -414,8 +417,8 @@ export class Select {
|
|
|
414
417
|
async openPopover(ev) {
|
|
415
418
|
const { fill, labelPlacement } = this;
|
|
416
419
|
const interfaceOptions = this.interfaceOptions;
|
|
417
|
-
const
|
|
418
|
-
const showBackdrop =
|
|
420
|
+
const theme = getIonTheme(this);
|
|
421
|
+
const showBackdrop = theme === 'md' ? false : true;
|
|
419
422
|
const multiple = this.multiple;
|
|
420
423
|
const value = this.value;
|
|
421
424
|
let event = ev;
|
|
@@ -426,7 +429,7 @@ export class Select {
|
|
|
426
429
|
* when using a fill in MD mode or if the
|
|
427
430
|
* label is floating/stacked.
|
|
428
431
|
*/
|
|
429
|
-
if (hasFloatingOrStackedLabel || (
|
|
432
|
+
if (hasFloatingOrStackedLabel || (theme === 'md' && fill !== undefined)) {
|
|
430
433
|
size = 'cover';
|
|
431
434
|
/**
|
|
432
435
|
* Otherwise the popover
|
|
@@ -439,7 +442,7 @@ export class Select {
|
|
|
439
442
|
ionShadowTarget: this.nativeWrapperEl,
|
|
440
443
|
} });
|
|
441
444
|
}
|
|
442
|
-
const popoverOpts = Object.assign(Object.assign({
|
|
445
|
+
const popoverOpts = Object.assign(Object.assign({ theme,
|
|
443
446
|
event, alignment: 'center', size,
|
|
444
447
|
showBackdrop }, interfaceOptions), { component: 'ion-select-popover', cssClass: ['select-popover', interfaceOptions.cssClass], componentProps: {
|
|
445
448
|
header: interfaceOptions.header,
|
|
@@ -464,9 +467,9 @@ export class Select {
|
|
|
464
467
|
return popoverController.create(popoverOpts);
|
|
465
468
|
}
|
|
466
469
|
async openActionSheet() {
|
|
467
|
-
const
|
|
470
|
+
const theme = getIonTheme(this);
|
|
468
471
|
const interfaceOptions = this.interfaceOptions;
|
|
469
|
-
const actionSheetOpts = Object.assign(Object.assign({
|
|
472
|
+
const actionSheetOpts = Object.assign(Object.assign({ theme }, interfaceOptions), { buttons: this.createActionSheetButtons(this.childOpts, this.value), cssClass: ['select-action-sheet', interfaceOptions.cssClass] });
|
|
470
473
|
/**
|
|
471
474
|
* Workaround for Stencil to autodefine
|
|
472
475
|
* ion-action-sheet when
|
|
@@ -483,8 +486,8 @@ export class Select {
|
|
|
483
486
|
async openAlert() {
|
|
484
487
|
const interfaceOptions = this.interfaceOptions;
|
|
485
488
|
const inputType = this.multiple ? 'checkbox' : 'radio';
|
|
486
|
-
const
|
|
487
|
-
const alertOpts = Object.assign(Object.assign({
|
|
489
|
+
const theme = getIonTheme(this);
|
|
490
|
+
const alertOpts = Object.assign(Object.assign({ theme }, interfaceOptions), { header: interfaceOptions.header ? interfaceOptions.header : this.labelText, inputs: this.createAlertInputs(this.childOpts, inputType, this.value), buttons: [
|
|
488
491
|
{
|
|
489
492
|
text: this.cancelText,
|
|
490
493
|
role: 'cancel',
|
|
@@ -518,8 +521,8 @@ export class Select {
|
|
|
518
521
|
}
|
|
519
522
|
openModal() {
|
|
520
523
|
const { multiple, value, interfaceOptions } = this;
|
|
521
|
-
const
|
|
522
|
-
const modalOpts = Object.assign(Object.assign({}, interfaceOptions), { mode, cssClass: ['select-modal', interfaceOptions.cssClass], component: 'ion-select-modal', componentProps: {
|
|
524
|
+
const theme = getIonTheme(this);
|
|
525
|
+
const modalOpts = Object.assign(Object.assign({}, interfaceOptions), { mode: theme, cssClass: ['select-modal', interfaceOptions.cssClass], component: 'ion-select-modal', componentProps: {
|
|
523
526
|
header: interfaceOptions.header,
|
|
524
527
|
multiple,
|
|
525
528
|
value,
|
|
@@ -592,6 +595,18 @@ export class Select {
|
|
|
592
595
|
};
|
|
593
596
|
this.ionStyle.emit(style);
|
|
594
597
|
}
|
|
598
|
+
getSize() {
|
|
599
|
+
const theme = getIonTheme(this);
|
|
600
|
+
const { size } = this;
|
|
601
|
+
// TODO(ROU-11370): Remove theme check when sizes are defined for all themes.
|
|
602
|
+
if (theme !== 'ionic') {
|
|
603
|
+
return undefined;
|
|
604
|
+
}
|
|
605
|
+
if (size === undefined) {
|
|
606
|
+
return 'medium';
|
|
607
|
+
}
|
|
608
|
+
return size;
|
|
609
|
+
}
|
|
595
610
|
renderLabel() {
|
|
596
611
|
const { label } = this;
|
|
597
612
|
return (h("div", { class: {
|
|
@@ -624,8 +639,8 @@ export class Select {
|
|
|
624
639
|
* when fill="outline".
|
|
625
640
|
*/
|
|
626
641
|
renderLabelContainer() {
|
|
627
|
-
const
|
|
628
|
-
const hasOutlineFill =
|
|
642
|
+
const theme = getIonTheme(this);
|
|
643
|
+
const hasOutlineFill = theme === 'md' && this.fill === 'outline';
|
|
629
644
|
if (hasOutlineFill) {
|
|
630
645
|
/**
|
|
631
646
|
* The outline fill has a special outline
|
|
@@ -674,15 +689,10 @@ export class Select {
|
|
|
674
689
|
* next to the select text.
|
|
675
690
|
*/
|
|
676
691
|
renderSelectIcon() {
|
|
677
|
-
const
|
|
678
|
-
|
|
679
|
-
|
|
680
|
-
|
|
681
|
-
icon = expandedIcon;
|
|
682
|
-
}
|
|
683
|
-
else {
|
|
684
|
-
const defaultIcon = mode === 'ios' ? chevronExpand : caretDownSharp;
|
|
685
|
-
icon = toggleIcon !== null && toggleIcon !== void 0 ? toggleIcon : defaultIcon;
|
|
692
|
+
const { isExpanded, selectExpandedIcon, selectCollapsedIcon } = this;
|
|
693
|
+
let icon = selectCollapsedIcon;
|
|
694
|
+
if (isExpanded) {
|
|
695
|
+
icon = selectExpandedIcon;
|
|
686
696
|
}
|
|
687
697
|
return h("ion-icon", { class: "select-icon", part: "icon", "aria-hidden": "true", icon: icon });
|
|
688
698
|
}
|
|
@@ -717,6 +727,63 @@ export class Select {
|
|
|
717
727
|
const { disabled, inputId, isExpanded, required } = this;
|
|
718
728
|
return (h("button", { disabled: disabled, id: inputId, "aria-label": this.ariaLabel, "aria-haspopup": "dialog", "aria-expanded": `${isExpanded}`, "aria-describedby": this.getHintTextID(), "aria-invalid": this.getHintTextID() === this.errorTextId, "aria-required": `${required}`, onFocus: this.onFocus, onBlur: this.onBlur, ref: (focusEl) => (this.focusEl = focusEl) }));
|
|
719
729
|
}
|
|
730
|
+
getShape() {
|
|
731
|
+
const theme = getIonTheme(this);
|
|
732
|
+
const { shape } = this;
|
|
733
|
+
// TODO(ROU-11366): Remove theme check when shapes are defined for all themes.
|
|
734
|
+
if (theme === 'ionic' && shape === undefined) {
|
|
735
|
+
return 'round';
|
|
736
|
+
}
|
|
737
|
+
return shape;
|
|
738
|
+
}
|
|
739
|
+
/**
|
|
740
|
+
* Get the icon to use for the expand icon.
|
|
741
|
+
* If an icon is set on the component, use that.
|
|
742
|
+
* Otherwise, use the icon set in the config.
|
|
743
|
+
* If no icon is set in the config, use the default icon.
|
|
744
|
+
*/
|
|
745
|
+
get selectExpandedIcon() {
|
|
746
|
+
// Return the expandedIcon or toggleIcon if either is explicitly set
|
|
747
|
+
if (this.expandedIcon != null) {
|
|
748
|
+
return this.expandedIcon;
|
|
749
|
+
}
|
|
750
|
+
else if (this.toggleIcon != null) {
|
|
751
|
+
return this.toggleIcon;
|
|
752
|
+
}
|
|
753
|
+
// Determine the theme and map to default icons
|
|
754
|
+
const theme = getIonTheme(this);
|
|
755
|
+
const defaultIcons = {
|
|
756
|
+
ios: chevronExpand,
|
|
757
|
+
ionic: caretDownRegular,
|
|
758
|
+
md: caretDownSharp,
|
|
759
|
+
};
|
|
760
|
+
// Get the default icon based on the theme, falling back to 'md' icon if necessary
|
|
761
|
+
const defaultIcon = defaultIcons[theme] || defaultIcons.md;
|
|
762
|
+
// Return the configured select expanded icon or the default icon
|
|
763
|
+
return config.get('selectExpandedIcon', defaultIcon);
|
|
764
|
+
}
|
|
765
|
+
/**
|
|
766
|
+
* Get the icon to use for the collapsed icon.
|
|
767
|
+
* If an icon is set on the component, use that.
|
|
768
|
+
* Otherwise, use the icon set in the config.
|
|
769
|
+
* If no icon is set in the config, use the default icon.
|
|
770
|
+
*/
|
|
771
|
+
get selectCollapsedIcon() {
|
|
772
|
+
// Return the toggleIcon if it is explicitly set
|
|
773
|
+
if (this.toggleIcon) {
|
|
774
|
+
return this.toggleIcon;
|
|
775
|
+
}
|
|
776
|
+
// Determine the theme and map to default icons
|
|
777
|
+
const theme = getIonTheme(this);
|
|
778
|
+
const defaultIcons = {
|
|
779
|
+
ios: chevronExpand,
|
|
780
|
+
ionic: caretDownRegular,
|
|
781
|
+
md: caretDownSharp,
|
|
782
|
+
};
|
|
783
|
+
// Get the default icon based on the theme, falling back to 'md' icon if necessary
|
|
784
|
+
const defaultIcon = defaultIcons[theme] || defaultIcons.md;
|
|
785
|
+
return config.get('selectCollapsedIcon', defaultIcon);
|
|
786
|
+
}
|
|
720
787
|
getHintTextID() {
|
|
721
788
|
const { el, helperText, errorText, helperTextId, errorTextId } = this;
|
|
722
789
|
if (el.classList.contains('ion-touched') && el.classList.contains('ion-invalid') && errorText) {
|
|
@@ -754,13 +821,17 @@ export class Select {
|
|
|
754
821
|
return h("div", { class: "select-bottom" }, this.renderHintText());
|
|
755
822
|
}
|
|
756
823
|
render() {
|
|
757
|
-
const { disabled, el, isExpanded, expandedIcon, labelPlacement, justify, placeholder, fill,
|
|
758
|
-
const
|
|
824
|
+
const { disabled, el, isExpanded, expandedIcon, labelPlacement, justify, placeholder, fill, name, value, hasFocus, } = this;
|
|
825
|
+
const theme = getIonTheme(this);
|
|
826
|
+
const shape = this.getShape();
|
|
759
827
|
const hasFloatingOrStackedLabel = labelPlacement === 'floating' || labelPlacement === 'stacked';
|
|
828
|
+
const shouldRenderOuterIcon = theme !== 'ionic' && hasFloatingOrStackedLabel;
|
|
829
|
+
const shouldRenderInnerIcon = theme === 'ionic' || !hasFloatingOrStackedLabel;
|
|
760
830
|
const justifyEnabled = !hasFloatingOrStackedLabel && justify !== undefined;
|
|
761
831
|
const rtl = isRTL(el) ? 'rtl' : 'ltr';
|
|
762
832
|
const inItem = hostContext('ion-item', this.el);
|
|
763
|
-
const
|
|
833
|
+
const size = this.getSize();
|
|
834
|
+
const shouldRenderHighlight = theme === 'md' && fill !== 'outline' && !inItem;
|
|
764
835
|
const hasValue = this.hasValue();
|
|
765
836
|
const hasStartEndSlots = el.querySelector('[slot="start"], [slot="end"]') !== null;
|
|
766
837
|
renderHiddenInput(true, el, name, parseValue(value), disabled);
|
|
@@ -782,8 +853,8 @@ export class Select {
|
|
|
782
853
|
* TODO(FW-5592): Remove hasStartEndSlots condition
|
|
783
854
|
*/
|
|
784
855
|
const labelShouldFloat = labelPlacement === 'stacked' || (labelPlacement === 'floating' && (hasValue || isExpanded || hasStartEndSlots));
|
|
785
|
-
return (h(Host, { key: '
|
|
786
|
-
[
|
|
856
|
+
return (h(Host, { key: '1ab6cf909651f167800bb3398a1522c360d03023', onClick: this.onClick, class: createColorClasses(this.color, {
|
|
857
|
+
[theme]: true,
|
|
787
858
|
'in-item': inItem,
|
|
788
859
|
'in-item-color': hostContext('ion-item.ion-color', el),
|
|
789
860
|
'select-disabled': disabled,
|
|
@@ -800,20 +871,33 @@ export class Select {
|
|
|
800
871
|
[`select-justify-${justify}`]: justifyEnabled,
|
|
801
872
|
[`select-shape-${shape}`]: shape !== undefined,
|
|
802
873
|
[`select-label-placement-${labelPlacement}`]: true,
|
|
803
|
-
|
|
874
|
+
[`select-size-${size}`]: size !== undefined,
|
|
875
|
+
}) }, h("label", { key: '9a78e88197abc7bc4d9fb8f42a56172ee50fcb64', class: "select-wrapper", id: "select-label", onClick: this.onLabelClick }, this.renderLabelContainer(), h("div", { key: '51e1ec9bfb08344c8d1ff2fb08ead29ece3fbe6d', class: "select-wrapper-inner" },
|
|
876
|
+
/**
|
|
877
|
+
* For the ionic theme, we render the outline container here
|
|
878
|
+
* instead of higher up, so it can be positioned relative to
|
|
879
|
+
* the native wrapper instead of the <label> element or the
|
|
880
|
+
* entire component. This allows the label text to be positioned
|
|
881
|
+
* above the outline, while staying within the bounds of the
|
|
882
|
+
* <label> element, ensuring that clicking the label text
|
|
883
|
+
* focuses the select.
|
|
884
|
+
*/
|
|
885
|
+
theme === 'ionic' && fill === 'outline' && h("div", { key: '9008f743f2cbeac39cb736e285854e855625f45d', class: "select-outline" }), h("slot", { key: 'a5c981053510d9b19d9097fb0b220d9eaccd61d7', name: "start" }), h("div", { key: '80ba2091466f912ee63a3e4c11334b657f8d9b3d', class: "native-wrapper", ref: (el) => (this.nativeWrapperEl = el), part: "container" }, this.renderSelectText(), this.renderListbox()), h("slot", { key: '18b657eee882ac2b63c945843d1035f26474aa58', name: "end" }), shouldRenderInnerIcon && this.renderSelectIcon()), shouldRenderOuterIcon && this.renderSelectIcon(), shouldRenderHighlight && h("div", { key: '84630c4f5716fd87400da571aa3cf6c1d624694e', class: "select-highlight" })), this.renderBottomContent()));
|
|
804
886
|
}
|
|
805
887
|
static get is() { return "ion-select"; }
|
|
806
888
|
static get encapsulation() { return "shadow"; }
|
|
807
889
|
static get originalStyleUrls() {
|
|
808
890
|
return {
|
|
809
891
|
"ios": ["select.ios.scss"],
|
|
810
|
-
"md": ["select.md.scss"]
|
|
892
|
+
"md": ["select.md.scss"],
|
|
893
|
+
"ionic": ["select.ionic.scss"]
|
|
811
894
|
};
|
|
812
895
|
}
|
|
813
896
|
static get styleUrls() {
|
|
814
897
|
return {
|
|
815
898
|
"ios": ["select.ios.css"],
|
|
816
|
-
"md": ["select.md.css"]
|
|
899
|
+
"md": ["select.md.css"],
|
|
900
|
+
"ionic": ["select.ionic.css"]
|
|
817
901
|
};
|
|
818
902
|
}
|
|
819
903
|
static get properties() {
|
|
@@ -921,7 +1005,7 @@ export class Select {
|
|
|
921
1005
|
"optional": true,
|
|
922
1006
|
"docs": {
|
|
923
1007
|
"tags": [],
|
|
924
|
-
"text": "The fill for the item. If `\"solid\"` the item will have a background. If\n`\"outline\"` the item will be transparent with a border. Only available in
|
|
1008
|
+
"text": "The fill for the item. If `\"solid\"` the item will have a background. If\n`\"outline\"` the item will be transparent with a border. Only available in the `\"md\"` theme."
|
|
925
1009
|
},
|
|
926
1010
|
"getter": false,
|
|
927
1011
|
"setter": false,
|
|
@@ -1180,7 +1264,7 @@ export class Select {
|
|
|
1180
1264
|
"optional": true,
|
|
1181
1265
|
"docs": {
|
|
1182
1266
|
"tags": [],
|
|
1183
|
-
"text": "The toggle icon to use. Defaults to
|
|
1267
|
+
"text": "The toggle icon to use. Defaults to `\"chevronExpand\"` for the `\"ios\"` theme,\nor `\"caretDownSharp\"` for the `\"md\"` and `\"ionic\"` themes."
|
|
1184
1268
|
},
|
|
1185
1269
|
"getter": false,
|
|
1186
1270
|
"setter": false,
|
|
@@ -1199,69 +1283,88 @@ export class Select {
|
|
|
1199
1283
|
"optional": true,
|
|
1200
1284
|
"docs": {
|
|
1201
1285
|
"tags": [],
|
|
1202
|
-
"text": "The toggle icon to show when the select is open. If defined, the icon\nrotation behavior in
|
|
1286
|
+
"text": "The toggle icon to show when the select is open. If defined, the icon\nrotation behavior in `\"md\"` theme will be disabled. If undefined, `toggleIcon`\nwill be used for when the select is both open and closed."
|
|
1203
1287
|
},
|
|
1204
1288
|
"getter": false,
|
|
1205
1289
|
"setter": false,
|
|
1206
1290
|
"reflect": false
|
|
1207
1291
|
},
|
|
1292
|
+
"required": {
|
|
1293
|
+
"type": "boolean",
|
|
1294
|
+
"attribute": "required",
|
|
1295
|
+
"mutable": false,
|
|
1296
|
+
"complexType": {
|
|
1297
|
+
"original": "boolean",
|
|
1298
|
+
"resolved": "boolean",
|
|
1299
|
+
"references": {}
|
|
1300
|
+
},
|
|
1301
|
+
"required": false,
|
|
1302
|
+
"optional": false,
|
|
1303
|
+
"docs": {
|
|
1304
|
+
"tags": [],
|
|
1305
|
+
"text": "If true, screen readers will announce it as a required field. This property\nworks only for accessibility purposes, it will not prevent the form from\nsubmitting if the value is invalid."
|
|
1306
|
+
},
|
|
1307
|
+
"getter": false,
|
|
1308
|
+
"setter": false,
|
|
1309
|
+
"reflect": false,
|
|
1310
|
+
"defaultValue": "false"
|
|
1311
|
+
},
|
|
1208
1312
|
"shape": {
|
|
1209
1313
|
"type": "string",
|
|
1210
1314
|
"attribute": "shape",
|
|
1211
1315
|
"mutable": false,
|
|
1212
1316
|
"complexType": {
|
|
1213
|
-
"original": "'round'",
|
|
1214
|
-
"resolved": "\"round\" | undefined",
|
|
1317
|
+
"original": "'soft' | 'round' | 'rectangular'",
|
|
1318
|
+
"resolved": "\"rectangular\" | \"round\" | \"soft\" | undefined",
|
|
1215
1319
|
"references": {}
|
|
1216
1320
|
},
|
|
1217
1321
|
"required": false,
|
|
1218
1322
|
"optional": true,
|
|
1219
1323
|
"docs": {
|
|
1220
1324
|
"tags": [],
|
|
1221
|
-
"text": "
|
|
1325
|
+
"text": "Set to `\"soft\"` for a select with slightly rounded corners,\n`\"round\"` for a select with fully rounded corners,\nor `\"rectangular\"` for a select without rounded corners.\n\nDefaults to `\"round\"` for the `\"ionic\"` theme, undefined for all other themes."
|
|
1222
1326
|
},
|
|
1223
1327
|
"getter": false,
|
|
1224
1328
|
"setter": false,
|
|
1225
1329
|
"reflect": false
|
|
1226
1330
|
},
|
|
1227
|
-
"
|
|
1228
|
-
"type": "
|
|
1229
|
-
"attribute": "
|
|
1230
|
-
"mutable":
|
|
1331
|
+
"size": {
|
|
1332
|
+
"type": "string",
|
|
1333
|
+
"attribute": "size",
|
|
1334
|
+
"mutable": false,
|
|
1231
1335
|
"complexType": {
|
|
1232
|
-
"original": "
|
|
1233
|
-
"resolved": "
|
|
1336
|
+
"original": "'small' | 'medium' | 'large'",
|
|
1337
|
+
"resolved": "\"large\" | \"medium\" | \"small\" | undefined",
|
|
1234
1338
|
"references": {}
|
|
1235
1339
|
},
|
|
1236
1340
|
"required": false,
|
|
1237
1341
|
"optional": true,
|
|
1238
1342
|
"docs": {
|
|
1239
1343
|
"tags": [],
|
|
1240
|
-
"text": "The
|
|
1344
|
+
"text": "The size of the select. If \"large\" it will increase the height of the select, while\n\"small\" and \"medium\" provide progressively smaller heights.\n\nDefaults to `\"medium\"` for the ionic theme, and undefined for all other themes."
|
|
1241
1345
|
},
|
|
1242
1346
|
"getter": false,
|
|
1243
1347
|
"setter": false,
|
|
1244
1348
|
"reflect": false
|
|
1245
1349
|
},
|
|
1246
|
-
"
|
|
1247
|
-
"type": "
|
|
1248
|
-
"attribute": "
|
|
1249
|
-
"mutable":
|
|
1350
|
+
"value": {
|
|
1351
|
+
"type": "any",
|
|
1352
|
+
"attribute": "value",
|
|
1353
|
+
"mutable": true,
|
|
1250
1354
|
"complexType": {
|
|
1251
|
-
"original": "
|
|
1252
|
-
"resolved": "
|
|
1355
|
+
"original": "any | null",
|
|
1356
|
+
"resolved": "any",
|
|
1253
1357
|
"references": {}
|
|
1254
1358
|
},
|
|
1255
1359
|
"required": false,
|
|
1256
|
-
"optional":
|
|
1360
|
+
"optional": true,
|
|
1257
1361
|
"docs": {
|
|
1258
1362
|
"tags": [],
|
|
1259
|
-
"text": "
|
|
1363
|
+
"text": "The value of the select."
|
|
1260
1364
|
},
|
|
1261
1365
|
"getter": false,
|
|
1262
1366
|
"setter": false,
|
|
1263
|
-
"reflect": false
|
|
1264
|
-
"defaultValue": "false"
|
|
1367
|
+
"reflect": false
|
|
1265
1368
|
}
|
|
1266
1369
|
};
|
|
1267
1370
|
}
|