@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,176 @@
|
|
|
1
|
+
/* eslint-disable @typescript-eslint/unbound-method */
|
|
2
|
+
import { classMap } from 'lit/directives/class-map.js';
|
|
3
|
+
import { html } from 'lit/static-html.js';
|
|
4
|
+
import { property, queryAssignedElements } from 'lit/decorators.js';
|
|
5
|
+
import type { CSSResultGroup } from 'lit';
|
|
6
|
+
import SynergyElement from '../../internal/synergy-element.js';
|
|
7
|
+
import { HasSlotController } from '../../internal/slot.js';
|
|
8
|
+
import SynDivider from '../divider/divider.component.js';
|
|
9
|
+
import type SynOption from '../option/option.component.js';
|
|
10
|
+
import styles from './optgroup.styles.js';
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* Handle the dataset value of the option when the disabled state changes.
|
|
14
|
+
* @param option The option to set the value for
|
|
15
|
+
* @param isDisabled The original disabled, usually from the parent optgroup
|
|
16
|
+
*/
|
|
17
|
+
const handleInitialDisabledForOption = (option: SynOption, isDisabled: boolean) => {
|
|
18
|
+
/* eslint-disable no-param-reassign */
|
|
19
|
+
if (option.disabled) {
|
|
20
|
+
option.dataset.originallyDisabled = 'true';
|
|
21
|
+
} else {
|
|
22
|
+
delete option.dataset.originallyDisabled;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
if (isDisabled) {
|
|
26
|
+
option.disabled = true;
|
|
27
|
+
}
|
|
28
|
+
/* eslint-enable no-param-reassign */
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
/**
|
|
32
|
+
* @summary The <syn-optgroup> element creates a grouping for <syn-option>s within a <syn-select>.
|
|
33
|
+
* @documentation https://synergy-design-system.github.io/?path=/docs/components-syn-optgroup--docs
|
|
34
|
+
* @status stable
|
|
35
|
+
* @since 1.3.0
|
|
36
|
+
*
|
|
37
|
+
* @dependency syn-divider
|
|
38
|
+
*
|
|
39
|
+
* @slot - The given options. Must be `<syn-option>` elements.
|
|
40
|
+
* @slot prefix - A presentational prefix icon or similar element.
|
|
41
|
+
* @slot label - The label for the optgroup
|
|
42
|
+
* @slot suffix - A presentational suffix icon or similar element.
|
|
43
|
+
*
|
|
44
|
+
* @csspart base - The component's base wrapper.
|
|
45
|
+
* @csspart label-container - The container that wraps prefix, label and base
|
|
46
|
+
* @csspart divider - The divider that is displayed above the content
|
|
47
|
+
* @csspart prefix - The container that wraps the prefix.
|
|
48
|
+
* @csspart suffix - The container that wraps the suffix.
|
|
49
|
+
* @csspart options - The container that wraps the <syn-option> elements.
|
|
50
|
+
*
|
|
51
|
+
* @cssproperty --display-divider - Display property of the divider. Defaults to "block"
|
|
52
|
+
*/
|
|
53
|
+
export default class SynOptgroup extends SynergyElement {
|
|
54
|
+
static styles: CSSResultGroup = styles;
|
|
55
|
+
|
|
56
|
+
static dependencies = {
|
|
57
|
+
'syn-divider': SynDivider,
|
|
58
|
+
};
|
|
59
|
+
|
|
60
|
+
private readonly hasSlotController = new HasSlotController(this, '[default]', 'prefix', 'suffix', 'label');
|
|
61
|
+
|
|
62
|
+
private mutationObserver: MutationObserver;
|
|
63
|
+
|
|
64
|
+
private enableObserver() {
|
|
65
|
+
this.mutationObserver.observe(this, {
|
|
66
|
+
attributeFilter: ['disabled'],
|
|
67
|
+
childList: true,
|
|
68
|
+
subtree: true,
|
|
69
|
+
});
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
@queryAssignedElements({ selector: 'syn-option' }) assignedOptions: SynOption[];
|
|
73
|
+
|
|
74
|
+
/**
|
|
75
|
+
* Disables all options in the optgroup.
|
|
76
|
+
*/
|
|
77
|
+
@property({ reflect: true, type: Boolean }) disabled = false;
|
|
78
|
+
|
|
79
|
+
/**
|
|
80
|
+
* The optgroups label. If you need to display HTML, use the `label` slot instead.
|
|
81
|
+
*/
|
|
82
|
+
@property() label = '';
|
|
83
|
+
|
|
84
|
+
connectedCallback() {
|
|
85
|
+
super.connectedCallback();
|
|
86
|
+
|
|
87
|
+
/* eslint-disable no-param-reassign */
|
|
88
|
+
// eslint-disable-next-line complexity
|
|
89
|
+
this.mutationObserver = new MutationObserver(entries => {
|
|
90
|
+
// Check if the mutation is for this optgroup
|
|
91
|
+
const optgroupChanges = entries.filter(entry => entry.target === this);
|
|
92
|
+
const optionChanges = entries.filter(entry => (entry.target as HTMLElement).matches('syn-option'));
|
|
93
|
+
|
|
94
|
+
const stopObserver = optgroupChanges.length > 0 || optionChanges.length > 0;
|
|
95
|
+
|
|
96
|
+
if (stopObserver) {
|
|
97
|
+
this.mutationObserver.disconnect();
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
// If options disabled state are changed dynamically,
|
|
101
|
+
// we need to store the new "originallyDisabled" state
|
|
102
|
+
if (optionChanges.length > 0) {
|
|
103
|
+
optionChanges.forEach(optionMutation => {
|
|
104
|
+
handleInitialDisabledForOption(optionMutation.target as SynOption, this.disabled);
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
// If the optgroup is disabled, disable all options
|
|
109
|
+
// If the optgroup is enabled, reenable all options that were enabled before
|
|
110
|
+
if (optgroupChanges.length > 0) {
|
|
111
|
+
optgroupChanges.forEach(optgroupMutation => {
|
|
112
|
+
if (optgroupMutation.type === 'attributes') {
|
|
113
|
+
this.assignedOptions.forEach(option => {
|
|
114
|
+
option.disabled = this.disabled
|
|
115
|
+
? true
|
|
116
|
+
: !!option.dataset?.originallyDisabled;
|
|
117
|
+
});
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
if (optgroupMutation.type === 'childList') {
|
|
121
|
+
optgroupMutation.addedNodes.forEach((node) => {
|
|
122
|
+
if (node instanceof HTMLElement && node.matches('syn-option')) {
|
|
123
|
+
handleInitialDisabledForOption(node as SynOption, this.disabled);
|
|
124
|
+
}
|
|
125
|
+
});
|
|
126
|
+
}
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
// Reenable the mutation observer when it was stopped.
|
|
131
|
+
// This is needed to make sure that we get future changes again
|
|
132
|
+
if (stopObserver) {
|
|
133
|
+
// eslint-disable-next-line @typescript-eslint/no-floating-promises
|
|
134
|
+
this.updateComplete.then(() => {
|
|
135
|
+
this.enableObserver();
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
});
|
|
139
|
+
/* eslint-enable no-param-reassign */
|
|
140
|
+
|
|
141
|
+
this.enableObserver();
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
render() {
|
|
145
|
+
const { disabled } = this;
|
|
146
|
+
const hasLabelSlot = this.hasSlotController.test('label');
|
|
147
|
+
const hasLabel = this.label ? true : !!hasLabelSlot;
|
|
148
|
+
return html`
|
|
149
|
+
<div
|
|
150
|
+
class=${classMap({
|
|
151
|
+
optgroup: true,
|
|
152
|
+
'optgroup--has-label': hasLabel,
|
|
153
|
+
'optgroup--has-prefix': this.hasSlotController.test('prefix'),
|
|
154
|
+
'optgroup--has-suffix': this.hasSlotController.test('suffix'),
|
|
155
|
+
'optgroup--is-disabled': this.disabled,
|
|
156
|
+
})}
|
|
157
|
+
role="${disabled ? 'presentation' : 'group'}"
|
|
158
|
+
part="base"
|
|
159
|
+
>
|
|
160
|
+
<syn-divider class="optgroup__divider" part="divider"></syn-divider>
|
|
161
|
+
<div class="optgroup__label-container" part="label-container">
|
|
162
|
+
<slot name="prefix" part="prefix" class="optgroup__prefix"></slot>
|
|
163
|
+
<slot name="label" part="label" class="optgroup__label">
|
|
164
|
+
<span class="optgroup__label-content">
|
|
165
|
+
${this.label}
|
|
166
|
+
</span>
|
|
167
|
+
</slot>
|
|
168
|
+
<slot name="suffix" part="suffix" class="optgroup__suffix"></slot>
|
|
169
|
+
</div>
|
|
170
|
+
<div class="optgroup__options" role="group" part="options">
|
|
171
|
+
<slot></slot>
|
|
172
|
+
</div>
|
|
173
|
+
</div>
|
|
174
|
+
`;
|
|
175
|
+
}
|
|
176
|
+
}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { css } from 'lit';
|
|
2
|
+
|
|
3
|
+
export default css`
|
|
4
|
+
:host {
|
|
5
|
+
--display-divider: block;
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
.optgroup__divider {
|
|
9
|
+
--spacing: var(--syn-spacing-x-small);
|
|
10
|
+
|
|
11
|
+
display: var(--display-divider);
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
.optgroup__label-container {
|
|
15
|
+
align-items: center;
|
|
16
|
+
border: solid transparent;
|
|
17
|
+
border-width: 0 var(--option-inset-border-vertical);
|
|
18
|
+
box-sizing: border-box;
|
|
19
|
+
color: var(--syn-input-color);
|
|
20
|
+
display: flex;
|
|
21
|
+
gap: var(--syn-spacing-small);
|
|
22
|
+
min-height: var(--option-min-height, var(--syn-input-height-medium));
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
/**
|
|
26
|
+
* Only show the label container when there is a label at all
|
|
27
|
+
*/
|
|
28
|
+
.optgroup--has-prefix .optgroup__label-container,
|
|
29
|
+
.optgroup--has-label .optgroup__label-container,
|
|
30
|
+
.optgroup--has-suffix .optgroup__label-container {
|
|
31
|
+
padding: 0 calc(var(--option-padding) - var(--option-inset-border-vertical));
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
/**
|
|
35
|
+
* Format main label.
|
|
36
|
+
* Make sure this works for props and slotted content
|
|
37
|
+
*/
|
|
38
|
+
.optgroup__label-content,
|
|
39
|
+
.optgroup__label::slotted(*) {
|
|
40
|
+
flex: 1;
|
|
41
|
+
font-family: var(--syn-font-sans);
|
|
42
|
+
font-size: var(--option-font-size, var(--syn-font-size-medium));
|
|
43
|
+
font-weight: var(--syn-font-weight-semibold);
|
|
44
|
+
line-height: var(--syn-line-height-normal);
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
/* Disabled Label */
|
|
48
|
+
.optgroup--is-disabled .optgroup__label-container {
|
|
49
|
+
opacity: var(--syn-input-disabled-opacity);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
.optgroup__prefix,
|
|
53
|
+
.optgroup__suffix {
|
|
54
|
+
color: var(--syn-option-icon-color);
|
|
55
|
+
font-size: var(--syn-spacing-large);
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
.optgroup__options ::slotted(syn-option[hidden]) {
|
|
59
|
+
display: none;
|
|
60
|
+
}
|
|
61
|
+
`;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
/* eslint-disable */
|
|
2
|
+
import SynOptGroup from './optgroup.component.js';
|
|
3
|
+
|
|
4
|
+
export * from './optgroup.component.js';
|
|
5
|
+
export default SynOptGroup;
|
|
6
|
+
|
|
7
|
+
SynOptGroup.define('syn-optgroup');
|
|
8
|
+
|
|
9
|
+
declare global {
|
|
10
|
+
interface HTMLElementTagNameMap {
|
|
11
|
+
'syn-optgroup': SynOptGroup;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export type SynOptgroupJSXElement = SynCustomElement<SynOptgroup, []>;
|
|
@@ -0,0 +1,41 @@
|
|
|
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/optgroup/optgroup.component.js';
|
|
9
|
+
|
|
10
|
+
const tagName = 'syn-optgroup';
|
|
11
|
+
Component.define('syn-optgroup');
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* @summary The <syn-optgroup> element creates a grouping for <syn-option>s within a <syn-select>.
|
|
15
|
+
* @documentation https://synergy-design-system.github.io/?path=/docs/components-syn-optgroup--docs
|
|
16
|
+
* @status stable
|
|
17
|
+
* @since 1.3.0
|
|
18
|
+
*
|
|
19
|
+
* @dependency syn-divider
|
|
20
|
+
*
|
|
21
|
+
* @slot - The given options. Must be `<syn-option>` elements.
|
|
22
|
+
* @slot prefix - A presentational prefix icon or similar element.
|
|
23
|
+
* @slot label - The label for the optgroup
|
|
24
|
+
* @slot suffix - A presentational suffix icon or similar element.
|
|
25
|
+
*
|
|
26
|
+
* @csspart base - The component's base wrapper.
|
|
27
|
+
* @csspart label-container - The container that wraps prefix, label and base
|
|
28
|
+
* @csspart divider - The divider that is displayed above the content
|
|
29
|
+
* @csspart prefix - The container that wraps the prefix.
|
|
30
|
+
* @csspart suffix - The container that wraps the suffix.
|
|
31
|
+
* @csspart options - The container that wraps the <syn-option> elements.
|
|
32
|
+
*
|
|
33
|
+
* @cssproperty --display-divider - Display property of the divider. Defaults to "block"
|
|
34
|
+
*/
|
|
35
|
+
export const SynOptgroup = createComponent({
|
|
36
|
+
displayName: 'SynOptgroup',
|
|
37
|
+
elementClass: Component,
|
|
38
|
+
events: {},
|
|
39
|
+
react: React,
|
|
40
|
+
tagName,
|
|
41
|
+
});
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
<script setup lang="ts">
|
|
2
|
+
// ---------------------------------------------------------------------
|
|
3
|
+
// 🔒 AUTOGENERATED @synergy-design-system/vue wrappers for @synergy-design-system/components
|
|
4
|
+
// Please do not edit this file directly!
|
|
5
|
+
// It will get recreated when running pnpm build.
|
|
6
|
+
// ---------------------------------------------------------------------
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* @summary The <syn-optgroup> element creates a grouping for <syn-option>s within a <syn-select>.
|
|
10
|
+
* @documentation https://synergy-design-system.github.io/?path=/docs/components-syn-optgroup--docs
|
|
11
|
+
* @status stable
|
|
12
|
+
* @since 1.3.0
|
|
13
|
+
*
|
|
14
|
+
* @dependency syn-divider
|
|
15
|
+
*
|
|
16
|
+
* @slot - The given options. Must be `<syn-option>` elements.
|
|
17
|
+
* @slot prefix - A presentational prefix icon or similar element.
|
|
18
|
+
* @slot label - The label for the optgroup
|
|
19
|
+
* @slot suffix - A presentational suffix icon or similar element.
|
|
20
|
+
*
|
|
21
|
+
* @csspart base - The component's base wrapper.
|
|
22
|
+
* @csspart label-container - The container that wraps prefix, label and base
|
|
23
|
+
* @csspart divider - The divider that is displayed above the content
|
|
24
|
+
* @csspart prefix - The container that wraps the prefix.
|
|
25
|
+
* @csspart suffix - The container that wraps the suffix.
|
|
26
|
+
* @csspart options - The container that wraps the <syn-option> elements.
|
|
27
|
+
*
|
|
28
|
+
* @cssproperty --display-divider - Display property of the divider. Defaults to "block"
|
|
29
|
+
*/
|
|
30
|
+
import { computed, ref } from 'vue';
|
|
31
|
+
import '@synergy-design-system/components/components/optgroup/optgroup.js';
|
|
32
|
+
|
|
33
|
+
import type { SynOptgroup } from '@synergy-design-system/components';
|
|
34
|
+
|
|
35
|
+
// DOM Reference to the element
|
|
36
|
+
const nativeElement = ref<SynOptgroup>();
|
|
37
|
+
|
|
38
|
+
defineExpose({
|
|
39
|
+
nativeElement,
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
// Map attributes
|
|
43
|
+
const props = defineProps<{
|
|
44
|
+
/**
|
|
45
|
+
* Disables all options in the optgroup.
|
|
46
|
+
*/
|
|
47
|
+
disabled?: SynOptgroup['disabled'];
|
|
48
|
+
|
|
49
|
+
/**
|
|
50
|
+
* The optgroups label.
|
|
51
|
+
* If you need to display HTML, use the `label` slot instead.
|
|
52
|
+
*/
|
|
53
|
+
label?: SynOptgroup['label'];
|
|
54
|
+
}>();
|
|
55
|
+
|
|
56
|
+
// Make sure prop binding only forwards the props that are actually there.
|
|
57
|
+
// This is needed because :param="param" also adds an empty attribute
|
|
58
|
+
// when using web-components, which breaks optional arguments like size in SynInput
|
|
59
|
+
// @see https://github.com/vuejs/core/issues/5190#issuecomment-1003112498
|
|
60
|
+
const visibleProps = computed(() =>
|
|
61
|
+
Object.fromEntries(
|
|
62
|
+
Object.entries(props).filter(([, value]) => typeof value !== 'undefined'),
|
|
63
|
+
),
|
|
64
|
+
);
|
|
65
|
+
</script>
|
|
66
|
+
|
|
67
|
+
<template>
|
|
68
|
+
<syn-optgroup v-bind="visibleProps" ref="nativeElement">
|
|
69
|
+
<slot></slot>
|
|
70
|
+
</syn-optgroup>
|
|
71
|
+
</template>
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
// ---------------------------------------------------------------------
|
|
2
|
+
// 🔒 AUTOGENERATED @synergy-design-system/angular 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 {
|
|
7
|
+
Component,
|
|
8
|
+
ElementRef,
|
|
9
|
+
NgZone,
|
|
10
|
+
Input,
|
|
11
|
+
Output,
|
|
12
|
+
EventEmitter,
|
|
13
|
+
AfterContentInit,
|
|
14
|
+
} from '@angular/core';
|
|
15
|
+
import type { SynOption } from '@synergy-design-system/components';
|
|
16
|
+
|
|
17
|
+
import '@synergy-design-system/components/components/option/option.js';
|
|
18
|
+
|
|
19
|
+
/**
|
|
20
|
+
* @summary Options define the selectable items within various form controls such as [select](/components/select).
|
|
21
|
+
* @documentation https://synergy-design-system.github.io/?path=/docs/components-syn-option--docs
|
|
22
|
+
* @status stable
|
|
23
|
+
* @since 2.0
|
|
24
|
+
*
|
|
25
|
+
* @dependency syn-icon
|
|
26
|
+
*
|
|
27
|
+
* @slot - The option's label.
|
|
28
|
+
* @slot prefix - Used to prepend an icon or similar element to the menu item.
|
|
29
|
+
* @slot suffix - Used to append an icon or similar element to the menu item.
|
|
30
|
+
*
|
|
31
|
+
* @csspart checked-icon - The checked icon, an `<syn-icon>` element.
|
|
32
|
+
* @csspart base - The component's base wrapper.
|
|
33
|
+
* @csspart label - The option's label.
|
|
34
|
+
* @csspart prefix - The container that wraps the prefix.
|
|
35
|
+
* @csspart suffix - The container that wraps the suffix.
|
|
36
|
+
*/
|
|
37
|
+
@Component({
|
|
38
|
+
selector: 'syn-option',
|
|
39
|
+
standalone: true,
|
|
40
|
+
template: '<ng-content></ng-content>',
|
|
41
|
+
})
|
|
42
|
+
export class SynOptionComponent {
|
|
43
|
+
public nativeElement: SynOption;
|
|
44
|
+
private _ngZone: NgZone;
|
|
45
|
+
|
|
46
|
+
constructor(e: ElementRef, ngZone: NgZone) {
|
|
47
|
+
this.nativeElement = e.nativeElement;
|
|
48
|
+
this._ngZone = ngZone;
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
/**
|
|
52
|
+
* The option's value.
|
|
53
|
+
* When selected, the containing form control will receive this value.
|
|
54
|
+
* The value must be unique
|
|
55
|
+
from other options in the same group.
|
|
56
|
+
* Values may not contain spaces, as spaces are used as delimiters when listing
|
|
57
|
+
multiple values.
|
|
58
|
+
*/
|
|
59
|
+
@Input()
|
|
60
|
+
set value(v: SynOption['value']) {
|
|
61
|
+
this._ngZone.runOutsideAngular(() => (this.nativeElement.value = v));
|
|
62
|
+
}
|
|
63
|
+
get value(): SynOption['value'] {
|
|
64
|
+
return this.nativeElement.value;
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
/**
|
|
68
|
+
* Draws the option in a disabled state, preventing selection.
|
|
69
|
+
*/
|
|
70
|
+
@Input()
|
|
71
|
+
set disabled(v: '' | SynOption['disabled']) {
|
|
72
|
+
this._ngZone.runOutsideAngular(
|
|
73
|
+
() => (this.nativeElement.disabled = v === '' || v),
|
|
74
|
+
);
|
|
75
|
+
}
|
|
76
|
+
get disabled(): SynOption['disabled'] {
|
|
77
|
+
return this.nativeElement.disabled;
|
|
78
|
+
}
|
|
79
|
+
}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { css } from 'lit';
|
|
2
|
+
|
|
3
|
+
export default css`
|
|
4
|
+
/**
|
|
5
|
+
* Size adjustments for syn-select and other widgets that use syn-option
|
|
6
|
+
* This allows to share the common settings between all components that
|
|
7
|
+
* should be able to set the size of a syn-option tag.
|
|
8
|
+
*
|
|
9
|
+
* Also note that we have to adjust the padding to take the border size into account.
|
|
10
|
+
*/
|
|
11
|
+
:host([size="small"]) {
|
|
12
|
+
--option-inset-border-horizontal: var(--syn-spacing-2x-small);
|
|
13
|
+
--option-inset-border-vertical: calc(var(--syn-spacing-x-small) - 1px);
|
|
14
|
+
--option-min-height: var(--syn-input-height-small);
|
|
15
|
+
--option-padding: var(--syn-input-spacing-small);
|
|
16
|
+
--option-font-size: var(--syn-input-font-size-small);
|
|
17
|
+
--option-icon-size: var(--syn-spacing-medium);
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
:host([size="medium"]) {
|
|
21
|
+
--option-inset-border-horizontal: var(--syn-spacing-2x-small);
|
|
22
|
+
--option-inset-border-vertical: calc(var(--syn-spacing-x-small) - 1px);
|
|
23
|
+
--option-min-height: var(--syn-input-height-medium);
|
|
24
|
+
--option-padding: var(--syn-input-spacing-medium);
|
|
25
|
+
--option-font-size: var(--syn-input-font-size-medium);
|
|
26
|
+
--option-icon-size: var(--syn-spacing-large);
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
:host([size="large"]) {
|
|
30
|
+
--option-inset-border-horizontal: var(--syn-spacing-2x-small);
|
|
31
|
+
--option-inset-border-vertical: calc(var(--syn-spacing-x-small) - 1px);
|
|
32
|
+
--option-min-height: var(--syn-input-height-large);
|
|
33
|
+
--option-padding: var(--syn-input-spacing-large);
|
|
34
|
+
--option-font-size: var(--syn-input-font-size-large);
|
|
35
|
+
--option-icon-size: var(--syn-spacing-x-large);
|
|
36
|
+
}
|
|
37
|
+
`;
|
|
@@ -0,0 +1,191 @@
|
|
|
1
|
+
/* eslint-disable */
|
|
2
|
+
import { classMap } from 'lit/directives/class-map.js';
|
|
3
|
+
import { html } from 'lit';
|
|
4
|
+
import { LocalizeController } from '../../utilities/localize.js';
|
|
5
|
+
import { property, query, state } from 'lit/decorators.js';
|
|
6
|
+
import { watch } from '../../internal/watch.js';
|
|
7
|
+
import componentStyles from '../../styles/component.styles.js';
|
|
8
|
+
import SynergyElement from '../../internal/synergy-element.js';
|
|
9
|
+
import SynIcon from '../icon/icon.component.js';
|
|
10
|
+
import styles from './option.styles.js';
|
|
11
|
+
import { delimiterToWhiteSpace } from './utility.js';
|
|
12
|
+
import type { CSSResultGroup } from 'lit';
|
|
13
|
+
import { enableDefaultSettings } from '../../utilities/defaultSettings/decorator.js';
|
|
14
|
+
|
|
15
|
+
/**
|
|
16
|
+
* @summary Options define the selectable items within various form controls such as [select](/components/select).
|
|
17
|
+
* @documentation https://synergy-design-system.github.io/?path=/docs/components-syn-option--docs
|
|
18
|
+
* @status stable
|
|
19
|
+
* @since 2.0
|
|
20
|
+
*
|
|
21
|
+
* @dependency syn-icon
|
|
22
|
+
*
|
|
23
|
+
* @slot - The option'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
|
+
*
|
|
27
|
+
* @csspart checked-icon - The checked icon, an `<syn-icon>` element.
|
|
28
|
+
* @csspart base - The component's base wrapper.
|
|
29
|
+
* @csspart label - The option's label.
|
|
30
|
+
* @csspart prefix - The container that wraps the prefix.
|
|
31
|
+
* @csspart suffix - The container that wraps the suffix.
|
|
32
|
+
*/
|
|
33
|
+
@enableDefaultSettings('SynOption')
|
|
34
|
+
export default class SynOption extends SynergyElement {
|
|
35
|
+
static styles: CSSResultGroup = [componentStyles, styles];
|
|
36
|
+
static dependencies = { 'syn-icon': SynIcon };
|
|
37
|
+
|
|
38
|
+
// @ts-expect-error - Controller is currently unused
|
|
39
|
+
private readonly localize = new LocalizeController(this);
|
|
40
|
+
|
|
41
|
+
// #1036: Needed to store the original value before any delimiter processing
|
|
42
|
+
private originalValue: string | number = '';
|
|
43
|
+
private isInitialized = false;
|
|
44
|
+
|
|
45
|
+
@query('.option__label') defaultSlot: HTMLSlotElement;
|
|
46
|
+
|
|
47
|
+
// the delimiter used to separate multiple values in a select
|
|
48
|
+
// This is provided by the wrapping syn-select
|
|
49
|
+
@state() delimiter = ' ';
|
|
50
|
+
|
|
51
|
+
@state() current = false; // the user has keyed into the option, but hasn't selected it yet (shows a highlight)
|
|
52
|
+
@state() selected = false; // the option is selected and has aria-selected="true"
|
|
53
|
+
@state() hasHover = false; // we need this because Safari doesn't honor :hover styles while dragging
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* The option's value. When selected, the containing form control will receive this value. The value must be unique
|
|
57
|
+
* from other options in the same group. Values may not contain spaces, as spaces are used as delimiters when listing
|
|
58
|
+
* multiple values.
|
|
59
|
+
*/
|
|
60
|
+
@property({ reflect: true }) value: string | number = '';
|
|
61
|
+
|
|
62
|
+
/** Draws the option in a disabled state, preventing selection. */
|
|
63
|
+
@property({ type: Boolean, reflect: true }) disabled = false;
|
|
64
|
+
|
|
65
|
+
connectedCallback() {
|
|
66
|
+
super.connectedCallback();
|
|
67
|
+
this.setAttribute('role', 'option');
|
|
68
|
+
this.setAttribute('aria-selected', 'false');
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
private handleDefaultSlotChange() {
|
|
72
|
+
if (this.isInitialized) {
|
|
73
|
+
// When the label changes, tell the controller to update
|
|
74
|
+
this.triggerParentDefaultSlotChange();
|
|
75
|
+
} else {
|
|
76
|
+
this.isInitialized = true;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
private handleMouseEnter() {
|
|
81
|
+
this.hasHover = true;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
private handleMouseLeave() {
|
|
85
|
+
this.hasHover = false;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
@watch('disabled')
|
|
89
|
+
handleDisabledChange() {
|
|
90
|
+
this.setAttribute('aria-disabled', this.disabled ? 'true' : 'false');
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
@watch('selected')
|
|
94
|
+
handleSelectedChange() {
|
|
95
|
+
this.setAttribute('aria-selected', this.selected ? 'true' : 'false');
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
@watch('delimiter')
|
|
99
|
+
handleDelimiterChange() {
|
|
100
|
+
this.sanitizeValueForDelimiter();
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
@watch('value')
|
|
104
|
+
handleValueChange() {
|
|
105
|
+
this.originalValue = this.value;
|
|
106
|
+
this.sanitizeValueForDelimiter();
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
/**
|
|
110
|
+
* Replaces any occurrences of the delimiter in the option's original value with underscores.
|
|
111
|
+
*/
|
|
112
|
+
sanitizeValueForDelimiter() {
|
|
113
|
+
let value = this.originalValue;
|
|
114
|
+
if (typeof value === 'number') {
|
|
115
|
+
return;
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
// Ensure the value is a string. This ensures the next line doesn't error and allows framework users to pass numbers
|
|
119
|
+
// instead of requiring them to cast the value to a string.
|
|
120
|
+
if (typeof value !== 'string') {
|
|
121
|
+
value = String(value);
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
const { delimiter } = this;
|
|
125
|
+
|
|
126
|
+
if (value.includes(delimiter)) {
|
|
127
|
+
console.error(`Option values cannot include "${delimiter}". All occurrences of "${delimiter}" have been replaced with "_".`, this);
|
|
128
|
+
value = delimiterToWhiteSpace(value, this.delimiter);
|
|
129
|
+
}
|
|
130
|
+
this.value = value;
|
|
131
|
+
// #1056 We need to trigger the parent component's default slot change, so it can update its value selection
|
|
132
|
+
this.triggerParentDefaultSlotChange();
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
/** Returns a plain text label based on the option's content. */
|
|
136
|
+
getTextLabel() {
|
|
137
|
+
const nodes = this.childNodes;
|
|
138
|
+
let label = '';
|
|
139
|
+
|
|
140
|
+
[...nodes].forEach(node => {
|
|
141
|
+
if (node.nodeType === Node.ELEMENT_NODE) {
|
|
142
|
+
if (!(node as HTMLElement).hasAttribute('slot')) {
|
|
143
|
+
label += (node as HTMLElement).textContent;
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
if (node.nodeType === Node.TEXT_NODE) {
|
|
148
|
+
label += node.textContent;
|
|
149
|
+
}
|
|
150
|
+
});
|
|
151
|
+
|
|
152
|
+
return label.trim();
|
|
153
|
+
}
|
|
154
|
+
|
|
155
|
+
private triggerParentDefaultSlotChange() {
|
|
156
|
+
customElements.whenDefined('syn-combobox').then(() => {
|
|
157
|
+
const controller = this.closest('syn-combobox');
|
|
158
|
+
if (controller) {
|
|
159
|
+
controller.handleDefaultSlotChange();
|
|
160
|
+
}
|
|
161
|
+
});
|
|
162
|
+
customElements.whenDefined('syn-select').then(() => {
|
|
163
|
+
const controller = this.closest('syn-select');
|
|
164
|
+
if (controller) {
|
|
165
|
+
controller.handleDefaultSlotChange();
|
|
166
|
+
}
|
|
167
|
+
});
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
render() {
|
|
171
|
+
return html`
|
|
172
|
+
<div
|
|
173
|
+
part="base"
|
|
174
|
+
class=${classMap({
|
|
175
|
+
option: true,
|
|
176
|
+
'option--current': this.current,
|
|
177
|
+
'option--disabled': this.disabled,
|
|
178
|
+
'option--selected': this.selected,
|
|
179
|
+
'option--hover': this.hasHover
|
|
180
|
+
})}
|
|
181
|
+
@mouseenter=${this.handleMouseEnter}
|
|
182
|
+
@mouseleave=${this.handleMouseLeave}
|
|
183
|
+
>
|
|
184
|
+
<syn-icon part="checked-icon" class="option__check" name="check" library="system" aria-hidden="true"></syn-icon>
|
|
185
|
+
<slot part="prefix" name="prefix" class="option__prefix"></slot>
|
|
186
|
+
<slot part="label" class="option__label" @slotchange=${this.handleDefaultSlotChange}></slot>
|
|
187
|
+
<slot part="suffix" name="suffix" class="option__suffix"></slot>
|
|
188
|
+
</div>
|
|
189
|
+
`;
|
|
190
|
+
}
|
|
191
|
+
}
|