@sbb-esta/lyne-elements 4.3.0 → 4.3.1

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 (59) hide show
  1. package/breadcrumb/breadcrumb/breadcrumb.component.js +11 -11
  2. package/breadcrumb/breadcrumb-group/breadcrumb-group.component.js +26 -26
  3. package/button/common.js +1 -1
  4. package/button.js +1 -1
  5. package/checkbox/checkbox/checkbox.component.d.ts.map +1 -1
  6. package/checkbox/checkbox/checkbox.component.js +18 -20
  7. package/chip/chip/chip.component.js +10 -10
  8. package/clock/clock.component.d.ts.map +1 -1
  9. package/clock/clock.component.js +36 -38
  10. package/container/sticky-bar/sticky-bar.component.js +1 -1
  11. package/core/styles/core.scss +13 -0
  12. package/core/testing/event-spy.d.ts.map +1 -1
  13. package/core/testing/event-spy.js +4 -4
  14. package/core.css +27 -0
  15. package/custom-elements.json +732 -668
  16. package/development/breadcrumb/breadcrumb/breadcrumb.component.js +6 -19
  17. package/development/breadcrumb/breadcrumb-group/breadcrumb-group.component.js +2 -15
  18. package/development/button/common.js +1 -1
  19. package/development/button.js +1 -1
  20. package/development/checkbox/checkbox/checkbox.component.d.ts.map +1 -1
  21. package/development/checkbox/checkbox/checkbox.component.js +5 -4
  22. package/development/chip/chip/chip.component.js +2 -1
  23. package/development/clock/clock.component.d.ts.map +1 -1
  24. package/development/clock/clock.component.js +25 -40
  25. package/development/container/sticky-bar/sticky-bar.component.js +1 -1
  26. package/development/core/testing/event-spy.d.ts.map +1 -1
  27. package/development/core/testing/event-spy.js +3 -3
  28. package/development/form-field/form-field/form-field.component.js +2 -1
  29. package/development/{mini-button-label-common-DzMdb-kV.js → mini-button-label-common-0DeEC1qs.js} +5 -1
  30. package/development/selection-action-panel/selection-action-panel.component.d.ts +1 -0
  31. package/development/selection-action-panel/selection-action-panel.component.d.ts.map +1 -1
  32. package/development/selection-action-panel/selection-action-panel.component.js +27 -3
  33. package/development/stepper/step-label/step-label.component.d.ts +9 -0
  34. package/development/stepper/step-label/step-label.component.d.ts.map +1 -1
  35. package/development/stepper/step-label/step-label.component.js +25 -3
  36. package/development/stepper/stepper/stepper.component.d.ts +5 -3
  37. package/development/stepper/stepper/stepper.component.d.ts.map +1 -1
  38. package/development/stepper/stepper/stepper.component.js +48 -22
  39. package/development/toggle/toggle/toggle.component.d.ts +1 -0
  40. package/development/toggle/toggle/toggle.component.d.ts.map +1 -1
  41. package/development/toggle/toggle/toggle.component.js +19 -10
  42. package/form-field/form-field/form-field.component.js +1 -1
  43. package/{mini-button-label-common-ps7PVXtB.js → mini-button-label-common-BOB7JQKi.js} +1 -1
  44. package/off-brand-theme.css +27 -0
  45. package/package.json +1 -1
  46. package/safety-theme.css +27 -0
  47. package/selection-action-panel/selection-action-panel.component.d.ts +1 -0
  48. package/selection-action-panel/selection-action-panel.component.d.ts.map +1 -1
  49. package/selection-action-panel/selection-action-panel.component.js +25 -16
  50. package/standard-theme.css +27 -0
  51. package/stepper/step-label/step-label.component.d.ts +9 -0
  52. package/stepper/step-label/step-label.component.d.ts.map +1 -1
  53. package/stepper/step-label/step-label.component.js +38 -16
  54. package/stepper/stepper/stepper.component.d.ts +5 -3
  55. package/stepper/stepper/stepper.component.d.ts.map +1 -1
  56. package/stepper/stepper/stepper.component.js +62 -68
  57. package/toggle/toggle/toggle.component.d.ts +1 -0
  58. package/toggle/toggle/toggle.component.d.ts.map +1 -1
  59. package/toggle/toggle/toggle.component.js +46 -44
