@sbb-esta/lyne-elements-dev 4.9.0-dev.1775022513 → 4.9.0-dev.1775049532

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 (35) hide show
  1. package/core/styles/core.scss +9 -0
  2. package/core.css +22 -0
  3. package/custom-elements.json +561 -561
  4. package/development/step-label.component-D3wrRPQ7.js +265 -0
  5. package/development/step.component-ewujsOVD.js +212 -0
  6. package/development/stepper/step/step.component.js +1 -1
  7. package/development/stepper/step-label/step-label.component.d.ts.map +1 -1
  8. package/development/stepper/step-label/step-label.component.js +1 -1
  9. package/development/stepper/step-label.js +1 -1
  10. package/development/stepper/step.js +1 -1
  11. package/development/stepper/stepper/stepper.component.d.ts.map +1 -1
  12. package/development/stepper/stepper/stepper.component.js +1 -1
  13. package/development/stepper/stepper.js +1 -1
  14. package/development/stepper.component-BJC_4cep.js +497 -0
  15. package/development/stepper.js +3 -3
  16. package/development/stepper.pure.js +3 -3
  17. package/off-brand-theme.css +22 -0
  18. package/package.json +2 -2
  19. package/safety-theme.css +22 -0
  20. package/standard-theme.css +22 -0
  21. package/step-label.component-Cu_Hck4P.js +80 -0
  22. package/{step.component-CbfVfpi6.js → step.component-DY61vAFB.js} +1 -1
  23. package/stepper/step/step.component.js +1 -1
  24. package/stepper/step-label/step-label.component.js +1 -1
  25. package/stepper/step-label.js +1 -1
  26. package/stepper/step.js +1 -1
  27. package/stepper/stepper/stepper.component.js +1 -1
  28. package/stepper/stepper.js +1 -1
  29. package/{stepper.component-CrMknCZm.js → stepper.component-83cngpic.js} +6 -8
  30. package/stepper.js +3 -3
  31. package/stepper.pure.js +3 -3
  32. package/development/step-label.component-C_obpSzp.js +0 -298
  33. package/development/step.component-DsXAckYS.js +0 -220
  34. package/development/stepper.component-yAkgcauE.js +0 -508
  35. package/step-label.component-BYaPBTcl.js +0 -82
