@marioschmidt/design-system-components 1.2.0 → 1.2.2

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.
Files changed (195) hide show
  1. package/dist/bds/bds.css +1 -1
  2. package/dist/bds/bds.esm.js +1 -1
  3. package/dist/bds/p-5fc1f965.entry.js +2 -0
  4. package/dist/bds/p-5fc1f965.entry.js.map +1 -0
  5. package/dist/bds/p-DjQpvXJW.js +3 -0
  6. package/dist/bds/p-DjQpvXJW.js.map +1 -0
  7. package/dist/cjs/bds.cjs.js +1 -1
  8. package/dist/cjs/ds-button_2.cjs.entry.js +11 -7
  9. package/dist/cjs/{index-B0IsCEmC.js → index-Bg-5nAHg.js} +3 -3
  10. package/dist/cjs/index-Bg-5nAHg.js.map +1 -0
  11. package/dist/cjs/loader.cjs.js +1 -1
  12. package/dist/collection/ds-button/ds-button.css +175 -29
  13. package/dist/collection/ds-button/ds-button.js +27 -13
  14. package/dist/collection/ds-button/ds-button.js.map +1 -1
  15. package/dist/components/ds-button.js +10 -6
  16. package/dist/components/ds-button.js.map +1 -1
  17. package/dist/components/index.js +1 -1
  18. package/dist/components/index.js.map +1 -1
  19. package/dist/docs/ds-button/readme.md +4 -4
  20. package/dist/esm/bds.js +2 -2
  21. package/dist/esm/ds-button_2.entry.js +11 -7
  22. package/dist/esm/{index-Wtf1fKUK.js → index-DjQpvXJW.js} +3 -3
  23. package/dist/esm/index-DjQpvXJW.js.map +1 -0
  24. package/dist/esm/loader.js +2 -2
  25. package/dist/types/components.d.ts +10 -8
  26. package/dist/types/ds-button/ds-button.d.ts +13 -3
  27. package/dist/www/build/bds.css +1 -1
  28. package/dist/www/build/bds.esm.js +1 -1
  29. package/dist/www/build/p-5fc1f965.entry.js +2 -0
  30. package/dist/www/build/p-5fc1f965.entry.js.map +1 -0
  31. package/dist/www/build/p-71b331cc.css +1 -0
  32. package/dist/www/build/p-DjQpvXJW.js +3 -0
  33. package/dist/www/build/p-DjQpvXJW.js.map +1 -0
  34. package/dist/www/css/advertorial/components/_dsysdocs.css +1 -1
  35. package/dist/www/css/advertorial/components/article.css +32 -1
  36. package/dist/www/css/advertorial/components/audioplayer.css +1 -1
  37. package/dist/www/css/advertorial/components/avatar.css +35 -1
  38. package/dist/www/css/advertorial/components/badge.css +9 -1
  39. package/dist/www/css/advertorial/components/breadcrumb.css +19 -1
  40. package/dist/www/css/advertorial/components/breakingnews.css +17 -1
  41. package/dist/www/css/advertorial/components/button.css +9 -1
  42. package/dist/www/css/advertorial/components/card.css +1 -1
  43. package/dist/www/css/advertorial/components/carousel.css +1 -1
  44. package/dist/www/css/advertorial/components/chip.css +1 -1
  45. package/dist/www/css/advertorial/components/datepicker.css +1 -1
  46. package/dist/www/css/advertorial/components/drawers.css +1 -1
  47. package/dist/www/css/advertorial/components/dropdown.css +1 -1
  48. package/dist/www/css/advertorial/components/footer.css +1 -1
  49. package/dist/www/css/advertorial/components/icon.css +1 -1
  50. package/dist/www/css/advertorial/components/iconbutton.css +1 -1
  51. package/dist/www/css/advertorial/components/infoelement.css +1 -1
  52. package/dist/www/css/advertorial/components/inputfield.css +1 -1
  53. package/dist/www/css/advertorial/components/liveticker.css +9 -1
  54. package/dist/www/css/advertorial/components/mediaplayer.css +17 -1
  55. package/dist/www/css/advertorial/components/menu.css +28 -1
  56. package/dist/www/css/advertorial/components/newsticker.css +17 -1
  57. package/dist/www/css/advertorial/components/pagination.css +1 -1
  58. package/dist/www/css/advertorial/components/paywall.css +10 -1
  59. package/dist/www/css/advertorial/components/quote.css +1 -1
  60. package/dist/www/css/advertorial/components/radiobutton.css +1 -1
  61. package/dist/www/css/advertorial/components/search.css +1 -1
  62. package/dist/www/css/advertorial/components/sectiontitle.css +1 -1
  63. package/dist/www/css/advertorial/components/separator.css +1 -1
  64. package/dist/www/css/advertorial/components/skeletons.css +1 -1
  65. package/dist/www/css/advertorial/components/slider.css +1 -1
  66. package/dist/www/css/advertorial/components/specialnavi.css +1 -1
  67. package/dist/www/css/advertorial/components/spinner.css +1 -1
  68. package/dist/www/css/advertorial/components/tab.css +17 -1
  69. package/dist/www/css/advertorial/components/table.css +1 -1
  70. package/dist/www/css/advertorial/components/teaser.css +41 -1
  71. package/dist/www/css/advertorial/components/toggleswitch.css +1 -1
  72. package/dist/www/css/advertorial/components/video.css +1 -1
  73. package/dist/www/css/advertorial/theme.css +1 -1
  74. package/dist/www/css/advertorial/tokens.css +275 -1
  75. package/dist/www/css/bild/components/_dsysdoc.css +1 -1
  76. package/dist/www/css/bild/components/_dsysdocs.css +1 -1
  77. package/dist/www/css/bild/components/alert.css +1 -1
  78. package/dist/www/css/bild/components/article.css +32 -1
  79. package/dist/www/css/bild/components/audioplayer.css +1 -1
  80. package/dist/www/css/bild/components/avatar.css +35 -1
  81. package/dist/www/css/bild/components/badge.css +9 -1
  82. package/dist/www/css/bild/components/breadcrumb.css +19 -1
  83. package/dist/www/css/bild/components/breakingnews.css +17 -1
  84. package/dist/www/css/bild/components/button.css +9 -1
  85. package/dist/www/css/bild/components/card.css +1 -1
  86. package/dist/www/css/bild/components/carousel.css +1 -1
  87. package/dist/www/css/bild/components/chip.css +1 -1
  88. package/dist/www/css/bild/components/datepicker.css +1 -1
  89. package/dist/www/css/bild/components/drawers.css +1 -1
  90. package/dist/www/css/bild/components/dropdown.css +1 -1
  91. package/dist/www/css/bild/components/empties.css +1 -1
  92. package/dist/www/css/bild/components/footer.css +1 -1
  93. package/dist/www/css/bild/components/gallery.css +1 -1
  94. package/dist/www/css/bild/components/icon.css +1 -1
  95. package/dist/www/css/bild/components/iconbutton.css +1 -1
  96. package/dist/www/css/bild/components/infoelement.css +1 -1
  97. package/dist/www/css/bild/components/inputfield.css +1 -1
  98. package/dist/www/css/bild/components/kicker.css +1 -1
  99. package/dist/www/css/bild/components/liveticker.css +9 -1
  100. package/dist/www/css/bild/components/mediaplayer.css +17 -1
  101. package/dist/www/css/bild/components/menu.css +28 -1
  102. package/dist/www/css/bild/components/menuitem.css +1 -1
  103. package/dist/www/css/bild/components/newsticker.css +17 -1
  104. package/dist/www/css/bild/components/pagination.css +1 -1
  105. package/dist/www/css/bild/components/partnerlinks.css +1 -1
  106. package/dist/www/css/bild/components/paywall.css +10 -1
  107. package/dist/www/css/bild/components/quote.css +1 -1
  108. package/dist/www/css/bild/components/radiobutton.css +1 -1
  109. package/dist/www/css/bild/components/search.css +1 -1
  110. package/dist/www/css/bild/components/sectiontitle.css +1 -1
  111. package/dist/www/css/bild/components/selection.css +1 -1
  112. package/dist/www/css/bild/components/separator.css +1 -1
  113. package/dist/www/css/bild/components/skeletons.css +1 -1
  114. package/dist/www/css/bild/components/slider.css +1 -1
  115. package/dist/www/css/bild/components/specialnavi.css +1 -1
  116. package/dist/www/css/bild/components/spinner.css +1 -1
  117. package/dist/www/css/bild/components/subheader.css +1 -1
  118. package/dist/www/css/bild/components/tab.css +17 -1
  119. package/dist/www/css/bild/components/table.css +1 -1
  120. package/dist/www/css/bild/components/teaser.css +41 -1
  121. package/dist/www/css/bild/components/toggleswitch.css +1 -1
  122. package/dist/www/css/bild/components/video.css +1 -1
  123. package/dist/www/css/bild/theme.css +1 -1
  124. package/dist/www/css/bild/tokens.css +275 -1
  125. package/dist/www/css/bundles/advertorial.css +522 -1
  126. package/dist/www/css/bundles/bild.css +522 -1
  127. package/dist/www/css/bundles/sportbild.css +544 -1
  128. package/dist/www/css/shared/colorprimitive.css +1 -1
  129. package/dist/www/css/shared/fontprimitive.css +1 -1
  130. package/dist/www/css/shared/primitives.css +1 -1
  131. package/dist/www/css/shared/sizeprimitive.css +1 -1
  132. package/dist/www/css/shared/spaceprimitive.css +1 -1
  133. package/dist/www/css/sportbild/components/_dsysdoc.css +1 -1
  134. package/dist/www/css/sportbild/components/_dsysdocs.css +1 -1
  135. package/dist/www/css/sportbild/components/alert.css +1 -1
  136. package/dist/www/css/sportbild/components/article.css +33 -1
  137. package/dist/www/css/sportbild/components/audioplayer.css +1 -1
  138. package/dist/www/css/sportbild/components/avatar.css +35 -1
  139. package/dist/www/css/sportbild/components/badge.css +9 -1
  140. package/dist/www/css/sportbild/components/breadcrumb.css +19 -1
  141. package/dist/www/css/sportbild/components/breakingnews.css +17 -1
  142. package/dist/www/css/sportbild/components/button.css +9 -1
  143. package/dist/www/css/sportbild/components/card.css +1 -1
  144. package/dist/www/css/sportbild/components/carousel.css +1 -1
  145. package/dist/www/css/sportbild/components/chip.css +1 -1
  146. package/dist/www/css/sportbild/components/datepicker.css +1 -1
  147. package/dist/www/css/sportbild/components/drawers.css +1 -1
  148. package/dist/www/css/sportbild/components/dropdown.css +1 -1
  149. package/dist/www/css/sportbild/components/empties.css +1 -1
  150. package/dist/www/css/sportbild/components/footer.css +1 -1
  151. package/dist/www/css/sportbild/components/gallery.css +1 -1
  152. package/dist/www/css/sportbild/components/icon.css +1 -1
  153. package/dist/www/css/sportbild/components/iconbutton.css +1 -1
  154. package/dist/www/css/sportbild/components/infoelement.css +1 -1
  155. package/dist/www/css/sportbild/components/inputfield.css +1 -1
  156. package/dist/www/css/sportbild/components/kicker.css +1 -1
  157. package/dist/www/css/sportbild/components/liveticker.css +9 -1
  158. package/dist/www/css/sportbild/components/mediaplayer.css +17 -1
  159. package/dist/www/css/sportbild/components/menu.css +30 -1
  160. package/dist/www/css/sportbild/components/menuitem.css +1 -1
  161. package/dist/www/css/sportbild/components/newsticker.css +18 -1
  162. package/dist/www/css/sportbild/components/pagination.css +1 -1
  163. package/dist/www/css/sportbild/components/partnerlinks.css +1 -1
  164. package/dist/www/css/sportbild/components/paywall.css +10 -1
  165. package/dist/www/css/sportbild/components/quote.css +1 -1
  166. package/dist/www/css/sportbild/components/radiobutton.css +1 -1
  167. package/dist/www/css/sportbild/components/search.css +1 -1
  168. package/dist/www/css/sportbild/components/sectiontitle.css +1 -1
  169. package/dist/www/css/sportbild/components/selection.css +1 -1
  170. package/dist/www/css/sportbild/components/separator.css +1 -1
  171. package/dist/www/css/sportbild/components/skeletons.css +1 -1
  172. package/dist/www/css/sportbild/components/slider.css +1 -1
  173. package/dist/www/css/sportbild/components/specialnavi.css +1 -1
  174. package/dist/www/css/sportbild/components/spinner.css +1 -1
  175. package/dist/www/css/sportbild/components/subheader.css +1 -1
  176. package/dist/www/css/sportbild/components/tab.css +17 -1
  177. package/dist/www/css/sportbild/components/table.css +1 -1
  178. package/dist/www/css/sportbild/components/teaser.css +46 -1
  179. package/dist/www/css/sportbild/components/toggleswitch.css +1 -1
  180. package/dist/www/css/sportbild/components/video.css +1 -1
  181. package/dist/www/css/sportbild/theme.css +1 -1
  182. package/dist/www/css/sportbild/tokens.css +288 -1
  183. package/dist/www/index.html +1 -1
  184. package/package.json +1 -1
  185. package/dist/bds/p-67bc59c5.entry.js +0 -2
  186. package/dist/bds/p-67bc59c5.entry.js.map +0 -1
  187. package/dist/bds/p-Wtf1fKUK.js +0 -3
  188. package/dist/bds/p-Wtf1fKUK.js.map +0 -1
  189. package/dist/cjs/index-B0IsCEmC.js.map +0 -1
  190. package/dist/esm/index-Wtf1fKUK.js.map +0 -1
  191. package/dist/www/build/p-444f99b6.css +0 -1
  192. package/dist/www/build/p-67bc59c5.entry.js +0 -2
  193. package/dist/www/build/p-67bc59c5.entry.js.map +0 -1
  194. package/dist/www/build/p-Wtf1fKUK.js +0 -3
  195. package/dist/www/build/p-Wtf1fKUK.js.map +0 -1
