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,7 @@
|
|
|
2
2
|
* (C) Ionic http://ionicframework.com - MIT License
|
|
3
3
|
*/
|
|
4
4
|
import { Host, h } from "@stencil/core";
|
|
5
|
-
import {
|
|
6
|
-
import { getAriaLabel, renderHiddenInput, inheritAriaAttributes } from "../../utils/helpers";
|
|
7
|
-
import { printIonWarning } from "../../utils/logging/index";
|
|
5
|
+
import { renderHiddenInput, inheritAriaAttributes } from "../../utils/helpers";
|
|
8
6
|
import { hapticSelection } from "../../utils/native/haptic";
|
|
9
7
|
import { isRTL } from "../../utils/rtl/index";
|
|
10
8
|
import { createColorClasses, hostContext } from "../../utils/theme";
|
|
@@ -26,8 +24,6 @@ export class Toggle {
|
|
|
26
24
|
this.lastDrag = 0;
|
|
27
25
|
this.inheritedAttributes = {};
|
|
28
26
|
this.didLoad = false;
|
|
29
|
-
// This flag ensures we log the deprecation warning at most once.
|
|
30
|
-
this.hasLoggedDeprecationWarning = false;
|
|
31
27
|
this.setupGesture = async () => {
|
|
32
28
|
const { toggleTrack } = this;
|
|
33
29
|
if (toggleTrack) {
|
|
@@ -73,12 +69,10 @@ export class Toggle {
|
|
|
73
69
|
this.value = 'on';
|
|
74
70
|
this.enableOnOffLabels = config.get('toggleOnOffLabels');
|
|
75
71
|
this.labelPlacement = 'start';
|
|
76
|
-
this.legacy = undefined;
|
|
77
72
|
this.justify = 'space-between';
|
|
78
73
|
this.alignment = 'center';
|
|
79
74
|
}
|
|
80
75
|
disabledChanged() {
|
|
81
|
-
this.emitStyle();
|
|
82
76
|
if (this.gesture) {
|
|
83
77
|
this.gesture.enable(!this.disabled);
|
|
84
78
|
}
|
|
@@ -93,7 +87,6 @@ export class Toggle {
|
|
|
93
87
|
});
|
|
94
88
|
}
|
|
95
89
|
async connectedCallback() {
|
|
96
|
-
this.legacyFormController = createLegacyFormController(this.el);
|
|
97
90
|
/**
|
|
98
91
|
* If we have not yet rendered
|
|
99
92
|
* ion-toggle, then toggleTrack is not defined.
|
|
@@ -115,19 +108,7 @@ export class Toggle {
|
|
|
115
108
|
}
|
|
116
109
|
}
|
|
117
110
|
componentWillLoad() {
|
|
118
|
-
this.
|
|
119
|
-
if (!this.legacyFormController.hasLegacyControl()) {
|
|
120
|
-
this.inheritedAttributes = Object.assign({}, inheritAriaAttributes(this.el));
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
emitStyle() {
|
|
124
|
-
if (this.legacyFormController.hasLegacyControl()) {
|
|
125
|
-
this.ionStyle.emit({
|
|
126
|
-
'interactive-disabled': this.disabled,
|
|
127
|
-
// TODO(FW-2990): remove this
|
|
128
|
-
legacy: !!this.legacy,
|
|
129
|
-
});
|
|
130
|
-
}
|
|
111
|
+
this.inheritedAttributes = Object.assign({}, inheritAriaAttributes(this.el));
|
|
131
112
|
}
|
|
132
113
|
onStart() {
|
|
133
114
|
this.activated = true;
|
|
@@ -171,16 +152,12 @@ export class Toggle {
|
|
|
171
152
|
return this.el.textContent !== '';
|
|
172
153
|
}
|
|
173
154
|
render() {
|
|
174
|
-
const { legacyFormController } = this;
|
|
175
|
-
return legacyFormController.hasLegacyControl() ? this.renderLegacyToggle() : this.renderToggle();
|
|
176
|
-
}
|
|
177
|
-
renderToggle() {
|
|
178
155
|
const { activated, color, checked, disabled, el, justify, labelPlacement, inputId, name, alignment } = this;
|
|
179
156
|
const mode = getIonMode(this);
|
|
180
157
|
const value = this.getValue();
|
|
181
158
|
const rtl = isRTL(el) ? 'rtl' : 'ltr';
|
|
182
159
|
renderHiddenInput(true, el, name, checked ? value : '', disabled);
|
|
183
|
-
return (h(Host, { onClick: this.onClick, class: createColorClasses(color, {
|
|
160
|
+
return (h(Host, { key: '3c0acc5498682a610e7a6f095590ad79391e1ba4', onClick: this.onClick, class: createColorClasses(color, {
|
|
184
161
|
[mode]: true,
|
|
185
162
|
'in-item': hostContext('ion-item', el),
|
|
186
163
|
'toggle-activated': activated,
|
|
@@ -190,42 +167,10 @@ export class Toggle {
|
|
|
190
167
|
[`toggle-alignment-${alignment}`]: true,
|
|
191
168
|
[`toggle-label-placement-${labelPlacement}`]: true,
|
|
192
169
|
[`toggle-${rtl}`]: true,
|
|
193
|
-
}) }, h("label", { class: "toggle-wrapper" }, h("input", Object.assign({ type: "checkbox", role: "switch", "aria-checked": `${checked}`, checked: checked, disabled: disabled, id: inputId, onFocus: () => this.onFocus(), onBlur: () => this.onBlur(), ref: (focusEl) => (this.focusEl = focusEl) }, this.inheritedAttributes)), h("div", { class: {
|
|
170
|
+
}) }, h("label", { key: '68133afe76d290ebcb8f05883a27875529f0bfff', class: "toggle-wrapper" }, h("input", Object.assign({ key: 'abd6aad2a3e62fbffb80d5c3dbdc57182bc97fab', type: "checkbox", role: "switch", "aria-checked": `${checked}`, checked: checked, disabled: disabled, id: inputId, onFocus: () => this.onFocus(), onBlur: () => this.onBlur(), ref: (focusEl) => (this.focusEl = focusEl) }, this.inheritedAttributes)), h("div", { key: '8e70ddd2b4daada4bf16e85e56df9078116933f9', class: {
|
|
194
171
|
'label-text-wrapper': true,
|
|
195
172
|
'label-text-wrapper-hidden': !this.hasLabel,
|
|
196
|
-
}, part: "label" }, h("slot",
|
|
197
|
-
}
|
|
198
|
-
renderLegacyToggle() {
|
|
199
|
-
if (!this.hasLoggedDeprecationWarning) {
|
|
200
|
-
printIonWarning(`ion-toggle now requires providing a label with either the default slot or the "aria-label" attribute. To migrate, remove any usage of "ion-label" and pass the label text to either the component or the "aria-label" attribute.
|
|
201
|
-
|
|
202
|
-
Example: <ion-toggle>Email</ion-toggle>
|
|
203
|
-
Example with aria-label: <ion-toggle aria-label="Email"></ion-toggle>
|
|
204
|
-
|
|
205
|
-
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);
|
|
206
|
-
if (this.legacy) {
|
|
207
|
-
printIonWarning(`ion-toggle 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.
|
|
208
|
-
|
|
209
|
-
Developers can dismiss this warning by removing their usage of the "legacy" property and using the new toggle syntax.`, this.el);
|
|
210
|
-
}
|
|
211
|
-
this.hasLoggedDeprecationWarning = true;
|
|
212
|
-
}
|
|
213
|
-
const { activated, color, checked, disabled, el, inputId, name } = this;
|
|
214
|
-
const mode = getIonMode(this);
|
|
215
|
-
const { label, labelId, labelText } = getAriaLabel(el, inputId);
|
|
216
|
-
const value = this.getValue();
|
|
217
|
-
const rtl = isRTL(el) ? 'rtl' : 'ltr';
|
|
218
|
-
renderHiddenInput(true, el, name, checked ? value : '', disabled);
|
|
219
|
-
return (h(Host, { onClick: this.onClick, "aria-labelledby": label ? labelId : null, "aria-checked": `${checked}`, "aria-hidden": disabled ? 'true' : null, role: "switch", class: createColorClasses(color, {
|
|
220
|
-
[mode]: true,
|
|
221
|
-
'in-item': hostContext('ion-item', el),
|
|
222
|
-
'toggle-activated': activated,
|
|
223
|
-
'toggle-checked': checked,
|
|
224
|
-
'toggle-disabled': disabled,
|
|
225
|
-
'legacy-toggle': true,
|
|
226
|
-
interactive: true,
|
|
227
|
-
[`toggle-${rtl}`]: true,
|
|
228
|
-
}) }, this.renderToggleControl(), h("label", { htmlFor: inputId }, labelText), h("input", { type: "checkbox", role: "switch", "aria-checked": `${checked}`, disabled: disabled, id: inputId, onFocus: () => this.onFocus(), onBlur: () => this.onBlur(), ref: (focusEl) => (this.focusEl = focusEl) })));
|
|
173
|
+
}, part: "label" }, h("slot", { key: 'eae25cdeefe1e6589f06b3a2568522e74cf44d66' })), h("div", { key: 'df9adddd1d8d73c8a23e1e91261d84c876ac5935', class: "native-wrapper" }, this.renderToggleControl()))));
|
|
229
174
|
}
|
|
230
175
|
static get is() { return "ion-toggle"; }
|
|
231
176
|
static get encapsulation() { return "shadow"; }
|
|
@@ -374,23 +319,6 @@ Developers can dismiss this warning by removing their usage of the "legacy" prop
|
|
|
374
319
|
"reflect": false,
|
|
375
320
|
"defaultValue": "'start'"
|
|
376
321
|
},
|
|
377
|
-
"legacy": {
|
|
378
|
-
"type": "boolean",
|
|
379
|
-
"mutable": false,
|
|
380
|
-
"complexType": {
|
|
381
|
-
"original": "boolean",
|
|
382
|
-
"resolved": "boolean | undefined",
|
|
383
|
-
"references": {}
|
|
384
|
-
},
|
|
385
|
-
"required": false,
|
|
386
|
-
"optional": true,
|
|
387
|
-
"docs": {
|
|
388
|
-
"tags": [],
|
|
389
|
-
"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 default slot that contains\nthe label text. As a result, the `legacy` property should only be used as\nan escape hatch when you want to avoid 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."
|
|
390
|
-
},
|
|
391
|
-
"attribute": "legacy",
|
|
392
|
-
"reflect": false
|
|
393
|
-
},
|
|
394
322
|
"justify": {
|
|
395
323
|
"type": "string",
|
|
396
324
|
"mutable": false,
|
|
@@ -486,30 +414,6 @@ Developers can dismiss this warning by removing their usage of the "legacy" prop
|
|
|
486
414
|
"resolved": "void",
|
|
487
415
|
"references": {}
|
|
488
416
|
}
|
|
489
|
-
}, {
|
|
490
|
-
"method": "ionStyle",
|
|
491
|
-
"name": "ionStyle",
|
|
492
|
-
"bubbles": true,
|
|
493
|
-
"cancelable": true,
|
|
494
|
-
"composed": true,
|
|
495
|
-
"docs": {
|
|
496
|
-
"tags": [{
|
|
497
|
-
"name": "internal",
|
|
498
|
-
"text": undefined
|
|
499
|
-
}],
|
|
500
|
-
"text": "Emitted when the styles change."
|
|
501
|
-
},
|
|
502
|
-
"complexType": {
|
|
503
|
-
"original": "StyleEventDetail",
|
|
504
|
-
"resolved": "StyleEventDetail",
|
|
505
|
-
"references": {
|
|
506
|
-
"StyleEventDetail": {
|
|
507
|
-
"location": "import",
|
|
508
|
-
"path": "../../interface",
|
|
509
|
-
"id": "src/interface.d.ts::StyleEventDetail"
|
|
510
|
-
}
|
|
511
|
-
}
|
|
512
|
-
}
|
|
513
417
|
}];
|
|
514
418
|
}
|
|
515
419
|
static get elementRef() { return "el"; }
|
|
@@ -81,7 +81,7 @@
|
|
|
81
81
|
z-index: 2;
|
|
82
82
|
}
|
|
83
83
|
|
|
84
|
-
:host(.in-item
|
|
84
|
+
:host(.in-item) {
|
|
85
85
|
width: 100%;
|
|
86
86
|
height: 100%;
|
|
87
87
|
}
|
|
@@ -92,16 +92,11 @@
|
|
|
92
92
|
* toolbar which is why we do not
|
|
93
93
|
* limit the below behavior to just ion-item.
|
|
94
94
|
*/
|
|
95
|
-
:host([slot=start]
|
|
96
|
-
:host([slot=end]
|
|
95
|
+
:host([slot=start]),
|
|
96
|
+
:host([slot=end]) {
|
|
97
97
|
width: auto;
|
|
98
98
|
}
|
|
99
99
|
|
|
100
|
-
:host(.legacy-toggle) {
|
|
101
|
-
contain: content;
|
|
102
|
-
touch-action: none;
|
|
103
|
-
}
|
|
104
|
-
|
|
105
100
|
:host(.ion-focused) input {
|
|
106
101
|
border: 2px solid #5e9ed6;
|
|
107
102
|
}
|
|
@@ -110,51 +105,6 @@
|
|
|
110
105
|
pointer-events: none;
|
|
111
106
|
}
|
|
112
107
|
|
|
113
|
-
:host(.legacy-toggle) label {
|
|
114
|
-
top: 0;
|
|
115
|
-
margin-left: 0;
|
|
116
|
-
margin-right: 0;
|
|
117
|
-
margin-top: 0;
|
|
118
|
-
margin-bottom: 0;
|
|
119
|
-
position: absolute;
|
|
120
|
-
width: 100%;
|
|
121
|
-
height: 100%;
|
|
122
|
-
border: 0;
|
|
123
|
-
background: transparent;
|
|
124
|
-
cursor: pointer;
|
|
125
|
-
appearance: none;
|
|
126
|
-
outline: none;
|
|
127
|
-
display: flex;
|
|
128
|
-
align-items: center;
|
|
129
|
-
opacity: 0;
|
|
130
|
-
pointer-events: none;
|
|
131
|
-
}
|
|
132
|
-
@supports (inset-inline-start: 0) {
|
|
133
|
-
:host(.legacy-toggle) label {
|
|
134
|
-
inset-inline-start: 0;
|
|
135
|
-
}
|
|
136
|
-
}
|
|
137
|
-
@supports not (inset-inline-start: 0) {
|
|
138
|
-
:host(.legacy-toggle) label {
|
|
139
|
-
left: 0;
|
|
140
|
-
}
|
|
141
|
-
:host-context([dir=rtl]):host(.legacy-toggle) label, :host-context([dir=rtl]).legacy-toggle label {
|
|
142
|
-
left: unset;
|
|
143
|
-
right: unset;
|
|
144
|
-
right: 0;
|
|
145
|
-
}
|
|
146
|
-
@supports selector(:dir(rtl)) {
|
|
147
|
-
:host(.legacy-toggle:dir(rtl)) label {
|
|
148
|
-
left: unset;
|
|
149
|
-
right: unset;
|
|
150
|
-
right: 0;
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
|
-
}
|
|
154
|
-
:host(.legacy-toggle) label::-moz-focus-inner {
|
|
155
|
-
border: 0;
|
|
156
|
-
}
|
|
157
|
-
|
|
158
108
|
input {
|
|
159
109
|
position: absolute;
|
|
160
110
|
top: 0;
|
|
@@ -189,7 +139,7 @@ input {
|
|
|
189
139
|
overflow: hidden;
|
|
190
140
|
}
|
|
191
141
|
|
|
192
|
-
:host(.in-item
|
|
142
|
+
:host(.in-item) .label-text-wrapper {
|
|
193
143
|
margin-top: 10px;
|
|
194
144
|
margin-bottom: 10px;
|
|
195
145
|
}
|
|
@@ -532,10 +482,10 @@ input {
|
|
|
532
482
|
*/
|
|
533
483
|
:host {
|
|
534
484
|
--track-background: rgba(var(--ion-text-color-rgb, 0, 0, 0), 0.39);
|
|
535
|
-
--track-background-checked: rgba(var(--ion-color-primary-rgb,
|
|
485
|
+
--track-background-checked: rgba(var(--ion-color-primary-rgb, 0, 84, 233), 0.5);
|
|
536
486
|
--border-radius: 14px;
|
|
537
487
|
--handle-background: #ffffff;
|
|
538
|
-
--handle-background-checked: var(--ion-color-primary, #
|
|
488
|
+
--handle-background-checked: var(--ion-color-primary, #0054e9);
|
|
539
489
|
--handle-border-radius: 50%;
|
|
540
490
|
--handle-box-shadow: 0 3px 1px -2px rgba(0, 0, 0, 0.2), 0 2px 2px 0 rgba(0, 0, 0, 0.14), 0 1px 5px 0 rgba(0, 0, 0, 0.12);
|
|
541
491
|
--handle-width: 20px;
|
|
@@ -545,18 +495,6 @@ input {
|
|
|
545
495
|
--handle-transition: transform 160ms cubic-bezier(0.4, 0, 0.2, 1), background-color 160ms cubic-bezier(0.4, 0, 0.2, 1);
|
|
546
496
|
}
|
|
547
497
|
|
|
548
|
-
:host(.legacy-toggle) {
|
|
549
|
-
-webkit-padding-start: 12px;
|
|
550
|
-
padding-inline-start: 12px;
|
|
551
|
-
-webkit-padding-end: 12px;
|
|
552
|
-
padding-inline-end: 12px;
|
|
553
|
-
padding-top: 12px;
|
|
554
|
-
padding-bottom: 12px;
|
|
555
|
-
width: 36px;
|
|
556
|
-
height: 14px;
|
|
557
|
-
contain: strict;
|
|
558
|
-
}
|
|
559
|
-
|
|
560
498
|
.native-wrapper .toggle-icon {
|
|
561
499
|
width: 36px;
|
|
562
500
|
height: 14px;
|
|
@@ -599,27 +537,4 @@ input {
|
|
|
599
537
|
|
|
600
538
|
:host(.toggle-disabled) {
|
|
601
539
|
opacity: 0.38;
|
|
602
|
-
}
|
|
603
|
-
|
|
604
|
-
:host(.in-item.legacy-toggle) {
|
|
605
|
-
margin-left: 0;
|
|
606
|
-
margin-right: 0;
|
|
607
|
-
margin-top: 0;
|
|
608
|
-
margin-bottom: 0;
|
|
609
|
-
-webkit-padding-start: 16px;
|
|
610
|
-
padding-inline-start: 16px;
|
|
611
|
-
-webkit-padding-end: 0;
|
|
612
|
-
padding-inline-end: 0;
|
|
613
|
-
padding-top: 12px;
|
|
614
|
-
padding-bottom: 12px;
|
|
615
|
-
cursor: pointer;
|
|
616
|
-
}
|
|
617
|
-
|
|
618
|
-
:host(.in-item.legacy-toggle[slot=start]) {
|
|
619
|
-
-webkit-padding-start: 2px;
|
|
620
|
-
padding-inline-start: 2px;
|
|
621
|
-
-webkit-padding-end: 18px;
|
|
622
|
-
padding-inline-end: 18px;
|
|
623
|
-
padding-top: 12px;
|
|
624
|
-
padding-bottom: 12px;
|
|
625
540
|
}
|
|
@@ -198,9 +198,9 @@
|
|
|
198
198
|
* }
|
|
199
199
|
*/
|
|
200
200
|
:host {
|
|
201
|
-
--background: var(--ion-toolbar-background, var(--ion-color-step-50, #f7f7f7));
|
|
201
|
+
--background: var(--ion-toolbar-background, var(--ion-color-step-50, var(--ion-background-color-step-50, #f7f7f7)));
|
|
202
202
|
--color: var(--ion-toolbar-color, var(--ion-text-color, #000));
|
|
203
|
-
--border-color: var(--ion-toolbar-border-color, var(--ion-border-color, var(--ion-color-step-150, rgba(0, 0, 0, 0.2))));
|
|
203
|
+
--border-color: var(--ion-toolbar-border-color, var(--ion-border-color, var(--ion-color-step-150, var(--ion-background-color-step-150, rgba(0, 0, 0, 0.2)))));
|
|
204
204
|
--padding-top: 3px;
|
|
205
205
|
--padding-bottom: 3px;
|
|
206
206
|
--padding-start: 4px;
|
|
@@ -62,10 +62,10 @@ export class Toolbar {
|
|
|
62
62
|
this.childrenStyles.forEach((value) => {
|
|
63
63
|
Object.assign(childStyles, value);
|
|
64
64
|
});
|
|
65
|
-
return (h(Host, { key: '
|
|
65
|
+
return (h(Host, { key: 'f72d6a7ed20c88ba15d64050acfc20f320569862', class: Object.assign(Object.assign({}, childStyles), createColorClasses(this.color, {
|
|
66
66
|
[mode]: true,
|
|
67
67
|
'in-toolbar': hostContext('ion-toolbar', this.el),
|
|
68
|
-
})) }, h("div", { key: '
|
|
68
|
+
})) }, h("div", { key: 'ccf18eea9756ca56ca828b05bd3f86cf8a32e24c', class: "toolbar-background" }), h("div", { key: '1fa699d8e17f57b42a52d47a1bdb793f2cbbfe5d', class: "toolbar-container" }, h("slot", { key: 'ef4d877bad0918eefdc67fa7aa258024a58d26ef', name: "start" }), h("slot", { key: '41858db7a8d58c9165952c9336731d621ec3c2b8', name: "secondary" }), h("div", { key: '577770b9346b48a0fa1412cbdbd9393d553d2286', class: "toolbar-content" }, h("slot", { key: 'ae47b29e1f7d2c3dde7a170c9737b48f075139c2' })), h("slot", { key: 'cfbf7879daf1a38fee434335abff936d8f3690e0', name: "primary" }), h("slot", { key: 'ed3a66248f43e0749f6aef9fb78ea4f5034c0774', name: "end" }))));
|
|
69
69
|
}
|
|
70
70
|
static get is() { return "ion-toolbar"; }
|
|
71
71
|
static get encapsulation() { return "shadow"; }
|
|
@@ -200,7 +200,7 @@
|
|
|
200
200
|
:host {
|
|
201
201
|
--background: var(--ion-toolbar-background, var(--ion-background-color, #fff));
|
|
202
202
|
--color: var(--ion-toolbar-color, var(--ion-text-color, #424242));
|
|
203
|
-
--border-color: var(--ion-toolbar-border-color, var(--ion-border-color, var(--ion-color-step-150, #c1c4cd)));
|
|
203
|
+
--border-color: var(--ion-toolbar-border-color, var(--ion-border-color, var(--ion-color-step-150, var(--ion-background-color-step-150, #c1c4cd))));
|
|
204
204
|
--padding-top: 0;
|
|
205
205
|
--padding-bottom: 0;
|
|
206
206
|
--padding-start: 0;
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
/*!
|
|
2
2
|
* (C) Ionic http://ionicframework.com - MIT License
|
|
3
3
|
*/
|
|
4
|
+
import AxeBuilder from "@axe-core/playwright";
|
|
4
5
|
import { expect } from "@playwright/test";
|
|
5
6
|
import { configs, test } from "../../../utils/test/playwright/index";
|
|
6
7
|
configs({ directions: ['ltr'], modes: ['ios'] }).forEach(({ title, screenshot, config }) => {
|
|
@@ -30,3 +31,20 @@ configs({ directions: ['ltr'], modes: ['ios'] }).forEach(({ title, screenshot, c
|
|
|
30
31
|
});
|
|
31
32
|
});
|
|
32
33
|
});
|
|
34
|
+
configs({ directions: ['ltr'], themes: ['light', 'dark'] }).forEach(({ config, title }) => {
|
|
35
|
+
test.describe(title('typography: a11y'), () => {
|
|
36
|
+
test('should not have accessibility violations for anchor tags', async ({ page }) => {
|
|
37
|
+
/**
|
|
38
|
+
* All page content should be contained by landmarks (main, nav, etc.)
|
|
39
|
+
* By containing the badge in a main element, we can avoid this violation.
|
|
40
|
+
*/
|
|
41
|
+
await page.setContent(`
|
|
42
|
+
<main>
|
|
43
|
+
<a href="#">Link</a>
|
|
44
|
+
</main>
|
|
45
|
+
`, config);
|
|
46
|
+
const results = await new AxeBuilder({ page }).analyze();
|
|
47
|
+
expect(results.violations).toEqual([]);
|
|
48
|
+
});
|
|
49
|
+
});
|
|
50
|
+
});
|
|
@@ -0,0 +1,170 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* (C) Ionic http://ionicframework.com - MIT License
|
|
3
|
+
*/
|
|
4
|
+
import AxeBuilder from "@axe-core/playwright";
|
|
5
|
+
import { expect } from "@playwright/test";
|
|
6
|
+
import { configs, test } from "../../../utils/test/playwright/index";
|
|
7
|
+
/**
|
|
8
|
+
* Small text is defined as 14pt (~18.5px)
|
|
9
|
+
* when computing color contrast: https://www.w3.org/WAI/WCAG21/Understanding/contrast-minimum.html
|
|
10
|
+
*/
|
|
11
|
+
const styleTestHelpers = `
|
|
12
|
+
<style>
|
|
13
|
+
main {
|
|
14
|
+
background: var(--ion-color-contrast);
|
|
15
|
+
font-size: 14pt;
|
|
16
|
+
}
|
|
17
|
+
.ion-background {
|
|
18
|
+
background: var(--ion-color-base);
|
|
19
|
+
}
|
|
20
|
+
.ion-background-shade {
|
|
21
|
+
background: var(--ion-color-shade);
|
|
22
|
+
}
|
|
23
|
+
.ion-background-tint {
|
|
24
|
+
background: var(--ion-color-tint);
|
|
25
|
+
}
|
|
26
|
+
.ion-background-opacity-08 {
|
|
27
|
+
background: rgba(var(--ion-color-base-rgb), 0.08);
|
|
28
|
+
}
|
|
29
|
+
.ion-background-opacity-12 {
|
|
30
|
+
background: rgba(var(--ion-color-base-rgb), 0.12);
|
|
31
|
+
}
|
|
32
|
+
.ion-background-opacity-16 {
|
|
33
|
+
background: rgba(var(--ion-color-base-rgb), 0.16);
|
|
34
|
+
}
|
|
35
|
+
.ion-color {
|
|
36
|
+
color: var(--ion-color-base);
|
|
37
|
+
}
|
|
38
|
+
.ion-color-contrast {
|
|
39
|
+
color: var(--ion-color-contrast);
|
|
40
|
+
}
|
|
41
|
+
</style>
|
|
42
|
+
`;
|
|
43
|
+
/**
|
|
44
|
+
* All colors should be tested in the following scenarios:
|
|
45
|
+
* 1) The base color as the text color against the contrast color as the background color
|
|
46
|
+
* 2) The contrast color as the text color against the base color as the background color
|
|
47
|
+
* 3) The contrast color as the text color against the shade color as the background color
|
|
48
|
+
* 4) The contrast color as the text color against the tint color as the background color
|
|
49
|
+
* 5) The base color as the text color against the base color at 0.08 opacity as the background color
|
|
50
|
+
* 6) The base color as the text color against the base color at 0.12 opacity as the background color
|
|
51
|
+
* 7) The base color as the text color against the base color at 0.16 opacity as the background color
|
|
52
|
+
*/
|
|
53
|
+
configs({ modes: ['md'], directions: ['ltr'], themes: ['light', 'dark'] }).forEach(({ config, title }) => {
|
|
54
|
+
const colors = ['primary', 'secondary', 'tertiary', 'success', 'warning', 'danger', 'light', 'medium', 'dark'];
|
|
55
|
+
test.describe(title('theme'), () => {
|
|
56
|
+
test.beforeEach(({ skip }) => {
|
|
57
|
+
skip.browser('firefox', 'Color contrast ratio is consistent across browsers');
|
|
58
|
+
skip.browser('webkit', 'Color contrast ratio is consistent across browsers');
|
|
59
|
+
});
|
|
60
|
+
for (const color of colors) {
|
|
61
|
+
test(`color "${color}" should pass AA guidelines`, async ({ page }) => {
|
|
62
|
+
await page.setContent(`${styleTestHelpers}
|
|
63
|
+
<main class="ion-color-${color}">
|
|
64
|
+
<p class="ion-color">Hello World</p>
|
|
65
|
+
</main>`, config);
|
|
66
|
+
const results = await new AxeBuilder({ page }).analyze();
|
|
67
|
+
expect(results.violations).toEqual([]);
|
|
68
|
+
});
|
|
69
|
+
test(`contrast color on "${color}" background should pass AA guidelines`, async ({ page }) => {
|
|
70
|
+
await page.setContent(`${styleTestHelpers}
|
|
71
|
+
<main class="ion-color-${color}">
|
|
72
|
+
<p class="ion-color-contrast ion-background">Hello World</p>
|
|
73
|
+
</main>`, config);
|
|
74
|
+
const results = await new AxeBuilder({ page }).analyze();
|
|
75
|
+
expect(results.violations).toEqual([]);
|
|
76
|
+
});
|
|
77
|
+
test(`contrast color on "${color}" background shade should pass AA guidelines`, async ({ page }) => {
|
|
78
|
+
await page.setContent(`${styleTestHelpers}
|
|
79
|
+
<main class="ion-color-${color}">
|
|
80
|
+
<p class="ion-color-contrast ion-background-shade">Hello World</p>
|
|
81
|
+
</main>`, config);
|
|
82
|
+
const results = await new AxeBuilder({ page }).analyze();
|
|
83
|
+
expect(results.violations).toEqual([]);
|
|
84
|
+
});
|
|
85
|
+
test(`contrast color on "${color}" background tint should pass AA guidelines`, async ({ page }) => {
|
|
86
|
+
await page.setContent(`${styleTestHelpers}
|
|
87
|
+
<main class="ion-color-${color}">
|
|
88
|
+
<p class="ion-color-contrast ion-background-tint">Hello World</p>
|
|
89
|
+
</main>`, config);
|
|
90
|
+
const results = await new AxeBuilder({ page }).analyze();
|
|
91
|
+
expect(results.violations).toEqual([]);
|
|
92
|
+
});
|
|
93
|
+
test(`color "${color}" on 0.08 opacity background should pass AA guidelines`, async ({ page }) => {
|
|
94
|
+
await page.setContent(`${styleTestHelpers}
|
|
95
|
+
<main class="ion-color-${color}">
|
|
96
|
+
<p class="ion-color ion-background-opacity-08">Hello World</p>
|
|
97
|
+
</main>`, config);
|
|
98
|
+
const results = await new AxeBuilder({ page }).analyze();
|
|
99
|
+
expect(results.violations).toEqual([]);
|
|
100
|
+
});
|
|
101
|
+
test(`color "${color}" on 0.12 opacity background should pass AA guidelines`, async ({ page }) => {
|
|
102
|
+
await page.setContent(`${styleTestHelpers}
|
|
103
|
+
<main class="ion-color-${color}">
|
|
104
|
+
<p class="ion-color ion-background-opacity-12">Hello World</p>
|
|
105
|
+
</main>`, config);
|
|
106
|
+
const results = await new AxeBuilder({ page }).analyze();
|
|
107
|
+
expect(results.violations).toEqual([]);
|
|
108
|
+
});
|
|
109
|
+
test(`color "${color}" on 0.16 opacity background should pass AA guidelines`, async ({ page }) => {
|
|
110
|
+
await page.setContent(`${styleTestHelpers}
|
|
111
|
+
<main class="ion-color-${color}">
|
|
112
|
+
<p class="ion-color ion-background-opacity-16">Hello World</p>
|
|
113
|
+
</main>`, config);
|
|
114
|
+
const results = await new AxeBuilder({ page }).analyze();
|
|
115
|
+
expect(results.violations).toEqual([]);
|
|
116
|
+
});
|
|
117
|
+
}
|
|
118
|
+
});
|
|
119
|
+
});
|
|
120
|
+
configs({ modes: ['md'], directions: ['ltr'], themes: ['high-contrast', 'high-contrast-dark'] }).forEach(({ config, title }) => {
|
|
121
|
+
const colors = ['primary', 'secondary', 'tertiary', 'success', 'warning', 'danger', 'light', 'medium', 'dark'];
|
|
122
|
+
test.describe(title('theme'), () => {
|
|
123
|
+
test.beforeEach(({ skip }) => {
|
|
124
|
+
skip.browser('firefox', 'Color contrast ratio is consistent across browsers');
|
|
125
|
+
skip.browser('webkit', 'Color contrast ratio is consistent across browsers');
|
|
126
|
+
});
|
|
127
|
+
for (const color of colors) {
|
|
128
|
+
test(`color "${color}" should pass AAA guidelines`, async ({ page }) => {
|
|
129
|
+
await page.setContent(`${styleTestHelpers}
|
|
130
|
+
<main class="ion-color-${color}">
|
|
131
|
+
<p class="ion-color">Hello World</p>
|
|
132
|
+
</main>`, config);
|
|
133
|
+
const results = await new AxeBuilder({ page })
|
|
134
|
+
.options({ rules: { 'color-contrast-enhanced': { enabled: true } } })
|
|
135
|
+
.analyze();
|
|
136
|
+
expect(results.violations).toEqual([]);
|
|
137
|
+
});
|
|
138
|
+
test(`contrast color on "${color}" background should pass AAA guidelines`, async ({ page }) => {
|
|
139
|
+
await page.setContent(`${styleTestHelpers}
|
|
140
|
+
<main class="ion-color-${color}">
|
|
141
|
+
<p class="ion-color-contrast ion-background">Hello World</p>
|
|
142
|
+
</main>`, config);
|
|
143
|
+
const results = await new AxeBuilder({ page })
|
|
144
|
+
.options({ rules: { 'color-contrast-enhanced': { enabled: true } } })
|
|
145
|
+
.analyze();
|
|
146
|
+
expect(results.violations).toEqual([]);
|
|
147
|
+
});
|
|
148
|
+
test(`contrast color on "${color}" background shade should pass AAA guidelines`, async ({ page }) => {
|
|
149
|
+
await page.setContent(`${styleTestHelpers}
|
|
150
|
+
<main class="ion-color-${color}">
|
|
151
|
+
<p class="ion-color-contrast ion-background-shade">Hello World</p>
|
|
152
|
+
</main>`, config);
|
|
153
|
+
const results = await new AxeBuilder({ page })
|
|
154
|
+
.options({ rules: { 'color-contrast-enhanced': { enabled: true } } })
|
|
155
|
+
.analyze();
|
|
156
|
+
expect(results.violations).toEqual([]);
|
|
157
|
+
});
|
|
158
|
+
test(`contrast color on "${color}" background tint should pass AAA guidelines`, async ({ page }) => {
|
|
159
|
+
await page.setContent(`${styleTestHelpers}
|
|
160
|
+
<main class="ion-color-${color}">
|
|
161
|
+
<p class="ion-color-contrast ion-background-tint">Hello World</p>
|
|
162
|
+
</main>`, config);
|
|
163
|
+
const results = await new AxeBuilder({ page })
|
|
164
|
+
.options({ rules: { 'color-contrast-enhanced': { enabled: true } } })
|
|
165
|
+
.analyze();
|
|
166
|
+
expect(results.violations).toEqual([]);
|
|
167
|
+
});
|
|
168
|
+
}
|
|
169
|
+
});
|
|
170
|
+
});
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
/*!
|
|
2
|
+
* (C) Ionic http://ionicframework.com - MIT License
|
|
3
|
+
*/
|
|
4
|
+
import { focusVisibleElement } from "./helpers";
|
|
5
|
+
/**
|
|
6
|
+
* This query string selects elements that
|
|
7
|
+
* are eligible to receive focus. We select
|
|
8
|
+
* interactive elements that meet the following
|
|
9
|
+
* criteria:
|
|
10
|
+
* 1. Element does not have a negative tabindex
|
|
11
|
+
* 2. Element does not have `hidden`
|
|
12
|
+
* 3. Element does not have `disabled` for non-Ionic components.
|
|
13
|
+
* 4. Element does not have `disabled` or `disabled="true"` for Ionic components.
|
|
14
|
+
* Note: We need this distinction because `disabled="false"` is
|
|
15
|
+
* valid usage for the disabled property on ion-button.
|
|
16
|
+
*/
|
|
17
|
+
export const focusableQueryString = '[tabindex]:not([tabindex^="-"]):not([hidden]):not([disabled]), input:not([type=hidden]):not([tabindex^="-"]):not([hidden]):not([disabled]), textarea:not([tabindex^="-"]):not([hidden]):not([disabled]), button:not([tabindex^="-"]):not([hidden]):not([disabled]), select:not([tabindex^="-"]):not([hidden]):not([disabled]), .ion-focusable:not([tabindex^="-"]):not([hidden]):not([disabled]), .ion-focusable[disabled="false"]:not([tabindex^="-"]):not([hidden])';
|
|
18
|
+
/**
|
|
19
|
+
* Focuses the first descendant in a context
|
|
20
|
+
* that can receive focus. If none exists,
|
|
21
|
+
* a fallback element will be focused.
|
|
22
|
+
* This fallback is typically an ancestor
|
|
23
|
+
* container such as a menu or overlay so focus does not
|
|
24
|
+
* leave the container we are trying to trap focus in.
|
|
25
|
+
*
|
|
26
|
+
* If no fallback is specified then we focus the container itself.
|
|
27
|
+
*/
|
|
28
|
+
export const focusFirstDescendant = (ref, fallbackElement) => {
|
|
29
|
+
const firstInput = ref.querySelector(focusableQueryString);
|
|
30
|
+
focusElementInContext(firstInput, fallbackElement !== null && fallbackElement !== void 0 ? fallbackElement : ref);
|
|
31
|
+
};
|
|
32
|
+
/**
|
|
33
|
+
* Focuses the last descendant in a context
|
|
34
|
+
* that can receive focus. If none exists,
|
|
35
|
+
* a fallback element will be focused.
|
|
36
|
+
* This fallback is typically an ancestor
|
|
37
|
+
* container such as a menu or overlay so focus does not
|
|
38
|
+
* leave the container we are trying to trap focus in.
|
|
39
|
+
*
|
|
40
|
+
* If no fallback is specified then we focus the container itself.
|
|
41
|
+
*/
|
|
42
|
+
export const focusLastDescendant = (ref, fallbackElement) => {
|
|
43
|
+
const inputs = Array.from(ref.querySelectorAll(focusableQueryString));
|
|
44
|
+
const lastInput = inputs.length > 0 ? inputs[inputs.length - 1] : null;
|
|
45
|
+
focusElementInContext(lastInput, fallbackElement !== null && fallbackElement !== void 0 ? fallbackElement : ref);
|
|
46
|
+
};
|
|
47
|
+
/**
|
|
48
|
+
* Focuses a particular element in a context. If the element
|
|
49
|
+
* doesn't have anything focusable associated with it then
|
|
50
|
+
* a fallback element will be focused.
|
|
51
|
+
*
|
|
52
|
+
* This fallback is typically an ancestor
|
|
53
|
+
* container such as a menu or overlay so focus does not
|
|
54
|
+
* leave the container we are trying to trap focus in.
|
|
55
|
+
* This should be used instead of the focus() method
|
|
56
|
+
* on most elements because the focusable element
|
|
57
|
+
* may not be the host element.
|
|
58
|
+
*
|
|
59
|
+
* For example, if an ion-button should be focused
|
|
60
|
+
* then we should actually focus the native <button>
|
|
61
|
+
* element inside of ion-button's shadow root, not
|
|
62
|
+
* the host element itself.
|
|
63
|
+
*/
|
|
64
|
+
const focusElementInContext = (hostToFocus, fallbackElement) => {
|
|
65
|
+
let elementToFocus = hostToFocus;
|
|
66
|
+
const shadowRoot = hostToFocus === null || hostToFocus === void 0 ? void 0 : hostToFocus.shadowRoot;
|
|
67
|
+
if (shadowRoot) {
|
|
68
|
+
// If there are no inner focusable elements, just focus the host element.
|
|
69
|
+
elementToFocus = shadowRoot.querySelector(focusableQueryString) || hostToFocus;
|
|
70
|
+
}
|
|
71
|
+
if (elementToFocus) {
|
|
72
|
+
focusVisibleElement(elementToFocus);
|
|
73
|
+
}
|
|
74
|
+
else {
|
|
75
|
+
// Focus fallback element instead of letting focus escape
|
|
76
|
+
fallbackElement.focus();
|
|
77
|
+
}
|
|
78
|
+
};
|
|
@@ -12,7 +12,7 @@ export const createButtonActiveGesture = (el, isButton) => {
|
|
|
12
12
|
return;
|
|
13
13
|
}
|
|
14
14
|
const target = document.elementFromPoint(x, y);
|
|
15
|
-
if (!target || !isButton(target)) {
|
|
15
|
+
if (!target || !isButton(target) || target.disabled) {
|
|
16
16
|
clearActiveButton();
|
|
17
17
|
return;
|
|
18
18
|
}
|