@synergy-design-system/metadata 1.0.0 → 3.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +17 -0
- package/README.md +96 -0
- package/data/core/asset/asset:sick2018-icons.json +89042 -0
- package/data/core/asset/asset:sick2018-logos.json +28 -0
- package/data/core/asset/asset:sick2018-system-icons.json +52 -0
- package/data/core/asset/asset:sick2025-icons-fill.json +152214 -0
- package/data/core/asset/asset:sick2025-icons-outline.json +152214 -0
- package/data/core/asset/asset:sick2025-logos.json +34 -0
- package/data/core/asset/asset:sick2025-system-icons.json +52 -0
- package/data/core/component/component:syn-accordion.json +189 -0
- package/data/core/component/component:syn-alert.json +244 -0
- package/data/core/component/component:syn-badge.json +183 -0
- package/data/core/component/component:syn-breadcrumb-item.json +139 -0
- package/data/core/component/component:syn-breadcrumb.json +188 -0
- package/data/core/component/component:syn-button-group.json +200 -0
- package/data/core/component/component:syn-button.json +273 -0
- package/data/core/component/component:syn-card.json +205 -0
- package/data/core/component/component:syn-checkbox.json +259 -0
- package/data/core/component/component:syn-combobox.json +421 -0
- package/data/core/component/component:syn-details.json +222 -0
- package/data/core/component/component:syn-dialog.json +219 -0
- package/data/core/component/component:syn-divider.json +178 -0
- package/data/core/component/component:syn-drawer.json +268 -0
- package/data/core/component/component:syn-dropdown.json +211 -0
- package/data/core/component/component:syn-file.json +284 -0
- package/data/core/component/component:syn-header.json +235 -0
- package/data/core/component/component:syn-icon-button.json +223 -0
- package/data/core/component/component:syn-icon.json +166 -0
- package/data/core/component/component:syn-input.json +352 -0
- package/data/core/component/component:syn-menu-item.json +218 -0
- package/data/core/component/component:syn-menu-label.json +139 -0
- package/data/core/component/component:syn-menu.json +161 -0
- package/data/core/component/component:syn-nav-item.json +259 -0
- package/data/core/component/component:syn-optgroup.json +126 -0
- package/data/core/component/component:syn-option.json +182 -0
- package/data/core/component/component:syn-pagination.json +125 -0
- package/data/core/component/component:syn-popup.json +138 -0
- package/data/core/component/component:syn-prio-nav.json +167 -0
- package/data/core/component/component:syn-progress-bar.json +183 -0
- package/data/core/component/component:syn-progress-ring.json +190 -0
- package/data/core/component/component:syn-radio-button.json +114 -0
- package/data/core/component/component:syn-radio-group.json +262 -0
- package/data/core/component/component:syn-radio.json +214 -0
- package/data/core/component/component:syn-range-tick.json +166 -0
- package/data/core/component/component:syn-range.json +333 -0
- package/data/core/component/component:syn-select.json +347 -0
- package/data/core/component/component:syn-side-nav.json +234 -0
- package/data/core/component/component:syn-spinner.json +172 -0
- package/data/core/component/component:syn-switch.json +232 -0
- package/data/core/component/component:syn-tab-group.json +230 -0
- package/data/core/component/component:syn-tab-panel.json +139 -0
- package/data/core/component/component:syn-tab.json +149 -0
- package/data/core/component/component:syn-tag-group.json +168 -0
- package/data/core/component/component:syn-tag.json +173 -0
- package/data/core/component/component:syn-textarea.json +276 -0
- package/data/core/component/component:syn-tooltip.json +233 -0
- package/data/core/component/component:syn-validate.json +245 -0
- package/data/core/setup/setup:angular-components-module.json +36 -0
- package/data/core/setup/setup:angular-forms-module.json +37 -0
- package/data/core/setup/setup:angular-package.json +56 -0
- package/data/core/setup/setup:angular-validators-module.json +37 -0
- package/data/core/setup/setup:assets-package.json +56 -0
- package/data/core/setup/setup:components-package.json +59 -0
- package/data/core/setup/setup:fonts-package.json +46 -0
- package/data/core/setup/setup:react-package.json +60 -0
- package/data/core/setup/setup:styles-package.json +48 -0
- package/data/core/setup/setup:synergy-migrations.json +63 -0
- package/data/core/setup/setup:tokens-package.json +66 -0
- package/data/core/setup/setup:vue-package.json +50 -0
- package/data/core/style/style:syn-body.json +37 -0
- package/data/core/style/style:syn-heading.json +37 -0
- package/data/core/style/style:syn-link-list.json +37 -0
- package/data/core/style/style:syn-link.json +37 -0
- package/data/core/style/style:syn-table-cell.json +37 -0
- package/data/core/style/style:syn-table.json +37 -0
- package/data/core/style/style:syn-weight.json +37 -0
- package/data/core/template/template:appshell.json +22 -0
- package/data/core/template/template:breadcrumb.json +22 -0
- package/data/core/template/template:footer.json +22 -0
- package/data/core/template/template:forms.json +22 -0
- package/data/core/template/template:localization.json +22 -0
- package/data/core/template/template:table.json +22 -0
- package/data/core/template/template:tag-group.json +22 -0
- package/data/core/token/token:tokens-figma-variables-sick2018-dark-json.json +32 -0
- package/data/core/token/token:tokens-figma-variables-sick2018-light-json.json +32 -0
- package/data/core/token/token:tokens-figma-variables-sick2025-dark-json.json +32 -0
- package/data/core/token/token:tokens-figma-variables-sick2025-light-json.json +32 -0
- package/data/core/token/token:tokens-js-index-d-ts.json +31 -0
- package/data/core/token/token:tokens-js-index-js.json +31 -0
- package/data/core/token/token:tokens-scss-tokens-scss.json +31 -0
- package/data/core/token/token:tokens-themes-sick2018-dark-css.json +32 -0
- package/data/core/token/token:tokens-themes-sick2018-light-css.json +32 -0
- package/data/core/token/token:tokens-themes-sick2025-dark-css.json +32 -0
- package/data/core/token/token:tokens-themes-sick2025-light-css.json +32 -0
- package/data/core/utility/utility:fonts-sick-intl.json +35 -0
- package/data/index.json +1754 -0
- package/data/layers/examples/component/component:syn-accordion.md +410 -0
- package/data/layers/examples/component/component:syn-alert.md +262 -0
- package/data/layers/examples/component/component:syn-badge.md +102 -0
- package/data/layers/examples/component/component:syn-breadcrumb-item.md +16 -0
- package/data/layers/examples/component/component:syn-breadcrumb.md +110 -0
- package/data/layers/examples/component/component:syn-button-group.md +183 -0
- package/data/layers/examples/component/component:syn-button.md +289 -0
- package/data/layers/examples/component/component:syn-card.md +257 -0
- package/data/layers/examples/component/component:syn-checkbox.md +159 -0
- package/data/layers/examples/component/component:syn-combobox.md +629 -0
- package/data/layers/examples/component/component:syn-details.md +202 -0
- package/data/layers/examples/component/component:syn-dialog.md +349 -0
- package/data/layers/examples/component/component:syn-divider.md +57 -0
- package/data/layers/examples/component/component:syn-drawer.md +346 -0
- package/data/layers/examples/component/component:syn-dropdown.md +165 -0
- package/data/layers/examples/component/component:syn-file.md +192 -0
- package/data/layers/examples/component/component:syn-header.md +171 -0
- package/data/layers/examples/component/component:syn-icon-button.md +141 -0
- package/data/layers/examples/component/component:syn-icon.md +130 -0
- package/data/layers/examples/component/component:syn-input.md +294 -0
- package/data/layers/examples/component/component:syn-menu-item.md +132 -0
- package/data/layers/examples/component/component:syn-menu-label.md +17 -0
- package/data/layers/examples/component/component:syn-menu.md +66 -0
- package/data/layers/examples/component/component:syn-nav-item.md +154 -0
- package/data/layers/examples/component/component:syn-optgroup.md +67 -0
- package/data/layers/examples/component/component:syn-option.md +54 -0
- package/data/layers/examples/component/component:syn-pagination.md +92 -0
- package/data/layers/examples/component/component:syn-popup.md +705 -0
- package/data/layers/examples/component/component:syn-prio-nav.md +42 -0
- package/data/layers/examples/component/component:syn-progress-bar.md +87 -0
- package/data/layers/examples/component/component:syn-progress-ring.md +99 -0
- package/data/layers/examples/component/component:syn-radio-group.md +184 -0
- package/data/layers/examples/component/component:syn-radio.md +93 -0
- package/data/layers/examples/component/component:syn-range-tick.md +110 -0
- package/data/layers/examples/component/component:syn-range.md +403 -0
- package/data/layers/examples/component/component:syn-select.md +359 -0
- package/data/layers/examples/component/component:syn-side-nav.md +627 -0
- package/data/layers/examples/component/component:syn-spinner.md +45 -0
- package/data/layers/examples/component/component:syn-switch.md +113 -0
- package/data/layers/examples/component/component:syn-tab-group.md +318 -0
- package/data/layers/examples/component/component:syn-tab-panel.md +38 -0
- package/data/layers/examples/component/component:syn-tab.md +11 -0
- package/data/layers/examples/component/component:syn-tag-group.md +197 -0
- package/data/layers/examples/component/component:syn-tag.md +60 -0
- package/data/layers/examples/component/component:syn-textarea.md +153 -0
- package/data/layers/examples/component/component:syn-tooltip.md +220 -0
- package/data/layers/examples/component/component:syn-validate.md +349 -0
- package/data/layers/examples/style/style:syn-body.md +5 -0
- package/data/layers/examples/style/style:syn-heading.md +5 -0
- package/data/layers/examples/style/style:syn-link-list.md +213 -0
- package/data/layers/examples/style/style:syn-link.md +116 -0
- package/data/layers/examples/style/style:syn-table-cell.md +127 -0
- package/data/layers/examples/style/style:syn-table.md +201 -0
- package/data/layers/examples/style/style:syn-weight.md +5 -0
- package/data/layers/examples/template/template:appshell.md +2274 -0
- package/data/layers/examples/template/template:breadcrumb.md +240 -0
- package/data/layers/examples/template/template:footer.md +353 -0
- package/data/layers/examples/template/template:forms.md +536 -0
- package/data/layers/examples/template/template:localization.md +263 -0
- package/data/layers/examples/template/template:table.md +1143 -0
- package/data/layers/examples/template/template:tag-group.md +419 -0
- package/data/layers/full/assets/sick2018/js/index.ts +2167 -0
- package/data/layers/full/assets/sick2025/js/filled.ts +3704 -0
- package/data/layers/full/assets/sick2025/js/outline.ts +3704 -0
- package/data/layers/full/component/component:syn-accordion/angular/accordion.component.ts +80 -0
- package/data/layers/full/component/component:syn-accordion/components/accordion.component.ts +111 -0
- package/data/layers/full/component/component:syn-accordion/components/accordion.styles.ts +15 -0
- package/data/layers/full/component/component:syn-accordion/components/accordion.ts +12 -0
- package/data/layers/full/component/component:syn-accordion/react/SynAccordionJSXElement.ts +1 -0
- package/data/layers/full/component/component:syn-accordion/react/accordion.ts +30 -0
- package/data/layers/full/component/component:syn-accordion/vue/SynVueAccordion.vue +64 -0
- package/data/layers/full/component/component:syn-alert/angular/alert.component.ts +169 -0
- package/data/layers/full/component/component:syn-alert/components/alert.component.ts +322 -0
- package/data/layers/full/component/component:syn-alert/components/alert.styles.ts +203 -0
- package/data/layers/full/component/component:syn-alert/components/alert.ts +13 -0
- package/data/layers/full/component/component:syn-alert/react/SynAlertJSXElement.ts +9 -0
- package/data/layers/full/component/component:syn-alert/react/alert.ts +60 -0
- package/data/layers/full/component/component:syn-alert/vue/SynVueAlert.vue +135 -0
- package/data/layers/full/component/component:syn-badge/angular/badge.component.ts +53 -0
- package/data/layers/full/component/component:syn-badge/components/badge.component.ts +58 -0
- package/data/layers/full/component/component:syn-badge/components/badge.custom.styles.ts +62 -0
- package/data/layers/full/component/component:syn-badge/components/badge.styles.ts +52 -0
- package/data/layers/full/component/component:syn-badge/components/badge.ts +13 -0
- package/data/layers/full/component/component:syn-badge/react/SynBadgeJSXElement.ts +1 -0
- package/data/layers/full/component/component:syn-badge/react/badge.ts +29 -0
- package/data/layers/full/component/component:syn-badge/vue/SynVueBadge.vue +53 -0
- package/data/layers/full/component/component:syn-breadcrumb/angular/breadcrumb.component.ts +58 -0
- package/data/layers/full/component/component:syn-breadcrumb/components/breadcrumb.component.ts +103 -0
- package/data/layers/full/component/component:syn-breadcrumb/components/breadcrumb.custom.styles.ts +5 -0
- package/data/layers/full/component/component:syn-breadcrumb/components/breadcrumb.styles.ts +11 -0
- package/data/layers/full/component/component:syn-breadcrumb/components/breadcrumb.ts +13 -0
- package/data/layers/full/component/component:syn-breadcrumb/react/SynBreadcrumbJSXElement.ts +1 -0
- package/data/layers/full/component/component:syn-breadcrumb/react/breadcrumb.ts +32 -0
- package/data/layers/full/component/component:syn-breadcrumb/vue/SynVueBreadcrumb.vue +58 -0
- package/data/layers/full/component/component:syn-breadcrumb-item/angular/breadcrumb-item.component.ts +88 -0
- package/data/layers/full/component/component:syn-breadcrumb-item/components/breadcrumb-item.component.ts +132 -0
- package/data/layers/full/component/component:syn-breadcrumb-item/components/breadcrumb-item.custom.styles.ts +78 -0
- package/data/layers/full/component/component:syn-breadcrumb-item/components/breadcrumb-item.styles.ts +88 -0
- package/data/layers/full/component/component:syn-breadcrumb-item/components/breadcrumb-item.ts +13 -0
- package/data/layers/full/component/component:syn-breadcrumb-item/react/SynBreadcrumbItemJSXElement.ts +4 -0
- package/data/layers/full/component/component:syn-breadcrumb-item/react/breadcrumb-item.ts +37 -0
- package/data/layers/full/component/component:syn-breadcrumb-item/vue/SynVueBreadcrumbItem.vue +76 -0
- package/data/layers/full/component/component:syn-button/angular/button.component.ts +318 -0
- package/data/layers/full/component/component:syn-button/components/button.component.ts +315 -0
- package/data/layers/full/component/component:syn-button/components/button.custom.styles.ts +245 -0
- package/data/layers/full/component/component:syn-button/components/button.styles.ts +361 -0
- package/data/layers/full/component/component:syn-button/components/button.ts +13 -0
- package/data/layers/full/component/component:syn-button/react/SynButtonJSXElement.ts +8 -0
- package/data/layers/full/component/component:syn-button/react/button.ts +56 -0
- package/data/layers/full/component/component:syn-button/vue/SynVueButton.vue +204 -0
- package/data/layers/full/component/component:syn-button-group/angular/button-group.component.ts +79 -0
- package/data/layers/full/component/component:syn-button-group/components/button-group.component.ts +171 -0
- package/data/layers/full/component/component:syn-button-group/components/button-group.custom.styles.ts +5 -0
- package/data/layers/full/component/component:syn-button-group/components/button-group.styles.ts +14 -0
- package/data/layers/full/component/component:syn-button-group/components/button-group.ts +13 -0
- package/data/layers/full/component/component:syn-button-group/react/SynButtonGroupJSXElement.ts +1 -0
- package/data/layers/full/component/component:syn-button-group/react/button-group.ts +29 -0
- package/data/layers/full/component/component:syn-button-group/vue/SynVueButtonGroup.vue +67 -0
- package/data/layers/full/component/component:syn-card/angular/card.component.ts +83 -0
- package/data/layers/full/component/component:syn-card/components/card.component.ts +65 -0
- package/data/layers/full/component/component:syn-card/components/card.custom.styles.ts +60 -0
- package/data/layers/full/component/component:syn-card/components/card.styles.ts +70 -0
- package/data/layers/full/component/component:syn-card/components/card.ts +13 -0
- package/data/layers/full/component/component:syn-card/react/SynCardJSXElement.ts +1 -0
- package/data/layers/full/component/component:syn-card/react/card.ts +41 -0
- package/data/layers/full/component/component:syn-card/vue/SynVueCard.vue +73 -0
- package/data/layers/full/component/component:syn-checkbox/angular/checkbox.component.ts +273 -0
- package/data/layers/full/component/component:syn-checkbox/components/checkbox.component.ts +287 -0
- package/data/layers/full/component/component:syn-checkbox/components/checkbox.styles.ts +183 -0
- package/data/layers/full/component/component:syn-checkbox/components/checkbox.ts +13 -0
- package/data/layers/full/component/component:syn-checkbox/react/SynCheckboxJSXElement.ts +10 -0
- package/data/layers/full/component/component:syn-checkbox/react/checkbox.ts +64 -0
- package/data/layers/full/component/component:syn-checkbox/vue/SynVueCheckbox.vue +191 -0
- package/data/layers/full/component/component:syn-combobox/angular/combobox.component.ts +516 -0
- package/data/layers/full/component/component:syn-combobox/components/combobox.component.ts +1684 -0
- package/data/layers/full/component/component:syn-combobox/components/combobox.styles.ts +393 -0
- package/data/layers/full/component/component:syn-combobox/components/combobox.ts +12 -0
- package/data/layers/full/component/component:syn-combobox/components/option-renderer.ts +47 -0
- package/data/layers/full/component/component:syn-combobox/components/utils.ts +134 -0
- package/data/layers/full/component/component:syn-combobox/react/SynComboboxJSXElement.ts +16 -0
- package/data/layers/full/component/component:syn-combobox/react/combobox.ts +118 -0
- package/data/layers/full/component/component:syn-combobox/vue/SynVueCombobox.vue +350 -0
- package/data/layers/full/component/component:syn-details/angular/details.component.ts +186 -0
- package/data/layers/full/component/component:syn-details/components/details.component.ts +261 -0
- package/data/layers/full/component/component:syn-details/components/details.styles.ts +181 -0
- package/data/layers/full/component/component:syn-details/components/details.ts +13 -0
- package/data/layers/full/component/component:syn-details/react/SynDetailsJSXElement.ts +9 -0
- package/data/layers/full/component/component:syn-details/react/details.ts +65 -0
- package/data/layers/full/component/component:syn-details/vue/SynVueDetails.vue +136 -0
- package/data/layers/full/component/component:syn-dialog/angular/dialog.component.ts +201 -0
- package/data/layers/full/component/component:syn-dialog/components/dialog.component.ts +367 -0
- package/data/layers/full/component/component:syn-dialog/components/dialog.styles.ts +130 -0
- package/data/layers/full/component/component:syn-dialog/components/dialog.ts +13 -0
- package/data/layers/full/component/component:syn-dialog/react/SynDialogJSXElement.ts +11 -0
- package/data/layers/full/component/component:syn-dialog/react/dialog.ts +91 -0
- package/data/layers/full/component/component:syn-dialog/vue/SynVueDialog.vue +169 -0
- package/data/layers/full/component/component:syn-divider/angular/divider.component.ts +55 -0
- package/data/layers/full/component/component:syn-divider/components/divider.component.ts +34 -0
- package/data/layers/full/component/component:syn-divider/components/divider.styles.ts +22 -0
- package/data/layers/full/component/component:syn-divider/components/divider.ts +13 -0
- package/data/layers/full/component/component:syn-divider/react/SynDividerJSXElement.ts +1 -0
- package/data/layers/full/component/component:syn-divider/react/divider.ts +29 -0
- package/data/layers/full/component/component:syn-divider/vue/SynVueDivider.vue +51 -0
- package/data/layers/full/component/component:syn-drawer/angular/drawer.component.ts +234 -0
- package/data/layers/full/component/component:syn-drawer/components/drawer.component.ts +489 -0
- package/data/layers/full/component/component:syn-drawer/components/drawer.custom.styles.ts +78 -0
- package/data/layers/full/component/component:syn-drawer/components/drawer.styles.ts +158 -0
- package/data/layers/full/component/component:syn-drawer/components/drawer.ts +13 -0
- package/data/layers/full/component/component:syn-drawer/react/SynDrawerJSXElement.ts +11 -0
- package/data/layers/full/component/component:syn-drawer/react/drawer.ts +98 -0
- package/data/layers/full/component/component:syn-drawer/vue/SynVueDrawer.vue +188 -0
- package/data/layers/full/component/component:syn-dropdown/angular/dropdown.component.ts +208 -0
- package/data/layers/full/component/component:syn-dropdown/components/dropdown.component.ts +469 -0
- package/data/layers/full/component/component:syn-dropdown/components/dropdown.styles.ts +51 -0
- package/data/layers/full/component/component:syn-dropdown/components/dropdown.ts +13 -0
- package/data/layers/full/component/component:syn-dropdown/react/SynDropdownJSXElement.ts +9 -0
- package/data/layers/full/component/component:syn-dropdown/react/dropdown.ts +59 -0
- package/data/layers/full/component/component:syn-dropdown/vue/SynVueDropdown.vue +152 -0
- package/data/layers/full/component/component:syn-file/angular/file.component.ts +372 -0
- package/data/layers/full/component/component:syn-file/components/file.component.ts +645 -0
- package/data/layers/full/component/component:syn-file/components/file.styles.ts +197 -0
- package/data/layers/full/component/component:syn-file/components/file.ts +12 -0
- package/data/layers/full/component/component:syn-file/react/SynFileJSXElement.ts +10 -0
- package/data/layers/full/component/component:syn-file/react/file.ts +85 -0
- package/data/layers/full/component/component:syn-file/vue/SynVueFile.vue +256 -0
- package/data/layers/full/component/component:syn-header/angular/header.component.ts +149 -0
- package/data/layers/full/component/component:syn-header/components/header.component.ts +310 -0
- package/data/layers/full/component/component:syn-header/components/header.styles.ts +143 -0
- package/data/layers/full/component/component:syn-header/components/header.ts +12 -0
- package/data/layers/full/component/component:syn-header/react/SynHeaderJSXElement.ts +8 -0
- package/data/layers/full/component/component:syn-header/react/header.ts +68 -0
- package/data/layers/full/component/component:syn-header/vue/SynVueHeader.vue +126 -0
- package/data/layers/full/component/component:syn-icon/angular/icon.component.ts +115 -0
- package/data/layers/full/component/component:syn-icon/components/icon.component.ts +227 -0
- package/data/layers/full/component/component:syn-icon/components/icon.custom.styles.ts +5 -0
- package/data/layers/full/component/component:syn-icon/components/icon.styles.ts +18 -0
- package/data/layers/full/component/component:syn-icon/components/icon.ts +13 -0
- package/data/layers/full/component/component:syn-icon/components/library.default.ts +10 -0
- package/data/layers/full/component/component:syn-icon/components/library.migration.ts +317 -0
- package/data/layers/full/component/component:syn-icon/components/library.system.ts +46 -0
- package/data/layers/full/component/component:syn-icon/components/library.ts +54 -0
- package/data/layers/full/component/component:syn-icon/components/sick2018-system-icons.ts +37 -0
- package/data/layers/full/component/component:syn-icon/components/sick2025-system-icons.ts +34 -0
- package/data/layers/full/component/component:syn-icon/react/SynIconJSXElement.ts +4 -0
- package/data/layers/full/component/component:syn-icon/react/icon.ts +41 -0
- package/data/layers/full/component/component:syn-icon/vue/SynVueIcon.vue +100 -0
- package/data/layers/full/component/component:syn-icon-button/angular/icon-button.component.ts +185 -0
- package/data/layers/full/component/component:syn-icon-button/components/icon-button.component.ts +147 -0
- package/data/layers/full/component/component:syn-icon-button/components/icon-button.custom.styles.ts +79 -0
- package/data/layers/full/component/component:syn-icon-button/components/icon-button.styles.ts +52 -0
- package/data/layers/full/component/component:syn-icon-button/components/icon-button.ts +13 -0
- package/data/layers/full/component/component:syn-icon-button/react/SynIconButtonJSXElement.ts +4 -0
- package/data/layers/full/component/component:syn-icon-button/react/icon-button.ts +42 -0
- package/data/layers/full/component/component:syn-icon-button/vue/SynVueIconButton.vue +132 -0
- package/data/layers/full/component/component:syn-input/angular/input.component.ts +608 -0
- package/data/layers/full/component/component:syn-input/components/formatter.ts +75 -0
- package/data/layers/full/component/component:syn-input/components/input.component.ts +941 -0
- package/data/layers/full/component/component:syn-input/components/input.custom.styles.ts +278 -0
- package/data/layers/full/component/component:syn-input/components/input.styles.ts +280 -0
- package/data/layers/full/component/component:syn-input/components/input.ts +13 -0
- package/data/layers/full/component/component:syn-input/components/strategies.ts +79 -0
- package/data/layers/full/component/component:syn-input/react/SynInputJSXElement.ts +12 -0
- package/data/layers/full/component/component:syn-input/react/input.ts +91 -0
- package/data/layers/full/component/component:syn-input/vue/SynVueInput.vue +370 -0
- package/data/layers/full/component/component:syn-menu/angular/menu.component.ts +52 -0
- package/data/layers/full/component/component:syn-menu/components/menu.component.ts +191 -0
- package/data/layers/full/component/component:syn-menu/components/menu.styles.ts +37 -0
- package/data/layers/full/component/component:syn-menu/components/menu.ts +13 -0
- package/data/layers/full/component/component:syn-menu/react/SynMenuJSXElement.ts +4 -0
- package/data/layers/full/component/component:syn-menu/react/menu.ts +36 -0
- package/data/layers/full/component/component:syn-menu/vue/SynVueMenu.vue +48 -0
- package/data/layers/full/component/component:syn-menu-item/angular/menu-item.component.ts +121 -0
- package/data/layers/full/component/component:syn-menu-item/components/menu-item.component.ts +201 -0
- package/data/layers/full/component/component:syn-menu-item/components/menu-item.styles.ts +285 -0
- package/data/layers/full/component/component:syn-menu-item/components/menu-item.ts +13 -0
- package/data/layers/full/component/component:syn-menu-item/components/submenu-controller.ts +285 -0
- package/data/layers/full/component/component:syn-menu-item/react/SynMenuItemJSXElement.ts +1 -0
- package/data/layers/full/component/component:syn-menu-item/react/menu-item.ts +45 -0
- package/data/layers/full/component/component:syn-menu-item/vue/SynVueMenuItem.vue +91 -0
- package/data/layers/full/component/component:syn-menu-label/angular/menu-label.component.ts +48 -0
- package/data/layers/full/component/component:syn-menu-label/components/menu-label.component.ts +46 -0
- package/data/layers/full/component/component:syn-menu-label/components/menu-label.styles.ts +31 -0
- package/data/layers/full/component/component:syn-menu-label/components/menu-label.ts +13 -0
- package/data/layers/full/component/component:syn-menu-label/react/SynMenuLabelJSXElement.ts +1 -0
- package/data/layers/full/component/component:syn-menu-label/react/menu-label.ts +35 -0
- package/data/layers/full/component/component:syn-menu-label/vue/SynVueMenuLabel.vue +41 -0
- package/data/layers/full/component/component:syn-nav-item/angular/nav-item.component.ts +242 -0
- package/data/layers/full/component/component:syn-nav-item/components/nav-item.component.ts +491 -0
- package/data/layers/full/component/component:syn-nav-item/components/nav-item.styles.ts +333 -0
- package/data/layers/full/component/component:syn-nav-item/components/nav-item.ts +12 -0
- package/data/layers/full/component/component:syn-nav-item/react/SynNavItemJSXElement.ts +9 -0
- package/data/layers/full/component/component:syn-nav-item/react/nav-item.ts +82 -0
- package/data/layers/full/component/component:syn-nav-item/vue/SynVueNavItem.vue +182 -0
- package/data/layers/full/component/component:syn-optgroup/angular/optgroup.component.ts +79 -0
- package/data/layers/full/component/component:syn-optgroup/components/optgroup.component.ts +176 -0
- package/data/layers/full/component/component:syn-optgroup/components/optgroup.styles.ts +61 -0
- package/data/layers/full/component/component:syn-optgroup/components/optgroup.ts +13 -0
- package/data/layers/full/component/component:syn-optgroup/react/SynOptgroupJSXElement.ts +1 -0
- package/data/layers/full/component/component:syn-optgroup/react/optgroup.ts +41 -0
- package/data/layers/full/component/component:syn-optgroup/vue/SynVueOptgroup.vue +71 -0
- package/data/layers/full/component/component:syn-option/angular/option.component.ts +79 -0
- package/data/layers/full/component/component:syn-option/components/option-size.styles.ts +37 -0
- package/data/layers/full/component/component:syn-option/components/option.component.ts +191 -0
- package/data/layers/full/component/component:syn-option/components/option.styles.ts +165 -0
- package/data/layers/full/component/component:syn-option/components/option.ts +13 -0
- package/data/layers/full/component/component:syn-option/components/utility.ts +11 -0
- package/data/layers/full/component/component:syn-option/react/SynOptionJSXElement.ts +1 -0
- package/data/layers/full/component/component:syn-option/react/option.ts +37 -0
- package/data/layers/full/component/component:syn-option/vue/SynVueOption.vue +71 -0
- package/data/layers/full/component/component:syn-pagination/angular/pagination.component.ts +201 -0
- package/data/layers/full/component/component:syn-pagination/components/pagination.component.ts +452 -0
- package/data/layers/full/component/component:syn-pagination/components/pagination.styles.ts +128 -0
- package/data/layers/full/component/component:syn-pagination/components/pagination.ts +12 -0
- package/data/layers/full/component/component:syn-pagination/components/utility.ts +123 -0
- package/data/layers/full/component/component:syn-pagination/react/SynPaginationJSXElement.ts +7 -0
- package/data/layers/full/component/component:syn-pagination/react/pagination.ts +56 -0
- package/data/layers/full/component/component:syn-pagination/vue/SynVuePagination.vue +144 -0
- package/data/layers/full/component/component:syn-popup/angular/popup.component.ts +372 -0
- package/data/layers/full/component/component:syn-popup/components/popup.component.ts +582 -0
- package/data/layers/full/component/component:syn-popup/components/popup.styles.ts +70 -0
- package/data/layers/full/component/component:syn-popup/components/popup.ts +13 -0
- package/data/layers/full/component/component:syn-popup/react/SynPopupJSXElement.ts +4 -0
- package/data/layers/full/component/component:syn-popup/react/popup.ts +55 -0
- package/data/layers/full/component/component:syn-popup/vue/SynVuePopup.vue +233 -0
- package/data/layers/full/component/component:syn-prio-nav/angular/prio-nav.component.ts +67 -0
- package/data/layers/full/component/component:syn-prio-nav/components/prio-nav.component.ts +288 -0
- package/data/layers/full/component/component:syn-prio-nav/components/prio-nav.styles.ts +48 -0
- package/data/layers/full/component/component:syn-prio-nav/components/prio-nav.ts +12 -0
- package/data/layers/full/component/component:syn-prio-nav/components/utils.ts +57 -0
- package/data/layers/full/component/component:syn-prio-nav/react/SynPrioNavJSXElement.ts +1 -0
- package/data/layers/full/component/component:syn-prio-nav/react/prio-nav.ts +54 -0
- package/data/layers/full/component/component:syn-prio-nav/vue/SynVuePrioNav.vue +60 -0
- package/data/layers/full/component/component:syn-progress-bar/angular/progress-bar.component.ts +85 -0
- package/data/layers/full/component/component:syn-progress-bar/components/progress-bar.component.ts +67 -0
- package/data/layers/full/component/component:syn-progress-bar/components/progress-bar.custom.styles.ts +24 -0
- package/data/layers/full/component/component:syn-progress-bar/components/progress-bar.styles.ts +87 -0
- package/data/layers/full/component/component:syn-progress-bar/components/progress-bar.ts +13 -0
- package/data/layers/full/component/component:syn-progress-bar/react/SynProgressBarJSXElement.ts +1 -0
- package/data/layers/full/component/component:syn-progress-bar/react/progress-bar.ts +37 -0
- package/data/layers/full/component/component:syn-progress-bar/vue/SynVueProgressBar.vue +71 -0
- package/data/layers/full/component/component:syn-progress-ring/angular/progress-ring.component.ts +72 -0
- package/data/layers/full/component/component:syn-progress-ring/components/progress-ring.component.ts +83 -0
- package/data/layers/full/component/component:syn-progress-ring/components/progress-ring.custom.styles.ts +19 -0
- package/data/layers/full/component/component:syn-progress-ring/components/progress-ring.styles.ts +70 -0
- package/data/layers/full/component/component:syn-progress-ring/components/progress-ring.ts +13 -0
- package/data/layers/full/component/component:syn-progress-ring/react/SynProgressRingJSXElement.ts +4 -0
- package/data/layers/full/component/component:syn-progress-ring/react/progress-ring.ts +37 -0
- package/data/layers/full/component/component:syn-progress-ring/vue/SynVueProgressRing.vue +66 -0
- package/data/layers/full/component/component:syn-radio/angular/radio.component.ts +122 -0
- package/data/layers/full/component/component:syn-radio/components/radio.component.ts +131 -0
- package/data/layers/full/component/component:syn-radio/components/radio.styles.ts +179 -0
- package/data/layers/full/component/component:syn-radio/components/radio.ts +13 -0
- package/data/layers/full/component/component:syn-radio/react/SynRadioJSXElement.ts +4 -0
- package/data/layers/full/component/component:syn-radio/react/radio.ts +48 -0
- package/data/layers/full/component/component:syn-radio/vue/SynVueRadio.vue +104 -0
- package/data/layers/full/component/component:syn-radio-button/angular/radio-button.component.ts +123 -0
- package/data/layers/full/component/component:syn-radio-button/components/radio-button.component.ts +142 -0
- package/data/layers/full/component/component:syn-radio-button/components/radio-button.styles.ts +30 -0
- package/data/layers/full/component/component:syn-radio-button/components/radio-button.ts +13 -0
- package/data/layers/full/component/component:syn-radio-button/react/SynRadioButtonJSXElement.ts +4 -0
- package/data/layers/full/component/component:syn-radio-button/react/radio-button.ts +49 -0
- package/data/layers/full/component/component:syn-radio-button/vue/SynVueRadioButton.vue +105 -0
- package/data/layers/full/component/component:syn-radio-group/angular/radio-group.component.ts +204 -0
- package/data/layers/full/component/component:syn-radio-group/components/radio-group.component.ts +440 -0
- package/data/layers/full/component/component:syn-radio-group/components/radio-group.styles.ts +58 -0
- package/data/layers/full/component/component:syn-radio-group/components/radio-group.ts +13 -0
- package/data/layers/full/component/component:syn-radio-group/react/SynRadioGroupJSXElement.ts +8 -0
- package/data/layers/full/component/component:syn-radio-group/react/radio-group.ts +56 -0
- package/data/layers/full/component/component:syn-radio-group/vue/SynVueRadioGroup.vue +158 -0
- package/data/layers/full/component/component:syn-range/angular/range.component.ts +347 -0
- package/data/layers/full/component/component:syn-range/components/range.component.ts +933 -0
- package/data/layers/full/component/component:syn-range/components/range.styles.ts +310 -0
- package/data/layers/full/component/component:syn-range/components/range.ts +12 -0
- package/data/layers/full/component/component:syn-range/components/utility.ts +38 -0
- package/data/layers/full/component/component:syn-range/react/SynRangeJSXElement.ts +11 -0
- package/data/layers/full/component/component:syn-range/react/range.ts +92 -0
- package/data/layers/full/component/component:syn-range/vue/SynVueRange.vue +245 -0
- package/data/layers/full/component/component:syn-range-tick/angular/range-tick.component.ts +59 -0
- package/data/layers/full/component/component:syn-range-tick/components/range-tick.component.ts +50 -0
- package/data/layers/full/component/component:syn-range-tick/components/range-tick.styles.ts +34 -0
- package/data/layers/full/component/component:syn-range-tick/components/range-tick.ts +12 -0
- package/data/layers/full/component/component:syn-range-tick/react/SynRangeTickJSXElement.ts +1 -0
- package/data/layers/full/component/component:syn-range-tick/react/range-tick.ts +33 -0
- package/data/layers/full/component/component:syn-range-tick/vue/SynVueRangeTick.vue +57 -0
- package/data/layers/full/component/component:syn-select/angular/select.component.ts +439 -0
- package/data/layers/full/component/component:syn-select/components/select.component.ts +1056 -0
- package/data/layers/full/component/component:syn-select/components/select.styles.ts +380 -0
- package/data/layers/full/component/component:syn-select/components/select.ts +13 -0
- package/data/layers/full/component/component:syn-select/components/utility.ts +41 -0
- package/data/layers/full/component/component:syn-select/react/SynSelectJSXElement.ts +15 -0
- package/data/layers/full/component/component:syn-select/react/select.ts +101 -0
- package/data/layers/full/component/component:syn-select/vue/SynVueSelect.vue +301 -0
- package/data/layers/full/component/component:syn-side-nav/angular/side-nav.component.ts +210 -0
- package/data/layers/full/component/component:syn-side-nav/components/side-nav.component.ts +458 -0
- package/data/layers/full/component/component:syn-side-nav/components/side-nav.styles.ts +142 -0
- package/data/layers/full/component/component:syn-side-nav/components/side-nav.ts +12 -0
- package/data/layers/full/component/component:syn-side-nav/react/SynSideNavJSXElement.ts +9 -0
- package/data/layers/full/component/component:syn-side-nav/react/side-nav.ts +95 -0
- package/data/layers/full/component/component:syn-side-nav/vue/SynVueSideNav.vue +188 -0
- package/data/layers/full/component/component:syn-spinner/angular/spinner.component.ts +44 -0
- package/data/layers/full/component/component:syn-spinner/components/spinner.component.ts +35 -0
- package/data/layers/full/component/component:syn-spinner/components/spinner.custom.styles.ts +32 -0
- package/data/layers/full/component/component:syn-spinner/components/spinner.styles.ts +48 -0
- package/data/layers/full/component/component:syn-spinner/components/spinner.ts +13 -0
- package/data/layers/full/component/component:syn-spinner/react/SynSpinnerJSXElement.ts +1 -0
- package/data/layers/full/component/component:syn-spinner/react/spinner.ts +31 -0
- package/data/layers/full/component/component:syn-spinner/vue/SynVueSpinner.vue +35 -0
- package/data/layers/full/component/component:syn-switch/angular/switch.component.ts +257 -0
- package/data/layers/full/component/component:syn-switch/components/switch.component.ts +279 -0
- package/data/layers/full/component/component:syn-switch/components/switch.styles.ts +252 -0
- package/data/layers/full/component/component:syn-switch/components/switch.ts +13 -0
- package/data/layers/full/component/component:syn-switch/react/SynSwitchJSXElement.ts +10 -0
- package/data/layers/full/component/component:syn-switch/react/switch.ts +63 -0
- package/data/layers/full/component/component:syn-switch/vue/SynVueSwitch.vue +183 -0
- package/data/layers/full/component/component:syn-tab/angular/tab.component.ts +109 -0
- package/data/layers/full/component/component:syn-tab/components/tab.component.ts +125 -0
- package/data/layers/full/component/component:syn-tab/components/tab.custom.styles.ts +94 -0
- package/data/layers/full/component/component:syn-tab/components/tab.styles.ts +70 -0
- package/data/layers/full/component/component:syn-tab/components/tab.ts +13 -0
- package/data/layers/full/component/component:syn-tab/react/SynTabJSXElement.ts +4 -0
- package/data/layers/full/component/component:syn-tab/react/tab.ts +42 -0
- package/data/layers/full/component/component:syn-tab/vue/SynVueTab.vue +91 -0
- package/data/layers/full/component/component:syn-tab-group/angular/tab-group.component.ts +166 -0
- package/data/layers/full/component/component:syn-tab-group/components/tab-group.component.ts +551 -0
- package/data/layers/full/component/component:syn-tab-group/components/tab-group.custom.styles.ts +218 -0
- package/data/layers/full/component/component:syn-tab-group/components/tab-group.styles.ts +193 -0
- package/data/layers/full/component/component:syn-tab-group/components/tab-group.ts +13 -0
- package/data/layers/full/component/component:syn-tab-group/react/SynTabGroupJSXElement.ts +4 -0
- package/data/layers/full/component/component:syn-tab-group/react/tab-group.ts +58 -0
- package/data/layers/full/component/component:syn-tab-group/vue/SynVueTabGroup.vue +126 -0
- package/data/layers/full/component/component:syn-tab-panel/angular/tab-panel.component.ts +68 -0
- package/data/layers/full/component/component:syn-tab-panel/components/tab-panel.component.ts +60 -0
- package/data/layers/full/component/component:syn-tab-panel/components/tab-panel.custom.styles.ts +8 -0
- package/data/layers/full/component/component:syn-tab-panel/components/tab-panel.styles.ts +20 -0
- package/data/layers/full/component/component:syn-tab-panel/components/tab-panel.ts +13 -0
- package/data/layers/full/component/component:syn-tab-panel/react/SynTabPanelJSXElement.ts +1 -0
- package/data/layers/full/component/component:syn-tab-panel/react/tab-panel.ts +31 -0
- package/data/layers/full/component/component:syn-tab-panel/vue/SynVueTabPanel.vue +60 -0
- package/data/layers/full/component/component:syn-tag/angular/tag.component.ts +83 -0
- package/data/layers/full/component/component:syn-tag/components/tag.component.ts +83 -0
- package/data/layers/full/component/component:syn-tag/components/tag.custom.styles.ts +121 -0
- package/data/layers/full/component/component:syn-tag/components/tag.styles.ts +58 -0
- package/data/layers/full/component/component:syn-tag/components/tag.ts +13 -0
- package/data/layers/full/component/component:syn-tag/react/SynTagJSXElement.ts +4 -0
- package/data/layers/full/component/component:syn-tag/react/tag.ts +43 -0
- package/data/layers/full/component/component:syn-tag/vue/SynVueTag.vue +81 -0
- package/data/layers/full/component/component:syn-tag-group/angular/tag-group.component.ts +83 -0
- package/data/layers/full/component/component:syn-tag-group/components/tag-group.component.ts +95 -0
- package/data/layers/full/component/component:syn-tag-group/components/tag-group.styles.ts +49 -0
- package/data/layers/full/component/component:syn-tag-group/components/tag-group.ts +12 -0
- package/data/layers/full/component/component:syn-tag-group/react/SynTagGroupJSXElement.ts +1 -0
- package/data/layers/full/component/component:syn-tag-group/react/tag-group.ts +33 -0
- package/data/layers/full/component/component:syn-tag-group/vue/SynVueTagGroup.vue +69 -0
- package/data/layers/full/component/component:syn-textarea/angular/textarea.component.ts +396 -0
- package/data/layers/full/component/component:syn-textarea/components/textarea.component.ts +400 -0
- package/data/layers/full/component/component:syn-textarea/components/textarea.styles.ts +208 -0
- package/data/layers/full/component/component:syn-textarea/components/textarea.ts +13 -0
- package/data/layers/full/component/component:syn-textarea/react/SynTextareaJSXElement.ts +10 -0
- package/data/layers/full/component/component:syn-textarea/react/textarea.ts +60 -0
- package/data/layers/full/component/component:syn-textarea/vue/SynVueTextarea.vue +244 -0
- package/data/layers/full/component/component:syn-tooltip/angular/tooltip.component.ts +196 -0
- package/data/layers/full/component/component:syn-tooltip/components/tooltip.component.ts +312 -0
- package/data/layers/full/component/component:syn-tooltip/components/tooltip.styles.ts +62 -0
- package/data/layers/full/component/component:syn-tooltip/components/tooltip.ts +13 -0
- package/data/layers/full/component/component:syn-tooltip/react/SynTooltipJSXElement.ts +9 -0
- package/data/layers/full/component/component:syn-tooltip/react/tooltip.ts +63 -0
- package/data/layers/full/component/component:syn-tooltip/vue/SynVueTooltip.vue +150 -0
- package/data/layers/full/component/component:syn-validate/angular/validate.component.ts +137 -0
- package/data/layers/full/component/component:syn-validate/components/utility.ts +160 -0
- package/data/layers/full/component/component:syn-validate/components/validate.component.ts +590 -0
- package/data/layers/full/component/component:syn-validate/components/validate.styles.ts +9 -0
- package/data/layers/full/component/component:syn-validate/components/validate.ts +12 -0
- package/data/layers/full/component/component:syn-validate/react/SynValidateJSXElement.ts +1 -0
- package/data/layers/full/component/component:syn-validate/react/validate.ts +44 -0
- package/data/layers/full/component/component:syn-validate/vue/SynVueValidate.vue +107 -0
- package/data/layers/full/fonts/sick-intl/LICENSE +3 -0
- package/data/layers/full/fonts/sick-intl/font.css +17 -0
- package/data/layers/full/setup/setup:angular-components-module/angular/index.ts +53 -0
- package/data/layers/full/setup/setup:angular-components-module/angular/synergy.module.ts +115 -0
- package/data/layers/full/setup/setup:angular-forms-module/angular/forms.module.ts +92 -0
- package/data/layers/full/setup/setup:angular-package/angular/CHANGELOG.md +628 -0
- package/data/layers/full/setup/setup:angular-package/angular/LIMITATIONS.md +32 -0
- package/data/layers/full/setup/setup:angular-package/angular/README.md +393 -0
- package/data/layers/full/setup/setup:angular-package/angular/index.ts +9 -0
- package/data/layers/full/setup/setup:angular-package/angular/package.json +64 -0
- package/data/layers/full/setup/setup:angular-validators-module/angular/validators.ts +125 -0
- package/data/layers/full/setup/setup:assets-package/assets/BREAKING_CHANGES.md +305 -0
- package/data/layers/full/setup/setup:assets-package/assets/CHANGELOG.md +382 -0
- package/data/layers/full/setup/setup:assets-package/assets/README.md +103 -0
- package/data/layers/full/setup/setup:assets-package/assets/package.json +98 -0
- package/data/layers/full/setup/setup:components-package/components/BREAKING_CHANGES.md +908 -0
- package/data/layers/full/setup/setup:components-package/components/CHANGELOG.md +2166 -0
- package/data/layers/full/setup/setup:components-package/components/LIMITATIONS.md +433 -0
- package/data/layers/full/setup/setup:components-package/components/README.md +231 -0
- package/data/layers/full/setup/setup:components-package/components/package.json +125 -0
- package/data/layers/full/setup/setup:components-package/docs/icon-usage.md +411 -0
- package/data/layers/full/setup/setup:components-package/docs/prerequisites.md +319 -0
- package/data/layers/full/setup/setup:fonts-package/fonts/CHANGELOG.md +65 -0
- package/data/layers/full/setup/setup:fonts-package/fonts/README.md +164 -0
- package/data/layers/full/setup/setup:fonts-package/fonts/package.json +72 -0
- package/data/layers/full/setup/setup:react-package/react/CHANGELOG.md +551 -0
- package/data/layers/full/setup/setup:react-package/react/LIMITATIONS.md +31 -0
- package/data/layers/full/setup/setup:react-package/react/README.md +262 -0
- package/data/layers/full/setup/setup:react-package/react/index.ts +53 -0
- package/data/layers/full/setup/setup:react-package/react/package.json +54 -0
- package/data/layers/full/setup/setup:react-package/react/syn-jsx-elements.ts +2830 -0
- package/data/layers/full/setup/setup:styles-package/styles/BREAKING_CHANGES.md +105 -0
- package/data/layers/full/setup/setup:styles-package/styles/CHANGELOG.md +196 -0
- package/data/layers/full/setup/setup:styles-package/styles/README.md +132 -0
- package/data/layers/full/setup/setup:styles-package/styles/package.json +57 -0
- package/data/layers/full/setup/setup:synergy-migrations/components/BREAKING_CHANGES.md +908 -0
- package/data/layers/full/setup/setup:synergy-migrations/davinci/basic-elements.md +1859 -0
- package/data/layers/full/setup/setup:synergy-migrations/migration/index.md +57 -0
- package/data/layers/full/setup/setup:synergy-migrations/migration/v2-2018-to-v2-2025.md +481 -0
- package/data/layers/full/setup/setup:synergy-migrations/migration/v2-2018-to-v3-2018.md +147 -0
- package/data/layers/full/setup/setup:synergy-migrations/migration/v2-2018-to-v3-2025.md +150 -0
- package/data/layers/full/setup/setup:synergy-migrations/migration/v2-2025-to-v3-2025.md +133 -0
- package/data/layers/full/setup/setup:tokens-package/tokens/BREAKING_CHANGES.md +180 -0
- package/data/layers/full/setup/setup:tokens-package/tokens/CHANGELOG.md +967 -0
- package/data/layers/full/setup/setup:tokens-package/tokens/README.md +435 -0
- package/data/layers/full/setup/setup:tokens-package/tokens/package.json +81 -0
- package/data/layers/full/setup/setup:vue-package/vue/CHANGELOG.md +618 -0
- package/data/layers/full/setup/setup:vue-package/vue/LIMITATIONS.md +53 -0
- package/data/layers/full/setup/setup:vue-package/vue/README.md +252 -0
- package/data/layers/full/setup/setup:vue-package/vue/index.ts +53 -0
- package/data/layers/full/setup/setup:vue-package/vue/package.json +58 -0
- package/data/layers/full/styles/link/index.css +89 -0
- package/data/layers/full/styles/link-list/index.css +51 -0
- package/data/layers/full/styles/tables/table-cell.css +125 -0
- package/data/layers/full/styles/tables/table.css +16 -0
- package/data/layers/full/styles/typography/body.css +19 -0
- package/data/layers/full/styles/typography/heading.css +19 -0
- package/data/layers/full/styles/typography/weight.css +16 -0
- package/data/layers/full/tokens/figma-variables/sick2018-dark.json +2268 -0
- package/data/layers/full/tokens/figma-variables/sick2018-light.json +2268 -0
- package/data/layers/full/tokens/figma-variables/sick2025-dark.json +2268 -0
- package/data/layers/full/tokens/figma-variables/sick2025-light.json +2268 -0
- package/data/layers/full/tokens/js/index.d.ts +2224 -0
- package/data/layers/full/tokens/js/index.js +2224 -0
- package/data/layers/full/tokens/scss/_tokens.scss +448 -0
- package/data/layers/full/tokens/themes/sick2018_dark.css +454 -0
- package/data/layers/full/tokens/themes/sick2018_light.css +454 -0
- package/data/layers/full/tokens/themes/sick2025_dark.css +454 -0
- package/data/layers/full/tokens/themes/sick2025_light.css +454 -0
- package/data/layers/interface/component/component:syn-accordion.json +95 -0
- package/data/layers/interface/component/component:syn-accordion.md +57 -0
- package/data/layers/interface/component/component:syn-alert.json +182 -0
- package/data/layers/interface/component/component:syn-alert.md +135 -0
- package/data/layers/interface/component/component:syn-badge.json +43 -0
- package/data/layers/interface/component/component:syn-badge.md +39 -0
- package/data/layers/interface/component/component:syn-breadcrumb-item.json +114 -0
- package/data/layers/interface/component/component:syn-breadcrumb-item.md +64 -0
- package/data/layers/interface/component/component:syn-breadcrumb.json +61 -0
- package/data/layers/interface/component/component:syn-breadcrumb.md +44 -0
- package/data/layers/interface/component/component:syn-button-group.json +86 -0
- package/data/layers/interface/component/component:syn-button-group.md +57 -0
- package/data/layers/interface/component/component:syn-button.json +424 -0
- package/data/layers/interface/component/component:syn-button.md +287 -0
- package/data/layers/interface/component/component:syn-card.json +86 -0
- package/data/layers/interface/component/component:syn-card.md +55 -0
- package/data/layers/interface/component/component:syn-checkbox.json +330 -0
- package/data/layers/interface/component/component:syn-checkbox.md +237 -0
- package/data/layers/interface/component/component:syn-combobox.json +667 -0
- package/data/layers/interface/component/component:syn-combobox.md +388 -0
- package/data/layers/interface/component/component:syn-details.json +202 -0
- package/data/layers/interface/component/component:syn-details.md +129 -0
- package/data/layers/interface/component/component:syn-dialog.json +194 -0
- package/data/layers/interface/component/component:syn-dialog.md +136 -0
- package/data/layers/interface/component/component:syn-divider.json +39 -0
- package/data/layers/interface/component/component:syn-divider.md +31 -0
- package/data/layers/interface/component/component:syn-drawer.json +239 -0
- package/data/layers/interface/component/component:syn-drawer.md +154 -0
- package/data/layers/interface/component/component:syn-dropdown.json +272 -0
- package/data/layers/interface/component/component:syn-dropdown.md +171 -0
- package/data/layers/interface/component/component:syn-file.json +445 -0
- package/data/layers/interface/component/component:syn-file.md +280 -0
- package/data/layers/interface/component/component:syn-header.json +149 -0
- package/data/layers/interface/component/component:syn-header.md +102 -0
- package/data/layers/interface/component/component:syn-icon-button.json +201 -0
- package/data/layers/interface/component/component:syn-icon-button.md +157 -0
- package/data/layers/interface/component/component:syn-icon.json +105 -0
- package/data/layers/interface/component/component:syn-icon.md +77 -0
- package/data/layers/interface/component/component:syn-input.json +758 -0
- package/data/layers/interface/component/component:syn-input.md +522 -0
- package/data/layers/interface/component/component:syn-menu-item.json +185 -0
- package/data/layers/interface/component/component:syn-menu-item.md +100 -0
- package/data/layers/interface/component/component:syn-menu-label.json +36 -0
- package/data/layers/interface/component/component:syn-menu-label.md +34 -0
- package/data/layers/interface/component/component:syn-menu.json +41 -0
- package/data/layers/interface/component/component:syn-menu.md +32 -0
- package/data/layers/interface/component/component:syn-nav-item.json +269 -0
- package/data/layers/interface/component/component:syn-nav-item.md +198 -0
- package/data/layers/interface/component/component:syn-optgroup.json +98 -0
- package/data/layers/interface/component/component:syn-optgroup.md +60 -0
- package/data/layers/interface/component/component:syn-option.json +149 -0
- package/data/layers/interface/component/component:syn-option.md +74 -0
- package/data/layers/interface/component/component:syn-pagination.json +200 -0
- package/data/layers/interface/component/component:syn-pagination.md +128 -0
- package/data/layers/interface/component/component:syn-popup.json +360 -0
- package/data/layers/interface/component/component:syn-popup.md +258 -0
- package/data/layers/interface/component/component:syn-prio-nav.json +51 -0
- package/data/layers/interface/component/component:syn-prio-nav.md +43 -0
- package/data/layers/interface/component/component:syn-progress-bar.json +81 -0
- package/data/layers/interface/component/component:syn-progress-bar.md +59 -0
- package/data/layers/interface/component/component:syn-progress-ring.json +74 -0
- package/data/layers/interface/component/component:syn-progress-ring.md +49 -0
- package/data/layers/interface/component/component:syn-radio-button.json +164 -0
- package/data/layers/interface/component/component:syn-radio-button.md +102 -0
- package/data/layers/interface/component/component:syn-radio-group.json +259 -0
- package/data/layers/interface/component/component:syn-radio-group.md +161 -0
- package/data/layers/interface/component/component:syn-radio.json +140 -0
- package/data/layers/interface/component/component:syn-radio.md +88 -0
- package/data/layers/interface/component/component:syn-range-tick.json +51 -0
- package/data/layers/interface/component/component:syn-range-tick.md +41 -0
- package/data/layers/interface/component/component:syn-range.json +429 -0
- package/data/layers/interface/component/component:syn-range.md +266 -0
- package/data/layers/interface/component/component:syn-select.json +580 -0
- package/data/layers/interface/component/component:syn-select.md +341 -0
- package/data/layers/interface/component/component:syn-side-nav.json +189 -0
- package/data/layers/interface/component/component:syn-side-nav.md +123 -0
- package/data/layers/interface/component/component:syn-spinner.json +21 -0
- package/data/layers/interface/component/component:syn-spinner.md +24 -0
- package/data/layers/interface/component/component:syn-switch.json +301 -0
- package/data/layers/interface/component/component:syn-switch.md +220 -0
- package/data/layers/interface/component/component:syn-tab-group.json +234 -0
- package/data/layers/interface/component/component:syn-tab-group.md +120 -0
- package/data/layers/interface/component/component:syn-tab-panel.json +64 -0
- package/data/layers/interface/component/component:syn-tab-panel.md +48 -0
- package/data/layers/interface/component/component:syn-tab.json +121 -0
- package/data/layers/interface/component/component:syn-tab.md +80 -0
- package/data/layers/interface/component/component:syn-tag-group.json +98 -0
- package/data/layers/interface/component/component:syn-tag-group.md +61 -0
- package/data/layers/interface/component/component:syn-tag.json +78 -0
- package/data/layers/interface/component/component:syn-tag.md +63 -0
- package/data/layers/interface/component/component:syn-textarea.json +532 -0
- package/data/layers/interface/component/component:syn-textarea.md +350 -0
- package/data/layers/interface/component/component:syn-tooltip.json +216 -0
- package/data/layers/interface/component/component:syn-tooltip.md +154 -0
- package/data/layers/interface/component/component:syn-validate.json +226 -0
- package/data/layers/interface/component/component:syn-validate.md +102 -0
- package/data/manifest.json +47 -0
- package/data/schemas/core-entity.schema.json +130 -0
- package/data/schemas/layer-ref.schema.json +22 -0
- package/data/schemas/manifest.schema.json +76 -0
- package/dist/index.d.ts +5 -0
- package/dist/index.js +5 -0
- package/dist/public/domains/assets.d.ts +34 -0
- package/dist/public/domains/assets.js +238 -0
- package/dist/public/domains/clusters.d.ts +21 -0
- package/dist/public/domains/clusters.js +189 -0
- package/dist/public/domains/components.d.ts +66 -0
- package/dist/public/domains/components.js +286 -0
- package/dist/public/domains/fonts.d.ts +21 -0
- package/dist/public/domains/fonts.js +141 -0
- package/dist/public/domains/migrations.d.ts +13 -0
- package/dist/public/domains/migrations.js +59 -0
- package/dist/public/domains/setup.d.ts +39 -0
- package/dist/public/domains/setup.js +144 -0
- package/dist/public/domains/styles.d.ts +47 -0
- package/dist/public/domains/styles.js +182 -0
- package/dist/public/domains/templates.d.ts +47 -0
- package/dist/public/domains/templates.js +182 -0
- package/dist/public/domains/tokens.d.ts +46 -0
- package/dist/public/domains/tokens.js +165 -0
- package/dist/public/index.d.ts +21 -0
- package/dist/public/index.js +11 -0
- package/dist/public/store.d.ts +19 -0
- package/dist/public/store.js +184 -0
- package/dist/public/types.d.ts +374 -0
- package/dist/public/types.js +5 -0
- package/dist/public/utils.d.ts +48 -0
- package/dist/public/utils.js +98 -0
- package/package.json +49 -7
- package/LICENSE +0 -9
- package/src/index.js +0 -1
|
@@ -0,0 +1,285 @@
|
|
|
1
|
+
import { css } from 'lit';
|
|
2
|
+
|
|
3
|
+
export default css`
|
|
4
|
+
/* stylelint-disable no-descending-specificity */
|
|
5
|
+
:host {
|
|
6
|
+
--submenu-offset: -2px;
|
|
7
|
+
|
|
8
|
+
/* Custom override for hiding the checkmark in menus it is not needed */
|
|
9
|
+
--display-checkmark: flex;
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* Default size settings for menu-item
|
|
13
|
+
* This prepares the custom sizes that we will add later on
|
|
14
|
+
* @see https://github.com/synergy-design-system/design/issues/277
|
|
15
|
+
*/
|
|
16
|
+
--menuitem-inset-border-horizontal: var(--syn-spacing-2x-small);
|
|
17
|
+
--menuitem-inset-border-vertical: calc(var(--syn-spacing-x-small) - 1px);
|
|
18
|
+
--menuitem-min-height: var(--syn-input-height-medium);
|
|
19
|
+
--menuitem-padding: var(--syn-input-spacing-medium);
|
|
20
|
+
--menuitem-font-size: var(--syn-input-font-size-medium);
|
|
21
|
+
--menuitem-icon-size: var(--syn-spacing-large);
|
|
22
|
+
|
|
23
|
+
display: block;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
:host([inert]) {
|
|
27
|
+
display: none;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
.menu-item {
|
|
31
|
+
align-items: center;
|
|
32
|
+
|
|
33
|
+
/*
|
|
34
|
+
* #1127: Brand2025 defines a small gap between options
|
|
35
|
+
* and rounded corners. We achieve that using an border
|
|
36
|
+
* that simulates the gap using the menu background color.
|
|
37
|
+
*/
|
|
38
|
+
border: solid var(--syn-panel-background-color);
|
|
39
|
+
|
|
40
|
+
/* Border Radius needs to be increased to cover the outline */
|
|
41
|
+
border-radius: calc(var(--syn-focus-ring-border-radius) + var(--menuitem-inset-border-vertical));
|
|
42
|
+
border-width: var(--menuitem-inset-border-horizontal) var(--menuitem-inset-border-vertical);
|
|
43
|
+
color: var(--syn-option-color);
|
|
44
|
+
cursor: pointer;
|
|
45
|
+
display: flex;
|
|
46
|
+
font-family: var(--syn-font-sans);
|
|
47
|
+
font-size: var(--menuitem-font-size);
|
|
48
|
+
font-weight: var(--syn-font-weight-normal);
|
|
49
|
+
letter-spacing: var(--syn-letter-spacing-normal);
|
|
50
|
+
line-height: var(--syn-line-height-normal);
|
|
51
|
+
|
|
52
|
+
/* Height is dependent on line-height of .option__label, which does not fit the layout completely */
|
|
53
|
+
min-height: var(--menuitem-min-height, var(--syn-input-height-medium));
|
|
54
|
+
padding: 0 calc(var(--menuitem-padding) - var(--menuitem-inset-border-vertical));
|
|
55
|
+
position: relative;
|
|
56
|
+
transition: var(--syn-transition-fast) fill;
|
|
57
|
+
/* stylelint-disable-next-line property-no-vendor-prefix */
|
|
58
|
+
-webkit-user-select: none;
|
|
59
|
+
user-select: none;
|
|
60
|
+
white-space: nowrap;
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
.menu-item.menu-item--disabled {
|
|
64
|
+
cursor: not-allowed;
|
|
65
|
+
|
|
66
|
+
/** #429: Use token for opacity */
|
|
67
|
+
opacity: var(--syn-opacity-50);
|
|
68
|
+
outline: none;
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
.menu-item.menu-item--loading {
|
|
72
|
+
cursor: wait;
|
|
73
|
+
outline: none;
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
.menu-item.menu-item--loading *:not(syn-spinner) {
|
|
77
|
+
opacity: var(--syn-opacity-50);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
.menu-item--loading syn-spinner {
|
|
81
|
+
--indicator-color: currentColor;
|
|
82
|
+
--track-width: 2px;
|
|
83
|
+
|
|
84
|
+
color: var(--syn-interactive-emphasis-color);
|
|
85
|
+
font-size: var(--syn-font-size-medium);
|
|
86
|
+
left: calc(var(--menuitem-padding) - var(--menuitem-inset-border-vertical));
|
|
87
|
+
opacity: 1;
|
|
88
|
+
position: absolute;
|
|
89
|
+
top: calc(50% - 0.5em);
|
|
90
|
+
}
|
|
91
|
+
|
|
92
|
+
.menu-item .menu-item__label {
|
|
93
|
+
display: inline-block;
|
|
94
|
+
flex: 1 1 auto;
|
|
95
|
+
overflow: hidden;
|
|
96
|
+
text-overflow: ellipsis;
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
.menu-item .menu-item__prefix {
|
|
100
|
+
align-items: center;
|
|
101
|
+
display: flex;
|
|
102
|
+
flex: 0 0 auto;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
.menu-item .menu-item__prefix::slotted(*) {
|
|
106
|
+
margin-inline-end: var(--syn-spacing-small);
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
.menu-item .menu-item__suffix {
|
|
110
|
+
align-items: center;
|
|
111
|
+
display: flex;
|
|
112
|
+
flex: 0 0 auto;
|
|
113
|
+
}
|
|
114
|
+
|
|
115
|
+
.menu-item .menu-item__suffix::slotted(*) {
|
|
116
|
+
margin-inline-start: var(--syn-spacing-small);
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
/**
|
|
120
|
+
* Set the default font size to make icons appear correct
|
|
121
|
+
*/
|
|
122
|
+
.menu-item .menu-item__prefix::slotted(syn-icon),
|
|
123
|
+
.menu-item .menu-item__suffix::slotted(syn-icon) {
|
|
124
|
+
color: var(--syn-option-icon-color);
|
|
125
|
+
font-size: var(--syn-font-size-x-large);
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
/**
|
|
129
|
+
* #1194: Make sure hover is only done on non disabled items
|
|
130
|
+
*/
|
|
131
|
+
:host(:hover) .menu-item:not(.menu-item--disabled) .menu-item__prefix::slotted(syn-icon),
|
|
132
|
+
:host(:hover) .menu-item:not(.menu-item--disabled) .menu-item__suffix::slotted(syn-icon) {
|
|
133
|
+
color: var(--syn-option-icon-color-hover);
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
:host(:focus-visible) .menu-item .menu-item__prefix::slotted(syn-icon),
|
|
137
|
+
:host(:focus-visible) .menu-item .menu-item__suffix::slotted(syn-icon) {
|
|
138
|
+
color: var(--syn-option-icon-color-active);
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
/* Safe triangle */
|
|
142
|
+
.menu-item--submenu-expanded::after {
|
|
143
|
+
clip-path: polygon(
|
|
144
|
+
var(--safe-triangle-cursor-x, 0) var(--safe-triangle-cursor-y, 0),
|
|
145
|
+
var(--safe-triangle-submenu-start-x, 0) var(--safe-triangle-submenu-start-y, 0),
|
|
146
|
+
var(--safe-triangle-submenu-end-x, 0) var(--safe-triangle-submenu-end-y, 0)
|
|
147
|
+
);
|
|
148
|
+
content: '';
|
|
149
|
+
inset: 0;
|
|
150
|
+
position: fixed;
|
|
151
|
+
z-index: calc(var(--syn-z-index-dropdown) - 1);
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
:host(:focus-visible) {
|
|
155
|
+
outline: none;
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
:host(:hover:not([aria-disabled='true']):not(:focus-visible)) .menu-item,
|
|
159
|
+
.menu-item--submenu-expanded {
|
|
160
|
+
background-color: var(--syn-option-background-color-hover);
|
|
161
|
+
color: var(--syn-option-color-hover);
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
:host(:focus-visible) .menu-item {
|
|
165
|
+
background-color: var(--syn-option-background-color-active);
|
|
166
|
+
color: var(--syn-color-neutral-0);
|
|
167
|
+
opacity: 1;
|
|
168
|
+
outline: none;
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
.menu-item .menu-item__check,
|
|
172
|
+
.menu-item .menu-item__chevron {
|
|
173
|
+
align-items: center;
|
|
174
|
+
display: var(--display-checkmark);
|
|
175
|
+
flex: 0 0 auto;
|
|
176
|
+
font-size: var(--syn-font-size-x-large);
|
|
177
|
+
justify-content: center;
|
|
178
|
+
visibility: hidden;
|
|
179
|
+
width: var(--syn-font-size-x-large);
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
.menu-item .menu-item__check {
|
|
183
|
+
color: var(--syn-option-check-color);
|
|
184
|
+
margin-inline-end: var(--syn-spacing-small);
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
/**
|
|
188
|
+
* This makes sure the chevron does not take any space if we do not have children
|
|
189
|
+
*/
|
|
190
|
+
.menu-item .menu-item__chevron {
|
|
191
|
+
display: none;
|
|
192
|
+
margin-inline-start: var(--syn-spacing-small);
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
.menu-item--checked .menu-item__check,
|
|
196
|
+
.menu-item--has-submenu .menu-item__chevron {
|
|
197
|
+
visibility: visible;
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
/**
|
|
201
|
+
* Make sure to show the chevron if there are children
|
|
202
|
+
*/
|
|
203
|
+
.menu-item--has-submenu .menu-item__chevron {
|
|
204
|
+
display: flex;
|
|
205
|
+
}
|
|
206
|
+
|
|
207
|
+
/**
|
|
208
|
+
* When in loading state, do not show the checkmark as it would bleed through
|
|
209
|
+
*/
|
|
210
|
+
.menu-item--loading .menu-item__check {
|
|
211
|
+
visibility: hidden;
|
|
212
|
+
}
|
|
213
|
+
|
|
214
|
+
/**
|
|
215
|
+
* Make sure the checkbox is also visible when the item is active
|
|
216
|
+
*/
|
|
217
|
+
:host(:focus-visible) .menu-item--checked .menu-item__check {
|
|
218
|
+
color: var(--syn-option-check-color-active);
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
:host(:hover) .menu-item--checked:not(.menu-item--disabled) .menu-item__check {
|
|
222
|
+
color: var(--syn-option-check-color-hover);
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
/**
|
|
226
|
+
* Special handling for the submenu chevron:
|
|
227
|
+
* We are using the "chevron-down" icon per default as
|
|
228
|
+
* we do not want all chevrons to be part of the bundle
|
|
229
|
+
* Therefore, we have to transform it into the right direction
|
|
230
|
+
*/
|
|
231
|
+
.menu-item .menu-item__chevron syn-icon {
|
|
232
|
+
transform: rotate(-90deg);
|
|
233
|
+
}
|
|
234
|
+
|
|
235
|
+
.menu-item--rtl .menu-item__chevron syn-icon {
|
|
236
|
+
transform: rotate(90deg);
|
|
237
|
+
}
|
|
238
|
+
|
|
239
|
+
/**
|
|
240
|
+
* Highlight checked items
|
|
241
|
+
*/
|
|
242
|
+
.menu-item--checked .menu-item__label {
|
|
243
|
+
font-weight: var(--syn-font-weight-semibold);
|
|
244
|
+
}
|
|
245
|
+
|
|
246
|
+
/* Needed if we do not show the checkmark */
|
|
247
|
+
:host(:not([type="checkmark"]):not([loading])) .menu-item__label {
|
|
248
|
+
min-height: var(--syn-font-size-x-large);
|
|
249
|
+
}
|
|
250
|
+
|
|
251
|
+
/* Add elevation and z-index to submenus */
|
|
252
|
+
syn-popup::part(popup) {
|
|
253
|
+
/* #1131: Make sure that slotted menus do show the correct border radius */
|
|
254
|
+
border-radius: var(--syn-input-border-radius-medium);
|
|
255
|
+
box-shadow: var(--syn-shadow-large);
|
|
256
|
+
margin-left: var(--submenu-offset);
|
|
257
|
+
z-index: var(--syn-z-index-dropdown);
|
|
258
|
+
}
|
|
259
|
+
|
|
260
|
+
.menu-item--rtl syn-popup::part(popup) {
|
|
261
|
+
margin-left: calc(-1 * var(--submenu-offset));
|
|
262
|
+
}
|
|
263
|
+
|
|
264
|
+
/**
|
|
265
|
+
* #1009: Adjust the position for submenus when they are opened to the left, too.
|
|
266
|
+
* This works because the data-current-placement attribute is set on the popup accordingly.
|
|
267
|
+
* We do not use the actual placement attribute, because it does not update when the placement changes
|
|
268
|
+
*/
|
|
269
|
+
syn-popup[data-current-placement^="left"]::part(popup) {
|
|
270
|
+
margin-left: calc(-1 * var(--submenu-offset));
|
|
271
|
+
}
|
|
272
|
+
|
|
273
|
+
@media (forced-colors: active) {
|
|
274
|
+
:host(:hover:not([aria-disabled='true'])) .menu-item,
|
|
275
|
+
:host(:focus-visible) .menu-item {
|
|
276
|
+
outline: dashed 1px SelectedItem;
|
|
277
|
+
outline-offset: -1px;
|
|
278
|
+
}
|
|
279
|
+
}
|
|
280
|
+
|
|
281
|
+
::slotted(syn-menu) {
|
|
282
|
+
max-height: var(--auto-size-available-height) !important;
|
|
283
|
+
max-width: var(--auto-size-available-width) !important;
|
|
284
|
+
}
|
|
285
|
+
`;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/* eslint-disable */
|
|
2
|
+
import SynMenuItem from './menu-item.component.js';
|
|
3
|
+
|
|
4
|
+
export * from './menu-item.component.js';
|
|
5
|
+
export default SynMenuItem;
|
|
6
|
+
|
|
7
|
+
SynMenuItem.define('syn-menu-item');
|
|
8
|
+
|
|
9
|
+
declare global {
|
|
10
|
+
interface HTMLElementTagNameMap {
|
|
11
|
+
'syn-menu-item': SynMenuItem;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
@@ -0,0 +1,285 @@
|
|
|
1
|
+
/* eslint-disable */
|
|
2
|
+
import { createRef, ref, type Ref } from 'lit/directives/ref.js';
|
|
3
|
+
import { type HasSlotController } from '../../internal/slot.js';
|
|
4
|
+
import { html } from 'lit';
|
|
5
|
+
import type { ReactiveController, ReactiveControllerHost } from 'lit';
|
|
6
|
+
import type SynMenuItem from './menu-item.js';
|
|
7
|
+
import type SynPopup from '../popup/popup.js';
|
|
8
|
+
|
|
9
|
+
/** A reactive controller to manage the registration of event listeners for submenus. */
|
|
10
|
+
export class SubmenuController implements ReactiveController {
|
|
11
|
+
private host: ReactiveControllerHost & SynMenuItem;
|
|
12
|
+
private popupRef: Ref<SynPopup> = createRef();
|
|
13
|
+
private enableSubmenuTimer = -1;
|
|
14
|
+
private isConnected = false;
|
|
15
|
+
private isPopupConnected = false;
|
|
16
|
+
private skidding = 0;
|
|
17
|
+
private readonly hasSlotController: HasSlotController;
|
|
18
|
+
private readonly submenuOpenDelay = 100;
|
|
19
|
+
|
|
20
|
+
constructor(host: ReactiveControllerHost & SynMenuItem, hasSlotController: HasSlotController) {
|
|
21
|
+
(this.host = host).addController(this);
|
|
22
|
+
this.hasSlotController = hasSlotController;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
hostConnected() {
|
|
26
|
+
if (this.hasSlotController.test('submenu') && !this.host.disabled) {
|
|
27
|
+
this.addListeners();
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
hostDisconnected() {
|
|
32
|
+
this.removeListeners();
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
hostUpdated() {
|
|
36
|
+
if (this.hasSlotController.test('submenu') && !this.host.disabled) {
|
|
37
|
+
this.addListeners();
|
|
38
|
+
this.updateSkidding();
|
|
39
|
+
} else {
|
|
40
|
+
this.removeListeners();
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
private addListeners() {
|
|
45
|
+
if (!this.isConnected) {
|
|
46
|
+
this.host.addEventListener('mousemove', this.handleMouseMove);
|
|
47
|
+
this.host.addEventListener('mouseover', this.handleMouseOver);
|
|
48
|
+
this.host.addEventListener('keydown', this.handleKeyDown);
|
|
49
|
+
this.host.addEventListener('click', this.handleClick);
|
|
50
|
+
this.host.addEventListener('focusout', this.handleFocusOut);
|
|
51
|
+
this.isConnected = true;
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
// The popup does not seem to get wired when the host is
|
|
55
|
+
// connected, so manage its listeners separately.
|
|
56
|
+
if (!this.isPopupConnected) {
|
|
57
|
+
if (this.popupRef.value) {
|
|
58
|
+
this.popupRef.value.addEventListener('mouseover', this.handlePopupMouseover);
|
|
59
|
+
this.popupRef.value.addEventListener('syn-reposition', this.handlePopupReposition);
|
|
60
|
+
this.isPopupConnected = true;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
private removeListeners() {
|
|
66
|
+
if (this.isConnected) {
|
|
67
|
+
this.host.removeEventListener('mousemove', this.handleMouseMove);
|
|
68
|
+
this.host.removeEventListener('mouseover', this.handleMouseOver);
|
|
69
|
+
this.host.removeEventListener('keydown', this.handleKeyDown);
|
|
70
|
+
this.host.removeEventListener('click', this.handleClick);
|
|
71
|
+
this.host.removeEventListener('focusout', this.handleFocusOut);
|
|
72
|
+
this.isConnected = false;
|
|
73
|
+
}
|
|
74
|
+
if (this.isPopupConnected) {
|
|
75
|
+
if (this.popupRef.value) {
|
|
76
|
+
this.popupRef.value.removeEventListener('mouseover', this.handlePopupMouseover);
|
|
77
|
+
this.popupRef.value.removeEventListener('syn-reposition', this.handlePopupReposition);
|
|
78
|
+
this.isPopupConnected = false;
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
// Set the safe triangle cursor position
|
|
84
|
+
private handleMouseMove = (event: MouseEvent) => {
|
|
85
|
+
this.host.style.setProperty('--safe-triangle-cursor-x', `${event.clientX}px`);
|
|
86
|
+
this.host.style.setProperty('--safe-triangle-cursor-y', `${event.clientY}px`);
|
|
87
|
+
};
|
|
88
|
+
|
|
89
|
+
private handleMouseOver = () => {
|
|
90
|
+
if (this.hasSlotController.test('submenu')) {
|
|
91
|
+
this.enableSubmenu();
|
|
92
|
+
}
|
|
93
|
+
};
|
|
94
|
+
|
|
95
|
+
private handleSubmenuEntry(event: KeyboardEvent) {
|
|
96
|
+
// Pass focus to the first menu-item in the submenu.
|
|
97
|
+
const submenuSlot: HTMLSlotElement | null = this.host.renderRoot.querySelector("slot[name='submenu']");
|
|
98
|
+
|
|
99
|
+
// Missing slot
|
|
100
|
+
if (!submenuSlot) {
|
|
101
|
+
console.error('Cannot activate a submenu if no corresponding menuitem can be found.', this);
|
|
102
|
+
return;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
// Menus
|
|
106
|
+
let menuItems: NodeListOf<Element> | null = null;
|
|
107
|
+
for (const elt of submenuSlot.assignedElements()) {
|
|
108
|
+
menuItems = elt.querySelectorAll("syn-menu-item, [role^='menuitem']");
|
|
109
|
+
if (menuItems.length !== 0) {
|
|
110
|
+
break;
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
if (!menuItems || menuItems.length === 0) {
|
|
115
|
+
return;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
menuItems[0].setAttribute('tabindex', '0');
|
|
119
|
+
for (let i = 1; i !== menuItems.length; ++i) {
|
|
120
|
+
menuItems[i].setAttribute('tabindex', '-1');
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
// Open the submenu (if not open), and set focus to first menuitem.
|
|
124
|
+
if (this.popupRef.value) {
|
|
125
|
+
event.preventDefault();
|
|
126
|
+
event.stopPropagation();
|
|
127
|
+
if (this.popupRef.value.active) {
|
|
128
|
+
if (menuItems[0] instanceof HTMLElement) {
|
|
129
|
+
menuItems[0].focus();
|
|
130
|
+
}
|
|
131
|
+
} else {
|
|
132
|
+
this.enableSubmenu(false);
|
|
133
|
+
this.host.updateComplete.then(() => {
|
|
134
|
+
if (menuItems[0] instanceof HTMLElement) {
|
|
135
|
+
menuItems[0].focus();
|
|
136
|
+
}
|
|
137
|
+
});
|
|
138
|
+
this.host.requestUpdate();
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
// Focus on the first menu-item of a submenu.
|
|
144
|
+
private handleKeyDown = (event: KeyboardEvent) => {
|
|
145
|
+
switch (event.key) {
|
|
146
|
+
case 'Escape':
|
|
147
|
+
case 'Tab':
|
|
148
|
+
this.disableSubmenu();
|
|
149
|
+
break;
|
|
150
|
+
case 'ArrowLeft':
|
|
151
|
+
// Either focus is currently on the host element or a child
|
|
152
|
+
if (event.target !== this.host) {
|
|
153
|
+
event.preventDefault();
|
|
154
|
+
event.stopPropagation();
|
|
155
|
+
this.host.focus();
|
|
156
|
+
this.disableSubmenu();
|
|
157
|
+
}
|
|
158
|
+
break;
|
|
159
|
+
case 'ArrowRight':
|
|
160
|
+
case 'Enter':
|
|
161
|
+
case ' ':
|
|
162
|
+
this.handleSubmenuEntry(event);
|
|
163
|
+
break;
|
|
164
|
+
default:
|
|
165
|
+
break;
|
|
166
|
+
}
|
|
167
|
+
};
|
|
168
|
+
|
|
169
|
+
private handleClick = (event: MouseEvent) => {
|
|
170
|
+
// Clicking on the item which heads the menu does nothing, otherwise hide submenu and propagate
|
|
171
|
+
if (event.target === this.host) {
|
|
172
|
+
event.preventDefault();
|
|
173
|
+
event.stopPropagation();
|
|
174
|
+
} else if (
|
|
175
|
+
event.target instanceof Element &&
|
|
176
|
+
(event.target.tagName === 'syn-menu-item' || event.target.role?.startsWith('menuitem'))
|
|
177
|
+
) {
|
|
178
|
+
this.disableSubmenu();
|
|
179
|
+
}
|
|
180
|
+
};
|
|
181
|
+
|
|
182
|
+
// Close this submenu on focus outside of the parent or any descendants.
|
|
183
|
+
private handleFocusOut = (event: FocusEvent) => {
|
|
184
|
+
if (event.relatedTarget && event.relatedTarget instanceof Element && this.host.contains(event.relatedTarget)) {
|
|
185
|
+
return;
|
|
186
|
+
}
|
|
187
|
+
this.disableSubmenu();
|
|
188
|
+
};
|
|
189
|
+
|
|
190
|
+
// Prevent the parent menu-item from getting focus on mouse movement on the submenu
|
|
191
|
+
private handlePopupMouseover = (event: MouseEvent) => {
|
|
192
|
+
event.stopPropagation();
|
|
193
|
+
};
|
|
194
|
+
|
|
195
|
+
// Set the safe triangle values for the submenu when the position changes
|
|
196
|
+
private handlePopupReposition = () => {
|
|
197
|
+
const submenuSlot: HTMLSlotElement | null = this.host.renderRoot.querySelector("slot[name='submenu']");
|
|
198
|
+
const menu = submenuSlot?.assignedElements({ flatten: true }).filter(el => el.localName === 'syn-menu')[0];
|
|
199
|
+
const isRtl = getComputedStyle(this.host).direction === 'rtl';
|
|
200
|
+
if (!menu) {
|
|
201
|
+
return;
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
const { left, top, width, height } = menu.getBoundingClientRect();
|
|
205
|
+
|
|
206
|
+
this.host.style.setProperty('--safe-triangle-submenu-start-x', `${isRtl ? left + width : left}px`);
|
|
207
|
+
this.host.style.setProperty('--safe-triangle-submenu-start-y', `${top}px`);
|
|
208
|
+
this.host.style.setProperty('--safe-triangle-submenu-end-x', `${isRtl ? left + width : left}px`);
|
|
209
|
+
this.host.style.setProperty('--safe-triangle-submenu-end-y', `${top + height}px`);
|
|
210
|
+
};
|
|
211
|
+
|
|
212
|
+
private setSubmenuState(state: boolean) {
|
|
213
|
+
if (this.popupRef.value) {
|
|
214
|
+
if (this.popupRef.value.active !== state) {
|
|
215
|
+
this.popupRef.value.active = state;
|
|
216
|
+
this.host.requestUpdate();
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
// Shows the submenu. Supports disabling the opening delay, e.g. for keyboard events that want to set the focus to the
|
|
222
|
+
// newly opened menu.
|
|
223
|
+
private enableSubmenu(delay = true) {
|
|
224
|
+
if (delay) {
|
|
225
|
+
window.clearTimeout(this.enableSubmenuTimer);
|
|
226
|
+
this.enableSubmenuTimer = window.setTimeout(() => {
|
|
227
|
+
this.setSubmenuState(true);
|
|
228
|
+
}, this.submenuOpenDelay);
|
|
229
|
+
} else {
|
|
230
|
+
this.setSubmenuState(true);
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
|
|
234
|
+
private disableSubmenu() {
|
|
235
|
+
window.clearTimeout(this.enableSubmenuTimer);
|
|
236
|
+
this.setSubmenuState(false);
|
|
237
|
+
}
|
|
238
|
+
|
|
239
|
+
// Calculate the space the top of a menu takes-up, for aligning the popup menu-item with the activating element.
|
|
240
|
+
private updateSkidding(): void {
|
|
241
|
+
// .computedStyleMap() not always available.
|
|
242
|
+
if (!this.host.parentElement?.computedStyleMap) {
|
|
243
|
+
return;
|
|
244
|
+
}
|
|
245
|
+
const styleMap: StylePropertyMapReadOnly = this.host.parentElement.computedStyleMap();
|
|
246
|
+
const attrs: string[] = ['padding-top', 'border-top-width', 'margin-top'];
|
|
247
|
+
|
|
248
|
+
const skidding = attrs.reduce((accumulator, attr) => {
|
|
249
|
+
const styleValue: CSSStyleValue = styleMap.get(attr) ?? new CSSUnitValue(0, 'px');
|
|
250
|
+
const unitValue = styleValue instanceof CSSUnitValue ? styleValue : new CSSUnitValue(0, 'px');
|
|
251
|
+
const pxValue = unitValue.to('px');
|
|
252
|
+
return accumulator - pxValue.value;
|
|
253
|
+
}, 0);
|
|
254
|
+
|
|
255
|
+
this.skidding = skidding;
|
|
256
|
+
}
|
|
257
|
+
|
|
258
|
+
isExpanded(): boolean {
|
|
259
|
+
return this.popupRef.value ? this.popupRef.value.active : false;
|
|
260
|
+
}
|
|
261
|
+
|
|
262
|
+
renderSubmenu() {
|
|
263
|
+
const isRtl = getComputedStyle(this.host).direction === 'rtl';
|
|
264
|
+
|
|
265
|
+
// Always render the slot, but conditionally render the outer <syn-popup>
|
|
266
|
+
if (!this.isConnected) {
|
|
267
|
+
return html` <slot name="submenu" hidden></slot> `;
|
|
268
|
+
}
|
|
269
|
+
|
|
270
|
+
return html`
|
|
271
|
+
<syn-popup
|
|
272
|
+
${ref(this.popupRef)}
|
|
273
|
+
placement=${isRtl ? 'left-start' : 'right-start'}
|
|
274
|
+
anchor="anchor"
|
|
275
|
+
flip
|
|
276
|
+
flip-fallback-strategy="best-fit"
|
|
277
|
+
skidding="${this.skidding}"
|
|
278
|
+
auto-size="vertical"
|
|
279
|
+
auto-size-padding="10"
|
|
280
|
+
>
|
|
281
|
+
<slot name="submenu"></slot>
|
|
282
|
+
</syn-popup>
|
|
283
|
+
`;
|
|
284
|
+
}
|
|
285
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export type SynMenuItemJSXElement = SynCustomElement<SynMenuItem, []>;
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
// ---------------------------------------------------------------------
|
|
2
|
+
// 🔒 AUTOGENERATED @synergy-design-system/react wrappers for @synergy-design-system/components
|
|
3
|
+
// Please do not edit this file directly!
|
|
4
|
+
// It will get recreated when running pnpm build.
|
|
5
|
+
// ---------------------------------------------------------------------
|
|
6
|
+
import * as React from 'react';
|
|
7
|
+
import { createComponent } from '@lit/react';
|
|
8
|
+
import Component from '@synergy-design-system/components/components/menu-item/menu-item.component.js';
|
|
9
|
+
|
|
10
|
+
const tagName = 'syn-menu-item';
|
|
11
|
+
Component.define('syn-menu-item');
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* @summary Menu items provide options for the user to pick from in a menu.
|
|
15
|
+
* @documentation https://synergy-design-system.github.io/?path=/docs/components-syn-menu-item--docs
|
|
16
|
+
* @status stable
|
|
17
|
+
* @since 2.0
|
|
18
|
+
*
|
|
19
|
+
* @dependency syn-icon
|
|
20
|
+
* @dependency syn-popup
|
|
21
|
+
* @dependency syn-spinner
|
|
22
|
+
*
|
|
23
|
+
* @slot - The menu item's label.
|
|
24
|
+
* @slot prefix - Used to prepend an icon or similar element to the menu item.
|
|
25
|
+
* @slot suffix - Used to append an icon or similar element to the menu item.
|
|
26
|
+
* @slot submenu - Used to denote a nested menu.
|
|
27
|
+
*
|
|
28
|
+
* @csspart base - The component's base wrapper.
|
|
29
|
+
* @csspart checked-icon - The checked icon, which is only visible when the menu item is checked.
|
|
30
|
+
* @csspart prefix - The prefix container.
|
|
31
|
+
* @csspart label - The menu item label.
|
|
32
|
+
* @csspart suffix - The suffix container.
|
|
33
|
+
* @csspart spinner - The spinner that shows when the menu item is in the loading state.
|
|
34
|
+
* @csspart spinner__base - The spinner's base part.
|
|
35
|
+
* @csspart submenu-icon - The submenu icon, visible only when the menu item has a submenu (not yet implemented).
|
|
36
|
+
*
|
|
37
|
+
* @cssproperty [--submenu-offset=-2px] - The distance submenus shift to overlap the parent menu.
|
|
38
|
+
*/
|
|
39
|
+
export const SynMenuItem = createComponent({
|
|
40
|
+
displayName: 'SynMenuItem',
|
|
41
|
+
elementClass: Component,
|
|
42
|
+
events: {},
|
|
43
|
+
react: React,
|
|
44
|
+
tagName,
|
|
45
|
+
});
|