@sbb-esta/lyne-elements 4.0.5 → 4.2.0

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 (125) hide show
  1. package/breadcrumb/breadcrumb/breadcrumb.component.js +5 -5
  2. package/breadcrumb/breadcrumb-group/breadcrumb-group.component.js +7 -7
  3. package/calendar/calendar.component.js +52 -52
  4. package/card/card/card.component.js +14 -14
  5. package/core/interfaces/overlay-close-details.d.ts +1 -0
  6. package/core/interfaces/overlay-close-details.d.ts.map +1 -1
  7. package/core/styles/core.scss +14 -0
  8. package/core/styles/mixins/buttons.scss +1 -2
  9. package/core/styles/mixins/card.scss +9 -3
  10. package/core/styles/mixins/inputs.scss +1 -1
  11. package/core/styles/mixins/link.scss +0 -1
  12. package/core/styles/normalize.scss +4 -6
  13. package/core.css +170 -4
  14. package/custom-elements.json +1019 -347
  15. package/development/breadcrumb/breadcrumb/breadcrumb.component.js +1 -2
  16. package/development/breadcrumb/breadcrumb-group/breadcrumb-group.component.js +2 -3
  17. package/development/calendar/calendar.component.js +3 -5
  18. package/development/card/card/card.component.js +11 -1
  19. package/development/core/interfaces/overlay-close-details.d.ts +1 -0
  20. package/development/core/interfaces/overlay-close-details.d.ts.map +1 -1
  21. package/development/dialog/dialog/dialog.component.d.ts +4 -0
  22. package/development/dialog/dialog/dialog.component.d.ts.map +1 -1
  23. package/development/dialog/dialog/dialog.component.js +23 -5
  24. package/development/dialog/dialog.js +5 -2
  25. package/development/dialog.js +5 -2
  26. package/development/flip-card/flip-card/flip-card.component.js +2 -3
  27. package/development/link/common/block-link-common.js +1 -1
  28. package/development/link/common/inline-link-common.js +1 -1
  29. package/development/link/common/link-common.js +1 -1
  30. package/development/link/common.js +1 -1
  31. package/development/{link-common-CYr3PeRf.js → link-common-d27fHmQw.js} +1 -2
  32. package/development/link.js +1 -1
  33. package/development/option/option-hint/option-hint.component.js +2 -1
  34. package/development/overlay/overlay-base-element.d.ts +37 -5
  35. package/development/overlay/overlay-base-element.d.ts.map +1 -1
  36. package/development/overlay/overlay-base-element.js +32 -20
  37. package/development/overlay/overlay.component.d.ts +3 -0
  38. package/development/overlay/overlay.component.d.ts.map +1 -1
  39. package/development/overlay/overlay.component.js +19 -4
  40. package/development/overlay.js +3 -1
  41. package/development/paginator/paginator/paginator.component.js +2 -3
  42. package/development/popover/popover.component.d.ts +2 -2
  43. package/development/popover/popover.component.d.ts.map +1 -1
  44. package/development/popover/popover.component.js +5 -5
  45. package/development/stepper/step/step.component.d.ts +4 -0
  46. package/development/stepper/step/step.component.d.ts.map +1 -1
  47. package/development/stepper/step/step.component.js +5 -1
  48. package/development/stepper/stepper/stepper.component.d.ts +15 -0
  49. package/development/stepper/stepper/stepper.component.d.ts.map +1 -1
  50. package/development/stepper/stepper/stepper.component.js +19 -4
  51. package/development/stepper/stepper.js +2 -1
  52. package/development/stepper.js +2 -1
  53. package/development/tabs/common.d.ts +4 -0
  54. package/development/tabs/common.d.ts.map +1 -0
  55. package/development/tabs/common.js +170 -0
  56. package/development/tabs/tab-group/tab-group.component.d.ts.map +1 -1
  57. package/development/tabs/tab-group/tab-group.component.js +11 -18
  58. package/development/tabs/tab-label/tab-label.component.d.ts.map +1 -1
  59. package/development/tabs/tab-label/tab-label.component.js +110 -134
  60. package/development/tabs/tab-nav-bar/tab-nav-bar.component.d.ts +30 -0
  61. package/development/tabs/tab-nav-bar/tab-nav-bar.component.d.ts.map +1 -0
  62. package/development/tabs/tab-nav-bar/tab-nav-bar.component.js +105 -0
  63. package/development/tabs/tab-nav-bar.d.ts +5 -0
  64. package/development/tabs/tab-nav-bar.d.ts.map +1 -0
  65. package/development/tabs/tab-nav-bar.js +5 -0
  66. package/development/tabs.d.ts +1 -0
  67. package/development/tabs.d.ts.map +1 -1
  68. package/development/tabs.js +4 -2
  69. package/development/toast/toast.component.js +2 -2
  70. package/dialog/dialog/dialog.component.d.ts +4 -0
  71. package/dialog/dialog/dialog.component.d.ts.map +1 -1
  72. package/dialog/dialog/dialog.component.js +46 -26
  73. package/dialog/dialog.js +5 -2
  74. package/dialog.js +9 -6
  75. package/flip-card/flip-card/flip-card.component.js +11 -11
  76. package/index.d.ts +2 -0
  77. package/index.js +2 -0
  78. package/link/common/block-link-common.js +1 -1
  79. package/link/common/inline-link-common.js +1 -1
  80. package/link/common/link-common.js +1 -1
  81. package/link/common.js +1 -1
  82. package/{link-common-D9TmX32v.js → link-common-7IiqjmPD.js} +1 -1
  83. package/link.js +1 -1
  84. package/normalize.css +4 -6
  85. package/off-brand-theme.css +174 -10
  86. package/option/option-hint/option-hint.component.js +7 -7
  87. package/overlay/overlay-base-element.d.ts +37 -5
  88. package/overlay/overlay-base-element.d.ts.map +1 -1
  89. package/overlay/overlay-base-element.js +68 -62
  90. package/overlay/overlay.component.d.ts +3 -0
  91. package/overlay/overlay.component.d.ts.map +1 -1
  92. package/overlay/overlay.component.js +49 -32
  93. package/overlay.js +7 -5
  94. package/package.json +11 -1
  95. package/paginator/paginator/paginator.component.js +1 -1
  96. package/popover/popover.component.d.ts +2 -2
  97. package/popover/popover.component.d.ts.map +1 -1
  98. package/popover/popover.component.js +4 -4
  99. package/safety-theme.css +174 -10
  100. package/standard-theme.css +174 -10
  101. package/stepper/step/step.component.d.ts +4 -0
  102. package/stepper/step/step.component.d.ts.map +1 -1
  103. package/stepper/step/step.component.js +4 -0
  104. package/stepper/stepper/stepper.component.d.ts +15 -0
  105. package/stepper/stepper/stepper.component.d.ts.map +1 -1
  106. package/stepper/stepper/stepper.component.js +41 -33
  107. package/stepper/stepper.js +3 -2
  108. package/stepper.js +4 -3
  109. package/tabs/common.d.ts +4 -0
  110. package/tabs/common.d.ts.map +1 -0
  111. package/tabs/common.js +6 -0
  112. package/tabs/tab-group/tab-group.component.d.ts.map +1 -1
  113. package/tabs/tab-group/tab-group.component.js +38 -38
  114. package/tabs/tab-label/tab-label.component.d.ts.map +1 -1
  115. package/tabs/tab-label/tab-label.component.js +34 -35
  116. package/tabs/tab-nav-bar/tab-nav-bar.component.d.ts +30 -0
  117. package/tabs/tab-nav-bar/tab-nav-bar.component.d.ts.map +1 -0
  118. package/tabs/tab-nav-bar/tab-nav-bar.component.js +66 -0
  119. package/tabs/tab-nav-bar.d.ts +5 -0
  120. package/tabs/tab-nav-bar.d.ts.map +1 -0
  121. package/tabs/tab-nav-bar.js +4 -0
  122. package/tabs.d.ts +1 -0
  123. package/tabs.d.ts.map +1 -1
  124. package/tabs.js +5 -3
  125. package/toast/toast.component.js +1 -1
