voyager-ionic-core 7.7.2 → 8.0.0-beta.1
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 +4 -4
- package/components/alert.js +2 -2
- package/components/backdrop.js +1 -13
- package/components/button-active.js +1 -1
- package/components/button.js +2 -2
- package/components/checkbox.js +8 -80
- package/components/data.js +1 -1
- package/components/gesture-controller.js +1 -1
- package/components/helpers.js +2 -2
- package/components/index9.js +1 -1
- package/components/input-shims.js +8 -1
- package/components/ion-accordion-group.js +1 -1
- package/components/ion-back-button.js +1 -1
- package/components/ion-badge.js +2 -2
- package/components/ion-breadcrumb.js +2 -2
- package/components/ion-card-subtitle.js +2 -2
- package/components/ion-card-title.js +1 -1
- package/components/ion-card.js +2 -2
- package/components/ion-chip.js +2 -2
- package/components/ion-col.js +2 -2
- package/components/ion-content.js +5 -6
- package/components/ion-datetime-button.js +5 -5
- package/components/ion-datetime.js +41 -105
- package/components/ion-fab-button.js +4 -4
- package/components/ion-fab-list.js +3 -3
- package/components/ion-fab.js +2 -2
- package/components/ion-footer.js +3 -3
- package/components/ion-grid.js +2 -2
- package/components/ion-header.js +3 -3
- package/components/ion-img.js +1 -1
- package/components/ion-infinite-scroll-content.js +4 -4
- package/components/ion-infinite-scroll.js +1 -1
- package/components/ion-input.js +7 -93
- package/components/ion-item-divider.js +4 -4
- package/components/ion-item-group.js +1 -1
- package/components/ion-item-option.js +4 -4
- package/components/ion-item-options.js +4 -4
- package/components/ion-item-sliding.js +2 -2
- package/components/ion-loading.js +4 -4
- package/components/ion-menu-button.js +3 -3
- package/components/ion-menu-toggle.js +2 -2
- package/components/ion-menu.js +28 -43
- package/components/ion-modal.js +43 -28
- package/components/ion-nav-link.js +1 -1
- package/components/ion-nav.js +9 -5
- package/components/ion-picker-column-option.d.ts +11 -0
- package/components/ion-picker-column-option.js +9 -0
- package/components/ion-picker-column.js +2 -2
- package/components/ion-picker-legacy-column.d.ts +11 -0
- package/components/ion-picker-legacy-column.js +9 -0
- package/components/{ion-picker-internal.d.ts → ion-picker-legacy.d.ts} +4 -4
- package/components/ion-picker-legacy.js +321 -0
- package/components/ion-picker.js +1 -315
- package/components/ion-progress-bar.js +7 -4
- package/components/ion-range.js +34 -88
- package/components/ion-refresher-content.js +1 -1
- package/components/ion-refresher.js +4 -4
- package/components/ion-reorder-group.js +1 -1
- package/components/ion-reorder.js +1 -1
- package/components/ion-router-link.js +3 -3
- package/components/ion-router-outlet.js +2 -2
- package/components/ion-router.js +1 -1
- package/components/ion-row.js +1 -1
- package/components/ion-searchbar.js +7 -7
- package/components/ion-segment-button.js +5 -5
- package/components/ion-segment.js +2 -2
- package/components/ion-select-option.js +1 -1
- package/components/ion-select.js +67 -161
- package/components/ion-skeleton-text.js +2 -2
- package/components/ion-split-pane.js +28 -17
- package/components/ion-tab-bar.js +4 -4
- package/components/ion-tab-button.js +4 -4
- package/components/ion-tab.js +2 -2
- package/components/ion-tabs.js +1 -1
- package/components/ion-text.js +2 -2
- package/components/ion-textarea.js +7 -70
- package/components/ion-thumbnail.js +1 -1
- package/components/ion-title.js +3 -3
- package/components/ion-toast.js +12 -6
- package/components/ion-toggle.js +7 -64
- package/components/ion-toolbar.js +4 -4
- package/components/item.js +22 -7
- package/components/label.js +3 -3
- package/components/list-header.js +4 -4
- package/components/list.js +2 -2
- package/components/note.js +4 -4
- package/components/overlays.js +138 -42
- package/components/picker-column-option.js +124 -0
- package/components/picker-column.js +367 -324
- package/components/picker-column2.js +381 -0
- package/components/{picker-internal.js → picker.js} +33 -26
- package/components/popover.js +6 -6
- package/components/radio-group.js +1 -1
- package/components/radio.js +8 -81
- package/components/refresher.utils.js +1 -1
- package/components/ripple-effect.js +1 -1
- package/components/select-popover.js +2 -2
- package/components/spinner.js +1 -1
- package/components/swipe-back.js +1 -1
- package/css/core.css +90 -27
- package/css/core.css.map +1 -1
- package/css/display.css.map +1 -1
- package/css/float-elements.css.map +1 -1
- package/css/global.bundle.css +1 -1
- package/css/global.bundle.css.map +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/padding.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/themes/dark.always.css +160 -0
- package/css/themes/dark.always.css.map +1 -0
- package/css/themes/dark.class.css +160 -0
- package/css/themes/dark.class.css.map +1 -0
- package/css/themes/dark.css +3 -0
- package/css/themes/dark.css.map +1 -0
- package/css/themes/dark.system.css +162 -0
- package/css/themes/dark.system.css.map +1 -0
- package/css/themes/high-contrast-dark.always.css +180 -0
- package/css/themes/high-contrast-dark.always.css.map +1 -0
- package/css/themes/high-contrast-dark.class.css +180 -0
- package/css/themes/high-contrast-dark.class.css.map +1 -0
- package/css/themes/high-contrast-dark.css +3 -0
- package/css/themes/high-contrast-dark.css.map +1 -0
- package/css/themes/high-contrast-dark.system.css +182 -0
- package/css/themes/high-contrast-dark.system.css.map +1 -0
- package/css/themes/high-contrast.always.css +101 -0
- package/css/themes/high-contrast.always.css.map +1 -0
- package/css/themes/high-contrast.class.css +101 -0
- package/css/themes/high-contrast.class.css.map +1 -0
- package/css/themes/high-contrast.css +3 -0
- package/css/themes/high-contrast.css.map +1 -0
- package/css/themes/high-contrast.system.css +103 -0
- package/css/themes/high-contrast.system.css.map +1 -0
- package/css/typography.css +1 -1
- package/css/typography.css.map +1 -1
- package/css/utils.bundle.css.map +1 -1
- package/dist/cjs/{animation-fdab9de5.js → animation-4ad55058.js} +1 -1
- package/dist/cjs/{app-globals-92ad1b3d.js → app-globals-4d26cb5a.js} +1 -1
- package/dist/cjs/{button-active-2d6520ec.js → button-active-e447f58b.js} +3 -3
- package/dist/cjs/{data-a5109f09.js → data-e2bf21de.js} +1 -1
- package/dist/cjs/{framework-delegate-a3e6d060.js → framework-delegate-53817ef1.js} +1 -1
- package/dist/cjs/{gesture-controller-c40c045a.js → gesture-controller-9436f482.js} +1 -0
- package/dist/cjs/{hardware-back-button-2696acaf.js → hardware-back-button-4cb049f1.js} +2 -2
- package/dist/cjs/{helpers-2e1028fa.js → helpers-b71ca811.js} +2 -3
- package/dist/cjs/{index-53d162b2.js → index-347883f6.js} +1 -1
- package/dist/cjs/{index-10da82ce.js → index-7574e3d2.js} +1 -1
- package/dist/cjs/{index-c3580a90.js → index-92bb95d6.js} +4 -4
- package/dist/cjs/{index-a43f7a0f.js → index-bbc5b1f7.js} +4 -4
- package/dist/cjs/{index-0ffe376d.js → index-ea266398.js} +2 -2
- package/dist/cjs/{index-d1b59ffa.js → index-ee07ed59.js} +1 -1
- package/dist/cjs/index.cjs.js +13 -13
- package/dist/cjs/{input-shims-6f804705.js → input-shims-679d87bc.js} +10 -3
- package/dist/cjs/{input.utils-d693d18a.js → input.utils-5175aea1.js} +1 -1
- package/dist/cjs/ion-accordion_2.cjs.entry.js +4 -4
- package/dist/cjs/ion-action-sheet.cjs.entry.js +14 -14
- package/dist/cjs/ion-alert.cjs.entry.js +12 -12
- package/dist/cjs/ion-app_8.cjs.entry.js +28 -29
- package/dist/cjs/ion-avatar_3.cjs.entry.js +5 -5
- package/dist/cjs/ion-back-button.cjs.entry.js +4 -4
- package/dist/cjs/ion-backdrop.cjs.entry.js +3 -15
- package/dist/cjs/ion-breadcrumb_2.cjs.entry.js +5 -5
- package/dist/cjs/ion-button_2.cjs.entry.js +5 -5
- package/dist/cjs/ion-card_5.cjs.entry.js +8 -8
- package/dist/cjs/ion-checkbox.cjs.entry.js +9 -77
- package/dist/cjs/ion-chip.cjs.entry.js +4 -4
- package/dist/cjs/ion-col_3.cjs.entry.js +7 -7
- package/dist/cjs/ion-datetime-button.cjs.entry.js +9 -9
- package/dist/cjs/ion-datetime_3.cjs.entry.js +56 -110
- package/dist/cjs/ion-fab_3.cjs.entry.js +12 -12
- package/dist/cjs/ion-img.cjs.entry.js +4 -4
- package/dist/cjs/ion-infinite-scroll_2.cjs.entry.js +9 -9
- package/dist/cjs/ion-input.cjs.entry.js +12 -92
- package/dist/cjs/ion-item-option_3.cjs.entry.js +13 -13
- package/dist/cjs/ion-item_8.cjs.entry.js +45 -30
- package/dist/cjs/ion-loading.cjs.entry.js +12 -11
- package/dist/cjs/ion-menu_3.cjs.entry.js +40 -56
- package/dist/cjs/ion-modal.cjs.entry.js +53 -38
- package/dist/cjs/ion-nav_2.cjs.entry.js +13 -10
- package/dist/cjs/ion-picker-column-option.cjs.entry.js +106 -0
- package/dist/cjs/{ion-picker-column-internal.cjs.entry.js → ion-picker-column.cjs.entry.js} +124 -93
- package/dist/cjs/{ion-picker-internal.cjs.entry.js → ion-picker.cjs.entry.js} +32 -25
- package/dist/cjs/ion-popover.cjs.entry.js +13 -12
- package/dist/cjs/ion-progress-bar.cjs.entry.js +9 -6
- package/dist/cjs/ion-radio_2.cjs.entry.js +10 -79
- package/dist/cjs/ion-range.cjs.entry.js +37 -90
- package/dist/cjs/ion-refresher_2.cjs.entry.js +12 -12
- package/dist/cjs/ion-reorder_2.cjs.entry.js +7 -7
- package/dist/cjs/ion-ripple-effect.cjs.entry.js +3 -3
- package/dist/cjs/ion-route_4.cjs.entry.js +6 -6
- package/dist/cjs/ion-searchbar.cjs.entry.js +9 -9
- package/dist/cjs/ion-segment_2.cjs.entry.js +11 -11
- package/dist/cjs/ion-select_3.cjs.entry.js +80 -171
- package/dist/cjs/ion-spinner.cjs.entry.js +3 -3
- package/dist/cjs/ion-split-pane.cjs.entry.js +28 -18
- package/dist/cjs/ion-tab-bar_2.cjs.entry.js +11 -11
- package/dist/cjs/ion-tab_2.cjs.entry.js +6 -6
- package/dist/cjs/ion-text.cjs.entry.js +4 -4
- package/dist/cjs/ion-textarea.cjs.entry.js +11 -71
- package/dist/cjs/ion-toast.cjs.entry.js +20 -14
- package/dist/cjs/ion-toggle.cjs.entry.js +10 -66
- package/dist/cjs/{ionic-global-59a10130.js → ionic-global-59aa7eb7.js} +1 -1
- package/dist/cjs/ionic.cjs.js +5 -5
- package/dist/cjs/{ios.transition-c3b11cc3.js → ios.transition-997fe325.js} +4 -4
- package/dist/cjs/loader.cjs.js +4 -4
- package/dist/cjs/{md.transition-82a8c649.js → md.transition-2b76c2c6.js} +4 -4
- package/dist/cjs/{notch-controller-db0127c4.js → notch-controller-8e0ae870.js} +1 -1
- package/dist/cjs/{overlays-fb7ca451.js → overlays-3d02b54f.js} +141 -44
- package/dist/cjs/{status-tap-692f6d32.js → status-tap-3761c2d4.js} +3 -3
- package/dist/cjs/{swipe-back-7a848bb8.js → swipe-back-5b71fc62.js} +3 -3
- package/dist/collection/collection-manifest.json +8 -7
- package/dist/collection/components/accordion-group/accordion-group.md.css +4 -26
- package/dist/collection/components/action-sheet/action-sheet.ios.css +16 -9
- package/dist/collection/components/action-sheet/action-sheet.js +2 -2
- package/dist/collection/components/action-sheet/action-sheet.md.css +10 -3
- package/dist/collection/components/action-sheet/test/a11y/action-sheet.e2e.js +23 -14
- package/dist/collection/components/action-sheet/test/basic/action-sheet-rendering.e2e.js +19 -0
- package/dist/collection/components/action-sheet/test/basic/action-sheet.spec.js +22 -0
- package/dist/collection/components/alert/alert.ios.css +33 -80
- package/dist/collection/components/alert/alert.md.css +25 -121
- package/dist/collection/components/alert/test/a11y/alert.e2e.js +22 -9
- package/dist/collection/components/back-button/back-button.ios.css +1 -1
- package/dist/collection/components/back-button/test/a11y/back-button.e2e.js +21 -0
- package/dist/collection/components/backdrop/backdrop.js +1 -13
- package/dist/collection/components/badge/badge.ios.css +1 -1
- package/dist/collection/components/badge/badge.md.css +1 -1
- package/dist/collection/components/badge/test/a11y/badge.e2e.js +18 -0
- package/dist/collection/components/breadcrumb/breadcrumb.ios.css +9 -9
- package/dist/collection/components/breadcrumb/breadcrumb.md.css +9 -9
- package/dist/collection/components/button/button.ios.css +11 -11
- package/dist/collection/components/button/button.md.css +9 -9
- package/dist/collection/components/button/test/a11y/button.e2e.js +48 -0
- package/dist/collection/components/button/test/wrap/button.e2e.js +12 -24
- package/dist/collection/components/card/card.ios.css +1 -1
- package/dist/collection/components/card/card.md.css +1 -1
- package/dist/collection/components/card-subtitle/card-subtitle.ios.css +1 -1
- package/dist/collection/components/card-subtitle/card-subtitle.md.css +1 -1
- package/dist/collection/components/card-title/card-title.md.css +1 -1
- package/dist/collection/components/checkbox/checkbox.ios.css +10 -88
- package/dist/collection/components/checkbox/checkbox.js +5 -118
- package/dist/collection/components/checkbox/checkbox.md.css +7 -85
- package/dist/collection/components/checkbox/test/a11y/checkbox.e2e.js +11 -2
- package/dist/collection/components/checkbox/test/basic/checkbox.e2e.js +10 -0
- package/dist/collection/components/chip/chip.js +2 -2
- package/dist/collection/components/col/col.js +2 -2
- package/dist/collection/components/content/content.css +0 -4
- package/dist/collection/components/content/content.js +3 -4
- package/dist/collection/components/datetime/datetime.ios.css +105 -117
- package/dist/collection/components/datetime/datetime.js +25 -77
- package/dist/collection/components/datetime/datetime.md.css +106 -114
- package/dist/collection/components/datetime/test/a11y/datetime.e2e.js +1 -1
- package/dist/collection/components/datetime/test/a11y/datetime.spec.js +6 -9
- package/dist/collection/components/datetime/test/basic/datetime.e2e.js +13 -1
- package/dist/collection/components/datetime/test/datetime.e2e.js +2 -2
- package/dist/collection/components/datetime/test/disabled/datetime.spec.js +4 -4
- package/dist/collection/components/datetime/test/locale/datetime.e2e.js +2 -2
- package/dist/collection/components/datetime/test/minmax/datetime.e2e.js +6 -6
- package/dist/collection/components/datetime/test/month-year-picker/datetime.e2e.js +1 -1
- package/dist/collection/components/datetime/test/prefer-wheel/datetime.e2e.js +43 -41
- package/dist/collection/components/datetime/test/presentation/datetime.e2e.js +1 -1
- package/dist/collection/components/datetime/test/readonly/datetime.e2e.js +4 -4
- package/dist/collection/components/datetime/test/values/datetime.e2e.js +15 -12
- package/dist/collection/components/datetime/utils/data.js +1 -1
- package/dist/collection/components/datetime-button/datetime-button.ios.css +107 -0
- package/dist/collection/components/datetime-button/datetime-button.js +5 -5
- package/dist/collection/components/datetime-button/{datetime-button.css → datetime-button.md.css} +10 -7
- package/dist/collection/components/datetime-button/test/basic/datetime-button.e2e.js +12 -0
- package/dist/collection/components/fab/fab.js +2 -2
- package/dist/collection/components/fab-button/fab-button.ios.css +7 -7
- package/dist/collection/components/fab-button/fab-button.js +2 -2
- package/dist/collection/components/fab-button/fab-button.md.css +1 -1
- package/dist/collection/components/fab-button/test/a11y/fab-button.e2e.js +50 -0
- package/dist/collection/components/fab-list/fab-list.css +4 -42
- package/dist/collection/components/fab-list/fab-list.js +2 -2
- package/dist/collection/components/footer/footer.js +2 -2
- package/dist/collection/components/grid/grid.js +2 -2
- package/dist/collection/components/header/header.js +2 -2
- package/dist/collection/components/img/img.js +1 -1
- package/dist/collection/components/infinite-scroll/infinite-scroll.js +1 -1
- package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.ios.css +3 -3
- package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.js +2 -2
- package/dist/collection/components/infinite-scroll-content/infinite-scroll-content.md.css +3 -3
- package/dist/collection/components/input/input.ios.css +11 -104
- package/dist/collection/components/input/input.js +6 -144
- package/dist/collection/components/input/input.md.css +35 -216
- package/dist/collection/components/input/test/a11y/input.e2e.js +41 -3
- package/dist/collection/components/input/test/item/input.e2e.js +21 -0
- package/dist/collection/components/item/item.ios.css +7 -31
- package/dist/collection/components/item/item.js +20 -5
- package/dist/collection/components/item/item.md.css +29 -112
- package/dist/collection/components/item/test/a11y/item.e2e.js +0 -40
- package/dist/collection/components/item-divider/item-divider.ios.css +3 -3
- package/dist/collection/components/item-divider/item-divider.js +2 -2
- package/dist/collection/components/item-divider/item-divider.md.css +7 -17
- package/dist/collection/components/item-group/item-group.js +1 -1
- package/dist/collection/components/item-option/item-option.ios.css +2 -2
- package/dist/collection/components/item-option/item-option.js +2 -2
- package/dist/collection/components/item-option/item-option.md.css +1 -1
- package/dist/collection/components/item-options/item-options.ios.css +1 -1
- package/dist/collection/components/item-options/item-options.js +1 -1
- package/dist/collection/components/item-options/item-options.md.css +1 -1
- package/dist/collection/components/item-sliding/item-sliding.js +1 -1
- package/dist/collection/components/item-sliding/test/a11y/item-sliding.e2e.js +28 -0
- package/dist/collection/components/label/label.ios.css +1 -5
- package/dist/collection/components/label/label.js +1 -1
- package/dist/collection/components/label/label.md.css +2 -6
- package/dist/collection/components/label/test/a11y/label.e2e.js +20 -0
- package/dist/collection/components/label/test/item/item.e2e.js +24 -0
- package/dist/collection/components/list/list.js +1 -1
- package/dist/collection/components/list/list.md.css +2 -26
- package/dist/collection/components/list-header/list-header.ios.css +2 -2
- package/dist/collection/components/list-header/list-header.js +2 -2
- package/dist/collection/components/list-header/list-header.md.css +1 -1
- package/dist/collection/components/loading/loading.ios.css +2 -2
- package/dist/collection/components/loading/loading.js +2 -2
- package/dist/collection/components/loading/loading.md.css +3 -3
- package/dist/collection/components/loading/test/a11y/loading.e2e.js +21 -5
- package/dist/collection/components/menu/menu.ios.css +72 -53
- package/dist/collection/components/menu/menu.js +25 -39
- package/dist/collection/components/menu/menu.md.css +72 -53
- package/dist/collection/components/menu-button/menu-button.ios.css +1 -1
- package/dist/collection/components/menu-button/menu-button.js +2 -2
- package/dist/collection/components/menu-button/test/a11y/menu-button.e2e.js +14 -0
- package/dist/collection/components/menu-toggle/menu-toggle.js +2 -2
- package/dist/collection/components/modal/gestures/swipe-to-close.js +1 -1
- package/dist/collection/components/modal/modal.ios.css +9 -38
- package/dist/collection/components/modal/modal.js +37 -5
- package/dist/collection/components/modal/modal.md.css +1 -1
- package/dist/collection/components/modal/test/modal-attributes.spec.js +32 -0
- package/dist/collection/components/modal/utils.js +2 -8
- package/dist/collection/components/nav/nav.js +23 -3
- package/dist/collection/components/nav/test/nav-controller.spec.js +36 -36
- package/dist/collection/components/nav-link/nav-link.js +1 -1
- package/dist/collection/components/note/note.ios.css +1 -1
- package/dist/collection/components/note/note.js +2 -2
- package/dist/collection/components/note/note.md.css +1 -1
- package/dist/collection/components/picker/picker.ios.css +97 -234
- package/dist/collection/components/picker/picker.js +488 -742
- package/dist/collection/components/picker/picker.md.css +98 -226
- package/dist/collection/components/{picker-internal/test/a11y/picker-internal.e2e.js → picker/test/a11y/picker.e2e.js} +2 -2
- package/dist/collection/components/picker/test/basic/picker.e2e.js +99 -13
- package/dist/collection/components/picker/test/custom/picker.e2e.js +85 -0
- package/dist/collection/components/{picker-internal/test/keyboard-entry/picker-internal.e2e.js → picker/test/keyboard-entry/picker.e2e.js} +79 -42
- package/dist/collection/components/{picker-column-internal/picker-column-internal.md.css → picker-column/picker-column.css} +96 -83
- package/dist/collection/components/picker-column/picker-column.js +514 -335
- package/dist/collection/components/{picker-column-internal/test/basic/picker-column-internal.e2e.js → picker-column/test/basic/picker-column.e2e.js} +8 -8
- package/dist/collection/components/picker-column/test/disabled/picker-column.e2e.js +91 -0
- package/dist/collection/components/picker-column/test/slots/picker-column.e2e.js +39 -0
- package/dist/collection/components/picker-column-option/picker-column-option.ios.css +87 -0
- package/dist/collection/components/picker-column-option/picker-column-option.js +173 -0
- package/dist/collection/components/{picker-column-internal/picker-column-internal.ios.css → picker-column-option/picker-column-option.md.css} +6 -53
- package/dist/collection/components/picker-column-option/test/a11y/picker-column-option.e2e.js +18 -0
- package/dist/collection/components/picker-column-option/test/basic/picker-column-option.e2e.js +37 -0
- package/dist/collection/components/picker-column-option/test/picker-column-option.spec.js +29 -0
- package/dist/collection/components/{picker-internal/picker-internal.ios.css → picker-legacy/picker.ios.css} +155 -117
- package/dist/collection/components/picker-legacy/picker.js +821 -0
- package/dist/collection/components/{picker-internal/picker-internal.md.css → picker-legacy/picker.md.css} +144 -115
- package/dist/collection/components/picker-legacy/test/basic/picker.e2e.js +25 -0
- package/dist/collection/components/{picker → picker-legacy}/test/is-open/picker.e2e.js +4 -4
- package/dist/collection/components/{picker → picker-legacy}/test/picker-id.spec.js +5 -5
- package/dist/collection/components/{picker → picker-legacy}/test/trigger/picker.e2e.js +1 -1
- package/dist/collection/components/{picker-column → picker-legacy-column}/picker-column.ios.css +2 -26
- package/dist/collection/components/picker-legacy-column/picker-column.js +419 -0
- package/dist/collection/components/{picker-column → picker-legacy-column}/picker-column.md.css +3 -27
- package/dist/collection/components/{picker-column → picker-legacy-column}/test/picker-column-aria.spec.js +3 -3
- package/dist/collection/components/{picker-column → picker-legacy-column}/test/picker-column-dynamic.spec.js +2 -2
- package/dist/collection/components/{picker-column → picker-legacy-column}/test/picker-column.spec.js +2 -2
- package/dist/collection/components/{picker-column → picker-legacy-column}/test/standalone/picker-column.e2e.js +3 -3
- package/dist/collection/components/popover/popover.ios.css +3 -27
- package/dist/collection/components/popover/popover.js +5 -4
- package/dist/collection/components/progress-bar/progress-bar.ios.css +17 -11
- package/dist/collection/components/progress-bar/progress-bar.js +4 -1
- package/dist/collection/components/progress-bar/progress-bar.md.css +8 -10
- package/dist/collection/components/progress-bar/test/a11y/progress-bar.e2e.js +24 -0
- package/dist/collection/components/radio/radio.ios.css +10 -101
- package/dist/collection/components/radio/radio.js +5 -119
- package/dist/collection/components/radio/radio.md.css +8 -105
- package/dist/collection/components/radio/test/a11y/radio.e2e.js +114 -81
- package/dist/collection/components/radio-group/radio-group.js +1 -1
- package/dist/collection/components/range/range.ios.css +12 -90
- package/dist/collection/components/range/range.js +30 -123
- package/dist/collection/components/range/range.md.css +22 -152
- package/dist/collection/components/range/test/a11y/range.e2e.js +20 -10
- package/dist/collection/components/range/test/range-events.e2e.js +1 -1
- package/dist/collection/components/range/test/range.spec.js +0 -12
- package/dist/collection/components/refresher/refresher.ios.css +4 -27
- package/dist/collection/components/refresher/refresher.js +1 -1
- package/dist/collection/components/refresher/refresher.md.css +7 -30
- package/dist/collection/components/refresher/test/a11y/refresher.e2e.js +26 -0
- package/dist/collection/components/refresher-content/refresher-content.js +1 -1
- package/dist/collection/components/reorder/reorder.js +1 -1
- package/dist/collection/components/reorder-group/reorder-group.js +1 -1
- package/dist/collection/components/ripple-effect/ripple-effect.js +1 -1
- package/dist/collection/components/router-link/router-link.css +1 -1
- package/dist/collection/components/router-link/router-link.js +2 -2
- package/dist/collection/components/router-link/test/a11y/router-link.e2e.js +23 -0
- package/dist/collection/components/router-outlet/router-outlet.js +1 -1
- package/dist/collection/components/row/row.js +1 -1
- package/dist/collection/components/searchbar/searchbar.ios.css +11 -59
- package/dist/collection/components/searchbar/searchbar.js +4 -4
- package/dist/collection/components/searchbar/searchbar.md.css +10 -82
- package/dist/collection/components/segment/segment.js +2 -2
- package/dist/collection/components/segment/test/a11y/segment.e2e.js +23 -0
- package/dist/collection/components/segment-button/segment-button.ios.css +3 -3
- package/dist/collection/components/segment-button/segment-button.js +3 -3
- package/dist/collection/components/segment-button/segment-button.md.css +2 -2
- package/dist/collection/components/select/select.ios.css +10 -81
- package/dist/collection/components/select/select.js +66 -175
- package/dist/collection/components/select/select.md.css +38 -169
- package/dist/collection/components/select/test/a11y/select.e2e.js +68 -4
- package/dist/collection/components/select-option/select-option.js +1 -1
- package/dist/collection/components/select-popover/select-popover.js +1 -1
- package/dist/collection/components/select-popover/select-popover.md.css +4 -4
- package/dist/collection/components/select-popover/test/a11y/select-popover.e2e.js +32 -0
- package/dist/collection/components/skeleton-text/skeleton-text.js +2 -2
- package/dist/collection/components/spinner/spinner.js +1 -1
- package/dist/collection/components/split-pane/split-pane.ios.css +3 -55
- package/dist/collection/components/split-pane/split-pane.js +48 -14
- package/dist/collection/components/split-pane/split-pane.md.css +3 -55
- package/dist/collection/components/split-pane/test/wrapped-menu/split-pane.e2e.js +41 -0
- package/dist/collection/components/tab/tab.js +2 -2
- package/dist/collection/components/tab-bar/tab-bar.ios.css +4 -4
- package/dist/collection/components/tab-bar/tab-bar.js +2 -2
- package/dist/collection/components/tab-bar/tab-bar.md.css +3 -3
- package/dist/collection/components/tab-button/tab-button.ios.css +16 -94
- package/dist/collection/components/tab-button/tab-button.js +2 -2
- package/dist/collection/components/tab-button/tab-button.md.css +10 -93
- package/dist/collection/components/tabs/tabs.js +1 -1
- package/dist/collection/components/text/text.js +2 -2
- package/dist/collection/components/textarea/test/a11y/textarea.e2e.js +41 -3
- package/dist/collection/components/textarea/test/item/textarea.e2e.js +21 -0
- package/dist/collection/components/textarea/textarea.ios.css +13 -103
- package/dist/collection/components/textarea/textarea.js +5 -84
- package/dist/collection/components/textarea/textarea.md.css +37 -226
- package/dist/collection/components/thumbnail/thumbnail.js +1 -1
- package/dist/collection/components/title/title.ios.css +2 -21
- package/dist/collection/components/title/title.js +2 -2
- package/dist/collection/components/toast/test/a11y/toast.e2e.js +89 -24
- package/dist/collection/components/toast/toast.ios.css +8 -55
- package/dist/collection/components/toast/toast.js +9 -3
- package/dist/collection/components/toast/toast.md.css +10 -57
- package/dist/collection/components/toggle/test/a11y/toggle.e2e.js +8 -2
- package/dist/collection/components/toggle/toggle.ios.css +11 -90
- package/dist/collection/components/toggle/toggle.js +5 -101
- package/dist/collection/components/toggle/toggle.md.css +6 -91
- package/dist/collection/components/toolbar/toolbar.ios.css +2 -2
- package/dist/collection/components/toolbar/toolbar.js +2 -2
- package/dist/collection/components/toolbar/toolbar.md.css +1 -1
- package/dist/collection/css/test/a11y/typography.e2e.js +18 -0
- package/dist/collection/themes/test/colors/theme.e2e.js +170 -0
- package/dist/collection/utils/focus-trap.js +78 -0
- package/dist/collection/utils/gesture/button-active.js +1 -1
- package/dist/collection/utils/gesture/gesture-controller.js +1 -1
- package/dist/collection/utils/helpers.js +1 -1
- package/dist/collection/utils/input-shims/input-shims.js +8 -1
- package/dist/collection/utils/native/status-bar.js +0 -11
- package/dist/collection/utils/overlays.js +63 -41
- package/dist/collection/utils/test/aria.spec.js +2 -1
- package/dist/collection/utils/test/overlays/overlays-scroll-blocking.spec.js +65 -0
- package/dist/collection/utils/test/overlays/overlays.e2e.js +89 -0
- package/dist/collection/utils/test/playwright/generator.js +1 -0
- package/dist/collection/utils/test/playwright/page/utils/set-content.js +1 -1
- package/dist/docs.json +569 -331
- package/dist/esm/{animation-60dbdd13.js → animation-a4acf150.js} +1 -1
- package/dist/esm/{app-globals-5cf6195b.js → app-globals-cfb6787b.js} +1 -1
- package/dist/esm/{button-active-47ac8092.js → button-active-454e5c57.js} +3 -3
- package/dist/esm/{data-0f3ab200.js → data-691286f1.js} +1 -1
- package/dist/esm/{framework-delegate-fed7fe7c.js → framework-delegate-1eb3236c.js} +1 -1
- package/dist/esm/{gesture-controller-1bf57181.js → gesture-controller-314a54f6.js} +1 -1
- package/dist/esm/{hardware-back-button-b410a047.js → hardware-back-button-3a14f99e.js} +2 -2
- package/dist/esm/{helpers-c0b9ca37.js → helpers-ae74b3c9.js} +2 -2
- package/dist/esm/{index-47b2066d.js → index-03086279.js} +4 -4
- package/dist/esm/{index-d64f34ea.js → index-1f563746.js} +1 -1
- package/dist/esm/{index-2cf77112.js → index-39782642.js} +2 -2
- package/dist/esm/{index-0b4beb69.js → index-5847f4a9.js} +4 -4
- package/dist/esm/{index-eb12ef92.js → index-66871a1d.js} +1 -1
- package/dist/esm/{index-4c30cddd.js → index-9b6d6df3.js} +2 -2
- package/dist/esm/index.js +13 -13
- package/dist/esm/{input-shims-b90ca55f.js → input-shims-56c1f603.js} +10 -3
- package/dist/esm/{input.utils-6e9b0046.js → input.utils-482fc893.js} +1 -1
- package/dist/esm/ion-accordion_2.entry.js +4 -4
- package/dist/esm/ion-action-sheet.entry.js +14 -14
- package/dist/esm/ion-alert.entry.js +12 -12
- package/dist/esm/ion-app_8.entry.js +28 -29
- package/dist/esm/ion-avatar_3.entry.js +5 -5
- package/dist/esm/ion-back-button.entry.js +4 -4
- package/dist/esm/ion-backdrop.entry.js +3 -15
- package/dist/esm/ion-breadcrumb_2.entry.js +5 -5
- package/dist/esm/ion-button_2.entry.js +5 -5
- package/dist/esm/ion-card_5.entry.js +8 -8
- package/dist/esm/ion-checkbox.entry.js +9 -77
- package/dist/esm/ion-chip.entry.js +4 -4
- package/dist/esm/ion-col_3.entry.js +7 -7
- package/dist/esm/ion-datetime-button.entry.js +9 -9
- package/dist/esm/ion-datetime_3.entry.js +55 -109
- package/dist/esm/ion-fab_3.entry.js +12 -12
- package/dist/esm/ion-img.entry.js +4 -4
- package/dist/esm/ion-infinite-scroll_2.entry.js +9 -9
- package/dist/esm/ion-input.entry.js +12 -92
- package/dist/esm/ion-item-option_3.entry.js +13 -13
- package/dist/esm/ion-item_8.entry.js +45 -30
- package/dist/esm/ion-loading.entry.js +12 -11
- package/dist/esm/ion-menu_3.entry.js +41 -57
- package/dist/esm/ion-modal.entry.js +53 -38
- package/dist/esm/ion-nav_2.entry.js +13 -10
- package/dist/esm/ion-picker-column-option.entry.js +102 -0
- package/dist/esm/{ion-picker-column-internal.entry.js → ion-picker-column.entry.js} +124 -93
- package/dist/esm/{ion-picker-internal.entry.js → ion-picker.entry.js} +32 -25
- package/dist/esm/ion-popover.entry.js +13 -12
- package/dist/esm/ion-progress-bar.entry.js +9 -6
- package/dist/esm/ion-radio_2.entry.js +10 -79
- package/dist/esm/ion-range.entry.js +38 -91
- package/dist/esm/ion-refresher_2.entry.js +12 -12
- package/dist/esm/ion-reorder_2.entry.js +7 -7
- package/dist/esm/ion-ripple-effect.entry.js +3 -3
- package/dist/esm/ion-route_4.entry.js +6 -6
- package/dist/esm/ion-searchbar.entry.js +9 -9
- package/dist/esm/ion-segment_2.entry.js +11 -11
- package/dist/esm/ion-select_3.entry.js +78 -169
- package/dist/esm/ion-spinner.entry.js +3 -3
- package/dist/esm/ion-split-pane.entry.js +28 -18
- package/dist/esm/ion-tab-bar_2.entry.js +11 -11
- package/dist/esm/ion-tab_2.entry.js +6 -6
- package/dist/esm/ion-text.entry.js +4 -4
- package/dist/esm/ion-textarea.entry.js +12 -72
- package/dist/esm/ion-toast.entry.js +21 -15
- package/dist/esm/ion-toggle.entry.js +10 -66
- package/dist/esm/{ionic-global-ad9a1810.js → ionic-global-c976d684.js} +1 -1
- package/dist/esm/ionic.js +6 -6
- package/dist/esm/{ios.transition-b76c7020.js → ios.transition-a097dbf5.js} +4 -4
- package/dist/esm/loader.js +5 -5
- package/dist/esm/{md.transition-564937a7.js → md.transition-b4170ef7.js} +4 -4
- package/dist/esm/{notch-controller-15d281a4.js → notch-controller-18bf9f76.js} +1 -1
- package/dist/esm/{overlays-04a9a43f.js → overlays-4ba3b255.js} +141 -45
- package/dist/esm/{status-tap-5a95077d.js → status-tap-7a12f017.js} +3 -3
- package/dist/esm/{swipe-back-fa0ec5cd.js → swipe-back-ae14449a.js} +3 -3
- package/dist/esm-es5/{animation-60dbdd13.js → animation-a4acf150.js} +1 -1
- package/dist/esm-es5/app-globals-cfb6787b.js +4 -0
- package/dist/esm-es5/button-active-454e5c57.js +4 -0
- package/dist/esm-es5/{framework-delegate-fed7fe7c.js → framework-delegate-1eb3236c.js} +1 -1
- package/dist/esm-es5/{gesture-controller-1bf57181.js → gesture-controller-314a54f6.js} +1 -1
- package/dist/esm-es5/{hardware-back-button-b410a047.js → hardware-back-button-3a14f99e.js} +1 -1
- package/dist/esm-es5/helpers-ae74b3c9.js +4 -0
- package/dist/esm-es5/{index-47b2066d.js → index-03086279.js} +1 -1
- package/dist/esm-es5/index-1f563746.js +4 -0
- package/dist/esm-es5/{index-2cf77112.js → index-39782642.js} +1 -1
- package/dist/esm-es5/{index-0b4beb69.js → index-5847f4a9.js} +1 -1
- package/dist/esm-es5/{index-eb12ef92.js → index-66871a1d.js} +1 -1
- package/dist/esm-es5/{index-4c30cddd.js → index-9b6d6df3.js} +1 -1
- package/dist/esm-es5/index.js +1 -1
- package/dist/esm-es5/{input-shims-b90ca55f.js → input-shims-56c1f603.js} +1 -1
- package/dist/esm-es5/{input.utils-6e9b0046.js → input.utils-482fc893.js} +1 -1
- package/dist/esm-es5/ion-accordion_2.entry.js +1 -1
- package/dist/esm-es5/ion-action-sheet.entry.js +1 -1
- package/dist/esm-es5/ion-alert.entry.js +1 -1
- package/dist/esm-es5/ion-app_8.entry.js +1 -1
- package/dist/esm-es5/ion-avatar_3.entry.js +1 -1
- package/dist/esm-es5/ion-back-button.entry.js +1 -1
- package/dist/esm-es5/ion-backdrop.entry.js +1 -1
- package/dist/esm-es5/ion-breadcrumb_2.entry.js +1 -1
- package/dist/esm-es5/ion-button_2.entry.js +1 -1
- package/dist/esm-es5/ion-card_5.entry.js +1 -1
- package/dist/esm-es5/ion-checkbox.entry.js +1 -1
- package/dist/esm-es5/ion-chip.entry.js +1 -1
- package/dist/esm-es5/ion-col_3.entry.js +1 -1
- package/dist/esm-es5/ion-datetime-button.entry.js +1 -1
- package/dist/esm-es5/ion-datetime_3.entry.js +1 -1
- package/dist/esm-es5/ion-fab_3.entry.js +1 -1
- package/dist/esm-es5/ion-img.entry.js +1 -1
- package/dist/esm-es5/ion-infinite-scroll_2.entry.js +1 -1
- package/dist/esm-es5/ion-input.entry.js +1 -1
- package/dist/esm-es5/ion-item-option_3.entry.js +1 -1
- package/dist/esm-es5/ion-item_8.entry.js +1 -1
- package/dist/esm-es5/ion-loading.entry.js +1 -1
- package/dist/esm-es5/ion-menu_3.entry.js +1 -1
- package/dist/esm-es5/ion-modal.entry.js +1 -1
- package/dist/esm-es5/ion-nav_2.entry.js +1 -1
- package/dist/esm-es5/ion-picker-column-option.entry.js +4 -0
- package/dist/esm-es5/ion-picker-column.entry.js +4 -0
- package/dist/esm-es5/ion-picker.entry.js +4 -0
- package/dist/esm-es5/ion-popover.entry.js +1 -1
- package/dist/esm-es5/ion-progress-bar.entry.js +1 -1
- package/dist/esm-es5/ion-radio_2.entry.js +1 -1
- package/dist/esm-es5/ion-range.entry.js +1 -1
- package/dist/esm-es5/ion-refresher_2.entry.js +1 -1
- package/dist/esm-es5/ion-reorder_2.entry.js +1 -1
- package/dist/esm-es5/ion-ripple-effect.entry.js +1 -1
- package/dist/esm-es5/ion-route_4.entry.js +1 -1
- package/dist/esm-es5/ion-searchbar.entry.js +1 -1
- package/dist/esm-es5/ion-segment_2.entry.js +1 -1
- package/dist/esm-es5/ion-select_3.entry.js +1 -1
- package/dist/esm-es5/ion-spinner.entry.js +1 -1
- package/dist/esm-es5/ion-split-pane.entry.js +1 -1
- package/dist/esm-es5/ion-tab-bar_2.entry.js +1 -1
- package/dist/esm-es5/ion-tab_2.entry.js +1 -1
- package/dist/esm-es5/ion-text.entry.js +1 -1
- package/dist/esm-es5/ion-textarea.entry.js +1 -1
- package/dist/esm-es5/ion-toast.entry.js +1 -1
- package/dist/esm-es5/ion-toggle.entry.js +1 -1
- package/dist/esm-es5/{ionic-global-ad9a1810.js → ionic-global-c976d684.js} +1 -1
- package/dist/esm-es5/ionic.js +1 -1
- package/dist/esm-es5/{ios.transition-b76c7020.js → ios.transition-a097dbf5.js} +1 -1
- package/dist/esm-es5/loader.js +1 -1
- package/dist/esm-es5/md.transition-b4170ef7.js +4 -0
- package/dist/esm-es5/{notch-controller-15d281a4.js → notch-controller-18bf9f76.js} +1 -1
- package/dist/esm-es5/overlays-4ba3b255.js +4 -0
- package/dist/esm-es5/{status-tap-5a95077d.js → status-tap-7a12f017.js} +1 -1
- package/dist/esm-es5/{swipe-back-fa0ec5cd.js → swipe-back-ae14449a.js} +1 -1
- package/dist/html.html-data.json +152 -37
- package/dist/ionic/index.esm.js +1 -1
- package/dist/ionic/ionic.esm.js +1 -1
- package/dist/ionic/ionic.js +1 -1
- package/dist/ionic/p-03f63663.system.js +4 -0
- package/dist/ionic/p-060fdc03.entry.js +4 -0
- package/dist/ionic/{p-b8c685a7.system.js → p-069388dd.system.js} +1 -1
- package/dist/ionic/p-06fccad7.entry.js +4 -0
- package/dist/ionic/p-09872ec8.system.entry.js +4 -0
- package/dist/ionic/p-0ca35c1d.system.entry.js +4 -0
- package/dist/ionic/p-134d4936.system.js +4 -0
- package/dist/ionic/{p-a3f572a7.js → p-15708968.js} +1 -1
- package/dist/ionic/p-1600d68c.system.entry.js +4 -0
- package/dist/ionic/p-19e79fe8.entry.js +4 -0
- package/dist/ionic/{p-61ba2137.system.js → p-19f6ac6c.system.js} +1 -1
- package/dist/ionic/{p-70e34286.system.entry.js → p-1a5ed3fe.system.entry.js} +1 -1
- package/dist/ionic/p-1a68de09.entry.js +4 -0
- package/dist/ionic/p-1bca443b.system.entry.js +4 -0
- package/dist/ionic/p-1c436e95.system.entry.js +4 -0
- package/dist/ionic/{p-657ccdd6.entry.js → p-1ce172db.entry.js} +1 -1
- package/dist/ionic/p-1e0a18a1.system.entry.js +4 -0
- package/dist/ionic/{p-c80c7e90.system.js → p-1ea88de9.system.js} +1 -1
- package/dist/ionic/p-1ed99eba.system.entry.js +4 -0
- package/dist/ionic/{p-de55ec45.js → p-1fa738c4.js} +1 -1
- package/dist/ionic/{p-c7c8429a.system.js → p-20d469d0.system.js} +1 -1
- package/dist/ionic/p-22d2a891.js +4 -0
- package/dist/ionic/p-239262e4.system.entry.js +4 -0
- package/dist/ionic/p-25850474.entry.js +4 -0
- package/dist/ionic/{p-ceceac26.js → p-27594fc2.js} +1 -1
- package/dist/ionic/{p-f0194418.system.entry.js → p-2b3e0d99.system.entry.js} +1 -1
- package/dist/ionic/p-300b2cf1.entry.js +4 -0
- package/dist/ionic/{p-6525a8cd.system.js → p-30892e0c.system.js} +1 -1
- package/dist/ionic/p-32bd7ed7.entry.js +4 -0
- package/dist/ionic/{p-74deb358.system.js → p-3410a9cb.system.js} +1 -1
- package/dist/ionic/{p-717e2526.system.entry.js → p-3bac30bf.system.entry.js} +2 -2
- package/dist/ionic/{p-31b2326e.system.js → p-3e1e14d9.system.js} +1 -1
- package/dist/ionic/p-41970e75.entry.js +4 -0
- package/dist/ionic/p-43322b14.js +4 -0
- package/dist/ionic/p-4523be60.entry.js +4 -0
- package/dist/ionic/p-454b36f7.system.entry.js +4 -0
- package/dist/ionic/p-466bdeae.entry.js +4 -0
- package/dist/ionic/p-4825e380.entry.js +4 -0
- package/dist/ionic/{p-6871553b.system.js → p-4a8f173c.system.js} +1 -1
- package/dist/ionic/p-4ad02639.entry.js +4 -0
- package/dist/ionic/p-4c2cac66.entry.js +4 -0
- package/dist/ionic/{p-eb07b88f.entry.js → p-5a055df4.entry.js} +1 -1
- package/dist/ionic/{p-5d7e32ce.js → p-5aa60929.js} +1 -1
- package/dist/ionic/p-5afb6e48.entry.js +4 -0
- package/dist/ionic/p-5c3991e3.system.entry.js +4 -0
- package/dist/ionic/p-602494c6.entry.js +4 -0
- package/dist/ionic/{p-ed7a529f.js → p-60efe117.js} +1 -1
- package/dist/ionic/p-62f15daf.system.entry.js +4 -0
- package/dist/ionic/{p-30cd5e7b.js → p-65d3f0e9.js} +1 -1
- package/dist/ionic/p-6657681b.system.entry.js +4 -0
- package/dist/ionic/p-6d95943d.system.js +4 -0
- package/dist/ionic/p-6e1fa025.js +4 -0
- package/dist/ionic/{p-c11bab7e.entry.js → p-6e5eeb35.entry.js} +1 -1
- package/dist/ionic/p-6ef5f4da.entry.js +4 -0
- package/dist/ionic/{p-c308f773.entry.js → p-6f6d56f1.entry.js} +1 -1
- package/dist/ionic/{p-123b4809.js → p-6fd26009.js} +1 -1
- package/dist/ionic/p-70218e28.system.entry.js +4 -0
- package/dist/ionic/p-72bc2484.system.entry.js +4 -0
- package/dist/ionic/p-7541ca9f.system.entry.js +4 -0
- package/dist/ionic/{p-31c495c2.js → p-760dbd5e.js} +1 -1
- package/dist/ionic/p-7665bbbc.system.entry.js +4 -0
- package/dist/ionic/{p-5c580e89.entry.js → p-77982637.entry.js} +1 -1
- package/dist/ionic/{p-64856c3c.system.entry.js → p-780ff3b5.system.entry.js} +1 -1
- package/dist/ionic/p-7a3fa32c.entry.js +4 -0
- package/dist/ionic/{p-88e9052d.entry.js → p-7b44b443.entry.js} +1 -1
- package/dist/ionic/p-7b795aee.system.entry.js +4 -0
- package/dist/ionic/p-7cc01684.js +4 -0
- package/dist/ionic/{p-3c6f02cf.system.js → p-816476b0.system.js} +1 -1
- package/dist/ionic/p-81869a97.system.entry.js +4 -0
- package/dist/ionic/p-82d459c1.js +4 -0
- package/dist/ionic/{p-a85d9047.system.entry.js → p-82f5375e.system.entry.js} +1 -1
- package/dist/ionic/p-842777af.js +4 -0
- package/dist/ionic/p-85464e28.system.entry.js +4 -0
- package/dist/ionic/{p-95d5a097.entry.js → p-85cb4733.entry.js} +1 -1
- package/dist/ionic/{p-8794fa00.system.entry.js → p-874510e9.system.entry.js} +1 -1
- package/dist/ionic/{p-37c33319.system.js → p-8a50f8d6.system.js} +1 -1
- package/dist/ionic/{p-b5839dc2.js → p-8ab308e9.js} +1 -1
- package/dist/ionic/{p-3481d54e.system.entry.js → p-8aeed464.system.entry.js} +1 -1
- package/dist/ionic/p-8ba5912c.entry.js +4 -0
- package/dist/ionic/{p-94be3ad7.js → p-8d4d902b.js} +1 -1
- package/dist/ionic/p-8d50220b.system.js +4 -0
- package/dist/ionic/{p-72fa96bf.system.js → p-8d602214.system.js} +1 -1
- package/dist/ionic/p-8e3ee444.system.entry.js +4 -0
- package/dist/ionic/{p-7173ba59.system.entry.js → p-8e83b7f1.system.entry.js} +2 -2
- package/dist/ionic/{p-f5d2dc9b.js → p-8ededb41.js} +1 -1
- package/dist/ionic/p-91a72ad6.system.entry.js +4 -0
- package/dist/ionic/p-9382ebab.entry.js +4 -0
- package/dist/ionic/p-942c19cb.entry.js +4 -0
- package/dist/ionic/{p-a5951821.system.js → p-95e14c7b.system.js} +1 -1
- package/dist/ionic/p-96391c0e.entry.js +4 -0
- package/dist/ionic/{p-275705e5.entry.js → p-97135baa.entry.js} +1 -1
- package/dist/ionic/{p-bb3615f7.js → p-9b97df10.js} +1 -1
- package/dist/ionic/{p-c2289cd1.js → p-9d6f351e.js} +1 -1
- package/dist/ionic/{p-fd8ced99.system.js → p-9e3b3f15.system.js} +1 -1
- package/dist/ionic/{p-9ec7208d.system.js → p-a06af32c.system.js} +1 -1
- package/dist/ionic/p-a375c9f6.system.entry.js +4 -0
- package/dist/ionic/p-a58ec401.js +4 -0
- package/dist/ionic/p-a5b7a286.entry.js +4 -0
- package/dist/ionic/{p-9393a49f.js → p-a6cc38d4.js} +1 -1
- package/dist/ionic/{p-2e14c533.system.js → p-a71dc777.system.js} +1 -1
- package/dist/ionic/{p-d4cadd34.system.js → p-a8cc0027.system.js} +1 -1
- package/dist/ionic/{p-afd6d696.system.entry.js → p-aaca8dd4.system.entry.js} +1 -1
- package/dist/ionic/p-ad2b216a.system.entry.js +4 -0
- package/dist/ionic/p-add93c7a.entry.js +4 -0
- package/dist/ionic/{p-3079950e.entry.js → p-afcd4f49.entry.js} +1 -1
- package/dist/ionic/p-b1a9e85a.system.entry.js +4 -0
- package/dist/ionic/p-b4bb9cd0.system.entry.js +4 -0
- package/dist/ionic/p-baa409f1.system.entry.js +4 -0
- package/dist/ionic/p-bcb58446.entry.js +4 -0
- package/dist/ionic/p-c2336a9e.system.entry.js +4 -0
- package/dist/ionic/p-c38c5dfc.system.js +4 -0
- package/dist/ionic/{p-337ac0f5.entry.js → p-c3a2e5cc.entry.js} +1 -1
- package/dist/ionic/{p-a3df16b9.system.entry.js → p-c5b77291.system.entry.js} +1 -1
- package/dist/ionic/{p-b253ad7f.js → p-c880c809.js} +1 -1
- package/dist/ionic/{p-c747f89b.system.entry.js → p-cb0e4100.system.entry.js} +2 -2
- package/dist/ionic/{p-e2bb92ed.system.js → p-cb944b1a.system.js} +1 -1
- package/dist/ionic/p-cbc3840e.entry.js +4 -0
- package/dist/ionic/p-cd366840.system.entry.js +4 -0
- package/dist/ionic/p-cf852615.system.entry.js +4 -0
- package/dist/ionic/{p-ea25b4c8.system.entry.js → p-d4d0538c.system.entry.js} +1 -1
- package/dist/ionic/{p-027f3674.entry.js → p-d504bc71.entry.js} +1 -1
- package/dist/ionic/{p-86813176.system.entry.js → p-da83d833.system.entry.js} +1 -1
- package/dist/ionic/p-dcfc297d.system.entry.js +4 -0
- package/dist/ionic/p-ddc4e717.entry.js +4 -0
- package/dist/ionic/p-ded27993.entry.js +4 -0
- package/dist/ionic/p-e15eda82.system.js +4 -0
- package/dist/ionic/{p-43a5edee.entry.js → p-e38b3c29.entry.js} +1 -1
- package/dist/ionic/p-e470466e.entry.js +4 -0
- package/dist/ionic/p-e64277c4.entry.js +4 -0
- package/dist/ionic/{p-abcedc15.system.entry.js → p-ebe0be94.system.entry.js} +1 -1
- package/dist/ionic/{p-89ca4c4b.system.js → p-eec92f77.system.js} +1 -1
- package/dist/ionic/{p-23c73017.entry.js → p-ef99a759.entry.js} +1 -1
- package/dist/ionic/{p-601e17b4.entry.js → p-f16bfd53.entry.js} +1 -1
- package/dist/ionic/{p-b6279412.entry.js → p-f3d6085c.entry.js} +1 -1
- package/dist/ionic/p-f6a6b7ef.system.entry.js +4 -0
- package/dist/ionic/p-f71082f7.entry.js +4 -0
- package/dist/ionic/p-f7ed6a44.system.entry.js +4 -0
- package/dist/ionic/p-fc5ddbf6.entry.js +4 -0
- package/dist/ionic/p-fd94dd20.system.entry.js +4 -0
- package/dist/ionic/p-feb66f6f.entry.js +4 -0
- package/dist/types/components/action-sheet/action-sheet-interface.d.ts +8 -0
- package/dist/types/components/backdrop/backdrop.d.ts +0 -3
- package/dist/types/components/checkbox/checkbox.d.ts +1 -24
- package/dist/types/components/datetime/datetime.d.ts +0 -1
- package/dist/types/components/datetime/utils/data.d.ts +11 -7
- package/dist/types/components/input/input.d.ts +0 -26
- package/dist/types/components/menu/menu.d.ts +12 -4
- package/dist/types/components/modal/utils.d.ts +0 -4
- package/dist/types/components/nav/nav.d.ts +4 -1
- package/dist/types/components/picker/picker-interfaces.d.ts +8 -0
- package/dist/types/components/picker/picker.d.ts +75 -133
- package/dist/types/components/picker-column/picker-column-interfaces.d.ts +4 -0
- package/dist/types/components/picker-column/picker-column.d.ts +99 -39
- package/dist/types/components/picker-column-option/picker-column-option.d.ts +66 -0
- package/dist/types/components/picker-legacy/picker.d.ts +158 -0
- package/dist/types/components/picker-legacy-column/picker-column.d.ts +46 -0
- package/dist/types/components/radio/radio.d.ts +1 -24
- package/dist/types/components/range/range.d.ts +1 -21
- package/dist/types/components/select/select.d.ts +0 -15
- package/dist/types/components/split-pane/split-pane.d.ts +14 -2
- package/dist/types/components/textarea/textarea.d.ts +0 -17
- package/dist/types/components/toast/toast-interface.d.ts +0 -4
- package/dist/types/components/toggle/toggle.d.ts +1 -21
- package/dist/types/components.d.ts +160 -195
- package/dist/types/interface.d.ts +1 -1
- package/dist/types/utils/config.d.ts +2 -2
- package/dist/types/utils/focus-trap.d.ts +35 -0
- package/dist/types/utils/gesture/gesture-controller.d.ts +1 -0
- package/dist/types/utils/helpers.d.ts +1 -1
- package/dist/types/utils/native/status-bar.d.ts +0 -1
- package/dist/types/utils/overlays.d.ts +5 -3
- package/dist/types/utils/test/playwright/generator.d.ts +3 -1
- package/hydrate/index.js +2095 -2398
- package/package.json +1 -2
- package/components/form-controller.js +0 -64
- package/components/ion-picker-column-internal.d.ts +0 -11
- package/components/ion-picker-column-internal.js +0 -9
- package/components/ion-picker-internal.js +0 -9
- package/components/picker-column-internal.js +0 -392
- package/dist/cjs/form-controller-7b90d7b7.js +0 -66
- package/dist/collection/components/checkbox/test/legacy/basic/checkbox.e2e.js +0 -68
- package/dist/collection/components/checkbox/test/legacy/indeterminate/checkbox.e2e.js +0 -14
- package/dist/collection/components/input/test/item/input.spec.js +0 -24
- package/dist/collection/components/input/test/legacy/a11y/input.e2e.js +0 -28
- package/dist/collection/components/input/test/legacy/basic/input.e2e.js +0 -181
- package/dist/collection/components/input/test/legacy/clear-on-edit/input.e2e.js +0 -55
- package/dist/collection/components/input/test/legacy/input-events.e2e.js +0 -71
- package/dist/collection/components/input/test/legacy/masking/input.e2e.js +0 -26
- package/dist/collection/components/input/test/legacy/spec/input.e2e.js +0 -16
- package/dist/collection/components/item/test/counter/item.e2e.js +0 -49
- package/dist/collection/components/item/test/highlight/item.e2e.js +0 -14
- package/dist/collection/components/item/test/legacy/alignment/item.e2e.js +0 -14
- package/dist/collection/components/item/test/legacy/fill/item.e2e.js +0 -14
- package/dist/collection/components/item/test/legacy/form/item.e2e.js +0 -14
- package/dist/collection/components/modal/test/a11y/modal.spec.js +0 -22
- package/dist/collection/components/picker-column-internal/picker-column-internal.js +0 -566
- package/dist/collection/components/picker-column-internal/test/disabled/picker-column-internal.e2e.js +0 -162
- package/dist/collection/components/picker-internal/picker-internal.js +0 -560
- package/dist/collection/components/picker-internal/test/basic/picker-internal.e2e.js +0 -118
- package/dist/collection/components/radio/test/legacy/a11y/radio.e2e.js +0 -53
- package/dist/collection/components/radio/test/legacy/basic/radio.e2e.js +0 -127
- package/dist/collection/components/radio-group/test/legacy/basic/radio-group.e2e.js +0 -122
- package/dist/collection/components/radio-group/test/legacy/form/radio-group.e2e.js +0 -30
- package/dist/collection/components/radio-group/test/legacy/search/radio-group.e2e.js +0 -38
- package/dist/collection/components/range/test/legacy/a11y/range.e2e.js +0 -49
- package/dist/collection/components/range/test/legacy/active-bar-start/range.e2e.js +0 -14
- package/dist/collection/components/range/test/legacy/basic/range.e2e.js +0 -75
- package/dist/collection/components/range/test/legacy/range-events.e2e.js +0 -90
- package/dist/collection/components/range/test/legacy/scroll-target/range.e2e.js +0 -32
- package/dist/collection/components/select/test/legacy/async/select.e2e.js +0 -19
- package/dist/collection/components/select/test/legacy/basic/select.e2e.js +0 -145
- package/dist/collection/components/select/test/legacy/compare-with/select.e2e.js +0 -67
- package/dist/collection/components/select/test/legacy/custom/custom.e2e.js +0 -13
- package/dist/collection/components/select/test/legacy/single-value/select.e2e.js +0 -16
- package/dist/collection/components/select/test/legacy/spec/select.e2e.js +0 -14
- package/dist/collection/components/select/test/legacy/standalone/select.e2e.js +0 -18
- package/dist/collection/components/select/test/legacy/wrapping/select.e2e.js +0 -39
- package/dist/collection/components/textarea/test/legacy/a11y/textarea.e2e.js +0 -31
- package/dist/collection/components/textarea/test/legacy/autogrow/textarea.e2e.js +0 -58
- package/dist/collection/components/textarea/test/legacy/basic/textarea.e2e.js +0 -43
- package/dist/collection/components/textarea/test/legacy/clear-on-edit/textarea.e2e.js +0 -25
- package/dist/collection/components/toggle/test/legacy/basic/toggle.e2e.js +0 -83
- package/dist/collection/components/toggle/test/legacy/enable-on-off-labels/toggle.e2e.js +0 -37
- package/dist/collection/components/toggle/test/legacy/sizes/power-outline.svg +0 -1
- package/dist/collection/components/toggle/test/legacy/sizes/toggle.e2e.js +0 -14
- package/dist/esm/form-controller-014aa89f.js +0 -64
- package/dist/esm-es5/app-globals-5cf6195b.js +0 -4
- package/dist/esm-es5/button-active-47ac8092.js +0 -4
- package/dist/esm-es5/form-controller-014aa89f.js +0 -4
- package/dist/esm-es5/helpers-c0b9ca37.js +0 -4
- package/dist/esm-es5/index-d64f34ea.js +0 -4
- package/dist/esm-es5/ion-picker-column-internal.entry.js +0 -4
- package/dist/esm-es5/ion-picker-internal.entry.js +0 -4
- package/dist/esm-es5/md.transition-564937a7.js +0 -4
- package/dist/esm-es5/overlays-04a9a43f.js +0 -4
- package/dist/ionic/p-0457213c.entry.js +0 -4
- package/dist/ionic/p-05d560ec.entry.js +0 -4
- package/dist/ionic/p-0b34d3a7.system.js +0 -4
- package/dist/ionic/p-0e23c289.system.entry.js +0 -4
- package/dist/ionic/p-1131946f.system.entry.js +0 -4
- package/dist/ionic/p-1636923f.system.js +0 -4
- package/dist/ionic/p-16a61810.entry.js +0 -4
- package/dist/ionic/p-18beebdf.system.entry.js +0 -4
- package/dist/ionic/p-1924f2e0.system.entry.js +0 -4
- package/dist/ionic/p-1f16d040.entry.js +0 -4
- package/dist/ionic/p-1f19958f.system.entry.js +0 -4
- package/dist/ionic/p-21ca1f1c.js +0 -4
- package/dist/ionic/p-2327064c.entry.js +0 -4
- package/dist/ionic/p-2e1f014a.system.entry.js +0 -4
- package/dist/ionic/p-30d77a91.system.js +0 -4
- package/dist/ionic/p-3471a7c0.system.entry.js +0 -4
- package/dist/ionic/p-396083cc.entry.js +0 -4
- package/dist/ionic/p-3a7de59c.entry.js +0 -4
- package/dist/ionic/p-3d961d93.entry.js +0 -4
- package/dist/ionic/p-3e9ad72a.system.entry.js +0 -4
- package/dist/ionic/p-42a9f663.system.entry.js +0 -4
- package/dist/ionic/p-49543c9c.system.js +0 -4
- package/dist/ionic/p-49aba878.js +0 -4
- package/dist/ionic/p-4f777b5e.js +0 -4
- package/dist/ionic/p-4fda5c35.entry.js +0 -4
- package/dist/ionic/p-502780e4.entry.js +0 -4
- package/dist/ionic/p-508a4c87.entry.js +0 -4
- package/dist/ionic/p-5928fac9.system.entry.js +0 -4
- package/dist/ionic/p-5b40d967.entry.js +0 -4
- package/dist/ionic/p-5c2ae448.js +0 -4
- package/dist/ionic/p-5c6a04bd.entry.js +0 -4
- package/dist/ionic/p-5cb5f63d.system.entry.js +0 -4
- package/dist/ionic/p-5e23bea8.system.entry.js +0 -4
- package/dist/ionic/p-5f169eba.entry.js +0 -4
- package/dist/ionic/p-64761c90.entry.js +0 -4
- package/dist/ionic/p-6486e393.system.entry.js +0 -4
- package/dist/ionic/p-64db1331.entry.js +0 -4
- package/dist/ionic/p-667e3e2d.entry.js +0 -4
- package/dist/ionic/p-68ba8e77.system.entry.js +0 -4
- package/dist/ionic/p-7b1ed642.system.entry.js +0 -4
- package/dist/ionic/p-7ce40e7b.entry.js +0 -4
- package/dist/ionic/p-8e651c29.entry.js +0 -4
- package/dist/ionic/p-9056778e.system.entry.js +0 -4
- package/dist/ionic/p-91cb3f9a.entry.js +0 -4
- package/dist/ionic/p-9cd7ba27.system.js +0 -4
- package/dist/ionic/p-a022b684.system.entry.js +0 -4
- package/dist/ionic/p-a0b28c69.system.entry.js +0 -4
- package/dist/ionic/p-a6e465f5.entry.js +0 -4
- package/dist/ionic/p-a8a56449.entry.js +0 -4
- package/dist/ionic/p-aaaa615c.system.entry.js +0 -4
- package/dist/ionic/p-ae35294f.system.entry.js +0 -4
- package/dist/ionic/p-b0ff8075.entry.js +0 -4
- package/dist/ionic/p-b2595011.system.entry.js +0 -4
- package/dist/ionic/p-ba97a133.system.entry.js +0 -4
- package/dist/ionic/p-bd4787eb.entry.js +0 -4
- package/dist/ionic/p-bdca4784.js +0 -4
- package/dist/ionic/p-bf05cbc7.entry.js +0 -4
- package/dist/ionic/p-c1797ec5.system.entry.js +0 -4
- package/dist/ionic/p-c39cc96d.system.entry.js +0 -4
- package/dist/ionic/p-c858f685.js +0 -4
- package/dist/ionic/p-cb9e71e0.entry.js +0 -4
- package/dist/ionic/p-cd9a7017.system.entry.js +0 -4
- package/dist/ionic/p-cde3ac34.system.entry.js +0 -4
- package/dist/ionic/p-d39ab63d.entry.js +0 -4
- package/dist/ionic/p-db30f71b.entry.js +0 -4
- package/dist/ionic/p-dbcba5a2.js +0 -4
- package/dist/ionic/p-dcb5711d.entry.js +0 -4
- package/dist/ionic/p-df504a37.system.js +0 -4
- package/dist/ionic/p-e04b9647.system.entry.js +0 -4
- package/dist/ionic/p-e81bf09e.system.entry.js +0 -4
- package/dist/ionic/p-e9f9388e.system.js +0 -4
- package/dist/ionic/p-edcada2b.system.entry.js +0 -4
- package/dist/ionic/p-f460c7ae.entry.js +0 -4
- package/dist/ionic/p-f53d074d.system.entry.js +0 -4
- package/dist/ionic/p-f840d817.entry.js +0 -4
- package/dist/ionic/p-f8c96502.system.entry.js +0 -4
- package/dist/ionic/p-fb9f8495.system.entry.js +0 -4
- package/dist/ionic/p-fd2aa50c.js +0 -4
- package/dist/types/components/picker-column-internal/picker-column-internal-interfaces.d.ts +0 -5
- package/dist/types/components/picker-column-internal/picker-column-internal.d.ts +0 -102
- package/dist/types/components/picker-internal/picker-internal-interfaces.d.ts +0 -8
- package/dist/types/components/picker-internal/picker-internal.d.ts +0 -102
- /package/dist/collection/components/{picker-internal/picker-internal-interfaces.js → picker/picker-interfaces.js} +0 -0
- /package/dist/collection/components/{picker-column-internal/picker-column-internal-interfaces.js → picker-column/picker-column-interfaces.js} +0 -0
- /package/dist/collection/components/{picker → picker-legacy}/animations/ios.enter.js +0 -0
- /package/dist/collection/components/{picker → picker-legacy}/animations/ios.leave.js +0 -0
- /package/dist/collection/components/{picker → picker-legacy}/picker-interface.js +0 -0
- /package/dist/collection/components/{picker-column → picker-legacy-column}/test/test.utils.js +0 -0
- /package/dist/esm-es5/{data-0f3ab200.js → data-691286f1.js} +0 -0
- /package/dist/ionic/{p-f7dce541.js → p-5289aade.js} +0 -0
- /package/dist/ionic/{p-7330c044.system.js → p-66e6860f.system.js} +0 -0
- /package/dist/types/components/{picker → picker-legacy}/animations/ios.enter.d.ts +0 -0
- /package/dist/types/components/{picker → picker-legacy}/animations/ios.leave.d.ts +0 -0
- /package/dist/types/components/{picker → picker-legacy}/picker-interface.d.ts +0 -0
- /package/dist/types/components/{picker-column → picker-legacy-column}/test/test.utils.d.ts +0 -0
|
@@ -2,9 +2,8 @@
|
|
|
2
2
|
* (C) Ionic http://ionicframework.com - MIT License
|
|
3
3
|
*/
|
|
4
4
|
import { Host, h, forceUpdate } from "@stencil/core";
|
|
5
|
-
import { compareOptions,
|
|
6
|
-
import {
|
|
7
|
-
import { printIonWarning } from "../../utils/logging/index";
|
|
5
|
+
import { compareOptions, createNotchController, isOptionSelected } from "../../utils/forms/index";
|
|
6
|
+
import { focusVisibleElement, getAriaLabel, renderHiddenInput, inheritAttributes } from "../../utils/helpers";
|
|
8
7
|
import { actionSheetController, alertController, popoverController } from "../../utils/overlays";
|
|
9
8
|
import { isRTL } from "../../utils/rtl/index";
|
|
10
9
|
import { createColorClasses, hostContext } from "../../utils/theme";
|
|
@@ -29,8 +28,6 @@ export class Select {
|
|
|
29
28
|
constructor() {
|
|
30
29
|
this.inputId = `ion-sel-${selectIds++}`;
|
|
31
30
|
this.inheritedAttributes = {};
|
|
32
|
-
// This flag ensures we log the deprecation warning at most once.
|
|
33
|
-
this.hasLoggedDeprecationWarning = false;
|
|
34
31
|
this.onClick = (ev) => {
|
|
35
32
|
const target = ev.target;
|
|
36
33
|
const closestSlot = target.closest('[slot="start"], [slot="end"]');
|
|
@@ -85,7 +82,6 @@ export class Select {
|
|
|
85
82
|
this.justify = 'space-between';
|
|
86
83
|
this.label = undefined;
|
|
87
84
|
this.labelPlacement = 'start';
|
|
88
|
-
this.legacy = undefined;
|
|
89
85
|
this.multiple = false;
|
|
90
86
|
this.name = this.inputId;
|
|
91
87
|
this.okText = 'OK';
|
|
@@ -108,7 +104,6 @@ export class Select {
|
|
|
108
104
|
}
|
|
109
105
|
async connectedCallback() {
|
|
110
106
|
const { el } = this;
|
|
111
|
-
this.legacyFormController = createLegacyFormController(el);
|
|
112
107
|
this.notchController = createNotchController(el, () => this.notchSpacerEl, () => this.labelSlot);
|
|
113
108
|
this.updateOverlayOptions();
|
|
114
109
|
this.emitStyle();
|
|
@@ -158,7 +153,7 @@ export class Select {
|
|
|
158
153
|
if (indexOfSelected > -1) {
|
|
159
154
|
const selectedItem = overlay.querySelector(`.select-interface-option:nth-child(${indexOfSelected + 1})`);
|
|
160
155
|
if (selectedItem) {
|
|
161
|
-
|
|
156
|
+
focusVisibleElement(selectedItem);
|
|
162
157
|
/**
|
|
163
158
|
* Browsers such as Firefox do not
|
|
164
159
|
* correctly delegate focus when manually
|
|
@@ -182,7 +177,7 @@ export class Select {
|
|
|
182
177
|
*/
|
|
183
178
|
const firstEnabledOption = overlay.querySelector('ion-radio:not(.radio-disabled), ion-checkbox:not(.checkbox-disabled)');
|
|
184
179
|
if (firstEnabledOption) {
|
|
185
|
-
|
|
180
|
+
focusVisibleElement(firstEnabledOption.closest('ion-item'));
|
|
186
181
|
/**
|
|
187
182
|
* Focus the option for the same reason as we do above.
|
|
188
183
|
*/
|
|
@@ -312,38 +307,24 @@ export class Select {
|
|
|
312
307
|
const value = this.value;
|
|
313
308
|
let event = ev;
|
|
314
309
|
let size = 'auto';
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
} });
|
|
324
|
-
size = 'cover';
|
|
325
|
-
}
|
|
326
|
-
}
|
|
327
|
-
else {
|
|
328
|
-
const hasFloatingOrStackedLabel = labelPlacement === 'floating' || labelPlacement === 'stacked';
|
|
310
|
+
const hasFloatingOrStackedLabel = labelPlacement === 'floating' || labelPlacement === 'stacked';
|
|
311
|
+
/**
|
|
312
|
+
* The popover should take up the full width
|
|
313
|
+
* when using a fill in MD mode or if the
|
|
314
|
+
* label is floating/stacked.
|
|
315
|
+
*/
|
|
316
|
+
if (hasFloatingOrStackedLabel || (mode === 'md' && fill !== undefined)) {
|
|
317
|
+
size = 'cover';
|
|
329
318
|
/**
|
|
330
|
-
*
|
|
331
|
-
*
|
|
332
|
-
*
|
|
319
|
+
* Otherwise the popover
|
|
320
|
+
* should be positioned relative
|
|
321
|
+
* to the native element.
|
|
333
322
|
*/
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
* to the native element.
|
|
340
|
-
*/
|
|
341
|
-
}
|
|
342
|
-
else {
|
|
343
|
-
event = Object.assign(Object.assign({}, ev), { detail: {
|
|
344
|
-
ionShadowTarget: this.nativeWrapperEl,
|
|
345
|
-
} });
|
|
346
|
-
}
|
|
323
|
+
}
|
|
324
|
+
else {
|
|
325
|
+
event = Object.assign(Object.assign({}, ev), { detail: {
|
|
326
|
+
ionShadowTarget: this.nativeWrapperEl,
|
|
327
|
+
} });
|
|
347
328
|
}
|
|
348
329
|
const popoverOpts = Object.assign(Object.assign({ mode,
|
|
349
330
|
event, alignment: 'center', size,
|
|
@@ -387,26 +368,10 @@ export class Select {
|
|
|
387
368
|
return actionSheetController.create(actionSheetOpts);
|
|
388
369
|
}
|
|
389
370
|
async openAlert() {
|
|
390
|
-
/**
|
|
391
|
-
* TODO FW-3194
|
|
392
|
-
* Remove legacyFormController logic.
|
|
393
|
-
* Remove label and labelText vars
|
|
394
|
-
* Pass `this.labelText` instead of `labelText`
|
|
395
|
-
* when setting the header.
|
|
396
|
-
*/
|
|
397
|
-
let label;
|
|
398
|
-
let labelText;
|
|
399
|
-
if (this.legacyFormController.hasLegacyControl()) {
|
|
400
|
-
label = this.getLabel();
|
|
401
|
-
labelText = label ? label.textContent : null;
|
|
402
|
-
}
|
|
403
|
-
else {
|
|
404
|
-
labelText = this.labelText;
|
|
405
|
-
}
|
|
406
371
|
const interfaceOptions = this.interfaceOptions;
|
|
407
372
|
const inputType = this.multiple ? 'checkbox' : 'radio';
|
|
408
373
|
const mode = getIonMode(this);
|
|
409
|
-
const alertOpts = Object.assign(Object.assign({ mode }, interfaceOptions), { header: interfaceOptions.header ? interfaceOptions.header : labelText, inputs: this.createAlertInputs(this.childOpts, inputType, this.value), buttons: [
|
|
374
|
+
const alertOpts = Object.assign(Object.assign({ mode }, interfaceOptions), { header: interfaceOptions.header ? interfaceOptions.header : this.labelText, inputs: this.createAlertInputs(this.childOpts, inputType, this.value), buttons: [
|
|
410
375
|
{
|
|
411
376
|
text: this.cancelText,
|
|
412
377
|
role: 'cancel',
|
|
@@ -447,10 +412,6 @@ export class Select {
|
|
|
447
412
|
}
|
|
448
413
|
return this.overlay.dismiss();
|
|
449
414
|
}
|
|
450
|
-
// TODO FW-3194 Remove this
|
|
451
|
-
getLabel() {
|
|
452
|
-
return findItemLabel(this.el);
|
|
453
|
-
}
|
|
454
415
|
hasValue() {
|
|
455
416
|
return this.getText() !== '';
|
|
456
417
|
}
|
|
@@ -493,16 +454,6 @@ export class Select {
|
|
|
493
454
|
const style = {
|
|
494
455
|
'interactive-disabled': disabled,
|
|
495
456
|
};
|
|
496
|
-
if (this.legacyFormController.hasLegacyControl()) {
|
|
497
|
-
style['interactive'] = true;
|
|
498
|
-
style['select'] = true;
|
|
499
|
-
style['select-disabled'] = disabled;
|
|
500
|
-
style['has-placeholder'] = this.placeholder !== undefined;
|
|
501
|
-
style['has-value'] = this.hasValue();
|
|
502
|
-
style['has-focus'] = this.isExpanded;
|
|
503
|
-
// TODO(FW-3194): remove this
|
|
504
|
-
style['legacy'] = !!this.legacy;
|
|
505
|
-
}
|
|
506
457
|
this.ionStyle.emit(style);
|
|
507
458
|
}
|
|
508
459
|
renderLabel() {
|
|
@@ -561,92 +512,6 @@ export class Select {
|
|
|
561
512
|
*/
|
|
562
513
|
return this.renderLabel();
|
|
563
514
|
}
|
|
564
|
-
renderSelect() {
|
|
565
|
-
const { disabled, el, isExpanded, expandedIcon, labelPlacement, justify, placeholder, fill, shape, name, value } = this;
|
|
566
|
-
const mode = getIonMode(this);
|
|
567
|
-
const hasFloatingOrStackedLabel = labelPlacement === 'floating' || labelPlacement === 'stacked';
|
|
568
|
-
const justifyEnabled = !hasFloatingOrStackedLabel;
|
|
569
|
-
const rtl = isRTL(el) ? 'rtl' : 'ltr';
|
|
570
|
-
const inItem = hostContext('ion-item', this.el);
|
|
571
|
-
const shouldRenderHighlight = mode === 'md' && fill !== 'outline' && !inItem;
|
|
572
|
-
const hasValue = this.hasValue();
|
|
573
|
-
const hasStartEndSlots = el.querySelector('[slot="start"], [slot="end"]') !== null;
|
|
574
|
-
renderHiddenInput(true, el, name, parseValue(value), disabled);
|
|
575
|
-
/**
|
|
576
|
-
* If the label is stacked, it should always sit above the select.
|
|
577
|
-
* For floating labels, the label should move above the select if
|
|
578
|
-
* the select has a value, is open, or has anything in either
|
|
579
|
-
* the start or end slot.
|
|
580
|
-
*
|
|
581
|
-
* If there is content in the start slot, the label would overlap
|
|
582
|
-
* it if not forced to float. This is also applied to the end slot
|
|
583
|
-
* because with the default or solid fills, the select is not
|
|
584
|
-
* vertically centered in the container, but the label is. This
|
|
585
|
-
* causes the slots and label to appear vertically offset from each
|
|
586
|
-
* other when the label isn't floating above the input. This doesn't
|
|
587
|
-
* apply to the outline fill, but this was not accounted for to keep
|
|
588
|
-
* things consistent.
|
|
589
|
-
*
|
|
590
|
-
* TODO(FW-5592): Remove hasStartEndSlots condition
|
|
591
|
-
*/
|
|
592
|
-
const labelShouldFloat = labelPlacement === 'stacked' || (labelPlacement === 'floating' && (hasValue || isExpanded || hasStartEndSlots));
|
|
593
|
-
return (h(Host, { onClick: this.onClick, class: createColorClasses(this.color, {
|
|
594
|
-
[mode]: true,
|
|
595
|
-
'in-item': inItem,
|
|
596
|
-
'in-item-color': hostContext('ion-item.ion-color', el),
|
|
597
|
-
'select-disabled': disabled,
|
|
598
|
-
'select-expanded': isExpanded,
|
|
599
|
-
'has-expanded-icon': expandedIcon !== undefined,
|
|
600
|
-
'has-value': hasValue,
|
|
601
|
-
'label-floating': labelShouldFloat,
|
|
602
|
-
'has-placeholder': placeholder !== undefined,
|
|
603
|
-
'ion-focusable': true,
|
|
604
|
-
[`select-${rtl}`]: true,
|
|
605
|
-
[`select-fill-${fill}`]: fill !== undefined,
|
|
606
|
-
[`select-justify-${justify}`]: justifyEnabled,
|
|
607
|
-
[`select-shape-${shape}`]: shape !== undefined,
|
|
608
|
-
[`select-label-placement-${labelPlacement}`]: true,
|
|
609
|
-
}) }, h("label", { class: "select-wrapper", id: "select-label" }, this.renderLabelContainer(), h("div", { class: "select-wrapper-inner" }, h("slot", { name: "start" }), h("div", { class: "native-wrapper", ref: (el) => (this.nativeWrapperEl = el), part: "container" }, this.renderSelectText(), this.renderListbox()), h("slot", { name: "end" }), !hasFloatingOrStackedLabel && this.renderSelectIcon()), hasFloatingOrStackedLabel && this.renderSelectIcon(), shouldRenderHighlight && h("div", { class: "select-highlight" }))));
|
|
610
|
-
}
|
|
611
|
-
// TODO FW-3194 - Remove this
|
|
612
|
-
renderLegacySelect() {
|
|
613
|
-
if (!this.hasLoggedDeprecationWarning) {
|
|
614
|
-
printIonWarning(`ion-select now requires providing a label with either the "label" property or the "aria-label" attribute. To migrate, remove any usage of "ion-label" and pass the label text to either the "label" property or the "aria-label" attribute.
|
|
615
|
-
|
|
616
|
-
Example: <ion-select label="Favorite Color">...</ion-select>
|
|
617
|
-
Example with aria-label: <ion-select aria-label="Favorite Color">...</ion-select>
|
|
618
|
-
|
|
619
|
-
Developers can use the "legacy" property to continue using the legacy form markup. This property will be removed in an upcoming major release of Ionic where this form control will use the modern form markup.`, this.el);
|
|
620
|
-
if (this.legacy) {
|
|
621
|
-
printIonWarning(`ion-select is being used with the "legacy" property enabled which will forcibly enable the legacy form markup. This property will be removed in an upcoming major release of Ionic where this form control will use the modern form markup.
|
|
622
|
-
Developers can dismiss this warning by removing their usage of the "legacy" property and using the new select syntax.`, this.el);
|
|
623
|
-
}
|
|
624
|
-
this.hasLoggedDeprecationWarning = true;
|
|
625
|
-
}
|
|
626
|
-
const { disabled, el, inputId, isExpanded, expandedIcon, name, placeholder, value } = this;
|
|
627
|
-
const mode = getIonMode(this);
|
|
628
|
-
const { labelText, labelId } = getAriaLabel(el, inputId);
|
|
629
|
-
renderHiddenInput(true, el, name, parseValue(value), disabled);
|
|
630
|
-
const displayValue = this.getText();
|
|
631
|
-
let selectText = displayValue;
|
|
632
|
-
if (selectText === '' && placeholder !== undefined) {
|
|
633
|
-
selectText = placeholder;
|
|
634
|
-
}
|
|
635
|
-
// If there is a label then we need to concatenate it with the
|
|
636
|
-
// current value (or placeholder) and a comma so it separates
|
|
637
|
-
// nicely when the screen reader announces it, otherwise just
|
|
638
|
-
// announce the value / placeholder
|
|
639
|
-
const displayLabel = labelText !== undefined ? (selectText !== '' ? `${selectText}, ${labelText}` : labelText) : selectText;
|
|
640
|
-
return (h(Host, { onClick: this.onClick, role: "button", "aria-haspopup": "listbox", "aria-disabled": disabled ? 'true' : null, "aria-label": displayLabel, class: {
|
|
641
|
-
[mode]: true,
|
|
642
|
-
'in-item': hostContext('ion-item', el),
|
|
643
|
-
'in-item-color': hostContext('ion-item.ion-color', el),
|
|
644
|
-
'select-disabled': disabled,
|
|
645
|
-
'select-expanded': isExpanded,
|
|
646
|
-
'has-expanded-icon': expandedIcon !== undefined,
|
|
647
|
-
'legacy-select': true,
|
|
648
|
-
} }, this.renderSelectText(), this.renderSelectIcon(), h("label", { id: labelId }, displayLabel), this.renderListbox()));
|
|
649
|
-
}
|
|
650
515
|
/**
|
|
651
516
|
* Renders either the placeholder
|
|
652
517
|
* or the selected values based on
|
|
@@ -717,8 +582,51 @@ Developers can use the "legacy" property to continue using the legacy form marku
|
|
|
717
582
|
return (h("button", { disabled: disabled, id: inputId, "aria-label": this.ariaLabel, "aria-haspopup": "dialog", "aria-expanded": `${isExpanded}`, onFocus: this.onFocus, onBlur: this.onBlur, ref: (focusEl) => (this.focusEl = focusEl) }));
|
|
718
583
|
}
|
|
719
584
|
render() {
|
|
720
|
-
const {
|
|
721
|
-
|
|
585
|
+
const { disabled, el, isExpanded, expandedIcon, labelPlacement, justify, placeholder, fill, shape, name, value } = this;
|
|
586
|
+
const mode = getIonMode(this);
|
|
587
|
+
const hasFloatingOrStackedLabel = labelPlacement === 'floating' || labelPlacement === 'stacked';
|
|
588
|
+
const justifyEnabled = !hasFloatingOrStackedLabel;
|
|
589
|
+
const rtl = isRTL(el) ? 'rtl' : 'ltr';
|
|
590
|
+
const inItem = hostContext('ion-item', this.el);
|
|
591
|
+
const shouldRenderHighlight = mode === 'md' && fill !== 'outline' && !inItem;
|
|
592
|
+
const hasValue = this.hasValue();
|
|
593
|
+
const hasStartEndSlots = el.querySelector('[slot="start"], [slot="end"]') !== null;
|
|
594
|
+
renderHiddenInput(true, el, name, parseValue(value), disabled);
|
|
595
|
+
/**
|
|
596
|
+
* If the label is stacked, it should always sit above the select.
|
|
597
|
+
* For floating labels, the label should move above the select if
|
|
598
|
+
* the select has a value, is open, or has anything in either
|
|
599
|
+
* the start or end slot.
|
|
600
|
+
*
|
|
601
|
+
* If there is content in the start slot, the label would overlap
|
|
602
|
+
* it if not forced to float. This is also applied to the end slot
|
|
603
|
+
* because with the default or solid fills, the select is not
|
|
604
|
+
* vertically centered in the container, but the label is. This
|
|
605
|
+
* causes the slots and label to appear vertically offset from each
|
|
606
|
+
* other when the label isn't floating above the input. This doesn't
|
|
607
|
+
* apply to the outline fill, but this was not accounted for to keep
|
|
608
|
+
* things consistent.
|
|
609
|
+
*
|
|
610
|
+
* TODO(FW-5592): Remove hasStartEndSlots condition
|
|
611
|
+
*/
|
|
612
|
+
const labelShouldFloat = labelPlacement === 'stacked' || (labelPlacement === 'floating' && (hasValue || isExpanded || hasStartEndSlots));
|
|
613
|
+
return (h(Host, { key: '39718ddb0685972f736089a6b4ec681aaa494bf4', onClick: this.onClick, class: createColorClasses(this.color, {
|
|
614
|
+
[mode]: true,
|
|
615
|
+
'in-item': inItem,
|
|
616
|
+
'in-item-color': hostContext('ion-item.ion-color', el),
|
|
617
|
+
'select-disabled': disabled,
|
|
618
|
+
'select-expanded': isExpanded,
|
|
619
|
+
'has-expanded-icon': expandedIcon !== undefined,
|
|
620
|
+
'has-value': hasValue,
|
|
621
|
+
'label-floating': labelShouldFloat,
|
|
622
|
+
'has-placeholder': placeholder !== undefined,
|
|
623
|
+
'ion-focusable': true,
|
|
624
|
+
[`select-${rtl}`]: true,
|
|
625
|
+
[`select-fill-${fill}`]: fill !== undefined,
|
|
626
|
+
[`select-justify-${justify}`]: justifyEnabled,
|
|
627
|
+
[`select-shape-${shape}`]: shape !== undefined,
|
|
628
|
+
[`select-label-placement-${labelPlacement}`]: true,
|
|
629
|
+
}) }, h("label", { key: '6d51bb692bda00bf34251520eba872c408128a59', class: "select-wrapper", id: "select-label" }, this.renderLabelContainer(), h("div", { key: 'd1544ae348f6013940e77b4c2fb5e53b24322414', class: "select-wrapper-inner" }, h("slot", { key: '53f334dbe960619583c1fe196be18584edb196ac', name: "start" }), h("div", { key: '924ae05b68bc9811b80acb4a9973b3ecfde00379', class: "native-wrapper", ref: (el) => (this.nativeWrapperEl = el), part: "container" }, this.renderSelectText(), this.renderListbox()), h("slot", { key: '916a4d542c8cffdf4be8f62c77eee6acc2e5ac7b', name: "end" }), !hasFloatingOrStackedLabel && this.renderSelectIcon()), hasFloatingOrStackedLabel && this.renderSelectIcon(), shouldRenderHighlight && h("div", { class: "select-highlight" }))));
|
|
722
630
|
}
|
|
723
631
|
static get is() { return "ion-select"; }
|
|
724
632
|
static get encapsulation() { return "shadow"; }
|
|
@@ -930,23 +838,6 @@ Developers can use the "legacy" property to continue using the legacy form marku
|
|
|
930
838
|
"reflect": false,
|
|
931
839
|
"defaultValue": "'start'"
|
|
932
840
|
},
|
|
933
|
-
"legacy": {
|
|
934
|
-
"type": "boolean",
|
|
935
|
-
"mutable": false,
|
|
936
|
-
"complexType": {
|
|
937
|
-
"original": "boolean",
|
|
938
|
-
"resolved": "boolean | undefined",
|
|
939
|
-
"references": {}
|
|
940
|
-
},
|
|
941
|
-
"required": false,
|
|
942
|
-
"optional": true,
|
|
943
|
-
"docs": {
|
|
944
|
-
"tags": [],
|
|
945
|
-
"text": "Set the `legacy` property to `true` to forcibly use the legacy form control markup.\nIonic will only opt components in to the modern form markup when they are\nusing either the `aria-label` attribute or the `label` property. As a result,\nthe `legacy` property should only be used as an escape hatch when you want to\navoid this automatic opt-in behavior.\nNote that this property will be removed in an upcoming major release\nof Ionic, and all form components will be opted-in to using the modern form markup."
|
|
946
|
-
},
|
|
947
|
-
"attribute": "legacy",
|
|
948
|
-
"reflect": false
|
|
949
|
-
},
|
|
950
841
|
"multiple": {
|
|
951
842
|
"type": "boolean",
|
|
952
843
|
"mutable": false,
|
|
@@ -80,12 +80,12 @@
|
|
|
80
80
|
--padding-bottom: 0px;
|
|
81
81
|
--padding-start: 0px;
|
|
82
82
|
--placeholder-color: currentColor;
|
|
83
|
-
--placeholder-opacity: 0.6;
|
|
83
|
+
--placeholder-opacity: var(--ion-placeholder-opacity, 0.6);
|
|
84
84
|
--background: transparent;
|
|
85
85
|
--border-style: solid;
|
|
86
|
-
--highlight-color-focused: var(--ion-color-primary, #
|
|
87
|
-
--highlight-color-valid: var(--ion-color-success, #
|
|
88
|
-
--highlight-color-invalid: var(--ion-color-danger, #
|
|
86
|
+
--highlight-color-focused: var(--ion-color-primary, #0054e9);
|
|
87
|
+
--highlight-color-valid: var(--ion-color-success, #2dd55b);
|
|
88
|
+
--highlight-color-invalid: var(--ion-color-danger, #c5000f);
|
|
89
89
|
/**
|
|
90
90
|
* This is a private API that is used to switch
|
|
91
91
|
* out the highlight color based on the state
|
|
@@ -95,17 +95,14 @@
|
|
|
95
95
|
--highlight-color: var(--highlight-color-focused);
|
|
96
96
|
display: block;
|
|
97
97
|
position: relative;
|
|
98
|
+
width: 100%;
|
|
99
|
+
min-height: 44px;
|
|
98
100
|
font-family: var(--ion-font-family, inherit);
|
|
99
101
|
white-space: nowrap;
|
|
100
102
|
cursor: pointer;
|
|
101
103
|
z-index: 2;
|
|
102
104
|
}
|
|
103
105
|
|
|
104
|
-
:host(:not(.legacy-select)) {
|
|
105
|
-
width: 100%;
|
|
106
|
-
min-height: 44px;
|
|
107
|
-
}
|
|
108
|
-
|
|
109
106
|
/**
|
|
110
107
|
* Since the label sits on top of the element,
|
|
111
108
|
* the component needs to be taller otherwise the
|
|
@@ -120,27 +117,10 @@
|
|
|
120
117
|
--highlight-color-focused: var(--ion-color-base);
|
|
121
118
|
}
|
|
122
119
|
|
|
123
|
-
:host(.
|
|
124
|
-
-webkit-padding-start: var(--padding-start);
|
|
125
|
-
padding-inline-start: var(--padding-start);
|
|
126
|
-
-webkit-padding-end: var(--padding-end);
|
|
127
|
-
padding-inline-end: var(--padding-end);
|
|
128
|
-
padding-top: var(--padding-top);
|
|
129
|
-
padding-bottom: var(--padding-bottom);
|
|
130
|
-
display: flex;
|
|
131
|
-
align-items: center;
|
|
132
|
-
overflow: hidden;
|
|
133
|
-
}
|
|
134
|
-
|
|
135
|
-
:host(.in-item:not(.legacy-select)) {
|
|
120
|
+
:host(.in-item) {
|
|
136
121
|
flex: 1 1 0;
|
|
137
122
|
}
|
|
138
123
|
|
|
139
|
-
:host(.in-item.legacy-select) {
|
|
140
|
-
position: static;
|
|
141
|
-
max-width: 45%;
|
|
142
|
-
}
|
|
143
|
-
|
|
144
124
|
:host(.select-disabled) {
|
|
145
125
|
pointer-events: none;
|
|
146
126
|
}
|
|
@@ -155,8 +135,8 @@
|
|
|
155
135
|
* toolbar which is why we do not
|
|
156
136
|
* limit the below behavior to just ion-item.
|
|
157
137
|
*/
|
|
158
|
-
:host([slot=start]
|
|
159
|
-
:host([slot=end]
|
|
138
|
+
:host([slot=start]),
|
|
139
|
+
:host([slot=end]) {
|
|
160
140
|
width: auto;
|
|
161
141
|
}
|
|
162
142
|
|
|
@@ -165,50 +145,6 @@
|
|
|
165
145
|
opacity: var(--placeholder-opacity);
|
|
166
146
|
}
|
|
167
147
|
|
|
168
|
-
:host(.legacy-select) label {
|
|
169
|
-
top: 0;
|
|
170
|
-
margin-left: 0;
|
|
171
|
-
margin-right: 0;
|
|
172
|
-
margin-top: 0;
|
|
173
|
-
margin-bottom: 0;
|
|
174
|
-
position: absolute;
|
|
175
|
-
width: 100%;
|
|
176
|
-
height: 100%;
|
|
177
|
-
border: 0;
|
|
178
|
-
background: transparent;
|
|
179
|
-
cursor: pointer;
|
|
180
|
-
appearance: none;
|
|
181
|
-
outline: none;
|
|
182
|
-
display: flex;
|
|
183
|
-
align-items: center;
|
|
184
|
-
opacity: 0;
|
|
185
|
-
}
|
|
186
|
-
@supports (inset-inline-start: 0) {
|
|
187
|
-
:host(.legacy-select) label {
|
|
188
|
-
inset-inline-start: 0;
|
|
189
|
-
}
|
|
190
|
-
}
|
|
191
|
-
@supports not (inset-inline-start: 0) {
|
|
192
|
-
:host(.legacy-select) label {
|
|
193
|
-
left: 0;
|
|
194
|
-
}
|
|
195
|
-
:host-context([dir=rtl]):host(.legacy-select) label, :host-context([dir=rtl]).legacy-select label {
|
|
196
|
-
left: unset;
|
|
197
|
-
right: unset;
|
|
198
|
-
right: 0;
|
|
199
|
-
}
|
|
200
|
-
@supports selector(:dir(rtl)) {
|
|
201
|
-
:host(.legacy-select:dir(rtl)) label {
|
|
202
|
-
left: unset;
|
|
203
|
-
right: unset;
|
|
204
|
-
right: 0;
|
|
205
|
-
}
|
|
206
|
-
}
|
|
207
|
-
}
|
|
208
|
-
:host(.legacy-select) label::-moz-focus-inner {
|
|
209
|
-
border: 0;
|
|
210
|
-
}
|
|
211
|
-
|
|
212
148
|
button {
|
|
213
149
|
position: absolute;
|
|
214
150
|
top: 0;
|
|
@@ -802,8 +738,8 @@ button {
|
|
|
802
738
|
* }
|
|
803
739
|
*/
|
|
804
740
|
:host(.select-fill-solid) {
|
|
805
|
-
--background: var(--ion-color-step-50, #f2f2f2);
|
|
806
|
-
--border-color: var(--ion-color-step-500, gray);
|
|
741
|
+
--background: var(--ion-color-step-50, var(--ion-background-color-step-50, #f2f2f2));
|
|
742
|
+
--border-color: var(--ion-color-step-500, var(--ion-background-color-step-500, gray));
|
|
807
743
|
--border-radius: 4px;
|
|
808
744
|
--padding-start: 16px;
|
|
809
745
|
--padding-end: 16px;
|
|
@@ -839,8 +775,8 @@ button {
|
|
|
839
775
|
*/
|
|
840
776
|
@media (any-hover: hover) {
|
|
841
777
|
:host(.select-fill-solid:hover) {
|
|
842
|
-
--background: var(--ion-color-step-100, #e6e6e6);
|
|
843
|
-
--border-color: var(--ion-color-step-750, #404040);
|
|
778
|
+
--background: var(--ion-color-step-100, var(--ion-background-color-step-100, #e6e6e6));
|
|
779
|
+
--border-color: var(--ion-color-step-750, var(--ion-background-color-step-750, #404040));
|
|
844
780
|
}
|
|
845
781
|
}
|
|
846
782
|
/**
|
|
@@ -849,8 +785,8 @@ button {
|
|
|
849
785
|
*/
|
|
850
786
|
:host(.select-fill-solid.select-expanded),
|
|
851
787
|
:host(.select-fill-solid.ion-focused) {
|
|
852
|
-
--background: var(--ion-color-step-150, #d9d9d9);
|
|
853
|
-
--border-color: var(--ion-color-step-750, #404040);
|
|
788
|
+
--background: var(--ion-color-step-150, var(--ion-background-color-step-150, #d9d9d9));
|
|
789
|
+
--border-color: var(--ion-color-step-750, var(--ion-background-color-step-750, #404040));
|
|
854
790
|
}
|
|
855
791
|
|
|
856
792
|
:host(.select-fill-solid) .select-wrapper {
|
|
@@ -858,25 +794,10 @@ button {
|
|
|
858
794
|
* Only the top left and top right borders should.
|
|
859
795
|
* have a radius when using a solid fill.
|
|
860
796
|
*/
|
|
861
|
-
border-
|
|
862
|
-
border-
|
|
863
|
-
border-
|
|
864
|
-
border-
|
|
865
|
-
}
|
|
866
|
-
:host-context([dir=rtl]):host(.select-fill-solid) .select-wrapper, :host-context([dir=rtl]).select-fill-solid .select-wrapper {
|
|
867
|
-
border-top-left-radius: var(--border-radius);
|
|
868
|
-
border-top-right-radius: var(--border-radius);
|
|
869
|
-
border-bottom-right-radius: 0px;
|
|
870
|
-
border-bottom-left-radius: 0px;
|
|
871
|
-
}
|
|
872
|
-
|
|
873
|
-
@supports selector(:dir(rtl)) {
|
|
874
|
-
:host(.select-fill-solid:dir(rtl)) .select-wrapper {
|
|
875
|
-
border-top-left-radius: var(--border-radius);
|
|
876
|
-
border-top-right-radius: var(--border-radius);
|
|
877
|
-
border-bottom-right-radius: 0px;
|
|
878
|
-
border-bottom-left-radius: 0px;
|
|
879
|
-
}
|
|
797
|
+
border-start-start-radius: var(--border-radius);
|
|
798
|
+
border-start-end-radius: var(--border-radius);
|
|
799
|
+
border-end-end-radius: 0px;
|
|
800
|
+
border-end-start-radius: 0px;
|
|
880
801
|
}
|
|
881
802
|
|
|
882
803
|
:host(.label-floating.select-fill-solid) .label-text-wrapper {
|
|
@@ -943,7 +864,7 @@ button {
|
|
|
943
864
|
* }
|
|
944
865
|
*/
|
|
945
866
|
:host(.select-fill-outline) {
|
|
946
|
-
--border-color: var(--ion-color-step-300, #b3b3b3);
|
|
867
|
+
--border-color: var(--ion-color-step-300, var(--ion-background-color-step-300, #b3b3b3));
|
|
947
868
|
--border-radius: 4px;
|
|
948
869
|
--padding-start: 16px;
|
|
949
870
|
--padding-end: 16px;
|
|
@@ -971,7 +892,7 @@ button {
|
|
|
971
892
|
*/
|
|
972
893
|
@media (any-hover: hover) {
|
|
973
894
|
:host(.select-fill-outline:hover) {
|
|
974
|
-
--border-color: var(--ion-color-step-750, #404040);
|
|
895
|
+
--border-color: var(--ion-color-step-750, var(--ion-background-color-step-750, #404040));
|
|
975
896
|
}
|
|
976
897
|
}
|
|
977
898
|
/**
|
|
@@ -1133,12 +1054,11 @@ button {
|
|
|
1133
1054
|
border-inline-start: var(--border-width) var(--border-style) var(--border-color);
|
|
1134
1055
|
}
|
|
1135
1056
|
|
|
1136
|
-
:host(.select-
|
|
1137
|
-
border-radius: var(--border-radius)
|
|
1138
|
-
|
|
1139
|
-
|
|
1140
|
-
|
|
1141
|
-
border-radius: 0px var(--border-radius) var(--border-radius) 0px;
|
|
1057
|
+
:host(.select-fill-outline) .select-outline-start {
|
|
1058
|
+
border-start-start-radius: var(--border-radius);
|
|
1059
|
+
border-start-end-radius: 0px;
|
|
1060
|
+
border-end-end-radius: 0px;
|
|
1061
|
+
border-end-start-radius: var(--border-radius);
|
|
1142
1062
|
}
|
|
1143
1063
|
|
|
1144
1064
|
:host(.select-fill-outline) .select-outline-start {
|
|
@@ -1158,12 +1078,11 @@ button {
|
|
|
1158
1078
|
border-inline-end: var(--border-width) var(--border-style) var(--border-color);
|
|
1159
1079
|
}
|
|
1160
1080
|
|
|
1161
|
-
:host(.select-
|
|
1162
|
-
border-
|
|
1163
|
-
|
|
1164
|
-
|
|
1165
|
-
|
|
1166
|
-
border-radius: var(--border-radius) 0px 0px var(--border-radius);
|
|
1081
|
+
:host(.select-fill-outline) .select-outline-end {
|
|
1082
|
+
border-start-start-radius: 0px;
|
|
1083
|
+
border-start-end-radius: var(--border-radius);
|
|
1084
|
+
border-end-end-radius: var(--border-radius);
|
|
1085
|
+
border-end-start-radius: 0px;
|
|
1167
1086
|
}
|
|
1168
1087
|
|
|
1169
1088
|
:host(.select-fill-outline) .select-outline-end {
|
|
@@ -1186,20 +1105,13 @@ button {
|
|
|
1186
1105
|
|
|
1187
1106
|
:host {
|
|
1188
1107
|
--border-width: 1px;
|
|
1189
|
-
--border-color: var(--ion-item-border-color, var(--ion-border-color, var(--ion-color-step-150, rgba(0, 0, 0, 0.13))));
|
|
1190
|
-
}
|
|
1191
|
-
|
|
1192
|
-
:host(.legacy-select) {
|
|
1193
|
-
--padding-top: 10px;
|
|
1194
|
-
--padding-end: 0;
|
|
1195
|
-
--padding-bottom: 10px;
|
|
1196
|
-
--padding-start: 16px;
|
|
1108
|
+
--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)))));
|
|
1197
1109
|
}
|
|
1198
1110
|
|
|
1199
1111
|
.select-icon {
|
|
1200
1112
|
width: 0.8125rem;
|
|
1201
1113
|
transition: transform 0.15s cubic-bezier(0.4, 0, 0.2, 1);
|
|
1202
|
-
color: var(--ion-color-step-500, gray);
|
|
1114
|
+
color: var(--ion-color-step-500, var(--ion-text-color-step-500, gray));
|
|
1203
1115
|
}
|
|
1204
1116
|
|
|
1205
1117
|
/**
|
|
@@ -1230,32 +1142,8 @@ button {
|
|
|
1230
1142
|
transition: transform 200ms;
|
|
1231
1143
|
background: var(--highlight-color);
|
|
1232
1144
|
}
|
|
1233
|
-
|
|
1234
|
-
|
|
1235
|
-
inset-inline-start: 0;
|
|
1236
|
-
}
|
|
1237
|
-
}
|
|
1238
|
-
@supports not (inset-inline-start: 0) {
|
|
1239
|
-
.select-highlight {
|
|
1240
|
-
left: 0;
|
|
1241
|
-
}
|
|
1242
|
-
:host-context([dir=rtl]) .select-highlight {
|
|
1243
|
-
left: unset;
|
|
1244
|
-
right: unset;
|
|
1245
|
-
right: 0;
|
|
1246
|
-
}
|
|
1247
|
-
[dir=rtl] .select-highlight {
|
|
1248
|
-
left: unset;
|
|
1249
|
-
right: unset;
|
|
1250
|
-
right: 0;
|
|
1251
|
-
}
|
|
1252
|
-
@supports selector(:dir(rtl)) {
|
|
1253
|
-
.select-highlight:dir(rtl) {
|
|
1254
|
-
left: unset;
|
|
1255
|
-
right: unset;
|
|
1256
|
-
right: 0;
|
|
1257
|
-
}
|
|
1258
|
-
}
|
|
1145
|
+
.select-highlight {
|
|
1146
|
+
inset-inline-start: 0;
|
|
1259
1147
|
}
|
|
1260
1148
|
|
|
1261
1149
|
:host(.select-expanded) .select-highlight,
|
|
@@ -1271,27 +1159,8 @@ button {
|
|
|
1271
1159
|
:host(.in-item) .select-highlight {
|
|
1272
1160
|
bottom: 0;
|
|
1273
1161
|
}
|
|
1274
|
-
|
|
1275
|
-
|
|
1276
|
-
inset-inline-start: 0;
|
|
1277
|
-
}
|
|
1278
|
-
}
|
|
1279
|
-
@supports not (inset-inline-start: 0) {
|
|
1280
|
-
:host(.in-item) .select-highlight {
|
|
1281
|
-
left: 0;
|
|
1282
|
-
}
|
|
1283
|
-
:host-context([dir=rtl]):host(.in-item) .select-highlight, :host-context([dir=rtl]).in-item .select-highlight {
|
|
1284
|
-
left: unset;
|
|
1285
|
-
right: unset;
|
|
1286
|
-
right: 0;
|
|
1287
|
-
}
|
|
1288
|
-
@supports selector(:dir(rtl)) {
|
|
1289
|
-
:host(.in-item:dir(rtl)) .select-highlight {
|
|
1290
|
-
left: unset;
|
|
1291
|
-
right: unset;
|
|
1292
|
-
right: 0;
|
|
1293
|
-
}
|
|
1294
|
-
}
|
|
1162
|
+
:host(.in-item) .select-highlight {
|
|
1163
|
+
inset-inline-start: 0;
|
|
1295
1164
|
}
|
|
1296
1165
|
|
|
1297
1166
|
/**
|
|
@@ -1299,7 +1168,7 @@ button {
|
|
|
1299
1168
|
* when the select is activated.
|
|
1300
1169
|
* This should only happen on MD.
|
|
1301
1170
|
*/
|
|
1302
|
-
:host(.select-expanded:not(.
|
|
1171
|
+
:host(.select-expanded:not(.has-expanded-icon)) .select-icon {
|
|
1303
1172
|
transform: rotate(180deg);
|
|
1304
1173
|
}
|
|
1305
1174
|
|