@sbb-esta/lyne-elements 3.0.0-next.2 → 3.0.0-next.3

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.
@@ -93301,11 +93301,12 @@
93301
93301
  {
93302
93302
  "kind": "field",
93303
93303
  "name": "label",
93304
- "privacy": "public",
93305
- "description": "The label of the step.",
93306
93304
  "type": {
93307
93305
  "text": "SbbStepLabelElement | null"
93308
93306
  },
93307
+ "privacy": "public",
93308
+ "description": "The label of the step.",
93309
+ "readonly": true,
93309
93310
  "default": "null"
93310
93311
  },
93311
93312
  {
@@ -93384,11 +93385,11 @@
93384
93385
  },
93385
93386
  {
93386
93387
  "kind": "method",
93387
- "name": "_getStepLabel",
93388
+ "name": "_assignLabel",
93388
93389
  "privacy": "private",
93389
93390
  "return": {
93390
93391
  "type": {
93391
- "text": "SbbStepLabelElement | null"
93392
+ "text": "void"
93392
93393
  }
93393
93394
  }
93394
93395
  },
@@ -93501,11 +93502,12 @@
93501
93502
  {
93502
93503
  "kind": "field",
93503
93504
  "name": "step",
93504
- "privacy": "public",
93505
- "description": "The step controlled by the label.",
93506
93505
  "type": {
93507
93506
  "text": "SbbStepElement | null"
93508
93507
  },
93508
+ "privacy": "public",
93509
+ "description": "The step controlled by the label.",
93510
+ "readonly": true,
93509
93511
  "default": "null"
93510
93512
  },
93511
93513
  {
@@ -93528,11 +93530,11 @@
93528
93530
  },
93529
93531
  {
93530
93532
  "kind": "method",
93531
- "name": "_getStep",
93533
+ "name": "_assignStep",
93532
93534
  "privacy": "private",
93533
93535
  "return": {
93534
93536
  "type": {
93535
- "text": "SbbStepElement | null"
93537
+ "text": "void"
93536
93538
  }
93537
93539
  }
93538
93540
  },