package/core.css CHANGED
@@ -148,6 +148,146 @@
148
148
  flex: var(--sbb-radio-button-group-radio-button-flex);
149
149
  }
150
150
 
151
+ :host {
152
+ --sbb-tab-label-animation-duration: var(
153
+ --sbb-disable-animation-duration,
154
+ var(--sbb-animation-duration-2x)
155
+ );
156
+ --sbb-tab-label-outline-border-radius-internal: calc(
157
+ var(--sbb-tab-label-outline-border-radius) - var(--sbb-focus-outline-offset)
158
+ );
159
+ }
160
+
161
+ :host(:is(:is(:state(size-s),[state--size-s]), [size=s])) {
162
+ --sbb-tab-label-height: var(--sbb-size-element-xs);
163
+ --sbb-tab-label-inline-padding: var(--sbb-spacing-responsive-xxxs);
164
+ --sbb-tab-label-font-size: var(--sbb-text-font-size-s);
165
+ }
166
+
167
+ :host(:is(:is(:state(size-l),[state--size-l]), [size=l])) {
168
+ --sbb-tab-label-height: var(--sbb-size-element-m);
169
+ --sbb-tab-label-inline-padding: var(--sbb-spacing-responsive-xs);
170
+ --sbb-tab-label-font-size: var(--sbb-text-font-size-m);
171
+ }
172
+
173
+ :host(:is(:is(:state(size-xl),[state--size-xl]), [size=xl])) {
174
+ --sbb-tab-label-height: var(--sbb-size-element-m);
175
+ --sbb-tab-label-inline-padding: var(--sbb-spacing-responsive-xs);
176
+ --sbb-tab-label-font-size: var(--sbb-text-font-size-xl);
177
+ }
178
+
179
+ :host(sbb-tab-label),
180
+ :host(sbb-tab-nav-bar) ::slotted(a) {
181
+ pointer-events: var(--sbb-tab-label-pointer-events, unset);
182
+ }
183
+ @media (forced-colors: active) {
184
+ :host(sbb-tab-label),
185
+ :host(sbb-tab-nav-bar) ::slotted(a) {
186
+ --sbb-tab-label-color: ButtonText;
187
+ --sbb-tab-label-amount-color: ButtonText;
188
+ }
189
+ }
190
+
191
+ :host(sbb-tab-nav-bar) ::slotted(a),
192
+ :host(sbb-tab-label) .sbb-tab-label {
193
+ position: relative;
194
+ display: flex;
195
+ align-items: center;
196
+ gap: var(--sbb-tab-label-gap);
197
+ color: var(--sbb-tab-label-color);
198
+ margin: 0;
199
+ padding-inline: var(--sbb-tab-label-inline-padding);
200
+ min-height: var(--sbb-tab-label-height);
201
+ transition: color var(--sbb-tab-label-animation-duration) var(--sbb-tab-label-animation-easing);
202
+ font-size: var(--sbb-tab-label-font-size);
203
+ letter-spacing: var(--sbb-typo-letter-spacing-text);
204
+ font-weight: var(--sbb-tab-label-font-weight);
205
+ text-decoration: var(--sbb-tab-label-text-decoration);
206
+ }
207
+ :host(sbb-tab-nav-bar) ::slotted(a)::after,
208
+ :host(sbb-tab-label) .sbb-tab-label::after {
209
+ position: absolute;
210
+ content: "";
211
+ inset-inline: 0;
212
+ inset-block-end: 0;
213
+ height: var(--sbb-tab-label-marker-thickness);
214
+ background-color: var(--sbb-tab-label-color);
215
+ scale: var(--sbb-tab-label-marker-scale, 0);
216
+ transition-duration: var(--sbb-tab-label-animation-duration);
217
+ transition-timing-function: var(--sbb-tab-label-animation-easing);
218
+ transition-property: scale, background-color;
219
+ }
220
+
221
+ :host(sbb-tab-nav-bar) .sbb-tab-nav-bar > [data-has-divider],
222
+ :host(sbb-tab-label:is(:state(has-divider),[state--has-divider])) {
223
+ position: relative;
224
+ }
225
+ :host(sbb-tab-nav-bar) .sbb-tab-nav-bar > [data-has-divider]::before,
226
+ :host(sbb-tab-label:is(:state(has-divider),[state--has-divider]))::before {
227
+ content: "";
228
+ position: absolute;
229
+ inset-inline-start: 0;
230
+ inset-block-end: 0;
231
+ width: var(--sbb-tab-group-width);
232
+ height: var(--sbb-border-width-1x);
233
+ background-color: var(--sbb-tab-label-line-color);
234
+ }
235
+
236
+ :host(sbb-tab-nav-bar) ::slotted(a.sbb-disabled),
237
+ :host(sbb-tab-label[disabled]) {
238
+ --sbb-tab-label-cursor: unset;
239
+ --sbb-tab-label-pointer-events: none;
240
+ --sbb-tab-label-text-decoration: line-through;
241
+ }
242
+ @media (forced-colors: active) {
243
+ :host(sbb-tab-nav-bar) ::slotted(a.sbb-disabled),
244
+ :host(sbb-tab-label[disabled]) {
245
+ --sbb-tab-label-color: GrayText;
246
+ --sbb-tab-label-amount-color: GrayText;
247
+ }
248
+ }
249
+
250
+ :host(sbb-tab-nav-bar) ::slotted(a.sbb-active:not(.sbb-disabled)),
251
+ :host(sbb-tab-label[active]:not([disabled])) {
252
+ --sbb-tab-label-color: var(--sbb-color-3);
253
+ --sbb-tab-label-cursor: unset;
254
+ --sbb-tab-label-pointer-events: none;
255
+ --sbb-tab-label-marker-scale: 1;
256
+ }
257
+ @media (forced-colors: active) {
258
+ :host(sbb-tab-nav-bar) ::slotted(a.sbb-active:not(.sbb-disabled)),
259
+ :host(sbb-tab-label[active]:not([disabled])) {
260
+ --sbb-tab-label-color: ButtonText;
261
+ --sbb-tab-label-amount-color: ButtonText;
262
+ }
263
+ }
264
+
265
+ @media (any-hover: hover) {
266
+ :host(sbb-tab-nav-bar) ::slotted(a:hover:not(.sbb-disabled)),
267
+ :host(sbb-tab-label:hover:not([disabled])) {
268
+ --sbb-tab-label-marker-scale: 1;
269
+ }
270
+ }
271
+
272
+ :host(sbb-tab-nav-bar) ::slotted(a:active:not(.sbb-disabled)),
273
+ :host(sbb-tab-label:active) {
274
+ --sbb-tab-label-color: var(--sbb-color-3);
275
+ }
276
+ @media (forced-colors: active) {
277
+ :host(sbb-tab-nav-bar) ::slotted(a:active:not(.sbb-disabled)),
278
+ :host(sbb-tab-label:active) {
279
+ --sbb-tab-label-color: ButtonText;
280
+ --sbb-tab-label-amount-color: ButtonText;
281
+ }
282
+ }
283
+
284
+ :host(sbb-tab-nav-bar) ::slotted(a:focus-visible),
285
+ :host(sbb-tab-label:focus-visible) .sbb-tab-label {
286
+ outline-offset: var(--sbb-focus-outline-offset);
287
+ outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);
288
+ border-radius: var(--sbb-tab-label-outline-border-radius-internal);
289
+ }
290
+
151
291
  *,
