@duetds/components 6.8.1 → 6.8.3
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.js +259 -63
- package/lib/cjs/duet-action-button.cjs.entry.js +1 -1
- package/lib/cjs/duet-alert.cjs.entry.js +1 -1
- package/lib/cjs/duet-badge.cjs.entry.js +1 -1
- package/lib/cjs/duet-breadcrumb.cjs.entry.js +1 -1
- package/lib/cjs/duet-breadcrumbs.cjs.entry.js +1 -1
- package/lib/cjs/duet-button_2.cjs.entry.js +1 -1
- package/lib/cjs/duet-caption_4.cjs.entry.js +1 -1
- package/lib/cjs/duet-card.cjs.entry.js +1 -1
- package/lib/cjs/duet-checkbox.cjs.entry.js +1 -1
- package/lib/cjs/duet-checkmark.cjs.entry.js +1 -1
- package/lib/cjs/duet-choice_2.cjs.entry.js +2 -2
- package/lib/cjs/duet-collapsible.cjs.entry.js +4 -2
- package/lib/cjs/duet-combobox.cjs.entry.js +1 -1
- package/lib/cjs/duet-contact-card.cjs.entry.js +1 -1
- package/lib/cjs/duet-cookie-consent.cjs.entry.js +1 -1
- package/lib/cjs/duet-date-picker.cjs.entry.js +2 -2
- package/lib/cjs/duet-divider_2.cjs.entry.js +1 -1
- package/lib/cjs/duet-editable-table_3.cjs.entry.js +1 -1
- package/lib/cjs/duet-empty-state.cjs.entry.js +1 -1
- package/lib/cjs/duet-fieldset.cjs.entry.js +1 -1
- package/lib/cjs/duet-footer.cjs.entry.js +1 -1
- package/lib/cjs/duet-grid_2.cjs.entry.js +1 -1
- package/lib/cjs/duet-header_2.cjs.entry.js +1 -1
- package/lib/cjs/duet-hero.cjs.entry.js +3 -3
- package/lib/cjs/duet-icon.cjs.entry.js +1 -1
- package/lib/cjs/duet-input_2.cjs.entry.js +1 -1
- package/lib/cjs/duet-layout.cjs.entry.js +1 -1
- package/lib/cjs/duet-list_2.cjs.entry.js +1 -1
- package/lib/cjs/duet-menu-bar-button.cjs.entry.js +2 -2
- package/lib/cjs/duet-menu-bar-dropdown-link.cjs.entry.js +11 -3
- package/lib/cjs/duet-menu-bar-dropdown.cjs.entry.js +17 -4
- package/lib/cjs/duet-menu-bar-link.cjs.entry.js +3 -3
- package/lib/cjs/duet-menu-bar.cjs.entry.js +7 -1
- package/lib/cjs/duet-modal.cjs.entry.js +2 -2
- package/lib/cjs/duet-multiselect.cjs.entry.js +1 -1
- package/lib/cjs/duet-nav.cjs.entry.js +1 -1
- package/lib/cjs/duet-notification_2.cjs.entry.js +1 -1
- package/lib/cjs/duet-number-input.cjs.entry.js +3 -3
- package/lib/cjs/duet-page-heading.cjs.entry.js +1 -1
- package/lib/cjs/duet-pagination_2.cjs.entry.js +1 -1
- package/lib/cjs/duet-progress.cjs.entry.js +1 -1
- package/lib/cjs/duet-radio_2.cjs.entry.js +1 -1
- package/lib/cjs/duet-range-slider.cjs.entry.js +1 -1
- package/lib/cjs/duet-scrollable_3.cjs.entry.js +2 -2
- package/lib/cjs/duet-section-layout.cjs.entry.js +1 -1
- package/lib/cjs/duet-select.cjs.entry.js +1 -1
- package/lib/cjs/duet-slideout-lang.cjs.entry.js +2 -2
- package/lib/cjs/duet-slideout-link.cjs.entry.js +3 -3
- package/lib/cjs/duet-slideout-panel-dropdown.cjs.entry.js +10 -4
- package/lib/cjs/duet-slideout-panel.cjs.entry.js +31 -10
- package/lib/cjs/duet-slideout.cjs.entry.js +42 -10
- package/lib/cjs/duet-step_2.cjs.entry.js +1 -1
- package/lib/cjs/duet-submenu-bar-dropdown-link.cjs.entry.js +13 -3
- package/lib/cjs/duet-submenu-bar-dropdown.cjs.entry.js +31 -5
- package/lib/cjs/duet-submenu-bar-link.cjs.entry.js +12 -3
- package/lib/cjs/duet-submenu-bar.cjs.entry.js +42 -4
- package/lib/cjs/duet-textarea.cjs.entry.js +1 -1
- package/lib/cjs/duet-toggle.cjs.entry.js +1 -1
- package/lib/cjs/duet-toolbar-dropdown-link.cjs.entry.js +11 -3
- package/lib/cjs/duet-toolbar-dropdown.cjs.entry.js +17 -4
- package/lib/cjs/duet-toolbar-link.cjs.entry.js +3 -3
- package/lib/cjs/duet-toolbar.cjs.entry.js +1 -1
- package/lib/cjs/duet-tooltip.cjs.entry.js +4 -1
- package/lib/cjs/duet-tray.cjs.entry.js +1 -1
- package/lib/cjs/duet-upload-aria-status.cjs.entry.js +1 -1
- package/lib/cjs/duet-visually-hidden.cjs.entry.js +1 -1
- package/lib/cjs/duet.cjs.js +2 -2
- package/lib/cjs/{focus-utils-b0dc8aa1.js → focus-utils-2ff2eab6.js} +1 -1
- package/lib/cjs/{index-d02209e9.js → index-6d5f06d0.js} +1 -1
- package/lib/cjs/loader.cjs.js +2 -2
- package/lib/collection/components/duet-collapsible/duet-collapsible.css +3 -0
- package/lib/collection/components/duet-collapsible/duet-collapsible.js +20 -0
- package/lib/collection/components/duet-hero/duet-hero.css +8 -2
- package/lib/collection/components/duet-hero/duet-hero.js +1 -1
- package/lib/collection/components/duet-menu-bar/duet-menu-bar.js +16 -1
- package/lib/collection/components/duet-menu-bar-button/duet-menu-bar-button.css +10 -0
- package/lib/collection/components/duet-menu-bar-dropdown/duet-menu-bar-dropdown.css +7 -0
- package/lib/collection/components/duet-menu-bar-dropdown/duet-menu-bar-dropdown.js +41 -2
- package/lib/collection/components/duet-menu-bar-dropdown-link/duet-menu-bar-dropdown-link.css +7 -0
- package/lib/collection/components/duet-menu-bar-dropdown-link/duet-menu-bar-dropdown-link.js +9 -1
- package/lib/collection/components/duet-menu-bar-link/duet-menu-bar-link.css +10 -0
- package/lib/collection/components/duet-menu-bar-link/duet-menu-bar-link.js +1 -1
- package/lib/collection/components/duet-number-input/duet-number-input.js +2 -2
- package/lib/collection/components/duet-slideout/duet-slideout.css +15 -1
- package/lib/collection/components/duet-slideout/duet-slideout.js +69 -7
- package/lib/collection/components/duet-slideout-lang/duet-slideout-lang.js +1 -1
- package/lib/collection/components/duet-slideout-link/duet-slideout-link.css +7 -0
- package/lib/collection/components/duet-slideout-link/duet-slideout-link.js +1 -1
- package/lib/collection/components/duet-slideout-panel/duet-slideout-panel.css +18 -2
- package/lib/collection/components/duet-slideout-panel/duet-slideout-panel.js +54 -7
- package/lib/collection/components/duet-slideout-panel-dropdown/duet-slideout-panel-dropdown.css +13 -3
- package/lib/collection/components/duet-slideout-panel-dropdown/duet-slideout-panel-dropdown.js +34 -2
- package/lib/collection/components/duet-submenu-bar/duet-submenu-bar.css +7 -0
- package/lib/collection/components/duet-submenu-bar/duet-submenu-bar.js +71 -2
- package/lib/collection/components/duet-submenu-bar-dropdown/duet-submenu-bar-dropdown.css +41 -8
- package/lib/collection/components/duet-submenu-bar-dropdown/duet-submenu-bar-dropdown.js +73 -3
- package/lib/collection/components/duet-submenu-bar-dropdown-link/duet-submenu-bar-dropdown-link.css +30 -0
- package/lib/collection/components/duet-submenu-bar-dropdown-link/duet-submenu-bar-dropdown-link.js +29 -1
- package/lib/collection/components/duet-submenu-bar-link/duet-submenu-bar-link.css +54 -0
- package/lib/collection/components/duet-submenu-bar-link/duet-submenu-bar-link.js +28 -1
- package/lib/collection/components/duet-tab-group/duet-tab-group.css +8 -0
- package/lib/collection/components/duet-toolbar-dropdown/duet-toolbar-dropdown.css +7 -0
- package/lib/collection/components/duet-toolbar-dropdown/duet-toolbar-dropdown.js +41 -2
- package/lib/collection/components/duet-toolbar-dropdown-link/duet-toolbar-dropdown-link.css +7 -0
- package/lib/collection/components/duet-toolbar-dropdown-link/duet-toolbar-dropdown-link.js +9 -1
- package/lib/collection/components/duet-toolbar-link/duet-toolbar-link.css +7 -0
- package/lib/collection/components/duet-toolbar-link/duet-toolbar-link.js +1 -1
- package/lib/collection/components/duet-tooltip/duet-tooltip.js +3 -0
- 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-breadcrumb.js +2 -2
- package/lib/dist-custom-elements/duet-breadcrumbs.js +2 -2
- package/lib/dist-custom-elements/duet-button.js +1 -1
- package/lib/dist-custom-elements/duet-caption.js +1 -1
- package/lib/dist-custom-elements/duet-card.js +3 -3
- 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-choice-group.js +6 -6
- package/lib/dist-custom-elements/duet-choice.js +5 -5
- package/lib/dist-custom-elements/duet-collapsible.js +6 -3
- package/lib/dist-custom-elements/duet-combobox.js +2 -2
- package/lib/dist-custom-elements/duet-contact-card.js +8 -8
- package/lib/dist-custom-elements/duet-cookie-consent.js +6 -6
- package/lib/dist-custom-elements/duet-date-picker.js +10 -10
- package/lib/dist-custom-elements/duet-divider.js +1 -1
- package/lib/dist-custom-elements/duet-editable-table.js +1 -1
- 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-footer.js +4 -4
- 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 +8 -8
- package/lib/dist-custom-elements/duet-heading.js +1 -1
- package/lib/dist-custom-elements/duet-hero.js +11 -11
- 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 +1 -1
- 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 +3 -3
- package/lib/dist-custom-elements/duet-menu-bar-dropdown-link.js +12 -4
- package/lib/dist-custom-elements/duet-menu-bar-dropdown.js +20 -6
- package/lib/dist-custom-elements/duet-menu-bar-link.js +4 -4
- package/lib/dist-custom-elements/duet-menu-bar.js +9 -3
- package/lib/dist-custom-elements/duet-modal.js +7 -7
- package/lib/dist-custom-elements/duet-multiselect.js +8 -8
- package/lib/dist-custom-elements/duet-nav.js +1 -1
- package/lib/dist-custom-elements/duet-notification-drawer.js +4 -4
- package/lib/dist-custom-elements/duet-notification.js +2 -2
- package/lib/dist-custom-elements/duet-number-input.js +11 -11
- package/lib/dist-custom-elements/duet-page-heading.js +2 -2
- package/lib/dist-custom-elements/duet-pagination.js +7 -7
- package/lib/dist-custom-elements/duet-paragraph.js +1 -1
- package/lib/dist-custom-elements/duet-progress.js +1 -1
- package/lib/dist-custom-elements/duet-radio-group.js +6 -6
- package/lib/dist-custom-elements/duet-radio.js +1 -1
- package/lib/dist-custom-elements/duet-range-slider.js +2 -2
- package/lib/dist-custom-elements/duet-range-stepper.js +4 -4
- package/lib/dist-custom-elements/duet-scrollable.js +1 -1
- package/lib/dist-custom-elements/duet-section-layout.js +1 -1
- package/lib/dist-custom-elements/duet-select.js +1 -1
- package/lib/dist-custom-elements/duet-slideout-lang.js +4 -10
- package/lib/dist-custom-elements/duet-slideout-link.js +4 -4
- package/lib/dist-custom-elements/duet-slideout-panel-dropdown.js +13 -6
- package/lib/dist-custom-elements/duet-slideout-panel.js +33 -11
- package/lib/dist-custom-elements/duet-slideout.js +44 -12
- 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 +4 -4
- package/lib/dist-custom-elements/duet-stepper.js +2 -2
- package/lib/dist-custom-elements/duet-submenu-bar-dropdown-link.js +15 -4
- package/lib/dist-custom-elements/duet-submenu-bar-dropdown.js +35 -7
- package/lib/dist-custom-elements/duet-submenu-bar-link.js +14 -4
- package/lib/dist-custom-elements/duet-submenu-bar.js +46 -6
- package/lib/dist-custom-elements/duet-tab-group.js +10 -10
- package/lib/dist-custom-elements/duet-tab.js +1 -1
- package/lib/dist-custom-elements/duet-table.js +1 -1
- package/lib/dist-custom-elements/duet-textarea.js +8 -8
- package/lib/dist-custom-elements/duet-toggle.js +2 -2
- package/lib/dist-custom-elements/duet-toolbar-dropdown-link.js +12 -4
- package/lib/dist-custom-elements/duet-toolbar-dropdown.js +20 -6
- package/lib/dist-custom-elements/duet-toolbar-link.js +4 -4
- package/lib/dist-custom-elements/duet-toolbar.js +1 -1
- package/lib/dist-custom-elements/duet-tooltip.js +1 -1
- package/lib/dist-custom-elements/duet-tray.js +3 -3
- package/lib/dist-custom-elements/duet-upload-aria-status.js +1 -1
- package/lib/dist-custom-elements/duet-upload.js +18 -18
- package/lib/dist-custom-elements/duet-visually-hidden.js +1 -1
- package/lib/dist-custom-elements/index.js +1 -1
- package/lib/dist-custom-elements/{p-6f251b0d.js → p-05e73b74.js} +1 -1
- package/lib/dist-custom-elements/{p-2b1e6b5d.js → p-10030e7c.js} +1 -1
- package/lib/dist-custom-elements/{p-2d0de36a.js → p-13d9d4b0.js} +1 -1
- package/lib/dist-custom-elements/{p-43c6d719.js → p-1cb77270.js} +2 -2
- package/lib/dist-custom-elements/{p-f6acbcec.js → p-26afb575.js} +1 -1
- package/lib/dist-custom-elements/{p-51d9c7c1.js → p-2e97d3cf.js} +1 -1
- package/lib/dist-custom-elements/{p-9ffd6287.js → p-4a7f34e4.js} +2 -2
- package/lib/dist-custom-elements/{p-01ffc602.js → p-4ad31816.js} +1 -1
- package/lib/dist-custom-elements/{p-bf7f746f.js → p-53076cdd.js} +2 -2
- package/lib/dist-custom-elements/{p-cc3bb9f3.js → p-57aace09.js} +6 -3
- package/lib/dist-custom-elements/{p-76544393.js → p-5ab6461c.js} +1 -1
- package/lib/dist-custom-elements/{p-cdd3420f.js → p-681c9a42.js} +5 -5
- package/lib/dist-custom-elements/{p-a9b833c4.js → p-6a8cdb7b.js} +1 -1
- package/lib/dist-custom-elements/{p-2053808f.js → p-7a6f9236.js} +1 -1
- package/lib/dist-custom-elements/{p-d9c36445.js → p-84c970d9.js} +1 -1
- package/lib/dist-custom-elements/{p-20a7e678.js → p-87b5525b.js} +3 -3
- package/lib/dist-custom-elements/{p-aa7f3d85.js → p-89dbfa07.js} +1 -1
- package/lib/dist-custom-elements/{p-ba3c9ede.js → p-8aa1b007.js} +1 -1
- package/lib/dist-custom-elements/{p-3ec4c5a3.js → p-8d8f500f.js} +6 -6
- package/lib/dist-custom-elements/{p-aa4fc281.js → p-9556589f.js} +1 -1
- package/lib/dist-custom-elements/{p-55d4ce4d.js → p-9b6166b7.js} +1 -1
- package/lib/dist-custom-elements/{p-1ef726c7.js → p-9bf072bd.js} +2 -2
- package/lib/dist-custom-elements/{p-e1c7945c.js → p-9cfa785f.js} +3 -3
- package/lib/dist-custom-elements/{p-5cd6cc1c.js → p-9f1bb199.js} +1 -1
- package/lib/dist-custom-elements/{p-c4e077b3.js → p-a0efab88.js} +4 -4
- package/lib/dist-custom-elements/{p-e65fa79a.js → p-c86c6df0.js} +2 -2
- package/lib/dist-custom-elements/{p-6a114fc5.js → p-cb7de9dd.js} +1 -1
- package/lib/dist-custom-elements/{p-d8caf2d2.js → p-ce7b7450.js} +1 -1
- package/lib/dist-custom-elements/{p-156628ee.js → p-d5e06462.js} +1 -1
- package/lib/dist-custom-elements/{p-326cf323.js → p-db69ae9d.js} +7 -7
- package/lib/dist-custom-elements/{p-53e6d3f1.js → p-dd03af24.js} +1 -1
- package/lib/dist-custom-elements/{p-6aa4d505.js → p-f7a12024.js} +8 -8
- package/lib/duet/duet.esm.js +1 -1
- package/lib/duet/duet.js +1 -1
- package/lib/duet/{p-f6b884c4.system.entry.js → p-0115b516.system.entry.js} +1 -1
- package/lib/duet/{p-b35baeed.system.entry.js → p-01833853.system.entry.js} +1 -1
- package/lib/duet/{p-427add54.system.entry.js → p-032d0db3.system.entry.js} +1 -1
- package/lib/duet/{p-d07aacdc.system.entry.js → p-0335d3ba.system.entry.js} +2 -2
- package/lib/duet/p-04a1f201.entry.js +4 -0
- package/lib/duet/{p-a37ef41d.system.entry.js → p-07f8de09.system.entry.js} +1 -1
- package/lib/duet/{p-21ecd01e.entry.js → p-0f2c807b.entry.js} +1 -1
- package/lib/duet/p-1515b46a.entry.js +4 -0
- package/lib/duet/{p-f5db84bb.entry.js → p-15b65a7c.entry.js} +1 -1
- package/lib/duet/p-15e1c955.entry.js +4 -0
- package/lib/duet/{p-113efe69.system.entry.js → p-18a1350b.system.entry.js} +2 -2
- package/lib/duet/{p-20dc2ce5.system.entry.js → p-1bb2106c.system.entry.js} +1 -1
- package/lib/duet/{p-afe0e62a.entry.js → p-1c21f6ee.entry.js} +1 -1
- package/lib/duet/{p-334a3c39.system.entry.js → p-1ccc3647.system.entry.js} +1 -1
- package/lib/duet/{p-700a95eb.system.entry.js → p-1e86fdd0.system.entry.js} +1 -1
- package/lib/duet/{p-81308c38.entry.js → p-1ea20994.entry.js} +1 -1
- package/lib/duet/{p-283301cd.entry.js → p-1ec42ecd.entry.js} +1 -1
- package/lib/duet/{p-17d9c17b.system.entry.js → p-20291d6a.system.entry.js} +1 -1
- package/lib/duet/{p-365da977.system.entry.js → p-259eff20.system.entry.js} +1 -1
- package/lib/duet/p-268a27e0.system.entry.js +4 -0
- package/lib/duet/{p-9291c5a9.system.entry.js → p-2765a53e.system.entry.js} +1 -1
- package/lib/duet/p-2a57d9b6.entry.js +4 -0
- package/lib/duet/{p-17680aab.system.entry.js → p-2b3c2e41.system.entry.js} +1 -1
- package/lib/duet/{p-6a4118bf.entry.js → p-2c19f162.entry.js} +1 -1
- package/lib/duet/{p-b11d4150.system.entry.js → p-2d0a6607.system.entry.js} +1 -1
- package/lib/duet/{p-61d0fa5b.entry.js → p-2e5b3bcf.entry.js} +1 -1
- package/lib/duet/{p-35daef86.entry.js → p-2e6a3a17.entry.js} +1 -1
- package/lib/duet/{p-6f621e11.system.entry.js → p-31159c85.system.entry.js} +1 -1
- package/lib/duet/{p-4f03d185.entry.js → p-35afcb27.entry.js} +1 -1
- package/lib/duet/p-39c79c00.system.entry.js +4 -0
- package/lib/duet/p-3ab084e8.system.entry.js +4 -0
- package/lib/duet/{p-da8c937e.entry.js → p-3aeb487a.entry.js} +1 -1
- package/lib/duet/{p-bde04bd3.entry.js → p-3c5967bc.entry.js} +1 -1
- package/lib/duet/p-3dc1f3c6.system.entry.js +4 -0
- package/lib/duet/p-3f01f964.system.entry.js +4 -0
- package/lib/duet/{p-04a72387.system.entry.js → p-3ffbaf35.system.entry.js} +1 -1
- package/lib/duet/p-40b6203e.system.entry.js +4 -0
- package/lib/duet/{p-03de94fe.entry.js → p-4266b177.entry.js} +1 -1
- package/lib/duet/p-44c56bb6.entry.js +4 -0
- package/lib/duet/{p-7727a44a.entry.js → p-470e0520.entry.js} +1 -1
- package/lib/duet/p-475f863c.entry.js +4 -0
- package/lib/duet/{p-bb7b92e9.entry.js → p-48a22eca.entry.js} +1 -1
- package/lib/duet/{p-a5b08a77.system.entry.js → p-49ebb54d.system.entry.js} +1 -1
- package/lib/duet/p-4af19474.entry.js +4 -0
- package/lib/duet/p-4d25be5d.entry.js +4 -0
- package/lib/duet/{p-25f31f1d.entry.js → p-4d5cb241.entry.js} +1 -1
- package/lib/duet/{p-93564d46.entry.js → p-4ddb8b0f.entry.js} +1 -1
- package/lib/duet/p-4f203781.js +4 -0
- package/lib/duet/{p-3a6729c3.entry.js → p-50ee41e3.entry.js} +1 -1
- package/lib/duet/p-51588335.entry.js +4 -0
- package/lib/duet/{p-fed8565c.entry.js → p-53de8491.entry.js} +1 -1
- package/lib/duet/p-56b49a2b.system.entry.js +4 -0
- package/lib/duet/{p-e4355e6c.entry.js → p-5a884cab.entry.js} +1 -1
- package/lib/duet/p-5bf71c27.entry.js +4 -0
- package/lib/duet/p-5fcf69f8.entry.js +4 -0
- package/lib/duet/{p-6bce1181.system.entry.js → p-614c7065.system.entry.js} +1 -1
- package/lib/duet/{p-d82c4706.entry.js → p-64c8ddb9.entry.js} +1 -1
- package/lib/duet/{p-78ed0c18.entry.js → p-68ab467a.entry.js} +1 -1
- package/lib/duet/{p-35f98b09.system.entry.js → p-70425e80.system.entry.js} +1 -1
- package/lib/duet/p-74c8d3c2.entry.js +4 -0
- package/lib/duet/{p-e97f7391.system.entry.js → p-74e6b8fd.system.entry.js} +1 -1
- package/lib/duet/p-75492e02.system.entry.js +4 -0
- package/lib/duet/{p-c1ebf12e.system.entry.js → p-76fdc86f.system.entry.js} +1 -1
- package/lib/duet/{p-1d7f1df4.entry.js → p-770f94ca.entry.js} +1 -1
- package/lib/duet/p-77c2e21e.system.js +4 -0
- package/lib/duet/p-7c7f6370.entry.js +4 -0
- package/lib/duet/p-7f1506d7.entry.js +4 -0
- package/lib/duet/p-7ff34de9.entry.js +4 -0
- package/lib/duet/p-82e4f38f.entry.js +4 -0
- package/lib/duet/{p-b81a4e3c.entry.js → p-84cf594e.entry.js} +1 -1
- package/lib/duet/{p-d6925758.entry.js → p-84f17b60.entry.js} +1 -1
- package/lib/duet/{p-1babc6be.entry.js → p-85961465.entry.js} +1 -1
- package/lib/duet/{p-4d585c01.entry.js → p-886c35c2.entry.js} +1 -1
- package/lib/duet/{p-be1ca3c9.system.entry.js → p-8ae86f38.system.entry.js} +1 -1
- package/lib/duet/{p-cdf2e7e8.system.entry.js → p-8d4c36cc.system.entry.js} +1 -1
- package/lib/duet/{p-9acb547a.entry.js → p-8e6d9b39.entry.js} +1 -1
- package/lib/duet/{p-4707c32c.entry.js → p-8ed7e105.entry.js} +1 -1
- package/lib/duet/p-8f1e0f63.entry.js +4 -0
- package/lib/duet/{p-95c75961.system.entry.js → p-9207cd90.system.entry.js} +1 -1
- package/lib/duet/{p-2c44325a.system.js → p-92d37e55.system.js} +1 -1
- package/lib/duet/{p-2fb4f3b5.entry.js → p-9431cbd9.entry.js} +1 -1
- package/lib/duet/{p-95c0d478.system.entry.js → p-94fa2062.system.entry.js} +1 -1
- package/lib/duet/{p-f12bf693.entry.js → p-9693b127.entry.js} +1 -1
- package/lib/duet/{p-7a3f2b74.entry.js → p-9a911da7.entry.js} +1 -1
- package/lib/duet/{p-40b97e14.system.entry.js → p-9abc893a.system.entry.js} +1 -1
- package/lib/duet/{p-072cc012.entry.js → p-9aebf3f7.entry.js} +1 -1
- package/lib/duet/{p-05ca989b.system.entry.js → p-9ca2af16.system.entry.js} +1 -1
- package/lib/duet/{p-0535962b.system.entry.js → p-9d4592dc.system.entry.js} +1 -1
- package/lib/duet/{p-66584556.system.entry.js → p-9fd3df4e.system.entry.js} +1 -1
- package/lib/duet/{p-975684e4.system.entry.js → p-a6653cdc.system.entry.js} +1 -1
- package/lib/duet/{p-70f4ebe3.system.entry.js → p-a8432547.system.entry.js} +1 -1
- package/lib/duet/{p-33884197.entry.js → p-a8d67797.entry.js} +1 -1
- package/lib/duet/{p-5f0b9b1c.system.entry.js → p-aabd9905.system.entry.js} +1 -1
- package/lib/duet/{p-cd7db17d.entry.js → p-ab4af140.entry.js} +1 -1
- package/lib/duet/p-abdd047f.system.entry.js +4 -0
- package/lib/duet/{p-f936f13c.system.entry.js → p-b1296afd.system.entry.js} +1 -1
- package/lib/duet/{p-51410532.system.entry.js → p-b3c6d973.system.entry.js} +1 -1
- package/lib/duet/{p-c7b63dea.system.entry.js → p-b7c160f8.system.entry.js} +1 -1
- package/lib/duet/{p-561ad02e.system.entry.js → p-c3436d4d.system.entry.js} +1 -1
- package/lib/duet/{p-2058c3cb.entry.js → p-c48232b6.entry.js} +1 -1
- package/lib/duet/p-c88e1b86.system.entry.js +4 -0
- package/lib/duet/{p-38a57d62.entry.js → p-c96b1fae.entry.js} +1 -1
- package/lib/duet/{p-6f85b3b2.entry.js → p-c989c952.entry.js} +1 -1
- package/lib/duet/{p-6ba49302.entry.js → p-ca6f6878.entry.js} +1 -1
- package/lib/duet/{p-9340367b.entry.js → p-cb814de3.entry.js} +1 -1
- package/lib/duet/p-cbd1e2c6.system.entry.js +4 -0
- package/lib/duet/{p-0b8d596f.entry.js → p-cc332f12.entry.js} +1 -1
- package/lib/duet/p-cffc25f7.system.entry.js +4 -0
- package/lib/duet/p-d03517b4.system.entry.js +4 -0
- package/lib/duet/{p-15df8929.js → p-d4d0fd29.js} +1 -1
- package/lib/duet/{p-062f3759.system.entry.js → p-d4e3b832.system.entry.js} +1 -1
- package/lib/duet/{p-a5331bb2.entry.js → p-d7014558.entry.js} +1 -1
- package/lib/duet/{p-f3ac3c5b.system.entry.js → p-d7d050f5.system.entry.js} +1 -1
- package/lib/duet/p-d871a695.system.entry.js +4 -0
- package/lib/duet/{p-3176b8fc.entry.js → p-d8d0fb8f.entry.js} +1 -1
- package/lib/duet/{p-4c1e550d.system.entry.js → p-d94e5b57.system.entry.js} +1 -1
- package/lib/duet/{p-047713ed.system.entry.js → p-d9a1ce3e.system.entry.js} +1 -1
- package/lib/duet/p-da73f58c.system.entry.js +4 -0
- package/lib/duet/{p-81844f31.system.js → p-dbc13c36.system.js} +1 -1
- package/lib/duet/p-dd6b8fec.system.entry.js +4 -0
- package/lib/duet/{p-3e100ee8.system.entry.js → p-deb0bf2b.system.entry.js} +1 -1
- package/lib/duet/{p-1c3be420.system.entry.js → p-def345e8.system.entry.js} +1 -1
- package/lib/duet/{p-e56d2f1e.system.entry.js → p-e30006d7.system.entry.js} +1 -1
- package/lib/duet/p-e459f448.entry.js +4 -0
- package/lib/duet/{p-410fd1f0.system.entry.js → p-e651dcce.system.entry.js} +1 -1
- package/lib/duet/{p-07e4077e.entry.js → p-eb92e362.entry.js} +1 -1
- package/lib/duet/p-ecb55af2.system.entry.js +4 -0
- package/lib/duet/{p-76858d7c.system.entry.js → p-ef7c6a28.system.entry.js} +2 -2
- package/lib/duet/p-efdc7c2e.entry.js +4 -0
- package/lib/duet/p-efe489f3.entry.js +4 -0
- package/lib/duet/{p-74d1ce07.system.entry.js → p-f5708af6.system.entry.js} +1 -1
- package/lib/duet/{p-f9b6198b.system.entry.js → p-f998b544.system.entry.js} +1 -1
- package/lib/duet/{p-c538413b.system.entry.js → p-fc1cf69f.system.entry.js} +1 -1
- package/lib/duet/p-fd7a5a08.entry.js +4 -0
- package/lib/duet/{p-2065404b.entry.js → p-fd7de93a.entry.js} +1 -1
- package/lib/duet/{p-1de3cfb8.entry.js → p-fee010a2.entry.js} +1 -1
- package/lib/duet/{p-b226a97c.system.entry.js → p-ff84ff9d.system.entry.js} +1 -1
- package/lib/esm/duet-action-button.entry.js +1 -1
- package/lib/esm/duet-alert.entry.js +1 -1
- package/lib/esm/duet-badge.entry.js +1 -1
- package/lib/esm/duet-breadcrumb.entry.js +1 -1
- package/lib/esm/duet-breadcrumbs.entry.js +1 -1
- package/lib/esm/duet-button_2.entry.js +1 -1
- package/lib/esm/duet-caption_4.entry.js +1 -1
- package/lib/esm/duet-card.entry.js +1 -1
- package/lib/esm/duet-checkbox.entry.js +1 -1
- package/lib/esm/duet-checkmark.entry.js +1 -1
- package/lib/esm/duet-choice_2.entry.js +2 -2
- package/lib/esm/duet-collapsible.entry.js +4 -2
- package/lib/esm/duet-combobox.entry.js +1 -1
- package/lib/esm/duet-contact-card.entry.js +1 -1
- package/lib/esm/duet-cookie-consent.entry.js +1 -1
- package/lib/esm/duet-date-picker.entry.js +2 -2
- package/lib/esm/duet-divider_2.entry.js +1 -1
- package/lib/esm/duet-editable-table_3.entry.js +1 -1
- package/lib/esm/duet-empty-state.entry.js +1 -1
- package/lib/esm/duet-fieldset.entry.js +1 -1
- package/lib/esm/duet-footer.entry.js +1 -1
- package/lib/esm/duet-grid_2.entry.js +1 -1
- package/lib/esm/duet-header_2.entry.js +1 -1
- package/lib/esm/duet-hero.entry.js +3 -3
- package/lib/esm/duet-icon.entry.js +1 -1
- package/lib/esm/duet-input_2.entry.js +1 -1
- package/lib/esm/duet-layout.entry.js +1 -1
- package/lib/esm/duet-list_2.entry.js +1 -1
- package/lib/esm/duet-menu-bar-button.entry.js +2 -2
- package/lib/esm/duet-menu-bar-dropdown-link.entry.js +11 -3
- package/lib/esm/duet-menu-bar-dropdown.entry.js +17 -4
- package/lib/esm/duet-menu-bar-link.entry.js +3 -3
- package/lib/esm/duet-menu-bar.entry.js +7 -1
- package/lib/esm/duet-modal.entry.js +2 -2
- package/lib/esm/duet-multiselect.entry.js +1 -1
- package/lib/esm/duet-nav.entry.js +1 -1
- package/lib/esm/duet-notification_2.entry.js +1 -1
- package/lib/esm/duet-number-input.entry.js +3 -3
- package/lib/esm/duet-page-heading.entry.js +1 -1
- package/lib/esm/duet-pagination_2.entry.js +1 -1
- package/lib/esm/duet-progress.entry.js +1 -1
- package/lib/esm/duet-radio_2.entry.js +1 -1
- package/lib/esm/duet-range-slider.entry.js +1 -1
- package/lib/esm/duet-scrollable_3.entry.js +2 -2
- package/lib/esm/duet-section-layout.entry.js +1 -1
- package/lib/esm/duet-select.entry.js +1 -1
- package/lib/esm/duet-slideout-lang.entry.js +2 -2
- package/lib/esm/duet-slideout-link.entry.js +3 -3
- package/lib/esm/duet-slideout-panel-dropdown.entry.js +10 -4
- package/lib/esm/duet-slideout-panel.entry.js +31 -10
- package/lib/esm/duet-slideout.entry.js +42 -10
- package/lib/esm/duet-step_2.entry.js +1 -1
- package/lib/esm/duet-submenu-bar-dropdown-link.entry.js +13 -3
- package/lib/esm/duet-submenu-bar-dropdown.entry.js +31 -5
- package/lib/esm/duet-submenu-bar-link.entry.js +12 -3
- package/lib/esm/duet-submenu-bar.entry.js +42 -4
- package/lib/esm/duet-textarea.entry.js +1 -1
- package/lib/esm/duet-toggle.entry.js +1 -1
- package/lib/esm/duet-toolbar-dropdown-link.entry.js +11 -3
- package/lib/esm/duet-toolbar-dropdown.entry.js +17 -4
- package/lib/esm/duet-toolbar-link.entry.js +3 -3
- package/lib/esm/duet-toolbar.entry.js +1 -1
- package/lib/esm/duet-tooltip.entry.js +4 -1
- package/lib/esm/duet-tray.entry.js +1 -1
- package/lib/esm/duet-upload-aria-status.entry.js +1 -1
- package/lib/esm/duet-visually-hidden.entry.js +1 -1
- package/lib/esm/duet.js +3 -3
- package/lib/esm/{focus-utils-e582db06.js → focus-utils-24487417.js} +1 -1
- package/lib/esm/{index-2ffd554c.js → index-3b6ef857.js} +1 -1
- package/lib/esm/loader.js +3 -3
- package/lib/esm-es5/duet-action-button.entry.js +1 -1
- package/lib/esm-es5/duet-alert.entry.js +1 -1
- package/lib/esm-es5/duet-badge.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-caption_4.entry.js +1 -1
- 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-choice_2.entry.js +1 -1
- package/lib/esm-es5/duet-collapsible.entry.js +1 -1
- 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 +1 -1
- 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-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 +1 -1
- package/lib/esm-es5/duet-icon.entry.js +1 -1
- 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 +1 -1
- 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 +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 +1 -1
- package/lib/esm-es5/duet-multiselect.entry.js +1 -1
- package/lib/esm-es5/duet-nav.entry.js +1 -1
- package/lib/esm-es5/duet-notification_2.entry.js +1 -1
- package/lib/esm-es5/duet-number-input.entry.js +1 -1
- package/lib/esm-es5/duet-page-heading.entry.js +1 -1
- package/lib/esm-es5/duet-pagination_2.entry.js +1 -1
- package/lib/esm-es5/duet-progress.entry.js +1 -1
- 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 +2 -2
- 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-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 +2 -2
- 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 +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 +2 -2
- 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-link.entry.js +1 -1
- package/lib/esm-es5/duet-toolbar.entry.js +1 -1
- 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-visually-hidden.entry.js +1 -1
- package/lib/esm-es5/duet.js +1 -1
- package/lib/esm-es5/focus-utils-24487417.js +4 -0
- package/lib/esm-es5/{index-2ffd554c.js → index-3b6ef857.js} +1 -1
- package/lib/esm-es5/loader.js +1 -1
- package/lib/types/components/duet-collapsible/duet-collapsible.d.ts +4 -0
- package/lib/types/components/duet-menu-bar/duet-menu-bar.d.ts +3 -1
- package/lib/types/components/duet-menu-bar-dropdown/duet-menu-bar-dropdown.d.ts +6 -0
- package/lib/types/components/duet-menu-bar-dropdown-link/duet-menu-bar-dropdown-link.d.ts +1 -0
- package/lib/types/components/duet-slideout/duet-slideout.d.ts +9 -0
- package/lib/types/components/duet-slideout-panel/duet-slideout-panel.d.ts +5 -0
- package/lib/types/components/duet-slideout-panel-dropdown/duet-slideout-panel-dropdown.d.ts +5 -0
- package/lib/types/components/duet-submenu-bar/duet-submenu-bar.d.ts +11 -0
- package/lib/types/components/duet-submenu-bar-dropdown/duet-submenu-bar-dropdown.d.ts +10 -0
- package/lib/types/components/duet-submenu-bar-dropdown-link/duet-submenu-bar-dropdown-link.d.ts +9 -0
- package/lib/types/components/duet-submenu-bar-link/duet-submenu-bar-link.d.ts +5 -0
- package/lib/types/components/duet-toolbar-dropdown/duet-toolbar-dropdown.d.ts +6 -0
- package/lib/types/components/duet-toolbar-dropdown-link/duet-toolbar-dropdown-link.d.ts +1 -0
- package/lib/types/components/duet-tooltip/duet-tooltip.d.ts +1 -0
- package/lib/types/components.d.ts +60 -0
- package/package.json +5 -5
- package/lib/duet/p-00172969.js +0 -4
- package/lib/duet/p-0050fcea.system.entry.js +0 -4
- package/lib/duet/p-0c65784e.entry.js +0 -4
- package/lib/duet/p-1ace9df6.system.entry.js +0 -4
- package/lib/duet/p-34db2dcf.entry.js +0 -4
- package/lib/duet/p-47ad406b.system.entry.js +0 -4
- package/lib/duet/p-4bd30449.system.entry.js +0 -4
- package/lib/duet/p-4f1e71ea.system.entry.js +0 -4
- package/lib/duet/p-56574368.entry.js +0 -4
- package/lib/duet/p-56f058c2.entry.js +0 -4
- package/lib/duet/p-643f0001.entry.js +0 -4
- package/lib/duet/p-666fe490.entry.js +0 -4
- package/lib/duet/p-729a6e20.entry.js +0 -4
- package/lib/duet/p-74ad3952.system.entry.js +0 -4
- package/lib/duet/p-7677f2f8.system.entry.js +0 -4
- package/lib/duet/p-7db95aa4.entry.js +0 -4
- package/lib/duet/p-7dea3b1c.entry.js +0 -4
- package/lib/duet/p-7e97bed4.system.entry.js +0 -4
- package/lib/duet/p-803bec7d.entry.js +0 -4
- package/lib/duet/p-8821f614.entry.js +0 -4
- package/lib/duet/p-8a363e59.entry.js +0 -4
- package/lib/duet/p-9bf1b6ec.entry.js +0 -4
- package/lib/duet/p-9e6763fd.system.entry.js +0 -4
- package/lib/duet/p-9e7923ce.entry.js +0 -4
- package/lib/duet/p-a036041f.entry.js +0 -4
- package/lib/duet/p-a09e6bdb.system.entry.js +0 -4
- package/lib/duet/p-a2293dee.system.js +0 -4
- package/lib/duet/p-a3da6b7b.system.entry.js +0 -4
- package/lib/duet/p-a5db1616.system.entry.js +0 -4
- package/lib/duet/p-a7ee23c4.entry.js +0 -4
- package/lib/duet/p-aace5d7b.entry.js +0 -4
- package/lib/duet/p-c829c363.entry.js +0 -4
- package/lib/duet/p-cad2ce97.system.entry.js +0 -4
- package/lib/duet/p-d337fd5d.entry.js +0 -4
- package/lib/duet/p-deadbb54.system.entry.js +0 -4
- package/lib/duet/p-e5aaea95.entry.js +0 -4
- package/lib/duet/p-ec4e2f2a.system.entry.js +0 -4
- package/lib/duet/p-f599ebfc.system.entry.js +0 -4
- package/lib/duet/p-f86b3eb4.system.entry.js +0 -4
- package/lib/duet/p-fd5f21d8.entry.js +0 -4
- package/lib/esm-es5/focus-utils-e582db06.js +0 -4
|
@@ -5,23 +5,28 @@
|
|
|
5
5
|
|
|
6
6
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
7
7
|
|
|
8
|
-
const index = require('./index-
|
|
8
|
+
const index = require('./index-6d5f06d0.js');
|
|
9
9
|
const themeableComponent = require('./themeable-component-fdeaef9f.js');
|
|
10
|
-
const focusUtils = require('./focus-utils-
|
|
10
|
+
const focusUtils = require('./focus-utils-2ff2eab6.js');
|
|
11
11
|
const languageUtils = require('./language-utils-44df1d37.js');
|
|
12
12
|
const tokenUtils = require('./token-utils-2e10264d.js');
|
|
13
13
|
require('./string-utils-5cadd058.js');
|
|
14
14
|
require('./tokens.module-69170ddd.js');
|
|
15
15
|
|
|
16
|
-
const duetSlideoutPanelCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;height:100%}:host slot:not([name=label])::slotted(*){position:relative;top:0.5rem;opacity:0;transition:top 0.3s ease-in, opacity 0.3s ease-in}:host([open]) slot:not([name=label])::slotted(*){top:0;opacity:1}.duet-slideout-panel{position:relative;height:100%}.duet-slideout-panel .link{position:relative;display:flex;gap:20px;align-items:center;justify-content:flex-start;width:100%;height:100%;padding:8px 0;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1.5rem;font-weight:800;line-height:1.25;color:rgb(0, 41, 77);text-align:left;text-decoration:none;cursor:pointer}.duet-slideout-panel .link .label{display:flex;gap:0.5rem;align-items:center;justify-content:space-between;width:100%}.duet-slideout-panel .link .label-text.small{font-size:1rem;font-weight:600}.duet-slideout-panel .link .label-text.medium{font-size:1.25rem;font-weight:600}.duet-slideout-panel .link .label-text.large{font-size:1.5rem;font-weight:800}.duet-slideout-panel .link.active .label-text{position:relative}.duet-slideout-panel .link.active .label-text.small::after{height:1px;transform:translateY(1px)}.duet-slideout-panel .link.active .label-text::after{position:absolute;top:auto;bottom:0;left:0;display:block;width:100%;height:2px;content:\"\";background:rgb(0, 119, 179);transform:translateY(2px)}.duet-slideout-panel .dialog{position:fixed;top:0;left:0;z-index:600;width:100%;height:100%;overflow-y:auto;visibility:visible}.duet-slideout-panel .dialog.hidden{visibility:hidden}.duet-slideout-panel .dialog.hidden .top .back,.duet-slideout-panel .dialog.hidden .top span{opacity:0}.duet-slideout-panel .top{display:flex;align-items:center;justify-content:space-between;padding:4px}.duet-slideout-panel .top .back{opacity:1;transition:top 0.3s ease-in, opacity 0.3s ease-in}.duet-slideout-panel .top duet-icon{padding:16px}.duet-slideout-panel .top span{font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1rem;font-weight:600;line-height:1.5;color:rgb(0, 41, 77);opacity:1;transition:top 0.3s ease-in, opacity 0.3s ease-in}.duet-slideout-panel .items{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;padding:1rem 16px;overflow-y:auto;color:rgb(0, 41, 77)}.duet-slideout-panel.duet-theme-turva .link{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(
|
|
16
|
+
const duetSlideoutPanelCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;height:100%}:host slot:not([name=label])::slotted(*){position:relative;top:0.5rem;opacity:0;transition:top 0.3s ease-in, opacity 0.3s ease-in}:host([open]) slot:not([name=label])::slotted(*){top:0;opacity:1}.duet-slideout-panel{position:relative;height:100%}.duet-slideout-panel .link{position:relative;display:flex;gap:20px;align-items:center;justify-content:flex-start;width:100%;height:100%;padding:8px 0;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1.5rem;font-weight:800;line-height:1.25;color:rgb(0, 41, 77);text-align:left;text-decoration:none;cursor:pointer}.duet-slideout-panel .link .label{display:flex;gap:0.5rem;align-items:center;justify-content:space-between;width:100%}.duet-slideout-panel .link .label-text.small{font-size:1rem;font-weight:600}.duet-slideout-panel .link .label-text.medium{font-size:1.25rem;font-weight:600}.duet-slideout-panel .link .label-text.large{font-size:1.5rem;font-weight:800}.duet-slideout-panel .link:focus{outline:0;box-shadow:0 0 0 4px rgba(0, 119, 179, 0.3), 0 0 0 1px rgb(0, 119, 179)}.duet-slideout-panel .link.active .label-text{position:relative}.duet-slideout-panel .link.active .label-text.small::after{height:1px;transform:translateY(1px)}.duet-slideout-panel .link.active .label-text::after{position:absolute;top:auto;bottom:0;left:0;display:block;width:100%;height:2px;content:\"\";background:rgb(0, 119, 179);transform:translateY(2px)}.duet-slideout-panel .dialog{position:fixed;top:0;left:0;z-index:600;width:100%;height:100%;overflow-y:auto;visibility:visible}.duet-slideout-panel .dialog.hidden{visibility:hidden}.duet-slideout-panel .dialog.hidden .top .back,.duet-slideout-panel .dialog.hidden .top span{opacity:0}.duet-slideout-panel .top{display:flex;align-items:center;justify-content:space-between;padding:4px}.duet-slideout-panel .top .back{opacity:1;transition:top 0.3s ease-in, opacity 0.3s ease-in}.duet-slideout-panel .top .back:focus,.duet-slideout-panel .top .close:focus{outline:0;box-shadow:0 0 0 4px rgba(0, 119, 179, 0.3), 0 0 0 1px rgb(0, 119, 179)}.duet-slideout-panel .top duet-icon{padding:16px}.duet-slideout-panel .top span{font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1rem;font-weight:600;line-height:1.5;color:rgb(0, 41, 77);opacity:1;transition:top 0.3s ease-in, opacity 0.3s ease-in}.duet-slideout-panel .items{display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;padding:1rem 16px;overflow-y:auto;color:rgb(0, 41, 77)}.duet-slideout-panel.duet-theme-turva .link{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}.duet-slideout-panel.duet-theme-turva .link:focus{box-shadow:0 0 0 4px rgba(23, 28, 58, 0.2), 0 0 0 1px rgb(23, 28, 58)}.duet-slideout-panel.duet-theme-turva .link.active .label-text::after{background:rgb(198, 12, 48)}.duet-slideout-panel.duet-theme-turva .top .back:focus,.duet-slideout-panel.duet-theme-turva .top .close:focus{box-shadow:0 0 0 4px rgba(23, 28, 58, 0.2), 0 0 0 1px rgb(23, 28, 58)}.duet-slideout-panel.duet-theme-turva .top span{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}slot:not([name=label]){--active-height:1px;--active-translate-y:translateY(1px);font-size:1rem;font-weight:600;color:rgb(0, 41, 77)}.duet-theme-turva slot:not([name=label]){color:rgb(23, 28, 58)}";
|
|
17
17
|
|
|
18
18
|
const DuetSlideoutPanel = class {
|
|
19
19
|
constructor(hostRef) {
|
|
20
20
|
index.registerInstance(this, hostRef);
|
|
21
21
|
this.exitLangObject = {
|
|
22
|
-
en: "Exit the
|
|
23
|
-
fi: "Poistu
|
|
24
|
-
sv: "
|
|
22
|
+
en: "Exit the menu",
|
|
23
|
+
fi: "Poistu valikosta",
|
|
24
|
+
sv: "Avsluta menyn",
|
|
25
|
+
};
|
|
26
|
+
this.backLangObject = {
|
|
27
|
+
en: "Back to main menu",
|
|
28
|
+
fi: "Takaisin päävalikkoon",
|
|
29
|
+
sv: "Tillbaka till huvudmenyn",
|
|
25
30
|
};
|
|
26
31
|
this.updateLabel = () => {
|
|
27
32
|
const labelSlotElement = this.element.querySelector("[slot='label']");
|
|
@@ -64,6 +69,21 @@ const DuetSlideoutPanel = class {
|
|
|
64
69
|
themeableComponent.inheritGlobalTheme(this);
|
|
65
70
|
this.updateLabel();
|
|
66
71
|
}
|
|
72
|
+
/**
|
|
73
|
+
* Sets focus. Use this method instead of the global focus().
|
|
74
|
+
*/
|
|
75
|
+
async setFocus(options) {
|
|
76
|
+
if (this.open) {
|
|
77
|
+
setTimeout(() => {
|
|
78
|
+
this.closeButton.focus(options);
|
|
79
|
+
}, 200);
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
setTimeout(() => {
|
|
83
|
+
this.openButton.focus(options);
|
|
84
|
+
}, 200);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
67
87
|
/**
|
|
68
88
|
* render() function
|
|
69
89
|
* Always the last one in the class.
|
|
@@ -78,19 +98,20 @@ const DuetSlideoutPanel = class {
|
|
|
78
98
|
background: tokenUtils.getColorByName(defaultBackgroundColor, this.theme),
|
|
79
99
|
};
|
|
80
100
|
const exitTranslation = languageUtils.getLocaleString(this.exitLangObject);
|
|
101
|
+
const backTranslation = languageUtils.getLocaleString(this.backLangObject);
|
|
81
102
|
return (index.h(index.Host, null, index.h("div", { class: {
|
|
82
103
|
"duet-slideout-panel": true,
|
|
83
104
|
"duet-theme-turva": this.theme === "turva",
|
|
84
105
|
active: this.open,
|
|
85
|
-
} }, index.h("button", { ref: element => (this.openButton = element), "aria-haspopup": "menu", "aria-controls": "menu", "aria-expanded": this.open ? "true" : "false", id: "button", type: "button", class: {
|
|
106
|
+
} }, index.h("button", { ref: element => (this.openButton = element), "aria-haspopup": "menu", "aria-controls": "menu", "aria-expanded": this.open ? "true" : "false", "aria-current": this.active ? "true" : "false", id: "button", type: "button", class: {
|
|
86
107
|
link: true,
|
|
87
108
|
active: this.active,
|
|
88
|
-
}, onClick: this.onToggleClick }, this.icon && index.h("duet-icon", { name: this.icon, size: "medium", margin: "none" }), index.h("div", { class: "label" }, index.h("span", { class: { "label-text": true, [this.labelSize]: true } }, index.h("slot", { name: "label" })), index.h("duet-icon", { class: "caret", name: "action-arrow-right", margin: "none", size: "x-small" }))), index.h("div", { class: {
|
|
109
|
+
}, onClick: this.onToggleClick }, this.icon && index.h("duet-icon", { name: this.icon, size: "medium", margin: "none", color: "secondary" }), index.h("div", { class: "label" }, index.h("span", { class: { "label-text": true, [this.labelSize]: true } }, index.h("slot", { name: "label" })), index.h("duet-icon", { class: "caret", name: "action-arrow-right", margin: "none", size: "x-small", color: "secondary" }))), index.h("div", { class: {
|
|
89
110
|
dialog: true,
|
|
90
111
|
hidden: !this.open,
|
|
91
|
-
}, style: styles }, index.h(focusUtils.FocusGuard, { moveFocusTo: this.closeButton }), index.h("div", { class: "top" }, index.h("button", { ref: element => (this.closeButton = element), "aria-haspopup": "menu", "aria-controls": "menu", "aria-expanded": this.open ? "true" : "false", type: "button", class: {
|
|
112
|
+
}, style: styles }, index.h(focusUtils.FocusGuard, { moveFocusTo: this.closeButton }), index.h("div", { class: "top" }, index.h("button", { ref: element => (this.closeButton = element), "aria-haspopup": "menu", "aria-controls": "menu", "aria-expanded": this.open ? "true" : "false", "aria-label": `${backTranslation}`, type: "button", class: {
|
|
92
113
|
back: true,
|
|
93
|
-
}, onClick: this.onToggleClick }, index.h("duet-icon", { class: "caret", name: "action-arrow-left", margin: "none", size: "small" })), index.h("span", null, this.label.innerHTML), index.h("button", { type: "button", onClick: this.onCloseClick, "aria-label": `${exitTranslation}` }, index.h("duet-icon", { name: "navigation-close", size: "small", margin: "none" }))), index.h("div", { tabindex: "-1", role: "menu", id: "menu", "aria-labelledby": "button", class: {
|
|
114
|
+
}, onClick: this.onToggleClick }, index.h("duet-icon", { class: "caret", name: "action-arrow-left", margin: "none", size: "small", color: "secondary" })), index.h("span", null, this.label.innerHTML), index.h("button", { class: "close", type: "button", onClick: this.onCloseClick, "aria-label": `${exitTranslation}` }, index.h("duet-icon", { name: "navigation-close", size: "small", margin: "none", color: "secondary" }))), index.h("div", { tabindex: "-1", role: "menu", id: "menu", "aria-labelledby": "button", class: {
|
|
94
115
|
items: true,
|
|
95
116
|
} }, index.h("slot", null)), index.h(focusUtils.FocusGuard, { moveFocusTo: this.closeButton })))));
|
|
96
117
|
}
|
|
@@ -5,18 +5,26 @@
|
|
|
5
5
|
|
|
6
6
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
7
7
|
|
|
8
|
-
const index = require('./index-
|
|
8
|
+
const index = require('./index-6d5f06d0.js');
|
|
9
9
|
const themeableComponent = require('./themeable-component-fdeaef9f.js');
|
|
10
|
-
const focusUtils = require('./focus-utils-
|
|
10
|
+
const focusUtils = require('./focus-utils-2ff2eab6.js');
|
|
11
|
+
const keyboardUtils = require('./keyboard-utils-bb32119b.js');
|
|
12
|
+
const languageUtils = require('./language-utils-44df1d37.js');
|
|
11
13
|
const tokenUtils = require('./token-utils-2e10264d.js');
|
|
14
|
+
require('./string-utils-5cadd058.js');
|
|
12
15
|
require('./tokens.module-69170ddd.js');
|
|
13
16
|
|
|
14
|
-
const duetSlideoutCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;height:100%}:host slot:not([name=toggle])::slotted(*){position:relative;visibility:hidden;opacity:0}:host([open]) slot:not([name=toggle])::slotted(*){visibility:visible;opacity:1}.duet-slideout{display:flex;align-items:center;height:100%}.duet-slideout .desktop-bg{display:none}@media (min-width: 62em){.duet-slideout .desktop-bg{position:fixed;top:0;left:0;z-index:400;display:block;width:100%;height:100%;visibility:hidden;background:rgba(0, 41, 77, 0.6);opacity:0;transition:600ms ease}.duet-slideout .desktop-bg:not(.hidden){visibility:visible;opacity:1;transition:600ms ease}}@media (min-width: 62em){.duet-slideout.duet-theme-turva .desktop-bg{background:rgba(23, 28, 58, 0.6)}}.duet-slideout .dialog{position:fixed;top:0;bottom:0;left:0;z-index:400;width:100%;height:100%;overflow-y:auto;box-shadow:0 3px 6px 0 rgba(0, 41, 77, 0.1) inset}@media (min-width: 62em){.duet-slideout .dialog{right:0;left:auto;width:500px;transition:right 300ms ease;transition-delay:0s}}.duet-slideout .dialog .top{position:relative;z-index:1;display:flex;align-items:center;justify-content:flex-end;padding:4px}.duet-slideout .dialog .top button{cursor:pointer}.duet-slideout .dialog .top duet-icon{padding:16px}.duet-slideout .dialog .items{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;width:100%;padding:0 1.5rem}.duet-slideout .dialog.hidden{pointer-events:none;visibility:hidden}@media (min-width: 62em){.duet-slideout .dialog.hidden{right:-500px;transition:300ms ease}}.duet-slideout.duet-theme-turva button{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}.duet-slideout.duet-theme-turva button.active{color:rgb(198, 12, 48)}.duet-slideout.duet-theme-turva button.active::after{background:rgb(198, 12, 48)}::slotted(*){width:100%}slot{color:rgb(0, 41, 77)}.duet-theme-turva slot{color:rgb(
|
|
17
|
+
const duetSlideoutCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;height:100%}:host slot:not([name=toggle])::slotted(*){position:relative;visibility:hidden;opacity:0}:host([open]) slot:not([name=toggle])::slotted(*){visibility:visible;opacity:1}:host(:not([open])) ::slotted(duet-slideout-panel){display:none}.duet-slideout{display:flex;align-items:center;height:100%}.duet-slideout .desktop-bg{display:none}@media (min-width: 62em){.duet-slideout .desktop-bg{position:fixed;top:0;left:0;z-index:400;display:block;width:100%;height:100%;visibility:hidden;background:rgba(0, 41, 77, 0.6);opacity:0;transition:600ms ease}.duet-slideout .desktop-bg:not(.hidden){visibility:visible;opacity:1;transition:600ms ease}}@media (min-width: 62em){.duet-slideout.duet-theme-turva .desktop-bg{background:rgba(23, 28, 58, 0.6)}}.duet-slideout .dialog{position:fixed;top:0;bottom:0;left:0;z-index:400;width:100%;height:100%;overflow-y:auto;box-shadow:0 3px 6px 0 rgba(0, 41, 77, 0.1) inset}@media (min-width: 62em){.duet-slideout .dialog{right:0;left:auto;width:500px;transition:right 300ms ease;transition-delay:0s}}.duet-slideout .dialog .top{position:relative;z-index:1;display:flex;align-items:center;justify-content:flex-end;padding:4px}.duet-slideout .dialog .top button{cursor:pointer}.duet-slideout .dialog .top button:focus{outline:0;box-shadow:0 0 0 4px rgba(0, 119, 179, 0.3), 0 0 0 1px rgb(0, 119, 179)}.duet-slideout .dialog .top duet-icon{padding:16px}.duet-slideout .dialog .items{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;width:100%;padding:0 1.5rem}.duet-slideout .dialog.hidden{pointer-events:none;visibility:hidden}@media (min-width: 62em){.duet-slideout .dialog.hidden{right:-500px;transition:300ms ease}}.duet-slideout.duet-theme-turva button{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}.duet-slideout.duet-theme-turva button:focus{box-shadow:0 0 0 4px rgba(23, 28, 58, 0.2), 0 0 0 1px rgb(23, 28, 58)}.duet-slideout.duet-theme-turva button.active{color:rgb(198, 12, 48)}.duet-slideout.duet-theme-turva button.active::after{background:rgb(198, 12, 48)}.duet-slideout .dialog .top button:focus{box-shadow:0 0 0 4px rgba(23, 28, 58, 0.2), 0 0 0 1px rgb(23, 28, 58)}::slotted(*){width:100%}slot{color:rgb(0, 41, 77)}.duet-theme-turva slot{color:rgb(23, 28, 58)}slot[name=toggle]{color:inherit}";
|
|
15
18
|
|
|
16
19
|
const DuetSlideout = class {
|
|
17
20
|
constructor(hostRef) {
|
|
18
21
|
index.registerInstance(this, hostRef);
|
|
19
22
|
this.duetSlideoutEvent = index.createEvent(this, "duetSlideoutEvent", 7);
|
|
23
|
+
this.exitLangObject = {
|
|
24
|
+
en: "Exit the menu",
|
|
25
|
+
fi: "Poistu valikosta",
|
|
26
|
+
sv: "Avsluta menyn",
|
|
27
|
+
};
|
|
20
28
|
this.toggleMenu = (e) => {
|
|
21
29
|
const toggle = !this.open;
|
|
22
30
|
this.open = toggle;
|
|
@@ -27,9 +35,15 @@ const DuetSlideout = class {
|
|
|
27
35
|
component: "duet-slideout",
|
|
28
36
|
});
|
|
29
37
|
if (toggle) {
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
38
|
+
const openPanel = this.element.querySelector("duet-slideout-panel[open]");
|
|
39
|
+
if (openPanel) {
|
|
40
|
+
openPanel.setFocus();
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
setTimeout(() => {
|
|
44
|
+
this.closeButton.focus();
|
|
45
|
+
}, 200);
|
|
46
|
+
}
|
|
33
47
|
}
|
|
34
48
|
else {
|
|
35
49
|
setTimeout(() => {
|
|
@@ -63,8 +77,8 @@ const DuetSlideout = class {
|
|
|
63
77
|
this.openButton = this.element.querySelector(":scope > [slot='toggle']");
|
|
64
78
|
}
|
|
65
79
|
if (this.openButton) {
|
|
66
|
-
this.openButton.
|
|
67
|
-
this.openButton.
|
|
80
|
+
this.openButton.accessiblePopup = "true";
|
|
81
|
+
this.openButton.accessibleExpanded = false;
|
|
68
82
|
this.openButton.addEventListener("click", e => {
|
|
69
83
|
e.stopPropagation();
|
|
70
84
|
e.preventDefault();
|
|
@@ -73,6 +87,23 @@ const DuetSlideout = class {
|
|
|
73
87
|
this.openButton = this.openButton;
|
|
74
88
|
}
|
|
75
89
|
}
|
|
90
|
+
/**
|
|
91
|
+
* Component event handling.
|
|
92
|
+
*/
|
|
93
|
+
handleKeyUp(ev) {
|
|
94
|
+
// When Esc is pressed
|
|
95
|
+
if (keyboardUtils.isEscapeKey(ev)) {
|
|
96
|
+
if (this.open) {
|
|
97
|
+
this.toggleMenu(ev);
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
/**
|
|
102
|
+
* Sets focus. Use this method instead of the global focus().
|
|
103
|
+
*/
|
|
104
|
+
async setFocus(options) {
|
|
105
|
+
this.openButton.focus(options);
|
|
106
|
+
}
|
|
76
107
|
/**
|
|
77
108
|
* render() function
|
|
78
109
|
* Always the last one in the class.
|
|
@@ -81,6 +112,7 @@ const DuetSlideout = class {
|
|
|
81
112
|
const styles = {
|
|
82
113
|
background: tokenUtils.getColorByName(this.backgroundColor, this.theme),
|
|
83
114
|
};
|
|
115
|
+
const exitTranslation = languageUtils.getLocaleString(this.exitLangObject);
|
|
84
116
|
return (index.h(index.Host, null, index.h("div", { class: { "duet-slideout": true, "duet-theme-turva": this.theme === "turva" } }, index.h("slot", { name: "toggle" }), index.h("div", { class: {
|
|
85
117
|
"desktop-bg": true,
|
|
86
118
|
hidden: !this.open,
|
|
@@ -89,10 +121,10 @@ const DuetSlideout = class {
|
|
|
89
121
|
} }), index.h("div", { tabindex: "-1", role: "dialog", id: "dialog", "aria-labelledby": "button", "aria-modal": "true", "aria-flowto": "menubar", class: {
|
|
90
122
|
dialog: true,
|
|
91
123
|
hidden: !this.open,
|
|
92
|
-
}, style: styles }, index.h(focusUtils.FocusGuard, { moveFocusTo: this.closeButton }), index.h("div", { class: "top" }, index.h("button", { ref: element => (this.closeButton = element), "aria-haspopup": "dialog", "aria-controls": "dialog", "aria-expanded": this.open ? "true" : "false", type: "button", class: {
|
|
124
|
+
}, style: styles }, index.h(focusUtils.FocusGuard, { moveFocusTo: this.closeButton }), index.h("div", { class: "top" }, index.h("button", { ref: element => (this.closeButton = element), "aria-haspopup": "dialog", "aria-controls": "dialog", "aria-expanded": this.open ? "true" : "false", "aria-label": `${exitTranslation}`, type: "button", class: {
|
|
93
125
|
"slideout-close": true,
|
|
94
126
|
active: this.open,
|
|
95
|
-
}, onClick: this.onClick }, index.h("duet-icon", { name: "navigation-close", size: "small", margin: "none" }))), index.h("div", { id: "menubar", role: "menubar", class: {
|
|
127
|
+
}, onClick: this.onClick }, index.h("duet-icon", { name: "navigation-close", size: "small", margin: "none", color: "secondary" }))), index.h("div", { id: "menubar", role: "menubar", class: {
|
|
96
128
|
items: true,
|
|
97
129
|
} }, index.h("slot", null)), index.h(focusUtils.FocusGuard, { moveFocusTo: this.closeButton })))));
|
|
98
130
|
}
|
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
|
|
6
6
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
7
7
|
|
|
8
|
-
const index = require('./index-
|
|
8
|
+
const index = require('./index-6d5f06d0.js');
|
|
9
9
|
const themeableComponent = require('./themeable-component-fdeaef9f.js');
|
|
10
10
|
const createId = require('./create-id-c3b984b1.js');
|
|
11
11
|
const keyboardUtils = require('./keyboard-utils-bb32119b.js');
|
|
@@ -5,15 +5,17 @@
|
|
|
5
5
|
|
|
6
6
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
7
7
|
|
|
8
|
-
const index = require('./index-
|
|
8
|
+
const index = require('./index-6d5f06d0.js');
|
|
9
9
|
const themeableComponent = require('./themeable-component-fdeaef9f.js');
|
|
10
|
+
const keyboardUtils = require('./keyboard-utils-bb32119b.js');
|
|
10
11
|
|
|
11
|
-
const duetSubmenuBarDropdownLinkCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%;height:100%}.duet-submenu-bar-dropdown-link{display:flex;flex-direction:row;gap:0.5rem;align-items:center;justify-content:flex-start;height:100%;padding:8px 20px 8px 60px;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1rem;font-weight:400;line-height:1.25;color:rgb(0, 41, 77);text-align:center;text-decoration:none}@media (min-width: 62em){.duet-submenu-bar-dropdown-link{padding:0.675rem 16px;font-size:0.875rem}}.duet-submenu-bar-dropdown-link.duet-theme-turva{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}@media (min-width: 62em){.duet-submenu-bar-dropdown-link:hover{color:rgb(0, 77, 128);background:rgb(243, 249, 252)}.duet-submenu-bar-dropdown-link:hover.duet-theme-turva{color:rgb(148, 9, 37);background:rgb(245, 245, 247)}}.duet-submenu-bar-dropdown-link.highlight{color:rgb(0, 119, 179)}.duet-submenu-bar-dropdown-link.highlight.duet-theme-turva{color:rgb(148, 9, 37)}";
|
|
12
|
+
const duetSubmenuBarDropdownLinkCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%;height:100%}.duet-submenu-bar-dropdown-link{display:flex;flex-direction:row;gap:0.5rem;align-items:center;justify-content:flex-start;height:100%;padding:8px 20px 8px 60px;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1rem;font-weight:400;line-height:1.25;color:rgb(0, 41, 77);text-align:center;text-decoration:none}@media (min-width: 62em){.duet-submenu-bar-dropdown-link{padding:0.675rem 16px;font-size:0.875rem}}.duet-submenu-bar-dropdown-link:focus{outline:0;box-shadow:0 0 0 4px rgba(0, 119, 179, 0.3), 0 0 0 1px rgb(0, 119, 179)}.duet-submenu-bar-dropdown-link:focus.duet-theme-turva{box-shadow:0 0 0 4px rgba(23, 28, 58, 0.2), 0 0 0 1px rgb(23, 28, 58)}.duet-submenu-bar-dropdown-link.active .label{position:relative}.duet-submenu-bar-dropdown-link.active .label::after{position:absolute;top:auto;bottom:0;left:0;display:block;width:100%;height:1px;content:\"\";background:rgb(0, 119, 179);transform:1px}@media (min-width: 62em){.duet-submenu-bar-dropdown-link.active .label::after{display:none}}.duet-submenu-bar-dropdown-link.duet-theme-turva{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}.duet-submenu-bar-dropdown-link.duet-theme-turva.active .label::after{background:rgb(198, 12, 48)}@media (min-width: 62em){.duet-submenu-bar-dropdown-link:hover{color:rgb(0, 77, 128);background:rgb(243, 249, 252)}.duet-submenu-bar-dropdown-link:hover.duet-theme-turva{color:rgb(148, 9, 37);background:rgb(245, 245, 247)}}.duet-submenu-bar-dropdown-link.highlight{color:rgb(0, 119, 179)}.duet-submenu-bar-dropdown-link.highlight.duet-theme-turva{color:rgb(148, 9, 37)}";
|
|
12
13
|
|
|
13
14
|
const DuetSubmenuBarDropdownLink = class {
|
|
14
15
|
constructor(hostRef) {
|
|
15
16
|
index.registerInstance(this, hostRef);
|
|
16
17
|
this.theme = "";
|
|
18
|
+
this.active = false;
|
|
17
19
|
this.href = "#";
|
|
18
20
|
this.icon = undefined;
|
|
19
21
|
this.caret = false;
|
|
@@ -25,6 +27,13 @@ const DuetSubmenuBarDropdownLink = class {
|
|
|
25
27
|
componentWillLoad() {
|
|
26
28
|
themeableComponent.inheritGlobalTheme(this);
|
|
27
29
|
}
|
|
30
|
+
handleEscape(e) {
|
|
31
|
+
if (keyboardUtils.isEscapeKey(e)) {
|
|
32
|
+
const dropdown = this.element.closest("duet-submenu-bar-dropdown");
|
|
33
|
+
dropdown.open = false;
|
|
34
|
+
dropdown.setFocus();
|
|
35
|
+
}
|
|
36
|
+
}
|
|
28
37
|
/**
|
|
29
38
|
* render() function
|
|
30
39
|
* Always the last one in the class.
|
|
@@ -34,7 +43,8 @@ const DuetSubmenuBarDropdownLink = class {
|
|
|
34
43
|
"duet-submenu-bar-dropdown-link": true,
|
|
35
44
|
"duet-theme-turva": this.theme === "turva",
|
|
36
45
|
highlight: this.highlight,
|
|
37
|
-
|
|
46
|
+
active: this.active,
|
|
47
|
+
}, "aria-current": this.active ? "true" : "false", href: this.href, onKeyUp: e => this.handleEscape(e) }, this.icon && index.h("duet-icon", { name: this.icon, size: "x-small", margin: "none", color: "currentColor" }), index.h("span", { class: "label" }, index.h("slot", null)), this.caret && index.h("duet-icon", { name: "action-arrow-right-small", size: "xxx-small", margin: "none" }))));
|
|
38
48
|
}
|
|
39
49
|
get element() { return index.getElement(this); }
|
|
40
50
|
};
|
|
@@ -5,11 +5,12 @@
|
|
|
5
5
|
|
|
6
6
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
7
7
|
|
|
8
|
-
const index = require('./index-
|
|
8
|
+
const index = require('./index-6d5f06d0.js');
|
|
9
9
|
const tokens = require('./tokens-21b244ee.js');
|
|
10
10
|
const themeableComponent = require('./themeable-component-fdeaef9f.js');
|
|
11
|
+
const keyboardUtils = require('./keyboard-utils-bb32119b.js');
|
|
11
12
|
|
|
12
|
-
const duetSubmenuBarDropdownCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%;height:100%}@media (min-width: 62em){:host{width:auto}}.duet-submenu-bar-dropdown{position:relative;height:100%}.duet-submenu-bar-dropdown button{position:relative;display:flex;flex-direction:row;gap:16px;align-items:center;justify-content:flex-start;width:100%;height:100%;padding:12px 1.5rem;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1rem;font-weight:600;line-height:1.25;color:rgb(0, 41, 77);text-align:center;text-decoration:none;cursor:pointer}@media (min-width: 62em){.duet-submenu-bar-dropdown button{flex-direction:column;gap:5px;align-items:center;justify-content:center;width:auto;font-size:0.875rem;color:rgb(0, 77, 128)}}.duet-submenu-bar-dropdown button .label{display:flex;gap:5px;align-items:center;justify-content:center}.duet-submenu-bar-dropdown button.
|
|
13
|
+
const duetSubmenuBarDropdownCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%;height:100%}@media (min-width: 62em){:host{width:auto}}.duet-submenu-bar-dropdown{position:relative;height:100%}.duet-submenu-bar-dropdown button{position:relative;display:flex;flex-direction:row;gap:16px;align-items:center;justify-content:flex-start;width:100%;height:100%;padding:12px 1.5rem;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1rem;font-weight:600;line-height:1.25;color:rgb(0, 41, 77);text-align:center;text-decoration:none;cursor:pointer}@media (min-width: 62em){.duet-submenu-bar-dropdown button{flex-direction:column;gap:5px;align-items:center;justify-content:center;width:auto;font-size:0.875rem;color:rgb(0, 77, 128)}}.duet-submenu-bar-dropdown button .label{display:flex;gap:5px;align-items:center;justify-content:center}.duet-submenu-bar-dropdown button:focus{outline:0;box-shadow:0 0 0 4px rgba(0, 119, 179, 0.3), 0 0 0 1px rgb(0, 119, 179)}.duet-submenu-bar-dropdown button.open .caret{transform:rotate(180deg)}.duet-submenu-bar-dropdown button.active .label-text{position:relative}.duet-submenu-bar-dropdown button.active .label-text::after{position:absolute;top:auto;bottom:0;left:0;display:block;width:100%;height:1px;content:\"\";background:rgb(0, 119, 179);transform:1px}@media (min-width: 62em){.duet-submenu-bar-dropdown button.active .label-text::after{display:none}}@media (min-width: 62em){.duet-submenu-bar-dropdown button .caret{position:absolute;right:12px}.duet-submenu-bar-dropdown button:hover{color:rgb(0, 41, 77);background:rgb(230, 242, 248)}.duet-submenu-bar-dropdown button:hover.active{color:rgb(0, 41, 77)}.duet-theme-turva .duet-submenu-bar-dropdown button:hover.active{color:rgb(23, 28, 58)}.duet-submenu-bar-dropdown button.active{color:rgb(0, 119, 179)}.duet-theme-turva .duet-submenu-bar-dropdown button.active{color:rgb(198, 12, 48)}.duet-submenu-bar-dropdown button.active::after,.duet-submenu-bar-dropdown button.open::after{position:absolute;top:auto;bottom:0;left:0;display:block;width:100%;height:1px;content:\"\";background:rgb(0, 119, 179);transition:300ms ease;transform:translateY(1px)}.duet-theme-turva .duet-submenu-bar-dropdown button.active::after,.duet-theme-turva .duet-submenu-bar-dropdown button.open::after{background:rgb(198, 12, 48)}}.duet-submenu-bar-dropdown .items{display:flex;flex-direction:column;align-items:center;justify-content:center;max-height:1000px;padding:4px 0 16px;overflow-y:auto;color:rgb(0, 41, 77);visibility:visible;transition:max-height 0.3s ease-in, padding 0.3s ease-in;-ms-overflow-style:none;scrollbar-width:none}.duet-submenu-bar-dropdown .items::-webkit-scrollbar{display:none}@media (min-width: 62em){.duet-submenu-bar-dropdown .items{position:absolute;top:102%;z-index:600;min-width:320px;padding:4px 0 0;background:rgb(255, 255, 255);border-radius:0 0 4px 4px;box-shadow:0 6px 6px 0 rgba(0, 41, 77, 0.1);transition:none}}.duet-submenu-bar-dropdown .items.hidden{max-height:0;padding:0;overflow:hidden;visibility:hidden;transition:max-height 0.3s ease-in, padding 0.3s ease-in}.duet-submenu-bar-dropdown.duet-theme-turva button{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}.duet-submenu-bar-dropdown.duet-theme-turva button:focus{box-shadow:0 0 0 4px rgba(23, 28, 58, 0.2), 0 0 0 1px rgb(23, 28, 58)}@media (min-width: 62em){.duet-submenu-bar-dropdown.duet-theme-turva button:hover{background:rgb(228, 228, 230)}}.duet-submenu-bar-dropdown.duet-theme-turva button.active .label-text::after,.duet-submenu-bar-dropdown.duet-theme-turva button.open .label-text::after{background:rgb(198, 12, 48)}@media (min-width: 62em){.duet-submenu-bar-dropdown.duet-theme-turva button.active,.duet-submenu-bar-dropdown.duet-theme-turva button.open{color:rgb(148, 9, 37)}}.duet-submenu-bar-dropdown.duet-theme-turva button.active::after,.duet-submenu-bar-dropdown.duet-theme-turva button.open::after{background:rgb(148, 9, 37)}@media (min-width: 62em){.duet-submenu-bar-dropdown.duet-theme-turva .items{background:rgb(255, 255, 255)}}";
|
|
13
14
|
|
|
14
15
|
const DuetSubmenuBarDropdown = class {
|
|
15
16
|
constructor(hostRef) {
|
|
@@ -32,6 +33,7 @@ const DuetSubmenuBarDropdown = class {
|
|
|
32
33
|
};
|
|
33
34
|
this.iconSize = "small";
|
|
34
35
|
this.theme = "";
|
|
36
|
+
this.active = false;
|
|
35
37
|
this.open = false;
|
|
36
38
|
this.icon = undefined;
|
|
37
39
|
}
|
|
@@ -67,14 +69,38 @@ const DuetSubmenuBarDropdown = class {
|
|
|
67
69
|
}
|
|
68
70
|
this.boundMqlFunctions = [];
|
|
69
71
|
}
|
|
72
|
+
handleEscape(e) {
|
|
73
|
+
if (keyboardUtils.isEscapeKey(e)) {
|
|
74
|
+
if (this.open) {
|
|
75
|
+
this.open = false;
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
const dropdown = this.element.closest("duet-submenu-bar");
|
|
79
|
+
dropdown.open = false;
|
|
80
|
+
dropdown.setFocus();
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* Sets focus. Use this method instead of the global focus().
|
|
86
|
+
*/
|
|
87
|
+
async setFocus(options) {
|
|
88
|
+
this.button.focus(options);
|
|
89
|
+
}
|
|
70
90
|
/**
|
|
71
91
|
* render() function
|
|
72
92
|
* Always the last one in the class.
|
|
73
93
|
*/
|
|
74
94
|
render() {
|
|
75
|
-
return (index.h(index.Host, null, index.h("div", { class: {
|
|
76
|
-
|
|
77
|
-
|
|
95
|
+
return (index.h(index.Host, null, index.h("div", { class: {
|
|
96
|
+
"duet-submenu-bar-dropdown": true,
|
|
97
|
+
"duet-theme-turva": this.theme === "turva",
|
|
98
|
+
open: this.open,
|
|
99
|
+
active: this.active,
|
|
100
|
+
} }, index.h("button", { ref: element => (this.button = element), "aria-haspopup": "menu", "aria-controls": "menu", "aria-expanded": this.open ? "true" : "false", "aria-current": this.active ? "true" : "false", id: "button", type: "button", class: {
|
|
101
|
+
open: this.open,
|
|
102
|
+
active: this.active,
|
|
103
|
+
}, onClick: this.onClick, onKeyUp: e => this.handleEscape(e) }, this.icon && (index.h("duet-icon", { theme: this.theme, name: this.icon, size: this.iconSize, margin: "none", color: "currentColor" })), index.h("div", { class: "label" }, index.h("span", { class: "label-text" }, index.h("slot", { name: "label" })), index.h("duet-icon", { class: "caret", theme: this.theme, name: "action-arrow-down-small", margin: "none", size: "xxx-small", color: "currentColor" }))), index.h("div", { tabindex: "-1", role: "menu", id: "menu", "aria-labelledby": "button", class: {
|
|
78
104
|
items: true,
|
|
79
105
|
hidden: !this.open,
|
|
80
106
|
} }, index.h("slot", null)))));
|
|
@@ -5,11 +5,12 @@
|
|
|
5
5
|
|
|
6
6
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
7
7
|
|
|
8
|
-
const index = require('./index-
|
|
8
|
+
const index = require('./index-6d5f06d0.js');
|
|
9
9
|
const tokens = require('./tokens-21b244ee.js');
|
|
10
10
|
const themeableComponent = require('./themeable-component-fdeaef9f.js');
|
|
11
|
+
const keyboardUtils = require('./keyboard-utils-bb32119b.js');
|
|
11
12
|
|
|
12
|
-
const duetSubmenuBarLinkCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%;height:100%}@media (min-width: 62em){:host{width:auto}}.duet-submenu-bar-link{display:flex;flex-direction:row;gap:16px;align-items:center;justify-content:flex-start;height:100%;padding:12px 1.5rem;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1rem;font-weight:600;line-height:1.25;color:rgb(0, 41, 77);text-align:center;text-decoration:none}@media (min-width: 62em){.duet-submenu-bar-link{flex-direction:column;gap:5px;align-items:center;justify-content:center;font-size:0.875rem;color:rgb(0, 77, 128)}}.duet-submenu-bar-link.duet-theme-turva{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}@media (min-width: 62em){.duet-submenu-bar-link:hover{color:rgb(0, 41, 77);background:rgb(230, 242, 248)}.duet-submenu-bar-link:hover.duet-theme-turva{color:rgb(23, 28, 58);background:rgb(228, 228, 230)}}";
|
|
13
|
+
const duetSubmenuBarLinkCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%;height:100%}@media (min-width: 62em){:host{width:auto}}.duet-submenu-bar-link{display:flex;flex-direction:row;gap:16px;align-items:center;justify-content:flex-start;height:100%;padding:12px 1.5rem;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:1rem;font-weight:600;line-height:1.25;color:rgb(0, 41, 77);text-align:center;text-decoration:none}@media (min-width: 62em){.duet-submenu-bar-link{flex-direction:column;gap:5px;align-items:center;justify-content:center;font-size:0.875rem;color:rgb(0, 77, 128)}}.duet-submenu-bar-link:focus{outline:0;box-shadow:0 0 0 4px rgba(0, 119, 179, 0.3), 0 0 0 1px rgb(0, 119, 179)}.duet-submenu-bar-link:focus.duet-theme-turva{box-shadow:0 0 0 4px rgba(23, 28, 58, 0.2), 0 0 0 1px rgb(23, 28, 58)}@media (min-width: 62em){.duet-submenu-bar-link.active{color:rgb(0, 119, 179)}.duet-theme-turva .duet-submenu-bar-link.active{color:rgb(198, 12, 48)}}.duet-submenu-bar-link.active .label{position:relative}.duet-submenu-bar-link.active .label::after{position:absolute;top:auto;bottom:0;left:0;display:block;width:100%;height:1px;content:\"\";background:rgb(0, 119, 179);transform:1px}@media (min-width: 62em){.duet-submenu-bar-link.active .label::after{display:none}.duet-submenu-bar-link.active::after{position:absolute;top:auto;bottom:0;left:0;display:block;width:100%;height:1px;content:\"\";background:rgb(0, 119, 179);transition:300ms ease;transform:translateY(1px)}}.duet-submenu-bar-link.duet-theme-turva{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}.duet-submenu-bar-link.duet-theme-turva.active .label::after{background:rgb(198, 12, 48)}.duet-submenu-bar-link.duet-theme-turva.active::after{background:rgb(198, 12, 48)}@media (min-width: 62em){.duet-submenu-bar-link:hover{color:rgb(0, 41, 77);background:rgb(230, 242, 248)}.duet-submenu-bar-link:hover.duet-theme-turva{color:rgb(23, 28, 58);background:rgb(228, 228, 230)}}";
|
|
13
14
|
|
|
14
15
|
const DuetSubmenuBarLink = class {
|
|
15
16
|
constructor(hostRef) {
|
|
@@ -29,6 +30,7 @@ const DuetSubmenuBarLink = class {
|
|
|
29
30
|
};
|
|
30
31
|
this.iconSize = "small";
|
|
31
32
|
this.theme = "";
|
|
33
|
+
this.active = false;
|
|
32
34
|
this.href = "#";
|
|
33
35
|
this.icon = undefined;
|
|
34
36
|
}
|
|
@@ -58,12 +60,19 @@ const DuetSubmenuBarLink = class {
|
|
|
58
60
|
}
|
|
59
61
|
this.boundMqlFunctions = [];
|
|
60
62
|
}
|
|
63
|
+
handleEscape(e) {
|
|
64
|
+
if (keyboardUtils.isEscapeKey(e)) {
|
|
65
|
+
const dropdown = this.element.closest("duet-submenu-bar");
|
|
66
|
+
dropdown.open = false;
|
|
67
|
+
dropdown.setFocus();
|
|
68
|
+
}
|
|
69
|
+
}
|
|
61
70
|
/**
|
|
62
71
|
* render() function
|
|
63
72
|
* Always the last one in the class.
|
|
64
73
|
*/
|
|
65
74
|
render() {
|
|
66
|
-
return (index.h(index.Host, null, index.h("a", { class: { "duet-submenu-bar-link": true, "duet-theme-turva": this.theme === "turva" }, href: this.href,
|
|
75
|
+
return (index.h(index.Host, null, index.h("a", { class: { "duet-submenu-bar-link": true, "duet-theme-turva": this.theme === "turva", active: this.active }, href: this.href, onKeyUp: e => this.handleEscape(e), "aria-current": this.active ? "true" : "false" }, this.icon && (index.h("duet-icon", { theme: this.theme, name: this.icon, size: this.iconSize, margin: "none", color: "currentColor" })), index.h("span", { class: "label" }, index.h("slot", null)))));
|
|
67
76
|
}
|
|
68
77
|
get element() { return index.getElement(this); }
|
|
69
78
|
};
|
|
@@ -5,17 +5,29 @@
|
|
|
5
5
|
|
|
6
6
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
7
7
|
|
|
8
|
-
const index = require('./index-
|
|
8
|
+
const index = require('./index-6d5f06d0.js');
|
|
9
|
+
const tokens = require('./tokens-21b244ee.js');
|
|
9
10
|
const themeableComponent = require('./themeable-component-fdeaef9f.js');
|
|
10
11
|
|
|
11
|
-
const duetSubmenuBarCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%}:host slot::slotted(duet-submenu-bar-link),:host slot::slotted(duet-submenu-bar-dropdown){position:relative;top:-0.5rem;opacity:0;transition:top 0.3s ease-in, opacity 0.3s ease-in}:host([open]) slot::slotted(duet-submenu-bar-link),:host([open]) slot::slotted(duet-submenu-bar-dropdown){top:0;opacity:1}@media (min-width: 62em){:host slot::slotted(duet-submenu-bar-link),:host slot::slotted(duet-submenu-bar-dropdown){position:relative;top:auto;opacity:1;transition:none}}.duet-submenu-bar{position:relative;background:rgb(243, 249, 252)}@media (min-width: 62em){.duet-submenu-bar{border-bottom:1px solid rgb(205, 229, 241)}}.duet-submenu-bar button{display:flex;align-items:center;justify-content:center;width:100%;padding:12px 0;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:0.875rem;font-weight:400;line-height:1.25;color:rgb(0, 41, 77)}.duet-submenu-bar button.active .caret{transform:rotate(180deg)}.duet-submenu-bar button .label{position:relative;display:flex;gap:8px;align-items:center;justify-content:center}@media (min-width: 62em){.duet-submenu-bar button{display:none}}.duet-submenu-bar .items{position:absolute;z-index:399;width:100%;max-height:1000px;visibility:visible;background:rgb(243, 249, 252);border-bottom:1px solid rgb(207, 210, 212);transition:300ms ease}.duet-submenu-bar .items.hidden{max-height:0;overflow:hidden;visibility:hidden;border-bottom:0 solid rgb(207, 210, 212);transition:300ms ease}@media (min-width: 62em){.duet-submenu-bar .items,.duet-submenu-bar .items.hidden{position:static;z-index:auto;display:flex;flex-direction:row;align-items:center;justify-content:center;max-height:unset;overflow:visible;visibility:visible;border:0;transition:none}}.duet-submenu-bar.duet-theme-turva{background:rgb(245, 245, 247);border-bottom:1px solid rgb(228, 228, 230)}.duet-submenu-bar.duet-theme-turva .items{background:rgb(245, 245, 247)}";
|
|
12
|
+
const duetSubmenuBarCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%}:host slot::slotted(duet-submenu-bar-link),:host slot::slotted(duet-submenu-bar-dropdown){position:relative;top:-0.5rem;opacity:0;transition:top 0.3s ease-in, opacity 0.3s ease-in}:host([open]) slot::slotted(duet-submenu-bar-link),:host([open]) slot::slotted(duet-submenu-bar-dropdown){top:0;opacity:1}@media (min-width: 62em){:host slot::slotted(duet-submenu-bar-link),:host slot::slotted(duet-submenu-bar-dropdown){position:relative;top:auto;opacity:1;transition:none}}.duet-submenu-bar{position:relative;background:rgb(243, 249, 252)}@media (min-width: 62em){.duet-submenu-bar{border-bottom:1px solid rgb(205, 229, 241)}}.duet-submenu-bar button{display:flex;align-items:center;justify-content:center;width:100%;padding:12px 0;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:0.875rem;font-weight:400;line-height:1.25;color:rgb(0, 41, 77)}.duet-submenu-bar button:focus{outline:0;box-shadow:0 0 0 4px rgba(0, 119, 179, 0.3), 0 0 0 1px rgb(0, 119, 179)}.duet-submenu-bar button.active .caret{transform:rotate(180deg)}.duet-submenu-bar button .label{position:relative;display:flex;gap:8px;align-items:center;justify-content:center}@media (min-width: 62em){.duet-submenu-bar button{display:none}}.duet-submenu-bar .items{position:absolute;z-index:399;width:100%;max-height:1000px;visibility:visible;background:rgb(243, 249, 252);border-bottom:1px solid rgb(207, 210, 212);transition:300ms ease}.duet-submenu-bar .items.hidden{max-height:0;overflow:hidden;visibility:hidden;border-bottom:0 solid rgb(207, 210, 212);transition:300ms ease}@media (min-width: 62em){.duet-submenu-bar .items,.duet-submenu-bar .items.hidden{position:static;z-index:auto;display:flex;flex-direction:row;align-items:center;justify-content:center;max-height:unset;overflow:visible;visibility:visible;border:0;transition:none}}.duet-submenu-bar.duet-theme-turva{background:rgb(245, 245, 247);border-bottom:1px solid rgb(228, 228, 230)}.duet-submenu-bar.duet-theme-turva button:focus{box-shadow:0 0 0 4px rgba(23, 28, 58, 0.2), 0 0 0 1px rgb(23, 28, 58)}.duet-submenu-bar.duet-theme-turva .items{background:rgb(245, 245, 247)}";
|
|
12
13
|
|
|
13
14
|
const DuetSubmenuBar = class {
|
|
14
15
|
constructor(hostRef) {
|
|
15
16
|
index.registerInstance(this, hostRef);
|
|
17
|
+
this.mql = [window.matchMedia(tokens.media_query_large.replace(/'/g, ""))];
|
|
18
|
+
this.boundMqlFunctions = [];
|
|
19
|
+
this.changeAriaProperties = () => {
|
|
20
|
+
if (this.mql[0].matches) {
|
|
21
|
+
this.mobile = false;
|
|
22
|
+
}
|
|
23
|
+
else {
|
|
24
|
+
this.mobile = true;
|
|
25
|
+
}
|
|
26
|
+
};
|
|
16
27
|
this.onClick = () => {
|
|
17
28
|
this.open = !this.open;
|
|
18
29
|
};
|
|
30
|
+
this.mobile = true;
|
|
19
31
|
this.theme = "";
|
|
20
32
|
this.open = false;
|
|
21
33
|
}
|
|
@@ -25,14 +37,40 @@ const DuetSubmenuBar = class {
|
|
|
25
37
|
componentWillLoad() {
|
|
26
38
|
themeableComponent.inheritGlobalTheme(this);
|
|
27
39
|
}
|
|
40
|
+
connectedCallback() {
|
|
41
|
+
this.changeAriaProperties();
|
|
42
|
+
for (let i = 0; i < this.mql.length; i++) {
|
|
43
|
+
// addEventListener is not available in Stencil hydrate
|
|
44
|
+
if (this.mql[i].addEventListener) {
|
|
45
|
+
const bound = this.changeAriaProperties.bind(this);
|
|
46
|
+
this.mql[i].addEventListener("change", bound);
|
|
47
|
+
this.boundMqlFunctions[i] = bound;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
disconnectedCallback() {
|
|
52
|
+
for (let i = 0; i < this.mql.length; i++) {
|
|
53
|
+
// removeEventListener is not available in Stencil hydrate
|
|
54
|
+
if (this.mql[i].removeEventListener) {
|
|
55
|
+
this.mql[i].removeEventListener("change", this.boundMqlFunctions[i]);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
this.boundMqlFunctions = [];
|
|
59
|
+
}
|
|
60
|
+
/**
|
|
61
|
+
* Sets focus. Use this method instead of the global focus().
|
|
62
|
+
*/
|
|
63
|
+
async setFocus(options) {
|
|
64
|
+
this.button.focus(options);
|
|
65
|
+
}
|
|
28
66
|
/**
|
|
29
67
|
* render() function
|
|
30
68
|
* Always the last one in the class.
|
|
31
69
|
*/
|
|
32
70
|
render() {
|
|
33
|
-
return (index.h(index.Host, null, index.h("div", { class: { "duet-submenu-bar": true, "duet-theme-turva": this.theme === "turva" }, role: "menubar" }, index.h("button", { "aria-haspopup": "menu", "aria-controls": "menu", "aria-expanded": this.open ? "true" : "false", id: "button", type: "button", class: {
|
|
71
|
+
return (index.h(index.Host, null, index.h("div", { class: { "duet-submenu-bar": true, "duet-theme-turva": this.theme === "turva" }, role: this.mobile ? null : "menubar" }, index.h("button", { ref: element => (this.button = element), "aria-haspopup": "menu", "aria-controls": "menu", "aria-expanded": this.open ? "true" : "false", id: "button", type: "button", class: {
|
|
34
72
|
active: this.open,
|
|
35
|
-
}, onClick: this.onClick }, index.h("div", { class: "label" }, index.h("slot", { name: "label" }), index.h("duet-icon", { theme: this.theme, class: "caret", name: "action-arrow-down-small", margin: "none", size: "xxx-small", color: "currentColor" }))), index.h("div", { role: "menu", id: "menu", "aria-labelledby": "button", "aria-expanded": this.open ? "true" : "false", class: {
|
|
73
|
+
}, onClick: this.onClick }, index.h("div", { class: "label" }, index.h("slot", { name: "label" }), index.h("duet-icon", { theme: this.theme, class: "caret", name: "action-arrow-down-small", margin: "none", size: "xxx-small", color: "currentColor" }))), index.h("div", { role: this.mobile ? "menu" : null, id: "menu", "aria-labelledby": this.mobile ? "button" : null, "aria-expanded": this.mobile ? (this.open ? "true" : "false") : null, class: {
|
|
36
74
|
items: true,
|
|
37
75
|
hidden: !this.open,
|
|
38
76
|
} }, index.h("slot", null)))));
|
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
|
|
6
6
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
7
7
|
|
|
8
|
-
const index = require('./index-
|
|
8
|
+
const index = require('./index-6d5f06d0.js');
|
|
9
9
|
const themeableComponent = require('./themeable-component-fdeaef9f.js');
|
|
10
10
|
const createId = require('./create-id-c3b984b1.js');
|
|
11
11
|
const inputUtils = require('./input-utils-b5e8f524.js');
|
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
|
|
6
6
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
7
7
|
|
|
8
|
-
const index = require('./index-
|
|
8
|
+
const index = require('./index-6d5f06d0.js');
|
|
9
9
|
const themeableComponent = require('./themeable-component-fdeaef9f.js');
|
|
10
10
|
const createId = require('./create-id-c3b984b1.js');
|
|
11
11
|
|
|
@@ -5,10 +5,11 @@
|
|
|
5
5
|
|
|
6
6
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
7
7
|
|
|
8
|
-
const index = require('./index-
|
|
8
|
+
const index = require('./index-6d5f06d0.js');
|
|
9
9
|
const themeableComponent = require('./themeable-component-fdeaef9f.js');
|
|
10
|
+
const keyboardUtils = require('./keyboard-utils-bb32119b.js');
|
|
10
11
|
|
|
11
|
-
const duetToolbarDropdownLinkCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%;height:100%}.duet-toolbar-dropdown-link{display:flex;flex-direction:row;gap:0.5rem;align-items:center;justify-content:flex-start;height:100%;padding:0.5rem 20px;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:0.875rem;font-weight:400;line-height:1.25;color:rgb(0, 41, 77);text-align:center;text-decoration:none}.duet-toolbar-dropdown-link.duet-theme-turva{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}.duet-toolbar-dropdown-link.active,.duet-toolbar-dropdown-link.active:hover{color:rgb(255, 255, 255);background:rgb(0, 119, 179)}.duet-toolbar-dropdown-link.active.duet-theme-turva,.duet-toolbar-dropdown-link.active:hover.duet-theme-turva{color:rgb(255, 255, 255);background:rgb(198, 12, 48)}.duet-toolbar-dropdown-link:hover{background:rgb(230, 242, 248)}.duet-toolbar-dropdown-link:hover.duet-theme-turva{background:rgb(228, 228, 230)}";
|
|
12
|
+
const duetToolbarDropdownLinkCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;width:100%;height:100%}.duet-toolbar-dropdown-link{display:flex;flex-direction:row;gap:0.5rem;align-items:center;justify-content:flex-start;height:100%;padding:0.5rem 20px;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:0.875rem;font-weight:400;line-height:1.25;color:rgb(0, 41, 77);text-align:center;text-decoration:none}.duet-toolbar-dropdown-link.duet-theme-turva{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}.duet-toolbar-dropdown-link:focus{outline:0;box-shadow:0 0 0 4px rgba(0, 119, 179, 0.3), 0 0 0 1px rgb(0, 119, 179)}.duet-toolbar-dropdown-link:focus.duet-theme-turva{box-shadow:0 0 0 4px rgba(23, 28, 58, 0.2), 0 0 0 1px rgb(23, 28, 58)}.duet-toolbar-dropdown-link.active,.duet-toolbar-dropdown-link.active:hover{color:rgb(255, 255, 255);background:rgb(0, 119, 179)}.duet-toolbar-dropdown-link.active.duet-theme-turva,.duet-toolbar-dropdown-link.active:hover.duet-theme-turva{color:rgb(255, 255, 255);background:rgb(198, 12, 48)}.duet-toolbar-dropdown-link:hover{background:rgb(230, 242, 248)}.duet-toolbar-dropdown-link:hover.duet-theme-turva{background:rgb(228, 228, 230)}";
|
|
12
13
|
|
|
13
14
|
const DuetToolbarDropdownLink = class {
|
|
14
15
|
constructor(hostRef) {
|
|
@@ -26,6 +27,13 @@ const DuetToolbarDropdownLink = class {
|
|
|
26
27
|
componentWillLoad() {
|
|
27
28
|
themeableComponent.inheritGlobalTheme(this);
|
|
28
29
|
}
|
|
30
|
+
handleEscape(e) {
|
|
31
|
+
if (keyboardUtils.isEscapeKey(e)) {
|
|
32
|
+
const dropdown = this.element.closest("duet-toolbar-dropdown");
|
|
33
|
+
dropdown.open = false;
|
|
34
|
+
dropdown.setFocus();
|
|
35
|
+
}
|
|
36
|
+
}
|
|
29
37
|
/**
|
|
30
38
|
* render() function
|
|
31
39
|
* Always the last one in the class.
|
|
@@ -35,7 +43,7 @@ const DuetToolbarDropdownLink = class {
|
|
|
35
43
|
"duet-toolbar-dropdown-link": true,
|
|
36
44
|
"duet-theme-turva": this.theme === "turva",
|
|
37
45
|
active: this.active,
|
|
38
|
-
}, href: this.href, lang: this.targetLanguage, hreflang: this.targetLanguage, role: "menuitem", "aria-label": this.accessibleLabel }, this.icon && index.h("duet-icon", { name: this.icon, size: "x-small", margin: "none" }), index.h("slot", null))));
|
|
46
|
+
}, href: this.href, lang: this.targetLanguage, hreflang: this.targetLanguage, role: "menuitem", "aria-label": this.accessibleLabel, "aria-current": this.active ? "true" : "false", onKeyUp: e => this.handleEscape(e) }, this.icon && index.h("duet-icon", { name: this.icon, size: "x-small", margin: "none" }), index.h("slot", null))));
|
|
39
47
|
}
|
|
40
48
|
get element() { return index.getElement(this); }
|
|
41
49
|
};
|
|
@@ -5,10 +5,11 @@
|
|
|
5
5
|
|
|
6
6
|
Object.defineProperty(exports, '__esModule', { value: true });
|
|
7
7
|
|
|
8
|
-
const index = require('./index-
|
|
8
|
+
const index = require('./index-6d5f06d0.js');
|
|
9
9
|
const themeableComponent = require('./themeable-component-fdeaef9f.js');
|
|
10
|
+
const keyboardUtils = require('./keyboard-utils-bb32119b.js');
|
|
10
11
|
|
|
11
|
-
const duetToolbarDropdownCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;height:100%}.duet-toolbar-dropdown{position:relative;height:100%}.duet-toolbar-dropdown button{position:relative;display:flex;gap:8px;align-items:center;justify-content:center;height:100%;padding:0 16px;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:0.875rem;font-weight:400;line-height:1.25;color:rgb(0, 77, 128);text-align:center;text-decoration:none;cursor:pointer}.duet-toolbar-dropdown button .label{display:flex;gap:0.5rem;align-items:center;justify-content:center}.duet-toolbar-dropdown button:hover{color:rgb(0, 41, 77);background:rgb(243, 249, 252)}.duet-toolbar-dropdown button.open .caret{transform:rotate(180deg)}.duet-toolbar-dropdown button.active,.duet-toolbar-dropdown button.open{color:rgb(0, 41, 77)}.duet-toolbar-dropdown button.active::after,.duet-toolbar-dropdown button.open::after{position:absolute;top:auto;bottom:1px;left:0;display:block;width:100%;height:1px;content:\"\";background:rgb(0, 119, 179);transition:300ms ease;transform:translateY(1px)}.duet-toolbar-dropdown .items{position:absolute;top:102%;right:0%;left:auto;z-index:600;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:175px;padding:1rem 0;color:rgb(0, 41, 77);background:rgb(243, 249, 252);border-radius:0 0 8px 8px;box-shadow:0 6px 6px 0 rgba(0, 41, 77, 0.1)}.duet-toolbar-dropdown .items.hidden{display:none}.duet-toolbar-dropdown.right .items{right:auto;left:0%}.duet-toolbar-dropdown.duet-theme-turva button{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}.duet-toolbar-dropdown.duet-theme-turva button:hover{color:rgb(23, 28, 58);background:rgb(245, 245, 247)}.duet-toolbar-dropdown.duet-theme-turva button.active,.duet-toolbar-dropdown.duet-theme-turva button.open{color:rgb(23, 28, 58)}.duet-toolbar-dropdown.duet-theme-turva button.active::after,.duet-toolbar-dropdown.duet-theme-turva button.open::after{background:rgb(198, 12, 48)}.duet-toolbar-dropdown.duet-theme-turva .items{background:rgb(245, 245, 247)}";
|
|
12
|
+
const duetToolbarDropdownCss = "*,*::after,*::before{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none}:host{box-sizing:border-box;padding:0;margin:0;background:transparent;border:0;-moz-appearance:none;-webkit-appearance:none;appearance:none;height:100%}.duet-toolbar-dropdown{position:relative;height:100%}.duet-toolbar-dropdown button{position:relative;display:flex;gap:8px;align-items:center;justify-content:center;height:100%;padding:0 16px;font-family:\"localtapiola-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";font-size:0.875rem;font-weight:400;line-height:1.25;color:rgb(0, 77, 128);text-align:center;text-decoration:none;cursor:pointer}.duet-toolbar-dropdown button .label{display:flex;gap:0.5rem;align-items:center;justify-content:center}.duet-toolbar-dropdown button:hover{color:rgb(0, 41, 77);background:rgb(243, 249, 252)}.duet-toolbar-dropdown button:focus{outline:0;box-shadow:0 0 0 4px rgba(0, 119, 179, 0.3), 0 0 0 1px rgb(0, 119, 179)}.duet-toolbar-dropdown button.open .caret{transform:rotate(180deg)}.duet-toolbar-dropdown button.active,.duet-toolbar-dropdown button.open{color:rgb(0, 41, 77)}.duet-toolbar-dropdown button.active::after,.duet-toolbar-dropdown button.open::after{position:absolute;top:auto;bottom:1px;left:0;display:block;width:100%;height:1px;content:\"\";background:rgb(0, 119, 179);transition:300ms ease;transform:translateY(1px)}.duet-toolbar-dropdown .items{position:absolute;top:102%;right:0%;left:auto;z-index:600;display:flex;flex-direction:column;align-items:center;justify-content:center;min-width:175px;padding:1rem 0;color:rgb(0, 41, 77);background:rgb(243, 249, 252);border-radius:0 0 8px 8px;box-shadow:0 6px 6px 0 rgba(0, 41, 77, 0.1)}.duet-toolbar-dropdown .items.hidden{display:none}.duet-toolbar-dropdown.right .items{right:auto;left:0%}.duet-toolbar-dropdown.duet-theme-turva button{font-family:\"turva-sans\", -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto, Helvetica, Arial, sans-serif, \"Apple Color Emoji\", \"Segoe UI Emoji\", \"Segoe UI Symbol\";color:rgb(23, 28, 58)}.duet-toolbar-dropdown.duet-theme-turva button:hover{color:rgb(23, 28, 58);background:rgb(245, 245, 247)}.duet-toolbar-dropdown.duet-theme-turva button:focus{box-shadow:0 0 0 4px rgba(23, 28, 58, 0.2), 0 0 0 1px rgb(23, 28, 58)}.duet-toolbar-dropdown.duet-theme-turva button.active,.duet-toolbar-dropdown.duet-theme-turva button.open{color:rgb(23, 28, 58)}.duet-toolbar-dropdown.duet-theme-turva button.active::after,.duet-toolbar-dropdown.duet-theme-turva button.open::after{background:rgb(198, 12, 48)}.duet-toolbar-dropdown.duet-theme-turva .items{background:rgb(245, 245, 247)}";
|
|
12
13
|
|
|
13
14
|
const DuetToolbarDropdown = class {
|
|
14
15
|
constructor(hostRef) {
|
|
@@ -33,6 +34,18 @@ const DuetToolbarDropdown = class {
|
|
|
33
34
|
componentWillLoad() {
|
|
34
35
|
themeableComponent.inheritGlobalTheme(this);
|
|
35
36
|
}
|
|
37
|
+
handleEscape(e) {
|
|
38
|
+
if (keyboardUtils.isEscapeKey(e)) {
|
|
39
|
+
this.open = false;
|
|
40
|
+
this.setFocus();
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Sets focus. Use this method instead of the global focus().
|
|
45
|
+
*/
|
|
46
|
+
async setFocus(options) {
|
|
47
|
+
this.button.focus(options);
|
|
48
|
+
}
|
|
36
49
|
/**
|
|
37
50
|
* render() function
|
|
38
51
|
* Always the last one in the class.
|
|
@@ -46,10 +59,10 @@ const DuetToolbarDropdown = class {
|
|
|
46
59
|
"duet-toolbar-dropdown": true,
|
|
47
60
|
"duet-theme-turva": this.theme === "turva",
|
|
48
61
|
[itemsAlign]: true,
|
|
49
|
-
} }, index.h("button", { "aria-haspopup": "menu", "aria-controls": "menu", "aria-expanded": this.open ? "true" : "false", id: "button", type: "button", class: {
|
|
62
|
+
} }, index.h("button", { ref: element => (this.button = element), "aria-haspopup": "menu", "aria-controls": "menu", "aria-expanded": this.open ? "true" : "false", "aria-current": this.active ? "true" : "false", id: "button", type: "button", class: {
|
|
50
63
|
active: this.active,
|
|
51
64
|
open: this.open,
|
|
52
|
-
}, onClick: this.onClick }, this.icon && (index.h("duet-icon", { theme: this.theme, name: this.icon, size: "x-small", margin: "none", color: "currentColor" })), index.h("div", { class: "label" }, index.h("slot", { name: "label" }), index.h("duet-icon", { class: "caret", theme: this.theme, name: "action-arrow-down-small", margin: "none", size: "xxx-small", color: "currentColor" }))), index.h("div", { tabindex: "-1", role: "menu", id: "menu", "aria-labelledby": "button", class: {
|
|
65
|
+
}, onClick: this.onClick, onKeyUp: e => this.handleEscape(e) }, this.icon && (index.h("duet-icon", { theme: this.theme, name: this.icon, size: "x-small", margin: "none", color: "currentColor" })), index.h("div", { class: "label" }, index.h("slot", { name: "label" }), index.h("duet-icon", { class: "caret", theme: this.theme, name: "action-arrow-down-small", margin: "none", size: "xxx-small", color: "currentColor" }))), index.h("div", { tabindex: "-1", role: "menu", id: "menu", "aria-labelledby": "button", class: {
|
|
53
66
|
items: true,
|
|
54
67
|
hidden: !this.open,
|
|
55
68
|
} }, index.h("slot", null)))));
|