@duetds/components 8.6.8 → 8.7.0
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/hydrate/index.d.ts +30 -12
- package/hydrate/index.js +33069 -23517
- package/lib/cjs/{app-globals-aece069f.js → app-globals-44f2c7a3.js} +2 -0
- package/lib/cjs/duet-action-button.cjs.entry.js +5 -4
- package/lib/cjs/duet-alert.cjs.entry.js +10 -9
- package/lib/cjs/duet-badge.cjs.entry.js +5 -4
- package/lib/cjs/duet-banner.cjs.entry.js +6 -5
- package/lib/cjs/duet-breadcrumb.cjs.entry.js +8 -7
- package/lib/cjs/duet-breadcrumbs.cjs.entry.js +6 -5
- package/lib/cjs/duet-button_2.cjs.entry.js +13 -11
- package/lib/cjs/duet-callout.cjs.entry.js +6 -5
- package/lib/cjs/duet-caption_4.cjs.entry.js +18 -14
- package/lib/cjs/duet-card.cjs.entry.js +6 -5
- package/lib/cjs/duet-checkbox.cjs.entry.js +3 -2
- package/lib/cjs/duet-checkmark.cjs.entry.js +5 -4
- package/lib/cjs/duet-chip.cjs.entry.js +4 -3
- package/lib/cjs/duet-choice_2.cjs.entry.js +7 -5
- package/lib/cjs/duet-collapsible.cjs.entry.js +6 -5
- package/lib/cjs/duet-combobox.cjs.entry.js +5 -4
- package/lib/cjs/duet-contact-card.cjs.entry.js +6 -5
- package/lib/cjs/duet-cookie-consent.cjs.entry.js +4 -3
- package/lib/cjs/duet-date-picker.cjs.entry.js +6 -5
- package/lib/cjs/duet-divider_2.cjs.entry.js +7 -5
- package/lib/cjs/duet-editable-table_3.cjs.entry.js +13 -10
- package/lib/cjs/duet-empty-state.cjs.entry.js +5 -4
- package/lib/cjs/duet-fieldset.cjs.entry.js +7 -6
- package/lib/cjs/duet-file-chooser.cjs.entry.js +4 -3
- package/lib/cjs/duet-footer.cjs.entry.js +9 -8
- package/lib/cjs/duet-grid_2.cjs.entry.js +5 -3
- package/lib/cjs/duet-header_2.cjs.entry.js +7 -5
- package/lib/cjs/duet-hero.cjs.entry.js +10 -9
- package/lib/cjs/duet-icon.cjs.entry.js +6 -5
- package/lib/cjs/duet-input_2.cjs.entry.js +7 -5
- package/lib/cjs/duet-layout.cjs.entry.js +8 -7
- package/lib/cjs/duet-list_2.cjs.entry.js +8 -6
- package/lib/cjs/duet-menu-bar-button.cjs.entry.js +5 -4
- package/lib/cjs/duet-menu-bar-dropdown-link.cjs.entry.js +5 -4
- package/lib/cjs/duet-menu-bar-dropdown.cjs.entry.js +7 -6
- package/lib/cjs/duet-menu-bar-item.cjs.entry.js +5 -4
- package/lib/cjs/duet-menu-bar-link.cjs.entry.js +5 -4
- package/lib/cjs/duet-menu-bar.cjs.entry.js +5 -4
- package/lib/cjs/duet-modal.cjs.entry.js +17 -14
- package/lib/cjs/duet-multiselect.cjs.entry.js +11 -10
- package/lib/cjs/duet-nav.cjs.entry.js +4 -3
- package/lib/cjs/duet-notification_2.cjs.entry.js +10 -8
- package/lib/cjs/duet-number-input.cjs.entry.js +5 -4
- package/lib/cjs/duet-overlay.cjs.entry.js +4 -3
- package/lib/cjs/duet-page-heading.cjs.entry.js +5 -4
- package/lib/cjs/duet-pagination_2.cjs.entry.js +19 -17
- package/lib/cjs/duet-popup-menu-item.cjs.entry.js +4 -3
- package/lib/cjs/duet-popup-menu.cjs.entry.js +5 -4
- package/lib/cjs/duet-progress.cjs.entry.js +4 -3
- package/lib/cjs/duet-promo-card.cjs.entry.js +6 -5
- package/lib/cjs/duet-radio_2.cjs.entry.js +6 -4
- package/lib/cjs/duet-range-slider.cjs.entry.js +3 -2
- package/lib/cjs/duet-scrollable_3.cjs.entry.js +44 -23
- package/lib/cjs/duet-section-layout.cjs.entry.js +6 -5
- package/lib/cjs/duet-select.cjs.entry.js +4 -3
- package/lib/cjs/duet-shaped-image.cjs.entry.js +5 -4
- package/lib/cjs/duet-show-more.cjs.entry.js +6 -5
- package/lib/cjs/duet-slideout-lang.cjs.entry.js +5 -4
- package/lib/cjs/duet-slideout-link.cjs.entry.js +5 -4
- package/lib/cjs/duet-slideout-panel-dropdown.cjs.entry.js +7 -6
- package/lib/cjs/duet-slideout-panel.cjs.entry.js +12 -11
- package/lib/cjs/duet-slideout.cjs.entry.js +10 -9
- package/lib/cjs/duet-step_2.cjs.entry.js +6 -4
- package/lib/cjs/duet-submenu-bar-dropdown-link.cjs.entry.js +5 -4
- package/lib/cjs/duet-submenu-bar-dropdown.cjs.entry.js +7 -6
- package/lib/cjs/duet-submenu-bar-item.cjs.entry.js +4 -3
- package/lib/cjs/duet-submenu-bar-link.cjs.entry.js +4 -3
- package/lib/cjs/duet-submenu-bar.cjs.entry.js +7 -6
- package/lib/cjs/duet-textarea.cjs.entry.js +4 -3
- package/lib/cjs/duet-toggle.cjs.entry.js +3 -2
- package/lib/cjs/duet-toolbar-dropdown-link.cjs.entry.js +5 -4
- package/lib/cjs/duet-toolbar-dropdown.cjs.entry.js +7 -6
- package/lib/cjs/duet-toolbar-item.cjs.entry.js +5 -4
- package/lib/cjs/duet-toolbar-link.cjs.entry.js +5 -4
- package/lib/cjs/duet-toolbar.cjs.entry.js +4 -3
- package/lib/cjs/duet-tooltip-button_2.cjs.entry.js +10 -8
- package/lib/cjs/duet-tooltip.cjs.entry.js +4 -3
- package/lib/cjs/duet-tray.cjs.entry.js +6 -5
- package/lib/cjs/duet-upload-aria-status.cjs.entry.js +2 -2
- package/lib/cjs/duet-upload-item.cjs.entry.js +7 -6
- package/lib/cjs/duet-visually-hidden.cjs.entry.js +4 -3
- package/lib/cjs/duet.cjs.js +15 -15
- package/lib/cjs/{errorcodes.utils-a86b1f94.js → errorcodes.utils-d9f472df.js} +1 -1
- package/lib/cjs/{focus-utils-f04d6c12.js → focus-utils-2de8d5de.js} +1 -1
- package/lib/cjs/index-7efe7e19.js +1996 -0
- package/lib/cjs/{language-utils-e8a527e5.js → language-utils-1ed4b266.js} +1 -0
- package/lib/cjs/loader.cjs.js +4 -4
- package/lib/cjs/{slot-utils-03a40c78.js → slot-utils-0664e341.js} +2 -0
- package/lib/collection/collection-manifest.json +2 -2
- package/lib/collection/components/duet-action-button/duet-action-button.js +1 -1
- package/lib/collection/components/duet-alert/duet-alert.js +5 -5
- package/lib/collection/components/duet-badge/duet-badge.js +2 -2
- package/lib/collection/components/duet-banner/duet-banner.js +2 -2
- package/lib/collection/components/duet-breadcrumbs/duet-breadcrumb.js +4 -4
- package/lib/collection/components/duet-breadcrumbs/duet-breadcrumbs.js +2 -2
- package/lib/collection/components/duet-button/duet-button.js +5 -5
- package/lib/collection/components/duet-callout/duet-callout.js +2 -2
- package/lib/collection/components/duet-caption/duet-caption.js +2 -2
- package/lib/collection/components/duet-card/duet-card.js +3 -3
- package/lib/collection/components/duet-chip/duet-chip.js +1 -1
- package/lib/collection/components/duet-choice/duet-checkmark.js +2 -2
- package/lib/collection/components/duet-collapsible/duet-collapsible.js +2 -2
- package/lib/collection/components/duet-contact-card/duet-contact-card.js +2 -2
- package/lib/collection/components/duet-cookie-consent/duet-cookie-consent.js +1 -1
- package/lib/collection/components/duet-divider/duet-divider.js +1 -1
- package/lib/collection/components/duet-empty-state/duet-empty-state.js +2 -2
- package/lib/collection/components/duet-fieldset/duet-fieldset.js +3 -3
- package/lib/collection/components/duet-file-chooser/duet-file-chooser.js +1 -1
- package/lib/collection/components/duet-footer/duet-footer.js +4 -4
- package/lib/collection/components/duet-heading/duet-heading.js +2 -2
- package/lib/collection/components/duet-hero/duet-hero.js +5 -5
- package/lib/collection/components/duet-icon/duet-icon.js +3 -3
- package/lib/collection/components/duet-layout/duet-layout.js +5 -5
- package/lib/collection/components/duet-link/duet-link.js +2 -2
- package/lib/collection/components/duet-list/duet-list.js +1 -1
- package/lib/collection/components/duet-list-item/duet-list-item.js +2 -2
- package/lib/collection/components/duet-logo/duet-logo.js +1 -1
- package/lib/collection/components/duet-menu-bar/duet-menu-bar.js +2 -2
- package/lib/collection/components/duet-menu-bar-button/duet-menu-bar-button.js +2 -2
- package/lib/collection/components/duet-menu-bar-dropdown/duet-menu-bar-dropdown.js +4 -4
- package/lib/collection/components/duet-menu-bar-dropdown-link/duet-menu-bar-dropdown-link.js +2 -2
- package/lib/collection/components/duet-menu-bar-item/duet-menu-bar-item.js +2 -2
- package/lib/collection/components/duet-menu-bar-link/duet-menu-bar-link.js +2 -2
- package/lib/collection/components/duet-modal/duet-modal.css +6 -0
- package/lib/collection/components/duet-modal/duet-modal.js +10 -8
- package/lib/collection/components/duet-multiselect/duet-multiselect.js +6 -6
- package/lib/collection/components/duet-nav/duet-nav.js +1 -1
- package/lib/collection/components/duet-notification/duet-notification.js +2 -2
- package/lib/collection/components/duet-notification-drawer/duet-notification-drawer.js +2 -2
- package/lib/collection/components/duet-overlay/duet-overlay.js +1 -1
- package/lib/collection/components/duet-page-heading/duet-page-heading.js +2 -2
- package/lib/collection/components/duet-pagination/duet-pagination.js +11 -11
- package/lib/collection/components/duet-paragraph/duet-paragraph.js +2 -2
- package/lib/collection/components/duet-popup-menu/duet-popup-menu.js +1 -1
- package/lib/collection/components/duet-popup-menu-item/duet-popup-menu-item.js +1 -1
- package/lib/collection/components/duet-promo-card/duet-promo-card.js +2 -2
- package/lib/collection/components/duet-range-stepper/duet-range-stepper.js +2 -2
- package/lib/collection/components/duet-scrollable/duet-scrollable.css +39 -9
- package/lib/collection/components/duet-scrollable/duet-scrollable.js +29 -11
- package/lib/collection/components/duet-section-layout/duet-section-layout.js +3 -3
- package/lib/collection/components/duet-shaped-image/duet-shaped-image.js +2 -2
- package/lib/collection/components/duet-show-more/duet-show-more.js +2 -2
- package/lib/collection/components/duet-slideout/duet-slideout.js +4 -4
- package/lib/collection/components/duet-slideout-lang/duet-slideout-lang.js +1 -1
- package/lib/collection/components/duet-slideout-link/duet-slideout-link.js +2 -2
- package/lib/collection/components/duet-slideout-panel/duet-slideout-panel.js +6 -6
- package/lib/collection/components/duet-slideout-panel-dropdown/duet-slideout-panel-dropdown.js +4 -4
- package/lib/collection/components/duet-spacer/duet-spacer.js +1 -1
- package/lib/collection/components/duet-spinner/duet-spinner.js +2 -2
- package/lib/collection/components/duet-stepper/duet-stepper.js +1 -1
- package/lib/collection/components/duet-submenu-bar/duet-submenu-bar.js +4 -4
- package/lib/collection/components/duet-submenu-bar-dropdown/duet-submenu-bar-dropdown.js +4 -4
- package/lib/collection/components/duet-submenu-bar-dropdown-link/duet-submenu-bar-dropdown-link.js +2 -2
- package/lib/collection/components/duet-submenu-bar-item/duet-submenu-bar-item.js +1 -1
- package/lib/collection/components/duet-submenu-bar-link/duet-submenu-bar-link.js +1 -1
- package/lib/collection/components/duet-tab-group/duet-tab-group.js +5 -5
- package/lib/collection/components/duet-table/duet-table.js +2 -2
- package/lib/collection/components/duet-toolbar/duet-toolbar.js +1 -1
- package/lib/collection/components/duet-toolbar-dropdown/duet-toolbar-dropdown.js +4 -4
- package/lib/collection/components/duet-toolbar-dropdown-link/duet-toolbar-dropdown-link.js +2 -2
- package/lib/collection/components/duet-toolbar-item/duet-toolbar-item.js +2 -2
- package/lib/collection/components/duet-toolbar-link/duet-toolbar-link.js +2 -2
- package/lib/collection/components/duet-tooltip/duet-tooltip-button.js +2 -2
- package/lib/collection/components/duet-tooltip/duet-tooltip-popup.js +2 -2
- package/lib/collection/components/duet-tray/duet-tray.js +2 -2
- package/lib/collection/components/duet-upload/duet-upload.js +2 -2
- package/lib/collection/components/duet-upload/mock.helpers.js +6 -4
- package/lib/collection/components/duet-upload-aria-status/duet-upload-aria-status.js +1 -1
- package/lib/collection/components/duet-upload-item/duet-upload-item.js +3 -3
- package/lib/collection/components/duet-visually-hidden/duet-visually-hidden.js +1 -1
- package/lib/collection/utils/axe-core-utils.js +12 -4
- package/lib/collection/utils/test-utils.js +82 -32
- package/lib/dist-custom-elements/duet-action-button.js +1 -1
- package/lib/dist-custom-elements/duet-alert.js +1 -1
- package/lib/dist-custom-elements/duet-badge.js +1 -1
- package/lib/dist-custom-elements/duet-banner.js +9 -8
- package/lib/dist-custom-elements/duet-breadcrumb.js +10 -9
- package/lib/dist-custom-elements/duet-breadcrumbs.js +6 -5
- package/lib/dist-custom-elements/duet-button.js +1 -1
- package/lib/dist-custom-elements/duet-callout.js +7 -6
- package/lib/dist-custom-elements/duet-caption.js +1 -1
- package/lib/dist-custom-elements/duet-card.js +8 -7
- package/lib/dist-custom-elements/duet-checkbox.js +1 -1
- package/lib/dist-custom-elements/duet-checkmark.js +1 -1
- package/lib/dist-custom-elements/duet-chip.js +1 -1
- package/lib/dist-custom-elements/duet-choice-group.js +11 -10
- package/lib/dist-custom-elements/duet-choice.js +8 -7
- package/lib/dist-custom-elements/duet-collapsible.js +7 -6
- package/lib/dist-custom-elements/duet-combobox.js +17 -16
- package/lib/dist-custom-elements/duet-contact-card.js +13 -12
- package/lib/dist-custom-elements/duet-cookie-consent.js +9 -8
- package/lib/dist-custom-elements/duet-date-picker.js +19 -18
- package/lib/dist-custom-elements/duet-divider.js +1 -1
- package/lib/dist-custom-elements/duet-editable-table.js +11 -10
- package/lib/dist-custom-elements/duet-empty-state.js +1 -1
- package/lib/dist-custom-elements/duet-fieldset.js +1 -1
- package/lib/dist-custom-elements/duet-file-chooser.js +5 -4
- package/lib/dist-custom-elements/duet-footer.js +15 -14
- package/lib/dist-custom-elements/duet-grid-item.js +1 -1
- package/lib/dist-custom-elements/duet-grid.js +1 -1
- package/lib/dist-custom-elements/duet-header.js +12 -11
- package/lib/dist-custom-elements/duet-heading.js +1 -1
- package/lib/dist-custom-elements/duet-hero.js +18 -17
- package/lib/dist-custom-elements/duet-icon.js +1 -1
- package/lib/dist-custom-elements/duet-input.js +1 -1
- package/lib/dist-custom-elements/duet-label.js +1 -1
- package/lib/dist-custom-elements/duet-layout.js +8 -7
- package/lib/dist-custom-elements/duet-link.js +1 -1
- package/lib/dist-custom-elements/duet-list-item.js +1 -1
- package/lib/dist-custom-elements/duet-list.js +1 -1
- package/lib/dist-custom-elements/duet-logo.js +1 -1
- package/lib/dist-custom-elements/duet-menu-bar-button.js +6 -5
- package/lib/dist-custom-elements/duet-menu-bar-dropdown-link.js +6 -5
- package/lib/dist-custom-elements/duet-menu-bar-dropdown.js +8 -7
- package/lib/dist-custom-elements/duet-menu-bar-item.js +6 -5
- package/lib/dist-custom-elements/duet-menu-bar-link.js +6 -5
- package/lib/dist-custom-elements/duet-menu-bar.js +6 -5
- package/lib/dist-custom-elements/duet-modal.js +24 -21
- package/lib/dist-custom-elements/duet-multiselect.js +19 -18
- package/lib/dist-custom-elements/duet-nav.js +4 -3
- package/lib/dist-custom-elements/duet-notification-drawer.js +9 -8
- package/lib/dist-custom-elements/duet-notification.js +7 -6
- package/lib/dist-custom-elements/duet-number-input.js +15 -14
- package/lib/dist-custom-elements/duet-overlay.js +1 -1
- package/lib/dist-custom-elements/duet-page-heading.js +6 -5
- package/lib/dist-custom-elements/duet-pagination.js +27 -26
- package/lib/dist-custom-elements/duet-paragraph.js +1 -1
- package/lib/dist-custom-elements/duet-popup-menu-item.js +5 -4
- package/lib/dist-custom-elements/duet-popup-menu.js +6 -5
- package/lib/dist-custom-elements/duet-progress.js +1 -1
- package/lib/dist-custom-elements/duet-promo-card.js +8 -7
- package/lib/dist-custom-elements/duet-radio-group.js +11 -10
- package/lib/dist-custom-elements/duet-radio.js +3 -2
- package/lib/dist-custom-elements/duet-range-slider.js +4 -3
- package/lib/dist-custom-elements/duet-range-stepper.js +9 -8
- package/lib/dist-custom-elements/duet-scrollable.js +1 -1
- package/lib/dist-custom-elements/duet-section-layout.js +6 -5
- package/lib/dist-custom-elements/duet-select.js +1 -1
- package/lib/dist-custom-elements/duet-shaped-image.js +5 -4
- package/lib/dist-custom-elements/duet-show-more.js +1 -1
- package/lib/dist-custom-elements/duet-slideout-lang.js +6 -5
- package/lib/dist-custom-elements/duet-slideout-link.js +6 -5
- package/lib/dist-custom-elements/duet-slideout-panel-dropdown.js +8 -7
- package/lib/dist-custom-elements/duet-slideout-panel.js +13 -12
- package/lib/dist-custom-elements/duet-slideout.js +12 -11
- package/lib/dist-custom-elements/duet-spacer.js +1 -1
- package/lib/dist-custom-elements/duet-spinner.js +1 -1
- package/lib/dist-custom-elements/duet-step.js +6 -5
- package/lib/dist-custom-elements/duet-stepper.js +5 -4
- package/lib/dist-custom-elements/duet-submenu-bar-dropdown-link.js +6 -5
- package/lib/dist-custom-elements/duet-submenu-bar-dropdown.js +8 -7
- package/lib/dist-custom-elements/duet-submenu-bar-item.js +5 -4
- package/lib/dist-custom-elements/duet-submenu-bar-link.js +5 -4
- package/lib/dist-custom-elements/duet-submenu-bar.js +9 -8
- package/lib/dist-custom-elements/duet-tab-group.js +21 -20
- package/lib/dist-custom-elements/duet-tab.js +4 -3
- package/lib/dist-custom-elements/duet-table.js +1 -1
- package/lib/dist-custom-elements/duet-textarea.js +13 -12
- package/lib/dist-custom-elements/duet-toggle.js +4 -3
- package/lib/dist-custom-elements/duet-toolbar-dropdown-link.js +6 -5
- package/lib/dist-custom-elements/duet-toolbar-dropdown.js +8 -7
- package/lib/dist-custom-elements/duet-toolbar-item.js +6 -5
- package/lib/dist-custom-elements/duet-toolbar-link.js +6 -5
- package/lib/dist-custom-elements/duet-toolbar.js +4 -3
- package/lib/dist-custom-elements/duet-tooltip-button.js +1 -1
- package/lib/dist-custom-elements/duet-tooltip-popup.js +1 -1
- package/lib/dist-custom-elements/duet-tooltip.js +1 -1
- package/lib/dist-custom-elements/duet-tray.js +8 -7
- package/lib/dist-custom-elements/duet-upload-aria-status.js +1 -1
- package/lib/dist-custom-elements/duet-upload-item.js +1 -1
- package/lib/dist-custom-elements/duet-upload.js +25 -24
- package/lib/dist-custom-elements/duet-visually-hidden.js +1 -1
- package/lib/dist-custom-elements/index.js +2 -1
- package/lib/dist-custom-elements/{p-5d1b1309.js → p-00eccbc8.js} +5 -4
- package/lib/dist-custom-elements/{p-dcbd3217.js → p-0231ea20.js} +5 -4
- package/lib/dist-custom-elements/{p-2f74a80b.js → p-02911244.js} +3 -3
- package/lib/dist-custom-elements/{p-f010dbb0.js → p-03c64124.js} +5 -4
- package/lib/dist-custom-elements/{p-184196bf.js → p-12a09bbc.js} +5 -4
- package/lib/dist-custom-elements/{p-8806e54e.js → p-151934ce.js} +8 -7
- package/lib/dist-custom-elements/{p-8b931125.js → p-1c341405.js} +11 -10
- package/lib/dist-custom-elements/{p-0301d789.js → p-21e0af47.js} +38 -19
- package/lib/dist-custom-elements/{p-2e4d752a.js → p-26d4d49e.js} +3 -2
- package/lib/dist-custom-elements/{p-a1b81dbc.js → p-2a041992.js} +7 -6
- package/lib/dist-custom-elements/{p-2e36d5bf.js → p-2f5e2da8.js} +1 -0
- package/lib/dist-custom-elements/{p-3a3e990d.js → p-330bf2a1.js} +4 -3
- package/lib/dist-custom-elements/{p-ecb49066.js → p-37e44d89.js} +5 -4
- package/lib/dist-custom-elements/{p-aaf04b7b.js → p-384f880b.js} +6 -5
- package/lib/dist-custom-elements/{p-164f1743.js → p-3e74515a.js} +10 -9
- package/lib/dist-custom-elements/{p-a5b07a4c.js → p-401b6b1f.js} +5 -4
- package/lib/dist-custom-elements/{p-e4489c9c.js → p-45dd5240.js} +7 -6
- package/lib/dist-custom-elements/p-47c44289.js +178 -0
- package/lib/dist-custom-elements/{p-d4cc9e7f.js → p-48a3af88.js} +3 -2
- package/lib/dist-custom-elements/{p-b691a561.js → p-5ad5934d.js} +4 -3
- package/lib/dist-custom-elements/{p-188198bb.js → p-61ffea9e.js} +6 -5
- package/lib/dist-custom-elements/{p-f3fed1d1.js → p-6bd18890.js} +15 -14
- package/lib/dist-custom-elements/{p-9d2943a1.js → p-706daff4.js} +14 -13
- package/lib/dist-custom-elements/{p-fe0978ef.js → p-7666f1bc.js} +5 -4
- package/lib/dist-custom-elements/{p-e4f40301.js → p-7eef087e.js} +12 -11
- package/lib/{esm/floating-ui.dom.esm-01fcd83a.js → dist-custom-elements/p-81287261.js} +1 -1
- package/lib/dist-custom-elements/{p-06e608ae.js → p-895db398.js} +2 -0
- package/lib/dist-custom-elements/{p-45ce252d.js → p-8fb1d873.js} +15 -14
- package/lib/dist-custom-elements/{p-2933d260.js → p-955053f9.js} +7 -5
- package/lib/dist-custom-elements/p-955746f9.js +1848 -0
- package/lib/dist-custom-elements/{p-d1f8f9d9.js → p-9bda0343.js} +5 -4
- package/lib/dist-custom-elements/{p-674040a2.js → p-9d348a4b.js} +4 -3
- package/lib/dist-custom-elements/{p-f390637a.js → p-9dc74a9b.js} +8 -7
- package/lib/dist-custom-elements/{p-9a63d9a1.js → p-ad23e869.js} +6 -5
- package/lib/dist-custom-elements/{p-2a29afc3.js → p-b8bb3910.js} +5 -4
- package/lib/dist-custom-elements/{p-c6788c34.js → p-bb20326f.js} +4 -3
- package/lib/dist-custom-elements/{p-ee310f8e.js → p-c7a796da.js} +4 -3
- package/lib/dist-custom-elements/{p-4bd749d9.js → p-d2f0147b.js} +1 -1
- package/lib/dist-custom-elements/{p-3ee1ee19.js → p-d7ff39b6.js} +5 -4
- package/lib/dist-custom-elements/{p-1a167655.js → p-e091bb48.js} +3 -2
- package/lib/dist-custom-elements/{p-2d44ce95.js → p-f1938f1a.js} +3 -2
- package/lib/dist-custom-elements/{p-b59388e4.js → p-fd601808.js} +9 -8
- package/lib/duet/duet.esm.js +1 -1
- package/lib/duet/duet.js +1 -1
- package/lib/duet/p-01e99b47.system.entry.js +4 -0
- package/lib/duet/p-032d42d4.entry.js +4 -0
- package/lib/duet/p-06472b8c.entry.js +4 -0
- package/lib/duet/p-064b908b.entry.js +4 -0
- package/lib/duet/p-069aaf78.entry.js +4 -0
- package/lib/duet/{p-00638431.system.entry.js → p-077b9a06.system.entry.js} +1 -1
- package/lib/duet/p-08866b96.system.entry.js +4 -0
- package/lib/duet/{p-09f2162b.system.entry.js → p-08daf525.system.entry.js} +1 -1
- package/lib/duet/p-0a042569.entry.js +4 -0
- package/lib/duet/p-0c3a491b.system.entry.js +4 -0
- package/lib/duet/{p-f0a8edfa.system.entry.js → p-0cbdf836.system.entry.js} +1 -1
- package/lib/duet/{p-15d65ccc.system.js → p-0dc9089b.system.js} +1 -1
- package/lib/duet/{p-fabb616b.js → p-0f1980bc.js} +1 -1
- package/lib/duet/{p-bc99f838.system.entry.js → p-115a50f2.system.entry.js} +1 -1
- package/lib/duet/{p-c9c57249.system.entry.js → p-12b4df90.system.entry.js} +1 -1
- package/lib/duet/p-13ea970e.system.entry.js +4 -0
- package/lib/duet/{p-d537a47b.entry.js → p-155b7733.entry.js} +1 -1
- package/lib/duet/p-16be8ba9.entry.js +4 -0
- package/lib/duet/{p-b0d67f51.entry.js → p-16e63390.entry.js} +1 -1
- package/lib/duet/p-1784b1d2.js +1 -1
- package/lib/duet/{p-48e4b33e.system.entry.js → p-17eeb1cc.system.entry.js} +1 -1
- package/lib/duet/p-1801e2be.entry.js +4 -0
- package/lib/duet/p-18d8207e.entry.js +4 -0
- package/lib/duet/{p-a87c1819.entry.js → p-198b0f16.entry.js} +1 -1
- package/lib/duet/p-1a6ea3db.entry.js +4 -0
- package/lib/duet/p-1d1f8607.entry.js +4 -0
- package/lib/duet/p-23805ac9.entry.js +4 -0
- package/lib/duet/p-2383fbeb.entry.js +4 -0
- package/lib/duet/p-2504c504.entry.js +4 -0
- package/lib/duet/p-28106a87.system.entry.js +4 -0
- package/lib/duet/{p-322273ee.system.entry.js → p-2928c320.system.entry.js} +1 -1
- package/lib/duet/{p-1af39d2d.entry.js → p-29665476.entry.js} +1 -1
- package/lib/duet/p-2aa796b7.js +4 -0
- package/lib/duet/p-2b9defde.system.entry.js +4 -0
- package/lib/duet/p-2c78ff7b.system.entry.js +4 -0
- package/lib/duet/p-300c8dd9.entry.js +4 -0
- package/lib/duet/{p-b3f5fea3.entry.js → p-32be247b.entry.js} +1 -1
- package/lib/duet/p-32d698f2.system.entry.js +4 -0
- package/lib/duet/{p-d9800a64.entry.js → p-364d7058.entry.js} +1 -1
- package/lib/duet/p-3e1a0cb7.entry.js +4 -0
- package/lib/duet/p-41b6d132.entry.js +4 -0
- package/lib/duet/{p-15a018c2.entry.js → p-41d5039a.entry.js} +1 -1
- package/lib/duet/p-428f66d6.system.entry.js +4 -0
- package/lib/duet/p-42e31c87.entry.js +4 -0
- package/lib/duet/p-43417c63.entry.js +4 -0
- package/lib/duet/{p-d2082904.system.entry.js → p-4487736b.system.entry.js} +1 -1
- package/lib/duet/p-4520f63d.system.entry.js +4 -0
- package/lib/duet/p-46079f71.entry.js +4 -0
- package/lib/duet/p-48879a51.entry.js +4 -0
- package/lib/duet/{p-4083bda5.entry.js → p-4a8d2af0.entry.js} +1 -1
- package/lib/duet/{p-0204b3b0.js → p-4bc401c3.js} +1 -1
- package/lib/duet/p-50c0ea9c.system.entry.js +4 -0
- package/lib/duet/p-54351362.entry.js +4 -0
- package/lib/duet/p-54c28fa4.system.entry.js +4 -0
- package/lib/duet/p-55327462.entry.js +4 -0
- package/lib/duet/p-5672308b.entry.js +4 -0
- package/lib/duet/p-56d35ccf.system.entry.js +4 -0
- package/lib/duet/p-5776972c.entry.js +4 -0
- package/lib/duet/p-585ad67b.entry.js +4 -0
- package/lib/duet/p-5866eaea.entry.js +4 -0
- package/lib/duet/p-58cb8b0b.system.entry.js +4 -0
- package/lib/duet/p-5abdc5ab.entry.js +4 -0
- package/lib/duet/p-5cb08833.system.entry.js +4 -0
- package/lib/duet/p-5f3de870.system.entry.js +4 -0
- package/lib/duet/{p-da20db91.system.js → p-6084bf4c.system.js} +1 -1
- package/lib/duet/{p-e36d3c27.entry.js → p-60d43265.entry.js} +1 -1
- package/lib/duet/{p-4a65e996.system.entry.js → p-61a24bce.system.entry.js} +1 -1
- package/lib/duet/{p-f370f3c5.system.entry.js → p-66e3ce81.system.entry.js} +1 -1
- package/lib/duet/p-6892b798.system.entry.js +4 -0
- package/lib/duet/{p-36eb52a8.system.entry.js → p-68a9aeee.system.entry.js} +1 -1
- package/lib/duet/p-68f52c23.system.entry.js +4 -0
- package/lib/duet/p-693ad8aa.entry.js +4 -0
- package/lib/duet/{p-e67c546c.system.entry.js → p-6a496c70.system.entry.js} +1 -1
- package/lib/duet/{p-e1fb0446.entry.js → p-6a84bf93.entry.js} +1 -1
- package/lib/duet/p-6bb927f9.system.entry.js +4 -0
- package/lib/duet/p-6c76d396.entry.js +4 -0
- package/lib/duet/p-6cdd3596.entry.js +4 -0
- package/lib/duet/{p-a909fac2.system.entry.js → p-6d157e53.system.entry.js} +2 -2
- package/lib/duet/p-6d75cdf6.system.js +4 -0
- package/lib/duet/p-6db296a5.entry.js +4 -0
- package/lib/duet/{p-95d3a1c1.system.entry.js → p-6dfa9f0e.system.entry.js} +1 -1
- package/lib/duet/{p-d54716cb.system.entry.js → p-70ba1823.system.entry.js} +1 -1
- package/lib/duet/p-72affe21.system.entry.js +4 -0
- package/lib/duet/p-7340e2e2.entry.js +4 -0
- package/lib/duet/p-7344d97c.system.js +4 -0
- package/lib/duet/p-7a5dd34d.entry.js +4 -0
- package/lib/duet/p-7b0e681f.system.entry.js +4 -0
- package/lib/duet/{p-55ce0916.system.entry.js → p-7bfc6d05.system.entry.js} +1 -1
- package/lib/duet/p-7c3649ba.js +5 -0
- package/lib/duet/p-7c533802.entry.js +4 -0
- package/lib/duet/p-7d473104.system.entry.js +4 -0
- package/lib/duet/{p-22b1cabe.system.entry.js → p-7e4597c6.system.entry.js} +1 -1
- package/lib/duet/p-7f8fc279.entry.js +4 -0
- package/lib/duet/p-7ff17c05.system.entry.js +4 -0
- package/lib/duet/p-80d722bc.entry.js +4 -0
- package/lib/duet/{p-31ed51c3.js → p-81287261.js} +1 -1
- package/lib/duet/p-813c2271.entry.js +4 -0
- package/lib/duet/{p-71b71fae.system.entry.js → p-83b88e0d.system.entry.js} +1 -1
- package/lib/duet/{p-e240a248.system.entry.js → p-84c50c75.system.entry.js} +1 -1
- package/lib/duet/p-8589c504.system.entry.js +4 -0
- package/lib/duet/p-86361d66.system.entry.js +4 -0
- package/lib/duet/p-8aefdb36.entry.js +4 -0
- package/lib/duet/p-8d4fde72.entry.js +4 -0
- package/lib/duet/{p-49492752.system.entry.js → p-8dcb869d.system.entry.js} +2 -2
- package/lib/duet/p-933895d6.system.entry.js +4 -0
- package/lib/duet/p-93d9f454.system.js +4 -0
- package/lib/duet/{p-2ebe1ac5.system.entry.js → p-95778aca.system.entry.js} +2 -2
- package/lib/duet/{p-fd736af1.entry.js → p-97f74160.entry.js} +1 -1
- package/lib/duet/p-98ac1721.system.entry.js +4 -0
- package/lib/duet/{p-b0c801cc.system.entry.js → p-9b6cc90a.system.entry.js} +1 -1
- package/lib/duet/{p-56c629ed.entry.js → p-9bdec5df.entry.js} +1 -1
- package/lib/duet/p-9d4cd103.system.entry.js +4 -0
- package/lib/duet/p-9d5823eb.entry.js +4 -0
- package/lib/duet/{p-847bf63e.entry.js → p-9e60a58d.entry.js} +1 -1
- package/lib/duet/p-9ef799f8.js +4 -0
- package/lib/duet/p-9f850d18.system.entry.js +4 -0
- package/lib/duet/p-9f9e290a.system.entry.js +4 -0
- package/lib/duet/p-a168b3f5.system.js +4 -0
- package/lib/duet/p-a32dad7f.system.entry.js +4 -0
- package/lib/duet/p-a4d9c151.system.entry.js +4 -0
- package/lib/duet/p-a5d65d5f.entry.js +4 -0
- package/lib/duet/{p-ec9dbf7d.system.entry.js → p-a7768425.system.entry.js} +2 -2
- package/lib/duet/p-a7c62459.system.entry.js +4 -0
- package/lib/duet/{p-7fcbb429.system.entry.js → p-a8301a1a.system.entry.js} +1 -1
- package/lib/duet/{p-dd9e6250.system.entry.js → p-a9891098.system.entry.js} +1 -1
- package/lib/duet/p-aa1f6b55.entry.js +4 -0
- package/lib/duet/p-ac596f9f.entry.js +4 -0
- package/lib/duet/p-acd65ed7.entry.js +4 -0
- package/lib/duet/p-ad433963.system.entry.js +4 -0
- package/lib/duet/{p-87e7e6d8.entry.js → p-ae714885.entry.js} +1 -1
- package/lib/duet/p-aeaa9698.entry.js +4 -0
- package/lib/duet/{p-1dc415a6.system.entry.js → p-aface64d.system.entry.js} +1 -1
- package/lib/duet/p-afadf391.entry.js +4 -0
- package/lib/duet/p-b0be53ba.entry.js +4 -0
- package/lib/duet/p-b25d69bf.system.entry.js +4 -0
- package/lib/duet/p-b2b49d1a.entry.js +4 -0
- package/lib/duet/p-b3bff87d.entry.js +4 -0
- package/lib/duet/{p-6f74db7d.system.entry.js → p-b5e50220.system.entry.js} +2 -2
- package/lib/duet/{p-ec7dd416.system.entry.js → p-b70dd317.system.entry.js} +1 -1
- package/lib/duet/p-b8fc9725.system.entry.js +4 -0
- package/lib/duet/p-b9772bdf.entry.js +4 -0
- package/lib/duet/p-b9e27ff4.entry.js +4 -0
- package/lib/duet/{p-9ef3bc8d.system.entry.js → p-ba7fbd88.system.entry.js} +1 -1
- package/lib/duet/p-bd936407.js +4 -0
- package/lib/duet/{p-24046fe3.system.entry.js → p-bddc227d.system.entry.js} +1 -1
- package/lib/duet/{p-b3c24039.system.entry.js → p-bf5630d6.system.entry.js} +1 -1
- package/lib/duet/p-bfecf35c.entry.js +4 -0
- package/lib/duet/p-c1445714.system.js +1 -1
- package/lib/duet/p-c3de57c1.system.entry.js +4 -0
- package/lib/duet/{p-81e718f5.system.entry.js → p-c45a4823.system.entry.js} +1 -1
- package/lib/duet/p-c45c1cc8.entry.js +4 -0
- package/lib/duet/{p-29ef8ffc.system.entry.js → p-c5759522.system.entry.js} +1 -1
- package/lib/duet/p-c62ed778.entry.js +4 -0
- package/lib/duet/{p-81681caf.entry.js → p-cb4e6c86.entry.js} +1 -1
- package/lib/duet/p-cf83f662.entry.js +4 -0
- package/lib/duet/p-d0f3224e.entry.js +4 -0
- package/lib/duet/{p-bdd90cdd.system.entry.js → p-d52fa492.system.entry.js} +1 -1
- package/lib/duet/p-d6c95c73.system.entry.js +4 -0
- package/lib/duet/p-d920063d.entry.js +4 -0
- package/lib/duet/p-dde61943.system.js +4 -0
- package/lib/duet/p-e0db32fc.system.entry.js +4 -0
- package/lib/duet/p-e38064d5.entry.js +4 -0
- package/lib/duet/p-e4674cda.entry.js +4 -0
- package/lib/duet/p-e7d7928e.system.js +5 -0
- package/lib/duet/{p-8a9f7476.entry.js → p-e824a614.entry.js} +1 -1
- package/lib/duet/p-ec143606.entry.js +4 -0
- package/lib/duet/{p-aad5c506.system.entry.js → p-ee6f4bc1.system.entry.js} +2 -2
- package/lib/duet/p-ee8bcb1f.entry.js +4 -0
- package/lib/duet/{p-bc2af760.system.entry.js → p-ef9675f8.system.entry.js} +2 -2
- package/lib/duet/{p-ed7d1160.system.entry.js → p-ef9b2ced.system.entry.js} +1 -1
- package/lib/duet/p-f0eeebb5.entry.js +4 -0
- package/lib/duet/p-f1a726c9.entry.js +4 -0
- package/lib/duet/{p-b5bbe11d.system.entry.js → p-f2f1de65.system.entry.js} +2 -2
- package/lib/duet/{p-2936ccf3.system.entry.js → p-f6ea07d1.system.entry.js} +1 -1
- package/lib/duet/p-f6fc4754.system.entry.js +4 -0
- package/lib/duet/p-f9069050.system.entry.js +4 -0
- package/lib/duet/p-fbb2d1c4.system.entry.js +4 -0
- package/lib/duet/{p-47fa3bf9.entry.js → p-fc76bb60.entry.js} +1 -1
- package/lib/duet/p-fd1cbfc8.entry.js +4 -0
- package/lib/esm/{app-globals-45aa6d20.js → app-globals-21820dd0.js} +2 -0
- package/lib/esm/duet-action-button.entry.js +5 -4
- package/lib/esm/duet-alert.entry.js +10 -9
- package/lib/esm/duet-badge.entry.js +5 -4
- package/lib/esm/duet-banner.entry.js +6 -5
- package/lib/esm/duet-breadcrumb.entry.js +8 -7
- package/lib/esm/duet-breadcrumbs.entry.js +6 -5
- package/lib/esm/duet-button_2.entry.js +13 -11
- package/lib/esm/duet-callout.entry.js +6 -5
- package/lib/esm/duet-caption_4.entry.js +18 -14
- package/lib/esm/duet-card.entry.js +6 -5
- package/lib/esm/duet-checkbox.entry.js +3 -2
- package/lib/esm/duet-checkmark.entry.js +5 -4
- package/lib/esm/duet-chip.entry.js +4 -3
- package/lib/esm/duet-choice_2.entry.js +7 -5
- package/lib/esm/duet-collapsible.entry.js +6 -5
- package/lib/esm/duet-combobox.entry.js +5 -4
- package/lib/esm/duet-contact-card.entry.js +6 -5
- package/lib/esm/duet-cookie-consent.entry.js +4 -3
- package/lib/esm/duet-date-picker.entry.js +6 -5
- package/lib/esm/duet-divider_2.entry.js +7 -5
- package/lib/esm/duet-editable-table_3.entry.js +13 -10
- package/lib/esm/duet-empty-state.entry.js +5 -4
- package/lib/esm/duet-fieldset.entry.js +7 -6
- package/lib/esm/duet-file-chooser.entry.js +4 -3
- package/lib/esm/duet-footer.entry.js +9 -8
- package/lib/esm/duet-grid_2.entry.js +5 -3
- package/lib/esm/duet-header_2.entry.js +7 -5
- package/lib/esm/duet-hero.entry.js +10 -9
- package/lib/esm/duet-icon.entry.js +6 -5
- package/lib/esm/duet-input_2.entry.js +7 -5
- package/lib/esm/duet-layout.entry.js +8 -7
- package/lib/esm/duet-list_2.entry.js +8 -6
- package/lib/esm/duet-menu-bar-button.entry.js +5 -4
- package/lib/esm/duet-menu-bar-dropdown-link.entry.js +5 -4
- package/lib/esm/duet-menu-bar-dropdown.entry.js +7 -6
- package/lib/esm/duet-menu-bar-item.entry.js +5 -4
- package/lib/esm/duet-menu-bar-link.entry.js +5 -4
- package/lib/esm/duet-menu-bar.entry.js +5 -4
- package/lib/esm/duet-modal.entry.js +17 -14
- package/lib/esm/duet-multiselect.entry.js +11 -10
- package/lib/esm/duet-nav.entry.js +4 -3
- package/lib/esm/duet-notification_2.entry.js +10 -8
- package/lib/esm/duet-number-input.entry.js +5 -4
- package/lib/esm/duet-overlay.entry.js +4 -3
- package/lib/esm/duet-page-heading.entry.js +5 -4
- package/lib/esm/duet-pagination_2.entry.js +19 -17
- package/lib/esm/duet-popup-menu-item.entry.js +4 -3
- package/lib/esm/duet-popup-menu.entry.js +6 -5
- package/lib/esm/duet-progress.entry.js +4 -3
- package/lib/esm/duet-promo-card.entry.js +6 -5
- package/lib/esm/duet-radio_2.entry.js +6 -4
- package/lib/esm/duet-range-slider.entry.js +3 -2
- package/lib/esm/duet-scrollable_3.entry.js +44 -23
- package/lib/esm/duet-section-layout.entry.js +6 -5
- package/lib/esm/duet-select.entry.js +4 -3
- package/lib/esm/duet-shaped-image.entry.js +5 -4
- package/lib/esm/duet-show-more.entry.js +6 -5
- package/lib/esm/duet-slideout-lang.entry.js +5 -4
- package/lib/esm/duet-slideout-link.entry.js +5 -4
- package/lib/esm/duet-slideout-panel-dropdown.entry.js +7 -6
- package/lib/esm/duet-slideout-panel.entry.js +12 -11
- package/lib/esm/duet-slideout.entry.js +10 -9
- package/lib/esm/duet-step_2.entry.js +6 -4
- package/lib/esm/duet-submenu-bar-dropdown-link.entry.js +5 -4
- package/lib/esm/duet-submenu-bar-dropdown.entry.js +7 -6
- package/lib/esm/duet-submenu-bar-item.entry.js +4 -3
- package/lib/esm/duet-submenu-bar-link.entry.js +4 -3
- package/lib/esm/duet-submenu-bar.entry.js +7 -6
- package/lib/esm/duet-textarea.entry.js +4 -3
- package/lib/esm/duet-toggle.entry.js +3 -2
- package/lib/esm/duet-toolbar-dropdown-link.entry.js +5 -4
- package/lib/esm/duet-toolbar-dropdown.entry.js +7 -6
- package/lib/esm/duet-toolbar-item.entry.js +5 -4
- package/lib/esm/duet-toolbar-link.entry.js +5 -4
- package/lib/esm/duet-toolbar.entry.js +4 -3
- package/lib/esm/duet-tooltip-button_2.entry.js +10 -8
- package/lib/esm/duet-tooltip.entry.js +5 -4
- package/lib/esm/duet-tray.entry.js +6 -5
- package/lib/esm/duet-upload-aria-status.entry.js +2 -2
- package/lib/esm/duet-upload-item.entry.js +7 -6
- package/lib/esm/duet-visually-hidden.entry.js +4 -3
- package/lib/esm/duet.js +16 -16
- package/lib/esm/{errorcodes.utils-e681347c.js → errorcodes.utils-a4ae6efc.js} +1 -1
- package/lib/{dist-custom-elements/p-31ed51c3.js → esm/floating-ui.dom.esm-ebc91b33.js} +1 -1
- package/lib/esm/{focus-utils-f0e6853d.js → focus-utils-f583d4fb.js} +1 -1
- package/lib/esm/index-640026f0.js +1962 -0
- package/lib/esm/{language-utils-00ca4c55.js → language-utils-eda57343.js} +1 -0
- package/lib/esm/loader.js +5 -5
- package/lib/esm/{slot-utils-b50aaef5.js → slot-utils-00899492.js} +2 -0
- package/lib/esm/token-utils-1f843fb9.js +1 -1
- package/lib/esm-es5/app-globals-21820dd0.js +4 -0
- package/lib/esm-es5/duet-action-button.entry.js +1 -1
- package/lib/esm-es5/duet-alert.entry.js +2 -2
- package/lib/esm-es5/duet-badge.entry.js +1 -1
- package/lib/esm-es5/duet-banner.entry.js +1 -1
- package/lib/esm-es5/duet-breadcrumb.entry.js +1 -1
- package/lib/esm-es5/duet-breadcrumbs.entry.js +1 -1
- package/lib/esm-es5/duet-button_2.entry.js +1 -1
- package/lib/esm-es5/duet-callout.entry.js +1 -1
- package/lib/esm-es5/duet-caption_4.entry.js +2 -2
- package/lib/esm-es5/duet-card.entry.js +1 -1
- package/lib/esm-es5/duet-checkbox.entry.js +1 -1
- package/lib/esm-es5/duet-checkmark.entry.js +1 -1
- package/lib/esm-es5/duet-chip.entry.js +2 -2
- package/lib/esm-es5/duet-choice_2.entry.js +1 -1
- package/lib/esm-es5/duet-collapsible.entry.js +2 -2
- package/lib/esm-es5/duet-combobox.entry.js +1 -1
- package/lib/esm-es5/duet-contact-card.entry.js +1 -1
- package/lib/esm-es5/duet-cookie-consent.entry.js +1 -1
- package/lib/esm-es5/duet-date-picker.entry.js +1 -1
- package/lib/esm-es5/duet-divider_2.entry.js +1 -1
- package/lib/esm-es5/duet-editable-table_3.entry.js +2 -2
- package/lib/esm-es5/duet-empty-state.entry.js +1 -1
- package/lib/esm-es5/duet-fieldset.entry.js +1 -1
- package/lib/esm-es5/duet-file-chooser.entry.js +2 -2
- package/lib/esm-es5/duet-footer.entry.js +1 -1
- package/lib/esm-es5/duet-grid_2.entry.js +1 -1
- package/lib/esm-es5/duet-header_2.entry.js +1 -1
- package/lib/esm-es5/duet-hero.entry.js +2 -2
- package/lib/esm-es5/duet-icon.entry.js +2 -2
- package/lib/esm-es5/duet-input_2.entry.js +1 -1
- package/lib/esm-es5/duet-layout.entry.js +1 -1
- package/lib/esm-es5/duet-list_2.entry.js +2 -2
- package/lib/esm-es5/duet-menu-bar-button.entry.js +2 -2
- package/lib/esm-es5/duet-menu-bar-dropdown-link.entry.js +1 -1
- package/lib/esm-es5/duet-menu-bar-dropdown.entry.js +1 -1
- package/lib/esm-es5/duet-menu-bar-item.entry.js +2 -2
- package/lib/esm-es5/duet-menu-bar-link.entry.js +1 -1
- package/lib/esm-es5/duet-menu-bar.entry.js +1 -1
- package/lib/esm-es5/duet-modal.entry.js +2 -2
- package/lib/esm-es5/duet-multiselect.entry.js +2 -2
- package/lib/esm-es5/duet-nav.entry.js +1 -1
- package/lib/esm-es5/duet-notification_2.entry.js +2 -2
- package/lib/esm-es5/duet-number-input.entry.js +2 -2
- package/lib/esm-es5/duet-overlay.entry.js +1 -1
- package/lib/esm-es5/duet-page-heading.entry.js +1 -1
- package/lib/esm-es5/duet-pagination_2.entry.js +2 -2
- package/lib/esm-es5/duet-popup-menu-item.entry.js +2 -2
- package/lib/esm-es5/duet-popup-menu.entry.js +1 -1
- package/lib/esm-es5/duet-progress.entry.js +1 -1
- package/lib/esm-es5/duet-promo-card.entry.js +2 -2
- package/lib/esm-es5/duet-radio_2.entry.js +1 -1
- package/lib/esm-es5/duet-range-slider.entry.js +1 -1
- package/lib/esm-es5/duet-scrollable_3.entry.js +1 -1
- package/lib/esm-es5/duet-section-layout.entry.js +1 -1
- package/lib/esm-es5/duet-select.entry.js +1 -1
- package/lib/esm-es5/duet-shaped-image.entry.js +1 -1
- package/lib/esm-es5/duet-show-more.entry.js +1 -1
- package/lib/esm-es5/duet-slideout-lang.entry.js +1 -1
- package/lib/esm-es5/duet-slideout-link.entry.js +1 -1
- package/lib/esm-es5/duet-slideout-panel-dropdown.entry.js +1 -1
- package/lib/esm-es5/duet-slideout-panel.entry.js +2 -2
- package/lib/esm-es5/duet-slideout.entry.js +2 -2
- package/lib/esm-es5/duet-step_2.entry.js +1 -1
- package/lib/esm-es5/duet-submenu-bar-dropdown-link.entry.js +1 -1
- package/lib/esm-es5/duet-submenu-bar-dropdown.entry.js +1 -1
- package/lib/esm-es5/duet-submenu-bar-item.entry.js +2 -2
- package/lib/esm-es5/duet-submenu-bar-link.entry.js +1 -1
- package/lib/esm-es5/duet-submenu-bar.entry.js +2 -2
- package/lib/esm-es5/duet-textarea.entry.js +1 -1
- package/lib/esm-es5/duet-toggle.entry.js +1 -1
- package/lib/esm-es5/duet-toolbar-dropdown-link.entry.js +1 -1
- package/lib/esm-es5/duet-toolbar-dropdown.entry.js +2 -2
- package/lib/esm-es5/duet-toolbar-item.entry.js +2 -2
- package/lib/esm-es5/duet-toolbar-link.entry.js +1 -1
- package/lib/esm-es5/duet-toolbar.entry.js +1 -1
- package/lib/esm-es5/duet-tooltip-button_2.entry.js +2 -2
- package/lib/esm-es5/duet-tooltip.entry.js +1 -1
- package/lib/esm-es5/duet-tray.entry.js +1 -1
- package/lib/esm-es5/duet-upload-aria-status.entry.js +1 -1
- package/lib/esm-es5/duet-upload-item.entry.js +2 -2
- package/lib/esm-es5/duet-visually-hidden.entry.js +1 -1
- package/lib/esm-es5/duet.js +2 -2
- package/lib/esm-es5/{errorcodes.utils-e681347c.js → errorcodes.utils-a4ae6efc.js} +1 -1
- package/lib/esm-es5/{floating-ui.dom.esm-01fcd83a.js → floating-ui.dom.esm-ebc91b33.js} +1 -1
- package/lib/esm-es5/focus-utils-f583d4fb.js +4 -0
- package/lib/esm-es5/index-640026f0.js +5 -0
- package/lib/esm-es5/language-utils-eda57343.js +4 -0
- package/lib/esm-es5/loader.js +2 -2
- package/lib/esm-es5/slot-utils-00899492.js +4 -0
- package/lib/esm-es5/token-utils-1f843fb9.js +1 -1
- package/lib/loader/cdn.js +1 -1
- package/lib/loader/index.cjs.js +1 -1
- package/lib/loader/index.d.ts +3 -0
- package/lib/loader/index.es2017.js +1 -1
- package/lib/loader/index.js +1 -1
- package/lib/types/components/duet-modal/duet-modal.d.ts +1 -0
- package/lib/types/components/duet-upload/mock.helpers.d.ts +1 -0
- package/lib/types/stencil-public-runtime.d.ts +3 -10
- package/lib/types/utils/axe-core-utils.d.ts +2 -1
- package/lib/types/utils/test-utils.d.ts +22 -10
- package/lib/types/utils/watch-options.d.ts +2 -2
- package/package.json +17 -16
- package/lib/cjs/index-c3716ea8.js +0 -2836
- package/lib/collection/components/duet-action-button/duet-action-button.a11y.e2e.js +0 -13
- package/lib/collection/components/duet-alert/duet-alert.a11y.e2e.js +0 -20
- package/lib/collection/components/duet-alert/duet-alert.e2e.js +0 -53
- package/lib/collection/components/duet-badge/duet-badge.a11y.e2e.js +0 -20
- package/lib/collection/components/duet-badge/duet-badge.e2e.js +0 -28
- package/lib/collection/components/duet-banner/duet-banner.a11y.e2e.js +0 -34
- package/lib/collection/components/duet-banner/duet-banner.e2e.js +0 -23
- package/lib/collection/components/duet-breadcrumbs/duet-breadcrumbs.a11y.e2e.js +0 -17
- package/lib/collection/components/duet-breadcrumbs/duet-breadcrumbs.e2e.js +0 -18
- package/lib/collection/components/duet-button/duet-button.a11y.e2e.js +0 -48
- package/lib/collection/components/duet-button/duet-button.e2e.js +0 -212
- package/lib/collection/components/duet-callout/duet-callout.a11y.e2e.js +0 -17
- package/lib/collection/components/duet-callout/duet-callout.e2e.js +0 -21
- package/lib/collection/components/duet-caption/duet-caption.a11y.e2e.js +0 -13
- package/lib/collection/components/duet-caption/duet-caption.e2e.js +0 -26
- package/lib/collection/components/duet-card/duet-card.a11y.e2e.js +0 -29
- package/lib/collection/components/duet-card/duet-card.e2e.js +0 -91
- package/lib/collection/components/duet-checkbox/duet-checkbox.a11y.e2e.js +0 -20
- package/lib/collection/components/duet-checkbox/duet-checkbox.e2e.js +0 -112
- package/lib/collection/components/duet-chip/duet-chip.a11y.e2e.js +0 -25
- package/lib/collection/components/duet-chip/duet-chip.e2e.js +0 -56
- package/lib/collection/components/duet-choice/duet-choice.a11y.e2e.js +0 -79
- package/lib/collection/components/duet-choice/duet-choice.e2e.js +0 -184
- package/lib/collection/components/duet-choice-group/duet-choice-group.a11y.e2e.js +0 -17
- package/lib/collection/components/duet-choice-group/duet-choice-group.e2e.js +0 -102
- package/lib/collection/components/duet-collapsible/duet-collapsible.a11y.e2e.js +0 -24
- package/lib/collection/components/duet-collapsible/duet-collapsible.e2e.js +0 -123
- package/lib/collection/components/duet-combobox/duet-combobox.a11y.e2e.js +0 -17
- package/lib/collection/components/duet-combobox/duet-combobox.e2e.js +0 -153
- package/lib/collection/components/duet-contact-card/duet-contact-card.a11y.e2e.js +0 -36
- package/lib/collection/components/duet-cookie-consent/duet-cookie-consent.a11y.e2e.js +0 -16
- package/lib/collection/components/duet-cookie-consent/duet-cookie-consent.e2e.js +0 -27
- package/lib/collection/components/duet-date-picker/date-utils.spec.js +0 -330
- package/lib/collection/components/duet-date-picker/duet-date-picker.a11y.e2e.js +0 -13
- package/lib/collection/components/duet-date-picker/duet-date-picker.e2e.js +0 -693
- package/lib/collection/components/duet-divider/duet-divider.a11y.e2e.js +0 -13
- package/lib/collection/components/duet-divider/duet-divider.e2e.js +0 -32
- package/lib/collection/components/duet-editable-table/duet-editable-table.a11y.e2e.js +0 -202
- package/lib/collection/components/duet-editable-table/duet-editable-table.e2e.js +0 -29
- package/lib/collection/components/duet-empty-state/duet-empty-state.a11y.e2e.js +0 -15
- package/lib/collection/components/duet-empty-state/duet-empty-state.e2e.js +0 -16
- package/lib/collection/components/duet-fieldset/duet-fieldset.a11y.e2e.js +0 -17
- package/lib/collection/components/duet-fieldset/duet-fieldset.e2e.js +0 -13
- package/lib/collection/components/duet-footer/duet-footer.a11y.e2e.js +0 -22
- package/lib/collection/components/duet-footer/duet-footer.e2e.js +0 -186
- package/lib/collection/components/duet-grid/duet-grid.a11y.e2e.js +0 -17
- package/lib/collection/components/duet-grid/duet-grid.e2e.js +0 -42
- package/lib/collection/components/duet-header/duet-header.a11y.e2e.js +0 -42
- package/lib/collection/components/duet-header/duet-header.e2e.js +0 -470
- package/lib/collection/components/duet-heading/duet-heading.a11y.e2e.js +0 -13
- package/lib/collection/components/duet-heading/duet-heading.e2e.js +0 -27
- package/lib/collection/components/duet-hero/duet-hero.a11y.e2e.js +0 -70
- package/lib/collection/components/duet-hero/duet-hero.e2e.js +0 -172
- package/lib/collection/components/duet-icon/duet-icon.a11y.e2e.js +0 -13
- package/lib/collection/components/duet-icon/duet-icon.e2e.js +0 -27
- package/lib/collection/components/duet-icon/icon-utils.spec.js +0 -84
- package/lib/collection/components/duet-input/duet-input.a11y.e2e.js +0 -33
- package/lib/collection/components/duet-input/duet-input.e2e.js +0 -201
- package/lib/collection/components/duet-label/duet-label.a11y.e2e.js +0 -14
- package/lib/collection/components/duet-label/duet-label.e2e.js +0 -32
- package/lib/collection/components/duet-layout/duet-layout.a11y.e2e.js +0 -18
- package/lib/collection/components/duet-layout/duet-layout.e2e.js +0 -32
- package/lib/collection/components/duet-link/duet-link.a11y.e2e.js +0 -39
- package/lib/collection/components/duet-link/duet-link.e2e.js +0 -53
- package/lib/collection/components/duet-list/duet-list.a11y.e2e.js +0 -30
- package/lib/collection/components/duet-list/duet-list.e2e.js +0 -105
- package/lib/collection/components/duet-logo/duet-logo.a11y.e2e.js +0 -13
- package/lib/collection/components/duet-logo/duet-logo.e2e.js +0 -42
- package/lib/collection/components/duet-menu-bar/duet-menu-bar.a11y.e2e.js +0 -63
- package/lib/collection/components/duet-modal/duet-modal.a11y.e2e.js +0 -49
- package/lib/collection/components/duet-modal/duet-modal.e2e.js +0 -113
- package/lib/collection/components/duet-multiselect/duet-multiselect.a11y.e2e.js +0 -22
- package/lib/collection/components/duet-multiselect/duet-multiselect.e2e.js +0 -157
- package/lib/collection/components/duet-notification/duet-notification.a11y.e2e.js +0 -20
- package/lib/collection/components/duet-notification/duet-notification.e2e.js +0 -12
- package/lib/collection/components/duet-notification-drawer/duet-notification-drawer.a11y.e2e.js +0 -28
- package/lib/collection/components/duet-notification-drawer/duet-notification-drawer.e2e.js +0 -177
- package/lib/collection/components/duet-number-input/duet-number-input-negative.e2e.js +0 -32
- package/lib/collection/components/duet-number-input/duet-number-input.a11y.e2e.js +0 -14
- package/lib/collection/components/duet-number-input/duet-number-input.e2e.js +0 -242
- package/lib/collection/components/duet-page-heading/duet-page-heading.a11y.e2e.js +0 -15
- package/lib/collection/components/duet-pagination/duet-pagination.a11y.e2e.js +0 -36
- package/lib/collection/components/duet-pagination/duet-pagination.e2e.js +0 -101
- package/lib/collection/components/duet-paragraph/duet-paragraph.a11y.e2e.js +0 -18
- package/lib/collection/components/duet-paragraph/duet-paragraph.e2e.js +0 -27
- package/lib/collection/components/duet-popup-menu/duet-popup-menu.a11y.e2e.js +0 -27
- package/lib/collection/components/duet-progress/duet-progress.a11y.e2e.js +0 -17
- package/lib/collection/components/duet-progress/duet-progress.e2e.js +0 -12
- package/lib/collection/components/duet-promo-card/duet-promo-card.a11y.e2e.js +0 -43
- package/lib/collection/components/duet-promo-card/duet-promo-card.e2e.js +0 -23
- package/lib/collection/components/duet-radio/duet-radio.a11y.e2e.js +0 -13
- package/lib/collection/components/duet-radio/duet-radio.e2e.js +0 -135
- package/lib/collection/components/duet-radio-group/duet-radio-group.a11y.e2e.js +0 -36
- package/lib/collection/components/duet-radio-group/duet-radio-group.e2e.js +0 -57
- package/lib/collection/components/duet-range-slider/duet-range-slider.a11y.e2e.js +0 -14
- package/lib/collection/components/duet-range-slider/duet-range-slider.e2e.js +0 -57
- package/lib/collection/components/duet-range-stepper/duet-range-stepper.a11y.e2e.js +0 -13
- package/lib/collection/components/duet-range-stepper/duet-range-stepper.e2e.js +0 -52
- package/lib/collection/components/duet-range-stepper/duet-range-stepper.spec.js +0 -23
- package/lib/collection/components/duet-scrollable/duet-scrollable.a11y.e2e.js +0 -17
- package/lib/collection/components/duet-scrollable/duet-scrollable.e2e.js +0 -12
- package/lib/collection/components/duet-section-layout/duet-section-layout.a11y.e2e.js +0 -18
- package/lib/collection/components/duet-section-layout/duet-section-layout.e2e.js +0 -22
- package/lib/collection/components/duet-select/duet-select.a11y.e2e.js +0 -45
- package/lib/collection/components/duet-select/duet-select.e2e.js +0 -211
- package/lib/collection/components/duet-shaped-image/duet-shaped-image.a11y.e2e.js +0 -20
- package/lib/collection/components/duet-show-more/duet-show-more.a11y.e2e.js +0 -13
- package/lib/collection/components/duet-slideout/duet-slideout.a11y.e2e.js +0 -47
- package/lib/collection/components/duet-spacer/duet-spacer.a11y.e2e.js +0 -13
- package/lib/collection/components/duet-spacer/duet-spacer.e2e.js +0 -27
- package/lib/collection/components/duet-spinner/duet-spinner.a11y.e2e.js +0 -13
- package/lib/collection/components/duet-spinner/duet-spinner.e2e.js +0 -30
- package/lib/collection/components/duet-step/duet-step.e2e.js +0 -94
- package/lib/collection/components/duet-stepper/duet-stepper.a11y.e2e.js +0 -26
- package/lib/collection/components/duet-stepper/duet-stepper.e2e.js +0 -84
- package/lib/collection/components/duet-submenu-bar/duet-submenu-bar.a11y.e2e.js +0 -21
- package/lib/collection/components/duet-tab/duet-tab.e2e.js +0 -16
- package/lib/collection/components/duet-tab-group/duet-tab-group.a11y.e2e.js +0 -16
- package/lib/collection/components/duet-tab-group/duet-tab-group.e2e.js +0 -108
- package/lib/collection/components/duet-table/duet-table.a11y.e2e.js +0 -35
- package/lib/collection/components/duet-table/duet-table.e2e.js +0 -95
- package/lib/collection/components/duet-textarea/duet-textarea.a11y.e2e.js +0 -28
- package/lib/collection/components/duet-textarea/duet-textarea.e2e.js +0 -199
- package/lib/collection/components/duet-toggle/duet-toggle.a11y.e2e.js +0 -13
- package/lib/collection/components/duet-toggle/duet-toggle.e2e.js +0 -73
- package/lib/collection/components/duet-toolbar/duet-toolbar.a11y.e2e.js +0 -82
- package/lib/collection/components/duet-tooltip/duet-tooltip.a11y.e2e.js +0 -34
- package/lib/collection/components/duet-tooltip/duet-tooltip.e2e.js +0 -104
- package/lib/collection/components/duet-tray/duet-tray.a11y.e2e.js +0 -22
- package/lib/collection/components/duet-tray/duet-tray.e2e.js +0 -103
- package/lib/collection/components/duet-upload/duet-upload.e2e.js +0 -48
- package/lib/collection/components/duet-upload/upload-validators.spec.js +0 -41
- package/lib/collection/components/duet-visually-hidden/duet-visually-hidden.a11y.e2e.js +0 -15
- package/lib/collection/components/duet-visually-hidden/duet-visually-hidden.e2e.js +0 -12
- package/lib/collection/utils/create-id.spec.js +0 -12
- package/lib/collection/utils/js-utils.spec.js +0 -22
- package/lib/collection/utils/language-utils.spec.js +0 -159
- package/lib/collection/utils/math.utils.spec.js +0 -140
- package/lib/collection/utils/string-utils.spec.js +0 -39
- package/lib/collection/utils/template-utils.spec.js +0 -39
- package/lib/collection/utils/token-utils.spec.js +0 -178
- package/lib/dist-custom-elements/p-33937fd7.js +0 -183
- package/lib/dist-custom-elements/p-d160ca6a.js +0 -2333
- package/lib/duet/p-021968b7.system.entry.js +0 -4
- package/lib/duet/p-039f1ee1.system.entry.js +0 -4
- package/lib/duet/p-06e608ae.js +0 -4
- package/lib/duet/p-09fdd234.entry.js +0 -4
- package/lib/duet/p-0b515d0c.system.entry.js +0 -4
- package/lib/duet/p-0b7e7cdd.entry.js +0 -4
- package/lib/duet/p-12e97d2c.entry.js +0 -4
- package/lib/duet/p-17abbe45.system.entry.js +0 -4
- package/lib/duet/p-1a815d69.entry.js +0 -4
- package/lib/duet/p-1c90a161.system.entry.js +0 -4
- package/lib/duet/p-1f0c6aa9.entry.js +0 -4
- package/lib/duet/p-224f6c46.system.js +0 -4
- package/lib/duet/p-252c61f9.entry.js +0 -4
- package/lib/duet/p-259a297a.system.js +0 -4
- package/lib/duet/p-2757e1be.entry.js +0 -4
- package/lib/duet/p-286cbd79.system.entry.js +0 -4
- package/lib/duet/p-2a3b428e.entry.js +0 -4
- package/lib/duet/p-2e36d5bf.js +0 -4
- package/lib/duet/p-2e615f90.entry.js +0 -4
- package/lib/duet/p-2f1b5c7d.js +0 -5
- package/lib/duet/p-354e8617.entry.js +0 -4
- package/lib/duet/p-36340a70.entry.js +0 -4
- package/lib/duet/p-36a4e269.system.entry.js +0 -4
- package/lib/duet/p-37aab3fc.entry.js +0 -4
- package/lib/duet/p-3aca8b0e.entry.js +0 -4
- package/lib/duet/p-3eb18ea9.system.entry.js +0 -4
- package/lib/duet/p-45ec9edc.entry.js +0 -4
- package/lib/duet/p-47ba309d.system.entry.js +0 -4
- package/lib/duet/p-48de6532.entry.js +0 -4
- package/lib/duet/p-4918a89e.entry.js +0 -4
- package/lib/duet/p-4bbe62cc.system.entry.js +0 -4
- package/lib/duet/p-4c41c996.system.entry.js +0 -4
- package/lib/duet/p-4db9c3d9.entry.js +0 -4
- package/lib/duet/p-52899472.entry.js +0 -4
- package/lib/duet/p-5318851f.system.entry.js +0 -4
- package/lib/duet/p-57346eff.system.entry.js +0 -4
- package/lib/duet/p-5747dc4a.entry.js +0 -4
- package/lib/duet/p-5852bc10.system.entry.js +0 -4
- package/lib/duet/p-59923821.system.entry.js +0 -4
- package/lib/duet/p-5c1c9204.system.entry.js +0 -4
- package/lib/duet/p-5f07590d.entry.js +0 -4
- package/lib/duet/p-61a1045e.entry.js +0 -4
- package/lib/duet/p-647e7930.entry.js +0 -4
- package/lib/duet/p-68ff07cc.entry.js +0 -4
- package/lib/duet/p-694dc2b2.entry.js +0 -4
- package/lib/duet/p-69b8ad83.system.entry.js +0 -4
- package/lib/duet/p-6ae750db.system.entry.js +0 -4
- package/lib/duet/p-6d7602d0.system.entry.js +0 -4
- package/lib/duet/p-6d839458.js +0 -4
- package/lib/duet/p-6dd2833f.entry.js +0 -4
- package/lib/duet/p-6e788570.entry.js +0 -4
- package/lib/duet/p-7187fcdb.entry.js +0 -4
- package/lib/duet/p-72a9c332.entry.js +0 -4
- package/lib/duet/p-7bba0a5f.entry.js +0 -4
- package/lib/duet/p-8030ac7d.entry.js +0 -4
- package/lib/duet/p-808390ff.entry.js +0 -4
- package/lib/duet/p-80c37175.system.entry.js +0 -4
- package/lib/duet/p-81488a05.system.js +0 -4
- package/lib/duet/p-820439f1.system.entry.js +0 -4
- package/lib/duet/p-848fd377.system.entry.js +0 -4
- package/lib/duet/p-86bb5185.entry.js +0 -4
- package/lib/duet/p-8868aefd.system.entry.js +0 -4
- package/lib/duet/p-8aa74f9c.system.entry.js +0 -4
- package/lib/duet/p-8c610e96.system.entry.js +0 -4
- package/lib/duet/p-916d8f4e.system.entry.js +0 -4
- package/lib/duet/p-92dd9326.entry.js +0 -4
- package/lib/duet/p-93abcf6f.system.entry.js +0 -4
- package/lib/duet/p-95ba5b53.system.entry.js +0 -4
- package/lib/duet/p-95bba705.entry.js +0 -4
- package/lib/duet/p-9c102070.system.entry.js +0 -4
- package/lib/duet/p-9c5e5c04.entry.js +0 -4
- package/lib/duet/p-9cbcb120.entry.js +0 -4
- package/lib/duet/p-a072af11.entry.js +0 -4
- package/lib/duet/p-a0be10bb.entry.js +0 -4
- package/lib/duet/p-a2ebc336.entry.js +0 -4
- package/lib/duet/p-a3def4ae.entry.js +0 -4
- package/lib/duet/p-a42bd424.system.entry.js +0 -4
- package/lib/duet/p-a52cfc5a.entry.js +0 -4
- package/lib/duet/p-a532d984.entry.js +0 -4
- package/lib/duet/p-a58f39e3.entry.js +0 -4
- package/lib/duet/p-a74d3389.system.entry.js +0 -4
- package/lib/duet/p-a787f19b.system.entry.js +0 -4
- package/lib/duet/p-a7b5f7e2.system.entry.js +0 -4
- package/lib/duet/p-aab7c415.system.js +0 -5
- package/lib/duet/p-ac32b610.entry.js +0 -4
- package/lib/duet/p-adcab9d7.system.entry.js +0 -4
- package/lib/duet/p-ae21ad57.system.js +0 -4
- package/lib/duet/p-b3bb7acb.entry.js +0 -4
- package/lib/duet/p-b86e538f.system.entry.js +0 -4
- package/lib/duet/p-bbe8cb06.system.entry.js +0 -4
- package/lib/duet/p-bbf58838.entry.js +0 -4
- package/lib/duet/p-bda99d9b.entry.js +0 -4
- package/lib/duet/p-be1dc5c4.entry.js +0 -4
- package/lib/duet/p-c1cc3eeb.entry.js +0 -4
- package/lib/duet/p-c75f879a.entry.js +0 -4
- package/lib/duet/p-c7626b56.entry.js +0 -4
- package/lib/duet/p-c7d7a477.system.entry.js +0 -4
- package/lib/duet/p-c7e75e4b.entry.js +0 -4
- package/lib/duet/p-d3964acf.entry.js +0 -4
- package/lib/duet/p-d43d061f.entry.js +0 -4
- package/lib/duet/p-d4c16da7.system.entry.js +0 -4
- package/lib/duet/p-d5eff7a7.system.js +0 -4
- package/lib/duet/p-d778d2ac.entry.js +0 -4
- package/lib/duet/p-dade1b81.entry.js +0 -4
- package/lib/duet/p-de217be7.entry.js +0 -4
- package/lib/duet/p-dfdc8492.system.entry.js +0 -4
- package/lib/duet/p-e11847f2.entry.js +0 -4
- package/lib/duet/p-e2760c6f.system.entry.js +0 -4
- package/lib/duet/p-e5f76223.entry.js +0 -4
- package/lib/duet/p-e81fdc04.entry.js +0 -4
- package/lib/duet/p-ec29ee80.system.entry.js +0 -4
- package/lib/duet/p-f04ed9cd.entry.js +0 -4
- package/lib/duet/p-f2da4d8f.entry.js +0 -4
- package/lib/duet/p-f6d62e5a.system.entry.js +0 -4
- package/lib/duet/p-ff45b962.entry.js +0 -4
- package/lib/duet/p-ff7efd44.entry.js +0 -4
- package/lib/esm/index-0f5e92a8.js +0 -2802
- package/lib/esm-es5/app-globals-45aa6d20.js +0 -4
- package/lib/esm-es5/focus-utils-f0e6853d.js +0 -4
- package/lib/esm-es5/index-0f5e92a8.js +0 -5
- package/lib/esm-es5/language-utils-00ca4c55.js +0 -4
- package/lib/esm-es5/slot-utils-b50aaef5.js +0 -4
|
@@ -1,693 +0,0 @@
|
|
|
1
|
-
/*!
|
|
2
|
-
* Built with Duet Design System
|
|
3
|
-
*/
|
|
4
|
-
import { createPage } from "../../utils/test-utils";
|
|
5
|
-
import i18n from "./date-i18n";
|
|
6
|
-
async function getFocusedElement(page) {
|
|
7
|
-
return page.evaluateHandle(() => document.activeElement);
|
|
8
|
-
}
|
|
9
|
-
async function getChooseDateButton(page) {
|
|
10
|
-
return page.find(".duet-date-button");
|
|
11
|
-
}
|
|
12
|
-
async function getInput(page) {
|
|
13
|
-
return page.find("duet-input");
|
|
14
|
-
}
|
|
15
|
-
async function getDialog(page) {
|
|
16
|
-
return page.find(`[role="dialog"]`);
|
|
17
|
-
}
|
|
18
|
-
async function getGrid(page) {
|
|
19
|
-
const dialog = await getDialog(page);
|
|
20
|
-
return dialog.find("table");
|
|
21
|
-
}
|
|
22
|
-
async function getPicker(page) {
|
|
23
|
-
return page.find("duet-date-picker");
|
|
24
|
-
}
|
|
25
|
-
async function setMonthDropdown(page, month) {
|
|
26
|
-
await page.select(".duet-date-month-select", month);
|
|
27
|
-
await page.waitForChanges();
|
|
28
|
-
}
|
|
29
|
-
async function setYearDropdown(page, year) {
|
|
30
|
-
await page.select(".duet-date-year-select", year);
|
|
31
|
-
await page.waitForChanges();
|
|
32
|
-
}
|
|
33
|
-
async function getPrevMonthButton(page) {
|
|
34
|
-
const dialog = await getDialog(page);
|
|
35
|
-
return dialog.find(`.duet-date-dialog-prev >>> button`);
|
|
36
|
-
}
|
|
37
|
-
async function getNextMonthButton(page) {
|
|
38
|
-
const dialog = await getDialog(page);
|
|
39
|
-
return dialog.find(`.duet-date-dialog-next >>> button`);
|
|
40
|
-
}
|
|
41
|
-
async function findByText(context, selector, text) {
|
|
42
|
-
const elements = await context.findAll(selector);
|
|
43
|
-
return elements.find(element => element.innerText.includes(text));
|
|
44
|
-
}
|
|
45
|
-
async function clickDay(page, date) {
|
|
46
|
-
const grid = await getGrid(page);
|
|
47
|
-
const button = await findByText(grid, "button", date);
|
|
48
|
-
await button.click();
|
|
49
|
-
await page.waitForChanges();
|
|
50
|
-
}
|
|
51
|
-
async function openCalendar(page) {
|
|
52
|
-
const button = await getChooseDateButton(page);
|
|
53
|
-
await button.click();
|
|
54
|
-
await page.waitForChanges();
|
|
55
|
-
const dialog = await getDialog(page);
|
|
56
|
-
await dialog.waitForVisible();
|
|
57
|
-
}
|
|
58
|
-
async function clickOutside(page) {
|
|
59
|
-
const input = await getInput(page);
|
|
60
|
-
await input.click();
|
|
61
|
-
await page.waitForChanges();
|
|
62
|
-
const dialog = await getDialog(page);
|
|
63
|
-
await dialog.waitForNotVisible();
|
|
64
|
-
}
|
|
65
|
-
async function isCalendarOpen(page) {
|
|
66
|
-
const dialog = await getDialog(page);
|
|
67
|
-
return dialog.isVisible();
|
|
68
|
-
}
|
|
69
|
-
const generatePage = (props) => {
|
|
70
|
-
const attrs = Object.entries(Object.assign({ label: "Valitse paiva", expand: true }, props))
|
|
71
|
-
.map(([attr, value]) => `${attr}="${value}"`)
|
|
72
|
-
.join(" ");
|
|
73
|
-
return createPage(`
|
|
74
|
-
<body style="min-height: 400px">
|
|
75
|
-
<duet-date-picker ${attrs}></duet-date-picker>
|
|
76
|
-
</body>
|
|
77
|
-
`);
|
|
78
|
-
};
|
|
79
|
-
const ANIMATION_DELAY = 600;
|
|
80
|
-
describe("duet-date-picker", () => {
|
|
81
|
-
it("should render a date picker", async () => {
|
|
82
|
-
const page = await createPage(`<duet-date-picker value="2020-06-16"></duet-date-picker>`);
|
|
83
|
-
const component = await getPicker(page);
|
|
84
|
-
expect(component).not.toBeNull();
|
|
85
|
-
});
|
|
86
|
-
describe("user input", () => {
|
|
87
|
-
it("does not reformat input if date doesn't have leading zeroes", async () => {
|
|
88
|
-
const page = await generatePage();
|
|
89
|
-
const picker = await getPicker(page);
|
|
90
|
-
const input = await page.find("duet-input input");
|
|
91
|
-
const spy = await picker.spyOnEvent("duetChange");
|
|
92
|
-
await input.type("1.2.2021", { delay: 50 });
|
|
93
|
-
await page.waitForChanges();
|
|
94
|
-
// the input's value should not get formatted with leading zeroes
|
|
95
|
-
expect(await input.getProperty("value")).toBe("1.2.2021");
|
|
96
|
-
// but we should still emit correctly formatted ISO dates
|
|
97
|
-
expect(await picker.getProperty("value")).toBe("2021-02-01");
|
|
98
|
-
expect(spy).toHaveReceivedEventTimes(1);
|
|
99
|
-
expect(spy.lastEvent.detail.value).toBe("2021-02-01");
|
|
100
|
-
});
|
|
101
|
-
it("allows input to be cleared by setting value to empty string", async () => {
|
|
102
|
-
const page = await generatePage();
|
|
103
|
-
const picker = await getPicker(page);
|
|
104
|
-
const input = await page.find("duet-input input");
|
|
105
|
-
await input.type("1.2.2021", { delay: 50 });
|
|
106
|
-
await page.waitForChanges();
|
|
107
|
-
picker.setProperty("value", "");
|
|
108
|
-
await page.waitForChanges();
|
|
109
|
-
expect(await input.getProperty("value")).toBe("");
|
|
110
|
-
});
|
|
111
|
-
it("supports dashes and slashes as separators", async () => {
|
|
112
|
-
const page = await generatePage();
|
|
113
|
-
const picker = await getPicker(page);
|
|
114
|
-
const input = await page.find("duet-input input");
|
|
115
|
-
const spy = await picker.spyOnEvent("duetChange");
|
|
116
|
-
// slashes
|
|
117
|
-
await input.type("1/1/2021", { delay: 50 });
|
|
118
|
-
await page.waitForChanges();
|
|
119
|
-
expect(await picker.getProperty("value")).toBe("2021-01-01");
|
|
120
|
-
expect(spy.lastEvent.detail.value).toBe("2021-01-01");
|
|
121
|
-
// clear input
|
|
122
|
-
picker.setProperty("value", "");
|
|
123
|
-
await page.waitForChanges();
|
|
124
|
-
// dashes
|
|
125
|
-
await input.type("2-1-2021", { delay: 50 });
|
|
126
|
-
await page.waitForChanges();
|
|
127
|
-
expect(await picker.getProperty("value")).toBe("2021-01-02");
|
|
128
|
-
expect(spy.lastEvent.detail.value).toBe("2021-01-02");
|
|
129
|
-
});
|
|
130
|
-
});
|
|
131
|
-
describe("mouse interaction", () => {
|
|
132
|
-
it("should open on button click", async () => {
|
|
133
|
-
const page = await generatePage();
|
|
134
|
-
expect(await isCalendarOpen(page)).toBe(false);
|
|
135
|
-
await openCalendar(page);
|
|
136
|
-
expect(await isCalendarOpen(page)).toBe(true);
|
|
137
|
-
});
|
|
138
|
-
it("should close on click outside", async () => {
|
|
139
|
-
const page = await generatePage();
|
|
140
|
-
await openCalendar(page);
|
|
141
|
-
expect(await isCalendarOpen(page)).toBe(true);
|
|
142
|
-
await clickOutside(page);
|
|
143
|
-
expect(await isCalendarOpen(page)).toBe(false);
|
|
144
|
-
});
|
|
145
|
-
it("supports selecting a date in the future", async () => {
|
|
146
|
-
const page = await generatePage({ value: "2020-01-01" });
|
|
147
|
-
await openCalendar(page);
|
|
148
|
-
const picker = await getPicker(page);
|
|
149
|
-
const nextMonth = await getNextMonthButton(page);
|
|
150
|
-
const spy = await picker.spyOnEvent("duetChange");
|
|
151
|
-
await nextMonth.click();
|
|
152
|
-
await nextMonth.click();
|
|
153
|
-
await nextMonth.click();
|
|
154
|
-
await clickDay(page, "19. huhtikuuta");
|
|
155
|
-
expect(spy).toHaveReceivedEventTimes(1);
|
|
156
|
-
expect(spy.lastEvent.detail).toEqual({
|
|
157
|
-
component: "duet-date-picker",
|
|
158
|
-
value: "2020-04-19",
|
|
159
|
-
valueAsDate: new Date(2020, 3, 19).toISOString(),
|
|
160
|
-
});
|
|
161
|
-
});
|
|
162
|
-
it("supports selecting a date in the past", async () => {
|
|
163
|
-
const page = await generatePage({ value: "2020-01-01" });
|
|
164
|
-
await openCalendar(page);
|
|
165
|
-
const picker = await getPicker(page);
|
|
166
|
-
const spy = await picker.spyOnEvent("duetChange");
|
|
167
|
-
await setMonthDropdown(page, "3");
|
|
168
|
-
await setYearDropdown(page, "2019");
|
|
169
|
-
await page.waitForTimeout(ANIMATION_DELAY);
|
|
170
|
-
await clickDay(page, "19. huhtikuuta");
|
|
171
|
-
expect(spy).toHaveReceivedEventTimes(1);
|
|
172
|
-
expect(spy.lastEvent.detail).toEqual({
|
|
173
|
-
component: "duet-date-picker",
|
|
174
|
-
value: "2019-04-19",
|
|
175
|
-
valueAsDate: new Date(2019, 3, 19).toISOString(),
|
|
176
|
-
});
|
|
177
|
-
});
|
|
178
|
-
});
|
|
179
|
-
// see: https://www.w3.org/TR/wai-aria-practices/examples/dialog-modal/datepicker-dialog.html
|
|
180
|
-
describe("a11y/ARIA requirements", () => {
|
|
181
|
-
describe("input", () => {
|
|
182
|
-
it("has accessible label", async () => {
|
|
183
|
-
const page = await generatePage({ label: "pick date" });
|
|
184
|
-
const input = await page.find("input");
|
|
185
|
-
const id = input.getAttribute("id");
|
|
186
|
-
expect(id).toBeDefined();
|
|
187
|
-
const label = await page.find(`label[for="${id}"]`);
|
|
188
|
-
expect(label).toEqualText("pick date");
|
|
189
|
-
});
|
|
190
|
-
});
|
|
191
|
-
describe("button", () => {
|
|
192
|
-
it("has an accessible label", async () => {
|
|
193
|
-
const page = await generatePage();
|
|
194
|
-
const button = await getChooseDateButton(page);
|
|
195
|
-
const element = await button.find("duet-visually-hidden");
|
|
196
|
-
expect(element).toEqualText(i18n.fi.buttonLabel);
|
|
197
|
-
});
|
|
198
|
-
});
|
|
199
|
-
describe("dialog", () => {
|
|
200
|
-
it("meets a11y requirements", async () => {
|
|
201
|
-
const page = await generatePage();
|
|
202
|
-
const dialog = await getDialog(page);
|
|
203
|
-
// has aria-modal attr
|
|
204
|
-
expect(dialog).toBeDefined();
|
|
205
|
-
expect(dialog).toEqualAttribute("aria-modal", "true");
|
|
206
|
-
// has accessible label
|
|
207
|
-
const labelledById = dialog.getAttribute("aria-labelledby");
|
|
208
|
-
const title = await page.find(`#${labelledById}`);
|
|
209
|
-
expect(title).toBeDefined();
|
|
210
|
-
// announces keyboard support
|
|
211
|
-
const instructionText = await dialog.find("duet-visually-hidden[aria-live]");
|
|
212
|
-
expect(instructionText).toEqualText(i18n.fi.keyboardInstruction);
|
|
213
|
-
});
|
|
214
|
-
});
|
|
215
|
-
describe("grid", () => {
|
|
216
|
-
it("meets a11y requirements", async () => {
|
|
217
|
-
const page = await generatePage({ value: "2020-01-01" });
|
|
218
|
-
const grid = await getGrid(page);
|
|
219
|
-
// has accessible label
|
|
220
|
-
const labelledById = await grid.getAttribute("aria-labelledby");
|
|
221
|
-
const title = await page.find(`#${labelledById}`);
|
|
222
|
-
expect(title).toBeDefined();
|
|
223
|
-
await openCalendar(page);
|
|
224
|
-
// should be single selected element, and it should have role="gridcell"
|
|
225
|
-
const selected = await grid.findAll(`[aria-pressed="true"]`);
|
|
226
|
-
expect(selected.length).toBe(1);
|
|
227
|
-
// only one button is in focus order, has accessible label, and correct text content
|
|
228
|
-
expect(selected[0]).toEqualAttribute("tabindex", "0");
|
|
229
|
-
expect(selected[0].innerText).toContain("1. tammikuuta");
|
|
230
|
-
});
|
|
231
|
-
it.todo("correctly abbreviates the shortened day names");
|
|
232
|
-
});
|
|
233
|
-
});
|
|
234
|
-
describe("keyboard a11y", () => {
|
|
235
|
-
it("closes on ESC press", async () => {
|
|
236
|
-
const page = await generatePage();
|
|
237
|
-
await openCalendar(page);
|
|
238
|
-
await page.waitForTimeout(ANIMATION_DELAY);
|
|
239
|
-
expect(await isCalendarOpen(page)).toBe(true);
|
|
240
|
-
await page.keyboard.press("Escape");
|
|
241
|
-
await page.waitForChanges();
|
|
242
|
-
await page.waitForTimeout(ANIMATION_DELAY);
|
|
243
|
-
expect(await isCalendarOpen(page)).toBe(false);
|
|
244
|
-
});
|
|
245
|
-
it("supports selecting a date in the future", async () => {
|
|
246
|
-
const page = await generatePage({ value: "2020-01-01" });
|
|
247
|
-
const picker = await getPicker(page);
|
|
248
|
-
const spy = await picker.spyOnEvent("duetChange");
|
|
249
|
-
// open calendar
|
|
250
|
-
await page.keyboard.press("Tab");
|
|
251
|
-
await page.waitForChanges();
|
|
252
|
-
await page.keyboard.press("Tab");
|
|
253
|
-
await page.waitForChanges();
|
|
254
|
-
await page.keyboard.press("Enter");
|
|
255
|
-
await page.waitForChanges();
|
|
256
|
-
// wait for calendar to open
|
|
257
|
-
await page.waitForTimeout(ANIMATION_DELAY);
|
|
258
|
-
// set month to april
|
|
259
|
-
await setMonthDropdown(page, "3");
|
|
260
|
-
// tab to grid
|
|
261
|
-
await page.keyboard.press("Tab");
|
|
262
|
-
await page.waitForChanges();
|
|
263
|
-
await page.keyboard.press("Tab");
|
|
264
|
-
await page.waitForChanges();
|
|
265
|
-
await page.keyboard.press("Tab");
|
|
266
|
-
await page.waitForChanges();
|
|
267
|
-
await page.keyboard.press("Tab");
|
|
268
|
-
await page.waitForChanges();
|
|
269
|
-
// select 19th of month
|
|
270
|
-
await page.keyboard.press("ArrowDown");
|
|
271
|
-
await page.waitForChanges();
|
|
272
|
-
await page.keyboard.press("ArrowDown");
|
|
273
|
-
await page.waitForChanges();
|
|
274
|
-
await page.keyboard.press("ArrowRight");
|
|
275
|
-
await page.waitForChanges();
|
|
276
|
-
await page.keyboard.press("ArrowRight");
|
|
277
|
-
await page.waitForChanges();
|
|
278
|
-
await page.keyboard.press("ArrowRight");
|
|
279
|
-
await page.waitForChanges();
|
|
280
|
-
await page.keyboard.press("ArrowRight");
|
|
281
|
-
await page.waitForChanges();
|
|
282
|
-
await page.keyboard.press("Enter");
|
|
283
|
-
await page.waitForChanges();
|
|
284
|
-
expect(spy).toHaveReceivedEventTimes(1);
|
|
285
|
-
expect(spy.lastEvent.detail).toEqual({
|
|
286
|
-
component: "duet-date-picker",
|
|
287
|
-
value: "2020-04-19",
|
|
288
|
-
valueAsDate: new Date(2020, 3, 19).toISOString(),
|
|
289
|
-
});
|
|
290
|
-
});
|
|
291
|
-
it("supports selecting a date in the past", async () => {
|
|
292
|
-
const page = await generatePage({ value: "2020-01-01" });
|
|
293
|
-
const picker = await getPicker(page);
|
|
294
|
-
const spy = await picker.spyOnEvent("duetChange");
|
|
295
|
-
// open calendar
|
|
296
|
-
await page.keyboard.press("Tab");
|
|
297
|
-
await page.waitForChanges();
|
|
298
|
-
await page.keyboard.press("Tab");
|
|
299
|
-
await page.waitForChanges();
|
|
300
|
-
await page.keyboard.press("Enter");
|
|
301
|
-
await page.waitForChanges();
|
|
302
|
-
// wait for calendar to open
|
|
303
|
-
await page.waitForTimeout(ANIMATION_DELAY);
|
|
304
|
-
// select april from month dropdown
|
|
305
|
-
await setMonthDropdown(page, "3");
|
|
306
|
-
// tab to year dropdown, select 2019
|
|
307
|
-
await setYearDropdown(page, "2019");
|
|
308
|
-
// tab to grid
|
|
309
|
-
await page.keyboard.press("Tab");
|
|
310
|
-
await page.waitForChanges();
|
|
311
|
-
await page.keyboard.press("Tab");
|
|
312
|
-
await page.waitForChanges();
|
|
313
|
-
await page.keyboard.press("Tab");
|
|
314
|
-
await page.waitForChanges();
|
|
315
|
-
await page.keyboard.press("Tab");
|
|
316
|
-
await page.waitForChanges();
|
|
317
|
-
// select date 19th of month
|
|
318
|
-
await page.keyboard.press("ArrowDown");
|
|
319
|
-
await page.waitForChanges();
|
|
320
|
-
await page.keyboard.press("ArrowDown");
|
|
321
|
-
await page.waitForChanges();
|
|
322
|
-
await page.keyboard.press("ArrowRight");
|
|
323
|
-
await page.waitForChanges();
|
|
324
|
-
await page.keyboard.press("ArrowRight");
|
|
325
|
-
await page.waitForChanges();
|
|
326
|
-
await page.keyboard.press("ArrowRight");
|
|
327
|
-
await page.waitForChanges();
|
|
328
|
-
await page.keyboard.press("ArrowRight");
|
|
329
|
-
await page.waitForChanges();
|
|
330
|
-
await page.keyboard.press("Enter");
|
|
331
|
-
await page.waitForChanges();
|
|
332
|
-
expect(spy).toHaveReceivedEventTimes(1);
|
|
333
|
-
expect(spy.lastEvent.detail).toEqual({
|
|
334
|
-
component: "duet-date-picker",
|
|
335
|
-
value: "2019-04-19",
|
|
336
|
-
valueAsDate: new Date(2019, 3, 19).toISOString(),
|
|
337
|
-
});
|
|
338
|
-
});
|
|
339
|
-
it.todo("moves focus to start of week on home press");
|
|
340
|
-
it.todo("moves focus to end of week end press");
|
|
341
|
-
it.todo("moves focus to previous month on page up press");
|
|
342
|
-
it.todo("moves focus to next month on page down press");
|
|
343
|
-
it.todo("moves focus to previous year on shift + page down press");
|
|
344
|
-
it.todo("moves focus to next year on shift + page down press");
|
|
345
|
-
});
|
|
346
|
-
describe("events", () => {
|
|
347
|
-
it("raises a duetBlur event when the input is blurred", async () => {
|
|
348
|
-
const page = await generatePage();
|
|
349
|
-
const picker = await page.find("duet-date-picker");
|
|
350
|
-
const spy = await picker.spyOnEvent("duetBlur");
|
|
351
|
-
await page.keyboard.press("Tab");
|
|
352
|
-
await page.keyboard.press("Tab");
|
|
353
|
-
expect(spy).toHaveReceivedEventTimes(1);
|
|
354
|
-
});
|
|
355
|
-
it("raises a duetFocus event when the input is focused", async () => {
|
|
356
|
-
const page = await generatePage();
|
|
357
|
-
const picker = await page.find("duet-date-picker");
|
|
358
|
-
const spy = await picker.spyOnEvent("duetFocus");
|
|
359
|
-
await page.keyboard.press("Tab");
|
|
360
|
-
expect(spy).toHaveReceivedEventTimes(1);
|
|
361
|
-
});
|
|
362
|
-
});
|
|
363
|
-
describe("focus management", () => {
|
|
364
|
-
async function assertDayButtonFocused(page) {
|
|
365
|
-
const focused = await getFocusedElement(page);
|
|
366
|
-
const tag = await page.evaluate((element) => element.tagName.toLowerCase(), focused);
|
|
367
|
-
const tabIndex = await page.evaluate((element) => element.tabIndex, focused);
|
|
368
|
-
expect(tabIndex).toBe(0);
|
|
369
|
-
expect(tag).toEqual("button");
|
|
370
|
-
}
|
|
371
|
-
async function assertCloseButtonFocused(page) {
|
|
372
|
-
const focused = await getFocusedElement(page);
|
|
373
|
-
const tag = await page.evaluate((element) => element.tagName.toLowerCase(), focused);
|
|
374
|
-
const text = await page.evaluate((element) => element.innerText, focused);
|
|
375
|
-
expect(text).toBe(i18n.fi.closeLabel);
|
|
376
|
-
expect(tag).toEqual("button");
|
|
377
|
-
}
|
|
378
|
-
async function assertMonthDropdownFocused(page) {
|
|
379
|
-
const focused = await getFocusedElement(page);
|
|
380
|
-
const tag = await page.evaluate(element => element.tagName.toLowerCase(), focused);
|
|
381
|
-
const id = await page.evaluate(element => element.id, focused);
|
|
382
|
-
const label = await page.find(`label[for="${id}"]`);
|
|
383
|
-
expect(label).toEqualText(i18n.fi.monthSelectLabel);
|
|
384
|
-
expect(tag).toEqual("select");
|
|
385
|
-
}
|
|
386
|
-
async function assertYearDropdownFocused(page) {
|
|
387
|
-
const focused = await getFocusedElement(page);
|
|
388
|
-
const tag = await page.evaluate(element => element.tagName.toLowerCase(), focused);
|
|
389
|
-
const id = await page.evaluate(element => element.id, focused);
|
|
390
|
-
const label = await page.find(`label[for="${id}"]`);
|
|
391
|
-
expect(label).toEqualText(i18n.fi.yearSelectLabel);
|
|
392
|
-
expect(tag).toEqual("select");
|
|
393
|
-
}
|
|
394
|
-
async function assertPrevMonthFocused(page) {
|
|
395
|
-
const focused = await getFocusedElement(page);
|
|
396
|
-
const tag = await page.evaluate((element) => element.tagName.toLowerCase(), focused);
|
|
397
|
-
const text = await page.evaluate((element) => element.innerText, focused);
|
|
398
|
-
expect(text).toBe(i18n.fi.prevMonthLabel);
|
|
399
|
-
expect(tag).toEqual("duet-action-button");
|
|
400
|
-
}
|
|
401
|
-
async function assertNextMonthFocused(page) {
|
|
402
|
-
const focused = await getFocusedElement(page);
|
|
403
|
-
const tag = await page.evaluate((element) => element.tagName.toLowerCase(), focused);
|
|
404
|
-
const text = await page.evaluate((element) => element.innerText, focused);
|
|
405
|
-
expect(text).toBe(i18n.fi.nextMonthLabel);
|
|
406
|
-
expect(tag).toEqual("duet-action-button");
|
|
407
|
-
}
|
|
408
|
-
async function assertToggleButtonFocused(page, negate = false) {
|
|
409
|
-
const focused = await getFocusedElement(page);
|
|
410
|
-
const tag = await page.evaluate((element) => element.tagName.toLowerCase(), focused);
|
|
411
|
-
const text = await page.evaluate((element) => element.innerText, focused);
|
|
412
|
-
if (negate) {
|
|
413
|
-
expect(tag).not.toEqual("button");
|
|
414
|
-
expect(text).not.toContain(`${i18n.fi.buttonLabel}, ${i18n.fi.selected}`);
|
|
415
|
-
}
|
|
416
|
-
else {
|
|
417
|
-
expect(tag).toEqual("button");
|
|
418
|
-
expect(text).toContain(`${i18n.fi.buttonLabel}, ${i18n.fi.selected}`);
|
|
419
|
-
}
|
|
420
|
-
}
|
|
421
|
-
it("traps focus in calendar", async () => {
|
|
422
|
-
const page = await generatePage();
|
|
423
|
-
await openCalendar(page);
|
|
424
|
-
await page.waitForTimeout(ANIMATION_DELAY);
|
|
425
|
-
const focusOrder = [
|
|
426
|
-
assertMonthDropdownFocused,
|
|
427
|
-
assertYearDropdownFocused,
|
|
428
|
-
assertPrevMonthFocused,
|
|
429
|
-
assertNextMonthFocused,
|
|
430
|
-
assertDayButtonFocused,
|
|
431
|
-
assertCloseButtonFocused,
|
|
432
|
-
];
|
|
433
|
-
for (const assertion of focusOrder) {
|
|
434
|
-
await assertion(page);
|
|
435
|
-
await page.keyboard.press("Tab");
|
|
436
|
-
}
|
|
437
|
-
// should arrive back at the start
|
|
438
|
-
const assertion = focusOrder[0];
|
|
439
|
-
await assertion(page);
|
|
440
|
-
});
|
|
441
|
-
it.todo("doesn't shift focus when interacting with calendar navigation controls");
|
|
442
|
-
it("shifts focus back to button on date select", async () => {
|
|
443
|
-
const page = await generatePage({ value: "2020-01-01" });
|
|
444
|
-
await openCalendar(page);
|
|
445
|
-
await page.waitForTimeout(ANIMATION_DELAY);
|
|
446
|
-
await clickDay(page, "10. tammikuuta");
|
|
447
|
-
await page.waitForChanges();
|
|
448
|
-
await assertToggleButtonFocused(page);
|
|
449
|
-
});
|
|
450
|
-
it("shifts focus back to button on ESC press", async () => {
|
|
451
|
-
const page = await generatePage({ value: "2020-01-01" });
|
|
452
|
-
await openCalendar(page);
|
|
453
|
-
await page.waitForTimeout(ANIMATION_DELAY);
|
|
454
|
-
await page.keyboard.press("Escape");
|
|
455
|
-
await page.waitForChanges();
|
|
456
|
-
await assertToggleButtonFocused(page);
|
|
457
|
-
});
|
|
458
|
-
it("doesn't shift focus to button on click outside", async () => {
|
|
459
|
-
const page = await generatePage({ value: "2020-01-01" });
|
|
460
|
-
await openCalendar(page);
|
|
461
|
-
await page.waitForTimeout(ANIMATION_DELAY);
|
|
462
|
-
await clickOutside(page);
|
|
463
|
-
await assertToggleButtonFocused(page, true);
|
|
464
|
-
});
|
|
465
|
-
});
|
|
466
|
-
describe("min/max support", () => {
|
|
467
|
-
it("supports a min date", async () => {
|
|
468
|
-
const page = await generatePage({ value: "2020-01-15", min: "2020-01-02" });
|
|
469
|
-
const picker = await getPicker(page);
|
|
470
|
-
const spy = await picker.spyOnEvent("duetChange");
|
|
471
|
-
await openCalendar(page);
|
|
472
|
-
// wait for calendar to open
|
|
473
|
-
await page.waitForTimeout(ANIMATION_DELAY);
|
|
474
|
-
// try clicking a day outside the range
|
|
475
|
-
await clickDay(page, "1. tammikuuta");
|
|
476
|
-
expect(spy).toHaveReceivedEventTimes(0);
|
|
477
|
-
// click a day inside the range
|
|
478
|
-
await clickDay(page, "2. tammikuuta");
|
|
479
|
-
expect(spy).toHaveReceivedEventTimes(1);
|
|
480
|
-
expect(spy.lastEvent.detail).toEqual({
|
|
481
|
-
component: "duet-date-picker",
|
|
482
|
-
value: "2020-01-02",
|
|
483
|
-
valueAsDate: new Date(2020, 0, 2).toISOString(),
|
|
484
|
-
});
|
|
485
|
-
});
|
|
486
|
-
it("supports a max date", async () => {
|
|
487
|
-
const page = await generatePage({ value: "2020-01-15", max: "2020-01-30" });
|
|
488
|
-
const picker = await getPicker(page);
|
|
489
|
-
const spy = await picker.spyOnEvent("duetChange");
|
|
490
|
-
await openCalendar(page);
|
|
491
|
-
// wait for calendar to open
|
|
492
|
-
await page.waitForTimeout(ANIMATION_DELAY);
|
|
493
|
-
// try clicking a day outside the range
|
|
494
|
-
await clickDay(page, "31. tammikuuta");
|
|
495
|
-
expect(spy).toHaveReceivedEventTimes(0);
|
|
496
|
-
// click a day inside the range
|
|
497
|
-
await clickDay(page, "30. tammikuuta");
|
|
498
|
-
expect(spy).toHaveReceivedEventTimes(1);
|
|
499
|
-
expect(spy.lastEvent.detail).toEqual({
|
|
500
|
-
component: "duet-date-picker",
|
|
501
|
-
value: "2020-01-30",
|
|
502
|
-
valueAsDate: new Date(2020, 0, 30).toISOString(),
|
|
503
|
-
});
|
|
504
|
-
});
|
|
505
|
-
it("supports min and max dates", async () => {
|
|
506
|
-
const page = await generatePage({ value: "2020-01-15", min: "2020-01-02", max: "2020-01-30" });
|
|
507
|
-
const picker = await getPicker(page);
|
|
508
|
-
const spy = await picker.spyOnEvent("duetChange");
|
|
509
|
-
await openCalendar(page);
|
|
510
|
-
// wait for calendar to open
|
|
511
|
-
await page.waitForTimeout(ANIMATION_DELAY);
|
|
512
|
-
// try clicking a day less than min
|
|
513
|
-
await clickDay(page, "1. tammikuuta");
|
|
514
|
-
expect(spy).toHaveReceivedEventTimes(0);
|
|
515
|
-
// try clicking a day greater than max
|
|
516
|
-
await clickDay(page, "31. tammikuuta");
|
|
517
|
-
expect(spy).toHaveReceivedEventTimes(0);
|
|
518
|
-
// click a day inside the range
|
|
519
|
-
await clickDay(page, "30. tammikuuta");
|
|
520
|
-
expect(spy).toHaveReceivedEventTimes(1);
|
|
521
|
-
expect(spy.lastEvent.detail).toEqual({
|
|
522
|
-
component: "duet-date-picker",
|
|
523
|
-
value: "2020-01-30",
|
|
524
|
-
valueAsDate: new Date(2020, 0, 30).toISOString(),
|
|
525
|
-
});
|
|
526
|
-
});
|
|
527
|
-
it("disables prev month button if same month and year as min", async () => {
|
|
528
|
-
const page = await generatePage({ value: "2020-04-19", min: "2020-04-01" });
|
|
529
|
-
await openCalendar(page);
|
|
530
|
-
const prevMonthButton = await getPrevMonthButton(page);
|
|
531
|
-
expect(prevMonthButton).toHaveAttribute("disabled");
|
|
532
|
-
});
|
|
533
|
-
it("disables next month button if same month and year as max", async () => {
|
|
534
|
-
const page = await generatePage({ value: "2020-04-19", max: "2020-04-30" });
|
|
535
|
-
await openCalendar(page);
|
|
536
|
-
const nextMonthButton = await getNextMonthButton(page);
|
|
537
|
-
expect(nextMonthButton).toHaveAttribute("disabled");
|
|
538
|
-
});
|
|
539
|
-
it("does not disable prev/next buttons when only month value (but not year) is same as min and max", async () => {
|
|
540
|
-
// there was a bug whereby both buttons would be disabled if the min/max/selected date
|
|
541
|
-
// had the same month (here: 4), but different years. this tests ensures no regression
|
|
542
|
-
const page = await generatePage({ value: "2020-04-19", min: "2019-04-19", max: "2021-04-19" });
|
|
543
|
-
await openCalendar(page);
|
|
544
|
-
const prevMonthButton = await getPrevMonthButton(page);
|
|
545
|
-
const nextMonthButton = await getNextMonthButton(page);
|
|
546
|
-
expect(prevMonthButton).not.toHaveAttribute("disabled");
|
|
547
|
-
expect(nextMonthButton).not.toHaveAttribute("disabled");
|
|
548
|
-
});
|
|
549
|
-
it("respects min/max dates when generating year dropdown", async () => {
|
|
550
|
-
const page = await generatePage({ value: "2020-04-19", min: "2019-04-19", max: "2021-04-19" });
|
|
551
|
-
const allowedYears = await page.$eval(".duet-date-year-select", (select) => {
|
|
552
|
-
return Array.from(select.options).map(option => option.value);
|
|
553
|
-
});
|
|
554
|
-
expect(allowedYears).toEqual(["2019", "2020", "2021"]);
|
|
555
|
-
});
|
|
556
|
-
it("respects min/max dates when generating month dropdown", async () => {
|
|
557
|
-
const page = await generatePage({ value: "2020-04-19", min: "2019-04-01", max: "2020-05-31" });
|
|
558
|
-
await openCalendar(page);
|
|
559
|
-
function getAllowedMonths() {
|
|
560
|
-
return page.$eval(".duet-date-month-select", (select) => {
|
|
561
|
-
return Array.from(select.options)
|
|
562
|
-
.filter(option => !option.disabled)
|
|
563
|
-
.map(option => option.value);
|
|
564
|
-
});
|
|
565
|
-
}
|
|
566
|
-
// in 2020, January - May is allowed
|
|
567
|
-
let allowedMonths = await getAllowedMonths();
|
|
568
|
-
expect(allowedMonths).toEqual(["0", "1", "2", "3", "4"]);
|
|
569
|
-
await setYearDropdown(page, "2019");
|
|
570
|
-
// in 2019, April - December is allowed
|
|
571
|
-
allowedMonths = await getAllowedMonths();
|
|
572
|
-
expect(allowedMonths).toEqual(["3", "4", "5", "6", "7", "8", "9", "10", "11"]);
|
|
573
|
-
});
|
|
574
|
-
});
|
|
575
|
-
describe("methods", () => {
|
|
576
|
-
it("should open calendar on show()", async () => {
|
|
577
|
-
const page = await generatePage();
|
|
578
|
-
const picker = await page.find("duet-date-picker");
|
|
579
|
-
expect(await isCalendarOpen(page)).toBe(false);
|
|
580
|
-
await picker.callMethod("show");
|
|
581
|
-
await page.waitForChanges();
|
|
582
|
-
expect(await isCalendarOpen(page)).toBe(true);
|
|
583
|
-
});
|
|
584
|
-
it("should close calendar on hide()", async () => {
|
|
585
|
-
const page = await generatePage();
|
|
586
|
-
const picker = await page.find("duet-date-picker");
|
|
587
|
-
await picker.callMethod("show");
|
|
588
|
-
await page.waitForChanges();
|
|
589
|
-
expect(await isCalendarOpen(page)).toBe(true);
|
|
590
|
-
await picker.callMethod("hide");
|
|
591
|
-
await page.waitForChanges();
|
|
592
|
-
const dialog = await getDialog(page);
|
|
593
|
-
await dialog.waitForNotVisible();
|
|
594
|
-
expect(await isCalendarOpen(page)).toBe(false);
|
|
595
|
-
});
|
|
596
|
-
it("should focus input on setFocus()", async () => {
|
|
597
|
-
const page = await generatePage({ label: "test label" });
|
|
598
|
-
const picker = await page.find("duet-date-picker");
|
|
599
|
-
await picker.callMethod("setFocus");
|
|
600
|
-
await page.waitForChanges();
|
|
601
|
-
const focused = await getFocusedElement(page);
|
|
602
|
-
const id = await page.evaluate(element => element.id, focused);
|
|
603
|
-
const label = await page.find(`label[for="${id}"]`);
|
|
604
|
-
expect(label).toEqualText("test label");
|
|
605
|
-
});
|
|
606
|
-
});
|
|
607
|
-
describe("form interaction", () => {
|
|
608
|
-
it("supports required attribute", async () => {
|
|
609
|
-
const page = await createPage(`
|
|
610
|
-
<form>
|
|
611
|
-
<duet-date-picker required></duet-date-picker>
|
|
612
|
-
<button type="submit">submit</button>
|
|
613
|
-
</form>
|
|
614
|
-
`);
|
|
615
|
-
const picker = await getPicker(page);
|
|
616
|
-
const button = await page.find("button[type='submit']");
|
|
617
|
-
const form = await page.find("form");
|
|
618
|
-
const spy = await form.spyOnEvent("submit");
|
|
619
|
-
await button.click();
|
|
620
|
-
await page.waitForChanges();
|
|
621
|
-
expect(spy).toHaveReceivedEventTimes(0);
|
|
622
|
-
picker.setProperty("value", "2020-01-01");
|
|
623
|
-
await page.waitForChanges();
|
|
624
|
-
await button.click();
|
|
625
|
-
expect(spy).toHaveReceivedEventTimes(1);
|
|
626
|
-
});
|
|
627
|
-
it("always submits value as ISO date", async () => {
|
|
628
|
-
const page = await createPage(`
|
|
629
|
-
<form>
|
|
630
|
-
<duet-date-picker name="test"></duet-date-picker>
|
|
631
|
-
<button type="submit">submit</button>
|
|
632
|
-
</form>
|
|
633
|
-
`);
|
|
634
|
-
const picker = await getPicker(page);
|
|
635
|
-
const input = await getInput(page);
|
|
636
|
-
picker.setProperty("value", "2020-01-01");
|
|
637
|
-
await page.waitForChanges();
|
|
638
|
-
// submitted value should be ISO format
|
|
639
|
-
const submittedValue = await page.$eval("form", (form) => new FormData(form).get("test"));
|
|
640
|
-
expect(submittedValue).toEqual("2020-01-01");
|
|
641
|
-
// whilst the displayed value should be Finnish format
|
|
642
|
-
expect(await input.getProperty("value")).toEqual("01.01.2020");
|
|
643
|
-
});
|
|
644
|
-
});
|
|
645
|
-
describe("constraint validation", () => {
|
|
646
|
-
test.each `
|
|
647
|
-
input | required | min | max | valueMissing | badInput | rangeUnderflow | rangeOverflow
|
|
648
|
-
${""} | ${false} | ${""} | ${""} | ${false} | ${false} | ${false} | ${false}
|
|
649
|
-
${""} | ${true} | ${""} | ${""} | ${true} | ${false} | ${false} | ${false}
|
|
650
|
-
${"11"} | ${false} | ${""} | ${""} | ${false} | ${true} | ${false} | ${false}
|
|
651
|
-
${"11"} | ${true} | ${""} | ${""} | ${true} | ${true} | ${false} | ${false}
|
|
652
|
-
${"01.01.2020"} | ${true} | ${"2021-01-01"} | ${""} | ${false} | ${false} | ${true} | ${false}
|
|
653
|
-
${"01.01.2023"} | ${true} | ${"2021-01-01"} | ${"2022-01-01"} | ${false} | ${false} | ${false} | ${true}
|
|
654
|
-
${"01.01.2021"} | ${true} | ${"2021-01-01"} | ${"2022-01-01"} | ${false} | ${false} | ${false} | ${false}
|
|
655
|
-
`("when '$input' is entered, required is '$required', min is '$min', max is '$max', then valueMissing is $valueMissing, badInput is $badInput, rangerOverflow is $rangeOverflow, rangeUnderflow is $rangeUnderflow", async ({ input, required, min, max, valueMissing, badInput, rangeUnderflow, rangeOverflow }) => {
|
|
656
|
-
const attrs = Object.entries({ min, max, required })
|
|
657
|
-
.filter(([, value]) => value)
|
|
658
|
-
.map(([attr, value]) => `${attr}="${value}"`)
|
|
659
|
-
.join(" ");
|
|
660
|
-
const page = await createPage(`
|
|
661
|
-
<duet-date-picker ${attrs}></duet-date-picker>
|
|
662
|
-
<input type="date" ${attrs} />
|
|
663
|
-
`);
|
|
664
|
-
await page.type(`duet-date-picker input[type="text"]`, input, { delay: 20 });
|
|
665
|
-
const duetValidity = await page.$eval(`duet-date-picker`, ({ validity }) => validity);
|
|
666
|
-
await page.type(`input[type="date"]`, input.replace(".", ""), { delay: 20 });
|
|
667
|
-
// have to manually copy properties into new object,
|
|
668
|
-
// since native ValidityState doesn't support JSON serialization
|
|
669
|
-
const nativeValidity = await page.$eval(`input[type="date"]`, ({ validity }) => {
|
|
670
|
-
const result = {};
|
|
671
|
-
for (const prop in validity) {
|
|
672
|
-
result[prop] = validity[prop];
|
|
673
|
-
}
|
|
674
|
-
return result;
|
|
675
|
-
});
|
|
676
|
-
const expected = {
|
|
677
|
-
patternMismatch: false,
|
|
678
|
-
customError: false,
|
|
679
|
-
stepMismatch: false,
|
|
680
|
-
tooLong: false,
|
|
681
|
-
tooShort: false,
|
|
682
|
-
typeMismatch: false,
|
|
683
|
-
valueMissing,
|
|
684
|
-
badInput,
|
|
685
|
-
rangeUnderflow,
|
|
686
|
-
rangeOverflow,
|
|
687
|
-
valid: !valueMissing && !badInput && !rangeUnderflow && !rangeOverflow,
|
|
688
|
-
};
|
|
689
|
-
expect(duetValidity).toEqual(expected);
|
|
690
|
-
expect(nativeValidity).toEqual(expected);
|
|
691
|
-
});
|
|
692
|
-
});
|
|
693
|
-
});
|