@synergy-design-system/mcp 2.15.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 +24 -0
- package/README.md +826 -303
- package/dist/bin/start.js +57 -6
- package/dist/middleware/compose.d.ts +15 -0
- package/dist/middleware/compose.js +10 -0
- package/dist/middleware/compression.d.ts +19 -0
- package/dist/middleware/compression.js +35 -0
- package/dist/middleware/error-handler.d.ts +13 -0
- package/dist/middleware/error-handler.js +42 -0
- package/dist/middleware/index.d.ts +9 -0
- package/dist/middleware/index.js +8 -0
- package/dist/middleware/logging.d.ts +14 -0
- package/dist/middleware/logging.js +64 -0
- package/dist/middleware/types.d.ts +20 -0
- package/dist/middleware/types.js +4 -0
- package/dist/resources/asset-list.d.ts +7 -0
- package/dist/resources/asset-list.js +34 -0
- package/dist/resources/component-cluster-list.d.ts +7 -0
- package/dist/resources/component-cluster-list.js +30 -0
- package/dist/resources/component-list.d.ts +7 -0
- package/dist/resources/component-list.js +31 -0
- package/dist/resources/index.d.ts +5 -0
- package/dist/resources/index.js +5 -0
- package/dist/resources/styles-list.d.ts +7 -0
- package/dist/resources/styles-list.js +31 -0
- package/dist/resources/templates-list.d.ts +7 -0
- package/dist/resources/templates-list.js +28 -0
- package/dist/server.js +5 -1
- package/dist/tools/asset-info.js +41 -85
- package/dist/tools/asset-list.js +22 -31
- package/dist/tools/component-cluster-list.d.ts +6 -0
- package/dist/tools/component-cluster-list.js +30 -0
- package/dist/tools/component-info.js +38 -21
- package/dist/tools/component-list.js +35 -30
- package/dist/tools/davinci-migration-info.d.ts +2 -0
- package/dist/tools/davinci-migration-info.js +21 -0
- package/dist/tools/davinci-migration-list.d.ts +2 -0
- package/dist/tools/davinci-migration-list.js +20 -0
- package/dist/tools/index.d.ts +6 -5
- package/dist/tools/index.js +6 -5
- package/dist/tools/migration-info.js +12 -37
- package/dist/tools/migration-list.js +7 -13
- package/dist/tools/setup.d.ts +6 -0
- package/dist/tools/setup.js +31 -0
- package/dist/tools/styles-info.d.ts +1 -2
- package/dist/tools/styles-info.js +24 -20
- package/dist/tools/styles-list.js +19 -33
- package/dist/tools/template-info.js +19 -20
- package/dist/tools/template-list.d.ts +1 -1
- package/dist/tools/template-list.js +17 -32
- package/dist/tools/{tokens.d.ts → token-info.d.ts} +2 -2
- package/dist/tools/token-info.js +31 -0
- package/dist/tools/tokens-list.d.ts +6 -0
- package/dist/tools/tokens-list.js +52 -0
- package/dist/transports/http.d.ts +14 -0
- package/dist/transports/http.js +157 -0
- package/dist/transports/index.d.ts +23 -0
- package/dist/transports/index.js +23 -0
- package/dist/transports/stdio.d.ts +10 -0
- package/dist/transports/stdio.js +21 -0
- package/dist/types/tool-response.d.ts +13 -0
- package/dist/types/tool-response.js +7 -0
- package/dist/utilities/cli.d.ts +27 -0
- package/dist/utilities/cli.js +170 -0
- package/dist/utilities/compression.d.ts +7 -0
- package/dist/utilities/compression.js +45 -0
- package/dist/utilities/config.d.ts +122 -80
- package/dist/utilities/config.js +212 -81
- package/dist/utilities/davinci.d.ts +12 -0
- package/dist/utilities/davinci.js +55 -0
- package/dist/utilities/index.d.ts +10 -10
- package/dist/utilities/index.js +10 -10
- package/dist/utilities/local-file-logger.d.ts +2 -0
- package/dist/utilities/local-file-logger.js +22 -0
- package/dist/utilities/logger.d.ts +12 -0
- package/dist/utilities/logger.js +30 -0
- package/dist/utilities/logging-context.d.ts +8 -0
- package/dist/utilities/logging-context.js +7 -0
- package/dist/utilities/logging-service.d.ts +2 -0
- package/dist/utilities/logging-service.js +24 -0
- package/dist/utilities/logging-types.d.ts +19 -0
- package/dist/utilities/metadata.d.ts +10 -17
- package/dist/utilities/metadata.js +34 -51
- package/dist/utilities/migration.d.ts +2 -1
- package/dist/utilities/migration.js +33 -30
- package/dist/utilities/rules.d.ts +8 -0
- package/dist/utilities/rules.js +37 -0
- package/dist/utilities/server.d.ts +7 -0
- package/dist/utilities/server.js +12 -0
- package/dist/utilities/token-counter.d.ts +14 -0
- package/dist/utilities/token-counter.js +53 -0
- package/package.json +20 -30
- package/rules/asset-info.md +10 -0
- package/rules/asset-list.md +10 -0
- package/rules/component-cluster-list.md +5 -0
- package/{metadata/static/angular/index.md → rules/component-info-angular.md} +2 -1
- package/{metadata/static/react/index.md → rules/component-info-react.md} +2 -1
- package/{metadata/static/vue/index.md → rules/component-info-vue.md} +4 -1
- package/{metadata/static/component-list/index.md → rules/component-list.md} +5 -7
- package/rules/styles-info.md +9 -0
- package/{metadata/static/styles/index.md → rules/styles-list.md} +0 -2
- package/{metadata/static/templates/index.md → rules/template-info.md} +0 -1
- package/rules/template-list.md +7 -0
- package/dist/bin/create-checksum.d.ts +0 -2
- package/dist/bin/create-checksum.js +0 -24
- package/dist/build/assets.d.ts +0 -4
- package/dist/build/assets.js +0 -57
- package/dist/build/build.js +0 -35
- package/dist/build/components.d.ts +0 -4
- package/dist/build/components.js +0 -133
- package/dist/build/fonts.d.ts +0 -4
- package/dist/build/fonts.js +0 -49
- package/dist/build/frameworks.d.ts +0 -4
- package/dist/build/frameworks.js +0 -61
- package/dist/build/static.d.ts +0 -4
- package/dist/build/static.js +0 -65
- package/dist/build/styles.d.ts +0 -4
- package/dist/build/styles.js +0 -58
- package/dist/build/tokens.d.ts +0 -4
- package/dist/build/tokens.js +0 -59
- package/dist/tools/davinci-migration.d.ts +0 -3
- package/dist/tools/davinci-migration.js +0 -66
- package/dist/tools/font-info.d.ts +0 -6
- package/dist/tools/font-info.js +0 -35
- package/dist/tools/framework-info.d.ts +0 -7
- package/dist/tools/framework-info.js +0 -58
- package/dist/tools/tokens.js +0 -24
- package/dist/tools/version.d.ts +0 -7
- package/dist/tools/version.js +0 -53
- package/dist/utilities/assets.d.ts +0 -2
- package/dist/utilities/assets.js +0 -3
- package/dist/utilities/checksum.d.ts +0 -36
- package/dist/utilities/checksum.js +0 -94
- package/dist/utilities/components.d.ts +0 -25
- package/dist/utilities/components.js +0 -86
- package/dist/utilities/file.d.ts +0 -12
- package/dist/utilities/file.js +0 -31
- package/dist/utilities/fonts.d.ts +0 -2
- package/dist/utilities/fonts.js +0 -3
- package/dist/utilities/stdio.d.ts +0 -14
- package/dist/utilities/stdio.js +0 -60
- package/dist/utilities/storybook/build-docs.d.ts +0 -2
- package/dist/utilities/storybook/build-docs.js +0 -43
- package/dist/utilities/storybook/configs.d.ts +0 -13
- package/dist/utilities/storybook/configs.js +0 -85
- package/dist/utilities/storybook/docs-scraper.d.ts +0 -26
- package/dist/utilities/storybook/docs-scraper.js +0 -96
- package/dist/utilities/storybook/index.d.ts +0 -5
- package/dist/utilities/storybook/index.js +0 -4
- package/dist/utilities/storybook/scraper.d.ts +0 -14
- package/dist/utilities/storybook/scraper.js +0 -243
- package/dist/utilities/storybook/storybook-manager.d.ts +0 -29
- package/dist/utilities/storybook/storybook-manager.js +0 -138
- package/dist/utilities/storybook/types.d.ts +0 -22
- package/dist/utilities/storybook/types.js +0 -1
- package/dist/utilities/styles.d.ts +0 -6
- package/dist/utilities/styles.js +0 -24
- package/dist/utilities/templates.d.ts +0 -12
- package/dist/utilities/templates.js +0 -28
- package/dist/utilities/tokens.d.ts +0 -1
- package/dist/utilities/tokens.js +0 -21
- package/dist/utilities/version.d.ts +0 -28
- package/dist/utilities/version.js +0 -21
- package/metadata/checksum.txt +0 -1
- package/metadata/davinci-migration/migration-guide.md +0 -1859
- package/metadata/packages/angular/LIMITATIONS.md +0 -32
- package/metadata/packages/angular/README.md +0 -393
- package/metadata/packages/assets/BREAKING_CHANGES.md +0 -305
- package/metadata/packages/assets/CHANGELOG.md +0 -374
- package/metadata/packages/assets/README.md +0 -103
- package/metadata/packages/components/components/syn-accordion/component.angular.ts +0 -80
- package/metadata/packages/components/components/syn-accordion/component.react.ts +0 -30
- package/metadata/packages/components/components/syn-accordion/component.styles.ts +0 -15
- package/metadata/packages/components/components/syn-accordion/component.ts +0 -111
- package/metadata/packages/components/components/syn-accordion/component.vue +0 -64
- package/metadata/packages/components/components/syn-alert/component.angular.ts +0 -169
- package/metadata/packages/components/components/syn-alert/component.react.ts +0 -60
- package/metadata/packages/components/components/syn-alert/component.styles.ts +0 -203
- package/metadata/packages/components/components/syn-alert/component.ts +0 -322
- package/metadata/packages/components/components/syn-alert/component.vue +0 -135
- package/metadata/packages/components/components/syn-badge/component.angular.ts +0 -53
- package/metadata/packages/components/components/syn-badge/component.custom.styles.ts +0 -62
- package/metadata/packages/components/components/syn-badge/component.react.ts +0 -29
- package/metadata/packages/components/components/syn-badge/component.styles.ts +0 -52
- package/metadata/packages/components/components/syn-badge/component.ts +0 -58
- package/metadata/packages/components/components/syn-badge/component.vue +0 -53
- package/metadata/packages/components/components/syn-breadcrumb/component.angular.ts +0 -58
- package/metadata/packages/components/components/syn-breadcrumb/component.custom.styles.ts +0 -5
- package/metadata/packages/components/components/syn-breadcrumb/component.react.ts +0 -32
- package/metadata/packages/components/components/syn-breadcrumb/component.styles.ts +0 -11
- package/metadata/packages/components/components/syn-breadcrumb/component.ts +0 -103
- package/metadata/packages/components/components/syn-breadcrumb/component.vue +0 -58
- package/metadata/packages/components/components/syn-breadcrumb-item/component.angular.ts +0 -88
- package/metadata/packages/components/components/syn-breadcrumb-item/component.custom.styles.ts +0 -78
- package/metadata/packages/components/components/syn-breadcrumb-item/component.react.ts +0 -37
- package/metadata/packages/components/components/syn-breadcrumb-item/component.styles.ts +0 -88
- package/metadata/packages/components/components/syn-breadcrumb-item/component.ts +0 -132
- package/metadata/packages/components/components/syn-breadcrumb-item/component.vue +0 -76
- package/metadata/packages/components/components/syn-button/component.angular.ts +0 -318
- package/metadata/packages/components/components/syn-button/component.custom.styles.ts +0 -245
- package/metadata/packages/components/components/syn-button/component.react.ts +0 -56
- package/metadata/packages/components/components/syn-button/component.styles.ts +0 -361
- package/metadata/packages/components/components/syn-button/component.ts +0 -315
- package/metadata/packages/components/components/syn-button/component.vue +0 -204
- package/metadata/packages/components/components/syn-button-group/component.angular.ts +0 -79
- package/metadata/packages/components/components/syn-button-group/component.custom.styles.ts +0 -5
- package/metadata/packages/components/components/syn-button-group/component.react.ts +0 -29
- package/metadata/packages/components/components/syn-button-group/component.styles.ts +0 -14
- package/metadata/packages/components/components/syn-button-group/component.ts +0 -171
- package/metadata/packages/components/components/syn-button-group/component.vue +0 -67
- package/metadata/packages/components/components/syn-card/component.angular.ts +0 -83
- package/metadata/packages/components/components/syn-card/component.custom.styles.ts +0 -60
- package/metadata/packages/components/components/syn-card/component.react.ts +0 -41
- package/metadata/packages/components/components/syn-card/component.styles.ts +0 -70
- package/metadata/packages/components/components/syn-card/component.ts +0 -65
- package/metadata/packages/components/components/syn-card/component.vue +0 -73
- package/metadata/packages/components/components/syn-checkbox/component.angular.ts +0 -273
- package/metadata/packages/components/components/syn-checkbox/component.react.ts +0 -64
- package/metadata/packages/components/components/syn-checkbox/component.styles.ts +0 -183
- package/metadata/packages/components/components/syn-checkbox/component.ts +0 -287
- package/metadata/packages/components/components/syn-checkbox/component.vue +0 -191
- package/metadata/packages/components/components/syn-combobox/component.angular.ts +0 -516
- package/metadata/packages/components/components/syn-combobox/component.react.ts +0 -118
- package/metadata/packages/components/components/syn-combobox/component.styles.ts +0 -393
- package/metadata/packages/components/components/syn-combobox/component.ts +0 -1684
- package/metadata/packages/components/components/syn-combobox/component.vue +0 -350
- package/metadata/packages/components/components/syn-details/component.angular.ts +0 -186
- package/metadata/packages/components/components/syn-details/component.react.ts +0 -65
- package/metadata/packages/components/components/syn-details/component.styles.ts +0 -181
- package/metadata/packages/components/components/syn-details/component.ts +0 -261
- package/metadata/packages/components/components/syn-details/component.vue +0 -136
- package/metadata/packages/components/components/syn-dialog/component.angular.ts +0 -201
- package/metadata/packages/components/components/syn-dialog/component.react.ts +0 -91
- package/metadata/packages/components/components/syn-dialog/component.styles.ts +0 -130
- package/metadata/packages/components/components/syn-dialog/component.ts +0 -367
- package/metadata/packages/components/components/syn-dialog/component.vue +0 -169
- package/metadata/packages/components/components/syn-divider/component.angular.ts +0 -55
- package/metadata/packages/components/components/syn-divider/component.react.ts +0 -29
- package/metadata/packages/components/components/syn-divider/component.styles.ts +0 -22
- package/metadata/packages/components/components/syn-divider/component.ts +0 -34
- package/metadata/packages/components/components/syn-divider/component.vue +0 -51
- package/metadata/packages/components/components/syn-drawer/component.angular.ts +0 -234
- package/metadata/packages/components/components/syn-drawer/component.custom.styles.ts +0 -78
- package/metadata/packages/components/components/syn-drawer/component.react.ts +0 -98
- package/metadata/packages/components/components/syn-drawer/component.styles.ts +0 -158
- package/metadata/packages/components/components/syn-drawer/component.ts +0 -489
- package/metadata/packages/components/components/syn-drawer/component.vue +0 -188
- package/metadata/packages/components/components/syn-dropdown/component.angular.ts +0 -208
- package/metadata/packages/components/components/syn-dropdown/component.react.ts +0 -59
- package/metadata/packages/components/components/syn-dropdown/component.styles.ts +0 -51
- package/metadata/packages/components/components/syn-dropdown/component.ts +0 -469
- package/metadata/packages/components/components/syn-dropdown/component.vue +0 -152
- package/metadata/packages/components/components/syn-file/component.angular.ts +0 -372
- package/metadata/packages/components/components/syn-file/component.react.ts +0 -85
- package/metadata/packages/components/components/syn-file/component.styles.ts +0 -197
- package/metadata/packages/components/components/syn-file/component.ts +0 -645
- package/metadata/packages/components/components/syn-file/component.vue +0 -256
- package/metadata/packages/components/components/syn-header/component.angular.ts +0 -149
- package/metadata/packages/components/components/syn-header/component.react.ts +0 -68
- package/metadata/packages/components/components/syn-header/component.styles.ts +0 -143
- package/metadata/packages/components/components/syn-header/component.ts +0 -310
- package/metadata/packages/components/components/syn-header/component.vue +0 -126
- package/metadata/packages/components/components/syn-icon/component.angular.ts +0 -115
- package/metadata/packages/components/components/syn-icon/component.custom.styles.ts +0 -5
- package/metadata/packages/components/components/syn-icon/component.react.ts +0 -41
- package/metadata/packages/components/components/syn-icon/component.styles.ts +0 -18
- package/metadata/packages/components/components/syn-icon/component.ts +0 -227
- package/metadata/packages/components/components/syn-icon/component.vue +0 -100
- package/metadata/packages/components/components/syn-icon-button/component.angular.ts +0 -185
- package/metadata/packages/components/components/syn-icon-button/component.custom.styles.ts +0 -79
- package/metadata/packages/components/components/syn-icon-button/component.react.ts +0 -42
- package/metadata/packages/components/components/syn-icon-button/component.styles.ts +0 -52
- package/metadata/packages/components/components/syn-icon-button/component.ts +0 -147
- package/metadata/packages/components/components/syn-icon-button/component.vue +0 -132
- package/metadata/packages/components/components/syn-input/component.angular.ts +0 -608
- package/metadata/packages/components/components/syn-input/component.custom.styles.ts +0 -278
- package/metadata/packages/components/components/syn-input/component.react.ts +0 -91
- package/metadata/packages/components/components/syn-input/component.styles.ts +0 -280
- package/metadata/packages/components/components/syn-input/component.ts +0 -941
- package/metadata/packages/components/components/syn-input/component.vue +0 -370
- package/metadata/packages/components/components/syn-menu/component.angular.ts +0 -52
- package/metadata/packages/components/components/syn-menu/component.react.ts +0 -36
- package/metadata/packages/components/components/syn-menu/component.styles.ts +0 -37
- package/metadata/packages/components/components/syn-menu/component.ts +0 -191
- package/metadata/packages/components/components/syn-menu/component.vue +0 -48
- package/metadata/packages/components/components/syn-menu-item/component.angular.ts +0 -121
- package/metadata/packages/components/components/syn-menu-item/component.react.ts +0 -45
- package/metadata/packages/components/components/syn-menu-item/component.styles.ts +0 -285
- package/metadata/packages/components/components/syn-menu-item/component.ts +0 -201
- package/metadata/packages/components/components/syn-menu-item/component.vue +0 -91
- package/metadata/packages/components/components/syn-menu-label/component.angular.ts +0 -48
- package/metadata/packages/components/components/syn-menu-label/component.react.ts +0 -35
- package/metadata/packages/components/components/syn-menu-label/component.styles.ts +0 -31
- package/metadata/packages/components/components/syn-menu-label/component.ts +0 -46
- package/metadata/packages/components/components/syn-menu-label/component.vue +0 -41
- package/metadata/packages/components/components/syn-nav-item/component.angular.ts +0 -242
- package/metadata/packages/components/components/syn-nav-item/component.react.ts +0 -82
- package/metadata/packages/components/components/syn-nav-item/component.styles.ts +0 -333
- package/metadata/packages/components/components/syn-nav-item/component.ts +0 -491
- package/metadata/packages/components/components/syn-nav-item/component.vue +0 -182
- package/metadata/packages/components/components/syn-optgroup/component.angular.ts +0 -79
- package/metadata/packages/components/components/syn-optgroup/component.react.ts +0 -41
- package/metadata/packages/components/components/syn-optgroup/component.styles.ts +0 -61
- package/metadata/packages/components/components/syn-optgroup/component.ts +0 -176
- package/metadata/packages/components/components/syn-optgroup/component.vue +0 -71
- package/metadata/packages/components/components/syn-option/component.angular.ts +0 -79
- package/metadata/packages/components/components/syn-option/component.react.ts +0 -37
- package/metadata/packages/components/components/syn-option/component.styles.ts +0 -165
- package/metadata/packages/components/components/syn-option/component.ts +0 -191
- package/metadata/packages/components/components/syn-option/component.vue +0 -71
- package/metadata/packages/components/components/syn-pagination/component.angular.ts +0 -201
- package/metadata/packages/components/components/syn-pagination/component.react.ts +0 -56
- package/metadata/packages/components/components/syn-pagination/component.styles.ts +0 -128
- package/metadata/packages/components/components/syn-pagination/component.ts +0 -452
- package/metadata/packages/components/components/syn-pagination/component.vue +0 -144
- package/metadata/packages/components/components/syn-popup/component.angular.ts +0 -372
- package/metadata/packages/components/components/syn-popup/component.react.ts +0 -55
- package/metadata/packages/components/components/syn-popup/component.styles.ts +0 -70
- package/metadata/packages/components/components/syn-popup/component.ts +0 -582
- package/metadata/packages/components/components/syn-popup/component.vue +0 -233
- package/metadata/packages/components/components/syn-prio-nav/component.angular.ts +0 -67
- package/metadata/packages/components/components/syn-prio-nav/component.react.ts +0 -54
- package/metadata/packages/components/components/syn-prio-nav/component.styles.ts +0 -48
- package/metadata/packages/components/components/syn-prio-nav/component.ts +0 -288
- package/metadata/packages/components/components/syn-prio-nav/component.vue +0 -60
- package/metadata/packages/components/components/syn-progress-bar/component.angular.ts +0 -85
- package/metadata/packages/components/components/syn-progress-bar/component.custom.styles.ts +0 -24
- package/metadata/packages/components/components/syn-progress-bar/component.react.ts +0 -37
- package/metadata/packages/components/components/syn-progress-bar/component.styles.ts +0 -87
- package/metadata/packages/components/components/syn-progress-bar/component.ts +0 -67
- package/metadata/packages/components/components/syn-progress-bar/component.vue +0 -71
- package/metadata/packages/components/components/syn-progress-ring/component.angular.ts +0 -72
- package/metadata/packages/components/components/syn-progress-ring/component.custom.styles.ts +0 -19
- package/metadata/packages/components/components/syn-progress-ring/component.react.ts +0 -37
- package/metadata/packages/components/components/syn-progress-ring/component.styles.ts +0 -70
- package/metadata/packages/components/components/syn-progress-ring/component.ts +0 -83
- package/metadata/packages/components/components/syn-progress-ring/component.vue +0 -66
- package/metadata/packages/components/components/syn-radio/component.angular.ts +0 -122
- package/metadata/packages/components/components/syn-radio/component.react.ts +0 -48
- package/metadata/packages/components/components/syn-radio/component.styles.ts +0 -179
- package/metadata/packages/components/components/syn-radio/component.ts +0 -131
- package/metadata/packages/components/components/syn-radio/component.vue +0 -104
- package/metadata/packages/components/components/syn-radio-button/component.angular.ts +0 -123
- package/metadata/packages/components/components/syn-radio-button/component.react.ts +0 -49
- package/metadata/packages/components/components/syn-radio-button/component.styles.ts +0 -30
- package/metadata/packages/components/components/syn-radio-button/component.ts +0 -142
- package/metadata/packages/components/components/syn-radio-button/component.vue +0 -105
- package/metadata/packages/components/components/syn-radio-group/component.angular.ts +0 -204
- package/metadata/packages/components/components/syn-radio-group/component.react.ts +0 -56
- package/metadata/packages/components/components/syn-radio-group/component.styles.ts +0 -58
- package/metadata/packages/components/components/syn-radio-group/component.ts +0 -440
- package/metadata/packages/components/components/syn-radio-group/component.vue +0 -158
- package/metadata/packages/components/components/syn-range/component.angular.ts +0 -347
- package/metadata/packages/components/components/syn-range/component.react.ts +0 -92
- package/metadata/packages/components/components/syn-range/component.styles.ts +0 -310
- package/metadata/packages/components/components/syn-range/component.ts +0 -933
- package/metadata/packages/components/components/syn-range/component.vue +0 -245
- package/metadata/packages/components/components/syn-range-tick/component.angular.ts +0 -59
- package/metadata/packages/components/components/syn-range-tick/component.react.ts +0 -33
- package/metadata/packages/components/components/syn-range-tick/component.styles.ts +0 -34
- package/metadata/packages/components/components/syn-range-tick/component.ts +0 -50
- package/metadata/packages/components/components/syn-range-tick/component.vue +0 -57
- package/metadata/packages/components/components/syn-resize-observer/component.styles.ts +0 -9
- package/metadata/packages/components/components/syn-resize-observer/component.ts +0 -91
- package/metadata/packages/components/components/syn-select/component.angular.ts +0 -439
- package/metadata/packages/components/components/syn-select/component.react.ts +0 -101
- package/metadata/packages/components/components/syn-select/component.styles.ts +0 -380
- package/metadata/packages/components/components/syn-select/component.ts +0 -1056
- package/metadata/packages/components/components/syn-select/component.vue +0 -301
- package/metadata/packages/components/components/syn-side-nav/component.angular.ts +0 -210
- package/metadata/packages/components/components/syn-side-nav/component.react.ts +0 -95
- package/metadata/packages/components/components/syn-side-nav/component.styles.ts +0 -142
- package/metadata/packages/components/components/syn-side-nav/component.ts +0 -458
- package/metadata/packages/components/components/syn-side-nav/component.vue +0 -188
- package/metadata/packages/components/components/syn-spinner/component.angular.ts +0 -44
- package/metadata/packages/components/components/syn-spinner/component.custom.styles.ts +0 -32
- package/metadata/packages/components/components/syn-spinner/component.react.ts +0 -31
- package/metadata/packages/components/components/syn-spinner/component.styles.ts +0 -48
- package/metadata/packages/components/components/syn-spinner/component.ts +0 -35
- package/metadata/packages/components/components/syn-spinner/component.vue +0 -35
- package/metadata/packages/components/components/syn-switch/component.angular.ts +0 -257
- package/metadata/packages/components/components/syn-switch/component.react.ts +0 -63
- package/metadata/packages/components/components/syn-switch/component.styles.ts +0 -252
- package/metadata/packages/components/components/syn-switch/component.ts +0 -279
- package/metadata/packages/components/components/syn-switch/component.vue +0 -183
- package/metadata/packages/components/components/syn-tab/component.angular.ts +0 -109
- package/metadata/packages/components/components/syn-tab/component.custom.styles.ts +0 -94
- package/metadata/packages/components/components/syn-tab/component.react.ts +0 -42
- package/metadata/packages/components/components/syn-tab/component.styles.ts +0 -70
- package/metadata/packages/components/components/syn-tab/component.ts +0 -125
- package/metadata/packages/components/components/syn-tab/component.vue +0 -91
- package/metadata/packages/components/components/syn-tab-group/component.angular.ts +0 -166
- package/metadata/packages/components/components/syn-tab-group/component.custom.styles.ts +0 -218
- package/metadata/packages/components/components/syn-tab-group/component.react.ts +0 -58
- package/metadata/packages/components/components/syn-tab-group/component.styles.ts +0 -193
- package/metadata/packages/components/components/syn-tab-group/component.ts +0 -551
- package/metadata/packages/components/components/syn-tab-group/component.vue +0 -126
- package/metadata/packages/components/components/syn-tab-panel/component.angular.ts +0 -68
- package/metadata/packages/components/components/syn-tab-panel/component.custom.styles.ts +0 -8
- package/metadata/packages/components/components/syn-tab-panel/component.react.ts +0 -31
- package/metadata/packages/components/components/syn-tab-panel/component.styles.ts +0 -20
- package/metadata/packages/components/components/syn-tab-panel/component.ts +0 -60
- package/metadata/packages/components/components/syn-tab-panel/component.vue +0 -60
- package/metadata/packages/components/components/syn-tag/component.angular.ts +0 -83
- package/metadata/packages/components/components/syn-tag/component.custom.styles.ts +0 -121
- package/metadata/packages/components/components/syn-tag/component.react.ts +0 -43
- package/metadata/packages/components/components/syn-tag/component.styles.ts +0 -58
- package/metadata/packages/components/components/syn-tag/component.ts +0 -83
- package/metadata/packages/components/components/syn-tag/component.vue +0 -81
- package/metadata/packages/components/components/syn-tag-group/component.angular.ts +0 -83
- package/metadata/packages/components/components/syn-tag-group/component.react.ts +0 -33
- package/metadata/packages/components/components/syn-tag-group/component.styles.ts +0 -49
- package/metadata/packages/components/components/syn-tag-group/component.ts +0 -95
- package/metadata/packages/components/components/syn-tag-group/component.vue +0 -69
- package/metadata/packages/components/components/syn-textarea/component.angular.ts +0 -396
- package/metadata/packages/components/components/syn-textarea/component.react.ts +0 -60
- package/metadata/packages/components/components/syn-textarea/component.styles.ts +0 -208
- package/metadata/packages/components/components/syn-textarea/component.ts +0 -400
- package/metadata/packages/components/components/syn-textarea/component.vue +0 -244
- package/metadata/packages/components/components/syn-tooltip/component.angular.ts +0 -196
- package/metadata/packages/components/components/syn-tooltip/component.react.ts +0 -63
- package/metadata/packages/components/components/syn-tooltip/component.styles.ts +0 -62
- package/metadata/packages/components/components/syn-tooltip/component.ts +0 -312
- package/metadata/packages/components/components/syn-tooltip/component.vue +0 -150
- package/metadata/packages/components/components/syn-validate/component.angular.ts +0 -137
- package/metadata/packages/components/components/syn-validate/component.react.ts +0 -44
- package/metadata/packages/components/components/syn-validate/component.styles.ts +0 -9
- package/metadata/packages/components/components/syn-validate/component.ts +0 -590
- package/metadata/packages/components/components/syn-validate/component.vue +0 -107
- package/metadata/packages/components/migration/BREAKING_CHANGES.md +0 -908
- package/metadata/packages/components/static/CHANGELOG.md +0 -2155
- package/metadata/packages/components/static/LIMITATIONS.md +0 -433
- package/metadata/packages/components/static/README.md +0 -231
- package/metadata/packages/fonts/CHANGELOG.md +0 -57
- package/metadata/packages/fonts/README.md +0 -164
- package/metadata/packages/fonts/package.json +0 -72
- package/metadata/packages/react/LIMITATIONS.md +0 -31
- package/metadata/packages/react/README.md +0 -262
- package/metadata/packages/styles/BREAKING_CHANGES.md +0 -105
- package/metadata/packages/styles/CHANGELOG.md +0 -188
- package/metadata/packages/styles/README.md +0 -132
- package/metadata/packages/styles/index.css +0 -300
- package/metadata/packages/styles/link-list.css +0 -47
- package/metadata/packages/styles/link.css +0 -81
- package/metadata/packages/styles/tables.css +0 -132
- package/metadata/packages/styles/typography.css +0 -52
- package/metadata/packages/tokens/BREAKING_CHANGES.md +0 -180
- package/metadata/packages/tokens/CHANGELOG.md +0 -959
- package/metadata/packages/tokens/README.md +0 -435
- package/metadata/packages/tokens/dark.css +0 -454
- package/metadata/packages/tokens/index.js +0 -2224
- package/metadata/packages/tokens/light.css +0 -454
- package/metadata/packages/tokens/sick2018_dark.css +0 -454
- package/metadata/packages/tokens/sick2018_light.css +0 -454
- package/metadata/packages/tokens/sick2025_dark.css +0 -454
- package/metadata/packages/tokens/sick2025_light.css +0 -454
- package/metadata/packages/vue/LIMITATIONS.md +0 -53
- package/metadata/packages/vue/README.md +0 -252
- package/metadata/static/assets/index.md +0 -10
- package/metadata/static/components/index.md +0 -10
- package/metadata/static/components/syn-accordion/docs.md +0 -449
- package/metadata/static/components/syn-alert/docs.md +0 -282
- package/metadata/static/components/syn-badge/docs.md +0 -106
- package/metadata/static/components/syn-breadcrumb/docs.md +0 -265
- package/metadata/static/components/syn-breadcrumb-item/docs.md +0 -49
- package/metadata/static/components/syn-button/docs.md +0 -472
- package/metadata/static/components/syn-button-group/docs.md +0 -259
- package/metadata/static/components/syn-card/docs.md +0 -314
- package/metadata/static/components/syn-checkbox/docs.md +0 -176
- package/metadata/static/components/syn-combobox/docs.md +0 -2633
- package/metadata/static/components/syn-details/docs.md +0 -227
- package/metadata/static/components/syn-dialog/docs.md +0 -220
- package/metadata/static/components/syn-divider/docs.md +0 -77
- package/metadata/static/components/syn-drawer/docs.md +0 -269
- package/metadata/static/components/syn-dropdown/docs.md +0 -316
- package/metadata/static/components/syn-file/docs.md +0 -239
- package/metadata/static/components/syn-header/docs.md +0 -209
- package/metadata/static/components/syn-icon/docs.md +0 -177
- package/metadata/static/components/syn-icon-button/docs.md +0 -142
- package/metadata/static/components/syn-input/docs.md +0 -462
- package/metadata/static/components/syn-menu/docs.md +0 -162
- package/metadata/static/components/syn-menu-item/docs.md +0 -216
- package/metadata/static/components/syn-menu-label/docs.md +0 -29
- package/metadata/static/components/syn-nav-item/docs.md +0 -166
- package/metadata/static/components/syn-optgroup/docs.md +0 -167
- package/metadata/static/components/syn-option/docs.md +0 -137
- package/metadata/static/components/syn-pagination/docs.md +0 -102
- package/metadata/static/components/syn-popup/docs.md +0 -812
- package/metadata/static/components/syn-prio-nav/docs.md +0 -54
- package/metadata/static/components/syn-progress-bar/docs.md +0 -77
- package/metadata/static/components/syn-progress-ring/docs.md +0 -89
- package/metadata/static/components/syn-radio/docs.md +0 -178
- package/metadata/static/components/syn-radio-group/docs.md +0 -484
- package/metadata/static/components/syn-range/docs.md +0 -438
- package/metadata/static/components/syn-range-tick/docs.md +0 -110
- package/metadata/static/components/syn-select/docs.md +0 -811
- package/metadata/static/components/syn-side-nav/docs.md +0 -593
- package/metadata/static/components/syn-spinner/docs.md +0 -45
- package/metadata/static/components/syn-switch/docs.md +0 -121
- package/metadata/static/components/syn-tab/docs.md +0 -47
- package/metadata/static/components/syn-tab-group/docs.md +0 -1094
- package/metadata/static/components/syn-tab-panel/docs.md +0 -91
- package/metadata/static/components/syn-tag/docs.md +0 -50
- package/metadata/static/components/syn-tag-group/docs.md +0 -269
- package/metadata/static/components/syn-textarea/docs.md +0 -215
- package/metadata/static/components/syn-tooltip/docs.md +0 -217
- package/metadata/static/components/syn-validate/docs.md +0 -305
- package/metadata/static/fonts/index.md +0 -4
- package/metadata/static/migration/index.md +0 -57
- package/metadata/static/migration/v2-2018-to-v2-2025.md +0 -481
- package/metadata/static/migration/v2-2018-to-v3-2018.md +0 -147
- package/metadata/static/migration/v2-2018-to-v3-2025.md +0 -150
- package/metadata/static/migration/v2-2025-to-v3-2025.md +0 -133
- package/metadata/static/setup/icon-usage.md +0 -411
- package/metadata/static/setup/prerequisites.md +0 -319
- package/metadata/static/styles/syn-body.md +0 -5
- package/metadata/static/styles/syn-heading.md +0 -5
- package/metadata/static/styles/syn-link-list.md +0 -325
- package/metadata/static/styles/syn-link.md +0 -156
- package/metadata/static/styles/syn-table-cell.md +0 -127
- package/metadata/static/styles/syn-table.md +0 -201
- package/metadata/static/styles/syn-weight.md +0 -5
- package/metadata/static/templates/appshell.md +0 -2053
- package/metadata/static/templates/breadcrumb.md +0 -379
- package/metadata/static/templates/footer.md +0 -340
- package/metadata/static/templates/forms.md +0 -558
- package/metadata/static/templates/localization.md +0 -279
- package/metadata/static/templates/table.md +0 -1425
- package/metadata/static/templates/tag-group.md +0 -833
- /package/dist/{build/build.d.ts → utilities/logging-types.js} +0 -0
- /package/{metadata/static/component-info/index.md → rules/component-info.md} +0 -0
|
@@ -1,181 +0,0 @@
|
|
|
1
|
-
/* eslint-disable */
|
|
2
|
-
import { css } from 'lit';
|
|
3
|
-
|
|
4
|
-
export default css`
|
|
5
|
-
:host {
|
|
6
|
-
/* Size-dependent custom properties (default to medium values) */
|
|
7
|
-
--details-header-padding: var(--syn-spacing-medium-large) 0;
|
|
8
|
-
--details-content-padding: var(--syn-spacing-medium) 0 var(--syn-spacing-large);
|
|
9
|
-
--details-summary-font: var(--syn-body-medium-bold);
|
|
10
|
-
--details-content-font-size: var(--syn-font-size-small);
|
|
11
|
-
--details-icon-size: var(--syn-spacing-large);
|
|
12
|
-
--details-slotted-icon-size: var(--syn-spacing-large);
|
|
13
|
-
|
|
14
|
-
/* Contained variant custom properties */
|
|
15
|
-
--details-header-padding-contained: var(--syn-spacing-medium-large) var(--syn-spacing-large);
|
|
16
|
-
--details-content-padding-contained: var(--syn-spacing-medium) var(--syn-spacing-large) var(--syn-spacing-large);
|
|
17
|
-
|
|
18
|
-
display: block;
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
.details {
|
|
22
|
-
background-color: transparent;
|
|
23
|
-
border: 1px solid var(--syn-panel-border-color);
|
|
24
|
-
border-radius: var(--syn-border-radius-none);
|
|
25
|
-
border-width: 0 0 var(--syn-border-width-small);
|
|
26
|
-
overflow-anchor: none;
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
/** #429: Use token for opacity */
|
|
30
|
-
.details--disabled {
|
|
31
|
-
opacity: var(--syn-opacity-50);
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
.details__header {
|
|
35
|
-
align-items: center;
|
|
36
|
-
border-radius: inherit;
|
|
37
|
-
cursor: pointer;
|
|
38
|
-
display: flex;
|
|
39
|
-
gap: var(--syn-spacing-medium);
|
|
40
|
-
padding: var(--details-header-padding);
|
|
41
|
-
user-select: none;
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
.details__header::-webkit-details-marker {
|
|
45
|
-
display: none;
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
.details__header:focus {
|
|
49
|
-
outline: none;
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
.details__header:focus-visible {
|
|
53
|
-
outline: var(--syn-focus-ring);
|
|
54
|
-
outline-offset: calc(1px + var(--syn-focus-ring-offset));
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
.details--disabled .details__header {
|
|
58
|
-
cursor: not-allowed;
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
.details--disabled .details__header:focus-visible {
|
|
62
|
-
box-shadow: none;
|
|
63
|
-
outline: none;
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
.details__summary {
|
|
67
|
-
align-items: center;
|
|
68
|
-
color: var(--syn-typography-color-text);
|
|
69
|
-
display: flex;
|
|
70
|
-
flex: 1 1 auto;
|
|
71
|
-
font: var(--details-summary-font);
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
.details__summary-icon {
|
|
75
|
-
align-items: center;
|
|
76
|
-
align-self: flex-start;
|
|
77
|
-
color: var(--syn-color-neutral-950);
|
|
78
|
-
display: flex;
|
|
79
|
-
flex: 0 0 auto;
|
|
80
|
-
font-size: var(--details-icon-size);
|
|
81
|
-
position: relative;
|
|
82
|
-
|
|
83
|
-
/**
|
|
84
|
-
* As we are using an alignment of "start" instead of "center" make sure
|
|
85
|
-
* the arrow starts on the same visual line as the first line of headline text
|
|
86
|
-
*/
|
|
87
|
-
top: 2px;
|
|
88
|
-
transition: var(--syn-transition-medium) rotate ease;
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
/**
|
|
92
|
-
* As we are using top/down arrows for the details element,
|
|
93
|
-
* we have to adjust the rotation of the icon when the details is open.
|
|
94
|
-
*/
|
|
95
|
-
.details--open .details__summary-icon {
|
|
96
|
-
rotate: var(--syn-details-open-rotation);
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
.details--open slot[name='expand-icon'],
|
|
100
|
-
.details:not(.details--open) slot[name='collapse-icon'] {
|
|
101
|
-
display: none;
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
.details__body {
|
|
105
|
-
overflow: hidden;
|
|
106
|
-
}
|
|
107
|
-
|
|
108
|
-
.details__content {
|
|
109
|
-
display: block;
|
|
110
|
-
font-size: var(--details-content-font-size);
|
|
111
|
-
line-height: var(--syn-line-height-normal);
|
|
112
|
-
padding: var(--details-content-padding);
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
/**
|
|
116
|
-
* Size variants
|
|
117
|
-
*/
|
|
118
|
-
.details--size-small {
|
|
119
|
-
--details-header-padding: var(--syn-spacing-small) 0;
|
|
120
|
-
--details-content-padding: var(--syn-spacing-small) 0 var(--syn-spacing-medium-large);
|
|
121
|
-
--details-summary-font: var(--syn-body-small-bold);
|
|
122
|
-
--details-content-font-size: var(--syn-font-size-x-small);
|
|
123
|
-
--details-icon-size: var(--syn-spacing-medium-large);
|
|
124
|
-
--details-slotted-icon-size: var(--syn-spacing-medium-large);
|
|
125
|
-
--details-header-padding-contained: var(--syn-spacing-small) var(--syn-spacing-large);
|
|
126
|
-
--details-content-padding-contained: var(--syn-spacing-small) var(--syn-spacing-large) var(--syn-spacing-medium-large);
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
/* stylelint-disable-next-line no-descending-specificity */
|
|
130
|
-
.details--size-small .details__header {
|
|
131
|
-
min-height: var(--syn-spacing-large);
|
|
132
|
-
}
|
|
133
|
-
|
|
134
|
-
.details--size-large {
|
|
135
|
-
--details-header-padding: var(--syn-spacing-large) 0;
|
|
136
|
-
--details-content-padding: var(--syn-spacing-medium-large) 0 var(--syn-spacing-large);
|
|
137
|
-
--details-summary-font: var(--syn-body-large-bold);
|
|
138
|
-
--details-content-font-size: var(--syn-font-size-medium);
|
|
139
|
-
--details-icon-size: var(--syn-spacing-x-large);
|
|
140
|
-
--details-slotted-icon-size: var(--syn-spacing-x-large);
|
|
141
|
-
--details-header-padding-contained: var(--syn-spacing-large);
|
|
142
|
-
--details-content-padding-contained: var(--syn-spacing-medium-large) var(--syn-spacing-large) var(--syn-spacing-large);
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
.details__summary::slotted(syn-icon) {
|
|
146
|
-
/* Avoid shrinking of the icon, if the text content of the summary is very long and multi line */
|
|
147
|
-
flex-shrink: 0;
|
|
148
|
-
font-size: var(--details-slotted-icon-size);
|
|
149
|
-
margin-right: var(--syn-spacing-small);
|
|
150
|
-
}
|
|
151
|
-
|
|
152
|
-
/**
|
|
153
|
-
* Add a visually visible hover effect to the summary element
|
|
154
|
-
*/
|
|
155
|
-
.details:not(.details--disabled) .details__header:hover .details__summary,
|
|
156
|
-
.details:not(.details--disabled) .details__header:hover .details__summary-icon {
|
|
157
|
-
color: var(--syn-interactive-quiet-color-hover);
|
|
158
|
-
}
|
|
159
|
-
|
|
160
|
-
/**
|
|
161
|
-
* Contained style
|
|
162
|
-
*/
|
|
163
|
-
.details--contained {
|
|
164
|
-
background-color: var(--syn-panel-background-color);
|
|
165
|
-
border-radius: var(--syn-border-radius-medium);
|
|
166
|
-
border-width: var(--syn-panel-border-width);
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
/* stylelint-disable-next-line no-descending-specificity */
|
|
170
|
-
.details--contained .details__header {
|
|
171
|
-
padding: var(--details-header-padding-contained);
|
|
172
|
-
}
|
|
173
|
-
|
|
174
|
-
.details--contained .details__content {
|
|
175
|
-
padding: var(--details-content-padding-contained);
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
.details--contained .details__header:focus-visible {
|
|
179
|
-
border-radius: var(--syn-border-radius-medium);
|
|
180
|
-
}
|
|
181
|
-
`;
|
|
@@ -1,261 +0,0 @@
|
|
|
1
|
-
/* eslint-disable */
|
|
2
|
-
import { animateTo, shimKeyframesHeightAuto, stopAnimations } from '../../internal/animate.js';
|
|
3
|
-
import { classMap } from 'lit/directives/class-map.js';
|
|
4
|
-
import { getAnimation, setDefaultAnimation } from '../../utilities/animation-registry.js';
|
|
5
|
-
import { html } from 'lit';
|
|
6
|
-
import { LocalizeController } from '../../utilities/localize.js';
|
|
7
|
-
import { property, query } from 'lit/decorators.js';
|
|
8
|
-
import { waitForEvent } from '../../internal/event.js';
|
|
9
|
-
import { watch } from '../../internal/watch.js';
|
|
10
|
-
import componentStyles from '../../styles/component.styles.js';
|
|
11
|
-
import SynergyElement from '../../internal/synergy-element.js';
|
|
12
|
-
import SynIcon from '../icon/icon.component.js';
|
|
13
|
-
import styles from './details.styles.js';
|
|
14
|
-
import type { CSSResultGroup } from 'lit';
|
|
15
|
-
import { enableDefaultSettings } from '../../utilities/defaultSettings/decorator.js';
|
|
16
|
-
|
|
17
|
-
/**
|
|
18
|
-
* @summary Details show a brief summary and expand to show additional content.
|
|
19
|
-
* @documentation https://synergy-design-system.github.io/?path=/docs/components-syn-details--docs
|
|
20
|
-
* @status stable
|
|
21
|
-
* @since 2.0
|
|
22
|
-
*
|
|
23
|
-
* @dependency syn-icon
|
|
24
|
-
*
|
|
25
|
-
* @slot - The details' main content.
|
|
26
|
-
* @slot summary - The details' summary. Alternatively, you can use the `summary` attribute.
|
|
27
|
-
* @slot expand-icon - Optional expand icon to use instead of the default. Works best with `<syn-icon>`.
|
|
28
|
-
* @slot collapse-icon - Optional collapse icon to use instead of the default. Works best with `<syn-icon>`.
|
|
29
|
-
*
|
|
30
|
-
* @event syn-show - Emitted when the details opens.
|
|
31
|
-
* @event syn-after-show - Emitted after the details opens and all animations are complete.
|
|
32
|
-
* @event syn-hide - Emitted when the details closes.
|
|
33
|
-
* @event syn-after-hide - Emitted after the details closes and all animations are complete.
|
|
34
|
-
*
|
|
35
|
-
* @csspart base - The component's base wrapper.
|
|
36
|
-
* @csspart header - The header that wraps both the summary and the expand/collapse icon.
|
|
37
|
-
* @csspart summary - The container that wraps the summary.
|
|
38
|
-
* @csspart summary-icon - The container that wraps the expand/collapse icons.
|
|
39
|
-
* @csspart content - The details content.
|
|
40
|
-
* @csspart body - The container that wraps the details content.
|
|
41
|
-
*
|
|
42
|
-
* @animation details.show - The animation to use when showing details. You can use `height: auto` with this animation.
|
|
43
|
-
* @animation details.hide - The animation to use when hiding details. You can use `height: auto` with this animation.
|
|
44
|
-
*
|
|
45
|
-
* @cssproperty --syn-details-open-rotation - The rotation angle of the summary icon when the details is open.
|
|
46
|
-
*/
|
|
47
|
-
@enableDefaultSettings('SynDetails')
|
|
48
|
-
export default class SynDetails extends SynergyElement {
|
|
49
|
-
static styles: CSSResultGroup = [componentStyles, styles];
|
|
50
|
-
|
|
51
|
-
static dependencies = {
|
|
52
|
-
'syn-icon': SynIcon
|
|
53
|
-
};
|
|
54
|
-
|
|
55
|
-
private readonly localize = new LocalizeController(this);
|
|
56
|
-
|
|
57
|
-
@query('.details') details: HTMLDetailsElement;
|
|
58
|
-
@query('.details__header') header: HTMLElement;
|
|
59
|
-
@query('.details__body') body: HTMLElement;
|
|
60
|
-
@query('.details__expand-icon-slot') expandIconSlot: HTMLSlotElement;
|
|
61
|
-
|
|
62
|
-
detailsObserver: MutationObserver;
|
|
63
|
-
|
|
64
|
-
/**
|
|
65
|
-
* Indicates whether or not the details is open. You can toggle this attribute to show and hide the details, or you
|
|
66
|
-
* can use the `show()` and `hide()` methods and this attribute will reflect the details' open state.
|
|
67
|
-
*/
|
|
68
|
-
@property({ type: Boolean, reflect: true }) open = false;
|
|
69
|
-
|
|
70
|
-
/** The summary to show in the header. If you need to display HTML, use the `summary` slot instead. */
|
|
71
|
-
@property() summary: string;
|
|
72
|
-
|
|
73
|
-
/** Disables the details so it can't be toggled. */
|
|
74
|
-
@property({ type: Boolean, reflect: true }) disabled = false;
|
|
75
|
-
|
|
76
|
-
/** Draws the details as contained element. */
|
|
77
|
-
@property({ type: Boolean, reflect: true }) contained = false;
|
|
78
|
-
|
|
79
|
-
/** The details's size. */
|
|
80
|
-
@property({ reflect: true }) size: 'small' | 'medium' | 'large' = 'medium';
|
|
81
|
-
|
|
82
|
-
firstUpdated() {
|
|
83
|
-
this.body.style.height = this.open ? 'auto' : '0';
|
|
84
|
-
if (this.open) {
|
|
85
|
-
this.details.open = true;
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
this.detailsObserver = new MutationObserver(changes => {
|
|
89
|
-
for (const change of changes) {
|
|
90
|
-
if (change.type === 'attributes' && change.attributeName === 'open') {
|
|
91
|
-
if (this.details.open) {
|
|
92
|
-
this.show();
|
|
93
|
-
} else {
|
|
94
|
-
this.hide();
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
});
|
|
99
|
-
this.detailsObserver.observe(this.details, { attributes: true });
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
disconnectedCallback() {
|
|
103
|
-
super.disconnectedCallback();
|
|
104
|
-
this.detailsObserver?.disconnect();
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
private handleSummaryClick(event: MouseEvent) {
|
|
108
|
-
event.preventDefault();
|
|
109
|
-
|
|
110
|
-
if (!this.disabled) {
|
|
111
|
-
if (this.open) {
|
|
112
|
-
this.hide();
|
|
113
|
-
} else {
|
|
114
|
-
this.show();
|
|
115
|
-
}
|
|
116
|
-
this.header.focus();
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
private handleSummaryKeyDown(event: KeyboardEvent) {
|
|
121
|
-
if (event.key === 'Enter' || event.key === ' ') {
|
|
122
|
-
event.preventDefault();
|
|
123
|
-
|
|
124
|
-
if (this.open) {
|
|
125
|
-
this.hide();
|
|
126
|
-
} else {
|
|
127
|
-
this.show();
|
|
128
|
-
}
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
if (event.key === 'ArrowUp' || event.key === 'ArrowLeft') {
|
|
132
|
-
event.preventDefault();
|
|
133
|
-
this.hide();
|
|
134
|
-
}
|
|
135
|
-
|
|
136
|
-
if (event.key === 'ArrowDown' || event.key === 'ArrowRight') {
|
|
137
|
-
event.preventDefault();
|
|
138
|
-
this.show();
|
|
139
|
-
}
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
@watch('open', { waitUntilFirstUpdate: true })
|
|
143
|
-
async handleOpenChange() {
|
|
144
|
-
if (this.open) {
|
|
145
|
-
this.details.open = true;
|
|
146
|
-
// Show
|
|
147
|
-
const slShow = this.emit('syn-show', { cancelable: true });
|
|
148
|
-
if (slShow.defaultPrevented) {
|
|
149
|
-
this.open = false;
|
|
150
|
-
this.details.open = false;
|
|
151
|
-
return;
|
|
152
|
-
}
|
|
153
|
-
|
|
154
|
-
await stopAnimations(this.body);
|
|
155
|
-
|
|
156
|
-
const { keyframes, options } = getAnimation(this, 'details.show', { dir: this.localize.dir() });
|
|
157
|
-
await animateTo(this.body, shimKeyframesHeightAuto(keyframes, this.body.scrollHeight), options);
|
|
158
|
-
this.body.style.height = 'auto';
|
|
159
|
-
|
|
160
|
-
this.emit('syn-after-show');
|
|
161
|
-
} else {
|
|
162
|
-
// Hide
|
|
163
|
-
const slHide = this.emit('syn-hide', { cancelable: true });
|
|
164
|
-
if (slHide.defaultPrevented) {
|
|
165
|
-
this.details.open = true;
|
|
166
|
-
this.open = true;
|
|
167
|
-
return;
|
|
168
|
-
}
|
|
169
|
-
|
|
170
|
-
await stopAnimations(this.body);
|
|
171
|
-
|
|
172
|
-
const { keyframes, options } = getAnimation(this, 'details.hide', { dir: this.localize.dir() });
|
|
173
|
-
await animateTo(this.body, shimKeyframesHeightAuto(keyframes, this.body.scrollHeight), options);
|
|
174
|
-
this.body.style.height = 'auto';
|
|
175
|
-
|
|
176
|
-
this.details.open = false;
|
|
177
|
-
this.emit('syn-after-hide');
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
|
|
181
|
-
/** Shows the details. */
|
|
182
|
-
async show() {
|
|
183
|
-
if (this.open || this.disabled) {
|
|
184
|
-
return undefined;
|
|
185
|
-
}
|
|
186
|
-
|
|
187
|
-
this.open = true;
|
|
188
|
-
return waitForEvent(this, 'syn-after-show');
|
|
189
|
-
}
|
|
190
|
-
|
|
191
|
-
/** Hides the details */
|
|
192
|
-
async hide() {
|
|
193
|
-
if (!this.open || this.disabled) {
|
|
194
|
-
return undefined;
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
this.open = false;
|
|
198
|
-
return waitForEvent(this, 'syn-after-hide');
|
|
199
|
-
}
|
|
200
|
-
|
|
201
|
-
render() {
|
|
202
|
-
return html`
|
|
203
|
-
<details
|
|
204
|
-
part="base"
|
|
205
|
-
class=${classMap({
|
|
206
|
-
details: true,
|
|
207
|
-
'details--size-small': this.size === 'small',
|
|
208
|
-
'details--size-medium': this.size === 'medium',
|
|
209
|
-
'details--size-large': this.size === 'large',
|
|
210
|
-
'details--open': this.open,
|
|
211
|
-
'details--disabled': this.disabled,
|
|
212
|
-
'details--contained': this.contained,
|
|
213
|
-
})}
|
|
214
|
-
>
|
|
215
|
-
<summary
|
|
216
|
-
part="header"
|
|
217
|
-
id="header"
|
|
218
|
-
class="details__header"
|
|
219
|
-
role="button"
|
|
220
|
-
aria-expanded=${this.open ? 'true' : 'false'}
|
|
221
|
-
aria-controls="content"
|
|
222
|
-
aria-disabled=${this.disabled ? 'true' : 'false'}
|
|
223
|
-
tabindex=${this.disabled ? '-1' : '0'}
|
|
224
|
-
@click=${this.handleSummaryClick}
|
|
225
|
-
@keydown=${this.handleSummaryKeyDown}
|
|
226
|
-
>
|
|
227
|
-
<slot name="summary" part="summary" class="details__summary">${this.summary}</slot>
|
|
228
|
-
|
|
229
|
-
<span part="summary-icon" class="details__summary-icon">
|
|
230
|
-
<slot name="expand-icon">
|
|
231
|
-
<syn-icon library="system" name="details-open"></syn-icon>
|
|
232
|
-
</slot>
|
|
233
|
-
<slot name="collapse-icon">
|
|
234
|
-
<syn-icon library="system" name="details-close"></syn-icon>
|
|
235
|
-
</slot>
|
|
236
|
-
</span>
|
|
237
|
-
</summary>
|
|
238
|
-
|
|
239
|
-
<div class="details__body" part="body" role="region" aria-labelledby="header">
|
|
240
|
-
<slot part="content" id="content" class="details__content"></slot>
|
|
241
|
-
</div>
|
|
242
|
-
</details>
|
|
243
|
-
`;
|
|
244
|
-
}
|
|
245
|
-
}
|
|
246
|
-
|
|
247
|
-
setDefaultAnimation('details.show', {
|
|
248
|
-
keyframes: [
|
|
249
|
-
{ height: '0', opacity: '0' },
|
|
250
|
-
{ height: 'auto', opacity: '1' }
|
|
251
|
-
],
|
|
252
|
-
options: { duration: 250, easing: 'linear' }
|
|
253
|
-
});
|
|
254
|
-
|
|
255
|
-
setDefaultAnimation('details.hide', {
|
|
256
|
-
keyframes: [
|
|
257
|
-
{ height: 'auto', opacity: '1' },
|
|
258
|
-
{ height: '0', opacity: '0' }
|
|
259
|
-
],
|
|
260
|
-
options: { duration: 250, easing: 'linear' }
|
|
261
|
-
});
|
|
@@ -1,136 +0,0 @@
|
|
|
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 Details show a brief summary and expand to show additional content.
|
|
10
|
-
* @documentation https://synergy-design-system.github.io/?path=/docs/components-syn-details--docs
|
|
11
|
-
* @status stable
|
|
12
|
-
* @since 2.0
|
|
13
|
-
*
|
|
14
|
-
* @dependency syn-icon
|
|
15
|
-
*
|
|
16
|
-
* @slot - The details' main content.
|
|
17
|
-
* @slot summary - The details' summary. Alternatively, you can use the `summary` attribute.
|
|
18
|
-
* @slot expand-icon - Optional expand icon to use instead of the default. Works best with `<syn-icon>`.
|
|
19
|
-
* @slot collapse-icon - Optional collapse icon to use instead of the default. Works best with `<syn-icon>`.
|
|
20
|
-
*
|
|
21
|
-
* @event syn-show - Emitted when the details opens.
|
|
22
|
-
* @event syn-after-show - Emitted after the details opens and all animations are complete.
|
|
23
|
-
* @event syn-hide - Emitted when the details closes.
|
|
24
|
-
* @event syn-after-hide - Emitted after the details closes and all animations are complete.
|
|
25
|
-
*
|
|
26
|
-
* @csspart base - The component's base wrapper.
|
|
27
|
-
* @csspart header - The header that wraps both the summary and the expand/collapse icon.
|
|
28
|
-
* @csspart summary - The container that wraps the summary.
|
|
29
|
-
* @csspart summary-icon - The container that wraps the expand/collapse icons.
|
|
30
|
-
* @csspart content - The details content.
|
|
31
|
-
* @csspart body - The container that wraps the details content.
|
|
32
|
-
*
|
|
33
|
-
* @animation details.show - The animation to use when showing details. You can use `height: auto` with this animation.
|
|
34
|
-
* @animation details.hide - The animation to use when hiding details. You can use `height: auto` with this animation.
|
|
35
|
-
*
|
|
36
|
-
* @cssproperty --syn-details-open-rotation - The rotation angle of the summary icon when the details is open.
|
|
37
|
-
*/
|
|
38
|
-
import { computed, ref } from 'vue';
|
|
39
|
-
import '@synergy-design-system/components/components/details/details.js';
|
|
40
|
-
|
|
41
|
-
import type { SynShowEvent } from '@synergy-design-system/components';
|
|
42
|
-
import type { SynAfterShowEvent } from '@synergy-design-system/components';
|
|
43
|
-
import type { SynHideEvent } from '@synergy-design-system/components';
|
|
44
|
-
import type { SynAfterHideEvent } from '@synergy-design-system/components';
|
|
45
|
-
import type { SynDetails } from '@synergy-design-system/components';
|
|
46
|
-
|
|
47
|
-
// DOM Reference to the element
|
|
48
|
-
const nativeElement = ref<SynDetails>();
|
|
49
|
-
|
|
50
|
-
defineExpose({
|
|
51
|
-
nativeElement,
|
|
52
|
-
});
|
|
53
|
-
|
|
54
|
-
// Map attributes
|
|
55
|
-
const props = defineProps<{
|
|
56
|
-
/**
|
|
57
|
-
* Indicates whether or not the details is open.
|
|
58
|
-
* You can toggle this attribute to show and hide the details, or you
|
|
59
|
-
can use the `show()` and `hide()` methods and this attribute will reflect the details' open state.
|
|
60
|
-
*/
|
|
61
|
-
open?: SynDetails['open'];
|
|
62
|
-
|
|
63
|
-
/**
|
|
64
|
-
* The summary to show in the header.
|
|
65
|
-
* If you need to display HTML, use the `summary` slot instead.
|
|
66
|
-
*/
|
|
67
|
-
summary?: SynDetails['summary'];
|
|
68
|
-
|
|
69
|
-
/**
|
|
70
|
-
* Disables the details so it can't be toggled.
|
|
71
|
-
*/
|
|
72
|
-
disabled?: SynDetails['disabled'];
|
|
73
|
-
|
|
74
|
-
/**
|
|
75
|
-
* Draws the details as contained element.
|
|
76
|
-
*/
|
|
77
|
-
contained?: SynDetails['contained'];
|
|
78
|
-
|
|
79
|
-
/**
|
|
80
|
-
* The details's size.
|
|
81
|
-
*/
|
|
82
|
-
size?: SynDetails['size'];
|
|
83
|
-
}>();
|
|
84
|
-
|
|
85
|
-
// Make sure prop binding only forwards the props that are actually there.
|
|
86
|
-
// This is needed because :param="param" also adds an empty attribute
|
|
87
|
-
// when using web-components, which breaks optional arguments like size in SynInput
|
|
88
|
-
// @see https://github.com/vuejs/core/issues/5190#issuecomment-1003112498
|
|
89
|
-
const visibleProps = computed(() =>
|
|
90
|
-
Object.fromEntries(
|
|
91
|
-
Object.entries(props).filter(([, value]) => typeof value !== 'undefined'),
|
|
92
|
-
),
|
|
93
|
-
);
|
|
94
|
-
|
|
95
|
-
// Map events
|
|
96
|
-
defineEmits<{
|
|
97
|
-
/**
|
|
98
|
-
* Emitted when the details opens.
|
|
99
|
-
*/
|
|
100
|
-
'syn-show': [e: SynShowEvent];
|
|
101
|
-
|
|
102
|
-
/**
|
|
103
|
-
* Emitted after the details opens and all animations are complete.
|
|
104
|
-
*/
|
|
105
|
-
'syn-after-show': [e: SynAfterShowEvent];
|
|
106
|
-
|
|
107
|
-
/**
|
|
108
|
-
* Emitted when the details closes.
|
|
109
|
-
*/
|
|
110
|
-
'syn-hide': [e: SynHideEvent];
|
|
111
|
-
|
|
112
|
-
/**
|
|
113
|
-
* Emitted after the details closes and all animations are complete.
|
|
114
|
-
*/
|
|
115
|
-
'syn-after-hide': [e: SynAfterHideEvent];
|
|
116
|
-
}>();
|
|
117
|
-
</script>
|
|
118
|
-
|
|
119
|
-
<script lang="ts">
|
|
120
|
-
export type { SynShowEvent } from '@synergy-design-system/components';
|
|
121
|
-
export type { SynAfterShowEvent } from '@synergy-design-system/components';
|
|
122
|
-
export type { SynHideEvent } from '@synergy-design-system/components';
|
|
123
|
-
export type { SynAfterHideEvent } from '@synergy-design-system/components';
|
|
124
|
-
</script>
|
|
125
|
-
|
|
126
|
-
<template>
|
|
127
|
-
<syn-details
|
|
128
|
-
@syn-show="$emit('syn-show', $event)"
|
|
129
|
-
@syn-after-show="$emit('syn-after-show', $event)"
|
|
130
|
-
@syn-hide="$emit('syn-hide', $event)"
|
|
131
|
-
@syn-after-hide="$emit('syn-after-hide', $event)"
|
|
132
|
-
v-bind="visibleProps"
|
|
133
|
-
ref="nativeElement">
|
|
134
|
-
<slot></slot>
|
|
135
|
-
</syn-details>
|
|
136
|
-
</template>
|