@sbb-esta/lyne-elements-dev 4.9.0-dev.1775022187 → 4.9.0-dev.1775028444

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 +616 -616
  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,265 @@
1
+ import { css, html } from "lit";
2
+ import { SbbButtonBaseElement } from "./core/base-elements.js";
3
+ import { SbbDisabledMixin, appendAriaElements, removeAriaElements } from "./core/mixins.js";
4
+ import { boxSizingStyles } from "./core/styles.js";
5
+ import { SbbPropertyWatcherController } from "./core/controllers.js";
6
+ import { SbbIconNameMixin } from "./icon.js";
7
+ //#region src/elements/stepper/step-label/step-label.scss?lit&inline
8
+ var step_label_default = css`:host {
9
+ --sbb-step-label-animation-duration: var(
10
+ --sbb-disable-animation-duration,
11
+ var(--sbb-animation-duration-2x)
12
+ );
13
+ --_sbb-step-label-inset-block-start: var(--sbb-step-label-inset-block-start-size-m);
14
+ --_sbb-step-label-inset-inline-start: calc(var(--sbb-step-label-prefix-size) / 2);
15
+ --_sbb-step-label-transform-y: calc(
16
+ -50% + var(--sbb-step-label-translate-y-content-hover, 0rem)
17
+ );
18
+ --_sbb-step-label-prefix-inset-block-start: calc(
19
+ 1em * (var(--sbb-typo-line-height-text) / 2) + (var(--sbb-border-width-1x) / 2) -
20
+ (var(--sbb-step-label-prefix-size) / 2)
21
+ );
22
+ position: relative;
23
+ display: flex;
24
+ min-width: 0;
25
+ max-width: fit-content;
26
+ gap: var(--sbb-step-label-gap);
27
+ cursor: var(--sbb-step-label-cursor);
28
+ color: var(--sbb-step-label-color);
29
+ font-size: var(--sbb-step-label-font-size);
30
+ letter-spacing: var(--sbb-typo-letter-spacing-text);
31
+ }
32
+ :host::before {
33
+ position: absolute;
34
+ top: 50%;
35
+ left: 50%;
36
+ transform: translate(-50%, -50%);
37
+ font-size: var(--sbb-text-font-size-xxs);
38
+ font-weight: var(--sbb-step-label-font-weight-selected, normal);
39
+ inset-block-start: var(--_sbb-step-label-inset-block-start);
40
+ inset-inline-start: var(--_sbb-step-label-inset-inline-start);
41
+ line-height: 1;
42
+ z-index: 1;
43
+ transform: translate(-50%, var(--_sbb-step-label-transform-y));
44
+ transition: transform var(--sbb-step-label-animation-duration) var(--sbb-animation-easing);
45
+ }
46
+
47
+ :host(:is(:state(selected),[state--selected])) {
48
+ --sbb-step-label-color: var(--sbb-color-3);
49
+ --sbb-step-label-font-weight-selected: bold;
50
+ }
51
+ @media (forced-colors: active) {
52
+ :host(:is(:state(selected),[state--selected])) {
53
+ --sbb-step-label-color: Highlight !important;
54
+ }
55
+ }
56
+
57
+ :host(:is(:state(size-s),[state--size-s])) {
58
+ --sbb-step-label-gap: var(--sbb-spacing-fixed-3x);
59
+ --sbb-step-label-prefix-size: var(--sbb-size-element-xxxs);
60
+ --sbb-step-label-font-size: var(--sbb-text-font-size-m);
61
+ --_sbb-step-label-inset-block-start: var(--sbb-step-label-inset-block-start-size-s);
62
+ }
63
+
64
+ :host(:disabled) {
65
+ --sbb-step-label-color: var(--sbb-color-granite);
66
+ --sbb-step-label-color: light-dark(var(--sbb-color-granite), var(--sbb-color-graphite));
67
+ --sbb-step-label-prefix-border-style: dashed;
68
+ }
69
+ @media (forced-colors: active) {
70
+ :host(:disabled) {
71
+ --sbb-step-label-color: GrayText !important;
72
+ }
73
+ }
74
+
75
+ @media (any-hover: hover) {
76
+ :host(:hover:not(:disabled)) {
77
+ --sbb-step-label-cursor: var(--sbb-cursor-pointer);
78
+ --sbb-step-label-prefix-background-color: var(--sbb-background-color-3);
79
+ --sbb-step-label-translate-y-content-hover: -0.0625rem;
80
+ --sbb-step-label-prefix-size-grow-hover: calc(var(--sbb-border-width-2x) * -1);
81
+ }
82
+ }
83
+
84
+ :host(:focus-visible) {
85
+ outline-offset: var(--sbb-focus-outline-offset);
86
+ outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);
87
+ border-radius: var(--sbb-border-radius-1x);
88
+ }
89
+
90
+ :host(:is(:state(orientation-vertical),[state--orientation-vertical])) {
91
+ transition: margin var(--sbb-stepper-animation-duration) var(--sbb-animation-easing);
92
+ }
93
+
94
+ :host(:is(:state(orientation-vertical),[state--orientation-vertical]):not(:first-of-type)) {
95
+ margin-block-start: var(--sbb-spacing-fixed-6x);
96
+ }
97
+
98
+ :host(:is(:state(selected),[state--selected]):is(:state(orientation-vertical),[state--orientation-vertical])) {
99
+ margin-block-end: var(--sbb-spacing-fixed-8x);
100
+ }
101
+
102
+ .sbb-step-label__prefix {
103
+ position: relative;
104
+ display: flex;
105
+ flex-shrink: 0;
106
+ align-items: center;
107
+ justify-content: center;
108
+ width: var(--sbb-step-label-prefix-size);
109
+ height: var(--sbb-step-label-prefix-size);
110
+ inset-block-start: var(--_sbb-step-label-prefix-inset-block-start);
111
+ }
112
+ .sbb-step-label__prefix::before {
113
+ content: "";
114
+ position: absolute;
115
+ inset: calc(var(--sbb-step-label-prefix-size-grow-hover, 0rem));
116
+ border-radius: var(--sbb-border-radius-infinity);
117
+ border: var(--sbb-border-width-1x) var(--sbb-step-label-prefix-border-style) var(--sbb-step-label-prefix-border-color);
118
+ background-color: var(--sbb-step-label-prefix-background-color);
119
+ transition-duration: var(--sbb-step-label-animation-duration);
120
+ transition-timing-function: var(--sbb-animation-easing);
121
+ transition-property: background-color, inset;
122
+ }
123
+
124
+ .sbb-step-label__text {
125
+ font-weight: bold;
126
+ }
127
+ :host(:is(:state(orientation-horizontal),[state--orientation-horizontal])) .sbb-step-label__text {
128
+ overflow: hidden;
129
+ white-space: nowrap;
130
+ text-overflow: ellipsis;
131
+ }
132
+
133
+ ::slotted(sbb-icon),
134
+ sbb-icon {
135
+ z-index: 1;
136
+ background-color: var(--sbb-step-label-prefix-background-color);
137
+ border-radius: var(--sbb-border-radius-infinity);
138
+ transform: translateY(var(--sbb-step-label-translate-y-content-hover, 0rem));
139
+ transition-duration: var(--sbb-step-label-animation-duration);
140
+ transition-timing-function: var(--sbb-animation-easing);
141
+ transition-property: background-color, transform;
142
+ }`;
143
+ //#endregion
144
+ //#region src/elements/stepper/step-label/step-label.component.ts
145
+ var nextId = 0;
146
+ /**
147
+ * Combined with a `sbb-stepper`, it displays a step's label.
148
+ *
149
+ * @slot - Use the unnamed slot to provide a label.
150
+ * @slot icon - Use this to display an icon in the label bubble.
151
+ */
152
+ var SbbStepLabelElement = class extends SbbIconNameMixin(SbbDisabledMixin(SbbButtonBaseElement)) {
153
+ static {
154
+ this.elementName = "sbb-step-label";
155
+ }
156
+ static {
157
+ this.role = "tab";
158
+ }
159
+ static {
160
+ this.styles = [boxSizingStyles, step_label_default];
161
+ }
162
+ /** The step controlled by the label. */
163
+ get step() {
164
+ return this._step;
165
+ }
166
+ get stepper() {
167
+ return this.closest("sbb-stepper");
168
+ }
169
+ set disabled(value) {
170
+ super.disabled = value;
171
+ this.toggleState("user-disabled", value);
172
+ }
173
+ get disabled() {
174
+ return super.disabled;
175
+ }
176
+ constructor() {
177
+ super();
178
+ this._step = null;
179
+ this.addEventListener?.("click", () => {
180
+ const stepper = this.stepper;
181
+ if (stepper && this.step && this._isNotDeactivatedByLinearMode(this.step)) stepper.selected = this.step;
182
+ });
183
+ this.addController(new SbbPropertyWatcherController(this, () => this.stepper, {
184
+ orientation: (s) => {
185
+ if (this._previousOrientation) this.internals.states.delete(`orientation-${this._previousOrientation}`);
186
+ this._previousOrientation = s.orientation;
187
+ if (this._previousOrientation) this.internals.states.add(`orientation-${this._previousOrientation}`);
188
+ },
189
+ size: (s) => {
190
+ if (this._previousSize) this.internals.states.delete(`size-${this._previousSize}`);
191
+ this._previousSize = s.size;
192
+ if (this._previousSize) this.internals.states.add(`size-${this._previousSize}`);
193
+ }
194
+ }));
195
+ }
196
+ _isNotDeactivatedByLinearMode(step) {
197
+ const stepper = this.stepper;
198
+ if (stepper?.linear && stepper.selectedIndex !== null) {
199
+ const index = stepper.steps.indexOf(step);
200
+ return index < stepper.selectedIndex || index === stepper.selectedIndex + 1;
201
+ }
202
+ return true;
203
+ }
204
+ connectedCallback() {
205
+ super.connectedCallback();
206
+ this.id ||= `sbb-step-label-${nextId++}`;
207
+ this.slot ||= "step-label";
208
+ this.internals.ariaSelected = "false";
209
+ this.tabIndex = -1;
210
+ this._assignStep();
211
+ }
212
+ /**
213
+ * Selects and configures the step label.
214
+ * @internal
215
+ */
216
+ select() {
217
+ this.tabIndex = 0;
218
+ this.internals.ariaSelected = "true";
219
+ this.internals.states.add("selected");
220
+ }
221
+ /**
222
+ * Deselects and configures the step label.
223
+ * @internal
224
+ */
225
+ deselect() {
226
+ this.tabIndex = -1;
227
+ this.internals.ariaSelected = "false";
228
+ this.internals.states.delete("selected");
229
+ }
230
+ /**
231
+ * Configures the step label.
232
+ * @internal
233
+ */
234
+ configure(posInSet, setSize, stepperLoaded) {
235
+ if (stepperLoaded) this._assignStep();
236
+ this.internals.ariaPosInSet = `${posInSet}`;
237
+ this.internals.ariaSetSize = `${setSize}`;
238
+ }
239
+ _assignStep() {
240
+ let nextSibling = this.nextElementSibling;
241
+ while (nextSibling && nextSibling.localName !== "sbb-step") nextSibling = nextSibling.nextElementSibling;
242
+ const value = nextSibling;
243
+ this.internals.ariaControlsElements = removeAriaElements(this.internals.ariaControlsElements, this._step);
244
+ this._step = value instanceof Element ? value : null;
245
+ this.internals.ariaControlsElements = appendAriaElements(this.internals.ariaControlsElements, this._step);
246
+ }
247
+ /**
248
+ * @internal
249
+ * Disables the step label and avoids setting the `disabled` state to preserve the initial
250
+ * disabled state in case of switching between linear and non-linear mode.
251
+ */
252
+ disable(value) {
253
+ super.disabled = value;
254
+ }
255
+ render() {
256
+ return html`
257
+ <span class="sbb-step-label__prefix">${this.renderIconSlot()}</span>
258
+ <span class="sbb-step-label__text"><slot></slot></span>
259
+ `;
260
+ }
261
+ };
262
+ //#endregion
263
+ export { SbbStepLabelElement as t };
264
+
265
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"step-label.component-D3wrRPQ7.js","names":[],"sources":["../../../src/elements/stepper/step-label/step-label.scss?lit&inline","../../../src/elements/stepper/step-label/step-label.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-step-label-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-2x)\n  );\n  --_sbb-step-label-inset-block-start: var(--sbb-step-label-inset-block-start-size-m);\n  --_sbb-step-label-inset-inline-start: calc(var(--sbb-step-label-prefix-size) / 2);\n  --_sbb-step-label-transform-y: calc(\n    -50% + var(--sbb-step-label-translate-y-content-hover, #{sbb.px-to-rem-build(0)})\n  );\n  --_sbb-step-label-prefix-inset-block-start: calc(\n    1em * (var(--sbb-typo-line-height-text) / 2) + (var(--sbb-border-width-1x) / 2) -\n      (var(--sbb-step-label-prefix-size) / 2)\n  );\n\n  position: relative;\n  display: flex;\n  min-width: 0;\n  max-width: fit-content;\n  gap: var(--sbb-step-label-gap);\n  cursor: var(--sbb-step-label-cursor);\n  color: var(--sbb-step-label-color);\n  font-size: var(--sbb-step-label-font-size);\n  letter-spacing: var(--sbb-typo-letter-spacing-text);\n\n  &::before {\n    @include sbb.absolute-center-x-y;\n\n    font-size: var(--sbb-text-font-size-xxs);\n    font-weight: var(--sbb-step-label-font-weight-selected, normal);\n    inset-block-start: var(--_sbb-step-label-inset-block-start);\n    inset-inline-start: var(--_sbb-step-label-inset-inline-start);\n    line-height: 1;\n    z-index: 1;\n    transform: translate(-50%, var(--_sbb-step-label-transform-y));\n    transition: transform var(--sbb-step-label-animation-duration) var(--sbb-animation-easing);\n  }\n}\n\n:host(:state(selected)) {\n  --sbb-step-label-color: var(--sbb-color-3);\n  --sbb-step-label-font-weight-selected: bold;\n\n  @include sbb.if-forced-colors {\n    --sbb-step-label-color: Highlight !important;\n  }\n}\n\n:host(:state(size-s)) {\n  --sbb-step-label-gap: var(--sbb-spacing-fixed-3x);\n  --sbb-step-label-prefix-size: var(--sbb-size-element-xxxs);\n  --sbb-step-label-font-size: var(--sbb-text-font-size-m);\n  --_sbb-step-label-inset-block-start: var(--sbb-step-label-inset-block-start-size-s);\n}\n\n:host(:disabled) {\n  --sbb-step-label-color: light-dark(var(--sbb-color-granite), var(--sbb-color-graphite));\n  --sbb-step-label-prefix-border-style: dashed;\n\n  @include sbb.if-forced-colors {\n    --sbb-step-label-color: GrayText !important;\n  }\n}\n\n:host(:hover:not(:disabled)) {\n  @include sbb.hover-mq($hover: true) {\n    --sbb-step-label-cursor: var(--sbb-cursor-pointer);\n    --sbb-step-label-prefix-background-color: var(--sbb-background-color-3);\n    --sbb-step-label-translate-y-content-hover: #{sbb.px-to-rem-build(-1)};\n    --sbb-step-label-prefix-size-grow-hover: calc(var(--sbb-border-width-2x) * -1);\n  }\n}\n\n:host(:focus-visible) {\n  @include sbb.focus-outline;\n\n  border-radius: var(--sbb-border-radius-1x);\n}\n\n:host(:state(orientation-vertical)) {\n  transition: margin var(--sbb-stepper-animation-duration) var(--sbb-animation-easing);\n}\n\n:host(:state(orientation-vertical):not(:first-of-type)) {\n  margin-block-start: var(--sbb-spacing-fixed-6x);\n}\n\n:host(:state(selected):state(orientation-vertical)) {\n  margin-block-end: var(--sbb-spacing-fixed-8x);\n}\n\n.sbb-step-label__prefix {\n  position: relative;\n  display: flex;\n  flex-shrink: 0;\n  align-items: center;\n  justify-content: center;\n  width: var(--sbb-step-label-prefix-size);\n  height: var(--sbb-step-label-prefix-size);\n  inset-block-start: var(--_sbb-step-label-prefix-inset-block-start);\n\n  &::before {\n    content: '';\n    position: absolute;\n    inset: calc(var(--sbb-step-label-prefix-size-grow-hover, #{sbb.px-to-rem-build(0)}));\n    border-radius: var(--sbb-border-radius-infinity);\n    border: var(--sbb-border-width-1x) var(--sbb-step-label-prefix-border-style)\n      var(--sbb-step-label-prefix-border-color);\n    background-color: var(--sbb-step-label-prefix-background-color);\n    transition: {\n      duration: var(--sbb-step-label-animation-duration);\n      timing-function: var(--sbb-animation-easing);\n      property: background-color, inset;\n    }\n  }\n}\n\n.sbb-step-label__text {\n  font-weight: bold;\n\n  :host(:state(orientation-horizontal)) & {\n    @include sbb.ellipsis;\n  }\n}\n\n::slotted(sbb-icon),\nsbb-icon {\n  z-index: 1;\n  background-color: var(--sbb-step-label-prefix-background-color);\n  border-radius: var(--sbb-border-radius-infinity);\n  transform: translateY(var(--sbb-step-label-translate-y-content-hover, #{sbb.px-to-rem-build(0)}));\n  transition: {\n    duration: var(--sbb-step-label-animation-duration);\n    timing-function: var(--sbb-animation-easing);\n    property: background-color, transform;\n  }\n}\n","import { type CSSResultGroup, html, type TemplateResult } from 'lit';\n\nimport { SbbButtonBaseElement } from '../../core/base-elements.ts';\nimport { SbbPropertyWatcherController } from '../../core/controllers.ts';\nimport { appendAriaElements, removeAriaElements, SbbDisabledMixin } from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport { SbbIconNameMixin } from '../../icon.ts';\nimport type { SbbStepElement } from '../step/step.component.ts';\nimport type { SbbStepperElement } from '../stepper/stepper.component.ts';\n\nimport style from './step-label.scss?lit&inline';\n\nlet nextId = 0;\n\n/**\n * Combined with a `sbb-stepper`, it displays a step's label.\n *\n * @slot - Use the unnamed slot to provide a label.\n * @slot icon - Use this to display an icon in the label bubble.\n */\nexport class SbbStepLabelElement extends SbbIconNameMixin(SbbDisabledMixin(SbbButtonBaseElement)) {\n  public static override readonly elementName: string = 'sbb-step-label';\n  public static override readonly role = 'tab';\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n\n  /** The step controlled by the label. */\n  public get step(): SbbStepElement | null {\n    return this._step;\n  }\n  private _step: SbbStepElement | null = null;\n\n  public get stepper(): SbbStepperElement | null {\n    return this.closest('sbb-stepper');\n  }\n\n  public override set disabled(value: boolean) {\n    super.disabled = value;\n\n    // We additionally keep track of the `disabled` state to preserve the user configured disabled state\n    // of step labels in case of switching between linear and non-linear mode.\n    this.toggleState('user-disabled', value);\n  }\n  public override get disabled(): boolean {\n    return super.disabled;\n  }\n\n  private _previousOrientation?: string;\n  private _previousSize?: string;\n\n  public constructor() {\n    super();\n\n    this.addEventListener?.('click', () => {\n      const stepper = this.stepper;\n      if (stepper && this.step && this._isNotDeactivatedByLinearMode(this.step)) {\n        stepper.selected = this.step;\n      }\n    });\n    this.addController(\n      new SbbPropertyWatcherController(this, () => this.stepper, {\n        orientation: (s) => {\n          if (this._previousOrientation) {\n            this.internals.states.delete(`orientation-${this._previousOrientation}`);\n          }\n          this._previousOrientation = s.orientation;\n          if (this._previousOrientation) {\n            this.internals.states.add(`orientation-${this._previousOrientation}`);\n          }\n        },\n        size: (s) => {\n          if (this._previousSize) {\n            this.internals.states.delete(`size-${this._previousSize}`);\n          }\n          this._previousSize = s.size;\n          if (this._previousSize) {\n            this.internals.states.add(`size-${this._previousSize}`);\n          }\n        },\n      }),\n    );\n  }\n\n  private _isNotDeactivatedByLinearMode(step: SbbStepElement): boolean {\n    const stepper = this.stepper;\n    if (stepper?.linear && stepper.selectedIndex !== null) {\n      const index = stepper.steps.indexOf(step);\n      return index < stepper.selectedIndex || index === stepper.selectedIndex + 1;\n    }\n    return true;\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.id ||= `sbb-step-label-${nextId++}`;\n    this.slot ||= 'step-label';\n    this.internals.ariaSelected = 'false';\n    this.tabIndex = -1;\n    this._assignStep();\n  }\n\n  /**\n   * Selects and configures the step label.\n   * @internal\n   */\n  public select(): void {\n    this.tabIndex = 0;\n    this.internals.ariaSelected = 'true';\n    this.internals.states.add('selected');\n  }\n\n  /**\n   * Deselects and configures the step label.\n   * @internal\n   */\n  public deselect(): void {\n    this.tabIndex = -1;\n    this.internals.ariaSelected = 'false';\n    this.internals.states.delete('selected');\n  }\n\n  /**\n   * Configures the step label.\n   * @internal\n   */\n  public configure(posInSet: number, setSize: number, stepperLoaded: boolean): void {\n    if (stepperLoaded) {\n      this._assignStep();\n    }\n    this.internals.ariaPosInSet = `${posInSet}`;\n    this.internals.ariaSetSize = `${setSize}`;\n  }\n\n  private _assignStep(): void {\n    let nextSibling = this.nextElementSibling;\n    while (nextSibling && nextSibling.localName !== 'sbb-step') {\n      nextSibling = nextSibling.nextElementSibling;\n    }\n\n    const value = nextSibling as SbbStepElement | null;\n    this.internals.ariaControlsElements = removeAriaElements(\n      this.internals.ariaControlsElements,\n      this._step,\n    );\n    this._step = value instanceof Element ? value : null;\n    this.internals.ariaControlsElements = appendAriaElements(\n      this.internals.ariaControlsElements,\n      this._step,\n    );\n  }\n\n  /**\n   * @internal\n   * Disables the step label and avoids setting the `disabled` state to preserve the initial\n   * disabled state in case of switching between linear and non-linear mode.\n   */\n  public disable(value: boolean): void {\n    super.disabled = value;\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <span class=\"sbb-step-label__prefix\">${this.renderIconSlot()}</span>\n      <span class=\"sbb-step-label__text\"><slot></slot></span>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-step-label': SbbStepLabelElement;\n  }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;ACYA,IAAI,SAAS;;;;;;;AAQb,IAAa,sBAAb,cAAyC,iBAAiB,iBAAiB,qBAAqB,CAAC,CAAA;;AAC/D,OAAA,cAAsB;;;AACtB,OAAA,OAAO;;;AAChB,OAAA,SAAyB,CAAC,iBAAiB,mBAAM;;;CAGxE,IAAW,OAAI;AACb,SAAO,KAAK;;CAId,IAAW,UAAO;AAChB,SAAO,KAAK,QAAQ,cAAc;;CAGpC,IAAoB,SAAS,OAAc;AACzC,QAAM,WAAW;AAIjB,OAAK,YAAY,iBAAiB,MAAM;;CAE1C,IAAoB,WAAQ;AAC1B,SAAO,MAAM;;CAMf,cAAA;AACE,SAAO;AArBD,OAAA,QAA+B;AAuBrC,OAAK,mBAAmB,eAAc;GACpC,MAAM,UAAU,KAAK;AACrB,OAAI,WAAW,KAAK,QAAQ,KAAK,8BAA8B,KAAK,KAAK,CACvE,SAAQ,WAAW,KAAK;IAE1B;AACF,OAAK,cACH,IAAI,6BAA6B,YAAY,KAAK,SAAS;GACzD,cAAc,MAAK;AACjB,QAAI,KAAK,qBACP,MAAK,UAAU,OAAO,OAAO,eAAe,KAAK,uBAAuB;AAE1E,SAAK,uBAAuB,EAAE;AAC9B,QAAI,KAAK,qBACP,MAAK,UAAU,OAAO,IAAI,eAAe,KAAK,uBAAuB;;GAGzE,OAAO,MAAK;AACV,QAAI,KAAK,cACP,MAAK,UAAU,OAAO,OAAO,QAAQ,KAAK,gBAAgB;AAE5D,SAAK,gBAAgB,EAAE;AACvB,QAAI,KAAK,cACP,MAAK,UAAU,OAAO,IAAI,QAAQ,KAAK,gBAAgB;;GAG5D,CAAC,CACH;;CAGK,8BAA8B,MAAoB;EACxD,MAAM,UAAU,KAAK;AACrB,MAAI,SAAS,UAAU,QAAQ,kBAAkB,MAAM;GACrD,MAAM,QAAQ,QAAQ,MAAM,QAAQ,KAAK;AACzC,UAAO,QAAQ,QAAQ,iBAAiB,UAAU,QAAQ,gBAAgB;;AAE5E,SAAO;;CAGO,oBAAiB;AAC/B,QAAM,mBAAmB;AACzB,OAAK,OAAO,kBAAkB;AAC9B,OAAK,SAAS;AACd,OAAK,UAAU,eAAe;AAC9B,OAAK,WAAW;AAChB,OAAK,aAAa;;;;;;CAOb,SAAM;AACX,OAAK,WAAW;AAChB,OAAK,UAAU,eAAe;AAC9B,OAAK,UAAU,OAAO,IAAI,WAAW;;;;;;CAOhC,WAAQ;AACb,OAAK,WAAW;AAChB,OAAK,UAAU,eAAe;AAC9B,OAAK,UAAU,OAAO,OAAO,WAAW;;;;;;CAOnC,UAAU,UAAkB,SAAiB,eAAsB;AACxE,MAAI,cACF,MAAK,aAAa;AAEpB,OAAK,UAAU,eAAe,GAAG;AACjC,OAAK,UAAU,cAAc,GAAG;;CAG1B,cAAW;EACjB,IAAI,cAAc,KAAK;AACvB,SAAO,eAAe,YAAY,cAAc,WAC9C,eAAc,YAAY;EAG5B,MAAM,QAAQ;AACd,OAAK,UAAU,uBAAuB,mBACpC,KAAK,UAAU,sBACf,KAAK,MACN;AACD,OAAK,QAAQ,iBAAiB,UAAU,QAAQ;AAChD,OAAK,UAAU,uBAAuB,mBACpC,KAAK,UAAU,sBACf,KAAK,MACN;;;;;;;CAQI,QAAQ,OAAc;AAC3B,QAAM,WAAW;;CAGA,SAAM;AACvB,SAAO,IAAI;6CAC8B,KAAK,gBAAgB,CAAA"}
@@ -0,0 +1,212 @@
1
+ import { css, html } from "lit";
2
+ import { SbbElement } from "./core/base-elements.js";
3
+ import { appendAriaElements, removeAriaElements } from "./core/mixins.js";
4
+ import { boxSizingStyles } from "./core/styles.js";
5
+ import { SbbPropertyWatcherController } from "./core/controllers.js";
6
+ import { ResizeController } from "@lit-labs/observers/resize-controller.js";
7
+ //#region src/elements/stepper/step/step.scss?lit&inline
8
+ var step_default = css`:host {
9
+ --sbb-step-opacity: 0;
10
+ --sbb-step-margin-inline-start: var(--sbb-spacing-fixed-4x);
11
+ --sbb-step-animation-duration: var(
12
+ --sbb-disable-animation-duration,
13
+ var(--sbb-animation-duration-2x)
14
+ );
15
+ display: contents;
16
+ font-size: var(--sbb-text-font-size-m);
17
+ letter-spacing: var(--sbb-typo-letter-spacing-text);
18
+ }
19
+
20
+ :host(:is(:state(selected),[state--selected])) {
21
+ --sbb-step-opacity: 1;
22
+ --sbb-step-display: block;
23
+ --sbb-step-height: fit-content;
24
+ --sbb-step-animation-duration: var(
25
+ --sbb-disable-animation-duration,
26
+ var(--sbb-animation-duration-4x)
27
+ );
28
+ --sbb-step-animation-delay: var(--sbb-step-animation-duration);
29
+ }
30
+
31
+ :host(:is(:state(orientation-horizontal),[state--orientation-horizontal])) {
32
+ --sbb-step-position: absolute;
33
+ --sbb-step-inset-block-start: 0;
34
+ }
35
+
36
+ :host(:is(:state(orientation-vertical),[state--orientation-vertical])) .sbb-step--wrapper {
37
+ margin-inline-start: var(--sbb-step-margin-inline-start);
38
+ opacity: 0;
39
+ height: 0;
40
+ transition: display var(--sbb-step-animation-duration) var(--sbb-animation-easing), height var(--sbb-stepper-animation-duration) var(--sbb-animation-easing), opacity var(--sbb-step-animation-duration) var(--sbb-animation-easing);
41
+ transition-behavior: allow-discrete;
42
+ }
43
+ :host(:is(:state(selected),[state--selected]):is(:state(orientation-vertical),[state--orientation-vertical])) .sbb-step--wrapper {
44
+ opacity: 1;
45
+ height: var(--sbb-stepper-content-height);
46
+ transition: display var(--sbb-step-animation-duration) var(--sbb-animation-easing), height var(--sbb-stepper-animation-duration) var(--sbb-animation-easing), opacity var(--sbb-step-animation-duration) var(--sbb-stepper-animation-duration) var(--sbb-animation-easing);
47
+ transition-behavior: allow-discrete;
48
+ }
49
+
50
+ .sbb-step {
51
+ position: var(--sbb-step-position, initial);
52
+ width: 100%;
53
+ inset-block-start: var(--sbb-step-inset-block-start, unset);
54
+ opacity: var(--sbb-step-opacity);
55
+ display: var(--sbb-step-display, none);
56
+ height: var(--sbb-step-height, 0);
57
+ transition-property: display, opacity;
58
+ transition-duration: var(--sbb-step-animation-duration);
59
+ transition-delay: var(--sbb-step-animation-delay, 0);
60
+ transition-timing-function: var(--sbb-animation-easing);
61
+ transition-behavior: allow-discrete;
62
+ }
63
+ @starting-style {
64
+ .sbb-step {
65
+ --sbb-step-opacity: 0;
66
+ }
67
+ }`;
68
+ //#endregion
69
+ //#region src/elements/stepper/step/step.component.ts
70
+ var nextId = 0;
71
+ /**
72
+ * Combined with a `sbb-stepper`, it displays a step's content.
73
+ *
74
+ * @slot - Use the unnamed slot to provide content.
75
+ */
76
+ var SbbStepElement = class extends SbbElement {
77
+ static {
78
+ this.elementName = "sbb-step";
79
+ }
80
+ static {
81
+ this.role = "tabpanel";
82
+ }
83
+ static {
84
+ this.styles = [boxSizingStyles, step_default];
85
+ }
86
+ static {
87
+ this.events = {
88
+ validate: "validate",
89
+ resizechange: "resizechange"
90
+ };
91
+ }
92
+ /** The label of the step. */
93
+ get label() {
94
+ return this._label;
95
+ }
96
+ get stepper() {
97
+ return this.closest("sbb-stepper");
98
+ }
99
+ constructor() {
100
+ super();
101
+ this._stepResizeObserver = new ResizeController(this, {
102
+ target: null,
103
+ skipInitial: true,
104
+ callback: () => setTimeout(() => this._onStepElementResize())
105
+ });
106
+ this._label = null;
107
+ this.addEventListener?.("click", (e) => this._handleClick(e));
108
+ this.addController(new SbbPropertyWatcherController(this, () => this.stepper, { orientation: (s) => {
109
+ if (this._previousOrientation) this.internals.states.delete(`orientation-${this._previousOrientation}`);
110
+ this._previousOrientation = s.orientation;
111
+ if (this._previousOrientation) this.internals.states.add(`orientation-${this._previousOrientation}`);
112
+ } }));
113
+ }
114
+ /**
115
+ * Selects and configures the step.
116
+ * @internal
117
+ * TODO: @breaking-change: make protected
118
+ */
119
+ select() {
120
+ if (!this.hasUpdated || !this.label) return;
121
+ this.internals.states.add("selected");
122
+ this.label.select();
123
+ }
124
+ /**
125
+ * Deselects and configures the step.
126
+ * @internal
127
+ * TODO: @breaking-change: make protected
128
+ */
129
+ deselect() {
130
+ if (!this.label) return;
131
+ this.internals.states.delete("selected");
132
+ this.label.deselect();
133
+ }
134
+ /**
135
+ * Emits a validate event whenever step switch is triggered.
136
+ * @internal
137
+ * TODO: @breaking-change: make protected
138
+ */
139
+ validate(eventData) {
140
+ /**
141
+ * @type {CustomEvent<SbbStepValidateEventDetails>}
142
+ * The validate event is dispatched when a step change is triggered. Can be canceled to abort the step change.
143
+ */
144
+ return this.dispatchEvent(new CustomEvent("validate", {
145
+ bubbles: true,
146
+ composed: true,
147
+ cancelable: true,
148
+ detail: eventData
149
+ }));
150
+ }
151
+ /**
152
+ * Configures the step.
153
+ * @internal
154
+ * TODO: @breaking-change: make protected
155
+ */
156
+ configure(stepperLoaded) {
157
+ if (stepperLoaded) this._assignLabel();
158
+ }
159
+ /** Watches for clicked elements with `sbb-stepper-next` or `sbb-stepper-previous` attributes. */
160
+ _handleClick(event) {
161
+ const composedPathElements = event.composedPath().filter((el) => el instanceof window.HTMLElement);
162
+ if (composedPathElements.some((el) => this._isGoNextElement(el))) this.stepper?.next();
163
+ else if (composedPathElements.some((el) => this._isGoPreviousElement(el))) this.stepper?.previous();
164
+ }
165
+ _isGoNextElement(element) {
166
+ return element.hasAttribute("sbb-stepper-next") && !element.hasAttribute("disabled");
167
+ }
168
+ _isGoPreviousElement(element) {
169
+ return element.hasAttribute("sbb-stepper-previous") && !element.hasAttribute("disabled");
170
+ }
171
+ _onStepElementResize() {
172
+ if (!this.matches(":is(:state(selected),[state--selected])")) return;
173
+ /**
174
+ * @internal
175
+ * Emits when a resize happens, used to avoid setting the height of the stepper from the step component.
176
+ */
177
+ this.dispatchEvent(new Event("resizechange", { bubbles: true }));
178
+ }
179
+ connectedCallback() {
180
+ super.connectedCallback();
181
+ this.id ||= `sbb-step-${nextId++}`;
182
+ this.slot ||= "step";
183
+ this._assignLabel();
184
+ }
185
+ firstUpdated(changedProperties) {
186
+ super.firstUpdated(changedProperties);
187
+ this.updateComplete.then(() => {
188
+ this._stepResizeObserver.observe(this.shadowRoot.querySelector(".sbb-step"));
189
+ });
190
+ }
191
+ _assignLabel() {
192
+ let previousSibling = this.previousElementSibling;
193
+ while (previousSibling && previousSibling.localName !== "sbb-step-label") previousSibling = previousSibling.previousElementSibling;
194
+ const value = previousSibling;
195
+ this.internals.ariaLabelledByElements = removeAriaElements(this.internals.ariaLabelledByElements, this._label);
196
+ this._label = value instanceof Element ? value : null;
197
+ this.internals.ariaLabelledByElements = appendAriaElements(this.internals.ariaLabelledByElements, this._label);
198
+ }
199
+ render() {
200
+ return html`
201
+ <div class="sbb-step--wrapper">
202
+ <div class="sbb-step">
203
+ <slot></slot>
204
+ </div>
205
+ </div>
206
+ `;
207
+ }
208
+ };
209
+ //#endregion
210
+ export { SbbStepElement as t };
211
+
212
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"step.component-ewujsOVD.js","names":[],"sources":["../../../src/elements/stepper/step/step.scss?lit&inline","../../../src/elements/stepper/step/step.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-step-opacity: 0;\n  --sbb-step-margin-inline-start: var(--sbb-spacing-fixed-4x);\n  --sbb-step-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-2x)\n  );\n\n  display: contents;\n  font-size: var(--sbb-text-font-size-m);\n  letter-spacing: var(--sbb-typo-letter-spacing-text);\n}\n\n:host(:state(selected)) {\n  --sbb-step-opacity: 1;\n  --sbb-step-display: block;\n  --sbb-step-height: fit-content;\n  --sbb-step-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-4x)\n  );\n  --sbb-step-animation-delay: var(--sbb-step-animation-duration);\n}\n\n:host(:state(orientation-horizontal)) {\n  --sbb-step-position: absolute;\n  --sbb-step-inset-block-start: 0;\n}\n\n.sbb-step--wrapper {\n  :host(:state(orientation-vertical)) & {\n    margin-inline-start: var(--sbb-step-margin-inline-start);\n    opacity: 0;\n    height: 0;\n    transition:\n      display var(--sbb-step-animation-duration) var(--sbb-animation-easing),\n      height var(--sbb-stepper-animation-duration) var(--sbb-animation-easing),\n      opacity var(--sbb-step-animation-duration) var(--sbb-animation-easing);\n\n    // Experimental property, but supported in every major browser.\n    transition-behavior: allow-discrete;\n  }\n\n  :host(:state(selected):state(orientation-vertical)) & {\n    opacity: 1;\n    height: var(--sbb-stepper-content-height);\n    transition:\n      display var(--sbb-step-animation-duration) var(--sbb-animation-easing),\n      height var(--sbb-stepper-animation-duration) var(--sbb-animation-easing),\n      opacity var(--sbb-step-animation-duration) var(--sbb-stepper-animation-duration)\n        var(--sbb-animation-easing);\n\n    // Experimental property, but supported in every major browser.\n    transition-behavior: allow-discrete;\n  }\n}\n\n.sbb-step {\n  position: var(--sbb-step-position, initial);\n  width: 100%;\n  inset-block-start: var(--sbb-step-inset-block-start, unset);\n  opacity: var(--sbb-step-opacity);\n  display: var(--sbb-step-display, none);\n  height: var(--sbb-step-height, 0);\n  transition: {\n    property: display, opacity;\n    duration: var(--sbb-step-animation-duration);\n    delay: var(--sbb-step-animation-delay, 0);\n    timing-function: var(--sbb-animation-easing);\n  }\n\n  // Experimental property, but supported in every major browser.\n  transition-behavior: allow-discrete;\n\n  // Experimental property, currently supported in every major browser except Firefox.\n  @starting-style {\n    --sbb-step-opacity: 0;\n  }\n}\n","import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport { type CSSResultGroup, html, type PropertyValues, type TemplateResult } from 'lit';\n\nimport { SbbElement } from '../../core/base-elements.ts';\nimport { SbbPropertyWatcherController } from '../../core/controllers.ts';\nimport { appendAriaElements, removeAriaElements } from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbStepLabelElement } from '../step-label/step-label.component.ts';\nimport type { SbbStepperElement } from '../stepper/stepper.component.ts';\n\nimport style from './step.scss?lit&inline';\n\nlet nextId = 0;\n\nexport interface SbbStepValidateEventDetails {\n  currentIndex: number | null;\n  currentStep: SbbStepElement | null;\n  nextIndex: number | null;\n  nextStep: SbbStepElement | null;\n}\n\n/**\n * Combined with a `sbb-stepper`, it displays a step's content.\n *\n * @slot - Use the unnamed slot to provide content.\n */\nexport class SbbStepElement extends SbbElement {\n  public static override readonly elementName: string = 'sbb-step';\n  public static override readonly role = 'tabpanel';\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  public static readonly events = {\n    validate: 'validate',\n    resizechange: 'resizechange',\n  } as const;\n\n  // We use a timeout as a workaround to the \"ResizeObserver loop completed with undelivered notifications\" error.\n  // For more details:\n  // - https://github.com/WICG/resize-observer/issues/38#issuecomment-422126006\n  // - https://github.com/juggle/resize-observer/issues/103#issuecomment-1711148285\n  private _stepResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: () => setTimeout(() => this._onStepElementResize()),\n  });\n\n  /** The label of the step. */\n  public get label(): SbbStepLabelElement | null {\n    return this._label;\n  }\n  private _label: SbbStepLabelElement | null = null;\n\n  public get stepper(): SbbStepperElement | null {\n    return this.closest('sbb-stepper');\n  }\n\n  private _previousOrientation?: string;\n\n  public constructor() {\n    super();\n    this.addEventListener?.('click', (e) => this._handleClick(e));\n    this.addController(\n      new SbbPropertyWatcherController(this, () => this.stepper, {\n        orientation: (s) => {\n          if (this._previousOrientation) {\n            this.internals.states.delete(`orientation-${this._previousOrientation}`);\n          }\n          this._previousOrientation = s.orientation;\n          if (this._previousOrientation) {\n            this.internals.states.add(`orientation-${this._previousOrientation}`);\n          }\n        },\n      }),\n    );\n  }\n\n  /**\n   * Selects and configures the step.\n   * @internal\n   * TODO: @breaking-change: make protected\n   */\n  public select(): void {\n    if (!this.hasUpdated || !this.label) {\n      return;\n    }\n    this.internals.states.add('selected');\n    this.label.select();\n  }\n\n  /**\n   * Deselects and configures the step.\n   * @internal\n   * TODO: @breaking-change: make protected\n   */\n  public deselect(): void {\n    if (!this.label) {\n      return;\n    }\n    this.internals.states.delete('selected');\n    this.label.deselect();\n  }\n\n  /**\n   * Emits a validate event whenever step switch is triggered.\n   * @internal\n   * TODO: @breaking-change: make protected\n   */\n  public validate(eventData: SbbStepValidateEventDetails): boolean {\n    // TODO: @breaking-change: Create a specific event type for this event.\n    /**\n     * @type {CustomEvent<SbbStepValidateEventDetails>}\n     * The validate event is dispatched when a step change is triggered. Can be canceled to abort the step change.\n     */\n    return this.dispatchEvent(\n      new CustomEvent<SbbStepValidateEventDetails>('validate', {\n        bubbles: true,\n        composed: true,\n        cancelable: true,\n        detail: eventData,\n      }),\n    );\n  }\n\n  /**\n   * Configures the step.\n   * @internal\n   * TODO: @breaking-change: make protected\n   */\n  public configure(stepperLoaded: boolean): void {\n    if (stepperLoaded) {\n      this._assignLabel();\n    }\n  }\n\n  /** Watches for clicked elements with `sbb-stepper-next` or `sbb-stepper-previous` attributes. */\n  private _handleClick(event: Event): void {\n    const composedPathElements = event\n      .composedPath()\n      .filter((el) => el instanceof window.HTMLElement);\n    if (composedPathElements.some((el) => this._isGoNextElement(el as HTMLElement))) {\n      this.stepper?.next();\n    } else if (composedPathElements.some((el) => this._isGoPreviousElement(el as HTMLElement))) {\n      this.stepper?.previous();\n    }\n  }\n\n  private _isGoNextElement(element: HTMLElement): boolean {\n    return element.hasAttribute('sbb-stepper-next') && !element.hasAttribute('disabled');\n  }\n\n  private _isGoPreviousElement(element: HTMLElement): boolean {\n    return element.hasAttribute('sbb-stepper-previous') && !element.hasAttribute('disabled');\n  }\n\n  private _onStepElementResize(): void {\n    if (!this.matches(':state(selected)')) {\n      return;\n    }\n\n    /**\n     * @internal\n     * Emits when a resize happens, used to avoid setting the height of the stepper from the step component.\n     */\n    this.dispatchEvent(new Event('resizechange', { bubbles: true }));\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.id ||= `sbb-step-${nextId++}`;\n    this.slot ||= 'step';\n    this._assignLabel();\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n    this.updateComplete.then(() => {\n      this._stepResizeObserver.observe(this.shadowRoot!.querySelector('.sbb-step') as HTMLElement);\n    });\n  }\n\n  private _assignLabel(): void {\n    let previousSibling = this.previousElementSibling;\n    while (previousSibling && previousSibling.localName !== 'sbb-step-label') {\n      previousSibling = previousSibling.previousElementSibling;\n    }\n    const value = previousSibling as SbbStepLabelElement | null;\n\n    this.internals.ariaLabelledByElements = removeAriaElements(\n      this.internals.ariaLabelledByElements,\n      this._label,\n    );\n    this._label = value instanceof Element ? value : null;\n    this.internals.ariaLabelledByElements = appendAriaElements(\n      this.internals.ariaLabelledByElements,\n      this._label,\n    );\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-step--wrapper\">\n        <div class=\"sbb-step\">\n          <slot></slot>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-step': SbbStepElement;\n  }\n}\n\ndeclare global {\n  interface GlobalEventHandlersEventMap {\n    resizechange: Event;\n  }\n}\n"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- import { t as SbbStepElement } from "../../step.component-DsXAckYS.js";
1
+ import { t as SbbStepElement } from "../../step.component-ewujsOVD.js";
2
2
  export { SbbStepElement };
@@ -1 +1 @@
1
- {"version":3,"file":"step-label.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/stepper/step-label/step-label.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAQ,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAErE,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAKnE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAChE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;;AAMzE;;;;;GAKG;AACH,qBAAa,mBAAoB,SAAQ,wBAAwD;IAC/F,gBAAgC,WAAW,EAAE,MAAM,CAAoB;IACvE,gBAAgC,IAAI,SAAS;IAC7C,OAAuB,MAAM,EAAE,cAAc,CAA4B;IAEzE,wCAAwC;IACxC,IAAW,IAAI,IAAI,cAAc,GAAG,IAAI,CAEvC;IACD,OAAO,CAAC,KAAK,CAA+B;IAE5C,IAAW,OAAO,IAAI,iBAAiB,GAAG,IAAI,CAE7C;IAED,IAAoB,QAAQ,CAAC,KAAK,EAAE,OAAO,EAM1C;IACD,IAAoB,QAAQ,IAAI,OAAO,CAEtC;IAED,OAAO,CAAC,oBAAoB,CAAC,CAAS;IACtC,OAAO,CAAC,aAAa,CAAC,CAAS;;IAmC/B,OAAO,CAAC,6BAA6B;IASrB,iBAAiB,IAAI,IAAI;IASzC;;;OAGG;IACI,MAAM,IAAI,IAAI;IAMrB;;;OAGG;IACI,QAAQ,IAAI,IAAI;IAMvB;;;OAGG;IACI,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,OAAO,GAAG,IAAI;IAQjF,OAAO,CAAC,WAAW;IAkBnB;;;;OAIG;IACI,OAAO,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI;cAIjB,MAAM,IAAI,cAAc;CAQ5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gBAAgB,EAAE,mBAAmB,CAAC;KACvC;CACF"}
1
+ {"version":3,"file":"step-label.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/stepper/step-label/step-label.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAQ,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAErE,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAKnE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAChE,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAC;;AAMzE;;;;;GAKG;AACH,qBAAa,mBAAoB,SAAQ,wBAAwD;IAC/F,gBAAgC,WAAW,EAAE,MAAM,CAAoB;IACvE,gBAAgC,IAAI,SAAS;IAC7C,OAAuB,MAAM,EAAE,cAAc,CAA4B;IAEzE,wCAAwC;IACxC,IAAW,IAAI,IAAI,cAAc,GAAG,IAAI,CAEvC;IACD,OAAO,CAAC,KAAK,CAA+B;IAE5C,IAAW,OAAO,IAAI,iBAAiB,GAAG,IAAI,CAE7C;IAED,IAAoB,QAAQ,CAAC,KAAK,EAAE,OAAO,EAM1C;IACD,IAAoB,QAAQ,IAAI,OAAO,CAEtC;IAED,OAAO,CAAC,oBAAoB,CAAC,CAAS;IACtC,OAAO,CAAC,aAAa,CAAC,CAAS;;IAmC/B,OAAO,CAAC,6BAA6B;IASrB,iBAAiB,IAAI,IAAI;IASzC;;;OAGG;IACI,MAAM,IAAI,IAAI;IAMrB;;;OAGG;IACI,QAAQ,IAAI,IAAI;IAMvB;;;OAGG;IACI,SAAS,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,aAAa,EAAE,OAAO,GAAG,IAAI;IAQjF,OAAO,CAAC,WAAW;IAkBnB;;;;OAIG;IACI,OAAO,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI;cAIjB,MAAM,IAAI,cAAc;CAM5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gBAAgB,EAAE,mBAAmB,CAAC;KACvC;CACF"}
@@ -1,2 +1,2 @@
1
- import { t as SbbStepLabelElement } from "../../step-label.component-C_obpSzp.js";
1
+ import { t as SbbStepLabelElement } from "../../step-label.component-D3wrRPQ7.js";
2
2
  export { SbbStepLabelElement };
@@ -1,4 +1,4 @@
1
- import { t as SbbStepLabelElement } from "../step-label.component-C_obpSzp.js";
1
+ import { t as SbbStepLabelElement } from "../step-label.component-D3wrRPQ7.js";
2
2
  //#region src/elements/stepper/step-label.ts
3
3
  /** @entrypoint */
4
4
  SbbStepLabelElement.define();
@@ -1,4 +1,4 @@
1
- import { t as SbbStepElement } from "../step.component-DsXAckYS.js";
1
+ import { t as SbbStepElement } from "../step.component-ewujsOVD.js";
2
2
  //#region src/elements/stepper/step.ts
3
3
  /** @entrypoint */
4
4
  SbbStepElement.define();
@@ -1 +1 @@
1
- {"version":3,"file":"stepper.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/stepper/stepper/stepper.component.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"stepper.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/stepper/stepper/stepper.component.ts"],"names":[],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- import { n as SbbStepperElement, t as SbbStepChangeEvent } from "../../stepper.component-yAkgcauE.js";
1
+ import { n as SbbStepperElement, t as SbbStepChangeEvent } from "../../stepper.component-BJC_4cep.js";
2
2
  export { SbbStepChangeEvent, SbbStepperElement };
@@ -1,4 +1,4 @@
1
- import { n as SbbStepperElement, t as SbbStepChangeEvent } from "../stepper.component-yAkgcauE.js";
1
+ import { n as SbbStepperElement, t as SbbStepChangeEvent } from "../stepper.component-BJC_4cep.js";
2
2
  //#region src/elements/stepper/stepper.ts
3
3
  /** @entrypoint */
4
4
  SbbStepperElement.define();