@scania/tegel 0.0.34 → 0.0.52
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/dist/cjs/{index-aff9d4d5.js → index-5ad19933.js} +60 -99
- package/dist/cjs/index-5ad19933.js.map +1 -0
- package/dist/cjs/loader.cjs.js +2 -2
- package/dist/cjs/sdds-accordion-item.cjs.entry.js +1 -1
- package/dist/cjs/sdds-accordion.cjs.entry.js +2 -3
- package/dist/cjs/sdds-accordion.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-badges.cjs.entry.js +1 -1
- package/dist/cjs/sdds-banner.cjs.entry.js +8 -8
- package/dist/cjs/sdds-banner.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-block.cjs.entry.js +1 -1
- package/dist/cjs/sdds-body-cell_2.cjs.entry.js +13 -13
- package/dist/cjs/sdds-body-cell_2.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-breadcrumb-link.cjs.entry.js +27 -0
- package/dist/cjs/sdds-breadcrumb-link.cjs.entry.js.map +1 -0
- package/dist/cjs/sdds-breadcrumb.cjs.entry.js +5 -5
- package/dist/cjs/sdds-breadcrumb.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-button.cjs.entry.js +2 -2
- package/dist/cjs/sdds-button.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-card.cjs.entry.js +2 -2
- package/dist/cjs/sdds-card.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-checkbox.cjs.entry.js +3 -3
- package/dist/cjs/sdds-checkbox.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-datetime.cjs.entry.js +15 -6
- package/dist/cjs/sdds-datetime.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-divider.cjs.entry.js +22 -0
- package/dist/cjs/sdds-divider.cjs.entry.js.map +1 -0
- package/dist/cjs/sdds-dropdown-filter.cjs.entry.js +10 -7
- package/dist/cjs/sdds-dropdown-filter.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-dropdown_2.cjs.entry.js +20 -20
- package/dist/cjs/sdds-dropdown_2.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-folder-tabs-button.cjs.entry.js +29 -0
- package/dist/cjs/sdds-folder-tabs-button.cjs.entry.js.map +1 -0
- package/dist/cjs/sdds-folder-tabs-link.cjs.entry.js +34 -0
- package/dist/cjs/sdds-folder-tabs-link.cjs.entry.js.map +1 -0
- package/dist/cjs/sdds-folder-tabs.cjs.entry.js +180 -0
- package/dist/cjs/sdds-folder-tabs.cjs.entry.js.map +1 -0
- package/dist/cjs/sdds-footer-link-group.cjs.entry.js +36 -0
- package/dist/cjs/sdds-footer-link-group.cjs.entry.js.map +1 -0
- package/dist/cjs/sdds-footer-link.cjs.entry.js +29 -0
- package/dist/cjs/sdds-footer-link.cjs.entry.js.map +1 -0
- package/dist/cjs/sdds-footer.cjs.entry.js +28 -0
- package/dist/cjs/sdds-footer.cjs.entry.js.map +1 -0
- package/dist/cjs/sdds-header-cell.cjs.entry.js +9 -13
- package/dist/cjs/sdds-header-cell.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-icon.cjs.entry.js +3 -2
- package/dist/cjs/sdds-icon.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-inline-tabs-button.cjs.entry.js +24 -0
- package/dist/cjs/sdds-inline-tabs-button.cjs.entry.js.map +1 -0
- package/dist/cjs/sdds-inline-tabs-link.cjs.entry.js +29 -0
- package/dist/cjs/sdds-inline-tabs-link.cjs.entry.js.map +1 -0
- package/dist/cjs/sdds-inline-tabs.cjs.entry.js +113 -148
- package/dist/cjs/sdds-inline-tabs.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-link.cjs.entry.js +1 -1
- package/dist/cjs/sdds-message.cjs.entry.js +1 -1
- package/dist/cjs/sdds-modal.cjs.entry.js +67 -22
- package/dist/cjs/sdds-modal.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-navigation-tabs-button.cjs.entry.js +24 -0
- package/dist/cjs/sdds-navigation-tabs-button.cjs.entry.js.map +1 -0
- package/dist/cjs/sdds-navigation-tabs-link.cjs.entry.js +29 -0
- package/dist/cjs/sdds-navigation-tabs-link.cjs.entry.js.map +1 -0
- package/dist/cjs/sdds-navigation-tabs.cjs.entry.js +69 -24
- package/dist/cjs/sdds-navigation-tabs.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-popover-canvas.cjs.entry.js +68 -41
- package/dist/cjs/sdds-popover-canvas.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-popover-menu.cjs.entry.js +1 -1
- package/dist/cjs/sdds-radio-button.cjs.entry.js +7 -3
- package/dist/cjs/sdds-radio-button.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-slider.cjs.entry.js +17 -17
- package/dist/cjs/sdds-slider.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-spinner.cjs.entry.js +1 -1
- package/dist/cjs/sdds-spinner.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-stepper-item.cjs.entry.js +40 -0
- package/dist/cjs/sdds-stepper-item.cjs.entry.js.map +1 -0
- package/dist/cjs/sdds-stepper.cjs.entry.js +45 -0
- package/dist/cjs/sdds-stepper.cjs.entry.js.map +1 -0
- package/dist/cjs/sdds-table-body-row-expandable.cjs.entry.js +6 -6
- package/dist/cjs/sdds-table-body-row-expandable.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-table-body.cjs.entry.js +13 -13
- package/dist/cjs/sdds-table-body.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-table-footer.cjs.entry.js +7 -7
- package/dist/cjs/sdds-table-footer.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-table-header.cjs.entry.js +7 -7
- package/dist/cjs/sdds-table-header.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-table-toolbar.cjs.entry.js +4 -4
- package/dist/cjs/sdds-table-toolbar.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-table.cjs.entry.js +10 -10
- package/dist/cjs/sdds-table.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-textarea.cjs.entry.js +13 -11
- package/dist/cjs/sdds-textarea.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-textfield.cjs.entry.js +13 -24
- package/dist/cjs/sdds-textfield.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-toast.cjs.entry.js +1 -1
- package/dist/cjs/sdds-toggle.cjs.entry.js +11 -12
- package/dist/cjs/sdds-toggle.cjs.entry.js.map +1 -1
- package/dist/cjs/sdds-tooltip.cjs.entry.js +1 -1
- package/dist/cjs/sdds-tooltip.cjs.entry.js.map +1 -1
- package/dist/cjs/tegel.cjs.js +2 -2
- package/dist/collection/collection-manifest.json +16 -5
- package/dist/collection/components/accordion/accordion.js +1 -20
- package/dist/collection/components/accordion/accordion.js.map +1 -1
- package/dist/collection/components/accordion/accordion.stories.js +21 -21
- package/dist/collection/components/accordion/accordion.stories.js.map +1 -1
- package/dist/collection/components/badge/badge.stories.js +16 -19
- package/dist/collection/components/badge/badge.stories.js.map +1 -1
- package/dist/collection/components/banner/banner.stories.js +5 -5
- package/dist/collection/components/banner/banner.stories.js.map +1 -1
- package/dist/collection/components/banner/sdds-banner.css +8 -2
- package/dist/collection/components/banner/sdds-banner.js +12 -93
- package/dist/collection/components/banner/sdds-banner.js.map +1 -1
- package/dist/collection/components/banner/sdds-banner.stories.js +12 -38
- package/dist/collection/components/banner/sdds-banner.stories.js.map +1 -1
- package/dist/collection/components/breadcrumb/{breadcrumb-item/breadcrumb-item.css → sdds-breadcrumb-link/sdds-breadcrumb-link.css} +13 -13
- package/dist/collection/components/breadcrumb/{breadcrumb-item/breadcrumb-item.js → sdds-breadcrumb-link/sdds-breadcrumb-link.js} +45 -9
- package/dist/collection/components/breadcrumb/sdds-breadcrumb-link/sdds-breadcrumb-link.js.map +1 -0
- package/dist/collection/components/breadcrumb/sdds-breadcrumb.css +15 -0
- package/dist/collection/components/breadcrumb/{breadcrumb.js → sdds-breadcrumb.js} +5 -5
- package/dist/collection/components/breadcrumb/sdds-breadcrumb.js.map +1 -0
- package/dist/collection/components/breadcrumb/sdds-breadcrumb.stories.js +36 -0
- package/dist/collection/components/breadcrumb/sdds-breadcrumb.stories.js.map +1 -0
- package/dist/collection/components/button/button-native.stories.js +39 -32
- package/dist/collection/components/button/button-native.stories.js.map +1 -1
- package/dist/collection/components/button/button-webcomponent.stories.js +36 -33
- package/dist/collection/components/button/button-webcomponent.stories.js.map +1 -1
- package/dist/collection/components/button/button.css +29 -60
- package/dist/collection/components/card/card.stories.js +48 -51
- package/dist/collection/components/card/card.stories.js.map +1 -1
- package/dist/collection/components/card/sdds-card.css +1 -0
- package/dist/collection/components/card/sdds-card.stories.js +27 -36
- package/dist/collection/components/card/sdds-card.stories.js.map +1 -1
- package/dist/collection/components/checkbox/checkbox.stories.js +20 -12
- package/dist/collection/components/checkbox/checkbox.stories.js.map +1 -1
- package/dist/collection/components/checkbox/sdds-checkbox.css +5 -4
- package/dist/collection/components/checkbox/sdds-checkbox.js +1 -1
- package/dist/collection/components/checkbox/sdds-checkbox.js.map +1 -1
- package/dist/collection/components/checkbox/sdds-checkbox.stories.js +21 -13
- package/dist/collection/components/checkbox/sdds-checkbox.stories.js.map +1 -1
- package/dist/collection/components/chips/chips.stories.js +51 -31
- package/dist/collection/components/chips/chips.stories.js.map +1 -1
- package/dist/collection/components/data-table/native-table.stories.js +44 -67
- package/dist/collection/components/data-table/native-table.stories.js.map +1 -1
- package/dist/collection/components/data-table/table/table.js +17 -14
- package/dist/collection/components/data-table/table/table.js.map +1 -1
- package/dist/collection/components/data-table/table-body/table-body.js +37 -28
- package/dist/collection/components/data-table/table-body/table-body.js.map +1 -1
- package/dist/collection/components/data-table/table-body-cell/table-body-cell.js +10 -10
- package/dist/collection/components/data-table/table-body-cell/table-body-cell.js.map +1 -1
- package/dist/collection/components/data-table/table-body-row/table-body-row.css +10 -5
- package/dist/collection/components/data-table/table-body-row/table-body-row.js +24 -18
- package/dist/collection/components/data-table/table-body-row/table-body-row.js.map +1 -1
- package/dist/collection/components/data-table/table-body-row-expandable/table-body-row-expandable.js +19 -13
- package/dist/collection/components/data-table/table-body-row-expandable/table-body-row-expandable.js.map +1 -1
- package/dist/collection/components/data-table/table-component-basic.stories.js +61 -39
- package/dist/collection/components/data-table/table-component-basic.stories.js.map +1 -1
- package/dist/collection/components/data-table/table-component-batch-actions.stories.js +61 -40
- package/dist/collection/components/data-table/table-component-batch-actions.stories.js.map +1 -1
- package/dist/collection/components/data-table/table-component-bodydata.stories.js +0 -6
- package/dist/collection/components/data-table/table-component-bodydata.stories.js.map +1 -1
- package/dist/collection/components/data-table/table-component-custom-width.stories.js +31 -55
- package/dist/collection/components/data-table/table-component-custom-width.stories.js.map +1 -1
- package/dist/collection/components/data-table/table-component-event-listeners.stories.js +65 -41
- package/dist/collection/components/data-table/table-component-event-listeners.stories.js.map +1 -1
- package/dist/collection/components/data-table/table-component-expandable-rows.stories.js +59 -35
- package/dist/collection/components/data-table/table-component-expandable-rows.stories.js.map +1 -1
- package/dist/collection/components/data-table/table-component-filtering.stories.js +63 -44
- package/dist/collection/components/data-table/table-component-filtering.stories.js.map +1 -1
- package/dist/collection/components/data-table/table-component-multiselect.stories.js +67 -45
- package/dist/collection/components/data-table/table-component-multiselect.stories.js.map +1 -1
- package/dist/collection/components/data-table/table-component-pagination.stories.js +65 -43
- package/dist/collection/components/data-table/table-component-pagination.stories.js.map +1 -1
- package/dist/collection/components/data-table/table-component-sorting.stories.js +87 -31
- package/dist/collection/components/data-table/table-component-sorting.stories.js.map +1 -1
- package/dist/collection/components/data-table/table-footer/table-footer.js +18 -15
- package/dist/collection/components/data-table/table-footer/table-footer.js.map +1 -1
- package/dist/collection/components/data-table/table-header/table-header.css +10 -5
- package/dist/collection/components/data-table/table-header/table-header.js +17 -14
- package/dist/collection/components/data-table/table-header/table-header.js.map +1 -1
- package/dist/collection/components/data-table/table-header-cell/table-header-cell.js +27 -31
- package/dist/collection/components/data-table/table-header-cell/table-header-cell.js.map +1 -1
- package/dist/collection/components/data-table/table-toolbar/table-toolbar.js +7 -7
- package/dist/collection/components/data-table/table-toolbar/table-toolbar.js.map +1 -1
- package/dist/collection/components/datetime/datetime.js +56 -11
- package/dist/collection/components/datetime/datetime.js.map +1 -1
- package/dist/collection/components/datetime/datetime.stories.js +62 -62
- package/dist/collection/components/datetime/datetime.stories.js.map +1 -1
- package/dist/collection/components/divider/divider-component.css +16 -0
- package/dist/collection/components/divider/divider-webcomponent.stories.js +62 -0
- package/dist/collection/components/divider/divider-webcomponent.stories.js.map +1 -0
- package/dist/collection/components/divider/divider.js +44 -0
- package/dist/collection/components/divider/divider.js.map +1 -0
- package/dist/collection/components/divider/divider.stories.js +21 -24
- package/dist/collection/components/divider/divider.stories.js.map +1 -1
- package/dist/collection/components/dropdown/dropdown-filter/dropdown-filter.js +35 -13
- package/dist/collection/components/dropdown/dropdown-filter/dropdown-filter.js.map +1 -1
- package/dist/collection/components/dropdown/dropdown-filter/dropdown-filter.stories.js +78 -26
- package/dist/collection/components/dropdown/dropdown-filter/dropdown-filter.stories.js.map +1 -1
- package/dist/collection/components/dropdown/dropdown-native.stories.js +35 -22
- package/dist/collection/components/dropdown/dropdown-native.stories.js.map +1 -1
- package/dist/collection/components/dropdown/dropdown-option/dropdown-option.js +21 -16
- package/dist/collection/components/dropdown/dropdown-option/dropdown-option.js.map +1 -1
- package/dist/collection/components/dropdown/dropdown-wc-default.stories.js +58 -51
- package/dist/collection/components/dropdown/dropdown-wc-default.stories.js.map +1 -1
- package/dist/collection/components/dropdown/dropdown-wc-multiselect.stories.js +73 -50
- package/dist/collection/components/dropdown/dropdown-wc-multiselect.stories.js.map +1 -1
- package/dist/collection/components/dropdown/dropdown.css +14 -167
- package/dist/collection/components/dropdown/dropdown.js +22 -17
- package/dist/collection/components/dropdown/dropdown.js.map +1 -1
- package/dist/collection/components/footer/footer.stories.js +6 -6
- package/dist/collection/components/footer/footer.stories.js.map +1 -1
- package/dist/collection/components/footer/webcomponent/sdds-footer-link/sdds-footer-link.css +45 -0
- package/dist/collection/components/footer/webcomponent/sdds-footer-link/sdds-footer-link.js +86 -0
- package/dist/collection/components/footer/webcomponent/sdds-footer-link/sdds-footer-link.js.map +1 -0
- package/dist/collection/components/footer/webcomponent/sdds-footer-link-group/sdds-footer-link-group.css +67 -0
- package/dist/collection/components/footer/webcomponent/sdds-footer-link-group/sdds-footer-link-group.js +62 -0
- package/dist/collection/components/footer/webcomponent/sdds-footer-link-group/sdds-footer-link-group.js.map +1 -0
- package/dist/collection/components/footer/webcomponent/sdds-footer.css +85 -0
- package/dist/collection/components/footer/webcomponent/sdds-footer.js +56 -0
- package/dist/collection/components/footer/webcomponent/sdds-footer.js.map +1 -0
- package/dist/collection/components/footer/webcomponent/sdds-footer.stories.js +118 -0
- package/dist/collection/components/footer/webcomponent/sdds-footer.stories.js.map +1 -0
- package/dist/collection/components/header/header-all.stories.js +4 -2
- package/dist/collection/components/header/header-all.stories.js.map +1 -1
- package/dist/collection/components/header/header-default.stories.js +4 -2
- package/dist/collection/components/header/header-default.stories.js.map +1 -1
- package/dist/collection/components/header/header-inline.stories.js +4 -2
- package/dist/collection/components/header/header-inline.stories.js.map +1 -1
- package/dist/collection/components/header/header-search.stories.js +4 -2
- package/dist/collection/components/header/header-search.stories.js.map +1 -1
- package/dist/collection/components/header/header-toolbar.stories.js +4 -2
- package/dist/collection/components/header/header-toolbar.stories.js.map +1 -1
- package/dist/collection/components/icon/iconsArray.js +111 -2
- package/dist/collection/components/link/link.stories.js +15 -9
- package/dist/collection/components/link/link.stories.js.map +1 -1
- package/dist/collection/components/link/sdds-link.stories.js +15 -15
- package/dist/collection/components/link/sdds-link.stories.js.map +1 -1
- package/dist/collection/components/message/message.stories.js +53 -33
- package/dist/collection/components/message/message.stories.js.map +1 -1
- package/dist/collection/components/message/sdds-message.stories.js +23 -22
- package/dist/collection/components/message/sdds-message.stories.js.map +1 -1
- package/dist/collection/components/modal/modal-native.stories.js +28 -20
- package/dist/collection/components/modal/modal-native.stories.js.map +1 -1
- package/dist/collection/components/modal/modal-webcomponent.stories.js +33 -22
- package/dist/collection/components/modal/modal-webcomponent.stories.js.map +1 -1
- package/dist/collection/components/modal/modal.js +147 -29
- package/dist/collection/components/modal/modal.js.map +1 -1
- package/dist/collection/components/popover-canvas/popover-canvas.css +0 -4
- package/dist/collection/components/popover-canvas/popover-canvas.js +99 -46
- package/dist/collection/components/popover-canvas/popover-canvas.js.map +1 -1
- package/dist/collection/components/popover-canvas/popover-canvas.stories.js +16 -14
- package/dist/collection/components/popover-canvas/popover-canvas.stories.js.map +1 -1
- package/dist/collection/components/popover-menu/popover-menu-icons.stories.js +7 -3
- package/dist/collection/components/popover-menu/popover-menu-icons.stories.js.map +1 -1
- package/dist/collection/components/popover-menu/popover-menu.stories.js +7 -3
- package/dist/collection/components/popover-menu/popover-menu.stories.js.map +1 -1
- package/dist/collection/components/radio-button/radio-button-component.stories.js +7 -8
- package/dist/collection/components/radio-button/radio-button-component.stories.js.map +1 -1
- package/dist/collection/components/radio-button/radio-button.js +6 -2
- package/dist/collection/components/radio-button/radio-button.js.map +1 -1
- package/dist/collection/components/radio-button/radio-button.stories.js +9 -6
- package/dist/collection/components/radio-button/radio-button.stories.js.map +1 -1
- package/dist/collection/components/slider/slider.css +27 -16
- package/dist/collection/components/slider/slider.js +27 -27
- package/dist/collection/components/slider/slider.js.map +1 -1
- package/dist/collection/components/slider/slider.stories.js +93 -67
- package/dist/collection/components/slider/slider.stories.js.map +1 -1
- package/dist/collection/components/spinner/spinner.stories.js +8 -2
- package/dist/collection/components/spinner/spinner.stories.js.map +1 -1
- package/dist/collection/components/stepper/sdds-stepper.css +13 -0
- package/dist/collection/components/stepper/sdds-stepper.js +126 -0
- package/dist/collection/components/stepper/sdds-stepper.js.map +1 -0
- package/dist/collection/components/stepper/stepper-item/sdds-stepper-item.css +197 -0
- package/dist/collection/components/stepper/stepper-item/sdds-stepper-item.js +112 -0
- package/dist/collection/components/stepper/stepper-item/sdds-stepper-item.js.map +1 -0
- package/dist/collection/components/stepper/stepper.stories.js +31 -41
- package/dist/collection/components/stepper/stepper.stories.js.map +1 -1
- package/dist/collection/components/tabs/folder-tabs/folder-tabs-button/sdds-folder-tabs-button.css +79 -0
- package/dist/collection/components/tabs/folder-tabs/folder-tabs-button/sdds-folder-tabs-button.js +100 -0
- package/dist/collection/components/tabs/folder-tabs/folder-tabs-button/sdds-folder-tabs-button.js.map +1 -0
- package/dist/collection/components/tabs/folder-tabs/folder-tabs-link/sdds-folder-tabs-link.css +77 -0
- package/dist/collection/components/tabs/folder-tabs/folder-tabs-link/sdds-folder-tabs-link.js +158 -0
- package/dist/collection/components/tabs/folder-tabs/folder-tabs-link/sdds-folder-tabs-link.js.map +1 -0
- package/dist/collection/components/tabs/folder-tabs/folder-tabs.css +64 -0
- package/dist/collection/components/tabs/folder-tabs/folder-tabs.js +256 -0
- package/dist/collection/components/tabs/folder-tabs/folder-tabs.js.map +1 -0
- package/dist/collection/components/tabs/folder-tabs/folder-tabs.stories.js +114 -0
- package/dist/collection/components/tabs/folder-tabs/folder-tabs.stories.js.map +1 -0
- package/dist/collection/components/tabs/inline-tabs/inline-tabs-button/sdds-inline-tabs-button.css +73 -0
- package/dist/collection/components/tabs/{inline-tabs-default/inline-tab/inline-tab.js → inline-tabs/inline-tabs-button/sdds-inline-tabs-button.js} +12 -29
- package/dist/collection/components/tabs/inline-tabs/inline-tabs-button/sdds-inline-tabs-button.js.map +1 -0
- package/dist/collection/components/tabs/inline-tabs/inline-tabs-link/sdds-inline-tabs-link.css +75 -0
- package/dist/collection/components/tabs/inline-tabs/inline-tabs-link/sdds-inline-tabs-link.js +122 -0
- package/dist/collection/components/tabs/inline-tabs/inline-tabs-link/sdds-inline-tabs-link.js.map +1 -0
- package/dist/collection/components/tabs/inline-tabs/inline-tabs.css +76 -0
- package/dist/collection/components/tabs/inline-tabs/inline-tabs.js +261 -0
- package/dist/collection/components/tabs/inline-tabs/inline-tabs.js.map +1 -0
- package/dist/collection/components/tabs/inline-tabs/inline-tabs.stories.js +109 -0
- package/dist/collection/components/tabs/inline-tabs/inline-tabs.stories.js.map +1 -0
- package/dist/collection/components/tabs/navigation-tabs/navigation-tabs-button/sdds-navigation-tabs-button.css +73 -0
- package/dist/collection/components/tabs/navigation-tabs/navigation-tabs-button/sdds-navigation-tabs-button.js +64 -0
- package/dist/collection/components/tabs/navigation-tabs/navigation-tabs-button/sdds-navigation-tabs-button.js.map +1 -0
- package/dist/collection/components/tabs/navigation-tabs/navigation-tabs-link/sdds-navigation-tabs-link.css +73 -0
- package/dist/collection/components/tabs/navigation-tabs/navigation-tabs-link/sdds-navigation-tabs-link.js +122 -0
- package/dist/collection/components/tabs/navigation-tabs/navigation-tabs-link/sdds-navigation-tabs-link.js.map +1 -0
- package/dist/collection/components/tabs/navigation-tabs/navigation-tabs.css +37 -118
- package/dist/collection/components/tabs/navigation-tabs/navigation-tabs.js +114 -26
- package/dist/collection/components/tabs/navigation-tabs/navigation-tabs.js.map +1 -1
- package/dist/collection/components/tabs/navigation-tabs/navigation-tabs.stories.js +79 -9
- package/dist/collection/components/tabs/navigation-tabs/navigation-tabs.stories.js.map +1 -1
- package/dist/collection/components/textarea/textarea.css +44 -114
- package/dist/collection/components/textarea/textarea.js +30 -9
- package/dist/collection/components/textarea/textarea.js.map +1 -1
- package/dist/collection/components/textarea/textarea.stories.js +66 -48
- package/dist/collection/components/textarea/textarea.stories.js.map +1 -1
- package/dist/collection/components/textfield/textfield.css +87 -226
- package/dist/collection/components/textfield/textfield.js +12 -22
- package/dist/collection/components/textfield/textfield.js.map +1 -1
- package/dist/collection/components/textfield/textfield.stories.js +94 -80
- package/dist/collection/components/textfield/textfield.stories.js.map +1 -1
- package/dist/collection/components/toast/sdds-toast.stories.js +6 -6
- package/dist/collection/components/toast/sdds-toast.stories.js.map +1 -1
- package/dist/collection/components/toast/toast.stories.js +19 -17
- package/dist/collection/components/toast/toast.stories.js.map +1 -1
- package/dist/collection/components/toggle/sdds-toggle.js +12 -64
- package/dist/collection/components/toggle/sdds-toggle.js.map +1 -1
- package/dist/collection/components/toggle/sdds-toggle.stories.js +22 -20
- package/dist/collection/components/toggle/sdds-toggle.stories.js.map +1 -1
- package/dist/collection/components/toggle/toggle.stories.js +19 -14
- package/dist/collection/components/toggle/toggle.stories.js.map +1 -1
- package/dist/collection/components/tooltip/tooltip.stories.js +30 -18
- package/dist/collection/components/tooltip/tooltip.stories.js.map +1 -1
- package/dist/components/dropdown-option.js +9 -11
- package/dist/components/dropdown-option.js.map +1 -1
- package/dist/components/dropdown.js +13 -10
- package/dist/components/dropdown.js.map +1 -1
- package/dist/components/icon.js +2 -1
- package/dist/components/icon.js.map +1 -1
- package/dist/components/index.d.ts +0 -12
- package/dist/components/index.js +0 -95
- package/dist/components/index.js.map +1 -1
- package/dist/components/sdds-accordion.js +1 -3
- package/dist/components/sdds-accordion.js.map +1 -1
- package/dist/components/sdds-banner.js +11 -20
- package/dist/components/sdds-banner.js.map +1 -1
- package/dist/components/{sdds-breadcrumb-item.d.ts → sdds-breadcrumb-link.d.ts} +4 -4
- package/dist/components/sdds-breadcrumb-link.js +47 -0
- package/dist/components/sdds-breadcrumb-link.js.map +1 -0
- package/dist/components/sdds-breadcrumb.js +4 -4
- package/dist/components/sdds-breadcrumb.js.map +1 -1
- package/dist/components/sdds-button.js +1 -1
- package/dist/components/sdds-button.js.map +1 -1
- package/dist/components/sdds-card.js +1 -1
- package/dist/components/sdds-card.js.map +1 -1
- package/dist/components/sdds-checkbox.js +2 -2
- package/dist/components/sdds-checkbox.js.map +1 -1
- package/dist/components/sdds-datetime.js +14 -5
- package/dist/components/sdds-datetime.js.map +1 -1
- package/dist/components/{sdds-inline-tab.d.ts → sdds-divider.d.ts} +4 -4
- package/dist/components/sdds-divider.js +38 -0
- package/dist/components/sdds-divider.js.map +1 -0
- package/dist/components/sdds-dropdown-filter.js +12 -8
- package/dist/components/sdds-dropdown-filter.js.map +1 -1
- package/dist/components/sdds-folder-tabs-button.d.ts +11 -0
- package/dist/components/sdds-folder-tabs-button.js +48 -0
- package/dist/components/sdds-folder-tabs-button.js.map +1 -0
- package/dist/components/sdds-folder-tabs-link.d.ts +11 -0
- package/dist/components/sdds-folder-tabs-link.js +56 -0
- package/dist/components/sdds-folder-tabs-link.js.map +1 -0
- package/dist/components/sdds-folder-tabs.d.ts +11 -0
- package/dist/components/sdds-folder-tabs.js +208 -0
- package/dist/components/sdds-folder-tabs.js.map +1 -0
- package/dist/components/sdds-footer-link-group.d.ts +11 -0
- package/dist/components/sdds-footer-link-group.js +58 -0
- package/dist/components/sdds-footer-link-group.js.map +1 -0
- package/dist/components/sdds-footer-link.d.ts +11 -0
- package/dist/components/sdds-footer-link.js +46 -0
- package/dist/components/sdds-footer-link.js.map +1 -0
- package/dist/components/sdds-footer.d.ts +11 -0
- package/dist/components/sdds-footer.js +45 -0
- package/dist/components/sdds-footer.js.map +1 -0
- package/dist/components/sdds-header-cell.js +9 -13
- package/dist/components/sdds-header-cell.js.map +1 -1
- package/dist/components/sdds-inline-tabs-button.d.ts +11 -0
- package/dist/components/sdds-inline-tabs-button.js +41 -0
- package/dist/components/sdds-inline-tabs-button.js.map +1 -0
- package/dist/components/sdds-inline-tabs-link.d.ts +11 -0
- package/dist/components/sdds-inline-tabs-link.js +49 -0
- package/dist/components/sdds-inline-tabs-link.js.map +1 -0
- package/dist/components/sdds-inline-tabs.js +123 -155
- package/dist/components/sdds-inline-tabs.js.map +1 -1
- package/dist/components/sdds-link.js +42 -1
- package/dist/components/sdds-link.js.map +1 -1
- package/dist/components/sdds-modal.js +73 -24
- package/dist/components/sdds-modal.js.map +1 -1
- package/dist/components/sdds-navigation-tabs-button.d.ts +11 -0
- package/dist/components/sdds-navigation-tabs-button.js +41 -0
- package/dist/components/sdds-navigation-tabs-button.js.map +1 -0
- package/dist/components/sdds-navigation-tabs-link.d.ts +11 -0
- package/dist/components/sdds-navigation-tabs-link.js +49 -0
- package/dist/components/sdds-navigation-tabs-link.js.map +1 -0
- package/dist/components/sdds-navigation-tabs.js +79 -27
- package/dist/components/sdds-navigation-tabs.js.map +1 -1
- package/dist/components/sdds-popover-canvas.js +71 -42
- package/dist/components/sdds-popover-canvas.js.map +1 -1
- package/dist/components/sdds-radio-button.js +6 -2
- package/dist/components/sdds-radio-button.js.map +1 -1
- package/dist/components/sdds-slider.js +17 -17
- package/dist/components/sdds-slider.js.map +1 -1
- package/dist/components/sdds-spinner.js.map +1 -1
- package/dist/components/sdds-stepper-item.d.ts +11 -0
- package/dist/components/sdds-stepper-item.js +69 -0
- package/dist/components/sdds-stepper-item.js.map +1 -0
- package/dist/components/sdds-stepper.d.ts +11 -0
- package/dist/components/sdds-stepper.js +65 -0
- package/dist/components/sdds-stepper.js.map +1 -0
- package/dist/components/sdds-table-body-row-expandable.js +6 -6
- package/dist/components/sdds-table-body-row-expandable.js.map +1 -1
- package/dist/components/sdds-table-body.js +13 -13
- package/dist/components/sdds-table-body.js.map +1 -1
- package/dist/components/sdds-table-footer.js +7 -7
- package/dist/components/sdds-table-footer.js.map +1 -1
- package/dist/components/sdds-table-header.js +7 -7
- package/dist/components/sdds-table-header.js.map +1 -1
- package/dist/components/sdds-table-toolbar.js +4 -4
- package/dist/components/sdds-table-toolbar.js.map +1 -1
- package/dist/components/sdds-table.js +9 -9
- package/dist/components/sdds-table.js.map +1 -1
- package/dist/components/sdds-textarea.js +14 -11
- package/dist/components/sdds-textarea.js.map +1 -1
- package/dist/components/sdds-textfield.js +13 -24
- package/dist/components/sdds-textfield.js.map +1 -1
- package/dist/components/sdds-toggle.js +10 -14
- package/dist/components/sdds-toggle.js.map +1 -1
- package/dist/components/sdds-tooltip.js.map +1 -1
- package/dist/components/table-body-cell.js +5 -5
- package/dist/components/table-body-cell.js.map +1 -1
- package/dist/components/table-body-row.js +9 -9
- package/dist/components/table-body-row.js.map +1 -1
- package/dist/esm/{index-b21fe3b7.js → index-fdfb114c.js} +60 -99
- package/dist/{tegel/p-1b74896d.js.map → esm/index-fdfb114c.js.map} +1 -1
- package/dist/esm/loader.js +3 -3
- package/dist/esm/sdds-accordion-item.entry.js +1 -1
- package/dist/esm/sdds-accordion.entry.js +2 -3
- package/dist/esm/sdds-accordion.entry.js.map +1 -1
- package/dist/esm/sdds-badges.entry.js +1 -1
- package/dist/esm/sdds-banner.entry.js +8 -8
- package/dist/esm/sdds-banner.entry.js.map +1 -1
- package/dist/esm/sdds-block.entry.js +1 -1
- package/dist/esm/sdds-body-cell_2.entry.js +13 -13
- package/dist/esm/sdds-body-cell_2.entry.js.map +1 -1
- package/dist/esm/sdds-breadcrumb-link.entry.js +23 -0
- package/dist/esm/sdds-breadcrumb-link.entry.js.map +1 -0
- package/dist/esm/sdds-breadcrumb.entry.js +5 -5
- package/dist/esm/sdds-breadcrumb.entry.js.map +1 -1
- package/dist/esm/sdds-button.entry.js +2 -2
- package/dist/esm/sdds-button.entry.js.map +1 -1
- package/dist/esm/sdds-card.entry.js +2 -2
- package/dist/esm/sdds-card.entry.js.map +1 -1
- package/dist/esm/sdds-checkbox.entry.js +3 -3
- package/dist/esm/sdds-checkbox.entry.js.map +1 -1
- package/dist/esm/sdds-datetime.entry.js +15 -6
- package/dist/esm/sdds-datetime.entry.js.map +1 -1
- package/dist/esm/sdds-divider.entry.js +18 -0
- package/dist/esm/sdds-divider.entry.js.map +1 -0
- package/dist/esm/sdds-dropdown-filter.entry.js +10 -7
- package/dist/esm/sdds-dropdown-filter.entry.js.map +1 -1
- package/dist/esm/sdds-dropdown_2.entry.js +20 -20
- package/dist/esm/sdds-dropdown_2.entry.js.map +1 -1
- package/dist/esm/sdds-folder-tabs-button.entry.js +25 -0
- package/dist/esm/sdds-folder-tabs-button.entry.js.map +1 -0
- package/dist/esm/sdds-folder-tabs-link.entry.js +30 -0
- package/dist/esm/sdds-folder-tabs-link.entry.js.map +1 -0
- package/dist/esm/sdds-folder-tabs.entry.js +176 -0
- package/dist/esm/sdds-folder-tabs.entry.js.map +1 -0
- package/dist/esm/sdds-footer-link-group.entry.js +32 -0
- package/dist/esm/sdds-footer-link-group.entry.js.map +1 -0
- package/dist/esm/sdds-footer-link.entry.js +25 -0
- package/dist/esm/sdds-footer-link.entry.js.map +1 -0
- package/dist/esm/sdds-footer.entry.js +24 -0
- package/dist/esm/sdds-footer.entry.js.map +1 -0
- package/dist/esm/sdds-header-cell.entry.js +9 -13
- package/dist/esm/sdds-header-cell.entry.js.map +1 -1
- package/dist/esm/sdds-icon.entry.js +3 -2
- package/dist/esm/sdds-icon.entry.js.map +1 -1
- package/dist/esm/sdds-inline-tabs-button.entry.js +20 -0
- package/dist/esm/sdds-inline-tabs-button.entry.js.map +1 -0
- package/dist/esm/sdds-inline-tabs-link.entry.js +25 -0
- package/dist/esm/sdds-inline-tabs-link.entry.js.map +1 -0
- package/dist/esm/sdds-inline-tabs.entry.js +113 -148
- package/dist/esm/sdds-inline-tabs.entry.js.map +1 -1
- package/dist/esm/sdds-link.entry.js +1 -1
- package/dist/esm/sdds-message.entry.js +1 -1
- package/dist/esm/sdds-modal.entry.js +67 -22
- package/dist/esm/sdds-modal.entry.js.map +1 -1
- package/dist/esm/sdds-navigation-tabs-button.entry.js +20 -0
- package/dist/esm/sdds-navigation-tabs-button.entry.js.map +1 -0
- package/dist/esm/sdds-navigation-tabs-link.entry.js +25 -0
- package/dist/esm/sdds-navigation-tabs-link.entry.js.map +1 -0
- package/dist/esm/sdds-navigation-tabs.entry.js +69 -24
- package/dist/esm/sdds-navigation-tabs.entry.js.map +1 -1
- package/dist/esm/sdds-popover-canvas.entry.js +68 -41
- package/dist/esm/sdds-popover-canvas.entry.js.map +1 -1
- package/dist/esm/sdds-popover-menu.entry.js +1 -1
- package/dist/esm/sdds-radio-button.entry.js +7 -3
- package/dist/esm/sdds-radio-button.entry.js.map +1 -1
- package/dist/esm/sdds-slider.entry.js +17 -17
- package/dist/esm/sdds-slider.entry.js.map +1 -1
- package/dist/esm/sdds-spinner.entry.js +1 -1
- package/dist/esm/sdds-spinner.entry.js.map +1 -1
- package/dist/esm/sdds-stepper-item.entry.js +36 -0
- package/dist/esm/sdds-stepper-item.entry.js.map +1 -0
- package/dist/esm/sdds-stepper.entry.js +41 -0
- package/dist/esm/sdds-stepper.entry.js.map +1 -0
- package/dist/esm/sdds-table-body-row-expandable.entry.js +6 -6
- package/dist/esm/sdds-table-body-row-expandable.entry.js.map +1 -1
- package/dist/esm/sdds-table-body.entry.js +13 -13
- package/dist/esm/sdds-table-body.entry.js.map +1 -1
- package/dist/esm/sdds-table-footer.entry.js +7 -7
- package/dist/esm/sdds-table-footer.entry.js.map +1 -1
- package/dist/esm/sdds-table-header.entry.js +7 -7
- package/dist/esm/sdds-table-header.entry.js.map +1 -1
- package/dist/esm/sdds-table-toolbar.entry.js +4 -4
- package/dist/esm/sdds-table-toolbar.entry.js.map +1 -1
- package/dist/esm/sdds-table.entry.js +10 -10
- package/dist/esm/sdds-table.entry.js.map +1 -1
- package/dist/esm/sdds-textarea.entry.js +13 -11
- package/dist/esm/sdds-textarea.entry.js.map +1 -1
- package/dist/esm/sdds-textfield.entry.js +13 -24
- package/dist/esm/sdds-textfield.entry.js.map +1 -1
- package/dist/esm/sdds-toast.entry.js +1 -1
- package/dist/esm/sdds-toggle.entry.js +11 -12
- package/dist/esm/sdds-toggle.entry.js.map +1 -1
- package/dist/esm/sdds-tooltip.entry.js +1 -1
- package/dist/esm/sdds-tooltip.entry.js.map +1 -1
- package/dist/esm/tegel.js +3 -3
- package/dist/tegel/{p-c5b3ef65.entry.js → p-067789d2.entry.js} +2 -2
- package/dist/tegel/p-067789d2.entry.js.map +1 -0
- package/dist/tegel/p-12f566b7.entry.js +2 -0
- package/dist/tegel/p-12f566b7.entry.js.map +1 -0
- package/dist/tegel/p-15c44320.entry.js +2 -0
- package/dist/tegel/p-15c44320.entry.js.map +1 -0
- package/dist/tegel/{p-7e41ac2c.entry.js → p-1a7f94d3.entry.js} +2 -2
- package/dist/tegel/p-1a7f94d3.entry.js.map +1 -0
- package/dist/tegel/p-1df2e987.entry.js +2 -0
- package/dist/tegel/p-1df2e987.entry.js.map +1 -0
- package/dist/tegel/p-1e196fff.entry.js +2 -0
- package/dist/tegel/p-1e196fff.entry.js.map +1 -0
- package/dist/tegel/p-2080db62.entry.js +2 -0
- package/dist/tegel/p-2080db62.entry.js.map +1 -0
- package/dist/tegel/p-23998948.entry.js +2 -0
- package/dist/tegel/p-23998948.entry.js.map +1 -0
- package/dist/tegel/p-29bcd369.entry.js +2 -0
- package/dist/tegel/p-29bcd369.entry.js.map +1 -0
- package/dist/tegel/p-2c57f4bb.entry.js +2 -0
- package/dist/tegel/p-2c57f4bb.entry.js.map +1 -0
- package/dist/tegel/p-387e1798.js +3 -0
- package/dist/tegel/p-387e1798.js.map +1 -0
- package/dist/tegel/p-3a93619e.entry.js +2 -0
- package/dist/tegel/p-3a93619e.entry.js.map +1 -0
- package/dist/tegel/p-3a9db8c4.entry.js +2 -0
- package/dist/tegel/p-3a9db8c4.entry.js.map +1 -0
- package/dist/tegel/{p-7d097f54.entry.js → p-400d74c2.entry.js} +2 -2
- package/dist/tegel/{p-73ebb46d.entry.js → p-4499e5cd.entry.js} +2 -2
- package/dist/tegel/p-479b1c4e.entry.js +2 -0
- package/dist/tegel/p-479b1c4e.entry.js.map +1 -0
- package/dist/tegel/p-4dee91c9.entry.js +2 -0
- package/dist/tegel/p-4dee91c9.entry.js.map +1 -0
- package/dist/tegel/p-52ecce88.entry.js +2 -0
- package/dist/tegel/p-52ecce88.entry.js.map +1 -0
- package/dist/tegel/p-5812ec42.entry.js +2 -0
- package/dist/tegel/p-5812ec42.entry.js.map +1 -0
- package/dist/tegel/p-595c05f4.entry.js +2 -0
- package/dist/tegel/p-595c05f4.entry.js.map +1 -0
- package/dist/tegel/p-5ca26ce8.entry.js +2 -0
- package/dist/tegel/p-5ca26ce8.entry.js.map +1 -0
- package/dist/tegel/p-5cc6d070.entry.js +2 -0
- package/dist/tegel/p-5cc6d070.entry.js.map +1 -0
- package/dist/tegel/{p-c1f9c2a8.entry.js → p-5dc33f45.entry.js} +2 -2
- package/dist/tegel/p-5f6fe516.entry.js +2 -0
- package/dist/tegel/p-5f6fe516.entry.js.map +1 -0
- package/dist/tegel/p-626434af.entry.js +2 -0
- package/dist/tegel/p-626434af.entry.js.map +1 -0
- package/dist/tegel/{p-847f81ac.entry.js → p-64dd37d4.entry.js} +2 -2
- package/dist/tegel/p-64dd37d4.entry.js.map +1 -0
- package/dist/tegel/p-68e4c190.entry.js +2 -0
- package/dist/tegel/p-68e4c190.entry.js.map +1 -0
- package/dist/tegel/{p-f9d14b96.entry.js → p-750b7e5f.entry.js} +2 -2
- package/dist/tegel/{p-94c6ef69.entry.js → p-7991d22f.entry.js} +2 -2
- package/dist/tegel/p-7f10356d.entry.js +2 -0
- package/dist/tegel/p-7f10356d.entry.js.map +1 -0
- package/dist/tegel/p-7f22cee6.entry.js +2 -0
- package/dist/tegel/p-7f22cee6.entry.js.map +1 -0
- package/dist/tegel/p-88ba44a7.entry.js +2 -0
- package/dist/tegel/p-88ba44a7.entry.js.map +1 -0
- package/dist/tegel/p-8b807df5.entry.js +2 -0
- package/dist/tegel/p-8b807df5.entry.js.map +1 -0
- package/dist/tegel/{p-c46e2117.entry.js → p-a2cbef2c.entry.js} +2 -2
- package/dist/tegel/p-a5cd0006.entry.js +2 -0
- package/dist/tegel/p-a5cd0006.entry.js.map +1 -0
- package/dist/tegel/{p-35146934.entry.js → p-ad3439b8.entry.js} +2 -2
- package/dist/tegel/p-ad3439b8.entry.js.map +1 -0
- package/dist/tegel/p-ae631412.entry.js +2 -0
- package/dist/tegel/p-ae631412.entry.js.map +1 -0
- package/dist/tegel/p-b8d838d1.entry.js +2 -0
- package/dist/tegel/p-b8d838d1.entry.js.map +1 -0
- package/dist/tegel/{p-ce848ab7.entry.js → p-b9b329c0.entry.js} +2 -2
- package/dist/tegel/p-bdae6bc9.entry.js +2 -0
- package/dist/tegel/p-bdae6bc9.entry.js.map +1 -0
- package/dist/tegel/p-bdaf0bc2.entry.js +2 -0
- package/dist/tegel/p-bdaf0bc2.entry.js.map +1 -0
- package/dist/tegel/{p-991b5017.entry.js → p-c4d28002.entry.js} +2 -2
- package/dist/tegel/p-c4d28002.entry.js.map +1 -0
- package/dist/tegel/p-c6c75439.entry.js +2 -0
- package/dist/tegel/p-c6c75439.entry.js.map +1 -0
- package/dist/tegel/{p-c037d66f.entry.js → p-ccb82bc3.entry.js} +2 -2
- package/dist/tegel/p-ccb82bc3.entry.js.map +1 -0
- package/dist/tegel/p-ce84159b.entry.js +2 -0
- package/dist/tegel/p-ce84159b.entry.js.map +1 -0
- package/dist/tegel/p-d517eaef.entry.js +2 -0
- package/dist/tegel/p-d517eaef.entry.js.map +1 -0
- package/dist/tegel/p-edc4d742.entry.js +2 -0
- package/dist/tegel/p-edc4d742.entry.js.map +1 -0
- package/dist/tegel/{p-243cc1a5.entry.js → p-ef5487a3.entry.js} +2 -2
- package/dist/tegel/p-ef5487a3.entry.js.map +1 -0
- package/dist/tegel/p-f23cb0ae.entry.js +2 -0
- package/dist/tegel/p-f23cb0ae.entry.js.map +1 -0
- package/dist/tegel/p-f55ab621.entry.js +2 -0
- package/dist/tegel/p-f55ab621.entry.js.map +1 -0
- package/dist/tegel/p-fcb9e2c1.entry.js +2 -0
- package/dist/tegel/p-fcb9e2c1.entry.js.map +1 -0
- package/dist/tegel/tegel.css +10 -10
- package/dist/tegel/tegel.esm.js +1 -1
- package/dist/tegel/tegel.esm.js.map +1 -1
- package/dist/types/components/accordion/accordion.d.ts +0 -2
- package/dist/types/components/accordion/accordion.stories.d.ts +14 -14
- package/dist/types/components/badge/badge.stories.d.ts +9 -14
- package/dist/types/components/banner/sdds-banner.d.ts +2 -10
- package/dist/types/components/banner/sdds-banner.stories.d.ts +3 -30
- package/dist/types/components/breadcrumb/sdds-breadcrumb-link/sdds-breadcrumb-link.d.ts +13 -0
- package/dist/types/components/breadcrumb/sdds-breadcrumb.stories.d.ts +16 -0
- package/dist/types/components/button/button-native.stories.d.ts +36 -25
- package/dist/types/components/button/button-webcomponent.stories.d.ts +30 -26
- package/dist/types/components/card/card.stories.d.ts +29 -30
- package/dist/types/components/card/sdds-card.stories.d.ts +13 -24
- package/dist/types/components/checkbox/checkbox.stories.d.ts +17 -5
- package/dist/types/components/checkbox/sdds-checkbox.stories.d.ts +17 -5
- package/dist/types/components/chips/chips.stories.d.ts +42 -18
- package/dist/types/components/data-table/native-table.stories.d.ts +17 -31
- package/dist/types/components/data-table/table/table.d.ts +5 -4
- package/dist/types/components/data-table/table-body/table-body.d.ts +9 -9
- package/dist/types/components/data-table/table-body-cell/table-body-cell.d.ts +4 -4
- package/dist/types/components/data-table/table-body-row/table-body-row.d.ts +7 -7
- package/dist/types/components/data-table/table-body-row-expandable/table-body-row-expandable.d.ts +6 -6
- package/dist/types/components/data-table/table-component-basic.stories.d.ts +54 -11
- package/dist/types/components/data-table/table-component-batch-actions.stories.d.ts +54 -14
- package/dist/types/components/data-table/table-component-bodydata.stories.d.ts +0 -5
- package/dist/types/components/data-table/table-component-custom-width.stories.d.ts +15 -32
- package/dist/types/components/data-table/table-component-event-listeners.stories.d.ts +54 -11
- package/dist/types/components/data-table/table-component-expandable-rows.stories.d.ts +54 -11
- package/dist/types/components/data-table/table-component-filtering.stories.d.ts +54 -16
- package/dist/types/components/data-table/table-component-multiselect.stories.d.ts +57 -14
- package/dist/types/components/data-table/table-component-pagination.stories.d.ts +58 -15
- package/dist/types/components/data-table/table-component-sorting.stories.d.ts +93 -10
- package/dist/types/components/data-table/table-footer/table-footer.d.ts +7 -7
- package/dist/types/components/data-table/table-header/table-header.d.ts +6 -6
- package/dist/types/components/data-table/table-header-cell/table-header-cell.d.ts +9 -10
- package/dist/types/components/data-table/table-toolbar/table-toolbar.d.ts +4 -4
- package/dist/types/components/datetime/datetime.d.ts +11 -5
- package/dist/types/components/datetime/datetime.stories.d.ts +36 -35
- package/dist/types/components/divider/divider-webcomponent.stories.d.ts +58 -0
- package/dist/types/components/divider/divider.d.ts +5 -0
- package/dist/types/components/divider/divider.stories.d.ts +11 -16
- package/dist/types/components/dropdown/dropdown-filter/dropdown-filter.d.ts +4 -2
- package/dist/types/components/dropdown/dropdown-filter/dropdown-filter.stories.d.ts +76 -12
- package/dist/types/components/dropdown/dropdown-native.stories.d.ts +26 -11
- package/dist/types/components/dropdown/dropdown-option/dropdown-option.d.ts +7 -2
- package/dist/types/components/dropdown/dropdown-wc-default.stories.d.ts +48 -33
- package/dist/types/components/dropdown/dropdown-wc-multiselect.stories.d.ts +61 -32
- package/dist/types/components/dropdown/dropdown.d.ts +4 -3
- package/dist/types/components/footer/footer.stories.d.ts +5 -5
- package/dist/types/components/footer/webcomponent/sdds-footer-link/sdds-footer-link.d.ts +13 -0
- package/dist/types/components/footer/webcomponent/sdds-footer-link-group/sdds-footer-link-group.d.ts +11 -0
- package/dist/types/components/footer/webcomponent/sdds-footer.d.ts +9 -0
- package/dist/types/components/{tabs/inline-tabs-fullbleed/inline-tabs-fullbleed.stories.d.ts → footer/webcomponent/sdds-footer.stories.d.ts} +16 -2
- package/dist/types/components/header/header-all.stories.d.ts +3 -1
- package/dist/types/components/header/header-default.stories.d.ts +3 -1
- package/dist/types/components/header/header-inline.stories.d.ts +3 -1
- package/dist/types/components/header/header-search.stories.d.ts +3 -1
- package/dist/types/components/header/header-toolbar.stories.d.ts +3 -1
- package/dist/types/components/link/link.stories.d.ts +13 -3
- package/dist/types/components/link/sdds-link.stories.d.ts +9 -9
- package/dist/types/components/message/message.stories.d.ts +32 -12
- package/dist/types/components/message/sdds-message.stories.d.ts +9 -8
- package/dist/types/components/modal/modal-native.stories.d.ts +23 -8
- package/dist/types/components/modal/modal-webcomponent.stories.d.ts +22 -4
- package/dist/types/components/modal/modal.d.ts +27 -7
- package/dist/types/components/popover-canvas/popover-canvas.d.ts +13 -4
- package/dist/types/components/popover-canvas/popover-canvas.stories.d.ts +5 -3
- package/dist/types/components/popover-menu/popover-menu-icons.stories.d.ts +5 -0
- package/dist/types/components/popover-menu/popover-menu.stories.d.ts +5 -0
- package/dist/types/components/radio-button/radio-button-component.stories.d.ts +1 -1
- package/dist/types/components/radio-button/radio-button.stories.d.ts +6 -1
- package/dist/types/components/slider/slider.d.ts +2 -2
- package/dist/types/components/slider/slider.stories.d.ts +90 -24
- package/dist/types/components/spinner/spinner.stories.d.ts +12 -2
- package/dist/types/components/stepper/sdds-stepper.d.ts +17 -0
- package/dist/types/components/stepper/stepper-item/sdds-stepper-item.d.ts +17 -0
- package/dist/types/components/stepper/stepper.stories.d.ts +25 -9
- package/dist/types/components/tabs/folder-tabs/folder-tabs-button/sdds-folder-tabs-button.d.ts +10 -0
- package/dist/types/components/tabs/folder-tabs/folder-tabs-link/sdds-folder-tabs-link.d.ts +16 -0
- package/dist/types/components/tabs/folder-tabs/folder-tabs.d.ts +38 -0
- package/dist/types/components/tabs/{inline-tabs-default/inline-tabs.stories.d.ts → folder-tabs/folder-tabs.stories.d.ts} +14 -11
- package/dist/types/components/tabs/inline-tabs/inline-tabs-button/sdds-inline-tabs-button.d.ts +7 -0
- package/dist/types/components/tabs/inline-tabs/inline-tabs-link/sdds-inline-tabs-link.d.ts +13 -0
- package/dist/types/components/tabs/inline-tabs/inline-tabs.d.ts +40 -0
- package/dist/types/components/tabs/inline-tabs/inline-tabs.stories.d.ts +44 -0
- package/dist/types/components/tabs/navigation-tabs/navigation-tabs-button/sdds-navigation-tabs-button.d.ts +7 -0
- package/dist/types/components/tabs/navigation-tabs/navigation-tabs-link/sdds-navigation-tabs-link.d.ts +13 -0
- package/dist/types/components/tabs/navigation-tabs/navigation-tabs.d.ts +25 -10
- package/dist/types/components/tabs/navigation-tabs/navigation-tabs.stories.d.ts +32 -1
- package/dist/types/components/textarea/textarea.d.ts +2 -0
- package/dist/types/components/textarea/textarea.stories.d.ts +50 -27
- package/dist/types/components/textfield/textfield.stories.d.ts +68 -47
- package/dist/types/components/toast/sdds-toast.d.ts +1 -1
- package/dist/types/components/toast/toast.stories.d.ts +8 -9
- package/dist/types/components/toggle/sdds-toggle.d.ts +4 -7
- package/dist/types/components/toggle/sdds-toggle.stories.d.ts +9 -9
- package/dist/types/components/toggle/toggle.stories.d.ts +10 -7
- package/dist/types/components/tooltip/tooltip.stories.d.ts +15 -3
- package/dist/types/components.d.ts +607 -219
- package/{dist/loader → loader}/cdn.js +1 -1
- package/{dist/loader → loader}/index.cjs.js +1 -1
- package/{dist/loader → loader}/index.d.ts +1 -1
- package/loader/index.es2017.js +3 -0
- package/{dist/loader → loader}/index.js +2 -2
- package/package.json +5 -3
- package/readme.md +23 -1
- package/dist/cjs/index-aff9d4d5.js.map +0 -1
- package/dist/cjs/sdds-breadcrumb-item.cjs.entry.js +0 -27
- package/dist/cjs/sdds-breadcrumb-item.cjs.entry.js.map +0 -1
- package/dist/cjs/sdds-inline-tab.cjs.entry.js +0 -24
- package/dist/cjs/sdds-inline-tab.cjs.entry.js.map +0 -1
- package/dist/cjs/sdds-inline-tabs-fullbleed.cjs.entry.js +0 -100
- package/dist/cjs/sdds-inline-tabs-fullbleed.cjs.entry.js.map +0 -1
- package/dist/collection/components/breadcrumb/breadcrumb-component.css +0 -30
- package/dist/collection/components/breadcrumb/breadcrumb-item/breadcrumb-item.js.map +0 -1
- package/dist/collection/components/breadcrumb/breadcrumb.js.map +0 -1
- package/dist/collection/components/tabs/inline-tabs-default/inline-tab/inline-tab.css +0 -3
- package/dist/collection/components/tabs/inline-tabs-default/inline-tab/inline-tab.js.map +0 -1
- package/dist/collection/components/tabs/inline-tabs-default/inline-tabs.css +0 -156
- package/dist/collection/components/tabs/inline-tabs-default/inline-tabs.js +0 -313
- package/dist/collection/components/tabs/inline-tabs-default/inline-tabs.js.map +0 -1
- package/dist/collection/components/tabs/inline-tabs-default/inline-tabs.stories.js +0 -72
- package/dist/collection/components/tabs/inline-tabs-default/inline-tabs.stories.js.map +0 -1
- package/dist/collection/components/tabs/inline-tabs-fullbleed/inline-tabs-fullbleed.css +0 -141
- package/dist/collection/components/tabs/inline-tabs-fullbleed/inline-tabs-fullbleed.js +0 -129
- package/dist/collection/components/tabs/inline-tabs-fullbleed/inline-tabs-fullbleed.js.map +0 -1
- package/dist/collection/components/tabs/inline-tabs-fullbleed/inline-tabs-fullbleed.stories.js +0 -47
- package/dist/collection/components/tabs/inline-tabs-fullbleed/inline-tabs-fullbleed.stories.js.map +0 -1
- package/dist/components/sdds-breadcrumb-item.js +0 -45
- package/dist/components/sdds-breadcrumb-item.js.map +0 -1
- package/dist/components/sdds-inline-tab.js +0 -42
- package/dist/components/sdds-inline-tab.js.map +0 -1
- package/dist/components/sdds-inline-tabs-fullbleed.d.ts +0 -11
- package/dist/components/sdds-inline-tabs-fullbleed.js +0 -119
- package/dist/components/sdds-inline-tabs-fullbleed.js.map +0 -1
- package/dist/components/sdds-link2.js +0 -46
- package/dist/components/sdds-link2.js.map +0 -1
- package/dist/esm/index-b21fe3b7.js.map +0 -1
- package/dist/esm/sdds-breadcrumb-item.entry.js +0 -23
- package/dist/esm/sdds-breadcrumb-item.entry.js.map +0 -1
- package/dist/esm/sdds-inline-tab.entry.js +0 -20
- package/dist/esm/sdds-inline-tab.entry.js.map +0 -1
- package/dist/esm/sdds-inline-tabs-fullbleed.entry.js +0 -96
- package/dist/esm/sdds-inline-tabs-fullbleed.entry.js.map +0 -1
- package/dist/loader/index.es2017.js +0 -3
- package/dist/node_modules/@types/jest/index.d.ts +0 -1512
- package/dist/tegel/p-0d53607f.entry.js +0 -2
- package/dist/tegel/p-0d53607f.entry.js.map +0 -1
- package/dist/tegel/p-15ae0f77.entry.js +0 -2
- package/dist/tegel/p-15ae0f77.entry.js.map +0 -1
- package/dist/tegel/p-1b74896d.js +0 -3
- package/dist/tegel/p-1dc0c48a.entry.js +0 -2
- package/dist/tegel/p-1dc0c48a.entry.js.map +0 -1
- package/dist/tegel/p-243cc1a5.entry.js.map +0 -1
- package/dist/tegel/p-24d22924.entry.js +0 -2
- package/dist/tegel/p-24d22924.entry.js.map +0 -1
- package/dist/tegel/p-26241196.entry.js +0 -2
- package/dist/tegel/p-26241196.entry.js.map +0 -1
- package/dist/tegel/p-35146934.entry.js.map +0 -1
- package/dist/tegel/p-3fcf9763.entry.js +0 -2
- package/dist/tegel/p-3fcf9763.entry.js.map +0 -1
- package/dist/tegel/p-3fd7d6ce.entry.js +0 -2
- package/dist/tegel/p-3fd7d6ce.entry.js.map +0 -1
- package/dist/tegel/p-4835650e.entry.js +0 -2
- package/dist/tegel/p-4835650e.entry.js.map +0 -1
- package/dist/tegel/p-4ee81b96.entry.js +0 -2
- package/dist/tegel/p-4ee81b96.entry.js.map +0 -1
- package/dist/tegel/p-58cfea69.entry.js +0 -2
- package/dist/tegel/p-58cfea69.entry.js.map +0 -1
- package/dist/tegel/p-591dfbcd.entry.js +0 -2
- package/dist/tegel/p-591dfbcd.entry.js.map +0 -1
- package/dist/tegel/p-5b615b67.entry.js +0 -2
- package/dist/tegel/p-5b615b67.entry.js.map +0 -1
- package/dist/tegel/p-650d5e31.entry.js +0 -2
- package/dist/tegel/p-650d5e31.entry.js.map +0 -1
- package/dist/tegel/p-7abe1300.entry.js +0 -2
- package/dist/tegel/p-7abe1300.entry.js.map +0 -1
- package/dist/tegel/p-7e41ac2c.entry.js.map +0 -1
- package/dist/tegel/p-847f81ac.entry.js.map +0 -1
- package/dist/tegel/p-991b5017.entry.js.map +0 -1
- package/dist/tegel/p-9cf4bc66.entry.js +0 -2
- package/dist/tegel/p-9cf4bc66.entry.js.map +0 -1
- package/dist/tegel/p-af6e7c14.entry.js +0 -2
- package/dist/tegel/p-af6e7c14.entry.js.map +0 -1
- package/dist/tegel/p-b65ffb92.entry.js +0 -2
- package/dist/tegel/p-b65ffb92.entry.js.map +0 -1
- package/dist/tegel/p-b72c66f3.entry.js +0 -2
- package/dist/tegel/p-b72c66f3.entry.js.map +0 -1
- package/dist/tegel/p-bd0af26a.entry.js +0 -2
- package/dist/tegel/p-bd0af26a.entry.js.map +0 -1
- package/dist/tegel/p-c037d66f.entry.js.map +0 -1
- package/dist/tegel/p-c5b3ef65.entry.js.map +0 -1
- package/dist/tegel/p-cea5bfcd.entry.js +0 -2
- package/dist/tegel/p-cea5bfcd.entry.js.map +0 -1
- package/dist/tegel/p-d3d8828b.entry.js +0 -2
- package/dist/tegel/p-d3d8828b.entry.js.map +0 -1
- package/dist/tegel/p-d42d3400.entry.js +0 -2
- package/dist/tegel/p-d42d3400.entry.js.map +0 -1
- package/dist/tegel/p-df17ed7c.entry.js +0 -2
- package/dist/tegel/p-df17ed7c.entry.js.map +0 -1
- package/dist/tegel/p-e7332a61.entry.js +0 -2
- package/dist/tegel/p-e7332a61.entry.js.map +0 -1
- package/dist/tegel/p-ef70c653.entry.js +0 -2
- package/dist/tegel/p-ef70c653.entry.js.map +0 -1
- package/dist/types/components/breadcrumb/breadcrumb-item/breadcrumb-item.d.ts +0 -9
- package/dist/types/components/tabs/inline-tabs-default/inline-tab/inline-tab.d.ts +0 -6
- package/dist/types/components/tabs/inline-tabs-default/inline-tabs.d.ts +0 -40
- package/dist/types/components/tabs/inline-tabs-fullbleed/inline-tabs-fullbleed.d.ts +0 -20
- /package/dist/tegel/{p-7d097f54.entry.js.map → p-400d74c2.entry.js.map} +0 -0
- /package/dist/tegel/{p-73ebb46d.entry.js.map → p-4499e5cd.entry.js.map} +0 -0
- /package/dist/tegel/{p-c1f9c2a8.entry.js.map → p-5dc33f45.entry.js.map} +0 -0
- /package/dist/tegel/{p-f9d14b96.entry.js.map → p-750b7e5f.entry.js.map} +0 -0
- /package/dist/tegel/{p-94c6ef69.entry.js.map → p-7991d22f.entry.js.map} +0 -0
- /package/dist/tegel/{p-c46e2117.entry.js.map → p-a2cbef2c.entry.js.map} +0 -0
- /package/dist/tegel/{p-ce848ab7.entry.js.map → p-b9b329c0.entry.js.map} +0 -0
- /package/dist/types/components/breadcrumb/{breadcrumb.d.ts → sdds-breadcrumb.d.ts} +0 -0
- /package/{dist/loader → loader}/package.json +0 -0
|
@@ -1 +1 @@
|
|
|
1
|
-
{"file":"sdds-dropdown.sdds-dropdown-option.entry.cjs.js","mappings":"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","names":["dropdownCss","h","Host"],"sources":["./src/components/dropdown/dropdown.scss?tag=sdds-dropdown&encapsulation=shadow","./src/components/dropdown/dropdown.tsx","./src/components/dropdown/dropdown.scss?tag=sdds-dropdown-option&encapsulation=shadow","./src/components/dropdown/dropdown-option/dropdown-option.tsx"],"sourcesContent":["@import '../../mixins/z-index';\n@import './dropdown-core';\n@import './dropdown-theme-vars.scss';\n@import '../../global/scania-fonts-vars.scss';\n\n@import '../checkbox/checkbox.scss';\n@import '../../mixins/box-sizing';\n\n:host,\n::slotted(*) {\n color: var(--sdds-grey-958);\n box-sizing: border-box;\n @include sdds-box-sizing;\n}\n\n:host,\n::slotted(*) {\n --sdds-dropdown-label-outside: var(--sdds-dropdown-label-outside);\n --sdds-dropdown-label-outside-text-decoration: none;\n\n font: var(--sdds-detail-02);\n letter-spacing: var(--sdds-detail-02-ls);\n color: var(--sdds-grey-958);\n box-sizing: border-box;\n}\n\n:host {\n position: relative;\n z-index: auto;\n\n &::part(dropdown-filter-disabled) {\n cursor: not-allowed;\n caret-color: transparent;\n pointer-events: none;\n color: var(--sdds-grey-400);\n border: none;\n\n &::placeholder {\n color: var(--sdds-grey-400);\n }\n }\n}\n\n.sdds-dropdown {\n position: relative;\n display: flex;\n flex-flow: column wrap;\n width: 100%;\n border: 0;\n\n &,\n * {\n box-sizing: border-box;\n }\n\n .sdds-dropdown-toggle {\n @include dropdown-wrapper;\n\n display: flex;\n align-items: center;\n\n &-lg {\n padding: 20px 16px;\n }\n\n &-md {\n padding: 16px;\n }\n\n &-sm {\n padding: 12px 16px;\n }\n\n &.sdds-dropdown-toggle-label-inside {\n &-lg {\n padding: 20px 16px 16px;\n }\n\n &-md {\n padding: 16px 16px 12px;\n }\n }\n }\n\n .sdds-dropdown-toggle--selected:not(:focus) {\n border-bottom: 1px solid var(--sdds-dropdown-border-not-focused);\n }\n\n .sdds-dropdown-arrow {\n width: 20px;\n position: absolute;\n right: 16px;\n color: inherit;\n transform: rotate(0);\n transition: transform ease 250ms;\n }\n\n .sdds-dropdown-placeholder {\n color: var(--sdds-grey-700);\n }\n\n .sdds-dropdown-label {\n display: grid;\n width: calc(100% - 25px);\n }\n\n .sdds-dropdown-label-container {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n &.sdds-dropdown.sdds-dropdown-sm {\n .sdds-dropdown-label-container--label-inside {\n padding-bottom: 12px;\n }\n }\n\n .sdds-dropdown-filter {\n border: 0;\n outline: none;\n font: var(--sdds-detail-02);\n letter-spacing: var(--sdds-detail-02-ls);\n color: var(--sdds-dropdown-link);\n width: 100%;\n background: transparent;\n\n &:focus {\n outline: none;\n }\n\n &::placeholder {\n color: var(--sdds-grey-700);\n opacity: 1;\n }\n }\n\n .sdds-dropdown-menu {\n z-index: z(dropdown);\n\n @include sdds-scrollbar;\n\n background-color: var(--sdds-dropdown-background);\n position: absolute;\n top: 100%;\n left: 0;\n min-width: 100%;\n max-height: 360px; // max 7 option items, then add scroll\n border-color: transparent;\n border-style: solid;\n border-width: 0 1px 1px;\n box-shadow: 0 2px 3px 0 rgb(0 0 0 / 10%);\n border-left-color: var(--sdds-dropdown-border);\n border-right-color: var(--sdds-dropdown-border);\n overflow-x: hidden;\n overflow-y: auto;\n transform: scaleY(0);\n transform-origin: top;\n transition: transform 250ms ease;\n }\n\n // Size lg\n &.sdds-dropdown-lg {\n .sdds-dropdown-toggle {\n height: 56px;\n }\n }\n\n // Size md\n &.sdds-dropdown-md {\n .sdds-dropdown-toggle {\n height: 48px;\n }\n }\n\n // Size sm\n &.sdds-dropdown-sm {\n .sdds-dropdown-toggle {\n height: 40px;\n }\n }\n}\n\n:host(.sdds-dropdown--open-upwards) {\n .sdds-dropdown {\n .sdds-dropdown-menu {\n top: auto;\n bottom: 100%;\n box-shadow: 0 -1px 3px 0 rgb(0 0 0 / 10%);\n transform-origin: bottom;\n }\n }\n}\n\n:host(.sdds-dropdown--open-upwards[label-position='outside']) {\n span.sdds-dropdown-menu {\n bottom: calc(100% - 24px);\n }\n}\n\n:host([disabled='true']) {\n cursor: not-allowed;\n\n .sdds-dropdown {\n .sdds-dropdown-toggle {\n pointer-events: none;\n color: var(--sdds-dropdown-option-disabled-color);\n border: none;\n padding: 0 16px;\n\n .sdds-dropdown-placeholder {\n color: var(--sdds-dropdown-placeholder);\n }\n\n .sdds-dropdown-label-inside {\n color: var(--sdds-dropdown-label-inside);\n }\n\n &:focus {\n &::before {\n content: none;\n }\n }\n }\n }\n}\n\n:host(.sdds-dropdown--error) {\n .sdds-dropdown {\n .sdds-dropdown-toggle {\n border-color: var(--sdds-negative);\n\n &:focus {\n &::before {\n border-color: var(--sdds-negative);\n }\n }\n }\n }\n\n .sdds-dropdown-helper {\n color: var(--sdds-negative);\n\n .sdds-dropdown-error-icon {\n display: flex;\n }\n }\n}\n\n// dropdown option\n:host {\n ::slotted(sdds-dropdown-option) {\n display: flex;\n padding: var(--sdds-spacing-element-16);\n background-color: var(--sdds-dropdown-background);\n border-top: 1px solid transparent;\n border-bottom: 1px solid var(--sdds-dropdown-border);\n opacity: 0;\n visibility: hidden;\n cursor: pointer;\n box-sizing: border-box;\n color: var(--sdds-dropdown-option-color);\n }\n\n ::slotted(sdds-dropdown-option:last-child) {\n border-bottom-color: transparent;\n border-bottom-left-radius: 4px;\n border-bottom-right-radius: 4px;\n }\n\n ::slotted(sdds-dropdown-option:hover),\n ::slotted(sdds-dropdown-option:focus) {\n background-color: var(--sdds-dropdown-background-hover);\n }\n\n ::slotted(sdds-dropdown-option:hover:not(:focus):not(sdds-dropdown-option.selected)) {\n background-color: var(--sdds-dropdown-background-hover);\n }\n\n ::slotted(sdds-dropdown-option:hover:focus) {\n outline: none;\n }\n\n ::slotted(sdds-dropdown-option:focus) {\n outline: 2px solid var(--sdds-blue-400);\n outline-offset: -2px;\n }\n\n ::slotted(sdds-dropdown-option.sdds-dropdown--selected),\n ::slotted(sdds-dropdown-option.selected),\n ::slotted(sdds-dropdown-option.active),\n ::slotted(sdds-dropdown-option:active) {\n background-color: var(--sdds-dropdown-background-hover);\n border-top: 1px solid var(--sdds-dropdown-border);\n border-bottom: 1px solid var(--sdds-dropdown-border);\n }\n\n ::slotted(sdds-dropdown-option.sdds-option--no-result) {\n cursor: not-allowed;\n pointer-events: none;\n }\n\n ::slotted(sdds-dropdown-option.sdds-dropdown-option-disabled),\n ::slotted(sdds-dropdown-option.selected.sdds-dropdown-option-disabled) {\n cursor: not-allowed;\n color: var(--sdds-dropdown-option-disabled-color);\n background-color: var(--sdds-dropdown-background-disabled);\n }\n}\n\n:host(.sdds-dropdown--open-upwards) {\n ::slotted(sdds-dropdown-option:first-child) {\n border-radius: 4px 4px 0 0;\n }\n\n ::slotted(sdds-dropdown-option:last-child) {\n border-radius: 0;\n border-bottom: 1px solid var(--sdds-dropdown-border);\n }\n}\n\n.sdds-option-label {\n margin: auto 0;\n display: flex;\n align-content: center;\n text-decoration: none;\n flex-grow: 2;\n}\n\n.sdds-option-checkmark {\n color: inherit;\n opacity: 0;\n transition: opacity 0.1s cubic-bezier(0.075, 0.82, 0.165, 1);\n margin-left: var(--sdds-spacing-element-16);\n\n path {\n color: var(--sdds-dropdown-option-color);\n }\n}\n\n:host([size='sm']) {\n ::slotted(sdds-dropdown-option) {\n padding: var(--sdds-spacing-element-12) var(--sdds-spacing-element-16);\n }\n}\n\n:host(.sdds-dropdown--open) {\n .sdds-dropdown {\n .sdds-dropdown-toggle {\n box-shadow: 0 -1px 3px -1px rgb(0 0 0 / 10%);\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n\n // TODO: what is this? it doesnt seem to do anything.\n &.is-filter {\n &::before {\n content: ' ';\n position: absolute;\n z-index: 2;\n bottom: 0;\n left: 0;\n width: 100%;\n border-bottom: 1px solid var(--sdds-blue-400);\n }\n }\n }\n\n .sdds-dropdown-arrow {\n transform: rotate(180deg);\n }\n\n .sdds-dropdown-menu {\n transform: scaleY(1);\n }\n }\n\n ::slotted(sdds-dropdown-option) {\n visibility: visible;\n opacity: 1;\n }\n}\n\n:host(.selected) {\n .sdds-option-checkmark {\n opacity: 1;\n }\n}\n\n.sdds-dropdown-label-inside {\n font: var(--sdds-detail-02);\n letter-spacing: var(--sdds-detail-02-ls);\n color: var(--sdds-dropdown-label-inside);\n position: absolute;\n transition: transform 250ms ease, color 200ms ease;\n width: calc(100% - 63px);\n overflow: hidden;\n text-overflow: ellipsis;\n transform: translate(0, -10px);\n font-size: 10px;\n}\n\n.sdds-dropdown-label-container.sdds-dropdown-label-container--label-inside {\n .sdds-dropdown-placeholder {\n display: block;\n padding-top: 4px;\n }\n}\n\n.sdds-dropdown-lg {\n .sdds-dropdown-label-inside {\n display: block;\n top: 16px;\n }\n}\n\n.sdds-dropdown-md {\n .sdds-dropdown-label-inside {\n display: block;\n top: 12px;\n }\n}\n\n.sdds-dropdown.sdds-dropdown-sm {\n .sdds-dropdown-label-inside {\n display: none;\n }\n}\n\n.sdds-dropdown-multiselect-result {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.sdds-option-checkbox {\n margin-right: 8px;\n}\n\n.sdds-form-label {\n display: flex;\n}\n","import {\n Component,\n h,\n Prop,\n State,\n Element,\n Listen,\n Host,\n Event,\n EventEmitter,\n Watch,\n Method,\n} from '@stencil/core';\n\n@Component({\n tag: 'sdds-dropdown',\n styleUrl: 'dropdown.scss',\n shadow: true,\n})\nexport class Dropdown {\n textInput?: HTMLInputElement;\n\n /** Set the variant of the the dropdown. */\n @Prop() modeVariant: 'primary' | 'secondary';\n\n /** Placeholder text for dropdown with no selectedLabel item */\n @Prop() placeholder: string;\n\n /** Add the value of the option as string to set it as default */\n @Prop() defaultOption: string;\n\n /** Add the value of the option as string to set it as new selected value */\n @Prop() selectedOption: string;\n\n /** Set to true for disabled states */\n @Prop() disabled: boolean;\n\n /** `Controls type of dropdown. */\n @Prop() type: 'default' | 'multiselect' | 'filter' = 'default';\n\n /** Controls the size of dropdown. 'sm', 'md' and 'lg' correct values and 'small', 'medium' and 'large' are deprecated */\n @Prop() size: 'sm' | 'md' | 'lg' | 'small' | 'medium' | 'large' = 'lg';\n\n /** Set to true to make the width following the label text length */\n @Prop() inline: boolean = false;\n\n /** Controls position of label */\n @Prop() labelPosition: 'no-label' | 'inside' | 'outside' = 'no-label';\n\n /** Label text for label inside & outside */\n @Prop() label: string;\n\n /** Support `error` state */\n @Prop() state: string = 'default';\n\n /** Add helper text in the bottom of dropdown */\n @Prop() helper: string = '';\n\n /** Direction that the dropdown will open. By default set to auto. */\n @Prop() openDirection: 'down' | 'up' | 'auto' = 'auto';\n\n @State() optionValues: Array<any> = [];\n\n @State() optionLabels: Array<any> = [];\n\n @State() open: boolean = false;\n\n @State() node: HTMLElement;\n\n @State() selectedLabel: string = '';\n\n @State() selectedValue: string = '';\n\n @State() selectedValuesArray: Array<any> = [];\n\n @State() selectedLabelsArray: Array<any> = [];\n\n @State() dropdownUniqueClass: string = '';\n\n @State() openUpwards: boolean = false;\n\n @State() dropdownMenuHeight: number = 0;\n\n @State() dropdownMenuSelector: HTMLElement;\n\n @State() listItemIndex: any = -1;\n\n @State() listItemArray: any;\n\n @Element() host: HTMLElement;\n\n componentWillLoad() {\n // If default option is set, update the default selectedLabel value\n // this.host.children is a HTMLCollection type, cannot use forEach\n this.listItemArray = Array.from(this.host.children);\n this.listItemArray.map((listItem) => {\n this.optionValues.push(listItem.value);\n this.optionLabels.push(listItem.innerText.trim());\n });\n this.setOptionFromOutside(this.defaultOption);\n\n if (this.size === 'small') {\n this.size = 'sm';\n console.warn('size=\"small\" is deprecated, use size=\"sm\" instead');\n }\n if (this.size === 'medium') {\n this.size = 'md';\n console.warn('size=\"medium\" is deprecated, use size=\"md\" instead');\n }\n if (this.size === 'large') {\n this.size = 'lg';\n console.warn('size=\"large\" is deprecated, use size=\"lg\" instead');\n }\n }\n\n setOptionFromOutside(optionValue) {\n if (optionValue) {\n this.deselectAll();\n // TODO\n // eslint-disable-next-line no-param-reassign\n optionValue = optionValue.split(',');\n for (let i = 0; i < this.host.children.length; i++) {\n // Todo - specify type\n const el: any = this.host.children[i];\n if (optionValue.includes(el.value.trim())) {\n this.selectedLabelsArray = [...this.selectedLabelsArray, el.textContent.trim()];\n this.selectedValuesArray = [...this.selectedValuesArray, el.value];\n this.selectedLabel = el.textContent;\n this.selectedValue = el.value;\n el.setAttribute('selectedLabel', 'true');\n el.setAttribute('selected', 'true');\n } else {\n el.setAttribute('selectedLabel', 'false');\n el.setAttribute('selected', 'false');\n }\n }\n }\n }\n\n @Watch('selectedOption')\n changeSelectedOption() {\n if (this.selectedValuesArray.includes(this.selectedOption)) {\n this.resetOption();\n }\n this.setOptionFromOutside(this.selectedOption);\n this.host.setAttribute('selected-option', '');\n }\n\n @Listen('click', { target: 'document' })\n handleDocClick(ev) {\n // To stop bubble click\n ev.stopPropagation();\n const target = ev ? ev.composedPath()[0] : window.event.target[0];\n if (this.node !== undefined && this.node.contains(target)) {\n if (typeof this.textInput !== 'undefined' || this.textInput === null) {\n this.textInput.focus();\n }\n } else {\n this.tabbingLabelReset();\n this.open = false;\n }\n }\n\n @Listen('keydown')\n keyListener(ev: KeyboardEvent) {\n if (!this.disabled) {\n switch (ev.key) {\n case 'ArrowDown':\n if (this.open) {\n ev.preventDefault();\n if (this.listItemIndex < this.listItemArray.length - 1) {\n this.listItemIndex++;\n } else {\n this.listItemIndex = 0;\n }\n this.listItemArray[this.listItemIndex].focus();\n }\n break;\n case 'ArrowUp':\n if (this.open) {\n ev.preventDefault();\n if (this.listItemIndex > 0) {\n this.listItemIndex--;\n } else {\n this.listItemIndex = this.listItemArray.length - 1;\n }\n this.listItemArray[this.listItemIndex].focus();\n }\n break;\n\n case 'Tab':\n this.open = false;\n break;\n\n case 'Escape':\n this.open = false;\n this.node.focus();\n break;\n\n default:\n break;\n }\n }\n }\n\n handleClick() {\n this.open = this.open === false;\n if (this.openDirection === 'auto') {\n this.dropdownMenuHeight = this.dropdownMenuSelector.offsetHeight;\n const distanceToBottom = this.host.getBoundingClientRect().top;\n const viewportHeight = window.innerHeight;\n this.openUpwards = distanceToBottom + this.dropdownMenuHeight + 57 > viewportHeight;\n // If summary of dropdown menu height and its distance to the bottom is more than viewport height, open menu upwards\n // Additional 57px is added as compensation for dropdown element own input/button height\n // It is added on handleClick due to possible dynamic injection of data when component is already rendered\n } else {\n this.openUpwards = this.openDirection === 'up';\n }\n }\n\n tabbingLabelReset() {\n if (typeof this.textInput !== 'undefined' || this.textInput === null) {\n if (!this.selectedLabel && this.selectedLabel.length <= 0) {\n this.textInput.value = '';\n this.inputSearch.emit('');\n }\n if (this.selectedLabel !== this.textInput.value) {\n this.textInput.value = this.selectedLabel;\n }\n }\n }\n\n @Listen('selectOption')\n selectOptionHandler(event: CustomEvent<any>) {\n this.open = this.type === 'multiselect';\n if (this.type !== 'multiselect') {\n this.selectedLabel = event.detail.label;\n this.selectedValue = event.detail.value;\n this.tabbingLabelReset();\n } else {\n if (this.selectedValuesArray.includes(event.detail.value)) {\n const itemIndex = this.selectedValuesArray.indexOf(event.detail.value);\n this.selectedValuesArray = this.selectedValuesArray.filter(\n (_value, index) => index !== itemIndex,\n );\n this.selectedLabelsArray = this.selectedLabelsArray.filter(\n (_value, index) => index !== itemIndex,\n );\n } else {\n this.selectedValuesArray = [...this.selectedValuesArray, event.detail.value];\n this.selectedLabelsArray = [...this.selectedLabelsArray, event.detail.label.trim()];\n }\n }\n }\n\n @Event({\n eventName: 'inputSearch',\n composed: true,\n cancelable: true,\n bubbles: true,\n })\n inputSearch: EventEmitter<any>;\n\n handleSearch(ev) {\n const searchTerm = ev.target.value;\n this.inputSearch.emit(searchTerm);\n this.open = true;\n }\n\n deselectAll() {\n this.selectedLabel = '';\n this.selectedValue = '';\n this.selectedLabelsArray = [];\n this.selectedValuesArray = [];\n this.listItemArray = this.listItemArray.map((optionItem) => ({\n ...optionItem,\n selected: false,\n }));\n }\n\n @Method() async resetOption() {\n this.deselectAll();\n this.open = false;\n\n if (this.defaultOption) {\n this.setOptionFromOutside(this.defaultOption);\n }\n }\n\n render() {\n return (\n <Host\n class={`\n ${this.modeVariant ? `sdds-mode-variant-${this.modeVariant}` : ''}\n ${this.open && !this.disabled ? 'sdds-dropdown--open' : ''}\n ${this.type === 'multiselect' ? 'sdds-dropdown-multiselect' : ''}\n ${this.inline ? 'sdds-dropdown-inline' : ''}\n ${\n this.selectedLabel.length > 0 || this.selectedLabel === ''\n ? 'sdds-dropdown--selected'\n : ''\n }\n ${this.state === 'error' ? 'sdds-dropdown--error' : ''}\n ${this.openUpwards ? 'sdds-dropdown--open-upwards' : ''}\n ${\n this.labelPosition === 'inside' && this.selectedLabelsArray.length > 0\n ? 'sdds-dropdown--label-inside-position'\n : ''\n }\n `}\n selected-value={this.selectedValue}\n selected-text={this.selectedLabel}\n multi-selected-values={JSON.stringify(this.selectedValuesArray)}\n multi-selected-labels={JSON.stringify(this.selectedLabelsArray)}\n >\n <span class={`sdds-dropdown sdds-dropdown-${this.size}`}>\n {this.labelPosition === 'outside' && this.label.length > 0 ? (\n <span class=\"sdds-dropdown-label-outside\">{this.label}</span>\n ) : (\n ''\n )}\n <button\n part={this.disabled ? 'dropdown-filter-disabled' : ''}\n disabled={this.disabled}\n tabindex={this.disabled ? '-1' : null}\n class={`sdds-dropdown-toggle ${this.selectedValue === 'filter' ? 'is-filter' : ''} ${\n this.selectedValue !== '' || this.selectedLabelsArray.length > 0\n ? 'sdds-dropdown-toggle--selected'\n : ''\n }\n ${\n this.labelPosition === 'inside' && this.selectedValue !== '' && this.size !== 'sm'\n ? `sdds-dropdown-toggle-label-inside-${this.size}`\n : `sdds-dropdown-toggle-${this.size}`\n }`}\n type=\"button\"\n onClick={() => this.handleClick()}\n ref={(node) => (this.node = node)}\n >\n <span class=\"sdds-dropdown-label\">\n {this.type === 'filter' ? (\n <input\n part={this.disabled ? 'dropdown-filter-disabled' : ''}\n disabled={this.disabled}\n tabindex=\"-1\"\n ref={(inputEl) => (this.textInput = inputEl as HTMLInputElement)}\n class=\"sdds-dropdown-filter\"\n type=\"text\"\n placeholder={this.placeholder}\n value={this.selectedLabel}\n onInput={(event) => this.handleSearch(event)}\n autoComplete=\"off\"\n />\n ) : (\n <span\n class={{\n 'sdds-dropdown-label-container': true,\n 'sdds-dropdown-label-container--label-inside':\n this.labelPosition === 'inside' &&\n this.size !== 'sm' &&\n (this.selectedLabel.length > 0 || this.selectedLabelsArray.length > 0),\n }}\n >\n {this.size !== 'sm' &&\n (this.selectedLabel.length > 0 || this.selectedLabelsArray.length > 0) &&\n this.labelPosition === 'inside' &&\n this.label.length > 0 && (\n <span class=\"sdds-dropdown-label-inside\">{this.label}</span>\n )}\n <span\n class={`sdds-dropdown-label-main ${\n (this.selectedLabel.length === 0 ||\n (this.labelPosition === 'inside' && this.label.length < 0)) &&\n 'sdds-dropdown-placeholder'\n }`}\n >\n {this.selectedLabel.length > 0 &&\n this.type !== 'multiselect' &&\n this.selectedLabel}\n\n {this.type === 'multiselect' && (\n <span class=\"sdds-dropdown-multiselect-result\">\n {this.labelPosition !== 'inside' &&\n this.selectedLabelsArray.toString().length < 1 &&\n this.placeholder}\n {this.selectedLabelsArray.toString().length > 0 &&\n this.selectedLabelsArray.toString().split(',').join(', ')}\n </span>\n )}\n {!this.selectedLabel &&\n this.labelPosition === 'inside' &&\n this.size !== 'sm' &&\n this.label}\n\n {!this.selectedLabel &&\n this.type !== 'multiselect' &&\n this.labelPosition !== 'inside' &&\n this.placeholder}\n\n {!this.selectedLabel &&\n this.size === 'sm' &&\n this.labelPosition === 'inside' &&\n this.placeholder}\n </span>\n </span>\n )}\n </span>\n <svg\n class=\"sdds-dropdown-arrow\"\n width=\"12\"\n height=\"7\"\n viewBox=\"0 0 12 7\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M1 1L6 6L11 1\"\n stroke=\"currentColor\"\n stroke-width=\"1.25\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n </svg>\n </button>\n <span\n class=\"sdds-dropdown-menu\"\n // Need to have reference in order to calc height and distance from bottom\n ref={(dropdownMenu) => (this.dropdownMenuSelector = dropdownMenu)}\n >\n <slot />\n </span>\n </span>\n <p class=\"sdds-dropdown-helper\">\n <svg\n class=\"sdds-dropdown-error-icon\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 32 32\"\n >\n <path\n fill-rule=\"evenodd\"\n clip-rule=\"evenodd\"\n d=\"M16 4C9.37 4 3.996 9.374 3.996 16.004S9.371 28.007 16 28.007c6.63 0 12.004-5.374 12.004-12.003C28.004 9.374 22.629 4 16 4ZM2 16.004c0-7.732 6.268-14 14-14s14 6.268 14 14-6.268 14-14 14-14-6.268-14-14Z\"\n fill=\"currentColor\"\n />\n <path\n d=\"M14.803 14.47V10h2.376v4.47l-.352 4.295h-1.672l-.352-4.295Zm-.053 5.632h2.5v2.394h-2.5v-2.394Z\"\n fill=\"currentColor\"\n />\n </svg>\n <span>{this.helper}</span>\n </p>\n </Host>\n );\n }\n}\n","@import '../../mixins/z-index';\n@import './dropdown-core';\n@import './dropdown-theme-vars.scss';\n@import '../../global/scania-fonts-vars.scss';\n\n@import '../checkbox/checkbox.scss';\n@import '../../mixins/box-sizing';\n\n:host,\n::slotted(*) {\n color: var(--sdds-grey-958);\n box-sizing: border-box;\n @include sdds-box-sizing;\n}\n\n:host,\n::slotted(*) {\n --sdds-dropdown-label-outside: var(--sdds-dropdown-label-outside);\n --sdds-dropdown-label-outside-text-decoration: none;\n\n font: var(--sdds-detail-02);\n letter-spacing: var(--sdds-detail-02-ls);\n color: var(--sdds-grey-958);\n box-sizing: border-box;\n}\n\n:host {\n position: relative;\n z-index: auto;\n\n &::part(dropdown-filter-disabled) {\n cursor: not-allowed;\n caret-color: transparent;\n pointer-events: none;\n color: var(--sdds-grey-400);\n border: none;\n\n &::placeholder {\n color: var(--sdds-grey-400);\n }\n }\n}\n\n.sdds-dropdown {\n position: relative;\n display: flex;\n flex-flow: column wrap;\n width: 100%;\n border: 0;\n\n &,\n * {\n box-sizing: border-box;\n }\n\n .sdds-dropdown-toggle {\n @include dropdown-wrapper;\n\n display: flex;\n align-items: center;\n\n &-lg {\n padding: 20px 16px;\n }\n\n &-md {\n padding: 16px;\n }\n\n &-sm {\n padding: 12px 16px;\n }\n\n &.sdds-dropdown-toggle-label-inside {\n &-lg {\n padding: 20px 16px 16px;\n }\n\n &-md {\n padding: 16px 16px 12px;\n }\n }\n }\n\n .sdds-dropdown-toggle--selected:not(:focus) {\n border-bottom: 1px solid var(--sdds-dropdown-border-not-focused);\n }\n\n .sdds-dropdown-arrow {\n width: 20px;\n position: absolute;\n right: 16px;\n color: inherit;\n transform: rotate(0);\n transition: transform ease 250ms;\n }\n\n .sdds-dropdown-placeholder {\n color: var(--sdds-grey-700);\n }\n\n .sdds-dropdown-label {\n display: grid;\n width: calc(100% - 25px);\n }\n\n .sdds-dropdown-label-container {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n &.sdds-dropdown.sdds-dropdown-sm {\n .sdds-dropdown-label-container--label-inside {\n padding-bottom: 12px;\n }\n }\n\n .sdds-dropdown-filter {\n border: 0;\n outline: none;\n font: var(--sdds-detail-02);\n letter-spacing: var(--sdds-detail-02-ls);\n color: var(--sdds-dropdown-link);\n width: 100%;\n background: transparent;\n\n &:focus {\n outline: none;\n }\n\n &::placeholder {\n color: var(--sdds-grey-700);\n opacity: 1;\n }\n }\n\n .sdds-dropdown-menu {\n z-index: z(dropdown);\n\n @include sdds-scrollbar;\n\n background-color: var(--sdds-dropdown-background);\n position: absolute;\n top: 100%;\n left: 0;\n min-width: 100%;\n max-height: 360px; // max 7 option items, then add scroll\n border-color: transparent;\n border-style: solid;\n border-width: 0 1px 1px;\n box-shadow: 0 2px 3px 0 rgb(0 0 0 / 10%);\n border-left-color: var(--sdds-dropdown-border);\n border-right-color: var(--sdds-dropdown-border);\n overflow-x: hidden;\n overflow-y: auto;\n transform: scaleY(0);\n transform-origin: top;\n transition: transform 250ms ease;\n }\n\n // Size lg\n &.sdds-dropdown-lg {\n .sdds-dropdown-toggle {\n height: 56px;\n }\n }\n\n // Size md\n &.sdds-dropdown-md {\n .sdds-dropdown-toggle {\n height: 48px;\n }\n }\n\n // Size sm\n &.sdds-dropdown-sm {\n .sdds-dropdown-toggle {\n height: 40px;\n }\n }\n}\n\n:host(.sdds-dropdown--open-upwards) {\n .sdds-dropdown {\n .sdds-dropdown-menu {\n top: auto;\n bottom: 100%;\n box-shadow: 0 -1px 3px 0 rgb(0 0 0 / 10%);\n transform-origin: bottom;\n }\n }\n}\n\n:host(.sdds-dropdown--open-upwards[label-position='outside']) {\n span.sdds-dropdown-menu {\n bottom: calc(100% - 24px);\n }\n}\n\n:host([disabled='true']) {\n cursor: not-allowed;\n\n .sdds-dropdown {\n .sdds-dropdown-toggle {\n pointer-events: none;\n color: var(--sdds-dropdown-option-disabled-color);\n border: none;\n padding: 0 16px;\n\n .sdds-dropdown-placeholder {\n color: var(--sdds-dropdown-placeholder);\n }\n\n .sdds-dropdown-label-inside {\n color: var(--sdds-dropdown-label-inside);\n }\n\n &:focus {\n &::before {\n content: none;\n }\n }\n }\n }\n}\n\n:host(.sdds-dropdown--error) {\n .sdds-dropdown {\n .sdds-dropdown-toggle {\n border-color: var(--sdds-negative);\n\n &:focus {\n &::before {\n border-color: var(--sdds-negative);\n }\n }\n }\n }\n\n .sdds-dropdown-helper {\n color: var(--sdds-negative);\n\n .sdds-dropdown-error-icon {\n display: flex;\n }\n }\n}\n\n// dropdown option\n:host {\n ::slotted(sdds-dropdown-option) {\n display: flex;\n padding: var(--sdds-spacing-element-16);\n background-color: var(--sdds-dropdown-background);\n border-top: 1px solid transparent;\n border-bottom: 1px solid var(--sdds-dropdown-border);\n opacity: 0;\n visibility: hidden;\n cursor: pointer;\n box-sizing: border-box;\n color: var(--sdds-dropdown-option-color);\n }\n\n ::slotted(sdds-dropdown-option:last-child) {\n border-bottom-color: transparent;\n border-bottom-left-radius: 4px;\n border-bottom-right-radius: 4px;\n }\n\n ::slotted(sdds-dropdown-option:hover),\n ::slotted(sdds-dropdown-option:focus) {\n background-color: var(--sdds-dropdown-background-hover);\n }\n\n ::slotted(sdds-dropdown-option:hover:not(:focus):not(sdds-dropdown-option.selected)) {\n background-color: var(--sdds-dropdown-background-hover);\n }\n\n ::slotted(sdds-dropdown-option:hover:focus) {\n outline: none;\n }\n\n ::slotted(sdds-dropdown-option:focus) {\n outline: 2px solid var(--sdds-blue-400);\n outline-offset: -2px;\n }\n\n ::slotted(sdds-dropdown-option.sdds-dropdown--selected),\n ::slotted(sdds-dropdown-option.selected),\n ::slotted(sdds-dropdown-option.active),\n ::slotted(sdds-dropdown-option:active) {\n background-color: var(--sdds-dropdown-background-hover);\n border-top: 1px solid var(--sdds-dropdown-border);\n border-bottom: 1px solid var(--sdds-dropdown-border);\n }\n\n ::slotted(sdds-dropdown-option.sdds-option--no-result) {\n cursor: not-allowed;\n pointer-events: none;\n }\n\n ::slotted(sdds-dropdown-option.sdds-dropdown-option-disabled),\n ::slotted(sdds-dropdown-option.selected.sdds-dropdown-option-disabled) {\n cursor: not-allowed;\n color: var(--sdds-dropdown-option-disabled-color);\n background-color: var(--sdds-dropdown-background-disabled);\n }\n}\n\n:host(.sdds-dropdown--open-upwards) {\n ::slotted(sdds-dropdown-option:first-child) {\n border-radius: 4px 4px 0 0;\n }\n\n ::slotted(sdds-dropdown-option:last-child) {\n border-radius: 0;\n border-bottom: 1px solid var(--sdds-dropdown-border);\n }\n}\n\n.sdds-option-label {\n margin: auto 0;\n display: flex;\n align-content: center;\n text-decoration: none;\n flex-grow: 2;\n}\n\n.sdds-option-checkmark {\n color: inherit;\n opacity: 0;\n transition: opacity 0.1s cubic-bezier(0.075, 0.82, 0.165, 1);\n margin-left: var(--sdds-spacing-element-16);\n\n path {\n color: var(--sdds-dropdown-option-color);\n }\n}\n\n:host([size='sm']) {\n ::slotted(sdds-dropdown-option) {\n padding: var(--sdds-spacing-element-12) var(--sdds-spacing-element-16);\n }\n}\n\n:host(.sdds-dropdown--open) {\n .sdds-dropdown {\n .sdds-dropdown-toggle {\n box-shadow: 0 -1px 3px -1px rgb(0 0 0 / 10%);\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n\n // TODO: what is this? it doesnt seem to do anything.\n &.is-filter {\n &::before {\n content: ' ';\n position: absolute;\n z-index: 2;\n bottom: 0;\n left: 0;\n width: 100%;\n border-bottom: 1px solid var(--sdds-blue-400);\n }\n }\n }\n\n .sdds-dropdown-arrow {\n transform: rotate(180deg);\n }\n\n .sdds-dropdown-menu {\n transform: scaleY(1);\n }\n }\n\n ::slotted(sdds-dropdown-option) {\n visibility: visible;\n opacity: 1;\n }\n}\n\n:host(.selected) {\n .sdds-option-checkmark {\n opacity: 1;\n }\n}\n\n.sdds-dropdown-label-inside {\n font: var(--sdds-detail-02);\n letter-spacing: var(--sdds-detail-02-ls);\n color: var(--sdds-dropdown-label-inside);\n position: absolute;\n transition: transform 250ms ease, color 200ms ease;\n width: calc(100% - 63px);\n overflow: hidden;\n text-overflow: ellipsis;\n transform: translate(0, -10px);\n font-size: 10px;\n}\n\n.sdds-dropdown-label-container.sdds-dropdown-label-container--label-inside {\n .sdds-dropdown-placeholder {\n display: block;\n padding-top: 4px;\n }\n}\n\n.sdds-dropdown-lg {\n .sdds-dropdown-label-inside {\n display: block;\n top: 16px;\n }\n}\n\n.sdds-dropdown-md {\n .sdds-dropdown-label-inside {\n display: block;\n top: 12px;\n }\n}\n\n.sdds-dropdown.sdds-dropdown-sm {\n .sdds-dropdown-label-inside {\n display: none;\n }\n}\n\n.sdds-dropdown-multiselect-result {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.sdds-option-checkbox {\n margin-right: 8px;\n}\n\n.sdds-form-label {\n display: flex;\n}\n","import {\n Component,\n h,\n Prop,\n State,\n Element,\n Host,\n Event,\n EventEmitter,\n Listen,\n} from '@stencil/core';\n\n@Component({\n tag: 'sdds-dropdown-option',\n styleUrl: './../dropdown.scss',\n shadow: true,\n})\nexport class DropdownOption {\n @Element() host: HTMLElement;\n\n // Used as a fallback if value prop is not recognized to match handleClick\n @State() innerValue: string;\n\n /** Selected set to true if selected */\n @Prop() selected: boolean = false;\n\n /** Sets option to disabled state if true */\n @Prop() disabled: boolean = false;\n\n /** Value is a unique string that will be used for application logic */\n @Prop({ reflect: true }) value: string;\n\n @Event({\n eventName: 'selectOption',\n composed: true,\n cancelable: true,\n bubbles: true,\n })\n selectOption: EventEmitter<any>;\n\n isMultiSelectOption: boolean;\n\n @Listen('mouseover')\n changeFocusHandler() {\n this.host.focus();\n }\n\n @Listen('mouseout')\n removeFocusHandler() {\n this.host.blur();\n }\n\n @Listen('keydown')\n onKeyDown(event: KeyboardEvent) {\n if (event.code === 'Enter') {\n this.selectOptionHandler({\n value: this.value,\n label: this.host.innerText,\n parent: this.host.parentNode,\n });\n }\n }\n\n componentWillLoad() {\n this.innerValue = this.value;\n this.isMultiSelectOption = this.host\n .closest('sdds-dropdown')\n .classList.contains('sdds-dropdown-multiselect');\n }\n\n selectOptionHandler(value) {\n if (!this.disabled) {\n const listOptions = value.parent.childNodes;\n this.selectOption.emit(value);\n if (!this.isMultiSelectOption) {\n listOptions.forEach((optionEl) => {\n // TODO: fix and enable rule\n // eslint-disable-next-line no-param-reassign\n optionEl.selected = false;\n });\n }\n const optionCheckbox = this.host.shadowRoot.querySelector('input');\n\n if (this.selected) {\n this.selected = false;\n if (optionCheckbox) {\n optionCheckbox.checked = false;\n }\n } else {\n this.selected = true;\n if (optionCheckbox) {\n optionCheckbox.checked = true;\n }\n }\n }\n }\n\n render() {\n return (\n <Host\n onClick={(ev) => {\n if (this.isMultiSelectOption) {\n ev.stopPropagation();\n }\n return this.selectOptionHandler({\n value: this.value,\n label: this.host.innerText,\n parent: ev.target.parentNode,\n });\n }}\n class={{\n 'selected': this.selected,\n 'sdds-dropdown-option-disabled': this.disabled,\n }}\n tabindex=\"-1\"\n aria-disabled={this.disabled}\n >\n {this.isMultiSelectOption && (\n <div class=\"sdds-checkbox-item sdds-option-checkbox\">\n <label class=\"sdds-form-label\">\n <input\n class=\"sdds-form-input\"\n type=\"checkbox\"\n checked={this.selected}\n disabled={this.disabled}\n />\n </label>\n </div>\n )}\n <span class=\"sdds-option-label\">\n <slot />\n </span>\n {!this.isMultiSelectOption && (\n <span class=\"sdds-option-checkmark\">\n <svg\n width=\"10\"\n height=\"7\"\n viewBox=\"0 0 10 7\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M1 3L4 6L9 1\"\n stroke=\"currentColor\"\n stroke-width=\"1.25\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n </svg>\n </span>\n )}\n </Host>\n );\n }\n}\n"],"version":3}
|
|
1
|
+
{"file":"sdds-dropdown.sdds-dropdown-option.entry.cjs.js","mappings":"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","names":["dropdownCss","h","Host"],"sources":["./src/components/dropdown/dropdown.scss?tag=sdds-dropdown&encapsulation=shadow","./src/components/dropdown/dropdown.tsx","./src/components/dropdown/dropdown.scss?tag=sdds-dropdown-option&encapsulation=shadow","./src/components/dropdown/dropdown-option/dropdown-option.tsx"],"sourcesContent":["@import '../../mixins/z-index';\n@import './dropdown-core';\n@import '../../global/scania-fonts-vars.scss';\n\n@import '../checkbox/checkbox.scss';\n@import '../../mixins/box-sizing';\n\n:host,\n::slotted(*) {\n color: var(--sdds-grey-958);\n box-sizing: border-box;\n @include sdds-box-sizing;\n}\n\n:host,\n::slotted(*) {\n --sdds-dropdown-label-outside: var(--sdds-dropdown-label-outside);\n --sdds-dropdown-label-outside-text-decoration: none;\n\n font: var(--sdds-detail-02);\n letter-spacing: var(--sdds-detail-02-ls);\n color: var(--sdds-grey-958);\n box-sizing: border-box;\n}\n\n:host {\n position: relative;\n z-index: auto;\n\n &::part(dropdown-filter-disabled) {\n cursor: not-allowed;\n caret-color: transparent;\n pointer-events: none;\n color: var(--sdds-dropdown-disabled);\n border: none;\n\n &::placeholder {\n color: var(--sdds-dropdown-disabled);\n }\n }\n}\n\n.sdds-dropdown {\n position: relative;\n display: flex;\n flex-flow: column wrap;\n width: 100%;\n border: 0;\n\n &,\n * {\n box-sizing: border-box;\n }\n\n .sdds-dropdown-toggle {\n @include dropdown-wrapper;\n\n display: flex;\n align-items: center;\n\n &-lg {\n padding: 20px 16px;\n }\n\n &-md {\n padding: 16px;\n }\n\n &-sm {\n padding: 12px 16px;\n }\n\n &.sdds-dropdown-toggle-label-inside {\n &-lg {\n padding: 20px 16px 16px;\n }\n\n &-md {\n padding: 16px 16px 12px;\n }\n }\n }\n\n .sdds-dropdown-toggle--selected:not(:focus) {\n border-bottom: 1px solid var(--sdds-dropdown-border-not-focused);\n }\n\n .sdds-dropdown-arrow {\n width: 20px;\n position: absolute;\n right: 16px;\n color: inherit;\n transform: rotate(0);\n transition: transform ease 250ms;\n }\n\n .sdds-dropdown-placeholder {\n color: var(--sdds-grey-700);\n }\n\n .sdds-dropdown-label {\n display: grid;\n width: calc(100% - 25px);\n }\n\n .sdds-dropdown-label-container {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n &.sdds-dropdown.sdds-dropdown-sm {\n .sdds-dropdown-label-container--label-inside {\n padding-bottom: 12px;\n }\n }\n\n .sdds-dropdown-filter {\n border: 0;\n outline: none;\n font: var(--sdds-detail-02);\n letter-spacing: var(--sdds-detail-02-ls);\n color: var(--sdds-dropdown-link);\n width: 100%;\n background: transparent;\n\n &:focus {\n outline: none;\n }\n\n &::placeholder {\n color: var(--sdds-grey-700);\n opacity: 1;\n }\n }\n\n .sdds-dropdown-menu {\n z-index: z(dropdown);\n\n @include sdds-scrollbar;\n\n background-color: var(--sdds-dropdown-background);\n position: absolute;\n top: 100%;\n left: 0;\n min-width: 100%;\n max-height: 360px; // max 7 option items, then add scroll\n border-color: transparent;\n border-style: solid;\n border-width: 0 1px 1px;\n box-shadow: 0 2px 3px 0 rgb(0 0 0 / 10%);\n border-left-color: var(--sdds-dropdown-border);\n border-right-color: var(--sdds-dropdown-border);\n overflow-x: hidden;\n overflow-y: auto;\n transform: scaleY(0);\n transform-origin: top;\n transition: transform 250ms ease;\n }\n\n // Size lg\n &.sdds-dropdown-lg {\n .sdds-dropdown-toggle {\n height: 56px;\n }\n }\n\n // Size md\n &.sdds-dropdown-md {\n .sdds-dropdown-toggle {\n height: 48px;\n }\n }\n\n // Size sm\n &.sdds-dropdown-sm {\n .sdds-dropdown-toggle {\n height: 40px;\n }\n }\n}\n\n:host(.sdds-dropdown--open-upwards) {\n .sdds-dropdown {\n .sdds-dropdown-menu {\n top: auto;\n bottom: 100%;\n box-shadow: 0 -1px 3px 0 rgb(0 0 0 / 10%);\n transform-origin: bottom;\n }\n }\n}\n\n:host(.sdds-dropdown--open-upwards[label-position='outside']) {\n span.sdds-dropdown-menu {\n bottom: calc(100% - 24px);\n }\n}\n\n:host([disabled='true']) {\n cursor: not-allowed;\n\n .sdds-dropdown {\n .sdds-dropdown-toggle {\n pointer-events: none;\n color: var(--sdds-dropdown-option-disabled-color);\n border: none;\n padding: 0 16px;\n\n .sdds-dropdown-placeholder {\n color: var(--sdds-dropdown-placeholder);\n }\n\n .sdds-dropdown-label-inside {\n color: var(--sdds-dropdown-label-inside);\n }\n\n &:focus {\n &::before {\n content: none;\n }\n }\n }\n }\n}\n\n:host(.sdds-dropdown--error) {\n .sdds-dropdown {\n .sdds-dropdown-toggle {\n border-color: var(--sdds-negative);\n\n &:focus {\n &::before {\n border-color: var(--sdds-negative);\n }\n }\n }\n }\n\n .sdds-dropdown-helper {\n color: var(--sdds-negative);\n\n .sdds-dropdown-error-icon {\n display: flex;\n }\n }\n}\n\n// dropdown option\n:host {\n ::slotted(sdds-dropdown-option) {\n display: flex;\n padding: var(--sdds-spacing-element-16);\n background-color: var(--sdds-dropdown-background);\n border-top: 1px solid transparent;\n border-bottom: 1px solid var(--sdds-dropdown-border);\n opacity: 0;\n visibility: hidden;\n cursor: pointer;\n box-sizing: border-box;\n color: var(--sdds-dropdown-option-color);\n }\n\n ::slotted(sdds-dropdown-option:last-child) {\n border-bottom-color: transparent;\n border-bottom-left-radius: 4px;\n border-bottom-right-radius: 4px;\n }\n\n ::slotted(sdds-dropdown-option:hover),\n ::slotted(sdds-dropdown-option:focus) {\n background-color: var(--sdds-dropdown-background-hover);\n }\n\n ::slotted(sdds-dropdown-option:hover:not(:focus):not(sdds-dropdown-option.selected)) {\n background-color: var(--sdds-dropdown-background-hover);\n }\n\n ::slotted(sdds-dropdown-option:hover:focus) {\n outline: none;\n }\n\n ::slotted(sdds-dropdown-option:focus) {\n outline: 2px solid var(--sdds-blue-400);\n outline-offset: -2px;\n }\n\n ::slotted(sdds-dropdown-option.sdds-dropdown--selected),\n ::slotted(sdds-dropdown-option.selected),\n ::slotted(sdds-dropdown-option.active),\n ::slotted(sdds-dropdown-option:active) {\n background-color: var(--sdds-dropdown-background-hover);\n border-top: 1px solid var(--sdds-dropdown-border);\n border-bottom: 1px solid var(--sdds-dropdown-border);\n }\n\n ::slotted(sdds-dropdown-option.sdds-option--no-result) {\n cursor: not-allowed;\n pointer-events: none;\n }\n\n ::slotted(sdds-dropdown-option.sdds-dropdown-option-disabled),\n ::slotted(sdds-dropdown-option.selected.sdds-dropdown-option-disabled) {\n cursor: not-allowed;\n color: var(--sdds-dropdown-option-disabled-color);\n background-color: var(--sdds-dropdown-background-disabled);\n }\n}\n\n:host(.sdds-dropdown--open-upwards) {\n ::slotted(sdds-dropdown-option:first-child) {\n border-radius: 4px 4px 0 0;\n }\n\n ::slotted(sdds-dropdown-option:last-child) {\n border-radius: 0;\n border-bottom: 1px solid var(--sdds-dropdown-border);\n }\n}\n\n.sdds-option-label {\n margin: auto 0;\n display: flex;\n align-content: center;\n text-decoration: none;\n flex-grow: 2;\n}\n\n.sdds-option-checkmark {\n color: inherit;\n opacity: 0;\n transition: opacity 0.1s cubic-bezier(0.075, 0.82, 0.165, 1);\n margin-left: var(--sdds-spacing-element-16);\n\n path {\n color: var(--sdds-dropdown-option-color);\n }\n}\n\n:host([size='sm']) {\n ::slotted(sdds-dropdown-option) {\n padding: var(--sdds-spacing-element-12) var(--sdds-spacing-element-16);\n }\n}\n\n:host(.sdds-dropdown--open) {\n .sdds-dropdown {\n .sdds-dropdown-toggle {\n box-shadow: 0 -1px 3px -1px rgb(0 0 0 / 10%);\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n\n // TODO: what is this? it doesnt seem to do anything.\n &.is-filter {\n &::before {\n content: ' ';\n position: absolute;\n z-index: 2;\n bottom: 0;\n left: 0;\n width: 100%;\n border-bottom: 1px solid var(--sdds-blue-400);\n }\n }\n }\n\n .sdds-dropdown-arrow {\n transform: rotate(180deg);\n }\n\n .sdds-dropdown-menu {\n transform: scaleY(1);\n }\n }\n\n ::slotted(sdds-dropdown-option) {\n visibility: visible;\n opacity: 1;\n }\n}\n\n:host(.selected) {\n .sdds-option-checkmark {\n opacity: 1;\n }\n}\n\n.sdds-dropdown-label-inside {\n font: var(--sdds-detail-02);\n letter-spacing: var(--sdds-detail-02-ls);\n color: var(--sdds-dropdown-label-inside);\n position: absolute;\n transition: transform 250ms ease, color 200ms ease;\n width: calc(100% - 63px);\n overflow: hidden;\n text-overflow: ellipsis;\n transform: translate(0, -10px);\n font-size: 10px;\n}\n\n.sdds-dropdown-label-container.sdds-dropdown-label-container--label-inside {\n .sdds-dropdown-placeholder {\n display: block;\n padding-top: 4px;\n }\n}\n\n.sdds-dropdown-lg {\n .sdds-dropdown-label-inside {\n display: block;\n top: 16px;\n }\n}\n\n.sdds-dropdown-md {\n .sdds-dropdown-label-inside {\n display: block;\n top: 12px;\n }\n}\n\n.sdds-dropdown.sdds-dropdown-sm {\n .sdds-dropdown-label-inside {\n display: none;\n }\n}\n\n.sdds-dropdown-multiselect-result {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.sdds-option-checkbox {\n margin-right: 8px;\n}\n\n.sdds-form-label {\n display: flex;\n}\n","import {\n Component,\n h,\n Prop,\n State,\n Element,\n Listen,\n Host,\n Event,\n EventEmitter,\n Watch,\n Method,\n} from '@stencil/core';\n\n@Component({\n tag: 'sdds-dropdown',\n styleUrl: 'dropdown.scss',\n shadow: true,\n})\nexport class Dropdown {\n textInput?: HTMLInputElement;\n\n /** Set the variant of the dropdown. */\n @Prop() modeVariant: 'primary' | 'secondary' = null;\n\n /** Placeholder text for dropdown with no selectedLabel item */\n @Prop() placeholder: string;\n\n /** Add the value of the option as string to set it as default */\n @Prop() defaultOption: string;\n\n /** Add the value of the option as string to set it as new selected value */\n @Prop() selectedOption: string;\n\n /** Set to true for disabled states */\n @Prop() disabled: boolean = false;\n\n /** `Controls type of dropdown. */\n @Prop() type: 'default' | 'multiselect' | 'filter' = 'default';\n\n /** Controls the size of dropdown. 'sm', 'md' and 'lg' correct values and 'small', 'medium' and 'large' are deprecated */\n @Prop() size: 'sm' | 'md' | 'lg' | 'small' | 'medium' | 'large' = 'lg';\n\n /** Set to true to make the width following the label text length */\n @Prop() inline: boolean = false;\n\n /** Controls position of label */\n @Prop() labelPosition: 'no-label' | 'inside' | 'outside' = 'no-label';\n\n /** Label text for label inside & outside */\n @Prop() label: string;\n\n /** Support `error` state */\n @Prop() state: boolean = false;\n\n /** Add helper text in the bottom of dropdown */\n @Prop() helper: string = '';\n\n /** Direction that the dropdown will open. Default is auto. */\n @Prop() openDirection: 'down' | 'up' | 'auto' = 'auto';\n\n @State() optionValues: Array<any> = [];\n\n @State() optionLabels: Array<any> = [];\n\n @State() open: boolean = false;\n\n @State() node: HTMLElement;\n\n @State() selectedLabel: string = '';\n\n @State() selectedValue: string = '';\n\n @State() selectedValuesArray: Array<any> = [];\n\n @State() selectedLabelsArray: Array<any> = [];\n\n @State() dropdownUniqueClass: string = '';\n\n @State() openUpwards: boolean = false;\n\n @State() dropdownMenuHeight: number = 0;\n\n @State() dropdownMenuSelector: HTMLElement;\n\n @State() listItemIndex: any = -1;\n\n @State() listItemArray: any;\n\n @State() listItemObject: any;\n\n @Element() host: HTMLElement;\n\n componentWillLoad() {\n // If default option is set, update the default selectedLabel value\n // this.host.children is a HTMLCollection type, cannot use forEach\n this.listItemObject = this.host.children;\n this.listItemArray = Array.from(this.listItemObject);\n this.listItemArray.map((listItem) => {\n this.optionValues.push(listItem.value);\n this.optionLabels.push(listItem.innerText.trim());\n });\n this.setOptionFromOutside(this.defaultOption);\n\n if (this.size === 'small') {\n this.size = 'sm';\n console.warn('size=\"small\" is deprecated, use size=\"sm\" instead');\n }\n if (this.size === 'medium') {\n this.size = 'md';\n console.warn('size=\"medium\" is deprecated, use size=\"md\" instead');\n }\n if (this.size === 'large') {\n this.size = 'lg';\n console.warn('size=\"large\" is deprecated, use size=\"lg\" instead');\n }\n }\n\n setOptionFromOutside(optionValue) {\n if (optionValue) {\n this.deselectAll();\n // TODO\n // eslint-disable-next-line no-param-reassign\n optionValue = optionValue.split(',');\n for (let i = 0; i < this.host.children.length; i++) {\n // Todo - specify type\n const el: any = this.host.children[i];\n if (optionValue.includes(el.value.trim())) {\n this.selectedLabelsArray = [...this.selectedLabelsArray, el.textContent.trim()];\n this.selectedValuesArray = [...this.selectedValuesArray, el.value];\n this.selectedLabel = el.textContent;\n this.selectedValue = el.value;\n el.setAttribute('selectedLabel', 'true');\n el.setAttribute('selected', 'true');\n } else {\n el.setAttribute('selectedLabel', 'false');\n el.setAttribute('selected', 'false');\n }\n }\n }\n }\n\n @Watch('selectedOption')\n changeSelectedOption() {\n if (this.selectedValuesArray.includes(this.selectedOption)) {\n this.resetOption();\n }\n this.setOptionFromOutside(this.selectedOption);\n this.host.setAttribute('selected-option', '');\n }\n\n @Listen('click', { target: 'document' })\n handleDocClick(ev) {\n // To stop bubble click\n ev.stopPropagation();\n const target = ev ? ev.composedPath()[0] : window.event.target[0];\n if (this.node !== undefined && this.node.contains(target)) {\n if (typeof this.textInput !== 'undefined' || this.textInput === null) {\n this.textInput.focus();\n }\n } else {\n this.tabbingLabelReset();\n this.open = false;\n }\n }\n\n @Listen('keydown')\n keyListener(ev: KeyboardEvent) {\n if (!this.disabled) {\n switch (ev.key) {\n case 'ArrowDown':\n if (this.open) {\n ev.preventDefault();\n if (this.listItemIndex < this.listItemArray.length - 1) {\n this.listItemIndex++;\n } else {\n this.listItemIndex = 0;\n }\n (this.listItemObject[this.listItemIndex] as HTMLElement).focus();\n }\n break;\n case 'ArrowUp':\n if (this.open) {\n ev.preventDefault();\n if (this.listItemIndex > 0) {\n this.listItemIndex--;\n } else {\n this.listItemIndex = this.listItemArray.length - 1;\n }\n (this.listItemObject[this.listItemIndex] as HTMLElement).focus();\n }\n break;\n\n case 'Tab':\n this.open = false;\n break;\n\n case 'Escape':\n this.open = false;\n this.node.focus();\n break;\n\n default:\n break;\n }\n }\n }\n\n handleClick() {\n this.open = this.open === false;\n if (this.openDirection === 'auto') {\n this.dropdownMenuHeight = this.dropdownMenuSelector.offsetHeight;\n const distanceToBottom = this.host.getBoundingClientRect().top;\n const viewportHeight = window.innerHeight;\n this.openUpwards = distanceToBottom + this.dropdownMenuHeight + 57 > viewportHeight;\n // If summary of dropdown menu height and its distance to the bottom is more than viewport height, open menu upwards\n // Additional 57px is added as compensation for dropdown element own input/button height\n // It is added on handleClick due to possible dynamic injection of data when component is already rendered\n } else {\n this.openUpwards = this.openDirection === 'up';\n }\n }\n\n tabbingLabelReset() {\n if (typeof this.textInput !== 'undefined' || this.textInput === null) {\n if (!this.selectedLabel && this.selectedLabel.length <= 0) {\n this.textInput.value = '';\n this.inputSearch.emit('');\n }\n if (this.selectedLabel !== this.textInput.value) {\n this.textInput.value = this.selectedLabel;\n }\n }\n }\n\n @Listen('internalSddsSelect')\n selectOptionHandler(event: CustomEvent<any>) {\n this.open = this.type === 'multiselect';\n if (this.type !== 'multiselect') {\n this.selectedLabel = event.detail.label;\n this.selectedValue = event.detail.value;\n this.tabbingLabelReset();\n } else {\n if (this.selectedValuesArray.includes(event.detail.value)) {\n const itemIndex = this.selectedValuesArray.indexOf(event.detail.value);\n this.selectedValuesArray = this.selectedValuesArray.filter(\n (_value, index) => index !== itemIndex,\n );\n this.selectedLabelsArray = this.selectedLabelsArray.filter(\n (_value, index) => index !== itemIndex,\n );\n } else {\n this.selectedValuesArray = [...this.selectedValuesArray, event.detail.value];\n this.selectedLabelsArray = [...this.selectedLabelsArray, event.detail.label.trim()];\n }\n }\n }\n\n @Event({\n eventName: 'inputSearch',\n composed: true,\n cancelable: true,\n bubbles: true,\n })\n inputSearch: EventEmitter<any>;\n\n handleSearch(ev) {\n const searchTerm = ev.target.value;\n this.inputSearch.emit(searchTerm);\n this.open = true;\n }\n\n deselectAll() {\n this.selectedLabel = '';\n this.selectedValue = '';\n this.selectedLabelsArray = [];\n this.selectedValuesArray = [];\n this.listItemArray = this.listItemArray.map((optionItem) => ({\n ...optionItem,\n selected: false,\n }));\n }\n\n @Method() async resetOption() {\n this.deselectAll();\n this.open = false;\n\n if (this.defaultOption) {\n this.setOptionFromOutside(this.defaultOption);\n }\n }\n\n render() {\n return (\n <Host\n class={`\n ${this.modeVariant ? `sdds-mode-variant-${this.modeVariant}` : ''}\n ${this.open && !this.disabled ? 'sdds-dropdown--open' : ''}\n ${this.type === 'multiselect' ? 'sdds-dropdown-multiselect' : ''}\n ${this.inline ? 'sdds-dropdown-inline' : ''}\n ${\n this.selectedLabel.length > 0 || this.selectedLabel === ''\n ? 'sdds-dropdown--selected'\n : ''\n }\n ${this.state ? 'sdds-dropdown--error' : ''}\n ${this.openUpwards ? 'sdds-dropdown--open-upwards' : ''}\n ${\n this.labelPosition === 'inside' && this.selectedLabelsArray.length > 0\n ? 'sdds-dropdown--label-inside-position'\n : ''\n }\n `}\n selected-value={this.selectedValue}\n selected-text={this.selectedLabel}\n multi-selected-values={JSON.stringify(this.selectedValuesArray)}\n multi-selected-labels={JSON.stringify(this.selectedLabelsArray)}\n >\n <span class={`sdds-dropdown sdds-dropdown-${this.size}`}>\n {this.labelPosition === 'outside' && this.label.length > 0 ? (\n <span class=\"sdds-dropdown-label-outside\">{this.label}</span>\n ) : (\n ''\n )}\n <button\n part={this.disabled ? 'dropdown-filter-disabled' : ''}\n disabled={this.disabled}\n tabindex={this.disabled ? '-1' : null}\n class={`sdds-dropdown-toggle ${this.selectedValue === 'filter' ? 'is-filter' : ''} ${\n this.selectedValue !== '' || this.selectedLabelsArray.length > 0\n ? 'sdds-dropdown-toggle--selected'\n : ''\n }\n ${\n this.labelPosition === 'inside' && this.selectedValue !== '' && this.size !== 'sm'\n ? `sdds-dropdown-toggle-label-inside-${this.size}`\n : `sdds-dropdown-toggle-${this.size}`\n }`}\n type=\"button\"\n onClick={() => this.handleClick()}\n ref={(node) => (this.node = node)}\n >\n <span class=\"sdds-dropdown-label\">\n {this.type === 'filter' ? (\n <input\n part={this.disabled ? 'dropdown-filter-disabled' : ''}\n disabled={this.disabled}\n tabindex=\"-1\"\n ref={(inputEl) => (this.textInput = inputEl as HTMLInputElement)}\n class=\"sdds-dropdown-filter\"\n type=\"text\"\n placeholder={this.placeholder}\n value={this.selectedLabel}\n onInput={(event) => this.handleSearch(event)}\n autoComplete=\"off\"\n />\n ) : (\n <span\n class={{\n 'sdds-dropdown-label-container': true,\n 'sdds-dropdown-label-container--label-inside':\n this.labelPosition === 'inside' &&\n this.size !== 'sm' &&\n (this.selectedLabel.length > 0 || this.selectedLabelsArray.length > 0),\n }}\n >\n {this.size !== 'sm' &&\n (this.selectedLabel.length > 0 || this.selectedLabelsArray.length > 0) &&\n this.labelPosition === 'inside' &&\n this.label.length > 0 && (\n <span class=\"sdds-dropdown-label-inside\">{this.label}</span>\n )}\n <span\n class={`sdds-dropdown-label-main ${\n (this.selectedLabel.length === 0 ||\n (this.labelPosition === 'inside' && this.label.length < 0)) &&\n 'sdds-dropdown-placeholder'\n }`}\n >\n {this.selectedLabel.length > 0 &&\n this.type !== 'multiselect' &&\n this.selectedLabel}\n\n {this.type === 'multiselect' && (\n <span class=\"sdds-dropdown-multiselect-result\">\n {this.labelPosition !== 'inside' &&\n this.selectedLabelsArray.toString().length < 1 &&\n this.placeholder}\n {this.selectedLabelsArray.toString().length > 0 &&\n this.selectedLabelsArray.toString().split(',').join(', ')}\n </span>\n )}\n {!this.selectedLabel &&\n this.labelPosition === 'inside' &&\n this.size !== 'sm' &&\n this.label}\n\n {!this.selectedLabel &&\n this.type !== 'multiselect' &&\n this.labelPosition !== 'inside' &&\n this.placeholder}\n\n {!this.selectedLabel &&\n this.size === 'sm' &&\n this.labelPosition === 'inside' &&\n this.placeholder}\n </span>\n </span>\n )}\n </span>\n <svg\n class=\"sdds-dropdown-arrow\"\n width=\"12\"\n height=\"7\"\n viewBox=\"0 0 12 7\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M1 1L6 6L11 1\"\n stroke=\"currentColor\"\n stroke-width=\"1.25\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n </svg>\n </button>\n <span\n class=\"sdds-dropdown-menu\"\n // Need to have reference in order to calc height and distance from bottom\n ref={(dropdownMenu) => (this.dropdownMenuSelector = dropdownMenu)}\n >\n <slot />\n </span>\n </span>\n <p class=\"sdds-dropdown-helper\">\n <svg\n class=\"sdds-dropdown-error-icon\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"0 0 32 32\"\n >\n <path\n fill-rule=\"evenodd\"\n clip-rule=\"evenodd\"\n d=\"M16 4C9.37 4 3.996 9.374 3.996 16.004S9.371 28.007 16 28.007c6.63 0 12.004-5.374 12.004-12.003C28.004 9.374 22.629 4 16 4ZM2 16.004c0-7.732 6.268-14 14-14s14 6.268 14 14-6.268 14-14 14-14-6.268-14-14Z\"\n fill=\"currentColor\"\n />\n <path\n d=\"M14.803 14.47V10h2.376v4.47l-.352 4.295h-1.672l-.352-4.295Zm-.053 5.632h2.5v2.394h-2.5v-2.394Z\"\n fill=\"currentColor\"\n />\n </svg>\n <span>{this.helper}</span>\n </p>\n </Host>\n );\n }\n}\n","@import '../../mixins/z-index';\n@import './dropdown-core';\n@import '../../global/scania-fonts-vars.scss';\n\n@import '../checkbox/checkbox.scss';\n@import '../../mixins/box-sizing';\n\n:host,\n::slotted(*) {\n color: var(--sdds-grey-958);\n box-sizing: border-box;\n @include sdds-box-sizing;\n}\n\n:host,\n::slotted(*) {\n --sdds-dropdown-label-outside: var(--sdds-dropdown-label-outside);\n --sdds-dropdown-label-outside-text-decoration: none;\n\n font: var(--sdds-detail-02);\n letter-spacing: var(--sdds-detail-02-ls);\n color: var(--sdds-grey-958);\n box-sizing: border-box;\n}\n\n:host {\n position: relative;\n z-index: auto;\n\n &::part(dropdown-filter-disabled) {\n cursor: not-allowed;\n caret-color: transparent;\n pointer-events: none;\n color: var(--sdds-dropdown-disabled);\n border: none;\n\n &::placeholder {\n color: var(--sdds-dropdown-disabled);\n }\n }\n}\n\n.sdds-dropdown {\n position: relative;\n display: flex;\n flex-flow: column wrap;\n width: 100%;\n border: 0;\n\n &,\n * {\n box-sizing: border-box;\n }\n\n .sdds-dropdown-toggle {\n @include dropdown-wrapper;\n\n display: flex;\n align-items: center;\n\n &-lg {\n padding: 20px 16px;\n }\n\n &-md {\n padding: 16px;\n }\n\n &-sm {\n padding: 12px 16px;\n }\n\n &.sdds-dropdown-toggle-label-inside {\n &-lg {\n padding: 20px 16px 16px;\n }\n\n &-md {\n padding: 16px 16px 12px;\n }\n }\n }\n\n .sdds-dropdown-toggle--selected:not(:focus) {\n border-bottom: 1px solid var(--sdds-dropdown-border-not-focused);\n }\n\n .sdds-dropdown-arrow {\n width: 20px;\n position: absolute;\n right: 16px;\n color: inherit;\n transform: rotate(0);\n transition: transform ease 250ms;\n }\n\n .sdds-dropdown-placeholder {\n color: var(--sdds-grey-700);\n }\n\n .sdds-dropdown-label {\n display: grid;\n width: calc(100% - 25px);\n }\n\n .sdds-dropdown-label-container {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n\n &.sdds-dropdown.sdds-dropdown-sm {\n .sdds-dropdown-label-container--label-inside {\n padding-bottom: 12px;\n }\n }\n\n .sdds-dropdown-filter {\n border: 0;\n outline: none;\n font: var(--sdds-detail-02);\n letter-spacing: var(--sdds-detail-02-ls);\n color: var(--sdds-dropdown-link);\n width: 100%;\n background: transparent;\n\n &:focus {\n outline: none;\n }\n\n &::placeholder {\n color: var(--sdds-grey-700);\n opacity: 1;\n }\n }\n\n .sdds-dropdown-menu {\n z-index: z(dropdown);\n\n @include sdds-scrollbar;\n\n background-color: var(--sdds-dropdown-background);\n position: absolute;\n top: 100%;\n left: 0;\n min-width: 100%;\n max-height: 360px; // max 7 option items, then add scroll\n border-color: transparent;\n border-style: solid;\n border-width: 0 1px 1px;\n box-shadow: 0 2px 3px 0 rgb(0 0 0 / 10%);\n border-left-color: var(--sdds-dropdown-border);\n border-right-color: var(--sdds-dropdown-border);\n overflow-x: hidden;\n overflow-y: auto;\n transform: scaleY(0);\n transform-origin: top;\n transition: transform 250ms ease;\n }\n\n // Size lg\n &.sdds-dropdown-lg {\n .sdds-dropdown-toggle {\n height: 56px;\n }\n }\n\n // Size md\n &.sdds-dropdown-md {\n .sdds-dropdown-toggle {\n height: 48px;\n }\n }\n\n // Size sm\n &.sdds-dropdown-sm {\n .sdds-dropdown-toggle {\n height: 40px;\n }\n }\n}\n\n:host(.sdds-dropdown--open-upwards) {\n .sdds-dropdown {\n .sdds-dropdown-menu {\n top: auto;\n bottom: 100%;\n box-shadow: 0 -1px 3px 0 rgb(0 0 0 / 10%);\n transform-origin: bottom;\n }\n }\n}\n\n:host(.sdds-dropdown--open-upwards[label-position='outside']) {\n span.sdds-dropdown-menu {\n bottom: calc(100% - 24px);\n }\n}\n\n:host([disabled='true']) {\n cursor: not-allowed;\n\n .sdds-dropdown {\n .sdds-dropdown-toggle {\n pointer-events: none;\n color: var(--sdds-dropdown-option-disabled-color);\n border: none;\n padding: 0 16px;\n\n .sdds-dropdown-placeholder {\n color: var(--sdds-dropdown-placeholder);\n }\n\n .sdds-dropdown-label-inside {\n color: var(--sdds-dropdown-label-inside);\n }\n\n &:focus {\n &::before {\n content: none;\n }\n }\n }\n }\n}\n\n:host(.sdds-dropdown--error) {\n .sdds-dropdown {\n .sdds-dropdown-toggle {\n border-color: var(--sdds-negative);\n\n &:focus {\n &::before {\n border-color: var(--sdds-negative);\n }\n }\n }\n }\n\n .sdds-dropdown-helper {\n color: var(--sdds-negative);\n\n .sdds-dropdown-error-icon {\n display: flex;\n }\n }\n}\n\n// dropdown option\n:host {\n ::slotted(sdds-dropdown-option) {\n display: flex;\n padding: var(--sdds-spacing-element-16);\n background-color: var(--sdds-dropdown-background);\n border-top: 1px solid transparent;\n border-bottom: 1px solid var(--sdds-dropdown-border);\n opacity: 0;\n visibility: hidden;\n cursor: pointer;\n box-sizing: border-box;\n color: var(--sdds-dropdown-option-color);\n }\n\n ::slotted(sdds-dropdown-option:last-child) {\n border-bottom-color: transparent;\n border-bottom-left-radius: 4px;\n border-bottom-right-radius: 4px;\n }\n\n ::slotted(sdds-dropdown-option:hover),\n ::slotted(sdds-dropdown-option:focus) {\n background-color: var(--sdds-dropdown-background-hover);\n }\n\n ::slotted(sdds-dropdown-option:hover:not(:focus):not(sdds-dropdown-option.selected)) {\n background-color: var(--sdds-dropdown-background-hover);\n }\n\n ::slotted(sdds-dropdown-option:hover:focus) {\n outline: none;\n }\n\n ::slotted(sdds-dropdown-option:focus) {\n outline: 2px solid var(--sdds-blue-400);\n outline-offset: -2px;\n }\n\n ::slotted(sdds-dropdown-option.sdds-dropdown--selected),\n ::slotted(sdds-dropdown-option.selected),\n ::slotted(sdds-dropdown-option.active),\n ::slotted(sdds-dropdown-option:active) {\n background-color: var(--sdds-dropdown-background-hover);\n border-top: 1px solid var(--sdds-dropdown-border);\n border-bottom: 1px solid var(--sdds-dropdown-border);\n }\n\n ::slotted(sdds-dropdown-option.sdds-option--no-result) {\n cursor: not-allowed;\n pointer-events: none;\n }\n\n ::slotted(sdds-dropdown-option.sdds-dropdown-option-disabled),\n ::slotted(sdds-dropdown-option.selected.sdds-dropdown-option-disabled) {\n cursor: not-allowed;\n color: var(--sdds-dropdown-option-disabled-color);\n background-color: var(--sdds-dropdown-background-disabled);\n }\n}\n\n:host(.sdds-dropdown--open-upwards) {\n ::slotted(sdds-dropdown-option:first-child) {\n border-radius: 4px 4px 0 0;\n }\n\n ::slotted(sdds-dropdown-option:last-child) {\n border-radius: 0;\n border-bottom: 1px solid var(--sdds-dropdown-border);\n }\n}\n\n.sdds-option-label {\n margin: auto 0;\n display: flex;\n align-content: center;\n text-decoration: none;\n flex-grow: 2;\n}\n\n.sdds-option-checkmark {\n color: inherit;\n opacity: 0;\n transition: opacity 0.1s cubic-bezier(0.075, 0.82, 0.165, 1);\n margin-left: var(--sdds-spacing-element-16);\n\n path {\n color: var(--sdds-dropdown-option-color);\n }\n}\n\n:host([size='sm']) {\n ::slotted(sdds-dropdown-option) {\n padding: var(--sdds-spacing-element-12) var(--sdds-spacing-element-16);\n }\n}\n\n:host(.sdds-dropdown--open) {\n .sdds-dropdown {\n .sdds-dropdown-toggle {\n box-shadow: 0 -1px 3px -1px rgb(0 0 0 / 10%);\n border-bottom-left-radius: 0;\n border-bottom-right-radius: 0;\n\n // TODO: what is this? it doesnt seem to do anything.\n &.is-filter {\n &::before {\n content: ' ';\n position: absolute;\n z-index: 2;\n bottom: 0;\n left: 0;\n width: 100%;\n border-bottom: 1px solid var(--sdds-blue-400);\n }\n }\n }\n\n .sdds-dropdown-arrow {\n transform: rotate(180deg);\n }\n\n .sdds-dropdown-menu {\n transform: scaleY(1);\n }\n }\n\n ::slotted(sdds-dropdown-option) {\n visibility: visible;\n opacity: 1;\n }\n}\n\n:host(.selected) {\n .sdds-option-checkmark {\n opacity: 1;\n }\n}\n\n.sdds-dropdown-label-inside {\n font: var(--sdds-detail-02);\n letter-spacing: var(--sdds-detail-02-ls);\n color: var(--sdds-dropdown-label-inside);\n position: absolute;\n transition: transform 250ms ease, color 200ms ease;\n width: calc(100% - 63px);\n overflow: hidden;\n text-overflow: ellipsis;\n transform: translate(0, -10px);\n font-size: 10px;\n}\n\n.sdds-dropdown-label-container.sdds-dropdown-label-container--label-inside {\n .sdds-dropdown-placeholder {\n display: block;\n padding-top: 4px;\n }\n}\n\n.sdds-dropdown-lg {\n .sdds-dropdown-label-inside {\n display: block;\n top: 16px;\n }\n}\n\n.sdds-dropdown-md {\n .sdds-dropdown-label-inside {\n display: block;\n top: 12px;\n }\n}\n\n.sdds-dropdown.sdds-dropdown-sm {\n .sdds-dropdown-label-inside {\n display: none;\n }\n}\n\n.sdds-dropdown-multiselect-result {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n}\n\n.sdds-option-checkbox {\n margin-right: 8px;\n}\n\n.sdds-form-label {\n display: flex;\n}\n","import {\n Component,\n h,\n Prop,\n State,\n Element,\n Host,\n Event,\n EventEmitter,\n Listen,\n} from '@stencil/core';\n\n@Component({\n tag: 'sdds-dropdown-option',\n styleUrl: './../dropdown.scss',\n shadow: true,\n})\nexport class DropdownOption {\n @Element() host: HTMLElement;\n\n // Used as a fallback if value prop is not recognized to match handleClick\n @State() innerValue: string;\n\n /** Selected set to true if selected */\n @Prop() selected: boolean = false;\n\n /** Sets option to disabled state if true */\n @Prop() disabled: boolean = false;\n\n /** Value is a unique string that will be used for application logic */\n @Prop({ reflect: true }) value: string;\n\n /** @internal Fires on click on one of the dropdown items */\n @Event({\n eventName: 'internalSddsSelect',\n composed: true,\n cancelable: false,\n bubbles: true,\n })\n internalSddsSelect: EventEmitter<{\n value: string | number;\n label: string | number;\n parent: HTMLSddsDropdownElement;\n }>;\n\n isMultiSelectOption: boolean;\n\n @Listen('mouseover')\n changeFocusHandler() {\n this.host.focus();\n }\n\n @Listen('mouseout')\n removeFocusHandler() {\n this.host.blur();\n }\n\n @Listen('keydown')\n onKeyDown(event: KeyboardEvent) {\n if (event.code === 'Enter') {\n this.handleClick({\n value: this.value,\n label: this.host.innerText,\n parent: this.host.parentNode,\n });\n }\n }\n\n componentWillLoad() {\n this.innerValue = this.value;\n this.isMultiSelectOption = this.host\n .closest('sdds-dropdown')\n .classList.contains('sdds-dropdown-multiselect');\n }\n\n handleClick(value) {\n if (!this.disabled) {\n const listOptions = value.parent.childNodes;\n this.internalSddsSelect.emit(value);\n if (!this.isMultiSelectOption) {\n listOptions.forEach((optionEl) => {\n optionEl.selected = false;\n });\n }\n const optionCheckbox = this.host.shadowRoot.querySelector('input');\n\n if (this.selected) {\n this.selected = false;\n if (optionCheckbox) {\n optionCheckbox.checked = false;\n }\n } else {\n this.selected = true;\n if (optionCheckbox) {\n optionCheckbox.checked = true;\n }\n }\n }\n }\n\n render() {\n return (\n <Host\n onClick={(event) => {\n if (this.isMultiSelectOption) {\n event.stopPropagation();\n }\n return this.handleClick({\n value: this.value,\n label: this.host.innerText,\n parent: event.target.parentNode,\n });\n }}\n class={{\n 'selected': this.selected,\n 'sdds-dropdown-option-disabled': this.disabled,\n }}\n tabindex=\"-1\"\n aria-disabled={this.disabled}\n >\n {this.isMultiSelectOption && (\n <div class=\"sdds-checkbox-item sdds-option-checkbox\">\n <label class=\"sdds-form-label\">\n <input\n class=\"sdds-form-input\"\n type=\"checkbox\"\n checked={this.selected}\n disabled={this.disabled}\n />\n </label>\n </div>\n )}\n <span class=\"sdds-option-label\">\n <slot />\n </span>\n {!this.isMultiSelectOption && (\n <span class=\"sdds-option-checkmark\">\n <svg\n width=\"10\"\n height=\"7\"\n viewBox=\"0 0 10 7\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n d=\"M1 3L4 6L9 1\"\n stroke=\"currentColor\"\n stroke-width=\"1.25\"\n stroke-linecap=\"round\"\n stroke-linejoin=\"round\"\n />\n </svg>\n </span>\n )}\n </Host>\n );\n }\n}\n"],"version":3}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
const index = require('./index-5ad19933.js');
|
|
6
|
+
|
|
7
|
+
const sddsFolderTabsButtonCss = ":host{box-sizing:border-box;display:block;position:relative;z-index:200}:host *{box-sizing:border-box}:host button{min-width:142px;height:100%;font:var(--sdds-headline-07);letter-spacing:var(--sdds-headline-07-ls);cursor:pointer;color:var(--sdds-folder-tab-color);padding:16px;white-space:nowrap;text-decoration:none;text-align:left;outline:none;border:none;border-top:2px solid var(--sdds-folder-tab-background);background-color:var(--sdds-folder-tab-background);border-right:none}:host button .label{opacity:var(--sdds-folder-tab-color-opacity)}:host button.selected{background-color:var(--sdds-folder-tab-background-selected);border-top:2px solid var(--sdds-folder-tab-border-selected)}:host button.selected::before{content:\" \";background-color:var(--sdds-folder-tab-background);width:1px;top:0;bottom:0;left:-1px;display:block;position:absolute}:host button.selected .label{opacity:var(--sdds-folder-tab-color-opacity-selected)}:host button:not(.selected){border-right-width:1px;border-right-style:solid;border-right-color:var(--sdds-folder-tab-divider-color)}:host button:not(.selected):hover{border-top-color:var(--sdds-folder-tab-background-hover);background-color:var(--sdds-folder-tab-background-hover)}:host button:not(.selected):hover .label{opacity:var(--sdds-folder-tab-color-opacity-hover)}:host button.disabled{pointer-events:none}:host button.disabled .label{opacity:var(--sdds-folder-tab-color-opacity-disabled)}:host button.disabled:focus-visible{outline:none}:host button.disabled:focus-visible .label{opacity:var(--sdds-folder-tab-color-opacity-disabled)}:host button:focus-visible{outline:2px solid var(--sdds-blue-400);outline-offset:-2px;opacity:var(--sdds-folder-tab-color-opacity-focus)}:host(.last) button:not(.selected){border-right-color:transparent}";
|
|
8
|
+
|
|
9
|
+
const SddsFolderTabsButton = class {
|
|
10
|
+
constructor(hostRef) {
|
|
11
|
+
index.registerInstance(this, hostRef);
|
|
12
|
+
this.disabled = false;
|
|
13
|
+
this.selected = false;
|
|
14
|
+
this.tabWidth = undefined;
|
|
15
|
+
}
|
|
16
|
+
/** @internal Method to set the width of the tab. Used by the <sdds-folder-tabs> */
|
|
17
|
+
async setTabWidth(width) {
|
|
18
|
+
this.tabWidth = width;
|
|
19
|
+
}
|
|
20
|
+
render() {
|
|
21
|
+
return (index.h(index.Host, { role: "listitem" }, index.h("button", { style: { width: `${this.tabWidth}px` }, class: `${this.selected ? 'selected' : ''}
|
|
22
|
+
${this.disabled ? 'disabled' : ''}`, disabled: this.disabled }, index.h("div", { class: "label" }, index.h("slot", { name: "label" })))));
|
|
23
|
+
}
|
|
24
|
+
};
|
|
25
|
+
SddsFolderTabsButton.style = sddsFolderTabsButtonCss;
|
|
26
|
+
|
|
27
|
+
exports.sdds_folder_tabs_button = SddsFolderTabsButton;
|
|
28
|
+
|
|
29
|
+
//# sourceMappingURL=sdds-folder-tabs-button.cjs.entry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"file":"sdds-folder-tabs-button.entry.cjs.js","mappings":";;;;;;AAAA,MAAM,uBAAuB,GAAG,svDAAsvD;;MCOzwD,oBAAoB;;;oBAEH,KAAK;oBAGL,KAAK;;;;EAMjC,MAAM,WAAW,CAAC,KAAa;IAC7B,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;GACvB;EAED,MAAM;IACJ,QACEA,QAACC,UAAI,IAAC,IAAI,EAAC,UAAU,IACnBD,oBACE,KAAK,EAAE,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC,QAAQ,IAAI,EAAE,EACtC,KAAK,EAAE,GAAG,IAAI,CAAC,QAAQ,GAAG,UAAU,GAAG,EAAE;YACvC,IAAI,CAAC,QAAQ,GAAG,UAAU,GAAG,EAAE,EAAE,EACnC,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAEvBA,iBAAK,KAAK,EAAC,OAAO,IAChBA,kBAAM,IAAI,EAAC,OAAO,GAAQ,CACtB,CACC,CACJ,EACP;GACH;;;;;;","names":["h","Host"],"sources":["./src/components/tabs/folder-tabs/folder-tabs-button/sdds-folder-tabs-button.scss?tag=sdds-folder-tabs-button&encapsulation=shadow","./src/components/tabs/folder-tabs/folder-tabs-button/sdds-folder-tabs-button.tsx"],"sourcesContent":["@import '../../../../mixins/focus-state';\n@import '../../../../mixins/z-index';\n@import '../../../../mixins/box-sizing';\n\n:host {\n @include sdds-box-sizing;\n\n display: block;\n position: relative;\n z-index: z(tab);\n\n button {\n min-width: 142px;\n height: 100%;\n font: var(--sdds-headline-07);\n letter-spacing: var(--sdds-headline-07-ls);\n cursor: pointer;\n color: var(--sdds-folder-tab-color);\n padding: 16px;\n white-space: nowrap;\n text-decoration: none;\n text-align: left;\n outline: none;\n border: none;\n border-top: 2px solid var(--sdds-folder-tab-background);\n background-color: var(--sdds-folder-tab-background);\n border-right: none;\n\n .label {\n opacity: var(--sdds-folder-tab-color-opacity);\n }\n\n &.selected {\n background-color: var(--sdds-folder-tab-background-selected);\n border-top: 2px solid var(--sdds-folder-tab-border-selected);\n\n &::before {\n // This ::before element hides the border-right of the tab to the left of the selected tab\n content: ' ';\n background-color: var(--sdds-folder-tab-background);\n width: 1px;\n top: 0;\n bottom: 0;\n left: -1px;\n display: block;\n position: absolute;\n }\n\n .label {\n opacity: var(--sdds-folder-tab-color-opacity-selected);\n }\n }\n\n &:not(.selected) {\n border-right-width: 1px;\n border-right-style: solid;\n border-right-color: var(--sdds-folder-tab-divider-color);\n\n &:hover {\n border-top-color: var(--sdds-folder-tab-background-hover);\n background-color: var(--sdds-folder-tab-background-hover);\n\n .label {\n opacity: var(--sdds-folder-tab-color-opacity-hover);\n }\n }\n }\n\n &.disabled {\n pointer-events: none;\n\n .label {\n opacity: var(--sdds-folder-tab-color-opacity-disabled);\n }\n\n &:focus-visible {\n .label {\n opacity: var(--sdds-folder-tab-color-opacity-disabled);\n }\n\n outline: none;\n }\n }\n\n &:focus-visible {\n @include sdds-focus-state;\n\n opacity: var(--sdds-folder-tab-color-opacity-focus);\n }\n }\n}\n\n:host(.last) {\n button:not(.selected) {\n border-right-color: transparent;\n }\n}\n","import { Component, Host, h, Prop, State, Method } from '@stencil/core';\n\n@Component({\n tag: 'sdds-folder-tabs-button',\n styleUrl: 'sdds-folder-tabs-button.scss',\n shadow: true,\n})\nexport class SddsFolderTabsButton {\n /** Disables the tab. */\n @Prop() disabled: boolean = false;\n\n /** Marks the tab as the selected one. */\n @Prop() selected: boolean = false;\n\n @State() tabWidth: number;\n\n /** @internal Method to set the width of the tab. Used by the <sdds-folder-tabs> */\n @Method()\n async setTabWidth(width: number) {\n this.tabWidth = width;\n }\n\n render() {\n return (\n <Host role=\"listitem\">\n <button\n style={{ width: `${this.tabWidth}px` }}\n class={`${this.selected ? 'selected' : ''}\n ${this.disabled ? 'disabled' : ''}`}\n disabled={this.disabled}\n >\n <div class=\"label\">\n <slot name=\"label\"></slot>\n </div>\n </button>\n </Host>\n );\n }\n}\n"],"version":3}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
const index = require('./index-5ad19933.js');
|
|
6
|
+
|
|
7
|
+
const sddsFolderTabsLinkCss = ":host{box-sizing:border-box;display:block;position:relative;z-index:200}:host *{box-sizing:border-box}:host a{min-width:142px;display:block;font:var(--sdds-headline-07);letter-spacing:var(--sdds-headline-07-ls);cursor:pointer;padding:16px;white-space:nowrap;text-decoration:none;text-align:left;outline:none;border:none;border-right:1px solid;border-right-color:transparent;color:var(--sdds-folder-tab-color);border-top:2px solid var(--sdds-folder-tab-background);background-color:var(--sdds-folder-tab-background)}:host a .label{opacity:var(--sdds-folder-tab-color-opacity)}:host a.selected{background-color:var(--sdds-folder-tab-background-selected);border-top:2px solid var(--sdds-folder-tab-border-selected)}:host a.selected::before{content:\" \";background-color:var(--sdds-folder-tab-background-selected);width:1px;top:0;bottom:0;left:-1px;display:block;position:absolute}:host a.selected .label{opacity:var(--sdds-folder-tab-color-opacity-selected)}:host a:not(.selected){border-right-color:var(--sdds-folder-tab-divider-color)}:host a:not(.selected):hover{background-color:var(--sdds-folder-tab-background-hover)}:host a:not(.selected):hover .label{opacity:var(--sdds-folder-tab-color-opacity-hover)}:host a.disabled{pointer-events:none}:host a.disabled .label{opacity:var(--sdds-folder-tab-color-opacity-disabled)}:host a.disabled:focus-visible{outline:none}:host a.disabled:focus-visible .label{opacity:var(--sdds-folder-tab-color-opacity-disabled)}:host a:focus-visible{outline:2px solid var(--sdds-blue-400);outline-offset:-2px;opacity:var(--sdds-folder-tab-color-opacity-focus)}:host(.last) a:not(.selected){border-right-color:transparent}";
|
|
8
|
+
|
|
9
|
+
const SddsFolderTabsLink = class {
|
|
10
|
+
constructor(hostRef) {
|
|
11
|
+
index.registerInstance(this, hostRef);
|
|
12
|
+
this.disabled = false;
|
|
13
|
+
this.selected = false;
|
|
14
|
+
this.href = undefined;
|
|
15
|
+
this.target = '_self';
|
|
16
|
+
this.rel = 'noopener';
|
|
17
|
+
this.tabWidth = undefined;
|
|
18
|
+
}
|
|
19
|
+
/** @internal Method to set the width of the tab. Used by the <sdds-folder-tabs> */
|
|
20
|
+
async setTabWidth(width) {
|
|
21
|
+
this.tabWidth = width;
|
|
22
|
+
}
|
|
23
|
+
render() {
|
|
24
|
+
return (index.h(index.Host, { role: "listitem" }, index.h("a", { style: { width: `${this.tabWidth}px` }, class: `
|
|
25
|
+
${this.selected ? 'selected' : ''}
|
|
26
|
+
${this.disabled ? 'disabled' : ''}
|
|
27
|
+
`, href: this.href, target: this.target, rel: this.rel }, index.h("div", { class: "label" }, index.h("slot", { name: "label" })))));
|
|
28
|
+
}
|
|
29
|
+
};
|
|
30
|
+
SddsFolderTabsLink.style = sddsFolderTabsLinkCss;
|
|
31
|
+
|
|
32
|
+
exports.sdds_folder_tabs_link = SddsFolderTabsLink;
|
|
33
|
+
|
|
34
|
+
//# sourceMappingURL=sdds-folder-tabs-link.cjs.entry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"file":"sdds-folder-tabs-link.entry.cjs.js","mappings":";;;;;;AAAA,MAAM,qBAAqB,GAAG,snDAAsnD;;MCOvoD,kBAAkB;;;oBAED,KAAK;oBAGL,KAAK;;kBAMyB,OAAO;eAG3C,UAAU;;;;EAMhC,MAAM,WAAW,CAAC,KAAa;IAC7B,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;GACvB;EAED,MAAM;IACJ,QACEA,QAACC,UAAI,IAAC,IAAI,EAAC,UAAU,IACnBD,eACE,KAAK,EAAE,EAAE,KAAK,EAAE,GAAG,IAAI,CAAC,QAAQ,IAAI,EAAE,EACtC,KAAK,EAAE;UACP,IAAI,CAAC,QAAQ,GAAG,UAAU,GAAG,EAAE;UAC/B,IAAI,CAAC,QAAQ,GAAG,UAAU,GAAG,EAAE;SAChC,EACC,IAAI,EAAE,IAAI,CAAC,IAAI,EACf,MAAM,EAAE,IAAI,CAAC,MAAM,EACnB,GAAG,EAAE,IAAI,CAAC,GAAG,IAEbA,iBAAK,KAAK,EAAC,OAAO,IAChBA,kBAAM,IAAI,EAAC,OAAO,GAAQ,CACtB,CACJ,CACC,EACP;GACH;;;;;;","names":["h","Host"],"sources":["./src/components/tabs/folder-tabs/folder-tabs-link/sdds-folder-tabs-link.scss?tag=sdds-folder-tabs-link&encapsulation=shadow","./src/components/tabs/folder-tabs/folder-tabs-link/sdds-folder-tabs-link.tsx"],"sourcesContent":["@import '../../../../mixins/focus-state';\n@import '../../../../mixins/z-index';\n@import '../../../../mixins/box-sizing';\n\n:host {\n @include sdds-box-sizing;\n\n display: block;\n position: relative;\n z-index: z(tab);\n\n a {\n min-width: 142px;\n display: block;\n font: var(--sdds-headline-07);\n letter-spacing: var(--sdds-headline-07-ls);\n cursor: pointer;\n padding: 16px;\n white-space: nowrap;\n text-decoration: none;\n text-align: left;\n outline: none;\n border: none;\n border-right: 1px solid;\n border-right-color: transparent;\n color: var(--sdds-folder-tab-color);\n border-top: 2px solid var(--sdds-folder-tab-background);\n background-color: var(--sdds-folder-tab-background);\n\n .label {\n opacity: var(--sdds-folder-tab-color-opacity);\n }\n\n &.selected {\n background-color: var(--sdds-folder-tab-background-selected);\n border-top: 2px solid var(--sdds-folder-tab-border-selected);\n\n &::before {\n content: ' ';\n background-color: var(--sdds-folder-tab-background-selected);\n width: 1px;\n top: 0;\n bottom: 0;\n left: -1px;\n display: block;\n position: absolute;\n }\n\n .label {\n opacity: var(--sdds-folder-tab-color-opacity-selected);\n }\n }\n\n &:not(.selected) {\n border-right-color: var(--sdds-folder-tab-divider-color);\n\n &:hover {\n background-color: var(--sdds-folder-tab-background-hover);\n\n .label {\n opacity: var(--sdds-folder-tab-color-opacity-hover);\n }\n }\n }\n\n &.disabled {\n pointer-events: none;\n\n .label {\n opacity: var(--sdds-folder-tab-color-opacity-disabled);\n }\n\n &:focus-visible {\n .label {\n opacity: var(--sdds-folder-tab-color-opacity-disabled);\n }\n\n outline: none;\n }\n }\n\n &:focus-visible {\n @include sdds-focus-state;\n\n opacity: var(--sdds-folder-tab-color-opacity-focus);\n }\n }\n}\n\n:host(.last) {\n a:not(.selected) {\n border-right-color: transparent;\n }\n}\n","import { Component, Host, h, Prop, State, Method } from '@stencil/core';\n\n@Component({\n tag: 'sdds-folder-tabs-link',\n styleUrl: 'sdds-folder-tabs-link.scss',\n shadow: true,\n})\nexport class SddsFolderTabsLink {\n /** Disables the tab. */\n @Prop() disabled: boolean = false;\n\n /** Marks the tab as the selected one. */\n @Prop() selected: boolean = false;\n\n /** Href for the link */\n @Prop() href: string;\n\n /** Where to open the linked URL */\n @Prop() target: '_self' | '_blank' | '_parent' | '_top' = '_self';\n\n /** 'noopener' is a security measure for legacy browsers that preventsthe opened page from getting access to the original page when using target='_blank'. */\n @Prop() rel: string = 'noopener';\n\n @State() tabWidth: number;\n\n /** @internal Method to set the width of the tab. Used by the <sdds-folder-tabs> */\n @Method()\n async setTabWidth(width: number) {\n this.tabWidth = width;\n }\n\n render() {\n return (\n <Host role=\"listitem\">\n <a\n style={{ width: `${this.tabWidth}px` }}\n class={`\n ${this.selected ? 'selected' : ''}\n ${this.disabled ? 'disabled' : ''}\n `}\n href={this.href}\n target={this.target}\n rel={this.rel}\n >\n <div class=\"label\">\n <slot name=\"label\"></slot>\n </div>\n </a>\n </Host>\n );\n }\n}\n"],"version":3}
|
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
const index = require('./index-5ad19933.js');
|
|
6
|
+
|
|
7
|
+
const folderTabsCss = ":host{box-sizing:border-box;overflow:hidden;outline:0}:host *{box-sizing:border-box}:host .wrapper{display:flex;overflow-x:scroll;scrollbar-width:none;position:relative}:host .wrapper::-webkit-scrollbar{display:none}:host .scroll-right-button{z-index:201;right:0}:host .scroll-left-button{z-index:201;left:0}:host .scroll-right-button,:host .scroll-left-button{height:50px;color:var(--sdds-folder-tabs-scroll-btn-color);cursor:pointer;border:0;width:0;background-color:var(--sdds-folder-tabs-scroll-btn-background);display:none;justify-content:center;align-items:center;opacity:0;pointer-events:none;position:sticky}:host .scroll-right-button.show,:host .scroll-left-button.show{min-width:48px;display:block;opacity:1;pointer-events:all}:host .scroll-right-button:hover,:host .scroll-left-button:hover{background-color:var(--sdds-folder-tabs-scroll-btn-background-hover)}:host .scroll-right-button:active,:host .scroll-left-button:active{background-color:var(--sdds-folder-tabs-scroll-btn-background-active)}:host .scroll-right-button:focus,:host .scroll-left-button:focus{outline:2px solid var(--sdds-blue-400);outline-offset:-2px}:host .scroll-right-button svg,:host .scroll-left-button svg{fill:var(--sdds-folder-tabs-scroll-btn-color)}";
|
|
8
|
+
|
|
9
|
+
const InlineTabs = class {
|
|
10
|
+
constructor(hostRef) {
|
|
11
|
+
index.registerInstance(this, hostRef);
|
|
12
|
+
this.sddsChange = index.createEvent(this, "sddsChange", 7);
|
|
13
|
+
this.navWrapperElement = null; // reference to container with nav buttons
|
|
14
|
+
this.componentWidth = 0; // visible width of this component
|
|
15
|
+
this.buttonsWidth = 0; // total width of all nav items combined
|
|
16
|
+
this.scrollWidth = 0; // total amount that is possible to scroll in the nav wrapper
|
|
17
|
+
this.addResizeObserver = () => {
|
|
18
|
+
const resizeObserver = new ResizeObserver((entries) => {
|
|
19
|
+
entries.forEach((entry) => {
|
|
20
|
+
const componentWidth = entry.contentRect.width;
|
|
21
|
+
let buttonsWidth = 0;
|
|
22
|
+
const navButtons = Array.from(this.host.children);
|
|
23
|
+
navButtons.forEach((navButton) => {
|
|
24
|
+
const style = window.getComputedStyle(navButton);
|
|
25
|
+
buttonsWidth +=
|
|
26
|
+
navButton.clientWidth + parseFloat(style.marginLeft) + parseFloat(style.marginRight);
|
|
27
|
+
});
|
|
28
|
+
this.componentWidth = componentWidth;
|
|
29
|
+
this.buttonsWidth = buttonsWidth;
|
|
30
|
+
this.scrollWidth = buttonsWidth - componentWidth;
|
|
31
|
+
if (this.buttonsWidth > this.componentWidth) {
|
|
32
|
+
this.evaluateScrollButtons();
|
|
33
|
+
}
|
|
34
|
+
else {
|
|
35
|
+
this.showLeftScroll = false;
|
|
36
|
+
this.showRightScroll = false;
|
|
37
|
+
}
|
|
38
|
+
});
|
|
39
|
+
});
|
|
40
|
+
resizeObserver.observe(this.navWrapperElement);
|
|
41
|
+
};
|
|
42
|
+
this.modeVariant = null;
|
|
43
|
+
this.buttonWidth = 0;
|
|
44
|
+
this.showLeftScroll = false;
|
|
45
|
+
this.showRightScroll = false;
|
|
46
|
+
this.selectedTab = undefined;
|
|
47
|
+
this.selectedTabIndex = undefined;
|
|
48
|
+
}
|
|
49
|
+
calculateButtonWidth() {
|
|
50
|
+
this.children = this.children.map((tab) => {
|
|
51
|
+
if (tab.offsetWidth > this.buttonWidth) {
|
|
52
|
+
this.buttonWidth = tab.offsetWidth;
|
|
53
|
+
}
|
|
54
|
+
return tab;
|
|
55
|
+
});
|
|
56
|
+
this.children.forEach((tab) => {
|
|
57
|
+
tab.setTabWidth(this.buttonWidth);
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
scrollRight() {
|
|
61
|
+
const scroll = this.navWrapperElement.scrollLeft;
|
|
62
|
+
this.navWrapperElement.scrollLeft = scroll + this.buttonWidth;
|
|
63
|
+
this.evaluateScrollButtons();
|
|
64
|
+
}
|
|
65
|
+
scrollLeft() {
|
|
66
|
+
const scroll = this.navWrapperElement.scrollLeft;
|
|
67
|
+
this.navWrapperElement.scrollLeft = scroll - this.buttonWidth;
|
|
68
|
+
this.evaluateScrollButtons();
|
|
69
|
+
}
|
|
70
|
+
evaluateScrollButtons() {
|
|
71
|
+
const scroll = this.navWrapperElement.scrollLeft;
|
|
72
|
+
if (scroll >= this.scrollWidth) {
|
|
73
|
+
this.showRightScroll = false;
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
this.showRightScroll = true;
|
|
77
|
+
}
|
|
78
|
+
if (scroll <= 0) {
|
|
79
|
+
this.showLeftScroll = false;
|
|
80
|
+
}
|
|
81
|
+
else {
|
|
82
|
+
this.showLeftScroll = true;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
connectedCallback() {
|
|
86
|
+
this.children = Array.from(this.host.children);
|
|
87
|
+
this.children = this.children.map((item, index) => {
|
|
88
|
+
item.addEventListener('click', () => {
|
|
89
|
+
if (!item.disabled) {
|
|
90
|
+
this.children.forEach((element) => element.removeAttribute('selected'));
|
|
91
|
+
item.setAttribute('selected', '');
|
|
92
|
+
this.selectedTab = item.innerHTML;
|
|
93
|
+
this.selectedTabIndex = index;
|
|
94
|
+
}
|
|
95
|
+
});
|
|
96
|
+
if (index === 0) {
|
|
97
|
+
item.classList.add('first');
|
|
98
|
+
}
|
|
99
|
+
if (index === this.children.length - 1) {
|
|
100
|
+
item.classList.add('last');
|
|
101
|
+
}
|
|
102
|
+
if (item.selected) {
|
|
103
|
+
this.selectedTab = item.innerHTML;
|
|
104
|
+
this.selectedTabIndex = index;
|
|
105
|
+
}
|
|
106
|
+
return item;
|
|
107
|
+
});
|
|
108
|
+
}
|
|
109
|
+
componentDidLoad() {
|
|
110
|
+
this.calculateButtonWidth();
|
|
111
|
+
}
|
|
112
|
+
componentDidUpdate() {
|
|
113
|
+
this.calculateButtonWidth();
|
|
114
|
+
}
|
|
115
|
+
componentWillRender() {
|
|
116
|
+
if (!this.selectedTab) {
|
|
117
|
+
this.children = Array.from(this.host.children);
|
|
118
|
+
this.children = this.children.map((item, index) => {
|
|
119
|
+
if (item.selected) {
|
|
120
|
+
this.selectedTab = item.innerHTML;
|
|
121
|
+
this.selectedTabIndex = index;
|
|
122
|
+
}
|
|
123
|
+
return item;
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
componentDidRender() {
|
|
128
|
+
if (this.buttonsWidth > this.componentWidth) {
|
|
129
|
+
this.evaluateScrollButtons();
|
|
130
|
+
}
|
|
131
|
+
else {
|
|
132
|
+
this.showLeftScroll = false;
|
|
133
|
+
this.showRightScroll = false;
|
|
134
|
+
}
|
|
135
|
+
this.addResizeObserver();
|
|
136
|
+
}
|
|
137
|
+
/** Sets the passed tabindex as the selected tab. */
|
|
138
|
+
async selectTab(tabIndex) {
|
|
139
|
+
if (!this.children[tabIndex].disabled) {
|
|
140
|
+
this.children.forEach((element) => element.removeAttribute('selected'));
|
|
141
|
+
this.children = this.children.map((element, index) => {
|
|
142
|
+
if (index === tabIndex) {
|
|
143
|
+
element.setAttribute('selected', '');
|
|
144
|
+
this.selectedTab = element.innerHTML;
|
|
145
|
+
this.selectedTabIndex = tabIndex;
|
|
146
|
+
}
|
|
147
|
+
return element;
|
|
148
|
+
});
|
|
149
|
+
}
|
|
150
|
+
return {
|
|
151
|
+
selectedTab: this.selectedTab,
|
|
152
|
+
selectedTabIndex: this.selectedTabIndex,
|
|
153
|
+
};
|
|
154
|
+
}
|
|
155
|
+
handleSelectedTabChange() {
|
|
156
|
+
this.host.setAttribute('selected-tab', this.selectedTab);
|
|
157
|
+
}
|
|
158
|
+
handleSelectedTabIndexChange() {
|
|
159
|
+
this.host.setAttribute('selected-tab-index', `${this.selectedTabIndex}`);
|
|
160
|
+
this.sddsChange.emit({
|
|
161
|
+
selectedTab: this.selectedTab,
|
|
162
|
+
selectedTabIndex: this.selectedTabIndex,
|
|
163
|
+
});
|
|
164
|
+
}
|
|
165
|
+
render() {
|
|
166
|
+
return (index.h(index.Host, { class: `${this.modeVariant ? `sdds-mode-variant-${this.modeVariant}` : ''}` }, index.h("div", { ref: (el) => {
|
|
167
|
+
this.navWrapperElement = el;
|
|
168
|
+
}, class: "wrapper", role: "list" }, index.h("button", { class: `scroll-left-button ${this.showLeftScroll ? 'show' : ''}`, disabled: !this.showLeftScroll, onClick: () => this.scrollLeft() }, index.h("sdds-icon", { name: "chevron_left", size: "20px" })), index.h("slot", null), index.h("button", { class: `scroll-right-button ${this.showRightScroll ? 'show' : ''}`, disabled: !this.showRightScroll, onClick: () => this.scrollRight() }, index.h("sdds-icon", { name: "chevron_right", size: "20px" })))));
|
|
169
|
+
}
|
|
170
|
+
get host() { return index.getElement(this); }
|
|
171
|
+
static get watchers() { return {
|
|
172
|
+
"selectedTab": ["handleSelectedTabChange"],
|
|
173
|
+
"selectedTabIndex": ["handleSelectedTabIndexChange"]
|
|
174
|
+
}; }
|
|
175
|
+
};
|
|
176
|
+
InlineTabs.style = folderTabsCss;
|
|
177
|
+
|
|
178
|
+
exports.sdds_folder_tabs = InlineTabs;
|
|
179
|
+
|
|
180
|
+
//# sourceMappingURL=sdds-folder-tabs.cjs.entry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"file":"sdds-folder-tabs.entry.cjs.js","mappings":"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","names":["h","Host"],"sources":["./src/components/tabs/folder-tabs/folder-tabs.scss?tag=sdds-folder-tabs&encapsulation=shadow","./src/components/tabs/folder-tabs/folder-tabs.tsx"],"sourcesContent":["@import '../../../mixins/focus-state';\n@import '../../../mixins/box-sizing';\n@import '../../../mixins/z-index';\n\n:host {\n @include sdds-box-sizing;\n\n overflow: hidden;\n outline: 0;\n\n .wrapper {\n display: flex;\n overflow-x: scroll;\n scrollbar-width: none;\n position: relative;\n\n &::-webkit-scrollbar {\n display: none;\n }\n }\n\n .scroll-right-button {\n z-index: calc(z(tab) + 1);\n right: 0;\n }\n\n .scroll-left-button {\n z-index: calc(z(tab) + 1);\n left: 0;\n }\n\n .scroll-right-button,\n .scroll-left-button {\n height: 50px;\n color: var(--sdds-folder-tabs-scroll-btn-color);\n cursor: pointer;\n border: 0;\n width: 0;\n background-color: var(--sdds-folder-tabs-scroll-btn-background);\n display: none;\n justify-content: center;\n align-items: center;\n opacity: 0;\n pointer-events: none;\n position: sticky;\n\n &.show {\n min-width: 48px;\n display: block;\n opacity: 1;\n pointer-events: all;\n }\n\n &:hover {\n background-color: var(--sdds-folder-tabs-scroll-btn-background-hover);\n }\n\n &:active {\n background-color: var(--sdds-folder-tabs-scroll-btn-background-active);\n }\n\n &:focus {\n @include sdds-focus-state;\n }\n\n svg {\n fill: var(--sdds-folder-tabs-scroll-btn-color);\n }\n }\n}\n","import {\n Component,\n Host,\n State,\n Element,\n Prop,\n h,\n Watch,\n Event,\n EventEmitter,\n Method,\n} from '@stencil/core';\n\n@Component({\n tag: 'sdds-folder-tabs',\n styleUrl: 'folder-tabs.scss',\n shadow: true,\n})\nexport class InlineTabs {\n /** Variant of the tabs, primary= on white, secondary= on grey50 */\n @Prop() modeVariant: 'primary' | 'secondary' = null;\n\n @State() buttonWidth: number = 0;\n\n @State() showLeftScroll: boolean = false;\n\n @State() showRightScroll: boolean = false;\n\n @State() selectedTab: string;\n\n @State() selectedTabIndex: number;\n\n @Element() host: HTMLElement;\n\n navWrapperElement: HTMLElement = null; // reference to container with nav buttons\n\n componentWidth: number = 0; // visible width of this component\n\n buttonsWidth: number = 0; // total width of all nav items combined\n\n scrollWidth: number = 0; // total amount that is possible to scroll in the nav wrapper\n\n children: Array<HTMLSddsFolderTabsLinkElement | HTMLSddsFolderTabsButtonElement>;\n\n calculateButtonWidth() {\n this.children = this.children.map(\n (tab: HTMLSddsFolderTabsLinkElement | HTMLSddsFolderTabsButtonElement) => {\n if (tab.offsetWidth > this.buttonWidth) {\n this.buttonWidth = tab.offsetWidth;\n }\n return tab;\n },\n );\n this.children.forEach((tab) => {\n tab.setTabWidth(this.buttonWidth);\n });\n }\n\n scrollRight() {\n const scroll = this.navWrapperElement.scrollLeft;\n this.navWrapperElement.scrollLeft = scroll + this.buttonWidth;\n this.evaluateScrollButtons();\n }\n\n scrollLeft() {\n const scroll = this.navWrapperElement.scrollLeft;\n this.navWrapperElement.scrollLeft = scroll - this.buttonWidth;\n this.evaluateScrollButtons();\n }\n\n evaluateScrollButtons() {\n const scroll = this.navWrapperElement.scrollLeft;\n\n if (scroll >= this.scrollWidth) {\n this.showRightScroll = false;\n } else {\n this.showRightScroll = true;\n }\n\n if (scroll <= 0) {\n this.showLeftScroll = false;\n } else {\n this.showLeftScroll = true;\n }\n }\n\n addResizeObserver = () => {\n const resizeObserver = new ResizeObserver((entries) => {\n entries.forEach((entry) => {\n const componentWidth = entry.contentRect.width;\n let buttonsWidth = 0;\n\n const navButtons = Array.from(this.host.children);\n navButtons.forEach((navButton: HTMLElement) => {\n const style = window.getComputedStyle(navButton);\n buttonsWidth +=\n navButton.clientWidth + parseFloat(style.marginLeft) + parseFloat(style.marginRight);\n });\n\n this.componentWidth = componentWidth;\n this.buttonsWidth = buttonsWidth;\n this.scrollWidth = buttonsWidth - componentWidth;\n\n if (this.buttonsWidth > this.componentWidth) {\n this.evaluateScrollButtons();\n } else {\n this.showLeftScroll = false;\n this.showRightScroll = false;\n }\n });\n });\n\n resizeObserver.observe(this.navWrapperElement);\n };\n\n connectedCallback() {\n this.children = Array.from(this.host.children) as Array<\n HTMLSddsFolderTabsLinkElement | HTMLSddsFolderTabsButtonElement\n >;\n this.children = this.children.map((item, index) => {\n item.addEventListener('click', () => {\n if (!item.disabled) {\n this.children.forEach((element) => element.removeAttribute('selected'));\n item.setAttribute('selected', '');\n this.selectedTab = item.innerHTML;\n this.selectedTabIndex = index;\n }\n });\n if (index === 0) {\n item.classList.add('first');\n }\n if (index === this.children.length - 1) {\n item.classList.add('last');\n }\n if (item.selected) {\n this.selectedTab = item.innerHTML;\n this.selectedTabIndex = index;\n }\n return item;\n });\n }\n\n componentDidLoad() {\n this.calculateButtonWidth();\n }\n\n componentDidUpdate() {\n this.calculateButtonWidth();\n }\n\n componentWillRender() {\n if (!this.selectedTab) {\n this.children = Array.from(this.host.children) as Array<\n HTMLSddsFolderTabsLinkElement | HTMLSddsFolderTabsButtonElement\n >;\n this.children = this.children.map((item, index) => {\n if (item.selected) {\n this.selectedTab = item.innerHTML;\n this.selectedTabIndex = index;\n }\n return item;\n });\n }\n }\n\n componentDidRender() {\n if (this.buttonsWidth > this.componentWidth) {\n this.evaluateScrollButtons();\n } else {\n this.showLeftScroll = false;\n this.showRightScroll = false;\n }\n this.addResizeObserver();\n }\n\n @Event({\n eventName: 'sddsChange',\n composed: true,\n cancelable: true,\n bubbles: true,\n })\n sddsChange: EventEmitter<{\n selectedTab: string;\n selectedTabIndex: number;\n }>;\n\n /** Sets the passed tabindex as the selected tab. */\n @Method()\n async selectTab(tabIndex: number) {\n if (!this.children[tabIndex].disabled) {\n this.children.forEach((element) => element.removeAttribute('selected'));\n this.children = this.children.map((element, index) => {\n if (index === tabIndex) {\n element.setAttribute('selected', '');\n this.selectedTab = element.innerHTML;\n this.selectedTabIndex = tabIndex;\n }\n return element;\n });\n }\n return {\n selectedTab: this.selectedTab,\n selectedTabIndex: this.selectedTabIndex,\n };\n }\n\n @Watch('selectedTab')\n handleSelectedTabChange() {\n this.host.setAttribute('selected-tab', this.selectedTab);\n }\n\n @Watch('selectedTabIndex')\n handleSelectedTabIndexChange() {\n this.host.setAttribute('selected-tab-index', `${this.selectedTabIndex}`);\n this.sddsChange.emit({\n selectedTab: this.selectedTab,\n selectedTabIndex: this.selectedTabIndex,\n });\n }\n\n render() {\n return (\n <Host class={`${this.modeVariant ? `sdds-mode-variant-${this.modeVariant}` : ''}`}>\n <div\n ref={(el) => {\n this.navWrapperElement = el as HTMLDivElement;\n }}\n class=\"wrapper\"\n role=\"list\"\n >\n <button\n class={`scroll-left-button ${this.showLeftScroll ? 'show' : ''}`}\n disabled={!this.showLeftScroll}\n onClick={() => this.scrollLeft()}\n >\n <sdds-icon name=\"chevron_left\" size=\"20px\"></sdds-icon>\n </button>\n <slot></slot>\n <button\n class={`scroll-right-button ${this.showRightScroll ? 'show' : ''}`}\n disabled={!this.showRightScroll}\n onClick={() => this.scrollRight()}\n >\n <sdds-icon name=\"chevron_right\" size=\"20px\"></sdds-icon>\n </button>\n </div>\n </Host>\n );\n }\n}\n"],"version":3}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
const index = require('./index-5ad19933.js');
|
|
6
|
+
|
|
7
|
+
const sddsFooterLinkGroupCss = ".sc-sdds-footer-link-group-h{display:block;width:100%}.sc-sdds-footer-link-group-h .footer-top-title.sc-sdds-footer-link-group{font:var(--sdds-headline-07);letter-spacing:var(--sdds-headline-07-ls);opacity:var(--sdds-footer-top-title-opacity);color:var(--sdds-footer-top-links);padding-bottom:8px}.sc-sdds-footer-link-group-h button.footer-top-title-button.sc-sdds-footer-link-group{display:none;border:none;width:100%;font:var(--sdds-headline-07);letter-spacing:var(--sdds-headline-07-ls);color:var(--sdds-footer-top-links);background-color:transparent;text-align:left;padding:19px 24px;justify-content:space-between;border-bottom:1px solid var(--sdds-footer-top-divider)}.sc-sdds-footer-link-group-h button.footer-top-title-button.expanded.sc-sdds-footer-link-group{border-bottom:none}.sc-sdds-footer-link-group-h button.footer-top-title-button.expanded.sc-sdds-footer-link-group sdds-icon.sc-sdds-footer-link-group{transform:rotateZ(180deg)}.sc-sdds-footer-link-group-h button.footer-top-title-button.sc-sdds-footer-link-group:hover{cursor:pointer}.sc-sdds-footer-link-group-h button.footer-top-title-button.sc-sdds-footer-link-group:active{background-color:var(--sdds-footer-top-button-active)}.sc-sdds-footer-link-group-h button.footer-top-title-button.sc-sdds-footer-link-group sdds-icon.sc-sdds-footer-link-group{transition:transform 0.2s ease-in-out}.sc-sdds-footer-link-group-h [role=list].sc-sdds-footer-link-group{list-style:none;padding:0;margin:0;display:flex;gap:8px}.sc-sdds-footer-link-group-h [role=list].top-part-child.sc-sdds-footer-link-group{flex-direction:column}@media all and (max-width: 992px){.sc-sdds-footer-link-group-h [role=list].left.sc-sdds-footer-link-group:not(.top-part-child){flex-direction:column}.sc-sdds-footer-link-group-h [role=list].top-part-child.closed.sc-sdds-footer-link-group{display:none}.sc-sdds-footer-link-group-h [role=list].top-part-child.sc-sdds-footer-link-group{gap:0}.sc-sdds-footer-link-group-h .footer-top-title.sc-sdds-footer-link-group{display:none}.sc-sdds-footer-link-group-h button.footer-top-title-button.sc-sdds-footer-link-group{display:flex;align-items:center}}";
|
|
8
|
+
|
|
9
|
+
const SddsFooterLinkGroup = class {
|
|
10
|
+
constructor(hostRef) {
|
|
11
|
+
index.registerInstance(this, hostRef);
|
|
12
|
+
this.rightSlot = false;
|
|
13
|
+
this.parentIsTopPart = false;
|
|
14
|
+
this.titleText = undefined;
|
|
15
|
+
this.open = false;
|
|
16
|
+
}
|
|
17
|
+
connectedCallback() {
|
|
18
|
+
this.rightSlot = this.host.parentElement.slot === 'main-right';
|
|
19
|
+
this.parentIsTopPart = this.host.parentElement.slot === 'top';
|
|
20
|
+
}
|
|
21
|
+
render() {
|
|
22
|
+
return (index.h(index.Host, null, this.titleText && this.parentIsTopPart && (index.h("div", { class: "footer-top-title" }, this.titleText)), this.titleText && this.parentIsTopPart && (index.h("button", { onClick: () => {
|
|
23
|
+
this.open = !this.open;
|
|
24
|
+
}, class: `footer-top-title-button ${this.open ? 'expanded' : 'closed'}` }, this.titleText, index.h("sdds-icon", { name: "chevron_down", size: "20px" }))), index.h("div", { role: "list", class: `
|
|
25
|
+
${this.rightSlot ? 'right' : 'left'}
|
|
26
|
+
${this.parentIsTopPart ? 'top-part-child' : ''}
|
|
27
|
+
${this.open ? 'expanded' : 'closed'}
|
|
28
|
+
` }, index.h("slot", null))));
|
|
29
|
+
}
|
|
30
|
+
get host() { return index.getElement(this); }
|
|
31
|
+
};
|
|
32
|
+
SddsFooterLinkGroup.style = sddsFooterLinkGroupCss;
|
|
33
|
+
|
|
34
|
+
exports.sdds_footer_link_group = SddsFooterLinkGroup;
|
|
35
|
+
|
|
36
|
+
//# sourceMappingURL=sdds-footer-link-group.cjs.entry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"file":"sdds-footer-link-group.entry.cjs.js","mappings":";;;;;;AAAA,MAAM,sBAAsB,GAAG,mlEAAmlE;;MCSrmE,mBAAmB;;;IAQ9B,cAAS,GAAY,KAAK,CAAC;IAE3B,oBAAe,GAAY,KAAK,CAAC;;gBAJR,KAAK;;EAM9B,iBAAiB;IACf,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,KAAK,YAAY,CAAC;IAC/D,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,KAAK,KAAK,CAAC;GAC/D;EAED,MAAM;IACJ,QACEA,QAACC,UAAI,QACF,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,eAAe,KACrCD,iBAAK,KAAK,EAAC,kBAAkB,IAAE,IAAI,CAAC,SAAS,CAAO,CACrD,EAEA,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,eAAe,KACrCA,oBACE,OAAO,EAAE;QACP,IAAI,CAAC,IAAI,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC;OACxB,EACD,KAAK,EAAE,4BAA4B,IAAI,CAAC,IAAI,GAAG,UAAU,GAAG,QAAQ,EAAE,IAErE,IAAI,CAAC,SAAS,EACfA,uBAAW,IAAI,EAAC,cAAc,EAAC,IAAI,EAAC,MAAM,GAAa,CAChD,CACV,EACDA,iBACE,IAAI,EAAC,MAAM,EACX,KAAK,EAAE;UACP,IAAI,CAAC,SAAS,GAAG,OAAO,GAAG,MAAM;UACjC,IAAI,CAAC,eAAe,GAAG,gBAAgB,GAAG,EAAE;UAC5C,IAAI,CAAC,IAAI,GAAG,UAAU,GAAG,QAAQ;SAClC,IAECA,qBAAa,CACT,CACD,EACP;GACH;;;;;;;","names":["h","Host"],"sources":["./src/components/footer/webcomponent/sdds-footer-link-group/sdds-footer-link-group.scss?tag=sdds-footer-link-group&encapsulation=scoped","./src/components/footer/webcomponent/sdds-footer-link-group/sdds-footer-link-group.tsx"],"sourcesContent":[":host {\n display: block;\n width: 100%;\n\n .footer-top-title {\n font: var(--sdds-headline-07);\n letter-spacing: var(--sdds-headline-07-ls);\n opacity: var(--sdds-footer-top-title-opacity);\n color: var(--sdds-footer-top-links);\n padding-bottom: 8px;\n }\n\n button.footer-top-title-button {\n display: none;\n border: none;\n width: 100%;\n font: var(--sdds-headline-07);\n letter-spacing: var(--sdds-headline-07-ls);\n color: var(--sdds-footer-top-links);\n background-color: transparent;\n text-align: left;\n padding: 19px 24px;\n justify-content: space-between;\n border-bottom: 1px solid var(--sdds-footer-top-divider);\n\n &.expanded {\n border-bottom: none;\n\n sdds-icon {\n transform: rotateZ(180deg);\n }\n }\n\n &:hover {\n cursor: pointer;\n }\n\n &:active {\n background-color: var(--sdds-footer-top-button-active);\n }\n\n sdds-icon {\n transition: transform 0.2s ease-in-out;\n }\n }\n\n [role='list'] {\n list-style: none;\n padding: 0;\n margin: 0;\n display: flex;\n gap: 8px;\n\n &.top-part-child {\n flex-direction: column;\n }\n }\n\n @media all and (max-width: 992px) {\n [role='list'].left:not(.top-part-child) {\n flex-direction: column;\n }\n\n [role='list'].top-part-child.closed {\n display: none;\n }\n\n [role='list'].top-part-child {\n gap: 0;\n }\n\n .footer-top-title {\n display: none;\n }\n\n button.footer-top-title-button {\n display: flex;\n align-items: center;\n }\n }\n}\n","import { Component, Host, h, Prop, Element } from '@stencil/core';\nimport { HostElement, State } from '@stencil/core/internal';\n\n@Component({\n tag: 'sdds-footer-link-group',\n styleUrl: 'sdds-footer-link-group.scss',\n shadow: false,\n scoped: true,\n})\nexport class SddsFooterLinkGroup {\n /** Title text for the link group, only valid on top part of footer. */\n @Prop() titleText: string;\n\n @Element() host: HostElement;\n\n @State() open: boolean = false;\n\n rightSlot: boolean = false;\n\n parentIsTopPart: boolean = false;\n\n connectedCallback() {\n this.rightSlot = this.host.parentElement.slot === 'main-right';\n this.parentIsTopPart = this.host.parentElement.slot === 'top';\n }\n\n render() {\n return (\n <Host>\n {this.titleText && this.parentIsTopPart && (\n <div class=\"footer-top-title\">{this.titleText}</div>\n )}\n\n {this.titleText && this.parentIsTopPart && (\n <button\n onClick={() => {\n this.open = !this.open;\n }}\n class={`footer-top-title-button ${this.open ? 'expanded' : 'closed'}`}\n >\n {this.titleText}\n <sdds-icon name=\"chevron_down\" size=\"20px\"></sdds-icon>\n </button>\n )}\n <div\n role=\"list\"\n class={`\n ${this.rightSlot ? 'right' : 'left'}\n ${this.parentIsTopPart ? 'top-part-child' : ''}\n ${this.open ? 'expanded' : 'closed'}\n `}\n >\n <slot></slot>\n </div>\n </Host>\n );\n }\n}\n"],"version":3}
|