@marioschmidt/design-system-components 1.1.0 → 1.2.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/dist/bds/bds.css +1 -1
- package/dist/bds/bds.esm.js +1 -1
- package/dist/bds/p-5fc1f965.entry.js +2 -0
- package/dist/bds/p-5fc1f965.entry.js.map +1 -0
- package/dist/bds/p-DjQpvXJW.js +3 -0
- package/dist/bds/p-DjQpvXJW.js.map +1 -0
- package/dist/cjs/bds.cjs.js +1 -1
- package/dist/cjs/ds-button_2.cjs.entry.js +11 -7
- package/dist/cjs/index-Bg-5nAHg.js +1398 -0
- package/dist/cjs/index-Bg-5nAHg.js.map +1 -0
- package/dist/cjs/loader.cjs.js +1 -1
- package/dist/collection/ds-button/ds-button.css +175 -29
- package/dist/collection/ds-button/ds-button.js +27 -13
- package/dist/collection/ds-button/ds-button.js.map +1 -1
- package/dist/components/ds-button.js +10 -6
- package/dist/components/ds-button.js.map +1 -1
- package/dist/components/index.js +1 -1
- package/dist/components/index.js.map +1 -1
- package/dist/docs/ds-button/readme.md +4 -4
- package/dist/esm/bds.js +2 -2
- package/dist/esm/ds-button_2.entry.js +11 -7
- package/dist/esm/index-DjQpvXJW.js +1391 -0
- package/dist/esm/index-DjQpvXJW.js.map +1 -0
- package/dist/esm/loader.js +2 -2
- package/dist/types/components.d.ts +10 -8
- package/dist/types/ds-button/ds-button.d.ts +13 -3
- package/dist/www/build/bds.css +1 -1
- package/dist/www/build/bds.esm.js +1 -1
- package/dist/www/build/p-5fc1f965.entry.js +2 -0
- package/dist/www/build/p-5fc1f965.entry.js.map +1 -0
- package/dist/www/build/p-71b331cc.css +1 -0
- package/dist/www/build/p-DjQpvXJW.js +3 -0
- package/dist/www/build/p-DjQpvXJW.js.map +1 -0
- package/dist/www/css/advertorial/components/_dsysdocs.css +1 -1
- package/dist/www/css/advertorial/components/article.css +32 -1
- package/dist/www/css/advertorial/components/audioplayer.css +1 -1
- package/dist/www/css/advertorial/components/avatar.css +35 -1
- package/dist/www/css/advertorial/components/badge.css +10 -2
- package/dist/www/css/advertorial/components/breadcrumb.css +19 -1
- package/dist/www/css/advertorial/components/breakingnews.css +17 -1
- package/dist/www/css/advertorial/components/button.css +9 -1
- package/dist/www/css/advertorial/components/card.css +1 -1
- package/dist/www/css/advertorial/components/carousel.css +1 -1
- package/dist/www/css/advertorial/components/chip.css +1 -1
- package/dist/www/css/advertorial/components/datepicker.css +1 -1
- package/dist/www/css/advertorial/components/drawers.css +1 -1
- package/dist/www/css/advertorial/components/dropdown.css +1 -1
- package/dist/www/css/advertorial/components/footer.css +1 -1
- package/dist/www/css/advertorial/components/icon.css +1 -1
- package/dist/www/css/advertorial/components/iconbutton.css +1 -1
- package/dist/www/css/advertorial/components/infoelement.css +1 -1
- package/dist/www/css/advertorial/components/inputfield.css +1 -1
- package/dist/www/css/advertorial/components/liveticker.css +9 -1
- package/dist/www/css/advertorial/components/mediaplayer.css +17 -1
- package/dist/www/css/advertorial/components/menu.css +28 -1
- package/dist/www/css/advertorial/components/newsticker.css +17 -1
- package/dist/www/css/advertorial/components/pagination.css +1 -1
- package/dist/www/css/advertorial/components/paywall.css +10 -1
- package/dist/www/css/advertorial/components/quote.css +1 -1
- package/dist/www/css/advertorial/components/radiobutton.css +1 -1
- package/dist/www/css/advertorial/components/search.css +1 -1
- package/dist/www/css/advertorial/components/sectiontitle.css +1 -1
- package/dist/www/css/advertorial/components/separator.css +1 -1
- package/dist/www/css/advertorial/components/skeletons.css +1 -1
- package/dist/www/css/advertorial/components/slider.css +1 -1
- package/dist/www/css/advertorial/components/specialnavi.css +1 -1
- package/dist/www/css/advertorial/components/spinner.css +1 -1
- package/dist/www/css/advertorial/components/tab.css +17 -1
- package/dist/www/css/advertorial/components/table.css +1 -1
- package/dist/www/css/advertorial/components/teaser.css +41 -1
- package/dist/www/css/advertorial/components/toggleswitch.css +1 -1
- package/dist/www/css/advertorial/components/video.css +1 -1
- package/dist/www/css/advertorial/theme.css +1 -1
- package/dist/www/css/advertorial/tokens.css +305 -31
- package/dist/www/css/bild/components/_dsysdoc.css +1 -1
- package/dist/www/css/bild/components/_dsysdocs.css +1 -1
- package/dist/www/css/bild/components/alert.css +1 -1
- package/dist/www/css/bild/components/article.css +32 -1
- package/dist/www/css/bild/components/audioplayer.css +1 -1
- package/dist/www/css/bild/components/avatar.css +35 -1
- package/dist/www/css/bild/components/badge.css +10 -2
- package/dist/www/css/bild/components/breadcrumb.css +19 -1
- package/dist/www/css/bild/components/breakingnews.css +17 -1
- package/dist/www/css/bild/components/button.css +10 -2
- package/dist/www/css/bild/components/card.css +1 -1
- package/dist/www/css/bild/components/carousel.css +1 -1
- package/dist/www/css/bild/components/chip.css +1 -1
- package/dist/www/css/bild/components/datepicker.css +1 -1
- package/dist/www/css/bild/components/drawers.css +1 -1
- package/dist/www/css/bild/components/dropdown.css +1 -1
- package/dist/www/css/bild/components/empties.css +1 -1
- package/dist/www/css/bild/components/footer.css +1 -1
- package/dist/www/css/bild/components/gallery.css +1 -1
- package/dist/www/css/bild/components/icon.css +1 -1
- package/dist/www/css/bild/components/iconbutton.css +1 -1
- package/dist/www/css/bild/components/infoelement.css +1 -1
- package/dist/www/css/bild/components/inputfield.css +2 -2
- package/dist/www/css/bild/components/kicker.css +1 -1
- package/dist/www/css/bild/components/liveticker.css +9 -1
- package/dist/www/css/bild/components/mediaplayer.css +17 -1
- package/dist/www/css/bild/components/menu.css +28 -1
- package/dist/www/css/bild/components/menuitem.css +1 -1
- package/dist/www/css/bild/components/newsticker.css +17 -1
- package/dist/www/css/bild/components/pagination.css +1 -1
- package/dist/www/css/bild/components/partnerlinks.css +1 -1
- package/dist/www/css/bild/components/paywall.css +10 -1
- package/dist/www/css/bild/components/quote.css +1 -1
- package/dist/www/css/bild/components/radiobutton.css +1 -1
- package/dist/www/css/bild/components/search.css +1 -1
- package/dist/www/css/bild/components/sectiontitle.css +1 -1
- package/dist/www/css/bild/components/selection.css +1 -1
- package/dist/www/css/bild/components/separator.css +1 -1
- package/dist/www/css/bild/components/skeletons.css +1 -1
- package/dist/www/css/bild/components/slider.css +1 -1
- package/dist/www/css/bild/components/specialnavi.css +1 -1
- package/dist/www/css/bild/components/spinner.css +1 -1
- package/dist/www/css/bild/components/subheader.css +1 -1
- package/dist/www/css/bild/components/tab.css +17 -1
- package/dist/www/css/bild/components/table.css +1 -1
- package/dist/www/css/bild/components/teaser.css +41 -1
- package/dist/www/css/bild/components/toggleswitch.css +1 -1
- package/dist/www/css/bild/components/video.css +1 -1
- package/dist/www/css/bild/theme.css +3 -5
- package/dist/www/css/bild/tokens.css +305 -31
- package/dist/www/css/bundles/advertorial.css +553 -42
- package/dist/www/css/bundles/bild.css +557 -48
- package/dist/www/css/bundles/sportbild.css +579 -48
- package/dist/www/css/shared/colorprimitive.css +1 -1
- package/dist/www/css/shared/fontprimitive.css +1 -1
- package/dist/www/css/shared/primitives.css +1 -1
- package/dist/www/css/shared/sizeprimitive.css +1 -1
- package/dist/www/css/shared/spaceprimitive.css +1 -1
- package/dist/www/css/sportbild/components/_dsysdoc.css +1 -1
- package/dist/www/css/sportbild/components/_dsysdocs.css +1 -1
- package/dist/www/css/sportbild/components/alert.css +1 -1
- package/dist/www/css/sportbild/components/article.css +33 -1
- package/dist/www/css/sportbild/components/audioplayer.css +1 -1
- package/dist/www/css/sportbild/components/avatar.css +35 -1
- package/dist/www/css/sportbild/components/badge.css +10 -2
- package/dist/www/css/sportbild/components/breadcrumb.css +19 -1
- package/dist/www/css/sportbild/components/breakingnews.css +17 -1
- package/dist/www/css/sportbild/components/button.css +10 -2
- package/dist/www/css/sportbild/components/card.css +1 -1
- package/dist/www/css/sportbild/components/carousel.css +1 -1
- package/dist/www/css/sportbild/components/chip.css +1 -1
- package/dist/www/css/sportbild/components/datepicker.css +1 -1
- package/dist/www/css/sportbild/components/drawers.css +1 -1
- package/dist/www/css/sportbild/components/dropdown.css +1 -1
- package/dist/www/css/sportbild/components/empties.css +1 -1
- package/dist/www/css/sportbild/components/footer.css +1 -1
- package/dist/www/css/sportbild/components/gallery.css +1 -1
- package/dist/www/css/sportbild/components/icon.css +1 -1
- package/dist/www/css/sportbild/components/iconbutton.css +1 -1
- package/dist/www/css/sportbild/components/infoelement.css +1 -1
- package/dist/www/css/sportbild/components/inputfield.css +2 -2
- package/dist/www/css/sportbild/components/kicker.css +1 -1
- package/dist/www/css/sportbild/components/liveticker.css +9 -1
- package/dist/www/css/sportbild/components/mediaplayer.css +17 -1
- package/dist/www/css/sportbild/components/menu.css +30 -1
- package/dist/www/css/sportbild/components/menuitem.css +1 -1
- package/dist/www/css/sportbild/components/newsticker.css +18 -1
- package/dist/www/css/sportbild/components/pagination.css +1 -1
- package/dist/www/css/sportbild/components/partnerlinks.css +1 -1
- package/dist/www/css/sportbild/components/paywall.css +10 -1
- package/dist/www/css/sportbild/components/quote.css +1 -1
- package/dist/www/css/sportbild/components/radiobutton.css +1 -1
- package/dist/www/css/sportbild/components/search.css +1 -1
- package/dist/www/css/sportbild/components/sectiontitle.css +1 -1
- package/dist/www/css/sportbild/components/selection.css +1 -1
- package/dist/www/css/sportbild/components/separator.css +1 -1
- package/dist/www/css/sportbild/components/skeletons.css +1 -1
- package/dist/www/css/sportbild/components/slider.css +1 -1
- package/dist/www/css/sportbild/components/specialnavi.css +1 -1
- package/dist/www/css/sportbild/components/spinner.css +1 -1
- package/dist/www/css/sportbild/components/subheader.css +1 -1
- package/dist/www/css/sportbild/components/tab.css +17 -1
- package/dist/www/css/sportbild/components/table.css +1 -1
- package/dist/www/css/sportbild/components/teaser.css +46 -1
- package/dist/www/css/sportbild/components/toggleswitch.css +1 -1
- package/dist/www/css/sportbild/components/video.css +1 -1
- package/dist/www/css/sportbild/theme.css +3 -5
- package/dist/www/css/sportbild/tokens.css +318 -31
- package/dist/www/index.html +1 -1
- package/package.json +1 -1
- package/dist/bds/p-84bc6959.entry.js +0 -2
- package/dist/bds/p-84bc6959.entry.js.map +0 -1
- package/dist/bds/p-ChFDVObC.js +0 -3
- package/dist/bds/p-ChFDVObC.js.map +0 -1
- package/dist/cjs/index-D8A-8VrK.js +0 -1398
- package/dist/cjs/index-D8A-8VrK.js.map +0 -1
- package/dist/esm/index-ChFDVObC.js +0 -1391
- package/dist/esm/index-ChFDVObC.js.map +0 -1
- package/dist/www/build/p-84bc6959.entry.js +0 -2
- package/dist/www/build/p-84bc6959.entry.js.map +0 -1
- package/dist/www/build/p-ChFDVObC.js +0 -3
- package/dist/www/build/p-ChFDVObC.js.map +0 -1
- package/dist/www/build/p-bbf896ac.css +0 -1
- package/dist/www/css/advertorial/components/accordion.css +0 -23
- package/dist/www/css/bild/components/accordion.css +0 -23
- package/dist/www/css/sportbild/components/accordion.css +0 -23
package/dist/cjs/loader.cjs.js
CHANGED
|
@@ -1,62 +1,208 @@
|
|
|
1
|
+
/* =============================================================================
|
|
2
|
+
DS-BUTTON Component Styles
|
|
3
|
+
|
|
4
|
+
Token-based styling for all button variants and states.
|
|
5
|
+
All values reference design system tokens for consistency across brands,
|
|
6
|
+
themes, and density modes.
|
|
7
|
+
============================================================================= */
|
|
8
|
+
|
|
1
9
|
:host {
|
|
2
10
|
display: inline-block;
|
|
3
11
|
}
|
|
4
12
|
|
|
13
|
+
/* =============================================================================
|
|
14
|
+
BASE STYLES
|
|
15
|
+
============================================================================= */
|
|
16
|
+
|
|
5
17
|
.ds-button {
|
|
6
18
|
display: inline-flex;
|
|
7
19
|
align-items: center;
|
|
8
20
|
justify-content: center;
|
|
9
21
|
cursor: pointer;
|
|
10
22
|
border: none;
|
|
11
|
-
|
|
23
|
+
background: transparent;
|
|
24
|
+
transition:
|
|
25
|
+
background-color 0.2s ease,
|
|
26
|
+
border-color 0.2s ease,
|
|
27
|
+
color 0.2s ease;
|
|
28
|
+
|
|
29
|
+
/* Spacing (reference density tokens automatically) */
|
|
30
|
+
padding: var(--button-stack-space) var(--button-inline-space);
|
|
31
|
+
min-height: var(--button-height-size);
|
|
32
|
+
gap: var(--button-content-gap-space);
|
|
12
33
|
|
|
13
|
-
/*
|
|
14
|
-
|
|
15
|
-
|
|
34
|
+
/* Sizing */
|
|
35
|
+
border-radius: var(--button-border-radius);
|
|
36
|
+
|
|
37
|
+
/* Typography (from composite .button-label token) */
|
|
16
38
|
font-family: var(--button-label-font-family);
|
|
17
|
-
font-weight: var(--font-weight-bold
|
|
18
|
-
font-size: var(--button-label-font-size
|
|
19
|
-
line-height: var(--button-label-line-height
|
|
39
|
+
font-weight: var(--font-weight-bold);
|
|
40
|
+
font-size: var(--button-label-font-size);
|
|
41
|
+
line-height: var(--button-label-line-height);
|
|
42
|
+
letter-spacing: var(--letter-space-0-p-5);
|
|
43
|
+
text-transform: uppercase;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
.ds-button__label {
|
|
47
|
+
display: inline-flex;
|
|
48
|
+
align-items: center;
|
|
49
|
+
gap: inherit;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
/* =============================================================================
|
|
53
|
+
PRIMARY BRAND VARIANT
|
|
54
|
+
Main call-to-action with brand color (BILD red, SportBILD blue)
|
|
55
|
+
============================================================================= */
|
|
56
|
+
|
|
57
|
+
.ds-button--primary-brand {
|
|
58
|
+
background-color: var(--button-primary-brand-bg-color-idle);
|
|
59
|
+
color: var(--button-primary-brand-label-color);
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
.ds-button--primary-brand:hover:not(:disabled) {
|
|
63
|
+
background-color: var(--button-primary-brand-bg-color-hover);
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
.ds-button--primary-brand:active:not(:disabled) {
|
|
67
|
+
background-color: var(--button-primary-brand-bg-color-active);
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
/* =============================================================================
|
|
71
|
+
PRIMARY NEUTRAL VARIANT
|
|
72
|
+
Primary action with neutral/dark background
|
|
73
|
+
============================================================================= */
|
|
74
|
+
|
|
75
|
+
.ds-button--primary-neutral {
|
|
76
|
+
background-color: var(--button-primary-neutral-bg-color-idle);
|
|
77
|
+
color: var(--button-primary-neutral-label-color);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
.ds-button--primary-neutral:hover:not(:disabled) {
|
|
81
|
+
background-color: var(--button-primary-neutral-bg-color-hover);
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
.ds-button--primary-neutral:active:not(:disabled) {
|
|
85
|
+
background-color: var(--button-primary-neutral-bg-color-active);
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
/* =============================================================================
|
|
89
|
+
PRIMARY SUCCESS VARIANT
|
|
90
|
+
Positive/confirmation action with success color
|
|
91
|
+
============================================================================= */
|
|
92
|
+
|
|
93
|
+
.ds-button--primary-success {
|
|
94
|
+
background-color: var(--button-primary-success-bg-color-idle);
|
|
95
|
+
color: var(--button-primary-success-label-color);
|
|
20
96
|
}
|
|
21
97
|
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
background-color: var(--button-primary-brand-bg-color-idle, #DD0000);
|
|
25
|
-
color: var(--button-primary-label-color, #FFFFFF);
|
|
98
|
+
.ds-button--primary-success:hover:not(:disabled) {
|
|
99
|
+
background-color: var(--button-primary-success-bg-color-hover);
|
|
26
100
|
}
|
|
27
101
|
|
|
28
|
-
.ds-button--primary:
|
|
29
|
-
background-color: var(--button-primary-
|
|
102
|
+
.ds-button--primary-success:active:not(:disabled) {
|
|
103
|
+
background-color: var(--button-primary-success-bg-color-active);
|
|
30
104
|
}
|
|
31
105
|
|
|
32
|
-
/*
|
|
106
|
+
/* =============================================================================
|
|
107
|
+
SECONDARY VARIANT
|
|
108
|
+
Secondary action with neutral gray background
|
|
109
|
+
============================================================================= */
|
|
110
|
+
|
|
33
111
|
.ds-button--secondary {
|
|
34
|
-
background-color: var(--button-secondary-bg-color-idle
|
|
35
|
-
color: var(--button-secondary-label-color
|
|
112
|
+
background-color: var(--button-secondary-bg-color-idle);
|
|
113
|
+
color: var(--button-secondary-label-color);
|
|
36
114
|
}
|
|
37
115
|
|
|
38
116
|
.ds-button--secondary:hover:not(:disabled) {
|
|
39
|
-
background-color: var(--button-secondary-bg-color-hover
|
|
117
|
+
background-color: var(--button-secondary-bg-color-hover);
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
.ds-button--secondary:active:not(:disabled) {
|
|
121
|
+
background-color: var(--button-secondary-bg-color-active);
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
/* =============================================================================
|
|
125
|
+
TERTIARY NEUTRAL VARIANT
|
|
126
|
+
Low-emphasis outlined style with neutral border
|
|
127
|
+
============================================================================= */
|
|
128
|
+
|
|
129
|
+
.ds-button--tertiary-neutral {
|
|
130
|
+
background-color: transparent;
|
|
131
|
+
color: var(--button-tertiary-neutral-label-color);
|
|
132
|
+
border: var(--button-border-width-size) solid var(--button-tertiary-neutral-border-color-idle);
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
.ds-button--tertiary-neutral:hover:not(:disabled) {
|
|
136
|
+
background-color: var(--button-tertiary-neutral-bg-color-hover);
|
|
137
|
+
border-color: var(--button-tertiary-neutral-border-color-hover);
|
|
40
138
|
}
|
|
41
139
|
|
|
42
|
-
|
|
43
|
-
|
|
140
|
+
.ds-button--tertiary-neutral:active:not(:disabled) {
|
|
141
|
+
background-color: var(--button-tertiary-neutral-bg-color-active);
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
/* =============================================================================
|
|
145
|
+
TERTIARY SUCCESS VARIANT
|
|
146
|
+
Low-emphasis outlined style with success color
|
|
147
|
+
============================================================================= */
|
|
148
|
+
|
|
149
|
+
.ds-button--tertiary-success {
|
|
44
150
|
background-color: transparent;
|
|
45
|
-
color: var(--button-tertiary-label-color
|
|
46
|
-
border:
|
|
151
|
+
color: var(--button-tertiary-success-label-color);
|
|
152
|
+
border: var(--button-border-width-size) solid var(--button-tertiary-success-border-color);
|
|
47
153
|
}
|
|
48
154
|
|
|
49
|
-
.ds-button--tertiary:hover:not(:disabled) {
|
|
50
|
-
|
|
155
|
+
.ds-button--tertiary-success:hover:not(:disabled) {
|
|
156
|
+
background-color: var(--button-tertiary-success-bg-color-hover);
|
|
51
157
|
}
|
|
52
158
|
|
|
53
|
-
/*
|
|
54
|
-
|
|
55
|
-
|
|
159
|
+
/* =============================================================================
|
|
160
|
+
GHOST VARIANT
|
|
161
|
+
Text-only button without background or border
|
|
162
|
+
============================================================================= */
|
|
163
|
+
|
|
164
|
+
.ds-button--ghost {
|
|
165
|
+
background-color: transparent;
|
|
166
|
+
color: var(--button-ghost-label-color);
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
.ds-button--ghost:hover:not(:disabled) {
|
|
170
|
+
background-color: var(--button-ghost-bg-color-hover);
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
.ds-button--ghost:active:not(:disabled) {
|
|
174
|
+
background-color: var(--button-ghost-bg-color-active);
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
/* =============================================================================
|
|
178
|
+
DISABLED STATE
|
|
179
|
+
Applies to all variants when disabled
|
|
180
|
+
============================================================================= */
|
|
181
|
+
|
|
182
|
+
.ds-button--disabled,
|
|
183
|
+
.ds-button:disabled {
|
|
56
184
|
cursor: not-allowed;
|
|
185
|
+
background-color: var(--button-disabled-bg-color);
|
|
186
|
+
color: var(--button-disabled-label-color);
|
|
187
|
+
border-color: var(--button-disabled-border-color);
|
|
57
188
|
}
|
|
58
189
|
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
190
|
+
/* Override any variant-specific hover/active for disabled */
|
|
191
|
+
.ds-button--disabled:hover,
|
|
192
|
+
.ds-button--disabled:active,
|
|
193
|
+
.ds-button:disabled:hover,
|
|
194
|
+
.ds-button:disabled:active {
|
|
195
|
+
background-color: var(--button-disabled-bg-color);
|
|
196
|
+
color: var(--button-disabled-label-color);
|
|
197
|
+
border-color: var(--button-disabled-border-color);
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
/* =============================================================================
|
|
201
|
+
FOCUS STATE
|
|
202
|
+
Keyboard navigation accessibility
|
|
203
|
+
============================================================================= */
|
|
204
|
+
|
|
205
|
+
.ds-button:focus-visible {
|
|
206
|
+
outline: 2px solid var(--core-color-primary);
|
|
207
|
+
outline-offset: 2px;
|
|
62
208
|
}
|
|
@@ -2,20 +2,22 @@ import { h } from "@stencil/core";
|
|
|
2
2
|
export class DsButton {
|
|
3
3
|
constructor() {
|
|
4
4
|
/**
|
|
5
|
-
* Button variant
|
|
5
|
+
* Button variant determining visual style.
|
|
6
|
+
* @default 'primary-brand'
|
|
6
7
|
*/
|
|
7
|
-
this.variant = 'primary';
|
|
8
|
+
this.variant = 'primary-brand';
|
|
8
9
|
/**
|
|
9
|
-
*
|
|
10
|
+
* Disables the button interaction and applies disabled styling.
|
|
11
|
+
* @default false
|
|
10
12
|
*/
|
|
11
13
|
this.disabled = false;
|
|
12
14
|
}
|
|
13
15
|
render() {
|
|
14
|
-
return (h("button", { key: '
|
|
16
|
+
return (h("button", { key: 'b2c29af56fa84e6274900496d1a57bf7be6070e0', class: {
|
|
15
17
|
'ds-button': true,
|
|
16
18
|
[`ds-button--${this.variant}`]: true,
|
|
17
19
|
'ds-button--disabled': this.disabled,
|
|
18
|
-
}, disabled: this.disabled }, h("span", { key: '
|
|
20
|
+
}, disabled: this.disabled }, h("span", { key: '8d7cd171306ed6e7b3507fea53e54df4d886d1a0', class: "ds-button__label" }, h("slot", { key: 'c040145f092daf57dd086a9991bcb5d0dc4f97dc' }))));
|
|
19
21
|
}
|
|
20
22
|
static get is() { return "ds-button"; }
|
|
21
23
|
static get encapsulation() { return "shadow"; }
|
|
@@ -35,21 +37,30 @@ export class DsButton {
|
|
|
35
37
|
"type": "string",
|
|
36
38
|
"mutable": false,
|
|
37
39
|
"complexType": {
|
|
38
|
-
"original": "
|
|
39
|
-
"resolved": "\"primary\" | \"secondary\" | \"tertiary\"",
|
|
40
|
-
"references": {
|
|
40
|
+
"original": "ButtonVariant",
|
|
41
|
+
"resolved": "\"ghost\" | \"primary-brand\" | \"primary-neutral\" | \"primary-success\" | \"secondary\" | \"tertiary-neutral\" | \"tertiary-success\"",
|
|
42
|
+
"references": {
|
|
43
|
+
"ButtonVariant": {
|
|
44
|
+
"location": "local",
|
|
45
|
+
"path": "/home/runner/work/vv-token-test-v3/vv-token-test-v3/packages/components/core/src/ds-button/ds-button.tsx",
|
|
46
|
+
"id": "../../packages/components/core/src/ds-button/ds-button.tsx::ButtonVariant"
|
|
47
|
+
}
|
|
48
|
+
}
|
|
41
49
|
},
|
|
42
50
|
"required": false,
|
|
43
51
|
"optional": false,
|
|
44
52
|
"docs": {
|
|
45
|
-
"tags": [
|
|
46
|
-
|
|
53
|
+
"tags": [{
|
|
54
|
+
"name": "default",
|
|
55
|
+
"text": "'primary-brand'"
|
|
56
|
+
}],
|
|
57
|
+
"text": "Button variant determining visual style."
|
|
47
58
|
},
|
|
48
59
|
"getter": false,
|
|
49
60
|
"setter": false,
|
|
50
61
|
"reflect": false,
|
|
51
62
|
"attribute": "variant",
|
|
52
|
-
"defaultValue": "'primary'"
|
|
63
|
+
"defaultValue": "'primary-brand'"
|
|
53
64
|
},
|
|
54
65
|
"disabled": {
|
|
55
66
|
"type": "boolean",
|
|
@@ -62,8 +73,11 @@ export class DsButton {
|
|
|
62
73
|
"required": false,
|
|
63
74
|
"optional": false,
|
|
64
75
|
"docs": {
|
|
65
|
-
"tags": [
|
|
66
|
-
|
|
76
|
+
"tags": [{
|
|
77
|
+
"name": "default",
|
|
78
|
+
"text": "false"
|
|
79
|
+
}],
|
|
80
|
+
"text": "Disables the button interaction and applies disabled styling."
|
|
67
81
|
},
|
|
68
82
|
"getter": false,
|
|
69
83
|
"setter": false,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ds-button.js","sourceRoot":"","sources":["../../../../packages/components/core/src/ds-button/ds-button.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,eAAe,CAAC;
|
|
1
|
+
{"version":3,"file":"ds-button.js","sourceRoot":"","sources":["../../../../packages/components/core/src/ds-button/ds-button.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,EAAE,MAAM,eAAe,CAAC;AAuBnD,MAAM,OAAO,QAAQ;IALrB;QAME;;;WAGG;QACK,YAAO,GAAkB,eAAe,CAAC;QAEjD;;;WAGG;QACK,aAAQ,GAAY,KAAK,CAAC;KAkBnC;IAhBC,MAAM;QACJ,OAAO,CACL,+DACE,KAAK,EAAE;gBACL,WAAW,EAAE,IAAI;gBACjB,CAAC,cAAc,IAAI,CAAC,OAAO,EAAE,CAAC,EAAE,IAAI;gBACpC,qBAAqB,EAAE,IAAI,CAAC,QAAQ;aACrC,EACD,QAAQ,EAAE,IAAI,CAAC,QAAQ;YAEvB,6DAAM,KAAK,EAAC,kBAAkB;gBAC5B,8DAAa,CACR,CACA,CACV,CAAC;IACJ,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACF","sourcesContent":["import { Component, Prop, h } from '@stencil/core';\n\n/**\n * Button variants matching the design system specification.\n * - Primary variants: Filled background (brand, neutral, success)\n * - Secondary: Neutral filled background\n * - Tertiary variants: Outlined style (neutral, success)\n * - Ghost: Text only, no background/border\n */\nexport type ButtonVariant =\n | 'primary-brand'\n | 'primary-neutral'\n | 'primary-success'\n | 'secondary'\n | 'tertiary-neutral'\n | 'tertiary-success'\n | 'ghost';\n\n@Component({\n tag: 'ds-button',\n styleUrl: 'ds-button.css',\n shadow: true,\n})\nexport class DsButton {\n /**\n * Button variant determining visual style.\n * @default 'primary-brand'\n */\n @Prop() variant: ButtonVariant = 'primary-brand';\n\n /**\n * Disables the button interaction and applies disabled styling.\n * @default false\n */\n @Prop() disabled: boolean = false;\n\n render() {\n return (\n <button\n class={{\n 'ds-button': true,\n [`ds-button--${this.variant}`]: true,\n 'ds-button--disabled': this.disabled,\n }}\n disabled={this.disabled}\n >\n <span class=\"ds-button__label\">\n <slot></slot>\n </span>\n </button>\n );\n }\n}\n"]}
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import { t as transformTag, p as proxyCustomElement, H, h } from './index.js';
|
|
2
2
|
|
|
3
|
-
const dsButtonCss = () => `:host{display:inline-block}.ds-button{display:inline-flex;align-items:center;justify-content:center;cursor:pointer;border:none;transition:background-color 0.2s ease,
|
|
3
|
+
const dsButtonCss = () => `:host{display:inline-block}.ds-button{display:inline-flex;align-items:center;justify-content:center;cursor:pointer;border:none;background:transparent;transition:background-color 0.2s ease,
|
|
4
|
+
border-color 0.2s ease,
|
|
5
|
+
color 0.2s ease;padding:var(--button-stack-space) var(--button-inline-space);min-height:var(--button-height-size);gap:var(--button-content-gap-space);border-radius:var(--button-border-radius);font-family:var(--button-label-font-family);font-weight:var(--font-weight-bold);font-size:var(--button-label-font-size);line-height:var(--button-label-line-height);letter-spacing:var(--letter-space-0-p-5);text-transform:uppercase}.ds-button__label{display:inline-flex;align-items:center;gap:inherit}.ds-button--primary-brand{background-color:var(--button-primary-brand-bg-color-idle);color:var(--button-primary-brand-label-color)}.ds-button--primary-brand:hover:not(:disabled){background-color:var(--button-primary-brand-bg-color-hover)}.ds-button--primary-brand:active:not(:disabled){background-color:var(--button-primary-brand-bg-color-active)}.ds-button--primary-neutral{background-color:var(--button-primary-neutral-bg-color-idle);color:var(--button-primary-neutral-label-color)}.ds-button--primary-neutral:hover:not(:disabled){background-color:var(--button-primary-neutral-bg-color-hover)}.ds-button--primary-neutral:active:not(:disabled){background-color:var(--button-primary-neutral-bg-color-active)}.ds-button--primary-success{background-color:var(--button-primary-success-bg-color-idle);color:var(--button-primary-success-label-color)}.ds-button--primary-success:hover:not(:disabled){background-color:var(--button-primary-success-bg-color-hover)}.ds-button--primary-success:active:not(:disabled){background-color:var(--button-primary-success-bg-color-active)}.ds-button--secondary{background-color:var(--button-secondary-bg-color-idle);color:var(--button-secondary-label-color)}.ds-button--secondary:hover:not(:disabled){background-color:var(--button-secondary-bg-color-hover)}.ds-button--secondary:active:not(:disabled){background-color:var(--button-secondary-bg-color-active)}.ds-button--tertiary-neutral{background-color:transparent;color:var(--button-tertiary-neutral-label-color);border:var(--button-border-width-size) solid var(--button-tertiary-neutral-border-color-idle)}.ds-button--tertiary-neutral:hover:not(:disabled){background-color:var(--button-tertiary-neutral-bg-color-hover);border-color:var(--button-tertiary-neutral-border-color-hover)}.ds-button--tertiary-neutral:active:not(:disabled){background-color:var(--button-tertiary-neutral-bg-color-active)}.ds-button--tertiary-success{background-color:transparent;color:var(--button-tertiary-success-label-color);border:var(--button-border-width-size) solid var(--button-tertiary-success-border-color)}.ds-button--tertiary-success:hover:not(:disabled){background-color:var(--button-tertiary-success-bg-color-hover)}.ds-button--ghost{background-color:transparent;color:var(--button-ghost-label-color)}.ds-button--ghost:hover:not(:disabled){background-color:var(--button-ghost-bg-color-hover)}.ds-button--ghost:active:not(:disabled){background-color:var(--button-ghost-bg-color-active)}.ds-button--disabled,.ds-button:disabled{cursor:not-allowed;background-color:var(--button-disabled-bg-color);color:var(--button-disabled-label-color);border-color:var(--button-disabled-border-color)}.ds-button--disabled:hover,.ds-button--disabled:active,.ds-button:disabled:hover,.ds-button:disabled:active{background-color:var(--button-disabled-bg-color);color:var(--button-disabled-label-color);border-color:var(--button-disabled-border-color)}.ds-button:focus-visible{outline:2px solid var(--core-color-primary);outline-offset:2px}`;
|
|
4
6
|
|
|
5
7
|
const DsButton$1 = /*@__PURE__*/ proxyCustomElement(class DsButton extends H {
|
|
6
8
|
constructor(registerHost) {
|
|
@@ -10,20 +12,22 @@ const DsButton$1 = /*@__PURE__*/ proxyCustomElement(class DsButton extends H {
|
|
|
10
12
|
}
|
|
11
13
|
this.__attachShadow();
|
|
12
14
|
/**
|
|
13
|
-
* Button variant
|
|
15
|
+
* Button variant determining visual style.
|
|
16
|
+
* @default 'primary-brand'
|
|
14
17
|
*/
|
|
15
|
-
this.variant = 'primary';
|
|
18
|
+
this.variant = 'primary-brand';
|
|
16
19
|
/**
|
|
17
|
-
*
|
|
20
|
+
* Disables the button interaction and applies disabled styling.
|
|
21
|
+
* @default false
|
|
18
22
|
*/
|
|
19
23
|
this.disabled = false;
|
|
20
24
|
}
|
|
21
25
|
render() {
|
|
22
|
-
return (h("button", { key: '
|
|
26
|
+
return (h("button", { key: 'b2c29af56fa84e6274900496d1a57bf7be6070e0', class: {
|
|
23
27
|
'ds-button': true,
|
|
24
28
|
[`ds-button--${this.variant}`]: true,
|
|
25
29
|
'ds-button--disabled': this.disabled,
|
|
26
|
-
}, disabled: this.disabled }, h("span", { key: '
|
|
30
|
+
}, disabled: this.disabled }, h("span", { key: '8d7cd171306ed6e7b3507fea53e54df4d886d1a0', class: "ds-button__label" }, h("slot", { key: 'c040145f092daf57dd086a9991bcb5d0dc4f97dc' }))));
|
|
27
31
|
}
|
|
28
32
|
static get style() { return dsButtonCss(); }
|
|
29
33
|
}, [257, "ds-button", {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"file":"ds-button.js","mappings":";;AAAA,MAAM,WAAW,GAAG,MAAM,CAAC,
|
|
1
|
+
{"file":"ds-button.js","mappings":";;AAAA,MAAM,WAAW,GAAG,MAAM,CAAC;AAC3B;AACA,+5GAA+5G,CAAC;;MCqBn5GA,UAAQ,iBAAAC,kBAAA,CAAA,MAAA,QAAA,SAAAC,CAAA,CAAA;AALrB,IAAA,WAAA,CAAA,YAAA,EAAA;;;;;;AAME;;;AAGG;AACK,QAAA,IAAO,CAAA,OAAA,GAAkB,eAAe;AAEhD;;;AAGG;AACK,QAAA,IAAQ,CAAA,QAAA,GAAY,KAAK;AAkBlC;IAhBC,MAAM,GAAA;QACJ,QACE,CACE,CAAA,QAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAE;AACL,gBAAA,WAAW,EAAE,IAAI;AACjB,gBAAA,CAAC,cAAc,IAAI,CAAC,OAAO,CAAE,CAAA,GAAG,IAAI;gBACpC,qBAAqB,EAAE,IAAI,CAAC,QAAQ;AACrC,aAAA,EACD,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAA,EAEvB,CAAM,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAC,kBAAkB,EAAA,EAC5B,CAAa,CAAA,MAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,CAAA,CACR,CACA;;;;;;;;;;;;;;;;;;;;;;;;;;;","names":["DsButton","__stencil_proxyCustomElement","HTMLElement"],"sources":["../../packages/components/core/src/ds-button/ds-button.css?tag=ds-button&encapsulation=shadow","../../packages/components/core/src/ds-button/ds-button.tsx"],"sourcesContent":["/* =============================================================================\n DS-BUTTON Component Styles\n\n Token-based styling for all button variants and states.\n All values reference design system tokens for consistency across brands,\n themes, and density modes.\n ============================================================================= */\n\n:host {\n display: inline-block;\n}\n\n/* =============================================================================\n BASE STYLES\n ============================================================================= */\n\n.ds-button {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n border: none;\n background: transparent;\n transition:\n background-color 0.2s ease,\n border-color 0.2s ease,\n color 0.2s ease;\n\n /* Spacing (reference density tokens automatically) */\n padding: var(--button-stack-space) var(--button-inline-space);\n min-height: var(--button-height-size);\n gap: var(--button-content-gap-space);\n\n /* Sizing */\n border-radius: var(--button-border-radius);\n\n /* Typography (from composite .button-label token) */\n font-family: var(--button-label-font-family);\n font-weight: var(--font-weight-bold);\n font-size: var(--button-label-font-size);\n line-height: var(--button-label-line-height);\n letter-spacing: var(--letter-space-0-p-5);\n text-transform: uppercase;\n}\n\n.ds-button__label {\n display: inline-flex;\n align-items: center;\n gap: inherit;\n}\n\n/* =============================================================================\n PRIMARY BRAND VARIANT\n Main call-to-action with brand color (BILD red, SportBILD blue)\n ============================================================================= */\n\n.ds-button--primary-brand {\n background-color: var(--button-primary-brand-bg-color-idle);\n color: var(--button-primary-brand-label-color);\n}\n\n.ds-button--primary-brand:hover:not(:disabled) {\n background-color: var(--button-primary-brand-bg-color-hover);\n}\n\n.ds-button--primary-brand:active:not(:disabled) {\n background-color: var(--button-primary-brand-bg-color-active);\n}\n\n/* =============================================================================\n PRIMARY NEUTRAL VARIANT\n Primary action with neutral/dark background\n ============================================================================= */\n\n.ds-button--primary-neutral {\n background-color: var(--button-primary-neutral-bg-color-idle);\n color: var(--button-primary-neutral-label-color);\n}\n\n.ds-button--primary-neutral:hover:not(:disabled) {\n background-color: var(--button-primary-neutral-bg-color-hover);\n}\n\n.ds-button--primary-neutral:active:not(:disabled) {\n background-color: var(--button-primary-neutral-bg-color-active);\n}\n\n/* =============================================================================\n PRIMARY SUCCESS VARIANT\n Positive/confirmation action with success color\n ============================================================================= */\n\n.ds-button--primary-success {\n background-color: var(--button-primary-success-bg-color-idle);\n color: var(--button-primary-success-label-color);\n}\n\n.ds-button--primary-success:hover:not(:disabled) {\n background-color: var(--button-primary-success-bg-color-hover);\n}\n\n.ds-button--primary-success:active:not(:disabled) {\n background-color: var(--button-primary-success-bg-color-active);\n}\n\n/* =============================================================================\n SECONDARY VARIANT\n Secondary action with neutral gray background\n ============================================================================= */\n\n.ds-button--secondary {\n background-color: var(--button-secondary-bg-color-idle);\n color: var(--button-secondary-label-color);\n}\n\n.ds-button--secondary:hover:not(:disabled) {\n background-color: var(--button-secondary-bg-color-hover);\n}\n\n.ds-button--secondary:active:not(:disabled) {\n background-color: var(--button-secondary-bg-color-active);\n}\n\n/* =============================================================================\n TERTIARY NEUTRAL VARIANT\n Low-emphasis outlined style with neutral border\n ============================================================================= */\n\n.ds-button--tertiary-neutral {\n background-color: transparent;\n color: var(--button-tertiary-neutral-label-color);\n border: var(--button-border-width-size) solid var(--button-tertiary-neutral-border-color-idle);\n}\n\n.ds-button--tertiary-neutral:hover:not(:disabled) {\n background-color: var(--button-tertiary-neutral-bg-color-hover);\n border-color: var(--button-tertiary-neutral-border-color-hover);\n}\n\n.ds-button--tertiary-neutral:active:not(:disabled) {\n background-color: var(--button-tertiary-neutral-bg-color-active);\n}\n\n/* =============================================================================\n TERTIARY SUCCESS VARIANT\n Low-emphasis outlined style with success color\n ============================================================================= */\n\n.ds-button--tertiary-success {\n background-color: transparent;\n color: var(--button-tertiary-success-label-color);\n border: var(--button-border-width-size) solid var(--button-tertiary-success-border-color);\n}\n\n.ds-button--tertiary-success:hover:not(:disabled) {\n background-color: var(--button-tertiary-success-bg-color-hover);\n}\n\n/* =============================================================================\n GHOST VARIANT\n Text-only button without background or border\n ============================================================================= */\n\n.ds-button--ghost {\n background-color: transparent;\n color: var(--button-ghost-label-color);\n}\n\n.ds-button--ghost:hover:not(:disabled) {\n background-color: var(--button-ghost-bg-color-hover);\n}\n\n.ds-button--ghost:active:not(:disabled) {\n background-color: var(--button-ghost-bg-color-active);\n}\n\n/* =============================================================================\n DISABLED STATE\n Applies to all variants when disabled\n ============================================================================= */\n\n.ds-button--disabled,\n.ds-button:disabled {\n cursor: not-allowed;\n background-color: var(--button-disabled-bg-color);\n color: var(--button-disabled-label-color);\n border-color: var(--button-disabled-border-color);\n}\n\n/* Override any variant-specific hover/active for disabled */\n.ds-button--disabled:hover,\n.ds-button--disabled:active,\n.ds-button:disabled:hover,\n.ds-button:disabled:active {\n background-color: var(--button-disabled-bg-color);\n color: var(--button-disabled-label-color);\n border-color: var(--button-disabled-border-color);\n}\n\n/* =============================================================================\n FOCUS STATE\n Keyboard navigation accessibility\n ============================================================================= */\n\n.ds-button:focus-visible {\n outline: 2px solid var(--core-color-primary);\n outline-offset: 2px;\n}\n","import { Component, Prop, h } from '@stencil/core';\n\n/**\n * Button variants matching the design system specification.\n * - Primary variants: Filled background (brand, neutral, success)\n * - Secondary: Neutral filled background\n * - Tertiary variants: Outlined style (neutral, success)\n * - Ghost: Text only, no background/border\n */\nexport type ButtonVariant =\n | 'primary-brand'\n | 'primary-neutral'\n | 'primary-success'\n | 'secondary'\n | 'tertiary-neutral'\n | 'tertiary-success'\n | 'ghost';\n\n@Component({\n tag: 'ds-button',\n styleUrl: 'ds-button.css',\n shadow: true,\n})\nexport class DsButton {\n /**\n * Button variant determining visual style.\n * @default 'primary-brand'\n */\n @Prop() variant: ButtonVariant = 'primary-brand';\n\n /**\n * Disables the button interaction and applies disabled styling.\n * @default false\n */\n @Prop() disabled: boolean = false;\n\n render() {\n return (\n <button\n class={{\n 'ds-button': true,\n [`ds-button--${this.variant}`]: true,\n 'ds-button--disabled': this.disabled,\n }}\n disabled={this.disabled}\n >\n <span class=\"ds-button__label\">\n <slot></slot>\n </span>\n </button>\n );\n }\n}\n"],"version":3}
|