@@ -151,7 +151,9 @@ let SbbStepperElement = (() => {
151
151
  this._horizontalFrom = (__runInitializers(this, _linear_extraInitializers), null);
152
152
  __privateSet(this, _orientation_accessor_storage, __runInitializers(this, _orientation_initializers, "horizontal"));
153
153
  __privateSet(this, _size_accessor_storage, (__runInitializers(this, _orientation_extraInitializers), __runInitializers(this, _size_initializers, isLean() ? "s" : "m")));
154
- this._loaded = (__runInitializers(this, _size_extraInitializers), false);
154
+ this._requestedSelected = (__runInitializers(this, _size_extraInitializers), null);
155
+ this._requestedSelectedIndex = null;
156
+ this._loaded = false;
155
157
  this._resizeObserverTimeout = null;
156
158
  this._mediaMatcher = new SbbMediaMatcherController(this, {});
157
159
  this._onStepperResize = () => {
@@ -171,7 +173,7 @@ let SbbStepperElement = (() => {
171
173
  set linear(value) {
172
174
  __privateSet(this, _linear_accessor_storage, value);
173
175
  }
174
- /** Overrides the behaviour of `orientation` property. */
176
+ /** Overrides the behavior of `orientation` property. */
175
177
  set horizontalFrom(value) {
176
178
  this._horizontalFrom = value && breakpointMap[value] ? value : null;
177
179
  if (this._horizontalFrom && this._loaded) {
@@ -203,6 +205,7 @@ let SbbStepperElement = (() => {
203
205
  if (this._loaded) {
204
206
  this._select(step);
205
207
  }
208
+ this._requestedSelected = step;
206
209
  }
207
210
  get selected() {
208
211
  return this.querySelector?.("sbb-step:is(:state(selected),[state--selected])") ?? null;
@@ -212,16 +215,28 @@ let SbbStepperElement = (() => {
212
215
  if (this._loaded && index !== null) {
213
216
  this._select(this.steps[index]);
214
217
  }
218
+ this._requestedSelectedIndex = index;
215
219
  }
216
220
  get selectedIndex() {
217
221
  return this.selected ? this.steps.indexOf(this.selected) : null;
218
222
  }
219
223
  /** The steps of the stepper. */
220
224
  get steps() {
221
- return Array.from(this.querySelectorAll?.("sbb-step") ?? []);
225
+ const steps = [];
226
+ this.querySelectorAll?.("sbb-step").forEach((step) => {
227
+ customElements.upgrade(step);
228
+ steps.push(step);
229
+ });
230
+ return steps;
222
231
  }
223
232
  get _enabledSteps() {
224
- return this.steps.filter((s) => !s.label?.hasAttribute("disabled"));
233
+ return this.steps.filter((s) => {
234
+ if (s.label) {
235
+ customElements.upgrade(s.label);
236
+ return !s.label.disabled;
237
+ }
238
+ return false;
239
+ });
225
240
  }
226
241
  /** Selects the next step. */
227
242
  next() {
@@ -248,21 +263,22 @@ let SbbStepperElement = (() => {
248
263
  this.selected?.label?.focus();
249
264
  }
250
265
  }
251
- _isValidStep(step) {
252
- if (!step || !this.linear && step.label?.hasAttribute("disabled")) {
266
+ _isSelectable(step) {
267
+ if (step) {
268
+ customElements.upgrade(step);
269
+ if (step.label) {
270
+ customElements.upgrade(step.label);
271
+ if (!this.linear && step.label.disabled) {
272
+ return false;
273
+ }
274
+ }
275
+ return true;
276
+ } else {
253
277
  return false;
254
278
  }
255
- if (this.linear && !this.selected) {
256
- return step === this.steps[0];
257
- }
258
- if (this.linear && this.selectedIndex !== null) {
259
- const index = this.steps.indexOf(step);
260
- return index < this.selectedIndex || index === this.selectedIndex + 1;
261
- }
262
- return true;
263
279
  }
264
280
  _select(step) {
265
- if (!this._isValidStep(step)) {
281
+ if (!this._isSelectable(step) || step === this.selected) {
266
282
  return;
267
283
  }
268
284
  const currentIndex = this.selectedIndex;
@@ -322,10 +338,9 @@ let SbbStepperElement = (() => {
322
338
  this._setStepperHeight(e.target);
323
339
  }
324
340
  _configure() {
325
- const steps = this.steps;
326
- steps.forEach((s) => s.configure(this._loaded));
327
- steps.filter((s) => s.label).map((s) => s.label).forEach((label, i, array) => {
328
- label.configure(i + 1, array.length, this._loaded);
341
+ this.steps.forEach((step, i, array) => {
342
+ step.configure(this._loaded);
343
+ step.label?.configure(i + 1, array.length, this._loaded);
329
344
  });
330
345
  this._select(this.selected || this._enabledSteps[0]);
331
346
  }
@@ -343,7 +358,11 @@ let SbbStepperElement = (() => {
343
358
  }
344
359
  _configureLinearMode() {
345
360
  this.steps.forEach((step, index) => {
346
- step.label?.toggleAttribute("disabled", this.linear && index > this.selectedIndex || !this.linear && step.label.matches(":is(:state(disabled),[state--disabled])"));
361
+ if (!step.label) {
362
+ return;
363
+ }
364
+ customElements.upgrade(step.label);
365
+ step.label.disable(this.linear && index > this.selectedIndex || !this.linear && step.label.matches(":is(:state(user-disabled),[state--user-disabled])"));
347
366
  });
348
367
  }
349
368
  connectedCallback() {
@@ -361,7 +380,14 @@ let SbbStepperElement = (() => {
361
380
  super.firstUpdated(changedProperties);
362
381
  this.updateComplete.then(() => {
363
382
  this._loaded = true;
364
- this.selectedIndex = this.linear ? 0 : Number(this.getAttribute("selected-index")) || 0;
383
+ this._configure();
384
+ if (this._requestedSelected && this.steps.indexOf(this._requestedSelected) !== -1) {
385
+ this.selectedIndex = this.steps.indexOf(this._requestedSelected);
386
+ } else if (this._requestedSelectedIndex) {
387
+ this.selectedIndex = this._requestedSelectedIndex;
388
+ } else {
389
+ this.selectedIndex = 0;
390
+ }
365
391
  this._observer.observe(this);
366
392
  this._checkOrientation();
367
393
  setTimeout(() => this.internals.states.delete("disable-animation"), DEBOUNCE_TIME);
@@ -443,4 +469,4 @@ export {
443
469
  SbbStepChangeEvent,
444
470
  SbbStepperElement
445
471
  };
446
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"stepper.component.js","sources":["../../../../../src/elements/stepper/stepper/stepper.component.ts"],"sourcesContent":["import { IntersectionController } from '@lit-labs/observers/intersection-controller.js';\nimport {\n  type CSSResultGroup,\n  html,\n  LitElement,\n  type TemplateResult,\n  type PropertyValues,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { getNextElementIndex, isArrowKeyPressed } from '../../core/a11y.ts';\nimport {\n  SbbMediaMatcherController,\n  SbbMediaQueryBreakpointLargeAndAbove,\n  SbbMediaQueryBreakpointSmallAndAbove,\n  SbbMediaQueryBreakpointUltraAndAbove,\n  SbbMediaQueryBreakpointZeroAndAbove,\n} from '../../core/controllers/media-matchers-controller.ts';\nimport { forceType } from '../../core/decorators.ts';\nimport { isLean } from '../../core/dom.ts';\nimport type { SbbHorizontalFrom, SbbOrientation } from '../../core/interfaces.ts';\nimport { SbbElementInternalsMixin, SbbHydrationMixin } from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbStepElement, SbbStepValidateEventDetails } from '../step.ts';\n\nimport style from './stepper.scss?lit&inline';\n\nconst DEBOUNCE_TIME = 150;\n\nconst breakpointMap: Record<string, string> = {\n  zero: SbbMediaQueryBreakpointZeroAndAbove,\n  small: SbbMediaQueryBreakpointSmallAndAbove,\n  large: SbbMediaQueryBreakpointLargeAndAbove,\n  ultra: SbbMediaQueryBreakpointUltraAndAbove,\n};\n\nexport class SbbStepChangeEvent extends Event {\n  /** The index of the newly selected step. */\n  public readonly selectedIndex: number | null;\n\n  /** The index of the previously selected step. */\n  public readonly previousIndex: number | null;\n\n  /** The newly selected step element. */\n  public readonly selectedStep: SbbStepElement | null;\n\n  /** The previously selected step element. */\n  public readonly previousStep: SbbStepElement | null;\n\n  public constructor(\n    selectedIndex: number | null,\n    previousIndex: number | null,\n    selectedStep: SbbStepElement | null,\n    previousStep: SbbStepElement | null,\n  ) {\n    super('stepchange', { bubbles: true, composed: true });\n    this.selectedIndex = selectedIndex;\n    this.previousIndex = previousIndex;\n    this.selectedStep = selectedStep;\n    this.previousStep = previousStep;\n  }\n}\n/**\n * Provides a structured, step-by-step workflow for user interactions.\n * @slot - Provide a `sbb-expansion-panel-header` and a `sbb-expansion-panel-content` to the stepper.\n * @slot step-label - Use this slot to provide an `sbb-step-label`.\n * @slot step - Use this slot to provide an `sbb-step`.\n * @event {SbbStepChangeEvent} stepchange - Emits whenever a step was changed.\n */\nexport\n@customElement('sbb-stepper')\nclass SbbStepperElement extends SbbHydrationMixin(SbbElementInternalsMixin(LitElement)) {\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  public static readonly events = {\n    stepchange: 'stepchange',\n  } as const;\n\n  /**\n   * If the sbb-stepper is used in a sbb-dialog, the marker on the selected element will not appear,\n   * because the calculations are done when the dialog is closed, so the marker has a width of 0;\n   * the same happens for the stepper height.\n   * We need to recalculate it when the element becomes visible.\n   */\n  private _observer = new IntersectionController(this, {\n    target: null,\n    callback: (entries) => {\n      entries.forEach((e) => {\n        if (e.intersectionRatio > 0) {\n          this._setStepperHeight(this.selected);\n          this._setMarkerSize();\n        }\n      });\n    },\n  });\n\n  /** If set to true, only the current and previous labels can be clicked and selected. */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor linear: boolean = false;\n\n  /** Overrides the behaviour of `orientation` property. */\n  @property({ attribute: 'horizontal-from', reflect: true })\n  public set horizontalFrom(value: SbbHorizontalFrom | null) {\n    this._horizontalFrom = value && breakpointMap[value] ? value : null;\n    if (this._horizontalFrom && this._loaded) {\n      this._checkOrientation();\n    }\n  }\n  public get horizontalFrom(): SbbHorizontalFrom | null {\n    return this._horizontalFrom;\n  }\n  private _horizontalFrom: SbbHorizontalFrom | null = null;\n\n  /** Steps orientation, either horizontal or vertical. */\n  @property({ reflect: true })\n  public accessor orientation: SbbOrientation = 'horizontal';\n\n  /**\n   * Size variant, either s or m.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true }) public accessor size: 's' | 'm' = isLean() ? 's' : 'm';\n\n  /** The currently selected step. */\n  @property({ attribute: false })\n  public set selected(step: SbbStepElement | null) {\n    if (this._loaded) {\n      this._select(step);\n    }\n  }\n  public get selected(): SbbStepElement | null {\n    return this.querySelector?.<SbbStepElement>('sbb-step:state(selected)') ?? null;\n  }\n\n  /** The currently selected step index. */\n  @property({ attribute: 'selected-index', type: Number })\n  public set selectedIndex(index: number | null) {\n    if (this._loaded && index !== null) {\n      this._select(this.steps[index]);\n    }\n  }\n  public get selectedIndex(): number | null {\n    return this.selected ? this.steps.indexOf(this.selected) : null;\n  }\n\n  /** The steps of the stepper. */\n  public get steps(): SbbStepElement[] {\n    return Array.from(this.querySelectorAll?.('sbb-step') ?? []);\n  }\n\n  private get _enabledSteps(): SbbStepElement[] {\n    return this.steps.filter((s) => !s.label?.hasAttribute('disabled'));\n  }\n\n  private _loaded: boolean = false;\n  private _resizeObserverTimeout: ReturnType<typeof setTimeout> | null = null;\n  private _mediaMatcher = new SbbMediaMatcherController(this, {});\n\n  public constructor() {\n    super();\n    this.addEventListener?.('keydown', (e) => this._handleKeyDown(e));\n    this.addEventListener?.('resizechange', (e: Event) => this._onSelectedStepResize(e));\n  }\n\n  /** Selects the next step. */\n  public next(): void {\n    if (this.selectedIndex !== null) {\n      this._select(this.steps[this.selectedIndex + 1]);\n    }\n  }\n\n  /** Selects the previous step. */\n  public previous(): void {\n    if (this.selectedIndex !== null) {\n      this._select(this.steps[this.selectedIndex - 1]);\n    }\n  }\n\n  /** Resets the form in which the stepper is nested or every form of each step, if any. */\n  public reset(): void {\n    const closestForm = this.closest('form');\n    if (closestForm) {\n      closestForm.reset();\n    } else {\n      this.querySelectorAll('form').forEach((form) => form.reset());\n    }\n    this.selectedIndex = 0;\n    // In case the focus is currently inside the stepper, we reset the focus to the first/selected step label.\n    if (document.activeElement?.closest('sbb-stepper') === this) {\n      this.selected?.label?.focus();\n    }\n  }\n\n  private _isValidStep(step: SbbStepElement | null): boolean {\n    if (!step || (!this.linear && step.label?.hasAttribute('disabled'))) {\n      return false;\n    }\n\n    if (this.linear && !this.selected) {\n      return step === this.steps[0];\n    }\n\n    if (this.linear && this.selectedIndex !== null) {\n      const index = this.steps.indexOf(step);\n      return index < this.selectedIndex || index === this.selectedIndex + 1;\n    }\n\n    return true;\n  }\n\n  private _select(step: SbbStepElement | null): void {\n    if (!this._isValidStep(step)) {\n      return;\n    }\n    const currentIndex = this.selectedIndex;\n    const currentStep = this.selected;\n    const validatePayload: SbbStepValidateEventDetails = {\n      currentIndex,\n      currentStep,\n      nextIndex: this.selectedIndex !== null ? this.selectedIndex + 1 : null,\n      nextStep: this.selectedIndex !== null ? this.steps[this.selectedIndex + 1] : null,\n    };\n\n    if (this.selected && !this.selected.validate(validatePayload)) {\n      return;\n    }\n\n    const current = this.selected;\n    current?.deselect();\n    step!.select();\n\n    /** @internal only to provide double entry in docs. It is a public event! */\n    this.dispatchEvent(\n      new SbbStepChangeEvent(this.selectedIndex, currentIndex, this.selected, currentStep),\n    );\n\n    this._setMarkerSize();\n    this._setStepperHeight(step);\n    this._configureLinearMode();\n    // In case the focus is currently inside the stepper, we focus the selected step label.\n    if (document.activeElement?.closest('sbb-stepper') === this) {\n      this.selected?.label?.focus();\n    }\n  }\n\n  private _setMarkerSize(): void {\n    if (\n      !this._loaded ||\n      !this.selected ||\n      this.selectedIndex === undefined ||\n      !this.selected.label\n    ) {\n      return;\n    }\n    const offset =\n      this.orientation === 'horizontal'\n        ? this.selected.label.offsetLeft + this.selected.label.offsetWidth\n        : this._calculateLabelOffsetTop();\n\n    this.style.setProperty('--sbb-stepper-marker-size', `${offset}px`);\n  }\n\n  /**\n   * Sets the stepper height based on the height of the provided step.\n   */\n  private _setStepperHeight(step: SbbStepElement | null): void {\n    if (step && step.shadowRoot) {\n      const innerElement: SbbStepElement | null = step.shadowRoot.querySelector('.sbb-step');\n      if (innerElement) {\n        this.style?.setProperty('--sbb-stepper-content-height', `${innerElement.offsetHeight}px`);\n      }\n    }\n  }\n\n  private _calculateLabelOffsetTop(): number | undefined {\n    if (this.selectedIndex === null) {\n      return;\n    }\n    let offset = 0;\n    for (const step of this.steps) {\n      if (step === this.selected) {\n        break;\n      }\n      offset = step.label!.offsetHeight + offset;\n    }\n    return (\n      offset +\n      this.selected!.label!.offsetHeight! +\n      parseFloat(getComputedStyle(this).getPropertyValue('--sbb-spacing-fixed-6x')) *\n        16 *\n        this.selectedIndex\n    );\n  }\n\n  private _onSelectedStepResize(e: Event): void {\n    this._setStepperHeight(e.target as SbbStepElement);\n  }\n\n  private _configure(): void {\n    const steps = this.steps;\n    steps.forEach((s) => s.configure(this._loaded));\n    steps\n      .filter((s) => s.label)\n      .map((s) => s.label!)\n      .forEach((label, i, array) => {\n        label.configure(i + 1, array.length, this._loaded);\n      });\n    this._select(this.selected || this._enabledSteps[0]);\n  }\n\n  private _updateLabels(): void {\n    this.steps.forEach((step) => {\n      step.slot = this.orientation === 'horizontal' ? 'step' : 'step-label';\n    });\n  }\n\n  private _checkOrientation(): void {\n    if (this.horizontalFrom) {\n      this.orientation = this._mediaMatcher.matches(breakpointMap[this.horizontalFrom])\n        ? 'horizontal'\n        : 'vertical';\n      this._updateLabels();\n    }\n    // The timeout is needed to make sure that the marker takes the correct step-label size.\n    setTimeout(() => this._setMarkerSize(), 0);\n  }\n\n  private _onStepperResize = (): void => {\n    this._checkOrientation();\n    this._setStepperHeight(this.selected);\n    clearTimeout(this._resizeObserverTimeout!);\n    this.internals.states.add('disable-animation');\n\n    // Disable the animation when resizing to avoid strange transition effects.\n    this._resizeObserverTimeout = setTimeout(\n      () => this.internals.states.delete('disable-animation'),\n      DEBOUNCE_TIME,\n    );\n  };\n\n  private _configureLinearMode(): void {\n    this.steps.forEach((step, index) => {\n      step.label?.toggleAttribute(\n        'disabled',\n        (this.linear && index > this.selectedIndex!) ||\n          (!this.linear && step.label.matches(':state(disabled)')),\n      );\n    });\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    window.addEventListener('resize', this._onStepperResize, {\n      passive: true,\n    });\n    this.toggleState('disable-animation', !this._loaded);\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    window.removeEventListener('resize', this._onStepperResize);\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n    this.updateComplete.then(() => {\n      this._loaded = true;\n      this.selectedIndex = this.linear ? 0 : Number(this.getAttribute('selected-index')) || 0;\n      this._observer.observe(this);\n      this._checkOrientation();\n      // Remove disable-animation state after component init\n      setTimeout(() => this.internals.states.delete('disable-animation'), DEBOUNCE_TIME);\n    });\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n    if (changedProperties.has('orientation') && !this.horizontalFrom) {\n      this._updateLabels();\n      this._setMarkerSize();\n    }\n    if (changedProperties.has('linear') && this._loaded) {\n      this._configureLinearMode();\n    }\n\n    if (changedProperties.has('size')) {\n      this._setMarkerSize();\n    }\n  }\n\n  private _handleKeyDown(evt: KeyboardEvent): void {\n    const enabledSteps: SbbStepElement[] = this._enabledSteps;\n\n    if (\n      !enabledSteps ||\n      // don't trap nested handling\n      ((evt.target as HTMLElement) !== this && (evt.target as HTMLElement).parentElement !== this)\n    ) {\n      return;\n    }\n\n    if (isArrowKeyPressed(evt)) {\n      const current: number = enabledSteps.indexOf(this.selected!);\n      const nextIndex: number = getNextElementIndex(evt, current, enabledSteps.length);\n      this._select(enabledSteps[nextIndex]);\n      evt.preventDefault();\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-stepper\">\n        <div class=\"sbb-stepper__labels\" role=\"tablist\">\n          <slot name=\"step-label\" @slotchange=${this._configure}></slot>\n        </div>\n        <div class=\"sbb-stepper__steps\">\n          <slot name=\"step\" @slotchange=${this._configure}></slot>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-stepper': SbbStepperElement;\n  }\n}\n"],"names":[],"mappings":"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"}
472
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"stepper.component.js","sources":["../../../../../src/elements/stepper/stepper/stepper.component.ts"],"sourcesContent":["import { IntersectionController } from '@lit-labs/observers/intersection-controller.js';\nimport {\n  type CSSResultGroup,\n  html,\n  LitElement,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { getNextElementIndex, isArrowKeyPressed } from '../../core/a11y.ts';\nimport {\n  SbbMediaMatcherController,\n  SbbMediaQueryBreakpointLargeAndAbove,\n  SbbMediaQueryBreakpointSmallAndAbove,\n  SbbMediaQueryBreakpointUltraAndAbove,\n  SbbMediaQueryBreakpointZeroAndAbove,\n} from '../../core/controllers/media-matchers-controller.ts';\nimport { forceType } from '../../core/decorators.ts';\nimport { isLean } from '../../core/dom.ts';\nimport type { SbbHorizontalFrom, SbbOrientation } from '../../core/interfaces.ts';\nimport { SbbElementInternalsMixin, SbbHydrationMixin } from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbStepElement, SbbStepValidateEventDetails } from '../step.ts';\n\nimport style from './stepper.scss?lit&inline';\n\nconst DEBOUNCE_TIME = 150;\n\nconst breakpointMap: Record<string, string> = {\n  zero: SbbMediaQueryBreakpointZeroAndAbove,\n  small: SbbMediaQueryBreakpointSmallAndAbove,\n  large: SbbMediaQueryBreakpointLargeAndAbove,\n  ultra: SbbMediaQueryBreakpointUltraAndAbove,\n};\n\nexport class SbbStepChangeEvent extends Event {\n  /** The index of the newly selected step. */\n  public readonly selectedIndex: number | null;\n\n  /** The index of the previously selected step. */\n  public readonly previousIndex: number | null;\n\n  /** The newly selected step element. */\n  public readonly selectedStep: SbbStepElement | null;\n\n  /** The previously selected step element. */\n  public readonly previousStep: SbbStepElement | null;\n\n  public constructor(\n    selectedIndex: number | null,\n    previousIndex: number | null,\n    selectedStep: SbbStepElement | null,\n    previousStep: SbbStepElement | null,\n  ) {\n    super('stepchange', { bubbles: true, composed: true });\n    this.selectedIndex = selectedIndex;\n    this.previousIndex = previousIndex;\n    this.selectedStep = selectedStep;\n    this.previousStep = previousStep;\n  }\n}\n/**\n * Provides a structured, step-by-step workflow for user interactions.\n * @slot - Provide a `sbb-expansion-panel-header` and a `sbb-expansion-panel-content` to the stepper.\n * @slot step-label - Use this slot to provide an `sbb-step-label`.\n * @slot step - Use this slot to provide an `sbb-step`.\n * @event {SbbStepChangeEvent} stepchange - Emits whenever a step was changed.\n */\nexport\n@customElement('sbb-stepper')\nclass SbbStepperElement extends SbbHydrationMixin(SbbElementInternalsMixin(LitElement)) {\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  public static readonly events = {\n    stepchange: 'stepchange',\n  } as const;\n\n  /**\n   * If the sbb-stepper is used in a sbb-dialog, the marker on the selected element will not appear,\n   * because the calculations are done when the dialog is closed, so the marker has a width of 0;\n   * the same happens for the stepper height.\n   * We need to recalculate it when the element becomes visible.\n   */\n  private _observer = new IntersectionController(this, {\n    target: null,\n    callback: (entries) => {\n      entries.forEach((e) => {\n        if (e.intersectionRatio > 0) {\n          this._setStepperHeight(this.selected);\n          this._setMarkerSize();\n        }\n      });\n    },\n  });\n\n  /** If set to true, only the current and previous labels can be clicked and selected. */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor linear: boolean = false;\n\n  /** Overrides the behavior of `orientation` property. */\n  @property({ attribute: 'horizontal-from', reflect: true })\n  public set horizontalFrom(value: SbbHorizontalFrom | null) {\n    this._horizontalFrom = value && breakpointMap[value] ? value : null;\n    if (this._horizontalFrom && this._loaded) {\n      this._checkOrientation();\n    }\n  }\n  public get horizontalFrom(): SbbHorizontalFrom | null {\n    return this._horizontalFrom;\n  }\n  private _horizontalFrom: SbbHorizontalFrom | null = null;\n\n  /** Steps orientation, either horizontal or vertical. */\n  @property({ reflect: true })\n  public accessor orientation: SbbOrientation = 'horizontal';\n\n  /**\n   * Size variant, either s or m.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true }) public accessor size: 's' | 'm' = isLean() ? 's' : 'm';\n\n  /** The currently selected step. */\n  @property({ attribute: false })\n  public set selected(step: SbbStepElement | null) {\n    if (this._loaded) {\n      this._select(step);\n    }\n    this._requestedSelected = step;\n  }\n  public get selected(): SbbStepElement | null {\n    return this.querySelector?.<SbbStepElement>('sbb-step:state(selected)') ?? null;\n  }\n  private _requestedSelected: SbbStepElement | null = null;\n\n  /** The currently selected step index. */\n  @property({ attribute: 'selected-index', type: Number })\n  public set selectedIndex(index: number | null) {\n    if (this._loaded && index !== null) {\n      this._select(this.steps[index]);\n    }\n    this._requestedSelectedIndex = index;\n  }\n  public get selectedIndex(): number | null {\n    return this.selected ? this.steps.indexOf(this.selected) : null;\n  }\n  private _requestedSelectedIndex: number | null = null;\n\n  /** The steps of the stepper. */\n  public get steps(): SbbStepElement[] {\n    const steps: SbbStepElement[] = [];\n    this.querySelectorAll?.('sbb-step').forEach((step) => {\n      customElements.upgrade(step);\n      steps.push(step);\n    });\n    return steps;\n  }\n\n  private get _enabledSteps(): SbbStepElement[] {\n    return this.steps.filter((s) => {\n      if (s.label) {\n        customElements.upgrade(s.label);\n        return !s.label.disabled;\n      }\n      return false;\n    });\n  }\n\n  private _loaded: boolean = false;\n  private _resizeObserverTimeout: ReturnType<typeof setTimeout> | null = null;\n  private _mediaMatcher = new SbbMediaMatcherController(this, {});\n\n  public constructor() {\n    super();\n    this.addEventListener?.('keydown', (e) => this._handleKeyDown(e));\n    this.addEventListener?.('resizechange', (e: Event) => this._onSelectedStepResize(e));\n  }\n\n  /** Selects the next step. */\n  public next(): void {\n    if (this.selectedIndex !== null) {\n      this._select(this.steps[this.selectedIndex + 1]);\n    }\n  }\n\n  /** Selects the previous step. */\n  public previous(): void {\n    if (this.selectedIndex !== null) {\n      this._select(this.steps[this.selectedIndex - 1]);\n    }\n  }\n\n  /** Resets the form in which the stepper is nested or every form of each step, if any. */\n  public reset(): void {\n    const closestForm = this.closest('form');\n    if (closestForm) {\n      closestForm.reset();\n    } else {\n      this.querySelectorAll('form').forEach((form) => form.reset());\n    }\n    this.selectedIndex = 0;\n    // In case the focus is currently inside the stepper, we reset the focus to the first/selected step label.\n    if (document.activeElement?.closest('sbb-stepper') === this) {\n      this.selected?.label?.focus();\n    }\n  }\n\n  private _isSelectable(step: SbbStepElement | null): step is SbbStepElement {\n    if (step) {\n      customElements.upgrade(step);\n      if (step.label) {\n        customElements.upgrade(step.label);\n        if (!this.linear && step.label.disabled) {\n          return false;\n        }\n      }\n      return true;\n    } else {\n      return false;\n    }\n  }\n\n  private _select(step: SbbStepElement | null): void {\n    if (!this._isSelectable(step) || step === this.selected) {\n      return;\n    }\n    const currentIndex = this.selectedIndex;\n    const currentStep = this.selected;\n    const validatePayload: SbbStepValidateEventDetails = {\n      currentIndex,\n      currentStep,\n      nextIndex: this.selectedIndex !== null ? this.selectedIndex + 1 : null,\n      nextStep: this.selectedIndex !== null ? this.steps[this.selectedIndex + 1] : null,\n    };\n\n    if (this.selected && !this.selected.validate(validatePayload)) {\n      return;\n    }\n\n    const current = this.selected;\n    current?.deselect();\n    step.select();\n\n    /** @internal only to provide double entry in docs. It is a public event! */\n    this.dispatchEvent(\n      new SbbStepChangeEvent(this.selectedIndex, currentIndex, this.selected, currentStep),\n    );\n\n    this._setMarkerSize();\n    this._setStepperHeight(step);\n    this._configureLinearMode();\n    // In case the focus is currently inside the stepper, we focus the selected step label.\n    if (document.activeElement?.closest('sbb-stepper') === this) {\n      this.selected?.label?.focus();\n    }\n  }\n\n  private _setMarkerSize(): void {\n    if (\n      !this._loaded ||\n      !this.selected ||\n      this.selectedIndex === undefined ||\n      !this.selected.label\n    ) {\n      return;\n    }\n    const offset =\n      this.orientation === 'horizontal'\n        ? this.selected.label.offsetLeft + this.selected.label.offsetWidth\n        : this._calculateLabelOffsetTop();\n\n    this.style.setProperty('--sbb-stepper-marker-size', `${offset}px`);\n  }\n\n  /**\n   * Sets the stepper height based on the height of the provided step.\n   */\n  private _setStepperHeight(step: SbbStepElement | null): void {\n    if (step && step.shadowRoot) {\n      const innerElement: SbbStepElement | null = step.shadowRoot.querySelector('.sbb-step');\n      if (innerElement) {\n        this.style?.setProperty('--sbb-stepper-content-height', `${innerElement.offsetHeight}px`);\n      }\n    }\n  }\n\n  private _calculateLabelOffsetTop(): number | undefined {\n    if (this.selectedIndex === null) {\n      return;\n    }\n    let offset = 0;\n    for (const step of this.steps) {\n      if (step === this.selected) {\n        break;\n      }\n      offset = step.label!.offsetHeight + offset;\n    }\n    return (\n      offset +\n      this.selected!.label!.offsetHeight! +\n      parseFloat(getComputedStyle(this).getPropertyValue('--sbb-spacing-fixed-6x')) *\n        16 *\n        this.selectedIndex\n    );\n  }\n\n  private _onSelectedStepResize(e: Event): void {\n    this._setStepperHeight(e.target as SbbStepElement);\n  }\n\n  private _configure(): void {\n    this.steps.forEach((step, i, array) => {\n      step.configure(this._loaded);\n      step.label?.configure(i + 1, array.length, this._loaded);\n    });\n    this._select(this.selected || this._enabledSteps[0]);\n  }\n\n  private _updateLabels(): void {\n    this.steps.forEach((step) => {\n      step.slot = this.orientation === 'horizontal' ? 'step' : 'step-label';\n    });\n  }\n\n  private _checkOrientation(): void {\n    if (this.horizontalFrom) {\n      this.orientation = this._mediaMatcher.matches(breakpointMap[this.horizontalFrom])\n        ? 'horizontal'\n        : 'vertical';\n      this._updateLabels();\n    }\n    // The timeout is needed to make sure that the marker takes the correct step-label size.\n    setTimeout(() => this._setMarkerSize(), 0);\n  }\n\n  private _onStepperResize = (): void => {\n    this._checkOrientation();\n    this._setStepperHeight(this.selected);\n    clearTimeout(this._resizeObserverTimeout!);\n    this.internals.states.add('disable-animation');\n\n    // Disable the animation when resizing to avoid strange transition effects.\n    this._resizeObserverTimeout = setTimeout(\n      () => this.internals.states.delete('disable-animation'),\n      DEBOUNCE_TIME,\n    );\n  };\n\n  private _configureLinearMode(): void {\n    this.steps.forEach((step, index) => {\n      if (!step.label) {\n        return;\n      }\n      customElements.upgrade(step.label);\n\n      step.label.disable(\n        (this.linear && index > this.selectedIndex!) ||\n          (!this.linear && step.label.matches(':state(user-disabled)')),\n      );\n    });\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    window.addEventListener('resize', this._onStepperResize, {\n      passive: true,\n    });\n    this.toggleState('disable-animation', !this._loaded);\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    window.removeEventListener('resize', this._onStepperResize);\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n    this.updateComplete.then(() => {\n      this._loaded = true;\n      this._configure();\n\n      if (this._requestedSelected && this.steps.indexOf(this._requestedSelected) !== -1) {\n        this.selectedIndex = this.steps.indexOf(this._requestedSelected);\n      } else if (this._requestedSelectedIndex) {\n        this.selectedIndex = this._requestedSelectedIndex;\n      } else {\n        this.selectedIndex = 0;\n      }\n\n      this._observer.observe(this);\n      this._checkOrientation();\n      // Remove disable-animation state after component init\n      setTimeout(() => this.internals.states.delete('disable-animation'), DEBOUNCE_TIME);\n    });\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n    if (changedProperties.has('orientation') && !this.horizontalFrom) {\n      this._updateLabels();\n      this._setMarkerSize();\n    }\n    if (changedProperties.has('linear') && this._loaded) {\n      this._configureLinearMode();\n    }\n\n    if (changedProperties.has('size')) {\n      this._setMarkerSize();\n    }\n  }\n\n  private _handleKeyDown(evt: KeyboardEvent): void {\n    const enabledSteps: SbbStepElement[] = this._enabledSteps;\n\n    if (\n      !enabledSteps ||\n      // don't trap nested handling\n      ((evt.target as HTMLElement) !== this && (evt.target as HTMLElement).parentElement !== this)\n    ) {\n      return;\n    }\n\n    if (isArrowKeyPressed(evt)) {\n      const current: number = enabledSteps.indexOf(this.selected!);\n      const nextIndex: number = getNextElementIndex(evt, current, enabledSteps.length);\n      this._select(enabledSteps[nextIndex]);\n      evt.preventDefault();\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-stepper\">\n        <div class=\"sbb-stepper__labels\" role=\"tablist\">\n          <slot name=\"step-label\" @slotchange=${this._configure}></slot>\n        </div>\n        <div class=\"sbb-stepper__steps\">\n          <slot name=\"step\" @slotchange=${this._configure}></slot>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-stepper': SbbStepperElement;\n  }\n}\n"],"names":[],"mappings":"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"}
@@ -60,6 +60,7 @@ export declare class SbbToggleElement<T = string> extends SbbToggleElement_base
60
60
  */
61
61
  private _handleInput;
62
62
  private _handleKeyDown;
63
+ private _selectAndFocusOption;
63
64
  protected render(): TemplateResult;
64
65
  }
65
66
  declare global {
@@ -1 +1 @@
1
- {"version":3,"file":"toggle.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/toggle/toggle/toggle.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAGnB,UAAU,EACV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAMb,OAAO,EACL,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,EAItB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EAAE,KAAK,sBAAsB,EAAE,MAAM,qBAAqB,CAAC;;AAIlE;;;;;GAKG;AACH,qBAEM,gBAAgB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,qBAE1C;IACC,gBAAgC,IAAI,gBAAgB;IACpD,OAAuB,MAAM,EAAE,cAAc,CAA4B;IACzE,gBAAuB,MAAM;;MAElB;IAEX;;;OAGG;IACH,SAEgB,IAAI,EAAE,OAAO,CAAS;IAEtC;;;OAGG;IACH,SAA6C,IAAI,EAAE,GAAG,GAAG,GAAG,CAAwB;IAEpF;;;OAGG;IACH,IACW,KAAK,CAAC,KAAK,EAAE,CAAC,GAAG,IAAI,EAM/B;IACD,IAAW,KAAK,IAAI,CAAC,GAAG,IAAI,CAI3B;IACD,OAAO,CAAC,cAAc,CAAkB;IAExC,4DAA4D;IAC5D,IAAW,OAAO,IAAI,sBAAsB,CAAC,CAAC,CAAC,EAAE,CAIhD;;cAQkB,UAAU,CAAC,iBAAiB,EAAE,cAAc,GAAG,IAAI;IAatE;;;OAGG;IACI,aAAa,IAAI,IAAI;IAK5B;;;OAGG;IACI,iBAAiB,IAAI,IAAI;IAIhC;;OAEG;IACI,wBAAwB,CAC7B,KAAK,EAAE,gBAAgB,GAAG,IAAI,EAC9B,OAAO,EAAE,iBAAiB,GACzB,IAAI;YAUO,aAAa;IAK3B,gBAAgB;IACT,kBAAkB,CAAC,QAAQ,UAAQ,GAAG,IAAI;IAqCjD,OAAO,CAAC,aAAa;IAKrB,OAAO,CAAC,aAAa;IAgBrB,OAAO,CAAC,eAAe;IAMvB;;OAEG;IACH,OAAO,CAAC,YAAY;IAUpB,OAAO,CAAC,cAAc;cA6BH,MAAM,IAAI,cAAc;CAO5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,YAAY,EAAE,gBAAgB,CAAC;KAChC;CACF"}
1
+ {"version":3,"file":"toggle.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/toggle/toggle/toggle.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAGnB,UAAU,EACV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAMb,OAAO,EACL,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,EAItB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EAAE,KAAK,sBAAsB,EAAE,MAAM,qBAAqB,CAAC;;AAIlE;;;;;GAKG;AACH,qBAEM,gBAAgB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,qBAE1C;IACC,gBAAgC,IAAI,gBAAgB;IACpD,OAAuB,MAAM,EAAE,cAAc,CAA4B;IACzE,gBAAuB,MAAM;;MAElB;IAEX;;;OAGG;IACH,SAEgB,IAAI,EAAE,OAAO,CAAS;IAEtC;;;OAGG;IACH,SAA6C,IAAI,EAAE,GAAG,GAAG,GAAG,CAAwB;IAEpF;;;OAGG;IACH,IACW,KAAK,CAAC,KAAK,EAAE,CAAC,GAAG,IAAI,EAM/B;IACD,IAAW,KAAK,IAAI,CAAC,GAAG,IAAI,CAI3B;IACD,OAAO,CAAC,cAAc,CAAkB;IAExC,4DAA4D;IAC5D,IAAW,OAAO,IAAI,sBAAsB,CAAC,CAAC,CAAC,EAAE,CAIhD;;cAQkB,UAAU,CAAC,iBAAiB,EAAE,cAAc,GAAG,IAAI;IAatE;;;OAGG;IACI,aAAa,IAAI,IAAI;IAK5B;;;OAGG;IACI,iBAAiB,IAAI,IAAI;IAIhC;;OAEG;IACI,wBAAwB,CAC7B,KAAK,EAAE,gBAAgB,GAAG,IAAI,EAC9B,OAAO,EAAE,iBAAiB,GACzB,IAAI;YAUO,aAAa;IAK3B,gBAAgB;IACT,kBAAkB,CAAC,QAAQ,UAAQ,GAAG,IAAI;IAqCjD,OAAO,CAAC,aAAa;IAKrB,OAAO,CAAC,aAAa;IAgBrB,OAAO,CAAC,eAAe;IAMvB;;OAEG;IACH,OAAO,CAAC,YAAY;IAUpB,OAAO,CAAC,cAAc;IA6BtB,OAAO,CAAC,qBAAqB;cASV,MAAM,IAAI,cAAc;CAO5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,YAAY,EAAE,gBAAgB,CAAC;KAChC;CACF"}
@@ -8,7 +8,7 @@ var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "
8
8
  import { __esDecorate, __runInitializers } from "tslib";
9
9
  import { css, LitElement, isServer, html } from "lit";
10
10
  import { customElement, property } from "lit/decorators.js";
11
- import { interactivityChecker, isArrowKeyPressed, getNextElementIndex } from "../../core/a11y.js";
11
+ import { interactivityChecker } from "../../core/a11y.js";
12
12
  import { forceType } from "../../core/decorators.js";
13
13
  import { isLean } from "../../core/dom.js";
14
14
  import { SbbDisabledMixin, SbbFormAssociatedMixin, SbbElementInternalsMixin } from "../../core/mixins.js";
@@ -286,17 +286,26 @@ let SbbToggleElement = (() => {
286
286
  evt.target !== this && evt.target.parentElement !== this) {
287
287
  return;
288
288
  }
289
- if (isArrowKeyPressed(evt)) {
290
- const checked = enabledToggleOptions.findIndex((toggleOption) => toggleOption.checked);
291
- const nextIndex = getNextElementIndex(evt, checked, enabledToggleOptions.length);
292
- if (!enabledToggleOptions[nextIndex].checked) {
293
- enabledToggleOptions[nextIndex].checked = true;
294
- enabledToggleOptions[nextIndex].focus();
295
- enabledToggleOptions[nextIndex].dispatchEvent(new InputEvent("input", { bubbles: true, composed: true }));
296
- }
289
+ const options = this.options;
290
+ const isRtl = this.matches(":dir(rtl)");
291
+ const currentIndex = options.findIndex((option) => option.checked) ?? options[0];
292
+ const availableOptions = options.slice(currentIndex + 1).concat(options.slice(0, currentIndex)).filter((o) => !o.disabled && interactivityChecker.isVisible(o));
293
+ if (!isRtl ? evt.key === " " || evt.key === "ArrowRight" : evt.key === "ArrowLeft") {
294
+ this._selectAndFocusOption(availableOptions[0]);
295
+ evt.preventDefault();
296
+ } else if (isRtl ? evt.key === " " || evt.key === "ArrowRight" : evt.key === "ArrowLeft") {
297
+ this._selectAndFocusOption(availableOptions.at(-1));
297
298
  evt.preventDefault();
298
299
  }
299
300
  }
301
+ _selectAndFocusOption(option) {
302
+ if (!option || option.disabled || option.checked) {
303
+ return;
304
+ }
305
+ option.checked = true;
306
+ option.focus();
307
+ option.dispatchEvent(new InputEvent("input", { bubbles: true, composed: true }));
308
+ }
300
309
  render() {
301
310
  return html`
302
311
  <div class="sbb-toggle">
@@ -329,4 +338,4 @@ let SbbToggleElement = (() => {
329
338
  export {
330
339
  SbbToggleElement
331
340
  };
332
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"toggle.component.js","sources":["../../../../../src/elements/toggle/toggle/toggle.component.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  LitElement,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { getNextElementIndex, interactivityChecker, isArrowKeyPressed } from '../../core/a11y.ts';\nimport { forceType } from '../../core/decorators.ts';\nimport { isLean } from '../../core/dom.ts';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbDisabledMixin,\n  SbbElementInternalsMixin,\n  SbbFormAssociatedMixin,\n} from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport { type SbbToggleOptionElement } from '../toggle-option.ts';\n\nimport style from './toggle.scss?lit&inline';\n\n/**\n * It can be used as a container for two `sbb-toggle-option`, acting as a toggle button.\n *\n * @slot - Use the unnamed slot to add `<sbb-toggle-option>` elements to the toggle.\n * @overrideType value - (T = string) | null\n */\nexport\n@customElement('sbb-toggle')\nclass SbbToggleElement<T = string> extends SbbDisabledMixin(\n  SbbFormAssociatedMixin(SbbElementInternalsMixin(LitElement)),\n) {\n  public static override readonly role = 'radiogroup';\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  public static readonly events = {\n    change: 'change',\n  } as const;\n\n  /**\n   * If true, set the width of the component fixed; if false,\n   * the width is dynamic based on the label of the sbb-toggle-option.\n   */\n  @forceType()\n  @property({ reflect: true, type: Boolean })\n  public accessor even: boolean = false;\n\n  /**\n   * Size variant, either m or s.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true }) public accessor size: 's' | 'm' = isLean() ? 's' : 'm';\n\n  /**\n   * The value of the toggle. It needs to be mutable since it is updated whenever\n   * a new option is selected (see the `onToggleOptionSelect()` method).\n   */\n  @property()\n  public set value(value: T | null) {\n    if (isServer || !this.hasUpdated) {\n      this._fallbackValue = value;\n    } else {\n      this._valueChanged(value);\n    }\n  }\n  public get value(): T | null {\n    return isServer\n      ? (this._fallbackValue ?? null)\n      : (this.options.find((o) => o.checked)?.value ?? this.options[0]?.value ?? null);\n  }\n  private _fallbackValue: T | null = null;\n\n  /** The child instances of sbb-toggle-option as an array. */\n  public get options(): SbbToggleOptionElement<T>[] {\n    return Array.from(\n      this.querySelectorAll?.<SbbToggleOptionElement<T>>('sbb-toggle-option') ?? [],\n    );\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('input', () => this._handleInput(), { passive: true });\n    this.addEventListener?.('keydown', (e) => this._handleKeyDown(e));\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues): void {\n    super.willUpdate(changedProperties);\n    if (changedProperties.has('disabled') || changedProperties.has('formDisabled')) {\n      this._updateDisabled();\n    }\n\n    // Before the first update, init with the fallback value.\n    // The willUpdate hook is safer than the 'value' setter.\n    if (!this.hasUpdated) {\n      this._valueChanged(this._fallbackValue);\n    }\n  }\n\n  /**\n   * Called whenever the value changes, both programmatically or by user interaction.\n   * @internal\n   */\n  public statusChanged(): void {\n    this.updateFormValue();\n    this.updatePillPosition();\n  }\n\n  /**\n   * Reset to the init value if present. Select the first option, otherwise.\n   * @internal\n   */\n  public formResetCallback(): void {\n    this.value = (this.hasAttribute('value') ? this.getAttribute('value') : null) as T;\n  }\n\n  /**\n   * @internal\n   */\n  public formStateRestoreCallback(\n    state: FormRestoreState | null,\n    _reason: FormRestoreReason,\n  ): void {\n    if (typeof state === 'string' || state == null) {\n      this.value = (state as T) ?? null;\n    } else if (state instanceof FormData) {\n      this._readFormData(state).then((data) => {\n        this.value = data;\n      });\n    }\n  }\n\n  private async _readFormData(formData: FormData): Promise<T> {\n    const data = formData.get(this.name);\n    return data instanceof Blob ? JSON.parse(await data.text()) : (data as T);\n  }\n\n  /** @internal */\n  public updatePillPosition(resizing = false): void {\n    const options = this.options;\n    const toggleElement = this.shadowRoot?.querySelector<HTMLDivElement>('.sbb-toggle');\n\n    if (\n      options.length < 2 ||\n      !toggleElement ||\n      options.every((o) => !o.checked) ||\n      options.every((o) => !o.clientWidth)\n    ) {\n      return;\n    }\n\n    this.toggleState('disable-animation-on-resizing', resizing);\n\n    const firstOption = options[0];\n    const isFirstChecked = firstOption.checked;\n    const pillLeft = isFirstChecked ? '0px' : `${firstOption.clientWidth}px`;\n    const pillRight = isFirstChecked\n      ? `${toggleElement.clientWidth - firstOption.clientWidth}px`\n      : '0px';\n\n    if (pillRight === '0px' && pillLeft === '0px') {\n      return;\n    }\n\n    this.style?.setProperty('--sbb-toggle-option-left', pillLeft);\n    this.style?.setProperty('--sbb-toggle-option-right', pillRight);\n\n    // Triggers a layout reflow which is needed to avoid animation glitches.\n    // eslint-disable-next-line @typescript-eslint/no-unused-expressions\n    this.offsetWidth;\n\n    // In order to avoid a transition glitch, we have to know when the first values were set.\n    this.internals.states.add('initialized');\n  }\n\n  private _updateToggle(): void {\n    this._valueChanged(this.value);\n    this._updateDisabled();\n  }\n\n  private _valueChanged(value: T | null): void {\n    const options = this.options;\n\n    const selectedOption =\n      options.find((o) => value === o.value) ?? options.find((o) => o.checked) ?? options[0];\n\n    if (!selectedOption) {\n      if (import.meta.env.DEV && !isServer) {\n        console.warn(`sbb-toggle: No available options! (${this.id || 'No id'})`);\n      }\n      return;\n    }\n    selectedOption.checked = true;\n    this.statusChanged();\n  }\n\n  private _updateDisabled(): void {\n    for (const toggleOption of this.options) {\n      toggleOption.disabled = this.disabled || this.formDisabled;\n    }\n  }\n\n  /**\n   * Called on user interaction (click or keyboard)\n   */\n  private _handleInput(): void {\n    this.statusChanged();\n    /**\n     * The change event is fired when the user modifies the element's value.\n     * Unlike the input event, the change event is not necessarily fired\n     * for each alteration to an element's value.\n     */\n    this.dispatchEvent(new Event('change', { bubbles: true }));\n  }\n\n  private _handleKeyDown(evt: KeyboardEvent): void {\n    const enabledToggleOptions = this.options.filter(\n      (t) => !t.disabled && interactivityChecker.isVisible(t),\n    );\n\n    if (\n      !enabledToggleOptions ||\n      // don't trap nested handling\n      ((evt.target as HTMLElement) !== this && (evt.target as HTMLElement).parentElement !== this)\n    ) {\n      return;\n    }\n\n    if (isArrowKeyPressed(evt)) {\n      const checked: number = enabledToggleOptions.findIndex(\n        (toggleOption: SbbToggleOptionElement<T>) => toggleOption.checked,\n      );\n      const nextIndex: number = getNextElementIndex(evt, checked, enabledToggleOptions.length);\n      if (!enabledToggleOptions[nextIndex].checked) {\n        enabledToggleOptions[nextIndex].checked = true;\n        enabledToggleOptions[nextIndex].focus();\n        enabledToggleOptions[nextIndex].dispatchEvent(\n          new InputEvent('input', { bubbles: true, composed: true }),\n        );\n      }\n      evt.preventDefault();\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-toggle\">\n        <slot @slotchange=${this._updateToggle}></slot>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-toggle': SbbToggleElement;\n  }\n}\n"],"names":[],"mappings":"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"}
341
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"toggle.component.js","sources":["../../../../../src/elements/toggle/toggle/toggle.component.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  LitElement,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { interactivityChecker } from '../../core/a11y.ts';\nimport { forceType } from '../../core/decorators.ts';\nimport { isLean } from '../../core/dom.ts';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbDisabledMixin,\n  SbbElementInternalsMixin,\n  SbbFormAssociatedMixin,\n} from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport { type SbbToggleOptionElement } from '../toggle-option.ts';\n\nimport style from './toggle.scss?lit&inline';\n\n/**\n * It can be used as a container for two `sbb-toggle-option`, acting as a toggle button.\n *\n * @slot - Use the unnamed slot to add `<sbb-toggle-option>` elements to the toggle.\n * @overrideType value - (T = string) | null\n */\nexport\n@customElement('sbb-toggle')\nclass SbbToggleElement<T = string> extends SbbDisabledMixin(\n  SbbFormAssociatedMixin(SbbElementInternalsMixin(LitElement)),\n) {\n  public static override readonly role = 'radiogroup';\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  public static readonly events = {\n    change: 'change',\n  } as const;\n\n  /**\n   * If true, set the width of the component fixed; if false,\n   * the width is dynamic based on the label of the sbb-toggle-option.\n   */\n  @forceType()\n  @property({ reflect: true, type: Boolean })\n  public accessor even: boolean = false;\n\n  /**\n   * Size variant, either m or s.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true }) public accessor size: 's' | 'm' = isLean() ? 's' : 'm';\n\n  /**\n   * The value of the toggle. It needs to be mutable since it is updated whenever\n   * a new option is selected (see the `onToggleOptionSelect()` method).\n   */\n  @property()\n  public set value(value: T | null) {\n    if (isServer || !this.hasUpdated) {\n      this._fallbackValue = value;\n    } else {\n      this._valueChanged(value);\n    }\n  }\n  public get value(): T | null {\n    return isServer\n      ? (this._fallbackValue ?? null)\n      : (this.options.find((o) => o.checked)?.value ?? this.options[0]?.value ?? null);\n  }\n  private _fallbackValue: T | null = null;\n\n  /** The child instances of sbb-toggle-option as an array. */\n  public get options(): SbbToggleOptionElement<T>[] {\n    return Array.from(\n      this.querySelectorAll?.<SbbToggleOptionElement<T>>('sbb-toggle-option') ?? [],\n    );\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('input', () => this._handleInput(), { passive: true });\n    this.addEventListener?.('keydown', (e) => this._handleKeyDown(e));\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues): void {\n    super.willUpdate(changedProperties);\n    if (changedProperties.has('disabled') || changedProperties.has('formDisabled')) {\n      this._updateDisabled();\n    }\n\n    // Before the first update, init with the fallback value.\n    // The willUpdate hook is safer than the 'value' setter.\n    if (!this.hasUpdated) {\n      this._valueChanged(this._fallbackValue);\n    }\n  }\n\n  /**\n   * Called whenever the value changes, both programmatically or by user interaction.\n   * @internal\n   */\n  public statusChanged(): void {\n    this.updateFormValue();\n    this.updatePillPosition();\n  }\n\n  /**\n   * Reset to the init value if present. Select the first option, otherwise.\n   * @internal\n   */\n  public formResetCallback(): void {\n    this.value = (this.hasAttribute('value') ? this.getAttribute('value') : null) as T;\n  }\n\n  /**\n   * @internal\n   */\n  public formStateRestoreCallback(\n    state: FormRestoreState | null,\n    _reason: FormRestoreReason,\n  ): void {\n    if (typeof state === 'string' || state == null) {\n      this.value = (state as T) ?? null;\n    } else if (state instanceof FormData) {\n      this._readFormData(state).then((data) => {\n        this.value = data;\n      });\n    }\n  }\n\n  private async _readFormData(formData: FormData): Promise<T> {\n    const data = formData.get(this.name);\n    return data instanceof Blob ? JSON.parse(await data.text()) : (data as T);\n  }\n\n  /** @internal */\n  public updatePillPosition(resizing = false): void {\n    const options = this.options;\n    const toggleElement = this.shadowRoot?.querySelector<HTMLDivElement>('.sbb-toggle');\n\n    if (\n      options.length < 2 ||\n      !toggleElement ||\n      options.every((o) => !o.checked) ||\n      options.every((o) => !o.clientWidth)\n    ) {\n      return;\n    }\n\n    this.toggleState('disable-animation-on-resizing', resizing);\n\n    const firstOption = options[0];\n    const isFirstChecked = firstOption.checked;\n    const pillLeft = isFirstChecked ? '0px' : `${firstOption.clientWidth}px`;\n    const pillRight = isFirstChecked\n      ? `${toggleElement.clientWidth - firstOption.clientWidth}px`\n      : '0px';\n\n    if (pillRight === '0px' && pillLeft === '0px') {\n      return;\n    }\n\n    this.style?.setProperty('--sbb-toggle-option-left', pillLeft);\n    this.style?.setProperty('--sbb-toggle-option-right', pillRight);\n\n    // Triggers a layout reflow which is needed to avoid animation glitches.\n    // eslint-disable-next-line @typescript-eslint/no-unused-expressions\n    this.offsetWidth;\n\n    // In order to avoid a transition glitch, we have to know when the first values were set.\n    this.internals.states.add('initialized');\n  }\n\n  private _updateToggle(): void {\n    this._valueChanged(this.value);\n    this._updateDisabled();\n  }\n\n  private _valueChanged(value: T | null): void {\n    const options = this.options;\n\n    const selectedOption =\n      options.find((o) => value === o.value) ?? options.find((o) => o.checked) ?? options[0];\n\n    if (!selectedOption) {\n      if (import.meta.env.DEV && !isServer) {\n        console.warn(`sbb-toggle: No available options! (${this.id || 'No id'})`);\n      }\n      return;\n    }\n    selectedOption.checked = true;\n    this.statusChanged();\n  }\n\n  private _updateDisabled(): void {\n    for (const toggleOption of this.options) {\n      toggleOption.disabled = this.disabled || this.formDisabled;\n    }\n  }\n\n  /**\n   * Called on user interaction (click or keyboard)\n   */\n  private _handleInput(): void {\n    this.statusChanged();\n    /**\n     * The change event is fired when the user modifies the element's value.\n     * Unlike the input event, the change event is not necessarily fired\n     * for each alteration to an element's value.\n     */\n    this.dispatchEvent(new Event('change', { bubbles: true }));\n  }\n\n  private _handleKeyDown(evt: KeyboardEvent): void {\n    const enabledToggleOptions = this.options.filter(\n      (t) => !t.disabled && interactivityChecker.isVisible(t),\n    );\n\n    if (\n      !enabledToggleOptions ||\n      // don't trap nested handling\n      ((evt.target as HTMLElement) !== this && (evt.target as HTMLElement).parentElement !== this)\n    ) {\n      return;\n    }\n\n    const options = this.options;\n    const isRtl = this.matches(':dir(rtl)');\n    const currentIndex = options.findIndex((option) => option.checked) ?? options[0];\n    const availableOptions = options\n      .slice(currentIndex + 1)\n      .concat(options.slice(0, currentIndex))\n      .filter((o) => !o.disabled && interactivityChecker.isVisible(o));\n    if (!isRtl ? evt.key === ' ' || evt.key === 'ArrowRight' : evt.key === 'ArrowLeft') {\n      this._selectAndFocusOption(availableOptions[0]);\n      evt.preventDefault();\n    } else if (isRtl ? evt.key === ' ' || evt.key === 'ArrowRight' : evt.key === 'ArrowLeft') {\n      this._selectAndFocusOption(availableOptions.at(-1));\n      evt.preventDefault();\n    }\n  }\n\n  private _selectAndFocusOption(option: SbbToggleOptionElement<T> | undefined): void {\n    if (!option || option.disabled || option.checked) {\n      return;\n    }\n    option.checked = true;\n    option.focus();\n    option.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-toggle\">\n        <slot @slotchange=${this._updateToggle}></slot>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-toggle': SbbToggleElement;\n  }\n}\n"],"names":[],"mappings":"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"}
@@ -14,7 +14,7 @@ import { i18nOptional as ye } from "../../core/i18n.js";
14
14
  import { SbbNegativeMixin as xe, SbbElementInternalsMixin as we, SbbHydrationMixin as Ee, removeAriaElements as ke, appendAriaElements as ze } from "../../core/mixins.js";
15
15
  import { boxSizingStyles as Ie } from "../../core/styles.js";
16
16
  import "../../icon.js";
17
- const Se = pe`@charset "UTF-8";:host{display:inline-block;color:var(--sbb-color-3);--sbb-form-field-background-color: var(--sbb-background-color-1);--sbb-form-field-border-color: var(--sbb-border-color-5);--sbb-form-field-border-style: solid;--sbb-form-field-border-radius: var(--sbb-border-radius-4x);--sbb-form-field-border-width: var(--sbb-border-width-1x);--sbb-form-field-min-height: var(--sbb-size-element-m);--sbb-form-field-label-color: var(--sbb-color-metal);--sbb-form-field-label-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));--sbb-form-field-prefix-color: var(--sbb-color-metal);--sbb-form-field-prefix-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));--sbb-form-field-padding-inline: var(--sbb-spacing-fixed-3x);--sbb-form-field-text-color: var(--sbb-color-3);--sbb-form-field-arrow-color: var(--sbb-color-3);--sbb-form-field-error-divider-width: var(--sbb-spacing-fixed-1x);--sbb-form-field-error-padding-block-start: var(--sbb-form-field-error-divider-width);--sbb-form-field-gap: var(--sbb-spacing-fixed-2x);--sbb-form-field-label-to-input-overlapping: var(--sbb-spacing-fixed-1x);--sbb-form-field-select-inline-padding-end: calc( var(--sbb-icon-svg-width) + var(--sbb-form-field-gap) );--sbb-form-field-overflow: hidden;--sbb-form-field-input-text-size: var(--sbb-text-font-size-m);--sbb-form-field-label-text-size: var(--sbb-text-font-size-xs);--sbb-form-field-label-size: calc( var(--sbb-form-field-label-text-size) * var(--sbb-typo-line-height-text) );--sbb-form-field-text-line-height: calc( var(--sbb-form-field-input-text-size) * var(--sbb-typo-line-height-text) );--sbb-form-field-margin-block-start: calc( ( var(--sbb-form-field-min-height) - var(--sbb-form-field-label-size) - var( --sbb-form-field-text-line-height ) + var(--sbb-form-field-label-to-input-overlapping) ) / 2 );--sbb-form-field-spacer-margin-block-end: calc( -1 * var(--sbb-form-field-label-to-input-overlapping) );--sbb-form-field-floating-label-transform: .53125rem;--sbb-icon-svg-width: var(--sbb-size-icon-ui-small);--sbb-icon-svg-height: var(--sbb-size-icon-ui-small);--sbb-focus-outline-color: var(--sbb-focus-outline-color-default);--sbb-focus-outline-color: light-dark( var(--sbb-focus-outline-color-default), var(--sbb-focus-outline-color-dark) )}@media(min-width:64rem){:host{--sbb-form-field-floating-label-transform: .65625rem}}@media(forced-colors:active){:host{--sbb-form-field-border-color: ButtonBorder}}:host(:where(:not([width=collapse]))){min-width:9.375rem;width:min(18.75rem,100%)}:host([negative]){color:var(--sbb-color-3-negative);--sbb-form-field-background-color: var(--sbb-background-color-1-negative);--sbb-form-field-border-color: var(--sbb-border-color-5);--sbb-form-field-label-color: var(--sbb-color-5);--sbb-form-field-prefix-color: var(--sbb-color-5);--sbb-form-field-text-color: var(--sbb-color-3-negative);--sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);--sbb-form-field-arrow-color: var(--sbb-color-3-negative)}@media(forced-colors:active){:host([negative]){--sbb-form-field-border-color: ButtonBorder}}:host([size=s]){--sbb-form-field-min-height: var(--sbb-size-element-xs);--sbb-form-field-padding-inline: var(--sbb-spacing-fixed-2x);--sbb-form-field-input-text-size: var(--sbb-text-font-size-s);--sbb-form-field-label-text-size: var(--sbb-text-font-size-xxs);--sbb-form-field-label-to-input-overlapping: .625rem;--sbb-form-field-floating-label-transform: .34375rem;--sbb-form-field-spacer-margin-block-end: -.53125rem}@media(min-width:64rem){:host([size=s]){--sbb-form-field-label-to-input-overlapping: .6875rem;--sbb-form-field-floating-label-transform: .3125rem;--sbb-form-field-spacer-margin-block-end: -.5rem}}:host([size=l]){--sbb-form-field-min-height: var(--sbb-size-element-l);--sbb-form-field-padding-inline: var(--sbb-spacing-responsive-xxxs)}:host([error-space=reserve]){--sbb-form-field-error-min-height: calc( var(--sbb-typo-line-height-text) * var(--sbb-text-font-size-xs) );--sbb-form-field-error-padding-block-start-override: var(--sbb-form-field-error-divider-width)}:host(:where(:is(:state(readonly),[state--readonly]),:is(:state(disabled),[state--disabled]))){--sbb-form-field-background-color: var(--sbb-background-color-3);--sbb-form-field-border-color: var(--sbb-color-graphite);--sbb-form-field-border-color: light-dark(var(--sbb-color-graphite), var(--sbb-color-smoke));--sbb-form-field-arrow-color: var(--sbb-color-granite);--sbb-form-field-arrow-color: light-dark(var(--sbb-color-granite), var(--sbb-color-storm))}@media(forced-colors:active){:host(:where(:is(:state(readonly),[state--readonly]),:is(:state(disabled),[state--disabled]))){--sbb-form-field-border-color: ButtonBorder}}:host(:where(:is(:state(readonly),[state--readonly]),:is(:state(disabled),[state--disabled]))[negative]){--sbb-form-field-background-color: var(--sbb-background-color-3-negative);--sbb-form-field-border-color: var(--sbb-border-color-5);--sbb-form-field-arrow-color: var(--sbb-border-color-5)}:host(:where(:is(:state(disabled),[state--disabled]))){--sbb-form-field-label-color: var(--sbb-color-granite);--sbb-form-field-label-color: light-dark(var(--sbb-color-granite), var(--sbb-color-smoke));--sbb-form-field-prefix-color: var(--sbb-color-granite);--sbb-form-field-prefix-color: light-dark(var(--sbb-color-granite), var(--sbb-color-storm));--sbb-form-field-border-style: dashed}@media(forced-colors:active){:host(:where(:is(:state(disabled),[state--disabled]))){--sbb-form-field-label-color: GrayText !important;--sbb-form-field-prefix-color: GrayText !important;--sbb-form-field-text-color: GrayText !important;--sbb-form-field-border-color: GrayText !important}}:host(:where(:is(:state(disabled),[state--disabled]))[negative]){--sbb-form-field-text-color: var(--sbb-color-5);--sbb-form-field-label-color: var(--sbb-color-5);--sbb-form-field-prefix-color: var(--sbb-color-5)}:host(:where(:is(:state(readonly),[state--readonly])):not([negative])){--sbb-form-field-label-color: var(--sbb-color-granite);--sbb-form-field-label-color: light-dark(var(--sbb-color-granite), var(--sbb-color-smoke));--sbb-form-field-prefix-color: var(--sbb-color-granite);--sbb-form-field-prefix-color: light-dark(var(--sbb-color-granite), var(--sbb-color-storm))}:host(:where(:is(:state(focus),[state--focus]))){--sbb-form-field-border-color: var(--sbb-border-color-3);--sbb-form-field-prefix-color: var(--sbb-color-3);--sbb-form-field-border-width: var(--sbb-border-width-2x)}:host(:where(:is(:state(focus),[state--focus]))[negative]){--sbb-form-field-border-color: var(--sbb-border-color-3-negative);--sbb-form-field-prefix-color: var(--sbb-color-3-negative)}@media(forced-colors:active){:host(:is(:state(focus),[state--focus])){--sbb-form-field-border-color: Highlight;--sbb-form-field-prefix-color: Highlight}}:host(:not(:where(:is(:state(has-error),[state--has-error])))){--sbb-form-field-error-padding-block-start: 0}:host([floating-label]){--sbb-select-placeholder-color: transparent}@media(forced-colors:active){:host([floating-label]){--sbb-select-placeholder-color: Canvas}}:host(:is(:not(:is(:state(slotted-label),[state--slotted-label])),[hidden-label])){--sbb-form-field-label-size: 0rem;--sbb-form-field-label-to-input-overlapping: 0rem}:host(:where(:is(:state(input-type-sbb-slider),[state--input-type-sbb-slider]))){--sbb-form-field-overflow: visible}:host(:where(:is(:state(input-type-textarea),[state--input-type-textarea]))){--sbb-form-field-max-height: fit-content}.sbb-form-field__space-wrapper{display:flex;flex-direction:column}.sbb-form-field__space-wrapper:before{content:"​";-webkit-user-select:none;user-select:none;width:0;height:0}.sbb-form-field__wrapper{display:flex;gap:var(--sbb-form-field-gap);padding-inline:var(--sbb-form-field-padding-inline);border-radius:var(--sbb-form-field-border-radius);min-height:var(--sbb-form-field-min-height);max-height:var(--sbb-form-field-max-height);background-color:var(--sbb-form-field-background-color);position:relative}.sbb-form-field__wrapper:before{content:"";display:block;position:absolute;inset:0;border:var(--sbb-form-field-border-width) var(--sbb-form-field-border-style) var(--sbb-form-field-border-color);border-radius:var(--sbb-form-field-border-radius)}:host(:where(:is(:state(focus),[state--focus]):is(:state(focus-origin-keyboard),[state--focus-origin-keyboard]))) .sbb-form-field__wrapper{outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);outline-offset:var(--sbb-form-field-outline-offset, var(--sbb-focus-outline-offset))}@media(forced-colors:none){:host(:is([borderless],:is(:state(input-type-sbb-slider),[state--input-type-sbb-slider]))) .sbb-form-field__wrapper:before{border-color:transparent}:host(:where(:is(:state(focus),[state--focus]),:is(:state(disabled),[state--disabled]))[borderless]) .sbb-form-field__wrapper:after{content:"";position:absolute;border-block-end:var(--sbb-border-width-1x) var(--sbb-form-field-border-style) var(--sbb-form-field-border-color);inset-inline:var(--sbb-form-field-padding-inline);inset-block-end:0;z-index:var(--sbb-form-field-focus-underline-z-index, initial)}}::slotted(*[slot=prefix]){color:var(--sbb-form-field-prefix-color)}::slotted(*[slot=prefix]),::slotted(*[slot=suffix]){display:flex;min-width:var(--sbb-icon-svg-width);margin-block-start:calc((var(--sbb-form-field-min-height) - var(--sbb-size-icon-ui-small)) / 2)}:host(:where(:is(:state(empty),[state--empty]),:is(:state(disabled),[state--disabled]),:is(:state(readonly),[state--readonly]))) ::slotted(sbb-form-field-clear){display:none}::slotted(sbb-datepicker-toggle){padding-block-end:calc((var(--sbb-form-field-min-height) - var(--sbb-size-icon-ui-small)) / 2)}@media(forced-colors:active){::slotted(*[slot=suffix]){color:var(--sbb-form-field-prefix-color)}}.sbb-form-field__select-input-icon{top:50%;transform:translateY(-50%);position:absolute;inset-inline-end:0;margin-block-start:calc(-1 * var(--sbb-form-field-margin-block-start) / 2);pointer-events:none;color:var(--sbb-form-field-arrow-color)}.sbb-form-field__input-container{flex:1 1 auto;position:relative;margin-block-start:var(--sbb-form-field-margin-block-start);min-width:0}.sbb-form-field__label-spacer{display:flex;height:calc(var(--sbb-form-field-label-text-size) * var(--sbb-typo-line-height-text));margin-block-end:var(--sbb-form-field-spacer-margin-block-end)}:host(:not(:is(:state(slotted-label),[state--slotted-label]))) :is(.sbb-form-field__label,.sbb-form-field__label-spacer){display:none}:host([hidden-label]) :is(.sbb-form-field__label,.sbb-form-field__label-spacer){border:0;clip-path:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.sbb-form-field__label{display:flex;max-width:100%;cursor:var(--sbb-cursor-default);position:absolute;inset-block-start:0;color:var(--sbb-form-field-label-color);--sbb-text-font-size: var(--sbb-text-font-size-xs);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-text);letter-spacing:var(--sbb-typo-letter-spacing-text);font-size:var(--sbb-text-font-size)}:host([size=s]) .sbb-form-field__label{--sbb-text-font-size: var(--sbb-text-font-size-xxs);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-text);letter-spacing:var(--sbb-typo-letter-spacing-text);font-size:var(--sbb-text-font-size)}:host(:where(:is(:state(input-type-select),[state--input-type-select]),:is(:state(input-type-sbb-select),[state--input-type-sbb-select]))) .sbb-form-field__label{padding-inline-end:var(--sbb-form-field-select-inline-padding-end)}:host([floating-label]) .sbb-form-field__label{transform-origin:0 0;pointer-events:none;backface-visibility:hidden;will-change:transform,font-size;transition-duration:var(--sbb-disable-animation-duration, var(--sbb-animation-duration-2x));transition-timing-function:var(--sbb-animation-easing);transition-property:transform,font-size}:host([floating-label]:is(:not(:where(:is(:state(focus),[state--focus])):not(:where(:is(:state(input-type-sbb-select),[state--input-type-sbb-select]))),:where(:is(:state(has-popup-open),[state--has-popup-open]))),:where(:is(:state(readonly),[state--readonly]))):where(:is(:state(empty),[state--empty]))) .sbb-form-field__label{font-size:var(--sbb-form-field-input-text-size);transform:translateY(var(--sbb-form-field-floating-label-transform))}@media(forced-colors:active){:host(:where(:is(:state(input-type-textarea),[state--input-type-textarea]))) .sbb-form-field__label{z-index:1}}.sbb-form-field__label-ellipsis{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.sbb-form-field__input{display:flex}:host([size=s]:is(:is(:state(input-type-input),[state--input-type-input]),:is(:state(input-type-select),[state--input-type-select]),:is(:state(input-type-sbb-select),[state--input-type-sbb-select]),:is(:state(input-type-sbb-date-input),[state--input-type-sbb-date-input]),:is(:state(input-type-sbb-time-input),[state--input-type-sbb-time-input]))) .sbb-form-field__input{margin-block-end:-.125rem}.sbb-form-field__error{display:flex;min-height:var(--sbb-form-field-error-min-height);margin-block-start:var(--sbb-form-field-error-padding-block-start-override, var(--sbb-form-field-error-padding-block-start))}`;
17
+ const Se = pe`@charset "UTF-8";:host{display:inline-block;color:var(--sbb-color-3);--sbb-form-field-background-color: var(--sbb-background-color-1);--sbb-form-field-border-color: var(--sbb-border-color-5);--sbb-form-field-border-style: solid;--sbb-form-field-border-radius: var(--sbb-border-radius-4x);--sbb-form-field-border-width: var(--sbb-border-width-1x);--sbb-form-field-min-height: var(--sbb-size-element-m);--sbb-form-field-label-color: var(--sbb-color-metal);--sbb-form-field-label-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));--sbb-form-field-prefix-color: var(--sbb-color-metal);--sbb-form-field-prefix-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));--sbb-form-field-padding-inline: var(--sbb-spacing-fixed-3x);--sbb-form-field-text-color: var(--sbb-color-3);--sbb-form-field-arrow-color: var(--sbb-color-3);--sbb-form-field-error-divider-width: var(--sbb-spacing-fixed-1x);--sbb-form-field-error-padding-block-start: var(--sbb-form-field-error-divider-width);--sbb-form-field-gap: var(--sbb-spacing-fixed-2x);--sbb-form-field-label-to-input-overlapping: var(--sbb-spacing-fixed-1x);--sbb-form-field-select-inline-padding-end: calc( var(--sbb-icon-svg-width) + var(--sbb-form-field-gap) );--sbb-form-field-overflow: hidden;--sbb-form-field-input-text-size: var(--sbb-text-font-size-m);--sbb-form-field-label-text-size: var(--sbb-text-font-size-xs);--sbb-form-field-label-size: calc( var(--sbb-form-field-label-text-size) * var(--sbb-typo-line-height-text) );--sbb-form-field-text-line-height: calc( var(--sbb-form-field-input-text-size) * var(--sbb-typo-line-height-text) );--sbb-form-field-margin-block-start: calc( ( var(--sbb-form-field-min-height) - var(--sbb-form-field-label-size) - var( --sbb-form-field-text-line-height ) + var(--sbb-form-field-label-to-input-overlapping) ) / 2 );--sbb-form-field-spacer-margin-block-end: calc( -1 * var(--sbb-form-field-label-to-input-overlapping) );--sbb-form-field-floating-label-transform: .53125rem;--sbb-icon-svg-width: var(--sbb-size-icon-ui-small);--sbb-icon-svg-height: var(--sbb-size-icon-ui-small);--sbb-focus-outline-color: var(--sbb-focus-outline-color-default);--sbb-focus-outline-color: light-dark( var(--sbb-focus-outline-color-default), var(--sbb-focus-outline-color-dark) )}@media(min-width:64rem){:host{--sbb-form-field-floating-label-transform: .65625rem}}@media(forced-colors:active){:host{--sbb-form-field-border-color: ButtonBorder}}:host(:where(:not([width=collapse]))){min-width:9.375rem;width:min(18.75rem,100%)}:host([negative]){color:var(--sbb-color-3-negative);--sbb-form-field-background-color: var(--sbb-background-color-1-negative);--sbb-form-field-border-color: var(--sbb-border-color-5);--sbb-form-field-label-color: var(--sbb-color-5);--sbb-form-field-prefix-color: var(--sbb-color-5);--sbb-form-field-text-color: var(--sbb-color-3-negative);--sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);--sbb-form-field-arrow-color: var(--sbb-color-3-negative)}@media(forced-colors:active){:host([negative]){--sbb-form-field-border-color: ButtonBorder}}:host([size=s]){--sbb-form-field-min-height: var(--sbb-size-element-xs);--sbb-form-field-padding-inline: var(--sbb-spacing-fixed-2x);--sbb-form-field-input-text-size: var(--sbb-text-font-size-s);--sbb-form-field-label-text-size: var(--sbb-text-font-size-xxs);--sbb-form-field-label-to-input-overlapping: .625rem;--sbb-form-field-floating-label-transform: .34375rem;--sbb-form-field-spacer-margin-block-end: -.53125rem}@media(min-width:64rem){:host([size=s]){--sbb-form-field-label-to-input-overlapping: .6875rem;--sbb-form-field-floating-label-transform: .3125rem;--sbb-form-field-spacer-margin-block-end: -.5rem}}:host([size=l]){--sbb-form-field-min-height: var(--sbb-size-element-l);--sbb-form-field-padding-inline: var(--sbb-spacing-responsive-xxxs)}:host([error-space=reserve]){--sbb-form-field-error-min-height: calc( var(--sbb-typo-line-height-text) * var(--sbb-text-font-size-xs) );--sbb-form-field-error-padding-block-start-override: var(--sbb-form-field-error-divider-width)}:host(:where(:is(:state(readonly),[state--readonly]),:is(:state(disabled),[state--disabled]))){--sbb-form-field-background-color: var(--sbb-background-color-3);--sbb-form-field-border-color: var(--sbb-color-graphite);--sbb-form-field-border-color: light-dark(var(--sbb-color-graphite), var(--sbb-color-smoke));--sbb-form-field-arrow-color: var(--sbb-color-granite);--sbb-form-field-arrow-color: light-dark(var(--sbb-color-granite), var(--sbb-color-storm))}@media(forced-colors:active){:host(:where(:is(:state(readonly),[state--readonly]),:is(:state(disabled),[state--disabled]))){--sbb-form-field-border-color: ButtonBorder}}:host(:where(:is(:state(readonly),[state--readonly]),:is(:state(disabled),[state--disabled]))[negative]){--sbb-form-field-background-color: var(--sbb-background-color-3-negative);--sbb-form-field-border-color: var(--sbb-border-color-5);--sbb-form-field-arrow-color: var(--sbb-border-color-5)}:host(:where(:is(:state(disabled),[state--disabled]))){--sbb-form-field-label-color: var(--sbb-color-granite);--sbb-form-field-label-color: light-dark(var(--sbb-color-granite), var(--sbb-color-smoke));--sbb-form-field-prefix-color: var(--sbb-color-granite);--sbb-form-field-prefix-color: light-dark(var(--sbb-color-granite), var(--sbb-color-storm));--sbb-form-field-border-style: dashed}@media(forced-colors:active){:host(:where(:is(:state(disabled),[state--disabled]))){--sbb-form-field-label-color: GrayText !important;--sbb-form-field-prefix-color: GrayText !important;--sbb-form-field-text-color: GrayText !important;--sbb-form-field-border-color: GrayText !important}}:host(:where(:is(:state(disabled),[state--disabled]))[negative]){--sbb-form-field-text-color: var(--sbb-color-5);--sbb-form-field-label-color: var(--sbb-color-5);--sbb-form-field-prefix-color: var(--sbb-color-5)}:host(:where(:is(:state(readonly),[state--readonly])):not([negative])){--sbb-form-field-label-color: var(--sbb-color-granite);--sbb-form-field-label-color: light-dark(var(--sbb-color-granite), var(--sbb-color-smoke));--sbb-form-field-prefix-color: var(--sbb-color-granite);--sbb-form-field-prefix-color: light-dark(var(--sbb-color-granite), var(--sbb-color-storm))}:host(:where(:is(:state(focus),[state--focus]))){--sbb-form-field-border-color: var(--sbb-border-color-3);--sbb-form-field-prefix-color: var(--sbb-color-3);--sbb-form-field-border-width: var(--sbb-border-width-2x)}:host(:where(:is(:state(focus),[state--focus]))[negative]){--sbb-form-field-border-color: var(--sbb-border-color-3-negative);--sbb-form-field-prefix-color: var(--sbb-color-3-negative)}@media(forced-colors:active){:host(:is(:state(focus),[state--focus])){--sbb-form-field-border-color: Highlight;--sbb-form-field-prefix-color: Highlight}}:host(:not(:where(:is(:state(has-error),[state--has-error])))){--sbb-form-field-error-padding-block-start: 0}:host([floating-label]){--sbb-select-placeholder-color: transparent}@media(forced-colors:active){:host([floating-label]){--sbb-select-placeholder-color: Canvas}}:host(:is(:not(:is(:state(slotted-label),[state--slotted-label])),[hidden-label])){--sbb-form-field-label-size: 0rem;--sbb-form-field-label-to-input-overlapping: 0rem}:host(:where(:is(:state(input-type-sbb-slider),[state--input-type-sbb-slider]))){--sbb-form-field-overflow: visible}:host(:where(:is(:state(input-type-textarea),[state--input-type-textarea]))){--sbb-form-field-max-height: fit-content}.sbb-form-field__space-wrapper{display:flex;flex-direction:column}.sbb-form-field__space-wrapper:before{content:"​";-webkit-user-select:none;user-select:none;width:0;height:0}.sbb-form-field__wrapper{display:flex;gap:var(--sbb-form-field-gap);padding-inline:var(--sbb-form-field-padding-inline);border-radius:var(--sbb-form-field-border-radius);min-height:var(--sbb-form-field-min-height);max-height:var(--sbb-form-field-max-height);background-color:var(--sbb-form-field-background-color);position:relative}.sbb-form-field__wrapper:before{content:"";display:block;position:absolute;inset:0;border:var(--sbb-form-field-border-width) var(--sbb-form-field-border-style) var(--sbb-form-field-border-color);border-radius:var(--sbb-form-field-border-radius)}:host(:where(:is(:state(focus),[state--focus]):is(:state(focus-origin-keyboard),[state--focus-origin-keyboard]))) .sbb-form-field__wrapper{outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);outline-offset:var(--sbb-form-field-outline-offset, var(--sbb-focus-outline-offset))}@media(forced-colors:none){:host(:is([borderless],:is(:state(input-type-sbb-slider),[state--input-type-sbb-slider]))) .sbb-form-field__wrapper:before{border-color:transparent}:host(:where(:is(:state(focus),[state--focus]),:is(:state(disabled),[state--disabled]))[borderless]) .sbb-form-field__wrapper:after{content:"";position:absolute;border-block-end:var(--sbb-border-width-1x) var(--sbb-form-field-border-style) var(--sbb-form-field-border-color);inset-inline:var(--sbb-form-field-padding-inline);inset-block-end:0;z-index:var(--sbb-form-field-focus-underline-z-index, initial)}}::slotted(*[slot=prefix]){color:var(--sbb-form-field-prefix-color)}::slotted(*[slot=prefix]),::slotted(*[slot=suffix]){display:flex;min-width:var(--sbb-icon-svg-width);margin-block-start:calc((var(--sbb-form-field-min-height) - var(--sbb-size-icon-ui-small)) / 2)}:host(:where(:is(:state(empty),[state--empty]),:is(:state(disabled),[state--disabled]),:is(:state(readonly),[state--readonly]))) ::slotted(sbb-form-field-clear){display:none}::slotted(sbb-datepicker-toggle){padding-block-end:calc((var(--sbb-form-field-min-height) - var(--sbb-size-icon-ui-small)) / 2)}@media(forced-colors:active){::slotted(*[slot=suffix]){color:var(--sbb-form-field-prefix-color)}}.sbb-form-field__select-input-icon{top:50%;transform:translateY(-50%);position:absolute;inset-inline-end:0;margin-block-start:calc(-1 * var(--sbb-form-field-margin-block-start) / 2);pointer-events:none;color:var(--sbb-form-field-arrow-color)}.sbb-form-field__input-container{flex:1 1 auto;position:relative;margin-block-start:var(--sbb-form-field-margin-block-start);min-width:0}.sbb-form-field__label-spacer{display:flex;height:calc(var(--sbb-form-field-label-text-size) * var(--sbb-typo-line-height-text));margin-block-end:var(--sbb-form-field-spacer-margin-block-end)}:host(:not(:is(:state(slotted-label),[state--slotted-label]))) :is(.sbb-form-field__label,.sbb-form-field__label-spacer){display:none}:host([hidden-label]) :is(.sbb-form-field__label,.sbb-form-field__label-spacer){border:0;clip-path:rect(0 0 0 0);height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.sbb-form-field__label{display:flex;max-width:100%;cursor:var(--sbb-cursor-default);position:absolute;inset-block-start:0;color:var(--sbb-form-field-label-color);--sbb-text-font-size: var(--sbb-text-font-size-xs);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-text);letter-spacing:var(--sbb-typo-letter-spacing-text);font-size:var(--sbb-text-font-size)}:host([size=s]) .sbb-form-field__label{--sbb-text-font-size: var(--sbb-text-font-size-xxs);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-text);letter-spacing:var(--sbb-typo-letter-spacing-text);font-size:var(--sbb-text-font-size)}:host(:where(:is(:state(input-type-select),[state--input-type-select]),:is(:state(input-type-sbb-select),[state--input-type-sbb-select]))) .sbb-form-field__label{padding-inline-end:var(--sbb-form-field-select-inline-padding-end)}:host([floating-label]) .sbb-form-field__label{transform-origin:0 0;pointer-events:none;backface-visibility:hidden;will-change:transform,font-size;transition-duration:var(--sbb-disable-animation-duration, var(--sbb-animation-duration-2x));transition-timing-function:var(--sbb-animation-easing);transition-property:transform,font-size}:host([floating-label]:is(:not(:where(:is(:state(focus),[state--focus])):not(:where(:is(:state(input-type-sbb-select),[state--input-type-sbb-select]))),:where(:is(:state(has-popup-open),[state--has-popup-open]))),:where(:is(:state(readonly),[state--readonly]))):where(:is(:state(empty),[state--empty]))) .sbb-form-field__label{font-size:var(--sbb-form-field-input-text-size);transform:translateY(var(--sbb-form-field-floating-label-transform))}@media(forced-colors:active){:host(:where(:is(:state(input-type-textarea),[state--input-type-textarea]))) .sbb-form-field__label{z-index:1}}.sbb-form-field__label-ellipsis{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.sbb-form-field__input{display:flex}:host([size=s]:is(:is(:state(input-type-input),[state--input-type-input]),:is(:state(input-type-select),[state--input-type-select]),:is(:state(input-type-sbb-select),[state--input-type-sbb-select]),:is(:state(input-type-sbb-date-input),[state--input-type-sbb-date-input]),:is(:state(input-type-sbb-time-input),[state--input-type-sbb-time-input]))) .sbb-form-field__input{margin-block-end:-.125rem}.sbb-form-field__error{display:flex;min-height:var(--sbb-form-field-error-min-height);flex-direction:column;margin-block-start:var(--sbb-form-field-error-padding-block-start-override, var(--sbb-form-field-error-padding-block-start))}`;
18
18
  let ne = 0;
19
19
  const z = /* @__PURE__ */ new WeakMap(), be = ["input", "textarea", "select"];
20
20
  class qe extends Event {