@@ -1,6 +1,6 @@
1
1
  'use strict';
2
2
 
3
- var index = require('./index-B0IsCEmC.js');
3
+ var index = require('./index-Bg-5nAHg.js');
4
4
 
5
5
  const defineCustomElements = async (win, options) => {
6
6
  if (typeof window === 'undefined') return undefined;
@@ -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
- transition: background-color 0.2s ease, border-color 0.2s ease;
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
- /* Token-based styling */
14
- padding: var(--button-stack-space, 6px) var(--button-inline-space, 16px);
15
- border-radius: var(--button-border-radius, 4px);
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, 700);
18
- font-size: var(--button-label-font-size, 15px);
19
- line-height: var(--button-label-line-height, 15px);
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
- /* Primary Variant */
23
- .ds-button--primary {
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:hover:not(:disabled) {
29
- background-color: var(--button-primary-brand-bg-color-hover, #B80000);
102
+ .ds-button--primary-success:active:not(:disabled) {
103
+ background-color: var(--button-primary-success-bg-color-active);
30
104
  }
31
105
 
32
- /* Secondary Variant */
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, #E9ECEF);
35
- color: var(--button-secondary-label-color, #4B525A);
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, #CED4DA);
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
- /* Tertiary Variant */
43
- .ds-button--tertiary {
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, #4B525A);
46
- border: 1px solid var(--button-tertiary-border-color-idle, #CED4DA);
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
- border-color: var(--button-tertiary-border-color-hover, #4B525A);
155
+ .ds-button--tertiary-success:hover:not(:disabled) {
156
+ background-color: var(--button-tertiary-success-bg-color-hover);
51
157
  }
52
158
 
53
- /* Disabled State */
54
- .ds-button--disabled {
55
- opacity: 0.5;
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
- .ds-button__label {
60
- text-transform: uppercase;
61
- letter-spacing: 0.02em;
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: primary, secondary, or tertiary
5
+ * Button variant determining visual style.
6
+ * @default 'primary-brand'
6
7
  */
7
- this.variant = 'primary';
8
+ this.variant = 'primary-brand';
8
9
  /**
9
- * Disabled state
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: '9cdec7f2d8913050c2f934f9b006113a73e52fe9', class: {
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: '0939f9a53d3c9c0d76f19edec687f1c869ebb9d9', class: "ds-button__label" }, h("slot", { key: 'adf41ca5922e4fab4dbb176a21134c9cb52937c1' }))));
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": "'primary' | 'secondary' | 'tertiary'",
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
- "text": "Button variant: primary, secondary, or tertiary"
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
- "text": "Disabled state"
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;AAOnD,MAAM,OAAO,QAAQ;IALrB;QAME;;WAEG;QACK,YAAO,GAAyC,SAAS,CAAC;QAElE;;WAEG;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@Component({\n tag: 'ds-button',\n styleUrl: 'ds-button.css',\n shadow: true,\n})\nexport class DsButton {\n /**\n * Button variant: primary, secondary, or tertiary\n */\n @Prop() variant: 'primary' | 'secondary' | 'tertiary' = 'primary';\n\n /**\n * Disabled state\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
+ {"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, border-color 0.2s ease;padding:var(--button-stack-space, 6px) var(--button-inline-space, 16px);border-radius:var(--button-border-radius, 4px);font-family:var(--button-label-font-family);font-weight:var(--font-weight-bold, 700);font-size:var(--button-label-font-size, 15px);line-height:var(--button-label-line-height, 15px)}.ds-button--primary{background-color:var(--button-primary-brand-bg-color-idle, #DD0000);color:var(--button-primary-label-color, #FFFFFF)}.ds-button--primary:hover:not(:disabled){background-color:var(--button-primary-brand-bg-color-hover, #B80000)}.ds-button--secondary{background-color:var(--button-secondary-bg-color-idle, #E9ECEF);color:var(--button-secondary-label-color, #4B525A)}.ds-button--secondary:hover:not(:disabled){background-color:var(--button-secondary-bg-color-hover, #CED4DA)}.ds-button--tertiary{background-color:transparent;color:var(--button-tertiary-label-color, #4B525A);border:1px solid var(--button-tertiary-border-color-idle, #CED4DA)}.ds-button--tertiary:hover:not(:disabled){border-color:var(--button-tertiary-border-color-hover, #4B525A)}.ds-button--disabled{opacity:0.5;cursor:not-allowed}.ds-button__label{text-transform:uppercase;letter-spacing:0.02em}`;
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: primary, secondary, or tertiary
15
+ * Button variant determining visual style.
16
+ * @default 'primary-brand'
14
17
  */
15
- this.variant = 'primary';
18
+ this.variant = 'primary-brand';
16
19
  /**
17
- * Disabled state
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: '9cdec7f2d8913050c2f934f9b006113a73e52fe9', class: {
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: '0939f9a53d3c9c0d76f19edec687f1c869ebb9d9', class: "ds-button__label" }, h("slot", { key: 'adf41ca5922e4fab4dbb176a21134c9cb52937c1' }))));
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,21CAA21C,CAAC;;MCO12CA,UAAQ,iBAAAC,kBAAA,CAAA,MAAA,QAAA,SAAAC,CAAA,CAAA;AALrB,IAAA,WAAA,CAAA,YAAA,EAAA;;;;;;AAME;;AAEG;AACK,QAAA,IAAO,CAAA,OAAA,GAAyC,SAAS;AAEjE;;AAEG;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":[":host {\n display: inline-block;\n}\n\n.ds-button {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n border: none;\n transition: background-color 0.2s ease, border-color 0.2s ease;\n\n /* Token-based styling */\n padding: var(--button-stack-space, 6px) var(--button-inline-space, 16px);\n border-radius: var(--button-border-radius, 4px);\n font-family: var(--button-label-font-family);\n font-weight: var(--font-weight-bold, 700);\n font-size: var(--button-label-font-size, 15px);\n line-height: var(--button-label-line-height, 15px);\n}\n\n/* Primary Variant */\n.ds-button--primary {\n background-color: var(--button-primary-brand-bg-color-idle, #DD0000);\n color: var(--button-primary-label-color, #FFFFFF);\n}\n\n.ds-button--primary:hover:not(:disabled) {\n background-color: var(--button-primary-brand-bg-color-hover, #B80000);\n}\n\n/* Secondary Variant */\n.ds-button--secondary {\n background-color: var(--button-secondary-bg-color-idle, #E9ECEF);\n color: var(--button-secondary-label-color, #4B525A);\n}\n\n.ds-button--secondary:hover:not(:disabled) {\n background-color: var(--button-secondary-bg-color-hover, #CED4DA);\n}\n\n/* Tertiary Variant */\n.ds-button--tertiary {\n background-color: transparent;\n color: var(--button-tertiary-label-color, #4B525A);\n border: 1px solid var(--button-tertiary-border-color-idle, #CED4DA);\n}\n\n.ds-button--tertiary:hover:not(:disabled) {\n border-color: var(--button-tertiary-border-color-hover, #4B525A);\n}\n\n/* Disabled State */\n.ds-button--disabled {\n opacity: 0.5;\n cursor: not-allowed;\n}\n\n.ds-button__label {\n text-transform: uppercase;\n letter-spacing: 0.02em;\n}\n","import { Component, Prop, h } from '@stencil/core';\n\n@Component({\n tag: 'ds-button',\n styleUrl: 'ds-button.css',\n shadow: true,\n})\nexport class DsButton {\n /**\n * Button variant: primary, secondary, or tertiary\n */\n @Prop() variant: 'primary' | 'secondary' | 'tertiary' = 'primary';\n\n /**\n * Disabled state\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}
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}