152
292
  ::before,
153
293
  ::after {
@@ -1106,9 +1246,9 @@
1106
1246
  --sbb-card-border-radius: var(--sbb-border-radius-4x);
1107
1247
  --sbb-card-animation-easing: var(--sbb-animation-easing);
1108
1248
  --sbb-card-border-style: solid;
1109
- --sbb-card-padding-inline: var(--sbb-spacing-responsive-s);
1110
- --sbb-card-padding-block: var(--sbb-spacing-responsive-xxxs);
1111
- --sbb-card-with-badge-padding-block: var(--sbb-spacing-fixed-6x) var(--sbb-spacing-responsive-xxxs);
1249
+ --sbb-card-padding-inline-default: var(--sbb-spacing-responsive-s);
1250
+ --sbb-card-padding-block-default: var(--sbb-spacing-responsive-xxxs);
1251
+ --sbb-card-with-badge-padding-block-default: var(--sbb-spacing-fixed-6x) var(--sbb-spacing-responsive-xxxs);
1112
1252
  }
1113
1253
  :root.sbb-lean {
1114
1254
  --sbb-card-padding-inline: var(--sbb-spacing-responsive-xxs);
@@ -1194,6 +1334,25 @@
1194
1334
  --sbb-selection-panel-input-padding-block-m
1195
1335
  );