@@ -0,0 +1,497 @@
1
+ import { __esDecorate, __runInitializers } from "tslib";
2
+ import { css, html } from "lit";
3
+ import { property } from "lit/decorators.js";
4
+ import { SbbElement } from "./core/base-elements.js";
5
+ import { forceType } from "./core/decorators.js";
6
+ import { isLean } from "./core/dom.js";
7
+ import { boxSizingStyles } from "./core/styles.js";
8
+ import { getNextElementIndex, isArrowKeyPressed } from "./core/a11y.js";
9
+ import { IntersectionController } from "@lit-labs/observers/intersection-controller.js";
10
+ import { SbbMediaMatcherController, SbbMediaQueryBreakpointLargeAndAbove, SbbMediaQueryBreakpointSmallAndAbove, SbbMediaQueryBreakpointUltraAndAbove, SbbMediaQueryBreakpointZeroAndAbove } from "./core/controllers/media-matchers-controller.js";
11
+ //#region src/elements/stepper/stepper/stepper.scss?lit&inline
12
+ var stepper_default = css`:host {
13
+ --sbb-stepper-animation-duration: var(
14
+ --sbb-disable-animation-duration,
15
+ var(--sbb-animation-duration-6x)
16
+ );
17
+ display: block;
18
+ position: relative;
19
+ counter-reset: step-label;
20
+ }
21
+ @media (forced-colors: active) {
22
+ :host {
23
+ --sbb-stepper-marker-color: ButtonText;
24
+ }
25
+ }
26
+
27
+ :host(:is(:state(disable-animation),[state--disable-animation])) {
28
+ --sbb-disable-animation-duration: 0s;
29
+ }
30
+
31
+ :host([orientation=vertical]) {
32
+ --sbb-stepper-orientation: column;
33
+ }
34
+
35
+ .sbb-stepper__labels {
36
+ display: flex;
37
+ flex-direction: var(--sbb-stepper-orientation);
38
+ position: relative;
39
+ justify-content: start;
40
+ margin-block-end: var(--sbb-spacing-responsive-m);
41
+ }
42
+ .sbb-stepper__labels::before {
43
+ content: "";
44
+ position: absolute;
45
+ inset-inline-start: calc(var(--sbb-stepper-border-width) * -1);
46
+ background-color: var(--sbb-stepper-marker-color);
47
+ }
48
+ :host([orientation=horizontal]) .sbb-stepper__labels {
49
+ gap: var(--sbb-spacing-responsive-m);
50
+ padding-block-end: var(--sbb-spacing-fixed-4x);
51
+ border-block-end: var(--sbb-stepper-border-width) solid var(--sbb-border-color-4-inverted);
52
+ }
53
+ :host([orientation=horizontal]) .sbb-stepper__labels::before {
54
+ inset-block-end: calc(var(--sbb-stepper-border-width) * -1);
55
+ height: var(--sbb-stepper-marker-width);
56
+ width: var(--sbb-stepper-marker-size, 0);
57
+ transition: width var(--sbb-stepper-animation-duration) var(--sbb-animation-easing);
58
+ }
59
+ :host([orientation=vertical]) .sbb-stepper__labels {
60
+ padding-inline-start: var(--sbb-spacing-fixed-4x);
61
+ border-inline-start: var(--sbb-stepper-border-width) solid var(--sbb-border-color-4-inverted);
62
+ }
63
+ :host([orientation=vertical]) .sbb-stepper__labels::before {
64
+ inset-block-start: 0;
65
+ width: var(--sbb-stepper-marker-width);
66
+ height: var(--sbb-stepper-marker-size, 0);
67
+ transition: height var(--sbb-stepper-animation-duration) var(--sbb-animation-easing);
68
+ }
69
+
70
+ .sbb-stepper__steps {
71
+ position: relative;
72
+ }
73
+ :host([orientation=horizontal]) .sbb-stepper__steps {
74
+ height: var(--sbb-stepper-content-height);
75
+ transition: height var(--sbb-stepper-animation-duration) var(--sbb-animation-easing);
76
+ }
77
+
78
+ ::slotted(sbb-step-label)::before {
79
+ content: counter(step-label);
80
+ counter-increment: step-label;
81
+ }`;
82
+ //#endregion
83
+ //#region src/elements/stepper/stepper/stepper.component.ts
84
+ var DEBOUNCE_TIME = 150;
85
+ var breakpointMap = {
86
+ zero: SbbMediaQueryBreakpointZeroAndAbove,
87
+ small: SbbMediaQueryBreakpointSmallAndAbove,
88
+ large: SbbMediaQueryBreakpointLargeAndAbove,
89
+ ultra: SbbMediaQueryBreakpointUltraAndAbove
90
+ };
91
+ var SbbStepChangeEvent = class extends Event {
92
+ constructor(selectedIndex, previousIndex, selectedStep, previousStep) {
93
+ super("stepchange", {
94
+ bubbles: true,
95
+ composed: true
96
+ });
97
+ this.selectedIndex = selectedIndex;
98
+ this.previousIndex = previousIndex;
99
+ this.selectedStep = selectedStep;
100
+ this.previousStep = previousStep;
101
+ }
102
+ };
103
+ /**
104
+ * Provides a structured, step-by-step workflow for user interactions.
105
+ * @slot - Provide a `sbb-expansion-panel-header` and a `sbb-expansion-panel-content` to the stepper.
106
+ * @slot step-label - Use this slot to provide an `sbb-step-label`.
107
+ * @slot step - Use this slot to provide an `sbb-step`.
108
+ * @event {SbbStepChangeEvent} stepchange - Emits whenever a step was changed.
109
+ */
110
+ var SbbStepperElement = (() => {
111
+ let _classSuper = SbbElement;
112
+ let _instanceExtraInitializers = [];
113
+ let _linear_decorators;
114
+ let _linear_initializers = [];
115
+ let _linear_extraInitializers = [];
116
+ let _set_horizontalFrom_decorators;
117
+ let _orientation_decorators;
118
+ let _orientation_initializers = [];
119
+ let _orientation_extraInitializers = [];
120
+ let _size_decorators;
121
+ let _size_initializers = [];
122
+ let _size_extraInitializers = [];
123
+ let _set_selected_decorators;
124
+ let _set_selectedIndex_decorators;
125
+ return class SbbStepperElement extends _classSuper {
126
+ static {
127
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
128
+ _linear_decorators = [forceType(), property({ type: Boolean })];
129
+ _set_horizontalFrom_decorators = [property({
130
+ attribute: "horizontal-from",
131
+ reflect: true
132
+ })];
133
+ _orientation_decorators = [property({ reflect: true })];
134
+ _size_decorators = [property({ reflect: true })];
135
+ _set_selected_decorators = [property({ attribute: false })];
136
+ _set_selectedIndex_decorators = [property({
137
+ attribute: "selected-index",
138
+ type: Number
139
+ })];
140
+ __esDecorate(this, null, _linear_decorators, {
141
+ kind: "accessor",
142
+ name: "linear",
143
+ static: false,
144
+ private: false,
145
+ access: {
146
+ has: (obj) => "linear" in obj,
147
+ get: (obj) => obj.linear,
148
+ set: (obj, value) => {
149
+ obj.linear = value;
150
+ }
151
+ },
152
+ metadata: _metadata
153
+ }, _linear_initializers, _linear_extraInitializers);
154
+ __esDecorate(this, null, _set_horizontalFrom_decorators, {
155
+ kind: "setter",
156
+ name: "horizontalFrom",
157
+ static: false,
158
+ private: false,
159
+ access: {
160
+ has: (obj) => "horizontalFrom" in obj,
161
+ set: (obj, value) => {
162
+ obj.horizontalFrom = value;
163
+ }
164
+ },
165
+ metadata: _metadata
166
+ }, null, _instanceExtraInitializers);
167
+ __esDecorate(this, null, _orientation_decorators, {
168
+ kind: "accessor",
169
+ name: "orientation",
170
+ static: false,
171
+ private: false,
172
+ access: {
173
+ has: (obj) => "orientation" in obj,
174
+ get: (obj) => obj.orientation,
175
+ set: (obj, value) => {
176
+ obj.orientation = value;
177
+ }
178
+ },
179
+ metadata: _metadata
180
+ }, _orientation_initializers, _orientation_extraInitializers);
181
+ __esDecorate(this, null, _size_decorators, {
182
+ kind: "accessor",
183
+ name: "size",
184
+ static: false,
185
+ private: false,
186
+ access: {
187
+ has: (obj) => "size" in obj,
188
+ get: (obj) => obj.size,
189
+ set: (obj, value) => {
190
+ obj.size = value;
191
+ }
192
+ },
193
+ metadata: _metadata
194
+ }, _size_initializers, _size_extraInitializers);
195
+ __esDecorate(this, null, _set_selected_decorators, {
196
+ kind: "setter",
197
+ name: "selected",
198
+ static: false,
199
+ private: false,
200
+ access: {
201
+ has: (obj) => "selected" in obj,
202
+ set: (obj, value) => {
203
+ obj.selected = value;
204
+ }
205
+ },
206
+ metadata: _metadata
207
+ }, null, _instanceExtraInitializers);
208
+ __esDecorate(this, null, _set_selectedIndex_decorators, {
209
+ kind: "setter",
210
+ name: "selectedIndex",
211
+ static: false,
212
+ private: false,
213
+ access: {
214
+ has: (obj) => "selectedIndex" in obj,
215
+ set: (obj, value) => {
216
+ obj.selectedIndex = value;
217
+ }
218
+ },
219
+ metadata: _metadata
220
+ }, null, _instanceExtraInitializers);
221
+ if (_metadata) Object.defineProperty(this, Symbol.metadata, {
222
+ enumerable: true,
223
+ configurable: true,
224
+ writable: true,
225
+ value: _metadata
226
+ });
227
+ }
228
+ static {
229
+ this.elementName = "sbb-stepper";
230
+ }
231
+ static {
232
+ this.styles = [boxSizingStyles, stepper_default];
233
+ }
234
+ static {
235
+ this.events = { stepchange: "stepchange" };
236
+ }
237
+ #linear_accessor_storage;
238
+ /** If set to true, only the current and previous labels can be clicked and selected. */
239
+ get linear() {
240
+ return this.#linear_accessor_storage;
241
+ }
242
+ set linear(value) {
243
+ this.#linear_accessor_storage = value;
244
+ }
245
+ /** Overrides the behavior of `orientation` property. */
246
+ set horizontalFrom(value) {
247
+ this._horizontalFrom = value && breakpointMap[value] ? value : null;
248
+ if (this._horizontalFrom && this._loaded) this._checkOrientation();
249
+ }
250
+ get horizontalFrom() {
251
+ return this._horizontalFrom;
252
+ }
253
+ #orientation_accessor_storage;
254
+ /** Steps orientation, either horizontal or vertical. */
255
+ get orientation() {
256
+ return this.#orientation_accessor_storage;
257
+ }
258
+ set orientation(value) {
259
+ this.#orientation_accessor_storage = value;
260
+ }
261
+ #size_accessor_storage;
262
+ /**
263
+ * Size variant, either s or m.
264
+ * @default 'm' / 's' (lean)
265
+ */
266
+ get size() {
267
+ return this.#size_accessor_storage;
268
+ }
269
+ set size(value) {
270
+ this.#size_accessor_storage = value;
271
+ }
272
+ /** The currently selected step. */
273
+ set selected(step) {
274
+ if (this._loaded) this._select(step);
275
+ this._requestedSelected = step;
276
+ }
277
+ get selected() {
278
+ return this.querySelector?.("sbb-step:is(:state(selected),[state--selected])") ?? null;
279
+ }
280
+ /** The currently selected step index. */
281
+ set selectedIndex(index) {
282
+ if (this._loaded && index !== null) this._select(this.steps[index]);
283
+ this._requestedSelectedIndex = index;
284
+ }
285
+ get selectedIndex() {
286
+ return this.selected ? this.steps.indexOf(this.selected) : null;
287
+ }
288
+ /** The steps of the stepper. */
289
+ get steps() {
290
+ const steps = [];
291
+ this.querySelectorAll?.("sbb-step").forEach((step) => {
292
+ customElements.upgrade(step);
293
+ steps.push(step);
294
+ });
295
+ return steps;
296
+ }
297
+ get _enabledSteps() {
298
+ return this.steps.filter((s) => {
299
+ if (s.label) {
300
+ customElements.upgrade(s.label);
301
+ return !s.label.disabled;
302
+ }
303
+ return false;
304
+ });
305
+ }
306
+ constructor() {
307
+ super();
308
+ /**
309
+ * If the sbb-stepper is used in a sbb-dialog, the marker on the selected element will not appear,
310
+ * because the calculations are done when the dialog is closed, so the marker has a width of 0;
311
+ * the same happens for the stepper height.
312
+ * We need to recalculate it when the element becomes visible.
313
+ */
314
+ this._observer = (__runInitializers(this, _instanceExtraInitializers), new IntersectionController(this, {
315
+ target: null,
316
+ callback: (entries) => {
317
+ entries.forEach((e) => {
318
+ if (e.intersectionRatio > 0) {
319
+ this._setStepperHeight(this.selected);
320
+ this._setMarkerSize();
321
+ }
322
+ });
323
+ }
324
+ }));
325
+ this.#linear_accessor_storage = __runInitializers(this, _linear_initializers, false);
326
+ this._horizontalFrom = (__runInitializers(this, _linear_extraInitializers), null);
327
+ this.#orientation_accessor_storage = __runInitializers(this, _orientation_initializers, "horizontal");
328
+ this.#size_accessor_storage = (__runInitializers(this, _orientation_extraInitializers), __runInitializers(this, _size_initializers, isLean() ? "s" : "m"));
329
+ this._requestedSelected = (__runInitializers(this, _size_extraInitializers), null);
330
+ this._requestedSelectedIndex = null;
331
+ this._loaded = false;
332
+ this._resizeObserverTimeout = null;
333
+ this._mediaMatcher = new SbbMediaMatcherController(this, {});
334
+ this._onStepperResize = () => {
335
+ this._checkOrientation();
336
+ this._setStepperHeight(this.selected);
337
+ clearTimeout(this._resizeObserverTimeout);
338
+ this.internals.states.add("disable-animation");
339
+ this._resizeObserverTimeout = setTimeout(() => this.internals.states.delete("disable-animation"), DEBOUNCE_TIME);
340
+ };
341
+ this.addEventListener?.("keydown", (e) => this._handleKeyDown(e));
342
+ this.addEventListener?.("resizechange", (e) => this._onSelectedStepResize(e));
343
+ }
344
+ /** Selects the next step. */
345
+ next() {
346
+ if (this.selectedIndex !== null) this._select(this.steps[this.selectedIndex + 1]);
347
+ }
348
+ /** Selects the previous step. */
349
+ previous() {
350
+ if (this.selectedIndex !== null) this._select(this.steps[this.selectedIndex - 1]);
351
+ }
352
+ /** Resets the form in which the stepper is nested or every form of each step, if any. */
353
+ reset() {
354
+ const closestForm = this.closest("form");
355
+ if (closestForm) closestForm.reset();
356
+ else this.querySelectorAll("form").forEach((form) => form.reset());
357
+ this.selectedIndex = 0;
358
+ if (document.activeElement?.closest("sbb-stepper") === this) this.selected?.label?.focus();
359
+ }
360
+ _isSelectable(step) {
361
+ if (step) {
362
+ customElements.upgrade(step);
363
+ if (step.label) {
364
+ customElements.upgrade(step.label);
365
+ if (!this.linear && step.label.disabled) return false;
366
+ }
367
+ return true;
368
+ } else return false;
369
+ }
370
+ _select(step) {
371
+ if (!this._isSelectable(step) || step === this.selected) return;
372
+ const currentIndex = this.selectedIndex;
373
+ const currentStep = this.selected;
374
+ const validatePayload = {
375
+ currentIndex,
376
+ currentStep,
377
+ nextIndex: this.selectedIndex !== null ? this.selectedIndex + 1 : null,
378
+ nextStep: this.selectedIndex !== null ? this.steps[this.selectedIndex + 1] : null
379
+ };
380
+ if (this.selected && !this.selected.validate(validatePayload)) return;
381
+ this.selected?.deselect();
382
+ step.select();
383
+ /** @internal only to provide double entry in docs. It is a public event! */
384
+ this.dispatchEvent(new SbbStepChangeEvent(this.selectedIndex, currentIndex, this.selected, currentStep));
385
+ this._setMarkerSize();
386
+ this._setStepperHeight(step);
387
+ this._configureLinearMode();
388
+ if (document.activeElement?.closest("sbb-stepper") === this) this.selected?.label?.focus();
389
+ }
390
+ _setMarkerSize() {
391
+ if (!this._loaded || !this.selected || this.selectedIndex === void 0 || !this.selected.label) return;
392
+ const offset = this.orientation === "horizontal" ? this.selected.label.offsetLeft + this.selected.label.offsetWidth : this._calculateLabelOffsetTop();
393
+ this.style.setProperty("--sbb-stepper-marker-size", `${offset}px`);
394
+ }
395
+ /**
396
+ * Sets the stepper height based on the height of the provided step.
397
+ */
398
+ _setStepperHeight(step) {
399
+ if (step && step.shadowRoot) {
400
+ const innerElement = step.shadowRoot.querySelector(".sbb-step");
401
+ if (innerElement) this.style?.setProperty("--sbb-stepper-content-height", `${innerElement.offsetHeight}px`);
402
+ }
403
+ }
404
+ _calculateLabelOffsetTop() {
405
+ if (this.selectedIndex === null) return;
406
+ let offset = 0;
407
+ for (const step of this.steps) {
408
+ if (step === this.selected) break;
409
+ offset = step.label.offsetHeight + offset;
410
+ }
411
+ return offset + this.selected.label.offsetHeight + parseFloat(getComputedStyle(this).getPropertyValue("--sbb-spacing-fixed-6x")) * 16 * this.selectedIndex;
412
+ }
413
+ _onSelectedStepResize(e) {
414
+ this._setStepperHeight(e.target);
415
+ }
416
+ _configure() {
417
+ this.steps.forEach((step, i, array) => {
418
+ step.configure(this._loaded);
419
+ step.label?.configure(i + 1, array.length, this._loaded);
420
+ });
421
+ this._select(this.selected || this._enabledSteps[0]);
422
+ }
423
+ _updateLabels() {
424
+ this.steps.forEach((step) => {
425
+ step.slot = this.orientation === "horizontal" ? "step" : "step-label";
426
+ });
427
+ }
428
+ _checkOrientation() {
429
+ if (this.horizontalFrom) {
430
+ this.orientation = this._mediaMatcher.matches(breakpointMap[this.horizontalFrom]) ? "horizontal" : "vertical";
431
+ this._updateLabels();
432
+ }
433
+ setTimeout(() => this._setMarkerSize(), 0);
434
+ }
435
+ _configureLinearMode() {
436
+ this.steps.forEach((step, index) => {
437
+ if (!step.label) return;
438
+ customElements.upgrade(step.label);
439
+ step.label.disable(this.linear && index > this.selectedIndex || !this.linear && step.label.matches(":is(:state(user-disabled),[state--user-disabled])"));
440
+ });
441
+ }
442
+ connectedCallback() {
443
+ super.connectedCallback();
444
+ window.addEventListener("resize", this._onStepperResize, { passive: true });
445
+ this.toggleState("disable-animation", !this._loaded);
446
+ }
447
+ disconnectedCallback() {
448
+ super.disconnectedCallback();
449
+ window.removeEventListener("resize", this._onStepperResize);
450
+ }
451
+ firstUpdated(changedProperties) {
452
+ super.firstUpdated(changedProperties);
453
+ this.updateComplete.then(() => {
454
+ this._loaded = true;
455
+ this._configure();
456
+ if (this._requestedSelected && this.steps.indexOf(this._requestedSelected) !== -1) this.selectedIndex = this.steps.indexOf(this._requestedSelected);
457
+ else if (this._requestedSelectedIndex) this.selectedIndex = this._requestedSelectedIndex;
458
+ else this.selectedIndex = 0;
459
+ this._observer.observe(this);
460
+ this._checkOrientation();
461
+ setTimeout(() => this.internals.states.delete("disable-animation"), DEBOUNCE_TIME);
462
+ });
463
+ }
464
+ willUpdate(changedProperties) {
465
+ super.willUpdate(changedProperties);
466
+ if (changedProperties.has("orientation") && !this.horizontalFrom) {
467
+ this._updateLabels();
468
+ this._setMarkerSize();
469
+ }
470
+ if (changedProperties.has("linear") && this._loaded) this._configureLinearMode();
471
+ if (changedProperties.has("size")) this._setMarkerSize();
472
+ }
473
+ _handleKeyDown(evt) {
474
+ const enabledSteps = this._enabledSteps;
475
+ if (!enabledSteps || evt.target !== this && evt.target.parentElement !== this) return;
476
+ if (isArrowKeyPressed(evt)) {
477
+ const nextIndex = getNextElementIndex(evt, enabledSteps.indexOf(this.selected), enabledSteps.length);
478
+ this._select(enabledSteps[nextIndex]);
479
+ evt.preventDefault();
480
+ }
481
+ }
482
+ render() {
483
+ return html`
484
+ <div class="sbb-stepper__labels" role="tablist">
485
+ <slot name="step-label" @slotchange=${this._configure}></slot>
486
+ </div>
487
+ <div class="sbb-stepper__steps">
488
+ <slot name="step" @slotchange=${this._configure}></slot>
489
+ </div>
490
+ `;
491
+ }
492
+ };
493
+ })();
494
+ //#endregion
495
+ export { SbbStepperElement as n, SbbStepChangeEvent as t };
496
+
497
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"stepper.component-BJC_4cep.js","names":[],"sources":["../../../src/elements/stepper/stepper/stepper.scss?lit&inline","../../../src/elements/stepper/stepper/stepper.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-stepper-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-6x)\n  );\n\n  display: block;\n  position: relative;\n  counter-reset: step-label;\n\n  @include sbb.if-forced-colors {\n    --sbb-stepper-marker-color: ButtonText;\n  }\n}\n\n:host(:state(disable-animation)) {\n  @include sbb.disable-animation;\n}\n\n:host([orientation='vertical']) {\n  --sbb-stepper-orientation: column;\n}\n\n.sbb-stepper__labels {\n  display: flex;\n  flex-direction: var(--sbb-stepper-orientation);\n  position: relative;\n  justify-content: start;\n  margin-block-end: var(--sbb-spacing-responsive-m);\n\n  &::before {\n    content: '';\n    position: absolute;\n    inset-inline-start: calc(var(--sbb-stepper-border-width) * -1);\n    background-color: var(--sbb-stepper-marker-color);\n  }\n\n  :host([orientation='horizontal']) & {\n    gap: var(--sbb-spacing-responsive-m);\n    padding-block-end: var(--sbb-spacing-fixed-4x);\n    border-block-end: var(--sbb-stepper-border-width) solid var(--sbb-border-color-4-inverted);\n\n    &::before {\n      inset-block-end: calc(var(--sbb-stepper-border-width) * -1);\n      height: var(--sbb-stepper-marker-width);\n      width: var(--sbb-stepper-marker-size, 0);\n      transition: width var(--sbb-stepper-animation-duration) var(--sbb-animation-easing);\n    }\n  }\n\n  :host([orientation='vertical']) & {\n    padding-inline-start: var(--sbb-spacing-fixed-4x);\n    border-inline-start: var(--sbb-stepper-border-width) solid var(--sbb-border-color-4-inverted);\n\n    &::before {\n      inset-block-start: 0;\n      width: var(--sbb-stepper-marker-width);\n      height: var(--sbb-stepper-marker-size, 0);\n      transition: height var(--sbb-stepper-animation-duration) var(--sbb-animation-easing);\n    }\n  }\n}\n\n.sbb-stepper__steps {\n  position: relative;\n\n  :host([orientation='horizontal']) & {\n    height: var(--sbb-stepper-content-height);\n    transition: height var(--sbb-stepper-animation-duration) var(--sbb-animation-easing);\n  }\n}\n\n::slotted(sbb-step-label)::before {\n  content: counter(step-label);\n  counter-increment: step-label;\n}\n","import { IntersectionController } from '@lit-labs/observers/intersection-controller.js';\nimport { type CSSResultGroup, html, type PropertyValues, type TemplateResult } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { getNextElementIndex, isArrowKeyPressed } from '../../core/a11y.ts';\nimport { SbbElement } from '../../core/base-elements.ts';\nimport {\n  SbbMediaMatcherController,\n  SbbMediaQueryBreakpointLargeAndAbove,\n  SbbMediaQueryBreakpointSmallAndAbove,\n  SbbMediaQueryBreakpointUltraAndAbove,\n  SbbMediaQueryBreakpointZeroAndAbove,\n} from '../../core/controllers/media-matchers-controller.ts';\nimport { forceType } from '../../core/decorators.ts';\nimport { isLean } from '../../core/dom.ts';\nimport type { SbbHorizontalFrom, SbbOrientation } from '../../core/interfaces.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbStepElement, SbbStepValidateEventDetails } from '../step/step.component.ts';\n\nimport style from './stepper.scss?lit&inline';\n\nconst DEBOUNCE_TIME = 150;\n\nconst breakpointMap: Record<string, string> = {\n  zero: SbbMediaQueryBreakpointZeroAndAbove,\n  small: SbbMediaQueryBreakpointSmallAndAbove,\n  large: SbbMediaQueryBreakpointLargeAndAbove,\n  ultra: SbbMediaQueryBreakpointUltraAndAbove,\n};\n\nexport class SbbStepChangeEvent extends Event {\n  /** The index of the newly selected step. */\n  public readonly selectedIndex: number | null;\n\n  /** The index of the previously selected step. */\n  public readonly previousIndex: number | null;\n\n  /** The newly selected step element. */\n  public readonly selectedStep: SbbStepElement | null;\n\n  /** The previously selected step element. */\n  public readonly previousStep: SbbStepElement | null;\n\n  public constructor(\n    selectedIndex: number | null,\n    previousIndex: number | null,\n    selectedStep: SbbStepElement | null,\n    previousStep: SbbStepElement | null,\n  ) {\n    super('stepchange', { bubbles: true, composed: true });\n    this.selectedIndex = selectedIndex;\n    this.previousIndex = previousIndex;\n    this.selectedStep = selectedStep;\n    this.previousStep = previousStep;\n  }\n}\n/**\n * Provides a structured, step-by-step workflow for user interactions.\n * @slot - Provide a `sbb-expansion-panel-header` and a `sbb-expansion-panel-content` to the stepper.\n * @slot step-label - Use this slot to provide an `sbb-step-label`.\n * @slot step - Use this slot to provide an `sbb-step`.\n * @event {SbbStepChangeEvent} stepchange - Emits whenever a step was changed.\n */\nexport class SbbStepperElement extends SbbElement {\n  public static override readonly elementName: string = 'sbb-stepper';\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  public static readonly events = {\n    stepchange: 'stepchange',\n  } as const;\n\n  /**\n   * If the sbb-stepper is used in a sbb-dialog, the marker on the selected element will not appear,\n   * because the calculations are done when the dialog is closed, so the marker has a width of 0;\n   * the same happens for the stepper height.\n   * We need to recalculate it when the element becomes visible.\n   */\n  private _observer = new IntersectionController(this, {\n    target: null,\n    callback: (entries) => {\n      entries.forEach((e) => {\n        if (e.intersectionRatio > 0) {\n          this._setStepperHeight(this.selected);\n          this._setMarkerSize();\n        }\n      });\n    },\n  });\n\n  /** If set to true, only the current and previous labels can be clicked and selected. */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor linear: boolean = false;\n\n  /** Overrides the behavior of `orientation` property. */\n  @property({ attribute: 'horizontal-from', reflect: true })\n  public set horizontalFrom(value: SbbHorizontalFrom | null) {\n    this._horizontalFrom = value && breakpointMap[value] ? value : null;\n    if (this._horizontalFrom && this._loaded) {\n      this._checkOrientation();\n    }\n  }\n  public get horizontalFrom(): SbbHorizontalFrom | null {\n    return this._horizontalFrom;\n  }\n  private _horizontalFrom: SbbHorizontalFrom | null = null;\n\n  /** Steps orientation, either horizontal or vertical. */\n  @property({ reflect: true })\n  public accessor orientation: SbbOrientation = 'horizontal';\n\n  /**\n   * Size variant, either s or m.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true }) public accessor size: 's' | 'm' = isLean() ? 's' : 'm';\n\n  /** The currently selected step. */\n  @property({ attribute: false })\n  public set selected(step: SbbStepElement | null) {\n    if (this._loaded) {\n      this._select(step);\n    }\n    this._requestedSelected = step;\n  }\n  public get selected(): SbbStepElement | null {\n    return this.querySelector?.<SbbStepElement>('sbb-step:state(selected)') ?? null;\n  }\n  private _requestedSelected: SbbStepElement | null = null;\n\n  /** The currently selected step index. */\n  @property({ attribute: 'selected-index', type: Number })\n  public set selectedIndex(index: number | null) {\n    if (this._loaded && index !== null) {\n      this._select(this.steps[index]);\n    }\n    this._requestedSelectedIndex = index;\n  }\n  public get selectedIndex(): number | null {\n    return this.selected ? this.steps.indexOf(this.selected) : null;\n  }\n  private _requestedSelectedIndex: number | null = null;\n\n  /** The steps of the stepper. */\n  public get steps(): SbbStepElement[] {\n    const steps: SbbStepElement[] = [];\n    this.querySelectorAll?.('sbb-step').forEach((step) => {\n      customElements.upgrade(step);\n      steps.push(step);\n    });\n    return steps;\n  }\n\n  private get _enabledSteps(): SbbStepElement[] {\n    return this.steps.filter((s) => {\n      if (s.label) {\n        customElements.upgrade(s.label);\n        return !s.label.disabled;\n      }\n      return false;\n    });\n  }\n\n  private _loaded: boolean = false;\n  private _resizeObserverTimeout: ReturnType<typeof setTimeout> | null = null;\n  private _mediaMatcher = new SbbMediaMatcherController(this, {});\n\n  public constructor() {\n    super();\n    this.addEventListener?.('keydown', (e) => this._handleKeyDown(e));\n    this.addEventListener?.('resizechange', (e: Event) => this._onSelectedStepResize(e));\n  }\n\n  /** Selects the next step. */\n  public next(): void {\n    if (this.selectedIndex !== null) {\n      this._select(this.steps[this.selectedIndex + 1]);\n    }\n  }\n\n  /** Selects the previous step. */\n  public previous(): void {\n    if (this.selectedIndex !== null) {\n      this._select(this.steps[this.selectedIndex - 1]);\n    }\n  }\n\n  /** Resets the form in which the stepper is nested or every form of each step, if any. */\n  public reset(): void {\n    const closestForm = this.closest('form');\n    if (closestForm) {\n      closestForm.reset();\n    } else {\n      this.querySelectorAll('form').forEach((form) => form.reset());\n    }\n    this.selectedIndex = 0;\n    // In case the focus is currently inside the stepper, we reset the focus to the first/selected step label.\n    if (document.activeElement?.closest('sbb-stepper') === this) {\n      this.selected?.label?.focus();\n    }\n  }\n\n  private _isSelectable(step: SbbStepElement | null): step is SbbStepElement {\n    if (step) {\n      customElements.upgrade(step);\n      if (step.label) {\n        customElements.upgrade(step.label);\n        if (!this.linear && step.label.disabled) {\n          return false;\n        }\n      }\n      return true;\n    } else {\n      return false;\n    }\n  }\n\n  private _select(step: SbbStepElement | null): void {\n    if (!this._isSelectable(step) || step === this.selected) {\n      return;\n    }\n    const currentIndex = this.selectedIndex;\n    const currentStep = this.selected;\n    const validatePayload: SbbStepValidateEventDetails = {\n      currentIndex,\n      currentStep,\n      nextIndex: this.selectedIndex !== null ? this.selectedIndex + 1 : null,\n      nextStep: this.selectedIndex !== null ? this.steps[this.selectedIndex + 1] : null,\n    };\n\n    if (this.selected && !this.selected.validate(validatePayload)) {\n      return;\n    }\n\n    const current = this.selected;\n    current?.deselect();\n    step.select();\n\n    /** @internal only to provide double entry in docs. It is a public event! */\n    this.dispatchEvent(\n      new SbbStepChangeEvent(this.selectedIndex, currentIndex, this.selected, currentStep),\n    );\n\n    this._setMarkerSize();\n    this._setStepperHeight(step);\n    this._configureLinearMode();\n    // In case the focus is currently inside the stepper, we focus the selected step label.\n    if (document.activeElement?.closest('sbb-stepper') === this) {\n      this.selected?.label?.focus();\n    }\n  }\n\n  private _setMarkerSize(): void {\n    if (\n      !this._loaded ||\n      !this.selected ||\n      this.selectedIndex === undefined ||\n      !this.selected.label\n    ) {\n      return;\n    }\n    const offset =\n      this.orientation === 'horizontal'\n        ? this.selected.label.offsetLeft + this.selected.label.offsetWidth\n        : this._calculateLabelOffsetTop();\n\n    this.style.setProperty('--sbb-stepper-marker-size', `${offset}px`);\n  }\n\n  /**\n   * Sets the stepper height based on the height of the provided step.\n   */\n  private _setStepperHeight(step: SbbStepElement | null): void {\n    if (step && step.shadowRoot) {\n      const innerElement: SbbStepElement | null = step.shadowRoot.querySelector('.sbb-step');\n      if (innerElement) {\n        this.style?.setProperty('--sbb-stepper-content-height', `${innerElement.offsetHeight}px`);\n      }\n    }\n  }\n\n  private _calculateLabelOffsetTop(): number | undefined {\n    if (this.selectedIndex === null) {\n      return;\n    }\n    let offset = 0;\n    for (const step of this.steps) {\n      if (step === this.selected) {\n        break;\n      }\n      offset = step.label!.offsetHeight + offset;\n    }\n    return (\n      offset +\n      this.selected!.label!.offsetHeight! +\n      parseFloat(getComputedStyle(this).getPropertyValue('--sbb-spacing-fixed-6x')) *\n        16 *\n        this.selectedIndex\n    );\n  }\n\n  private _onSelectedStepResize(e: Event): void {\n    this._setStepperHeight(e.target as SbbStepElement);\n  }\n\n  private _configure(): void {\n    this.steps.forEach((step, i, array) => {\n      step.configure(this._loaded);\n      step.label?.configure(i + 1, array.length, this._loaded);\n    });\n    this._select(this.selected || this._enabledSteps[0]);\n  }\n\n  private _updateLabels(): void {\n    this.steps.forEach((step) => {\n      step.slot = this.orientation === 'horizontal' ? 'step' : 'step-label';\n    });\n  }\n\n  private _checkOrientation(): void {\n    if (this.horizontalFrom) {\n      this.orientation = this._mediaMatcher.matches(breakpointMap[this.horizontalFrom])\n        ? 'horizontal'\n        : 'vertical';\n      this._updateLabels();\n    }\n    // The timeout is needed to make sure that the marker takes the correct step-label size.\n    setTimeout(() => this._setMarkerSize(), 0);\n  }\n\n  private _onStepperResize = (): void => {\n    this._checkOrientation();\n    this._setStepperHeight(this.selected);\n    clearTimeout(this._resizeObserverTimeout!);\n    this.internals.states.add('disable-animation');\n\n    // Disable the animation when resizing to avoid strange transition effects.\n    this._resizeObserverTimeout = setTimeout(\n      () => this.internals.states.delete('disable-animation'),\n      DEBOUNCE_TIME,\n    );\n  };\n\n  private _configureLinearMode(): void {\n    this.steps.forEach((step, index) => {\n      if (!step.label) {\n        return;\n      }\n      customElements.upgrade(step.label);\n\n      step.label.disable(\n        (this.linear && index > this.selectedIndex!) ||\n          (!this.linear && step.label.matches(':state(user-disabled)')),\n      );\n    });\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    window.addEventListener('resize', this._onStepperResize, {\n      passive: true,\n    });\n    this.toggleState('disable-animation', !this._loaded);\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    window.removeEventListener('resize', this._onStepperResize);\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n    this.updateComplete.then(() => {\n      this._loaded = true;\n      this._configure();\n\n      if (this._requestedSelected && this.steps.indexOf(this._requestedSelected) !== -1) {\n        this.selectedIndex = this.steps.indexOf(this._requestedSelected);\n      } else if (this._requestedSelectedIndex) {\n        this.selectedIndex = this._requestedSelectedIndex;\n      } else {\n        this.selectedIndex = 0;\n      }\n\n      this._observer.observe(this);\n      this._checkOrientation();\n      // Remove disable-animation state after component init\n      setTimeout(() => this.internals.states.delete('disable-animation'), DEBOUNCE_TIME);\n    });\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n    if (changedProperties.has('orientation') && !this.horizontalFrom) {\n      this._updateLabels();\n      this._setMarkerSize();\n    }\n    if (changedProperties.has('linear') && this._loaded) {\n      this._configureLinearMode();\n    }\n\n    if (changedProperties.has('size')) {\n      this._setMarkerSize();\n    }\n  }\n\n  private _handleKeyDown(evt: KeyboardEvent): void {\n    const enabledSteps: SbbStepElement[] = this._enabledSteps;\n\n    if (\n      !enabledSteps ||\n      // don't trap nested handling\n      ((evt.target as HTMLElement) !== this && (evt.target as HTMLElement).parentElement !== this)\n    ) {\n      return;\n    }\n\n    if (isArrowKeyPressed(evt)) {\n      const current: number = enabledSteps.indexOf(this.selected!);\n      const nextIndex: number = getNextElementIndex(evt, current, enabledSteps.length);\n      this._select(enabledSteps[nextIndex]);\n      evt.preventDefault();\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-stepper__labels\" role=\"tablist\">\n        <slot name=\"step-label\" @slotchange=${this._configure}></slot>\n      </div>\n      <div class=\"sbb-stepper__steps\">\n        <slot name=\"step\" @slotchange=${this._configure}></slot>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-stepper': SbbStepperElement;\n  }\n}\n"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
- import { t as SbbStepLabelElement } from "./step-label.component-C_obpSzp.js";
2
- import { t as SbbStepElement } from "./step.component-DsXAckYS.js";
3
- import { n as SbbStepperElement, t as SbbStepChangeEvent } from "./stepper.component-yAkgcauE.js";
1
+ import { t as SbbStepLabelElement } from "./step-label.component-D3wrRPQ7.js";
2
+ import { t as SbbStepElement } from "./step.component-ewujsOVD.js";
3
+ import { n as SbbStepperElement, t as SbbStepChangeEvent } from "./stepper.component-BJC_4cep.js";
4
4
  import "./stepper.pure.js";
5
5
  //#region src/elements/stepper.ts
6
6
  /** @entrypoint */
@@ -1,4 +1,4 @@
1
- import { t as SbbStepLabelElement } from "./step-label.component-C_obpSzp.js";
2
- import { t as SbbStepElement } from "./step.component-DsXAckYS.js";
3
- import { n as SbbStepperElement, t as SbbStepChangeEvent } from "./stepper.component-yAkgcauE.js";
1
+ import { t as SbbStepLabelElement } from "./step-label.component-D3wrRPQ7.js";
2
+ import { t as SbbStepElement } from "./step.component-ewujsOVD.js";
3
+ import { n as SbbStepperElement, t as SbbStepChangeEvent } from "./stepper.component-BJC_4cep.js";
4
4
  export { SbbStepChangeEvent, SbbStepElement, SbbStepLabelElement, SbbStepperElement };
@@ -1788,6 +1788,26 @@ slot[name=error]::slotted(*) {
1788
1788
  --sbb-status-font-size: var(--sbb-text-font-size-s);
1789
1789
  --sbb-status-title-color: var(--sbb-color-granite);
1790
1790
  --sbb-status-title-color: light-dark(var(--sbb-color-granite), var(--sbb-color-smoke));
1791
+ --sbb-step-label-color: var(--sbb-color-4);
1792
+ --sbb-step-label-font-size: var(--sbb-text-font-size-l);
1793
+ --sbb-step-label-prefix-size: var(--sbb-size-element-xxs);
1794
+ --sbb-step-label-prefix-border-style: solid;
1795
+ --sbb-step-label-prefix-border-color: var(--sbb-border-color-4-inverted);
1796
+ --sbb-step-label-prefix-background-color: var(--sbb-background-color-1);
1797
+ --sbb-step-label-gap: var(--sbb-spacing-fixed-4x);
1798
+ --sbb-step-label-inset-block-start-size-m: calc(
1799
+ var(--sbb-text-font-size-l) * (var(--sbb-typo-line-height-text) / 2) +
1800
+ (var(--sbb-border-width-1x) / 2)
1801
+ );
1802
+ --sbb-step-label-inset-block-start-size-s: calc(
1803
+ var(--sbb-text-font-size-m) * (var(--sbb-typo-line-height-text) / 2) +
1804
+ (var(--sbb-border-width-1x) / 2)
1805
+ );
1806
+ --sbb-step-label-inset-block-start: var(--sbb-step-label-inset-block-start-size-m);
1807
+ --sbb-stepper-orientation: row;
1808
+ --sbb-stepper-border-width: var(--sbb-border-width-1x);
1809
+ --sbb-stepper-marker-width: var(--sbb-border-width-3x);
1810
+ --sbb-stepper-marker-color: var(--sbb-color-3);
1791
1811
  --sbb-tab-group-content-gap-size-s: var(--sbb-spacing-responsive-xs);
1792
1812
  --sbb-tab-group-content-gap-size-l: var(--sbb-spacing-responsive-s);
1793
1813
  --sbb-tab-group-content-gap-size-xl: var(--sbb-spacing-responsive-m);
@@ -1862,6 +1882,8 @@ slot[name=error]::slotted(*) {
1862
1882
  --sbb-signet-icon-color: Canvas !important;
1863
1883
  --sbb-slider-selected-line-color: Highlight;
1864
1884
  --sbb-slider-line-color: CanvasText;
1885
+ --sbb-step-label-color: ButtonText;
1886
+ --sbb-step-label-prefix-border-color: ButtonText;
1865
1887
  }
1866
1888
  }
1867
1889
  :root {
package/package.json CHANGED
@@ -1,12 +1,12 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements-dev",
3
- "version": "4.9.0-dev.1775022513",
3
+ "version": "4.9.0-dev.1775049532",
4
4
  "description": "Lyne Design System",
5
5
  "keywords": [
6
6
  "design system",
7
7
  "web components",
8
8
  "lit",
9
- "https://github.com/sbb-design-systems/lyne-components/commit/fd3ebcfef5d28b757b789bccca709a6820f607f1"
9
+ "https://github.com/sbb-design-systems/lyne-components/commit/94e3bd05120aa6041503bf5f5a2a2328913af5a9"
10
10
  ],
11
11
  "type": "module",
12
12
  "exports": {
package/safety-theme.css CHANGED
@@ -1788,6 +1788,26 @@ slot[name=error]::slotted(*) {
1788
1788
  --sbb-status-font-size: var(--sbb-text-font-size-s);
1789
1789
  --sbb-status-title-color: var(--sbb-color-granite);
1790
1790
  --sbb-status-title-color: light-dark(var(--sbb-color-granite), var(--sbb-color-smoke));
1791
+ --sbb-step-label-color: var(--sbb-color-4);
1792
+ --sbb-step-label-font-size: var(--sbb-text-font-size-l);
1793
+ --sbb-step-label-prefix-size: var(--sbb-size-element-xxs);
1794
+ --sbb-step-label-prefix-border-style: solid;
1795
+ --sbb-step-label-prefix-border-color: var(--sbb-border-color-4-inverted);
1796
+ --sbb-step-label-prefix-background-color: var(--sbb-background-color-1);
1797
+ --sbb-step-label-gap: var(--sbb-spacing-fixed-4x);
1798
+ --sbb-step-label-inset-block-start-size-m: calc(
1799
+ var(--sbb-text-font-size-l) * (var(--sbb-typo-line-height-text) / 2) +
1800
+ (var(--sbb-border-width-1x) / 2)
1801
+ );
1802
+ --sbb-step-label-inset-block-start-size-s: calc(
1803
+ var(--sbb-text-font-size-m) * (var(--sbb-typo-line-height-text) / 2) +
1804
+ (var(--sbb-border-width-1x) / 2)
1805
+ );
1806
+ --sbb-step-label-inset-block-start: var(--sbb-step-label-inset-block-start-size-m);
1807
+ --sbb-stepper-orientation: row;
1808
+ --sbb-stepper-border-width: var(--sbb-border-width-1x);
1809
+ --sbb-stepper-marker-width: var(--sbb-border-width-3x);
1810
+ --sbb-stepper-marker-color: var(--sbb-color-3);
1791
1811
  --sbb-tab-group-content-gap-size-s: var(--sbb-spacing-responsive-xs);
1792
1812
  --sbb-tab-group-content-gap-size-l: var(--sbb-spacing-responsive-s);
1793
1813
  --sbb-tab-group-content-gap-size-xl: var(--sbb-spacing-responsive-m);
@@ -1862,6 +1882,8 @@ slot[name=error]::slotted(*) {
1862
1882
  --sbb-signet-icon-color: Canvas !important;
1863
1883
  --sbb-slider-selected-line-color: Highlight;
1864
1884
  --sbb-slider-line-color: CanvasText;
1885
+ --sbb-step-label-color: ButtonText;
1886
+ --sbb-step-label-prefix-border-color: ButtonText;
1865
1887
  }
1866
1888
  }
1867
1889
  :root {