@@ -30,7 +30,6 @@ export declare class SbbStepElement extends SbbStepElement_base {
30
30
  private _stepper;
31
31
  private _stepResizeObserver;
32
32
  /** The label of the step. */
33
- private set label(value);
34
33
  get label(): SbbStepLabelElement | null;
35
34
  private _label;
36
35
  constructor();
@@ -59,9 +58,9 @@ export declare class SbbStepElement extends SbbStepElement_base {
59
58
  private _isGoNextElement;
60
59
  private _isGoPreviousElement;
61
60
  private _onStepElementResize;
62
- private _getStepLabel;
63
61
  connectedCallback(): void;
64
62
  protected firstUpdated(changedProperties: PropertyValues<this>): void;
63
+ private _assignLabel;
65
64
  protected render(): TemplateResult;
66
65
  }
67
66
  declare global {
@@ -1 +1 @@
1
- {"version":3,"file":"step.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/stepper/step/step.component.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,cAAc,EAEnB,UAAU,EACV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AASb,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAO5D,MAAM,MAAM,2BAA2B,GAAG;IACxC,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,WAAW,EAAE,cAAc,GAAG,IAAI,CAAC;IACnC,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,QAAQ,EAAE,cAAc,GAAG,IAAI,CAAC;CACjC,CAAC;;AAEF;;;;;GAKG;AACH,qBAEM,cAAe,SAAQ,mBAAoC;IAC/D,gBAAgC,IAAI,cAAc;IAClD,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;;MAGlB;IAEX,+CAA+C;IAC/C,OAAO,CAAC,SAAS,CAGf;IAEF;;;OAGG;IACH,OAAO,CAAC,aAAa,CAInB;IAEF,OAAO,CAAC,QAAQ,CAAkC;IAMlD,OAAO,CAAC,mBAAmB,CAIxB;IAEH,6BAA6B;IAE7B,OAAO,KAAK,KAAK,QAUhB;IACD,IAAW,KAAK,IAAI,mBAAmB,GAAG,IAAI,CAE7C;IACD,OAAO,CAAC,MAAM,CAAoC;;IAOlD;;;OAGG;IACI,MAAM,IAAI,IAAI;IAQrB;;;OAGG;IACI,QAAQ,IAAI,IAAI;IAQvB;;;OAGG;IACI,QAAQ,CAAC,SAAS,EAAE,2BAA2B,GAAG,OAAO;IAIhE;;;OAGG;IACI,SAAS,CAAC,aAAa,EAAE,OAAO,GAAG,IAAI;IAM9C,iGAAiG;IACjG,OAAO,CAAC,YAAY;IAWpB,OAAO,CAAC,gBAAgB;IAIxB,OAAO,CAAC,oBAAoB;IAI5B,OAAO,CAAC,oBAAoB;IAO5B,OAAO,CAAC,aAAa;IAQL,iBAAiB,IAAI,IAAI;cAQtB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAO3D,MAAM,IAAI,cAAc;CAS5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,UAAU,EAAE,cAAc,CAAC;KAC5B;CACF;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,2BAA2B;QACnC,YAAY,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC;KACjC;CACF"}
1
+ {"version":3,"file":"step.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/stepper/step/step.component.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,cAAc,EAEnB,UAAU,EACV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AASb,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAO5D,MAAM,MAAM,2BAA2B,GAAG;IACxC,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,WAAW,EAAE,cAAc,GAAG,IAAI,CAAC;IACnC,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,QAAQ,EAAE,cAAc,GAAG,IAAI,CAAC;CACjC,CAAC;;AAEF;;;;;GAKG;AACH,qBAEM,cAAe,SAAQ,mBAAoC;IAC/D,gBAAgC,IAAI,cAAc;IAClD,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;;MAGlB;IAEX,+CAA+C;IAC/C,OAAO,CAAC,SAAS,CAGf;IAEF;;;OAGG;IACH,OAAO,CAAC,aAAa,CAInB;IAEF,OAAO,CAAC,QAAQ,CAAkC;IAMlD,OAAO,CAAC,mBAAmB,CAIxB;IAEH,6BAA6B;IAC7B,IAAW,KAAK,IAAI,mBAAmB,GAAG,IAAI,CAE7C;IACD,OAAO,CAAC,MAAM,CAAoC;;IAOlD;;;OAGG;IACI,MAAM,IAAI,IAAI;IAQrB;;;OAGG;IACI,QAAQ,IAAI,IAAI;IAQvB;;;OAGG;IACI,QAAQ,CAAC,SAAS,EAAE,2BAA2B,GAAG,OAAO;IAIhE;;;OAGG;IACI,SAAS,CAAC,aAAa,EAAE,OAAO,GAAG,IAAI;IAM9C,iGAAiG;IACjG,OAAO,CAAC,YAAY;IAWpB,OAAO,CAAC,gBAAgB;IAIxB,OAAO,CAAC,oBAAoB;IAI5B,OAAO,CAAC,oBAAoB;IAOZ,iBAAiB,IAAI,IAAI;cAQtB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAO9E,OAAO,CAAC,YAAY;cAkBD,MAAM,IAAI,cAAc;CAS5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,UAAU,EAAE,cAAc,CAAC;KAC5B;CACF;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,2BAA2B;QACnC,YAAY,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC;KACjC;CACF"}
@@ -90,12 +90,6 @@ let SbbStepElement = (() => {
90
90
  let _classSuper = SbbElementInternalsMixin(LitElement);
91
91
  var SbbStepElement2 = (_a = class extends _classSuper {
92
92
  /** The label of the step. */
93
- // eslint-disable-next-line @typescript-eslint/naming-convention
94
- set label(value) {
95
- this.internals.ariaLabelledByElements = removeAriaElements(this.internals.ariaLabelledByElements, this._label);
96
- this._label = value instanceof Element ? value : null;
97
- this.internals.ariaLabelledByElements = appendAriaElements(this.internals.ariaLabelledByElements, this._label);
98
- }
99
93
  get label() {
100
94
  return this._label;
101
95
  }
@@ -147,7 +141,7 @@ let SbbStepElement = (() => {
147
141
  */
148
142
  configure(stepperLoaded) {
149
143
  if (stepperLoaded) {
150
- this.label = this._getStepLabel();
144
+ this._assignLabel();
151
145
  }
152
146
  }
153
147
  /** Watches for clicked elements with `sbb-stepper-next` or `sbb-stepper-previous` attributes. */
@@ -171,19 +165,12 @@ let SbbStepElement = (() => {
171
165
  }
172
166
  this._resizeChange.emit();
173
167
  }
174
- _getStepLabel() {
175
- let previousSibling = this.previousElementSibling;
176
- while (previousSibling && previousSibling.localName !== "sbb-step-label") {
177
- previousSibling = previousSibling.previousElementSibling;
178
- }
179
- return previousSibling;
180
- }
181
168
  connectedCallback() {
182
169
  super.connectedCallback();
183
170
  this.id ||= `sbb-step-${nextId++}`;
184
171
  this.slot ||= "step";
185
172
  this._stepper = this.closest("sbb-stepper");
186
- this.label = this._getStepLabel();
173
+ this._assignLabel();
187
174
  }
188
175
  firstUpdated(changedProperties) {
189
176
  super.firstUpdated(changedProperties);
@@ -191,6 +178,16 @@ let SbbStepElement = (() => {
191
178
  this._stepResizeObserver.observe(this.shadowRoot.querySelector(".sbb-step"));
192
179
  });
193
180
  }
181
+ _assignLabel() {
182
+ let previousSibling = this.previousElementSibling;
183
+ while (previousSibling && previousSibling.localName !== "sbb-step-label") {
184
+ previousSibling = previousSibling.previousElementSibling;
185
+ }
186
+ const value = previousSibling;
187
+ this.internals.ariaLabelledByElements = removeAriaElements(this.internals.ariaLabelledByElements, this._label);
188
+ this._label = value instanceof Element ? value : null;
189
+ this.internals.ariaLabelledByElements = appendAriaElements(this.internals.ariaLabelledByElements, this._label);
190
+ }
194
191
  render() {
195
192
  return html`
196
193
  <div class="sbb-step--wrapper">
@@ -214,4 +211,4 @@ let SbbStepElement = (() => {
214
211
  export {
215
212
  SbbStepElement
216
213
  };
217
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"step.component.js","sources":["../../../../../src/elements/stepper/step/step.component.ts"],"sourcesContent":["import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport {\n  type CSSResultGroup,\n  html,\n  LitElement,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\nimport { EventEmitter } from '../../core/eventing.js';\nimport {\n  appendAriaElements,\n  removeAriaElements,\n  SbbElementInternalsMixin,\n} from '../../core/mixins.js';\nimport type { SbbStepLabelElement } from '../step-label.js';\nimport type { SbbStepperElement } from '../stepper.js';\n\nimport style from './step.scss?lit&inline';\n\nlet nextId = 0;\n\nexport type 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 * @event {CustomEvent<SbbStepValidateEventDetails>} validate - Emits whenever step switch is triggered. Can be canceled.\n */\nexport\n@customElement('sbb-step')\nclass SbbStepElement extends SbbElementInternalsMixin(LitElement) {\n  public static override readonly role = 'tabpanel';\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    validate: 'validate',\n    resizeChange: 'resizeChange',\n  } as const;\n\n  /** Emits whenever step switch is triggered. */\n  private _validate: EventEmitter<SbbStepValidateEventDetails> = new EventEmitter(\n    this,\n    SbbStepElement.events.validate,\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  private _resizeChange: EventEmitter<void> = new EventEmitter(\n    this,\n    SbbStepElement.events.resizeChange,\n    { bubbles: true },\n  );\n\n  private _stepper: SbbStepperElement | null = null;\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  // eslint-disable-next-line @typescript-eslint/naming-convention\n  private set label(value: SbbStepLabelElement | null) {\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  public get label(): SbbStepLabelElement | null {\n    return this._label;\n  }\n  private _label: SbbStepLabelElement | null = null;\n\n  public constructor() {\n    super();\n    this.addEventListener?.('click', (e) => this._handleClick(e));\n  }\n\n  /**\n   * Selects and configures the step.\n   * @internal\n   */\n  public select(): void {\n    if (!this.hasUpdated || !this.label) {\n      return;\n    }\n    this.toggleAttribute('data-selected', true);\n    this.label.select();\n  }\n\n  /**\n   * Deselects and configures the step.\n   * @internal\n   */\n  public deselect(): void {\n    if (!this.label) {\n      return;\n    }\n    this.toggleAttribute('data-selected', false);\n    this.label.deselect();\n  }\n\n  /**\n   * Emits a validate event whenever step switch is triggered.\n   * @internal\n   */\n  public validate(eventData: SbbStepValidateEventDetails): boolean {\n    return !!this._validate.emit(eventData);\n  }\n\n  /**\n   * Configures the step.\n   * @internal\n   */\n  public configure(stepperLoaded: boolean): void {\n    if (stepperLoaded) {\n      this.label = this._getStepLabel();\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.hasAttribute('data-selected')) {\n      return;\n    }\n    this._resizeChange.emit();\n  }\n\n  private _getStepLabel(): SbbStepLabelElement | null {\n    let previousSibling = this.previousElementSibling;\n    while (previousSibling && previousSibling.localName !== 'sbb-step-label') {\n      previousSibling = previousSibling.previousElementSibling;\n    }\n    return previousSibling as SbbStepLabelElement;\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.id ||= `sbb-step-${nextId++}`;\n    this.slot ||= 'step';\n    this._stepper = this.closest('sbb-stepper');\n    this.label = this._getStepLabel();\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  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: CustomEvent<void>;\n  }\n}\n"],"names":["SbbStepElement"],"mappings":"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"}
214
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"step.component.js","sources":["../../../../../src/elements/stepper/step/step.component.ts"],"sourcesContent":["import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport {\n  type CSSResultGroup,\n  html,\n  LitElement,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\nimport { EventEmitter } from '../../core/eventing.js';\nimport {\n  appendAriaElements,\n  removeAriaElements,\n  SbbElementInternalsMixin,\n} from '../../core/mixins.js';\nimport type { SbbStepLabelElement } from '../step-label.js';\nimport type { SbbStepperElement } from '../stepper.js';\n\nimport style from './step.scss?lit&inline';\n\nlet nextId = 0;\n\nexport type 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 * @event {CustomEvent<SbbStepValidateEventDetails>} validate - Emits whenever step switch is triggered. Can be canceled.\n */\nexport\n@customElement('sbb-step')\nclass SbbStepElement extends SbbElementInternalsMixin(LitElement) {\n  public static override readonly role = 'tabpanel';\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    validate: 'validate',\n    resizeChange: 'resizeChange',\n  } as const;\n\n  /** Emits whenever step switch is triggered. */\n  private _validate: EventEmitter<SbbStepValidateEventDetails> = new EventEmitter(\n    this,\n    SbbStepElement.events.validate,\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  private _resizeChange: EventEmitter<void> = new EventEmitter(\n    this,\n    SbbStepElement.events.resizeChange,\n    { bubbles: true },\n  );\n\n  private _stepper: SbbStepperElement | null = null;\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 constructor() {\n    super();\n    this.addEventListener?.('click', (e) => this._handleClick(e));\n  }\n\n  /**\n   * Selects and configures the step.\n   * @internal\n   */\n  public select(): void {\n    if (!this.hasUpdated || !this.label) {\n      return;\n    }\n    this.toggleAttribute('data-selected', true);\n    this.label.select();\n  }\n\n  /**\n   * Deselects and configures the step.\n   * @internal\n   */\n  public deselect(): void {\n    if (!this.label) {\n      return;\n    }\n    this.toggleAttribute('data-selected', false);\n    this.label.deselect();\n  }\n\n  /**\n   * Emits a validate event whenever step switch is triggered.\n   * @internal\n   */\n  public validate(eventData: SbbStepValidateEventDetails): boolean {\n    return !!this._validate.emit(eventData);\n  }\n\n  /**\n   * Configures the step.\n   * @internal\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.hasAttribute('data-selected')) {\n      return;\n    }\n    this._resizeChange.emit();\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.id ||= `sbb-step-${nextId++}`;\n    this.slot ||= 'step';\n    this._stepper = this.closest('sbb-stepper');\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: CustomEvent<void>;\n  }\n}\n"],"names":["SbbStepElement"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAqBA,IAAI,SAAS;IAiBP,kBAAc,MAAA;;0BADnB,cAAc,UAAU,CAAC;;;;oBACG,yBAAyB,UAAU;AAA3C,MAAAA,mBAAA,mBAAQ,YAAoC;AAAA;AAAA,IAqC/D,IAAW,QAAK;AACd,aAAO,KAAK;AAAA,IAAA;AAAA,IAId,cAAA;AACE,YAAA;AAlCM,WAAA,YAAuD,IAAI,aACjE,MACAA,gBAAe,OAAO,QAAQ;AAOxB,WAAA,gBAAoC,IAAI,aAC9C,MACAA,gBAAe,OAAO,cACtB,EAAE,SAAS,MAAM;AAGX,WAAA,WAAqC;AAMrC,WAAA,sBAAsB,IAAI,iBAAiB,MAAM;AAAA,QACvD,QAAQ;AAAA,QACR,aAAa;AAAA,QACb,UAAU,MAAM,WAAW,MAAM,KAAK,sBAAsB;AAAA,MAAA,CAC7D;AAMO,WAAA,SAAqC;AAI3C,WAAK,mBAAmB,SAAS,CAAC,MAAM,KAAK,aAAa,CAAC,CAAC;AAAA,IAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOvD,SAAM;AACX,UAAI,CAAC,KAAK,cAAc,CAAC,KAAK,OAAO;AACnC;AAAA,MAAA;AAEF,WAAK,gBAAgB,iBAAiB,IAAI;AAC1C,WAAK,MAAM,OAAA;AAAA;;;;;IAON,WAAQ;AACb,UAAI,CAAC,KAAK,OAAO;AACf;AAAA,MAAA;AAEF,WAAK,gBAAgB,iBAAiB,KAAK;AAC3C,WAAK,MAAM,SAAA;AAAA;;;;;IAON,SAAS,WAAsC;AACpD,aAAO,CAAC,CAAC,KAAK,UAAU,KAAK,SAAS;AAAA,IAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOjC,UAAU,eAAsB;AACrC,UAAI,eAAe;AACjB,aAAK,aAAA;AAAA,MAAY;AAAA,IACnB;AAAA;AAAA,IAIM,aAAa,OAAY;AAC/B,YAAM,uBAAuB,MAC1B,eACA,OAAO,CAAC,OAAO,cAAc,OAAO,WAAW;AAClD,UAAI,qBAAqB,KAAK,CAAC,OAAO,KAAK,iBAAiB,EAAiB,CAAC,GAAG;AAC/E,aAAK,UAAU,KAAA;AAAA,iBACN,qBAAqB,KAAK,CAAC,OAAO,KAAK,qBAAqB,EAAiB,CAAC,GAAG;AAC1F,aAAK,UAAU,SAAA;AAAA;IACjB;AAAA,IAGM,iBAAiB,SAAoB;AAC3C,aAAO,QAAQ,aAAa,kBAAkB,KAAK,CAAC,QAAQ,aAAa,UAAU;AAAA,IAAA;AAAA,IAG7E,qBAAqB,SAAoB;AAC/C,aAAO,QAAQ,aAAa,sBAAsB,KAAK,CAAC,QAAQ,aAAa,UAAU;AAAA,IAAA;AAAA,IAGjF,uBAAoB;AAC1B,UAAI,CAAC,KAAK,aAAa,eAAe,GAAG;AACvC;AAAA,MAAA;AAEF,WAAK,cAAc,KAAA;AAAA;IAGL,oBAAiB;AAC/B,YAAM,kBAAA;AACN,WAAK,OAAO,YAAY,QAAQ;AAChC,WAAK,SAAS;AACd,WAAK,WAAW,KAAK,QAAQ,aAAa;AAC1C,WAAK,aAAA;AAAA,IAAY;AAAA,IAGA,aAAa,mBAAuC;AACrE,YAAM,aAAa,iBAAiB;AACpC,WAAK,eAAe,KAAK,MAAK;AAC5B,aAAK,oBAAoB,QAAQ,KAAK,WAAY,cAAc,WAAW,CAAgB;AAAA,MAAA,CAC5F;AAAA,IAAA;AAAA,IAGK,eAAY;AAClB,UAAI,kBAAkB,KAAK;AAC3B,aAAO,mBAAmB,gBAAgB,cAAc,kBAAkB;AACxE,0BAAkB,gBAAgB;AAAA,MAAA;AAEpC,YAAM,QAAQ;AAEd,WAAK,UAAU,yBAAyB,mBACtC,KAAK,UAAU,wBACf,KAAK,MAAM;AAEb,WAAK,SAAS,iBAAiB,UAAU,QAAQ;AACjD,WAAK,UAAU,yBAAyB,mBACtC,KAAK,UAAU,wBACf,KAAK,MAAM;AAAA,IAAA;AAAA,IAII,SAAM;AACvB,aAAO;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAAA;AAAA;;AAtJX,iBAAA,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;QACkC,GAAA,OAAO,YAChB,GAAA,SAAyB,OACzB,GAAA,SAAS;AAAA,IAC9B,UAAU;AAAA,IACV,cAAc;AAAA,EAAA,GALZ,kBAAA,YAAA,uBAAA,GAAe;;;"}
@@ -13,12 +13,10 @@ export declare class SbbStepLabelElement extends SbbStepLabelElement_base {
13
13
  static readonly role = "tab";
14
14
  static styles: CSSResultGroup;
15
15
  /** The step controlled by the label. */
16
- private set step(value);
17
16
  get step(): SbbStepElement | null;
18
17
  private _step;
19
18
  private _stepper;
20
19
  constructor();
21
- private _getStep;
22
20
  connectedCallback(): void;
23
21
  /**
24
22
  * Selects and configures the step label.
@@ -35,6 +33,7 @@ export declare class SbbStepLabelElement extends SbbStepLabelElement_base {
35
33
  * @internal
36
34
  */
37
35
  configure(posInSet: number, setSize: number, stepperLoaded: boolean): void;
36
+ private _assignStep;
38
37
  protected render(): TemplateResult;
39
38
  }
40
39
  declare global {
@@ -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;AAGrE,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAGnE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;;AAOjD;;;;;;GAMG;AACH,qBAEM,mBAAoB,SAAQ,wBAAwD;IACxF,gBAAgC,IAAI,SAAS;IAC7C,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,wCAAwC;IAExC,OAAO,KAAK,IAAI,QAUf;IACD,IAAW,IAAI,IAAI,cAAc,GAAG,IAAI,CAEvC;IACD,OAAO,CAAC,KAAK,CAA+B;IAE5C,OAAO,CAAC,QAAQ,CAAkC;;IAWlD,OAAO,CAAC,QAAQ;IAQA,iBAAiB,IAAI,IAAI;IAazC;;;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;cAQ9D,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;AAGrE,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAGnE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;;AAOjD;;;;;;GAMG;AACH,qBAEM,mBAAoB,SAAQ,wBAAwD;IACxF,gBAAgC,IAAI,SAAS;IAC7C,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,wCAAwC;IACxC,IAAW,IAAI,IAAI,cAAc,GAAG,IAAI,CAEvC;IACD,OAAO,CAAC,KAAK,CAA+B;IAE5C,OAAO,CAAC,QAAQ,CAAkC;;IAWlC,iBAAiB,IAAI,IAAI;IAazC;;;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;cAkBA,MAAM,IAAI,cAAc;CAQ5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gBAAgB,EAAE,mBAAmB,CAAC;KACvC;CACF"}
@@ -185,12 +185,6 @@ let SbbStepLabelElement = (() => {
185
185
  let _classSuper = SbbIconNameMixin(SbbDisabledMixin(SbbButtonBaseElement));
186
186
  _a = class extends _classSuper {
187
187
  /** The step controlled by the label. */
188
- // eslint-disable-next-line @typescript-eslint/naming-convention
189
- set step(value) {
190
- this.internals.ariaControlsElements = removeAriaElements(this.internals.ariaControlsElements, this._step);
191
- this._step = value instanceof Element ? value : null;
192
- this.internals.ariaControlsElements = appendAriaElements(this.internals.ariaControlsElements, this._step);
193
- }
194
188
  get step() {
195
189
  return this._step;
196
190
  }
@@ -204,13 +198,6 @@ let SbbStepLabelElement = (() => {
204
198
  }
205
199
  });
206
200
  }
207
- _getStep() {
208
- let nextSibling = this.nextElementSibling;
209
- while (nextSibling && nextSibling.localName !== "sbb-step") {
210
- nextSibling = nextSibling.nextElementSibling;
211
- }
212
- return nextSibling;
213
- }
214
201
  connectedCallback() {
215
202
  super.connectedCallback();
216
203
  this.id ||= `sbb-step-label-${nextId++}`;
@@ -218,7 +205,7 @@ let SbbStepLabelElement = (() => {
218
205
  this.internals.ariaSelected = "false";
219
206
  this.tabIndex = -1;
220
207
  this._stepper = this.closest("sbb-stepper");
221
- this.step = this._getStep();
208
+ this._assignStep();
222
209
  this.toggleAttribute("data-disabled", this.hasAttribute("disabled"));
223
210
  }
224
211
  /**
@@ -245,11 +232,21 @@ let SbbStepLabelElement = (() => {
245
232
  */
246
233
  configure(posInSet, setSize, stepperLoaded) {
247
234
  if (stepperLoaded) {
248
- this.step = this._getStep();
235
+ this._assignStep();
249
236
  }
250
237
  this.internals.ariaPosInSet = `${posInSet}`;
251
238
  this.internals.ariaSetSize = `${setSize}`;
252
239
  }
240
+ _assignStep() {
241
+ let nextSibling = this.nextElementSibling;
242
+ while (nextSibling && nextSibling.localName !== "sbb-step") {
243
+ nextSibling = nextSibling.nextElementSibling;
244
+ }
245
+ const value = nextSibling;
246
+ this.internals.ariaControlsElements = removeAriaElements(this.internals.ariaControlsElements, this._step);
247
+ this._step = value instanceof Element ? value : null;
248
+ this.internals.ariaControlsElements = appendAriaElements(this.internals.ariaControlsElements, this._step);
249
+ }
253
250
  render() {
254
251
  return html`
255
252
  <div class="sbb-step-label">
@@ -269,4 +266,4 @@ let SbbStepLabelElement = (() => {
269
266
  export {
270
267
  SbbStepLabelElement
271
268
  };
272
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RlcC1sYWJlbC5jb21wb25lbnQuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9lbGVtZW50cy9zdGVwcGVyL3N0ZXAtbGFiZWwvc3RlcC1sYWJlbC5jb21wb25lbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdHlwZSBDU1NSZXN1bHRHcm91cCwgaHRtbCwgdHlwZSBUZW1wbGF0ZVJlc3VsdCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgeyBTYmJCdXR0b25CYXNlRWxlbWVudCB9IGZyb20gJy4uLy4uL2NvcmUvYmFzZS1lbGVtZW50cy5qcyc7XG5pbXBvcnQgeyBhcHBlbmRBcmlhRWxlbWVudHMsIHJlbW92ZUFyaWFFbGVtZW50cywgU2JiRGlzYWJsZWRNaXhpbiB9IGZyb20gJy4uLy4uL2NvcmUvbWl4aW5zLmpzJztcbmltcG9ydCB7IFNiYkljb25OYW1lTWl4aW4gfSBmcm9tICcuLi8uLi9pY29uLmpzJztcbmltcG9ydCB0eXBlIHsgU2JiU3RlcEVsZW1lbnQgfSBmcm9tICcuLi9zdGVwLmpzJztcbmltcG9ydCB0eXBlIHsgU2JiU3RlcHBlckVsZW1lbnQgfSBmcm9tICcuLi9zdGVwcGVyLmpzJztcblxuaW1wb3J0IHN0eWxlIGZyb20gJy4vc3RlcC1sYWJlbC5zY3NzP2xpdCZpbmxpbmUnO1xuXG5sZXQgbmV4dElkID0gMDtcblxuLyoqXG4gKiBDb21iaW5lZCB3aXRoIGEgYHNiYi1zdGVwcGVyYCwgaXQgZGlzcGxheXMgYSBzdGVwJ3MgbGFiZWwuXG4gKlxuICogQHNsb3QgLSBVc2UgdGhlIHVubmFtZWQgc2xvdCB0byBwcm92aWRlIGEgbGFiZWwuXG4gKiBAc2xvdCBpY29uIC0gVXNlIHRoaXMgdG8gZGlzcGxheSBhbiBpY29uIGluIHRoZSBsYWJlbCBidWJibGUuXG4gKiBAb3ZlcnJpZGVUeXBlIHZhbHVlIC0gc3RyaW5nXG4gKi9cbmV4cG9ydFxuQGN1c3RvbUVsZW1lbnQoJ3NiYi1zdGVwLWxhYmVsJylcbmNsYXNzIFNiYlN0ZXBMYWJlbEVsZW1lbnQgZXh0ZW5kcyBTYmJJY29uTmFtZU1peGluKFNiYkRpc2FibGVkTWl4aW4oU2JiQnV0dG9uQmFzZUVsZW1lbnQpKSB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgcmVhZG9ubHkgcm9sZSA9ICd0YWInO1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHN0eWxlczogQ1NTUmVzdWx0R3JvdXAgPSBzdHlsZTtcblxuICAvKiogVGhlIHN0ZXAgY29udHJvbGxlZCBieSB0aGUgbGFiZWwuICovXG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgcHJpdmF0ZSBzZXQgc3RlcCh2YWx1ZTogU2JiU3RlcEVsZW1lbnQgfCBudWxsKSB7XG4gICAgdGhpcy5pbnRlcm5hbHMuYXJpYUNvbnRyb2xzRWxlbWVudHMgPSByZW1vdmVBcmlhRWxlbWVudHMoXG4gICAgICB0aGlzLmludGVybmFscy5hcmlhQ29udHJvbHNFbGVtZW50cyxcbiAgICAgIHRoaXMuX3N0ZXAsXG4gICAgKTtcbiAgICB0aGlzLl9zdGVwID0gdmFsdWUgaW5zdGFuY2VvZiBFbGVtZW50ID8gdmFsdWUgOiBudWxsO1xuICAgIHRoaXMuaW50ZXJuYWxzLmFyaWFDb250cm9sc0VsZW1lbnRzID0gYXBwZW5kQXJpYUVsZW1lbnRzKFxuICAgICAgdGhpcy5pbnRlcm5hbHMuYXJpYUNvbnRyb2xzRWxlbWVudHMsXG4gICAgICB0aGlzLl9zdGVwLFxuICAgICk7XG4gIH1cbiAgcHVibGljIGdldCBzdGVwKCk6IFNiYlN0ZXBFbGVtZW50IHwgbnVsbCB7XG4gICAgcmV0dXJuIHRoaXMuX3N0ZXA7XG4gIH1cbiAgcHJpdmF0ZSBfc3RlcDogU2JiU3RlcEVsZW1lbnQgfCBudWxsID0gbnVsbDtcblxuICBwcml2YXRlIF9zdGVwcGVyOiBTYmJTdGVwcGVyRWxlbWVudCB8IG51bGwgPSBudWxsO1xuXG4gIHB1YmxpYyBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcigpO1xuICAgIHRoaXMuYWRkRXZlbnRMaXN0ZW5lcj8uKCdjbGljaycsICgpID0+IHtcbiAgICAgIGlmICh0aGlzLl9zdGVwcGVyICYmIHRoaXMuc3RlcCkge1xuICAgICAgICB0aGlzLl9zdGVwcGVyLnNlbGVjdGVkID0gdGhpcy5zdGVwO1xuICAgICAgfVxuICAgIH0pO1xuICB9XG5cbiAgcHJpdmF0ZSBfZ2V0U3RlcCgpOiBTYmJTdGVwRWxlbWVudCB8IG51bGwge1xuICAgIGxldCBuZXh0U2libGluZyA9IHRoaXMubmV4dEVsZW1lbnRTaWJsaW5nO1xuICAgIHdoaWxlIChuZXh0U2libGluZyAmJiBuZXh0U2libGluZy5sb2NhbE5hbWUgIT09ICdzYmItc3RlcCcpIHtcbiAgICAgIG5leHRTaWJsaW5nID0gbmV4dFNpYmxpbmcubmV4dEVsZW1lbnRTaWJsaW5nO1xuICAgIH1cbiAgICByZXR1cm4gbmV4dFNpYmxpbmcgYXMgU2JiU3RlcEVsZW1lbnQ7XG4gIH1cblxuICBwdWJsaWMgb3ZlcnJpZGUgY29ubmVjdGVkQ2FsbGJhY2soKTogdm9pZCB7XG4gICAgc3VwZXIuY29ubmVjdGVkQ2FsbGJhY2soKTtcbiAgICB0aGlzLmlkIHx8PSBgc2JiLXN0ZXAtbGFiZWwtJHtuZXh0SWQrK31gO1xuICAgIHRoaXMuc2xvdCB8fD0gJ3N0ZXAtbGFiZWwnO1xuICAgIHRoaXMuaW50ZXJuYWxzLmFyaWFTZWxlY3RlZCA9ICdmYWxzZSc7XG4gICAgdGhpcy50YWJJbmRleCA9IC0xO1xuICAgIHRoaXMuX3N0ZXBwZXIgPSB0aGlzLmNsb3Nlc3QoJ3NiYi1zdGVwcGVyJyk7XG4gICAgdGhpcy5zdGVwID0gdGhpcy5fZ2V0U3RlcCgpO1xuICAgIC8vIFRoZSBgZGF0YS1kaXNhYmxlZGAgYXR0cmlidXRlIGlzIHVzZWQgdG8gcHJlc2VydmUgdGhlIGluaXRpYWwgZGlzYWJsZWQgc3RhdGUgb2ZcbiAgICAvLyBzdGVwIGxhYmVscyBpbiBjYXNlIG9mIHN3aXRjaGluZyBmcm9tIGxpbmVhciB0byBub24tbGluZWFyIG1vZGUuXG4gICAgdGhpcy50b2dnbGVBdHRyaWJ1dGUoJ2RhdGEtZGlzYWJsZWQnLCB0aGlzLmhhc0F0dHJpYnV0ZSgnZGlzYWJsZWQnKSk7XG4gIH1cblxuICAvKipcbiAgICogU2VsZWN0cyBhbmQgY29uZmlndXJlcyB0aGUgc3RlcCBsYWJlbC5cbiAgICogQGludGVybmFsXG4gICAqL1xuICBwdWJsaWMgc2VsZWN0KCk6IHZvaWQge1xuICAgIHRoaXMudGFiSW5kZXggPSAwO1xuICAgIHRoaXMuaW50ZXJuYWxzLmFyaWFTZWxlY3RlZCA9ICd0cnVlJztcbiAgICB0aGlzLnRvZ2dsZUF0dHJpYnV0ZSgnZGF0YS1zZWxlY3RlZCcsIHRydWUpO1xuICB9XG5cbiAgLyoqXG4gICAqIERlc2VsZWN0cyBhbmQgY29uZmlndXJlcyB0aGUgc3RlcCBsYWJlbC5cbiAgICogQGludGVybmFsXG4gICAqL1xuICBwdWJsaWMgZGVzZWxlY3QoKTogdm9pZCB7XG4gICAgdGhpcy50YWJJbmRleCA9IC0xO1xuICAgIHRoaXMuaW50ZXJuYWxzLmFyaWFTZWxlY3RlZCA9ICdmYWxzZSc7XG4gICAgdGhpcy50b2dnbGVBdHRyaWJ1dGUoJ2RhdGEtc2VsZWN0ZWQnLCBmYWxzZSk7XG4gIH1cblxuICAvKipcbiAgICogQ29uZmlndXJlcyB0aGUgc3RlcCBsYWJlbC5cbiAgICogQGludGVybmFsXG4gICAqL1xuICBwdWJsaWMgY29uZmlndXJlKHBvc0luU2V0OiBudW1iZXIsIHNldFNpemU6IG51bWJlciwgc3RlcHBlckxvYWRlZDogYm9vbGVhbik6IHZvaWQge1xuICAgIGlmIChzdGVwcGVyTG9hZGVkKSB7XG4gICAgICB0aGlzLnN0ZXAgPSB0aGlzLl9nZXRTdGVwKCk7XG4gICAgfVxuICAgIHRoaXMuaW50ZXJuYWxzLmFyaWFQb3NJblNldCA9IGAke3Bvc0luU2V0fWA7XG4gICAgdGhpcy5pbnRlcm5hbHMuYXJpYVNldFNpemUgPSBgJHtzZXRTaXplfWA7XG4gIH1cblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGBcbiAgICAgIDxkaXYgY2xhc3M9XCJzYmItc3RlcC1sYWJlbFwiPlxuICAgICAgICA8c3BhbiBjbGFzcz1cInNiYi1zdGVwLWxhYmVsX19wcmVmaXhcIj4ke3RoaXMucmVuZGVySWNvblNsb3QoKX08L3NwYW4+XG4gICAgICAgIDxzcGFuIGNsYXNzPVwic2JiLXN0ZXAtbGFiZWxfX3RleHRcIj48c2xvdD48L3Nsb3Q+PC9zcGFuPlxuICAgICAgPC9kaXY+XG4gICAgYDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLXN0ZXAtbGFiZWwnOiBTYmJTdGVwTGFiZWxFbGVtZW50O1xuICB9XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBV0EsSUFBSSxTQUFTO0lBV1AsdUJBQW1CLE1BQUE7OzBCQUR4QixjQUFjLGdCQUFnQixDQUFDOzs7O0FBQ0UsTUFBQSxjQUFBLGlCQUFpQixpQkFBaUIsb0JBQW9CLENBQUM7QUFBL0QsRUFBQSxtQkFBUSxZQUF3RDtBQUFBO0FBQUE7QUFBQSxJQU14RixJQUFZLEtBQUssT0FBNEI7QUFDM0MsV0FBSyxVQUFVLHVCQUF1QixtQkFDcEMsS0FBSyxVQUFVLHNCQUNmLEtBQUssS0FBSztBQUVaLFdBQUssUUFBUSxpQkFBaUIsVUFBVSxRQUFRO0FBQ2hELFdBQUssVUFBVSx1QkFBdUIsbUJBQ3BDLEtBQUssVUFBVSxzQkFDZixLQUFLLEtBQUs7QUFBQSxJQUFBO0FBQUEsSUFHZCxJQUFXLE9BQUk7QUFDYixhQUFPLEtBQUs7QUFBQSxJQUFBO0FBQUEsSUFNZCxjQUFBO0FBQ0UsWUFBQTtBQUxNLFdBQUEsUUFBK0I7QUFFL0IsV0FBQSxXQUFxQztBQUkzQyxXQUFLLG1CQUFtQixTQUFTLE1BQUs7QUFDcEMsWUFBSSxLQUFLLFlBQVksS0FBSyxNQUFNO0FBQzlCLGVBQUssU0FBUyxXQUFXLEtBQUs7QUFBQSxRQUFBO0FBQUEsTUFDaEMsQ0FDRDtBQUFBLElBQUE7QUFBQSxJQUdLLFdBQVE7QUFDZCxVQUFJLGNBQWMsS0FBSztBQUN2QixhQUFPLGVBQWUsWUFBWSxjQUFjLFlBQVk7QUFDMUQsc0JBQWMsWUFBWTtBQUFBLE1BQUE7QUFFNUIsYUFBTztBQUFBLElBQUE7QUFBQSxJQUdPLG9CQUFpQjtBQUMvQixZQUFNLGtCQUFBO0FBQ04sV0FBSyxPQUFPLGtCQUFrQixRQUFRO0FBQ3RDLFdBQUssU0FBUztBQUNkLFdBQUssVUFBVSxlQUFlO0FBQzlCLFdBQUssV0FBVztBQUNoQixXQUFLLFdBQVcsS0FBSyxRQUFRLGFBQWE7QUFDMUMsV0FBSyxPQUFPLEtBQUssU0FBQTtBQUdqQixXQUFLLGdCQUFnQixpQkFBaUIsS0FBSyxhQUFhLFVBQVUsQ0FBQztBQUFBLElBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLElBTzlELFNBQU07QUFDWCxXQUFLLFdBQVc7QUFDaEIsV0FBSyxVQUFVLGVBQWU7QUFDOUIsV0FBSyxnQkFBZ0IsaUJBQWlCLElBQUk7QUFBQSxJQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxJQU9yQyxXQUFRO0FBQ2IsV0FBSyxXQUFXO0FBQ2hCLFdBQUssVUFBVSxlQUFlO0FBQzlCLFdBQUssZ0JBQWdCLGlCQUFpQixLQUFLO0FBQUEsSUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsSUFPdEMsVUFBVSxVQUFrQixTQUFpQixlQUFzQjtBQUN4RSxVQUFJLGVBQWU7QUFDakIsYUFBSyxPQUFPLEtBQUssU0FBQTtBQUFBO0FBRW5CLFdBQUssVUFBVSxlQUFlLEdBQUcsUUFBUTtBQUN6QyxXQUFLLFVBQVUsY0FBYyxHQUFHLE9BQU87QUFBQSxJQUFBO0FBQUEsSUFHdEIsU0FBTTtBQUN2QixhQUFPO0FBQUE7QUFBQSwrQ0FFb0MsS0FBSyxnQkFBZ0I7QUFBQTtBQUFBO0FBQUE7QUFBQSxJQUFBO0FBQUE7O0FBekZwRSxpQkFBQSxNQUFBLG1CQUFBLEVBQUEsT0FBQSxXQUFBLEdBQUEsa0JBQUEsRUFBQSxNQUFBLFNBQUEsTUFBQSxXQUFBLE1BQUEsVUFBQSxVQUFBLEdBQUEsTUFBQSx1QkFBQTs7O1FBQ2tDLEdBQUEsT0FBTyxPQUNoQixHQUFBLFNBQXlCLE9BRjVDLGtCQUFBLFlBQUEsdUJBQUEsR0FBb0I7OzsifQ==
269
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RlcC1sYWJlbC5jb21wb25lbnQuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9lbGVtZW50cy9zdGVwcGVyL3N0ZXAtbGFiZWwvc3RlcC1sYWJlbC5jb21wb25lbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdHlwZSBDU1NSZXN1bHRHcm91cCwgaHRtbCwgdHlwZSBUZW1wbGF0ZVJlc3VsdCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgeyBTYmJCdXR0b25CYXNlRWxlbWVudCB9IGZyb20gJy4uLy4uL2NvcmUvYmFzZS1lbGVtZW50cy5qcyc7XG5pbXBvcnQgeyBhcHBlbmRBcmlhRWxlbWVudHMsIHJlbW92ZUFyaWFFbGVtZW50cywgU2JiRGlzYWJsZWRNaXhpbiB9IGZyb20gJy4uLy4uL2NvcmUvbWl4aW5zLmpzJztcbmltcG9ydCB7IFNiYkljb25OYW1lTWl4aW4gfSBmcm9tICcuLi8uLi9pY29uLmpzJztcbmltcG9ydCB0eXBlIHsgU2JiU3RlcEVsZW1lbnQgfSBmcm9tICcuLi9zdGVwLmpzJztcbmltcG9ydCB0eXBlIHsgU2JiU3RlcHBlckVsZW1lbnQgfSBmcm9tICcuLi9zdGVwcGVyLmpzJztcblxuaW1wb3J0IHN0eWxlIGZyb20gJy4vc3RlcC1sYWJlbC5zY3NzP2xpdCZpbmxpbmUnO1xuXG5sZXQgbmV4dElkID0gMDtcblxuLyoqXG4gKiBDb21iaW5lZCB3aXRoIGEgYHNiYi1zdGVwcGVyYCwgaXQgZGlzcGxheXMgYSBzdGVwJ3MgbGFiZWwuXG4gKlxuICogQHNsb3QgLSBVc2UgdGhlIHVubmFtZWQgc2xvdCB0byBwcm92aWRlIGEgbGFiZWwuXG4gKiBAc2xvdCBpY29uIC0gVXNlIHRoaXMgdG8gZGlzcGxheSBhbiBpY29uIGluIHRoZSBsYWJlbCBidWJibGUuXG4gKiBAb3ZlcnJpZGVUeXBlIHZhbHVlIC0gc3RyaW5nXG4gKi9cbmV4cG9ydFxuQGN1c3RvbUVsZW1lbnQoJ3NiYi1zdGVwLWxhYmVsJylcbmNsYXNzIFNiYlN0ZXBMYWJlbEVsZW1lbnQgZXh0ZW5kcyBTYmJJY29uTmFtZU1peGluKFNiYkRpc2FibGVkTWl4aW4oU2JiQnV0dG9uQmFzZUVsZW1lbnQpKSB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgcmVhZG9ubHkgcm9sZSA9ICd0YWInO1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHN0eWxlczogQ1NTUmVzdWx0R3JvdXAgPSBzdHlsZTtcblxuICAvKiogVGhlIHN0ZXAgY29udHJvbGxlZCBieSB0aGUgbGFiZWwuICovXG4gIHB1YmxpYyBnZXQgc3RlcCgpOiBTYmJTdGVwRWxlbWVudCB8IG51bGwge1xuICAgIHJldHVybiB0aGlzLl9zdGVwO1xuICB9XG4gIHByaXZhdGUgX3N0ZXA6IFNiYlN0ZXBFbGVtZW50IHwgbnVsbCA9IG51bGw7XG5cbiAgcHJpdmF0ZSBfc3RlcHBlcjogU2JiU3RlcHBlckVsZW1lbnQgfCBudWxsID0gbnVsbDtcblxuICBwdWJsaWMgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoKTtcbiAgICB0aGlzLmFkZEV2ZW50TGlzdGVuZXI/LignY2xpY2snLCAoKSA9PiB7XG4gICAgICBpZiAodGhpcy5fc3RlcHBlciAmJiB0aGlzLnN0ZXApIHtcbiAgICAgICAgdGhpcy5fc3RlcHBlci5zZWxlY3RlZCA9IHRoaXMuc3RlcDtcbiAgICAgIH1cbiAgICB9KTtcbiAgfVxuXG4gIHB1YmxpYyBvdmVycmlkZSBjb25uZWN0ZWRDYWxsYmFjaygpOiB2b2lkIHtcbiAgICBzdXBlci5jb25uZWN0ZWRDYWxsYmFjaygpO1xuICAgIHRoaXMuaWQgfHw9IGBzYmItc3RlcC1sYWJlbC0ke25leHRJZCsrfWA7XG4gICAgdGhpcy5zbG90IHx8PSAnc3RlcC1sYWJlbCc7XG4gICAgdGhpcy5pbnRlcm5hbHMuYXJpYVNlbGVjdGVkID0gJ2ZhbHNlJztcbiAgICB0aGlzLnRhYkluZGV4ID0gLTE7XG4gICAgdGhpcy5fc3RlcHBlciA9IHRoaXMuY2xvc2VzdCgnc2JiLXN0ZXBwZXInKTtcbiAgICB0aGlzLl9hc3NpZ25TdGVwKCk7XG4gICAgLy8gVGhlIGBkYXRhLWRpc2FibGVkYCBhdHRyaWJ1dGUgaXMgdXNlZCB0byBwcmVzZXJ2ZSB0aGUgaW5pdGlhbCBkaXNhYmxlZCBzdGF0ZSBvZlxuICAgIC8vIHN0ZXAgbGFiZWxzIGluIGNhc2Ugb2Ygc3dpdGNoaW5nIGZyb20gbGluZWFyIHRvIG5vbi1saW5lYXIgbW9kZS5cbiAgICB0aGlzLnRvZ2dsZUF0dHJpYnV0ZSgnZGF0YS1kaXNhYmxlZCcsIHRoaXMuaGFzQXR0cmlidXRlKCdkaXNhYmxlZCcpKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBTZWxlY3RzIGFuZCBjb25maWd1cmVzIHRoZSBzdGVwIGxhYmVsLlxuICAgKiBAaW50ZXJuYWxcbiAgICovXG4gIHB1YmxpYyBzZWxlY3QoKTogdm9pZCB7XG4gICAgdGhpcy50YWJJbmRleCA9IDA7XG4gICAgdGhpcy5pbnRlcm5hbHMuYXJpYVNlbGVjdGVkID0gJ3RydWUnO1xuICAgIHRoaXMudG9nZ2xlQXR0cmlidXRlKCdkYXRhLXNlbGVjdGVkJywgdHJ1ZSk7XG4gIH1cblxuICAvKipcbiAgICogRGVzZWxlY3RzIGFuZCBjb25maWd1cmVzIHRoZSBzdGVwIGxhYmVsLlxuICAgKiBAaW50ZXJuYWxcbiAgICovXG4gIHB1YmxpYyBkZXNlbGVjdCgpOiB2b2lkIHtcbiAgICB0aGlzLnRhYkluZGV4ID0gLTE7XG4gICAgdGhpcy5pbnRlcm5hbHMuYXJpYVNlbGVjdGVkID0gJ2ZhbHNlJztcbiAgICB0aGlzLnRvZ2dsZUF0dHJpYnV0ZSgnZGF0YS1zZWxlY3RlZCcsIGZhbHNlKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBDb25maWd1cmVzIHRoZSBzdGVwIGxhYmVsLlxuICAgKiBAaW50ZXJuYWxcbiAgICovXG4gIHB1YmxpYyBjb25maWd1cmUocG9zSW5TZXQ6IG51bWJlciwgc2V0U2l6ZTogbnVtYmVyLCBzdGVwcGVyTG9hZGVkOiBib29sZWFuKTogdm9pZCB7XG4gICAgaWYgKHN0ZXBwZXJMb2FkZWQpIHtcbiAgICAgIHRoaXMuX2Fzc2lnblN0ZXAoKTtcbiAgICB9XG4gICAgdGhpcy5pbnRlcm5hbHMuYXJpYVBvc0luU2V0ID0gYCR7cG9zSW5TZXR9YDtcbiAgICB0aGlzLmludGVybmFscy5hcmlhU2V0U2l6ZSA9IGAke3NldFNpemV9YDtcbiAgfVxuXG4gIHByaXZhdGUgX2Fzc2lnblN0ZXAoKTogdm9pZCB7XG4gICAgbGV0IG5leHRTaWJsaW5nID0gdGhpcy5uZXh0RWxlbWVudFNpYmxpbmc7XG4gICAgd2hpbGUgKG5leHRTaWJsaW5nICYmIG5leHRTaWJsaW5nLmxvY2FsTmFtZSAhPT0gJ3NiYi1zdGVwJykge1xuICAgICAgbmV4dFNpYmxpbmcgPSBuZXh0U2libGluZy5uZXh0RWxlbWVudFNpYmxpbmc7XG4gICAgfVxuXG4gICAgY29uc3QgdmFsdWUgPSBuZXh0U2libGluZyBhcyBTYmJTdGVwRWxlbWVudCB8IG51bGw7XG4gICAgdGhpcy5pbnRlcm5hbHMuYXJpYUNvbnRyb2xzRWxlbWVudHMgPSByZW1vdmVBcmlhRWxlbWVudHMoXG4gICAgICB0aGlzLmludGVybmFscy5hcmlhQ29udHJvbHNFbGVtZW50cyxcbiAgICAgIHRoaXMuX3N0ZXAsXG4gICAgKTtcbiAgICB0aGlzLl9zdGVwID0gdmFsdWUgaW5zdGFuY2VvZiBFbGVtZW50ID8gdmFsdWUgOiBudWxsO1xuICAgIHRoaXMuaW50ZXJuYWxzLmFyaWFDb250cm9sc0VsZW1lbnRzID0gYXBwZW5kQXJpYUVsZW1lbnRzKFxuICAgICAgdGhpcy5pbnRlcm5hbHMuYXJpYUNvbnRyb2xzRWxlbWVudHMsXG4gICAgICB0aGlzLl9zdGVwLFxuICAgICk7XG4gIH1cblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGBcbiAgICAgIDxkaXYgY2xhc3M9XCJzYmItc3RlcC1sYWJlbFwiPlxuICAgICAgICA8c3BhbiBjbGFzcz1cInNiYi1zdGVwLWxhYmVsX19wcmVmaXhcIj4ke3RoaXMucmVuZGVySWNvblNsb3QoKX08L3NwYW4+XG4gICAgICAgIDxzcGFuIGNsYXNzPVwic2JiLXN0ZXAtbGFiZWxfX3RleHRcIj48c2xvdD48L3Nsb3Q+PC9zcGFuPlxuICAgICAgPC9kaXY+XG4gICAgYDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLXN0ZXAtbGFiZWwnOiBTYmJTdGVwTGFiZWxFbGVtZW50O1xuICB9XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBV0EsSUFBSSxTQUFTO0lBV1AsdUJBQW1CLE1BQUE7OzBCQUR4QixjQUFjLGdCQUFnQixDQUFDOzs7O0FBQ0UsTUFBQSxjQUFBLGlCQUFpQixpQkFBaUIsb0JBQW9CLENBQUM7QUFBL0QsRUFBQSxtQkFBUSxZQUF3RDtBQUFBO0FBQUEsSUFLeEYsSUFBVyxPQUFJO0FBQ2IsYUFBTyxLQUFLO0FBQUEsSUFBQTtBQUFBLElBTWQsY0FBQTtBQUNFLFlBQUE7QUFMTSxXQUFBLFFBQStCO0FBRS9CLFdBQUEsV0FBcUM7QUFJM0MsV0FBSyxtQkFBbUIsU0FBUyxNQUFLO0FBQ3BDLFlBQUksS0FBSyxZQUFZLEtBQUssTUFBTTtBQUM5QixlQUFLLFNBQVMsV0FBVyxLQUFLO0FBQUEsUUFBQTtBQUFBLE1BQ2hDLENBQ0Q7QUFBQSxJQUFBO0FBQUEsSUFHYSxvQkFBaUI7QUFDL0IsWUFBTSxrQkFBQTtBQUNOLFdBQUssT0FBTyxrQkFBa0IsUUFBUTtBQUN0QyxXQUFLLFNBQVM7QUFDZCxXQUFLLFVBQVUsZUFBZTtBQUM5QixXQUFLLFdBQVc7QUFDaEIsV0FBSyxXQUFXLEtBQUssUUFBUSxhQUFhO0FBQzFDLFdBQUssWUFBQTtBQUdMLFdBQUssZ0JBQWdCLGlCQUFpQixLQUFLLGFBQWEsVUFBVSxDQUFDO0FBQUEsSUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsSUFPOUQsU0FBTTtBQUNYLFdBQUssV0FBVztBQUNoQixXQUFLLFVBQVUsZUFBZTtBQUM5QixXQUFLLGdCQUFnQixpQkFBaUIsSUFBSTtBQUFBLElBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLElBT3JDLFdBQVE7QUFDYixXQUFLLFdBQVc7QUFDaEIsV0FBSyxVQUFVLGVBQWU7QUFDOUIsV0FBSyxnQkFBZ0IsaUJBQWlCLEtBQUs7QUFBQSxJQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxJQU90QyxVQUFVLFVBQWtCLFNBQWlCLGVBQXNCO0FBQ3hFLFVBQUksZUFBZTtBQUNqQixhQUFLLFlBQUE7QUFBQSxNQUFXO0FBRWxCLFdBQUssVUFBVSxlQUFlLEdBQUcsUUFBUTtBQUN6QyxXQUFLLFVBQVUsY0FBYyxHQUFHLE9BQU87QUFBQSxJQUFBO0FBQUEsSUFHakMsY0FBVztBQUNqQixVQUFJLGNBQWMsS0FBSztBQUN2QixhQUFPLGVBQWUsWUFBWSxjQUFjLFlBQVk7QUFDMUQsc0JBQWMsWUFBWTtBQUFBLE1BQUE7QUFHNUIsWUFBTSxRQUFRO0FBQ2QsV0FBSyxVQUFVLHVCQUF1QixtQkFDcEMsS0FBSyxVQUFVLHNCQUNmLEtBQUssS0FBSztBQUVaLFdBQUssUUFBUSxpQkFBaUIsVUFBVSxRQUFRO0FBQ2hELFdBQUssVUFBVSx1QkFBdUIsbUJBQ3BDLEtBQUssVUFBVSxzQkFDZixLQUFLLEtBQUs7QUFBQSxJQUFBO0FBQUEsSUFJSyxTQUFNO0FBQ3ZCLGFBQU87QUFBQTtBQUFBLCtDQUVvQyxLQUFLLGdCQUFnQjtBQUFBO0FBQUE7QUFBQTtBQUFBLElBQUE7QUFBQTs7QUF2RnBFLGlCQUFBLE1BQUEsbUJBQUEsRUFBQSxPQUFBLFdBQUEsR0FBQSxrQkFBQSxFQUFBLE1BQUEsU0FBQSxNQUFBLFdBQUEsTUFBQSxVQUFBLFVBQUEsR0FBQSxNQUFBLHVCQUFBOzs7UUFDa0MsR0FBQSxPQUFPLE9BQ2hCLEdBQUEsU0FBeUIsT0FGNUMsa0JBQUEsWUFBQSx1QkFBQSxHQUFvQjs7OyJ9
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements",
3
- "version": "3.0.0-next.2",
3
+ "version": "3.0.0-next.3",
4
4
  "description": "Lyne Design System",
5
5
  "keywords": [
6
6
  "design system",
@@ -30,7 +30,6 @@ export declare class SbbStepElement extends SbbStepElement_base {
30
30
  private _stepper;
31
31
  private _stepResizeObserver;
32
32
  /** The label of the step. */
33
- private set label(value);
34
33
  get label(): SbbStepLabelElement | null;
35
34
  private _label;
36
35
  constructor();
@@ -59,9 +58,9 @@ export declare class SbbStepElement extends SbbStepElement_base {
59
58
  private _isGoNextElement;
60
59
  private _isGoPreviousElement;
61
60
  private _onStepElementResize;
62
- private _getStepLabel;
63
61
  connectedCallback(): void;
64
62
  protected firstUpdated(changedProperties: PropertyValues<this>): void;
63
+ private _assignLabel;
65
64
  protected render(): TemplateResult;
66
65
  }
67
66
  declare global {
@@ -1 +1 @@
1
- {"version":3,"file":"step.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/stepper/step/step.component.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,cAAc,EAEnB,UAAU,EACV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AASb,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAO5D,MAAM,MAAM,2BAA2B,GAAG;IACxC,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,WAAW,EAAE,cAAc,GAAG,IAAI,CAAC;IACnC,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,QAAQ,EAAE,cAAc,GAAG,IAAI,CAAC;CACjC,CAAC;;AAEF;;;;;GAKG;AACH,qBAEM,cAAe,SAAQ,mBAAoC;IAC/D,gBAAgC,IAAI,cAAc;IAClD,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;;MAGlB;IAEX,+CAA+C;IAC/C,OAAO,CAAC,SAAS,CAGf;IAEF;;;OAGG;IACH,OAAO,CAAC,aAAa,CAInB;IAEF,OAAO,CAAC,QAAQ,CAAkC;IAMlD,OAAO,CAAC,mBAAmB,CAIxB;IAEH,6BAA6B;IAE7B,OAAO,KAAK,KAAK,QAUhB;IACD,IAAW,KAAK,IAAI,mBAAmB,GAAG,IAAI,CAE7C;IACD,OAAO,CAAC,MAAM,CAAoC;;IAOlD;;;OAGG;IACI,MAAM,IAAI,IAAI;IAQrB;;;OAGG;IACI,QAAQ,IAAI,IAAI;IAQvB;;;OAGG;IACI,QAAQ,CAAC,SAAS,EAAE,2BAA2B,GAAG,OAAO;IAIhE;;;OAGG;IACI,SAAS,CAAC,aAAa,EAAE,OAAO,GAAG,IAAI;IAM9C,iGAAiG;IACjG,OAAO,CAAC,YAAY;IAWpB,OAAO,CAAC,gBAAgB;IAIxB,OAAO,CAAC,oBAAoB;IAI5B,OAAO,CAAC,oBAAoB;IAO5B,OAAO,CAAC,aAAa;IAQL,iBAAiB,IAAI,IAAI;cAQtB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAO3D,MAAM,IAAI,cAAc;CAS5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,UAAU,EAAE,cAAc,CAAC;KAC5B;CACF;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,2BAA2B;QACnC,YAAY,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC;KACjC;CACF"}
1
+ {"version":3,"file":"step.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/stepper/step/step.component.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,cAAc,EAEnB,UAAU,EACV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AASb,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAO5D,MAAM,MAAM,2BAA2B,GAAG;IACxC,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,WAAW,EAAE,cAAc,GAAG,IAAI,CAAC;IACnC,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,QAAQ,EAAE,cAAc,GAAG,IAAI,CAAC;CACjC,CAAC;;AAEF;;;;;GAKG;AACH,qBAEM,cAAe,SAAQ,mBAAoC;IAC/D,gBAAgC,IAAI,cAAc;IAClD,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;;MAGlB;IAEX,+CAA+C;IAC/C,OAAO,CAAC,SAAS,CAGf;IAEF;;;OAGG;IACH,OAAO,CAAC,aAAa,CAInB;IAEF,OAAO,CAAC,QAAQ,CAAkC;IAMlD,OAAO,CAAC,mBAAmB,CAIxB;IAEH,6BAA6B;IAC7B,IAAW,KAAK,IAAI,mBAAmB,GAAG,IAAI,CAE7C;IACD,OAAO,CAAC,MAAM,CAAoC;;IAOlD;;;OAGG;IACI,MAAM,IAAI,IAAI;IAQrB;;;OAGG;IACI,QAAQ,IAAI,IAAI;IAQvB;;;OAGG;IACI,QAAQ,CAAC,SAAS,EAAE,2BAA2B,GAAG,OAAO;IAIhE;;;OAGG;IACI,SAAS,CAAC,aAAa,EAAE,OAAO,GAAG,IAAI;IAM9C,iGAAiG;IACjG,OAAO,CAAC,YAAY;IAWpB,OAAO,CAAC,gBAAgB;IAIxB,OAAO,CAAC,oBAAoB;IAI5B,OAAO,CAAC,oBAAoB;IAOZ,iBAAiB,IAAI,IAAI;cAQtB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAO9E,OAAO,CAAC,YAAY;cAkBD,MAAM,IAAI,cAAc;CAS5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,UAAU,EAAE,cAAc,CAAC;KAC5B;CACF;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,2BAA2B;QACnC,YAAY,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC;KACjC;CACF"}
@@ -1,24 +1,20 @@
1
- import { __esDecorate as h, __runInitializers as d } from "tslib";
1
+ import { __esDecorate as d, __runInitializers as h } from "tslib";
2
2
  import { ResizeController as c } from "@lit-labs/observers/resize-controller.js";
3
3
  import { css as m, LitElement as u, html as v } from "lit";
4
4
  import { customElement as g } from "lit/decorators.js";
5
- import { EventEmitter as o } from "../../core/eventing.js";
5
+ import { EventEmitter as l } from "../../core/eventing.js";
6
6
  import { SbbElementInternalsMixin as y, removeAriaElements as f, appendAriaElements as _ } from "../../core/mixins.js";
7
7
  const E = m`*,:before,:after{box-sizing:border-box}:host{--sbb-step-position: initial;--sbb-step-inset-block-start: unset;--sbb-step-opacity: 0;--sbb-step-display: none;--sbb-step-height: 0;--sbb-step-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-2x) );--sbb-step-animation-delay: 0;--sbb-step-color: var(--sbb-color-iron);display:contents}:host([data-selected]){--sbb-step-opacity: 1;--sbb-step-display: block;--sbb-step-height: fit-content;--sbb-step-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-4x) );--sbb-step-animation-delay: var(--sbb-step-animation-duration)}:host([data-orientation=horizontal]){--sbb-step-position: absolute;--sbb-step-inset-block-start: 0}:host([data-orientation=vertical]) .sbb-step--wrapper{margin-inline-start:var(--sbb-spacing-fixed-4x);opacity:0;height:0;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);transition-behavior:allow-discrete}:host([data-selected][data-orientation=vertical]) .sbb-step--wrapper{opacity:1;height:var(--sbb-stepper-content-height);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);transition-behavior:allow-discrete}.sbb-step{--sbb-text-font-size: var(--sbb-font-size-text-m);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-text);font-size:var(--sbb-text-font-size);position:var(--sbb-step-position);width:100%;inset-block-start:var(--sbb-step-inset-block-start);opacity:var(--sbb-step-opacity);display:var(--sbb-step-display);height:var(--sbb-step-height);color:var(--sbb-step-color);transition-property:display,opacity;transition-duration:var(--sbb-step-animation-duration);transition-delay:var(--sbb-step-animation-delay);transition-timing-function:var(--sbb-animation-easing);transition-behavior:allow-discrete}@starting-style{.sbb-step{--sbb-step-opacity: 0}}`;
8
8
  let x = 0, A = (() => {
9
9
  var e;
10
- let p = [g("sbb-step")], n, r = [], s, b = y(u);
11
- var a = (e = class extends b {
10
+ let p = [g("sbb-step")], r, b = [], s, o = y(u);
11
+ var n = (e = class extends o {
12
12
  /** The label of the step. */
13
- // eslint-disable-next-line @typescript-eslint/naming-convention
14
- set label(t) {
15
- this.internals.ariaLabelledByElements = f(this.internals.ariaLabelledByElements, this._label), this._label = t instanceof Element ? t : null, this.internals.ariaLabelledByElements = _(this.internals.ariaLabelledByElements, this._label);
16
- }
17
13
  get label() {
18
14
  return this._label;
19
15
  }
20
16
  constructor() {
21
- super(), this._validate = new o(this, a.events.validate), this._resizeChange = new o(this, a.events.resizeChange, { bubbles: !0 }), this._stepper = null, this._stepResizeObserver = new c(this, {
17
+ super(), this._validate = new l(this, n.events.validate), this._resizeChange = new l(this, n.events.resizeChange, { bubbles: !0 }), this._stepper = null, this._stepResizeObserver = new c(this, {
22
18
  target: null,
23
19
  skipInitial: !0,
24
20
  callback: () => setTimeout(() => this._onStepElementResize())
@@ -50,12 +46,12 @@ let x = 0, A = (() => {
50
46
  * @internal
51
47
  */
52
48
  configure(t) {
53
- t && (this.label = this._getStepLabel());
49
+ t && this._assignLabel();
54
50
  }
55
51
  /** Watches for clicked elements with `sbb-stepper-next` or `sbb-stepper-previous` attributes. */
56
52
  _handleClick(t) {
57
- const l = t.composedPath().filter((i) => i instanceof window.HTMLElement);
58
- l.some((i) => this._isGoNextElement(i)) ? this._stepper?.next() : l.some((i) => this._isGoPreviousElement(i)) && this._stepper?.previous();
53
+ const i = t.composedPath().filter((a) => a instanceof window.HTMLElement);
54
+ i.some((a) => this._isGoNextElement(a)) ? this._stepper?.next() : i.some((a) => this._isGoPreviousElement(a)) && this._stepper?.previous();
59
55
  }
60
56
  _isGoNextElement(t) {
61
57
  return t.hasAttribute("sbb-stepper-next") && !t.hasAttribute("disabled");
@@ -66,20 +62,21 @@ let x = 0, A = (() => {
66
62
  _onStepElementResize() {
67
63
  this.hasAttribute("data-selected") && this._resizeChange.emit();
68
64
  }
69
- _getStepLabel() {
70
- let t = this.previousElementSibling;
71
- for (; t && t.localName !== "sbb-step-label"; )
72
- t = t.previousElementSibling;
73
- return t;
74
- }
75
65
  connectedCallback() {
76
- super.connectedCallback(), this.id ||= `sbb-step-${x++}`, this.slot ||= "step", this._stepper = this.closest("sbb-stepper"), this.label = this._getStepLabel();
66
+ super.connectedCallback(), this.id ||= `sbb-step-${x++}`, this.slot ||= "step", this._stepper = this.closest("sbb-stepper"), this._assignLabel();
77
67
  }
78
68
  firstUpdated(t) {
79
69
  super.firstUpdated(t), this.updateComplete.then(() => {
80
70
  this._stepResizeObserver.observe(this.shadowRoot.querySelector(".sbb-step"));
81
71
  });
82
72
  }
73
+ _assignLabel() {
74
+ let t = this.previousElementSibling;
75
+ for (; t && t.localName !== "sbb-step-label"; )
76
+ t = t.previousElementSibling;
77
+ const i = t;
78
+ this.internals.ariaLabelledByElements = f(this.internals.ariaLabelledByElements, this._label), this._label = i instanceof Element ? i : null, this.internals.ariaLabelledByElements = _(this.internals.ariaLabelledByElements, this._label);
79
+ }
83
80
  render() {
84
81
  return v`
85
82
  <div class="sbb-step--wrapper">
@@ -90,13 +87,13 @@ let x = 0, A = (() => {
90
87
  `;
91
88
  }
92
89
  }, s = e, (() => {
93
- const t = typeof Symbol == "function" && Symbol.metadata ? Object.create(b[Symbol.metadata] ?? null) : void 0;
94
- h(null, n = { value: s }, p, { kind: "class", name: s.name, metadata: t }, null, r), a = s = n.value, t && Object.defineProperty(s, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: t });
90
+ const t = typeof Symbol == "function" && Symbol.metadata ? Object.create(o[Symbol.metadata] ?? null) : void 0;
91
+ d(null, r = { value: s }, p, { kind: "class", name: s.name, metadata: t }, null, b), n = s = r.value, t && Object.defineProperty(s, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: t });
95
92
  })(), e.role = "tabpanel", e.styles = E, e.events = {
96
93
  validate: "validate",
97
94
  resizeChange: "resizeChange"
98
- }, d(s, r), e);
99
- return a = s;
95
+ }, h(s, b), e);
96
+ return n = s;
100
97
  })();
101
98
  export {
102
99
  A as SbbStepElement
@@ -13,12 +13,10 @@ export declare class SbbStepLabelElement extends SbbStepLabelElement_base {
13
13
  static readonly role = "tab";
14
14
  static styles: CSSResultGroup;
15
15
  /** The step controlled by the label. */
16
- private set step(value);
17
16
  get step(): SbbStepElement | null;
18
17
  private _step;
19
18
  private _stepper;
20
19
  constructor();
21
- private _getStep;
22
20
  connectedCallback(): void;
23
21
  /**
24
22
  * Selects and configures the step label.
@@ -35,6 +33,7 @@ export declare class SbbStepLabelElement extends SbbStepLabelElement_base {
35
33
  * @internal
36
34
  */
37
35
  configure(posInSet: number, setSize: number, stepperLoaded: boolean): void;
36
+ private _assignStep;
38
37
  protected render(): TemplateResult;
39
38
  }
40
39
  declare global {
@@ -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;AAGrE,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAGnE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;;AAOjD;;;;;;GAMG;AACH,qBAEM,mBAAoB,SAAQ,wBAAwD;IACxF,gBAAgC,IAAI,SAAS;IAC7C,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,wCAAwC;IAExC,OAAO,KAAK,IAAI,QAUf;IACD,IAAW,IAAI,IAAI,cAAc,GAAG,IAAI,CAEvC;IACD,OAAO,CAAC,KAAK,CAA+B;IAE5C,OAAO,CAAC,QAAQ,CAAkC;;IAWlD,OAAO,CAAC,QAAQ;IAQA,iBAAiB,IAAI,IAAI;IAazC;;;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;cAQ9D,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;AAGrE,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAGnE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;;AAOjD;;;;;;GAMG;AACH,qBAEM,mBAAoB,SAAQ,wBAAwD;IACxF,gBAAgC,IAAI,SAAS;IAC7C,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,wCAAwC;IACxC,IAAW,IAAI,IAAI,cAAc,GAAG,IAAI,CAEvC;IACD,OAAO,CAAC,KAAK,CAA+B;IAE5C,OAAO,CAAC,QAAQ,CAAkC;;IAWlC,iBAAiB,IAAI,IAAI;IAazC;;;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;cAkBA,MAAM,IAAI,cAAc;CAQ5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gBAAgB,EAAE,mBAAmB,CAAC;KACvC;CACF"}
@@ -7,13 +7,9 @@ import { SbbIconNameMixin as u } from "../../icon.js";
7
7
  const g = c`*,:before,:after{box-sizing:border-box}:host{--sbb-step-label-color: var(--sbb-color-iron);--sbb-step-label-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-2x) );--sbb-step-label-prefix-size: var(--sbb-size-element-xxs);--sbb-step-label-prefix-border-style: solid;--sbb-step-label-prefix-border-color: var(--sbb-color-cloud);--sbb-step-label-prefix-background-color: var(--sbb-color-white);--sbb-step-label-gap: var(--sbb-spacing-fixed-4x);position:relative;min-width:0;max-width:fit-content}:host:before{--sbb-text-font-size: var(--sbb-font-size-text-xxs);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-text);font-size:var(--sbb-text-font-size);position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);cursor:var(--sbb-step-label-cursor);color:var(--sbb-step-label-color);inset-block-start:calc(var(--sbb-font-size-text-l) * var(--sbb-typo-line-height-body-text) / 2 + var(--sbb-border-width-1x) / 2);inset-inline-start:calc(var(--sbb-step-label-prefix-size) / 2);line-height:1;z-index:1;transform:translate(-50%,calc(-50% + var(--sbb-step-label-translate-y-content-hover, 0rem)));transition:transform var(--sbb-step-label-animation-duration) var(--sbb-animation-easing)}@media (forced-colors: active){:host{--sbb-step-label-color: ButtonText;--sbb-step-label-prefix-border-color: ButtonText}}:host([data-selected]){--sbb-text-font-size: var(--sbb-font-size-text-xxs);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-text);font-size:var(--sbb-text-font-size);font-weight:700;--sbb-step-label-color: var(--sbb-color-charcoal)}@media (forced-colors: active){:host([data-selected]){--sbb-step-label-color: Highlight !important}}:host([data-size=s]){--sbb-step-label-gap: var(--sbb-spacing-fixed-3x);--sbb-step-label-prefix-size: var(--sbb-size-element-xxxs)}:host([data-size=s]):before{inset-block-start:calc(var(--sbb-font-size-text-m) * var(--sbb-typo-line-height-body-text) / 2 + var(--sbb-border-width-1x) / 2)}:host(:disabled){--sbb-step-label-color: var(--sbb-color-granite);--sbb-step-label-prefix-border-style: dashed}@media (forced-colors: active){:host(:disabled){--sbb-step-label-color: GrayText !important}}@media (any-hover: hover){:host(:hover:not(:disabled)){--sbb-step-label-cursor: pointer;--sbb-step-label-prefix-background-color: var(--sbb-color-milk);--sbb-step-label-translate-y-content-hover: -.0625rem;--sbb-step-label-prefix-size-grow-hover: calc(var(--sbb-border-width-2x) * -1)}}:host(:focus-visible){outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);border-radius:var(--sbb-border-radius-1x)}:host([data-orientation=vertical]){transition:margin var(--sbb-stepper-animation-duration) var(--sbb-animation-easing)}:host([data-orientation=vertical]:not(:first-of-type)){margin-block-start:var(--sbb-spacing-fixed-6x)}:host([data-selected][data-orientation=vertical]){margin-block-end:var(--sbb-spacing-fixed-8x)}.sbb-step-label{--sbb-text-font-size: var(--sbb-font-size-text-l);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-text);font-size:var(--sbb-text-font-size);font-weight:700;cursor:var(--sbb-step-label-cursor);position:relative;display:flex;gap:var(--sbb-step-label-gap);color:var(--sbb-step-label-color)}:host([data-size=s]) .sbb-step-label{--sbb-text-font-size: var(--sbb-font-size-text-m);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-text);font-size:var(--sbb-text-font-size);font-weight:700}.sbb-step-label__prefix{position:relative;display:flex;flex-shrink:0;align-items:center;justify-content:center;width:var(--sbb-step-label-prefix-size);height:var(--sbb-step-label-prefix-size);inset-block-start:calc(1em * var(--sbb-typo-line-height-body-text) / 2 + var(--sbb-border-width-1x) / 2 - var(--sbb-step-label-prefix-size) / 2)}.sbb-step-label__prefix:before{content:"";position:absolute;inset:calc(var(--sbb-step-label-prefix-size-grow-hover, 0rem));border-radius:var(--sbb-border-radius-infinity);border:var(--sbb-border-width-1x) var(--sbb-step-label-prefix-border-style) var(--sbb-step-label-prefix-border-color);background-color:var(--sbb-step-label-prefix-background-color);transition-duration:var(--sbb-step-label-animation-duration);transition-timing-function:var(--sbb-animation-easing);transition-property:background-color,inset}:host([data-orientation=horizontal]) .sbb-step-label__text{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}::slotted(sbb-icon),sbb-icon{z-index:1;background-color:var(--sbb-step-label-prefix-background-color);border-radius:var(--sbb-border-radius-infinity);transform:translateY(var(--sbb-step-label-translate-y-content-hover, 0rem));transition-duration:var(--sbb-step-label-animation-duration);transition-timing-function:var(--sbb-animation-easing);transition-property:background-color,transform}`;
8
8
  let y = 0, I = (() => {
9
9
  var e;
10
- let b = [f("sbb-step-label")], a, i = [], s, r = u(v(h));
11
- return e = class extends r {
10
+ let o = [f("sbb-step-label")], i, r = [], s, b = u(v(h));
11
+ return e = class extends b {
12
12
  /** The step controlled by the label. */
13
- // eslint-disable-next-line @typescript-eslint/naming-convention
14
- set step(t) {
15
- this.internals.ariaControlsElements = x(this.internals.ariaControlsElements, this._step), this._step = t instanceof Element ? t : null, this.internals.ariaControlsElements = m(this.internals.ariaControlsElements, this._step);
16
- }
17
13
  get step() {
18
14
  return this._step;
19
15
  }
@@ -22,14 +18,8 @@ let y = 0, I = (() => {
22
18
  this._stepper && this.step && (this._stepper.selected = this.step);
23
19
  });
24
20
  }
25
- _getStep() {
26
- let t = this.nextElementSibling;
27
- for (; t && t.localName !== "sbb-step"; )
28
- t = t.nextElementSibling;
29
- return t;
30
- }
31
21
  connectedCallback() {
32
- super.connectedCallback(), this.id ||= `sbb-step-label-${y++}`, this.slot ||= "step-label", this.internals.ariaSelected = "false", this.tabIndex = -1, this._stepper = this.closest("sbb-stepper"), this.step = this._getStep(), this.toggleAttribute("data-disabled", this.hasAttribute("disabled"));
22
+ super.connectedCallback(), this.id ||= `sbb-step-label-${y++}`, this.slot ||= "step-label", this.internals.ariaSelected = "false", this.tabIndex = -1, this._stepper = this.closest("sbb-stepper"), this._assignStep(), this.toggleAttribute("data-disabled", this.hasAttribute("disabled"));
33
23
  }
34
24
  /**
35
25
  * Selects and configures the step label.
@@ -49,8 +39,15 @@ let y = 0, I = (() => {
49
39
  * Configures the step label.
50
40
  * @internal
51
41
  */
52
- configure(t, o, l) {
53
- l && (this.step = this._getStep()), this.internals.ariaPosInSet = `${t}`, this.internals.ariaSetSize = `${o}`;
42
+ configure(t, a, l) {
43
+ l && this._assignStep(), this.internals.ariaPosInSet = `${t}`, this.internals.ariaSetSize = `${a}`;
44
+ }
45
+ _assignStep() {
46
+ let t = this.nextElementSibling;
47
+ for (; t && t.localName !== "sbb-step"; )
48
+ t = t.nextElementSibling;
49
+ const a = t;
50
+ this.internals.ariaControlsElements = x(this.internals.ariaControlsElements, this._step), this._step = a instanceof Element ? a : null, this.internals.ariaControlsElements = m(this.internals.ariaControlsElements, this._step);
54
51
  }
55
52
  render() {
56
53
  return d`
@@ -61,9 +58,9 @@ let y = 0, I = (() => {
61
58
  `;
62
59
  }
63
60
  }, s = e, (() => {
64
- const t = typeof Symbol == "function" && Symbol.metadata ? Object.create(r[Symbol.metadata] ?? null) : void 0;
65
- n(null, a = { value: s }, b, { kind: "class", name: s.name, metadata: t }, null, i), s = a.value, t && Object.defineProperty(s, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: t });
66
- })(), e.role = "tab", e.styles = g, p(s, i), s;
61
+ const t = typeof Symbol == "function" && Symbol.metadata ? Object.create(b[Symbol.metadata] ?? null) : void 0;
62
+ n(null, i = { value: s }, o, { kind: "class", name: s.name, metadata: t }, null, r), s = i.value, t && Object.defineProperty(s, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: t });
63
+ })(), e.role = "tab", e.styles = g, p(s, r), s;
67
64
  })();
68
65
  export {
69
66
  I as SbbStepLabelElement