1196
1336
  --sbb-selection-expansion-panel-content-padding-inline: var(--sbb-selection-panel-input-padding-inline-m);
1337
+ --sbb-tab-group-content-gap-size-s: var(--sbb-spacing-responsive-xs);
1338
+ --sbb-tab-group-content-gap-size-l: var(--sbb-spacing-responsive-s);
1339
+ --sbb-tab-group-content-gap-size-xl: var(--sbb-spacing-responsive-m);
1340
+ --sbb-tab-group-content-gap-default: var(--sbb-tab-group-content-gap-size-l);
1341
+ --sbb-tab-label-height: var(--sbb-size-element-m);
1342
+ --sbb-tab-label-inline-padding: var(--sbb-spacing-responsive-xs);
1343
+ --sbb-tab-label-color: var(--sbb-color-granite);
1344
+ --sbb-tab-label-color: light-dark(var(--sbb-color-granite), var(--sbb-color-graphite));
1345
+ --sbb-tab-label-marker-thickness: var(--sbb-border-width-3x);
1346
+ --sbb-tab-label-text-decoration: none;
1347
+ --sbb-tab-label-animation-easing: var(--sbb-animation-easing);
1348
+ --sbb-tab-label-font-size: var(--sbb-text-font-size-m);
1349
+ --sbb-tab-label-font-weight: bold;
1350
+ --sbb-tab-label-gap: var(--sbb-spacing-fixed-2x);
1351
+ --sbb-tab-label-outline-border-radius: var(--sbb-border-radius-2x);
1352
+ --sbb-tab-label-amount-color: var(--sbb-color-metal);
1353
+ --sbb-tab-label-amount-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));
1354
+ --sbb-tab-label-line-color: var(--sbb-border-color-4-inverted);
1355
+ --sbb-tab-label-cursor: var(--sbb-cursor-pointer);
1197
1356
  --sbb-visual-checkbox-dimension: var(--sbb-checkbox-dimension-m);
1198
1357
  --sbb-visual-checkbox-selection-color: var(--sbb-color-primary);
1199
1358
  --sbb-visual-checkbox-selection-color-negative: var(--sbb-color-primary85);
@@ -1364,6 +1523,13 @@
1364
1523
  font-display: swap;
1365
1524
  font-weight: 300;
1366
1525
  }
1526
+ sbb-tab-nav-bar .sbb-tab-amount {
1527
+ margin: 0;
1528
+ color: var(--sbb-tab-label-amount-color);
1529
+ font-weight: normal;
1530
+ text-decoration: var(--sbb-tab-label-text-decoration);
1531
+ }
1532
+
1367
1533
  .sbb-dark {
1368
1534
  color-scheme: dark;
1369
1535
  }
@@ -1407,7 +1573,7 @@ html {
1407
1573
  border: none;
1408
1574
  background-color: transparent;
1409
1575
  padding: 0;
1410
- -webkit-appearance: none;
1576
+ appearance: none;
1411
1577
  outline: none !important;
1412
1578
  overflow: var(--sbb-form-field-overflow);
1413
1579
  width: 100%;