@sbb-esta/lyne-elements 1.8.0 → 1.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (43) hide show
  1. package/clock.js +5 -5
  2. package/container/container.js +14 -14
  3. package/core/dom/platform.d.ts +2 -3
  4. package/core/dom/platform.d.ts.map +1 -1
  5. package/core/dom.js +38 -40
  6. package/core/styles/core.scss +6 -0
  7. package/core/styles/mixins/lists.scss +11 -1
  8. package/core/testing/wait-for-image-ready.d.ts.map +1 -1
  9. package/core/testing.js +61 -54
  10. package/core.css +5 -0
  11. package/custom-elements.json +123 -1
  12. package/datepicker/datepicker-toggle.js +3 -3
  13. package/development/clock.js +1 -1
  14. package/development/container/container.js +1 -1
  15. package/development/core/dom/platform.d.ts +2 -3
  16. package/development/core/dom/platform.d.ts.map +1 -1
  17. package/development/core/dom.js +4 -5
  18. package/development/core/testing/wait-for-image-ready.d.ts.map +1 -1
  19. package/development/core/testing.js +16 -2
  20. package/development/datepicker/datepicker-toggle.js +3 -3
  21. package/development/overlay.js +2 -9
  22. package/development/select/select.d.ts +3 -1
  23. package/development/select/select.d.ts.map +1 -1
  24. package/development/select.js +20 -6
  25. package/development/stepper/step-label.js +20 -2
  26. package/development/stepper/stepper/stepper.d.ts +3 -0
  27. package/development/stepper/stepper/stepper.d.ts.map +1 -1
  28. package/development/stepper/stepper.js +16 -1
  29. package/development/toggle/toggle-option/toggle-option.d.ts.map +1 -1
  30. package/development/toggle/toggle-option.js +2 -1
  31. package/lists.css +9 -1
  32. package/overlay.js +1 -1
  33. package/package.json +1 -1
  34. package/select/select.d.ts +3 -1
  35. package/select/select.d.ts.map +1 -1
  36. package/select.js +61 -50
  37. package/standard-theme.css +14 -1
  38. package/stepper/step-label.js +10 -10
  39. package/stepper/stepper/stepper.d.ts +3 -0
  40. package/stepper/stepper/stepper.d.ts.map +1 -1
  41. package/stepper/stepper.js +34 -25
  42. package/toggle/toggle-option/toggle-option.d.ts.map +1 -1
  43. package/toggle/toggle-option.js +1 -0
@@ -126,6 +126,7 @@ let SbbStepperElement = class extends SbbHydrationMixin(LitElement) {
126
126
  super(...arguments);
127
127
  this.linear = false;
128
128
  this.orientation = "horizontal";
129
+ this.size = "m";
129
130
  this._loaded = false;
130
131
  this._abort = new SbbConnectedAbortController(this);
131
132
  this._resizeObserverTimeout = null;
@@ -257,6 +258,7 @@ let SbbStepperElement = class extends SbbHydrationMixin(LitElement) {
257
258
  label.configure(i + 1, array.length, this._loaded);
258
259
  });
259
260
  this._select(this.selected || this._enabledSteps[0]);
261
+ this._proxySize();
260
262
  }
261
263
  _updateLabels() {
262
264
  this.steps.forEach((step) => {
@@ -318,6 +320,16 @@ let SbbStepperElement = class extends SbbHydrationMixin(LitElement) {
318
320
  if (changedProperties.has("linear") && this._loaded) {
319
321
  this._configureLinearMode();
320
322
  }
323
+ if (changedProperties.has("size")) {
324
+ this._proxySize();
325
+ this._setMarkerSize();
326
+ }
327
+ }
328
+ _proxySize() {
329
+ this.steps.forEach((step) => {
330
+ var _a;
331
+ (_a = step.label) == null ? void 0 : _a.setAttribute("data-size", this.size);
332
+ });
321
333
  }
322
334
  _handleKeyDown(evt) {
323
335
  const enabledSteps = this._enabledSteps;
@@ -355,6 +367,9 @@ __decorateClass([
355
367
  __decorateClass([
356
368
  property({ reflect: true })
357
369
  ], SbbStepperElement.prototype, "orientation", 2);
370
+ __decorateClass([
371
+ property({ reflect: true })
372
+ ], SbbStepperElement.prototype, "size", 2);
358
373
  __decorateClass([
359
374
  property({ attribute: false })
360
375
  ], SbbStepperElement.prototype, "selected", 1);
@@ -367,4 +382,4 @@ SbbStepperElement = __decorateClass([
367
382
  export {
368
383
  SbbStepperElement
369
384
  };
370
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"stepper.js","sources":["../../../../src/elements/stepper/stepper/stepper.ts"],"sourcesContent":["import {\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.js';\nimport { SbbConnectedAbortController } from '../../core/controllers.js';\nimport { breakpoints, isBreakpoint } from '../../core/dom.js';\nimport type { SbbHorizontalFrom, SbbOrientation } from '../../core/interfaces.js';\nimport { SbbHydrationMixin } from '../../core/mixins.js';\nimport type { SbbStepElement, SbbStepValidateEventDetails } from '../step.js';\n\nimport style from './stepper.scss?lit&inline';\n\nconst DEBOUNCE_TIME = 150;\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 */\n@customElement('sbb-stepper')\nexport class SbbStepperElement extends SbbHydrationMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n\n  /** If set to true, only the current and previous labels can be clicked and selected. */\n  @property({ type: Boolean }) public linear = false;\n\n  /** Overrides the behaviour of `orientation` property. */\n  @property({ attribute: 'horizontal-from', reflect: true })\n  public set horizontalFrom(value: SbbHorizontalFrom) {\n    this._horizontalFrom = breakpoints.includes(value) ? value : undefined;\n    if (this._horizontalFrom && this._loaded) {\n      this._checkOrientation();\n    }\n  }\n  public get horizontalFrom(): SbbHorizontalFrom | undefined {\n    return this._horizontalFrom;\n  }\n  private _horizontalFrom?: SbbHorizontalFrom | undefined;\n\n  /** Steps orientation, either horizontal or vertical. */\n  @property({ reflect: true })\n  public orientation: SbbOrientation = 'horizontal';\n\n  /** The currently selected step. */\n  @property({ attribute: false })\n  public set selected(step: SbbStepElement) {\n    if (this._loaded) {\n      this._select(step);\n    }\n  }\n  public get selected(): SbbStepElement | undefined {\n    return this.querySelector?.<SbbStepElement>('sbb-step[data-selected]') ?? undefined;\n  }\n\n  /** The currently selected step index. */\n  @property({ attribute: 'selected-index', type: Number })\n  public set selectedIndex(index: number) {\n    if (this._loaded) {\n      this._select(this.steps[index]);\n    }\n  }\n  public get selectedIndex(): number | undefined {\n    return this.selected ? this.steps.indexOf(this.selected) : undefined;\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  /** Selects the next step. */\n  public next(): void {\n    if (this.selectedIndex !== undefined) {\n      this._select(this.steps[this.selectedIndex + 1]);\n    }\n  }\n\n  /** Selects the previous step. */\n  public previous(): void {\n    if (this.selectedIndex !== undefined) {\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 _loaded: boolean = false;\n  private _abort = new SbbConnectedAbortController(this);\n  private _resizeObserverTimeout: ReturnType<typeof setTimeout> | null = null;\n\n  private _isValidStep(step: SbbStepElement): 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 !== undefined) {\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): void {\n    if (!this._isValidStep(step)) {\n      return;\n    }\n    const validatePayload: SbbStepValidateEventDetails = {\n      currentIndex: this.selectedIndex,\n      currentStep: this.selected,\n      nextIndex: this.selectedIndex !== undefined ? this.selectedIndex + 1 : undefined,\n      nextStep: this.selectedIndex !== undefined ? this.steps[this.selectedIndex + 1] : undefined,\n    };\n    if (this.selected && !this.selected.validate(validatePayload)) {\n      return;\n    }\n    const current = this.selected;\n    current?.deselect();\n    step.select();\n    this._setMarkerSize();\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  private _calculateLabelOffsetTop(): number | undefined {\n    if (this.selectedIndex === undefined) {\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 _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      step.setAttribute('data-orientation', this.orientation);\n      step.label?.setAttribute('data-orientation', this.orientation);\n    });\n  }\n\n  private _checkOrientation(): void {\n    if (this.horizontalFrom) {\n      this.orientation = isBreakpoint(this.horizontalFrom) ? 'horizontal' : '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    clearTimeout(this._resizeObserverTimeout!);\n    this.toggleAttribute('data-disable-animation', true);\n\n    // Disable the animation when resizing to avoid strange transition effects.\n    this._resizeObserverTimeout = setTimeout(\n      () => this.toggleAttribute('data-disable-animation', false),\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.hasAttribute('data-disabled')),\n      );\n    });\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    const signal = this._abort.signal;\n    this.addEventListener('keydown', (e) => this._handleKeyDown(e), { signal });\n    window.addEventListener('resize', () => this._onStepperResize(), {\n      signal,\n      passive: true,\n    });\n    this.toggleAttribute('data-disable-animation', !this._loaded);\n  }\n\n  protected override async firstUpdated(changedProperties: PropertyValues<this>): Promise<void> {\n    super.firstUpdated(changedProperties);\n    await this.updateComplete;\n    this._loaded = true;\n    this.selectedIndex = !this.linear ? Number(this.getAttribute('selected-index')) || 0 : 0;\n    this._checkOrientation();\n    // Remove [data-disable-animation] after component init\n    setTimeout(() => this.toggleAttribute('data-disable-animation', false), DEBOUNCE_TIME);\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\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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"}
385
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"stepper.js","sources":["../../../../src/elements/stepper/stepper/stepper.ts"],"sourcesContent":["import {\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.js';\nimport { SbbConnectedAbortController } from '../../core/controllers.js';\nimport { breakpoints, isBreakpoint } from '../../core/dom.js';\nimport type { SbbHorizontalFrom, SbbOrientation } from '../../core/interfaces.js';\nimport { SbbHydrationMixin } from '../../core/mixins.js';\nimport type { SbbStepElement, SbbStepValidateEventDetails } from '../step.js';\n\nimport style from './stepper.scss?lit&inline';\n\nconst DEBOUNCE_TIME = 150;\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 */\n@customElement('sbb-stepper')\nexport class SbbStepperElement extends SbbHydrationMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n\n  /** If set to true, only the current and previous labels can be clicked and selected. */\n  @property({ type: Boolean }) public linear = false;\n\n  /** Overrides the behaviour of `orientation` property. */\n  @property({ attribute: 'horizontal-from', reflect: true })\n  public set horizontalFrom(value: SbbHorizontalFrom) {\n    this._horizontalFrom = breakpoints.includes(value) ? value : undefined;\n    if (this._horizontalFrom && this._loaded) {\n      this._checkOrientation();\n    }\n  }\n  public get horizontalFrom(): SbbHorizontalFrom | undefined {\n    return this._horizontalFrom;\n  }\n  private _horizontalFrom?: SbbHorizontalFrom | undefined;\n\n  /** Steps orientation, either horizontal or vertical. */\n  @property({ reflect: true })\n  public orientation: SbbOrientation = 'horizontal';\n\n  /** Size variant, either s or m. */\n  @property({ reflect: true }) public size: 's' | 'm' = 'm';\n\n  /** The currently selected step. */\n  @property({ attribute: false })\n  public set selected(step: SbbStepElement) {\n    if (this._loaded) {\n      this._select(step);\n    }\n  }\n  public get selected(): SbbStepElement | undefined {\n    return this.querySelector?.<SbbStepElement>('sbb-step[data-selected]') ?? undefined;\n  }\n\n  /** The currently selected step index. */\n  @property({ attribute: 'selected-index', type: Number })\n  public set selectedIndex(index: number) {\n    if (this._loaded) {\n      this._select(this.steps[index]);\n    }\n  }\n  public get selectedIndex(): number | undefined {\n    return this.selected ? this.steps.indexOf(this.selected) : undefined;\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  /** Selects the next step. */\n  public next(): void {\n    if (this.selectedIndex !== undefined) {\n      this._select(this.steps[this.selectedIndex + 1]);\n    }\n  }\n\n  /** Selects the previous step. */\n  public previous(): void {\n    if (this.selectedIndex !== undefined) {\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 _loaded: boolean = false;\n  private _abort = new SbbConnectedAbortController(this);\n  private _resizeObserverTimeout: ReturnType<typeof setTimeout> | null = null;\n\n  private _isValidStep(step: SbbStepElement): 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 !== undefined) {\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): void {\n    if (!this._isValidStep(step)) {\n      return;\n    }\n    const validatePayload: SbbStepValidateEventDetails = {\n      currentIndex: this.selectedIndex,\n      currentStep: this.selected,\n      nextIndex: this.selectedIndex !== undefined ? this.selectedIndex + 1 : undefined,\n      nextStep: this.selectedIndex !== undefined ? this.steps[this.selectedIndex + 1] : undefined,\n    };\n    if (this.selected && !this.selected.validate(validatePayload)) {\n      return;\n    }\n    const current = this.selected;\n    current?.deselect();\n    step.select();\n    this._setMarkerSize();\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  private _calculateLabelOffsetTop(): number | undefined {\n    if (this.selectedIndex === undefined) {\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 _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    this._proxySize();\n  }\n\n  private _updateLabels(): void {\n    this.steps.forEach((step) => {\n      step.slot = this.orientation === 'horizontal' ? 'step' : 'step-label';\n      step.setAttribute('data-orientation', this.orientation);\n      step.label?.setAttribute('data-orientation', this.orientation);\n    });\n  }\n\n  private _checkOrientation(): void {\n    if (this.horizontalFrom) {\n      this.orientation = isBreakpoint(this.horizontalFrom) ? 'horizontal' : '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    clearTimeout(this._resizeObserverTimeout!);\n    this.toggleAttribute('data-disable-animation', true);\n\n    // Disable the animation when resizing to avoid strange transition effects.\n    this._resizeObserverTimeout = setTimeout(\n      () => this.toggleAttribute('data-disable-animation', false),\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.hasAttribute('data-disabled')),\n      );\n    });\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    const signal = this._abort.signal;\n    this.addEventListener('keydown', (e) => this._handleKeyDown(e), { signal });\n    window.addEventListener('resize', () => this._onStepperResize(), {\n      signal,\n      passive: true,\n    });\n    this.toggleAttribute('data-disable-animation', !this._loaded);\n  }\n\n  protected override async firstUpdated(changedProperties: PropertyValues<this>): Promise<void> {\n    super.firstUpdated(changedProperties);\n    await this.updateComplete;\n    this._loaded = true;\n    this.selectedIndex = !this.linear ? Number(this.getAttribute('selected-index')) || 0 : 0;\n    this._checkOrientation();\n    // Remove [data-disable-animation] after component init\n    setTimeout(() => this.toggleAttribute('data-disable-animation', false), DEBOUNCE_TIME);\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._proxySize();\n      this._setMarkerSize();\n    }\n  }\n\n  private _proxySize(): void {\n    this.steps.forEach((step) => {\n      step.label?.setAttribute('data-size', this.size);\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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAkBA,MAAM,gBAAgB;AASf,IAAM,oBAAN,cAAgC,kBAAkB,UAAU,EAAE;AAAA,EAA9D,cAAA;AAAA,UAAA,GAAA,SAAA;AAIwB,SAAO,SAAS;AAiB7C,SAAO,cAA8B;AAGR,SAAO,OAAkB;AA8DtD,SAAQ,UAAmB;AACnB,SAAA,SAAS,IAAI,4BAA4B,IAAI;AACrD,SAAQ,yBAA+D;AAAA,EAAA;AAAA,EAhFvE,IAAW,eAAe,OAA0B;AAClD,SAAK,kBAAkB,YAAY,SAAS,KAAK,IAAI,QAAQ;AACzD,QAAA,KAAK,mBAAmB,KAAK,SAAS;AACxC,WAAK,kBAAkB;AAAA,IACzB;AAAA,EACF;AAAA,EACA,IAAW,iBAAgD;AACzD,WAAO,KAAK;AAAA,EACd;AAAA,EAYA,IAAW,SAAS,MAAsB;AACxC,QAAI,KAAK,SAAS;AAChB,WAAK,QAAQ,IAAI;AAAA,IACnB;AAAA,EACF;AAAA,EACA,IAAW,WAAuC;;AACzC,aAAA,UAAK,kBAAL,8BAAqC,+BAA8B;AAAA,EAC5E;AAAA,EAIA,IAAW,cAAc,OAAe;AACtC,QAAI,KAAK,SAAS;AAChB,WAAK,QAAQ,KAAK,MAAM,KAAK,CAAC;AAAA,IAChC;AAAA,EACF;AAAA,EACA,IAAW,gBAAoC;AAC7C,WAAO,KAAK,WAAW,KAAK,MAAM,QAAQ,KAAK,QAAQ,IAAI;AAAA,EAC7D;AAAA;AAAA,EAGA,IAAW,QAA0B;;AACnC,WAAO,MAAM,OAAK,UAAK,qBAAL,8BAAwB,gBAAe,CAAA,CAAE;AAAA,EAC7D;AAAA,EAEA,IAAY,gBAAkC;AACrC,WAAA,KAAK,MAAM,OAAO,CAAC,MAAA;;AAAM,gBAAC,OAAE,UAAF,mBAAS,aAAa;AAAA,KAAW;AAAA,EACpE;AAAA;AAAA,EAGO,OAAa;AACd,QAAA,KAAK,kBAAkB,QAAW;AACpC,WAAK,QAAQ,KAAK,MAAM,KAAK,gBAAgB,CAAC,CAAC;AAAA,IACjD;AAAA,EACF;AAAA;AAAA,EAGO,WAAiB;AAClB,QAAA,KAAK,kBAAkB,QAAW;AACpC,WAAK,QAAQ,KAAK,MAAM,KAAK,gBAAgB,CAAC,CAAC;AAAA,IACjD;AAAA,EACF;AAAA;AAAA,EAGO,QAAc;;AACb,UAAA,cAAc,KAAK,QAAQ,MAAM;AACvC,QAAI,aAAa;AACf,kBAAY,MAAM;AAAA,IAAA,OACb;AACA,WAAA,iBAAiB,MAAM,EAAE,QAAQ,CAAC,SAAS,KAAK,OAAO;AAAA,IAC9D;AACA,SAAK,gBAAgB;AAErB,UAAI,cAAS,kBAAT,mBAAwB,QAAQ,oBAAmB,MAAM;AACtD,uBAAA,aAAA,mBAAU,UAAV,mBAAiB;AAAA,IACxB;AAAA,EACF;AAAA,EAMQ,aAAa,MAA+B;;AAC9C,QAAA,CAAC,QAAS,CAAC,KAAK,YAAU,UAAK,UAAL,mBAAY,aAAa,cAAc;AAC5D,aAAA;AAAA,IACT;AAEA,QAAI,KAAK,UAAU,CAAC,KAAK,UAAU;AAC1B,aAAA,SAAS,KAAK,MAAM,CAAC;AAAA,IAC9B;AAEA,QAAI,KAAK,UAAU,KAAK,kBAAkB,QAAW;AACnD,YAAM,QAAQ,KAAK,MAAM,QAAQ,IAAI;AACrC,aAAO,QAAQ,KAAK,iBAAiB,UAAU,KAAK,gBAAgB;AAAA,IACtE;AAEO,WAAA;AAAA,EACT;AAAA,EAEQ,QAAQ,MAA4B;;AAC1C,QAAI,CAAC,KAAK,aAAa,IAAI,GAAG;AAC5B;AAAA,IACF;AACA,UAAM,kBAA+C;AAAA,MACnD,cAAc,KAAK;AAAA,MACnB,aAAa,KAAK;AAAA,MAClB,WAAW,KAAK,kBAAkB,SAAY,KAAK,gBAAgB,IAAI;AAAA,MACvE,UAAU,KAAK,kBAAkB,SAAY,KAAK,MAAM,KAAK,gBAAgB,CAAC,IAAI;AAAA,IAAA;AAEpF,QAAI,KAAK,YAAY,CAAC,KAAK,SAAS,SAAS,eAAe,GAAG;AAC7D;AAAA,IACF;AACA,UAAM,UAAU,KAAK;AACrB,uCAAS;AACT,SAAK,OAAO;AACZ,SAAK,eAAe;AACpB,SAAK,qBAAqB;AAE1B,UAAI,cAAS,kBAAT,mBAAwB,QAAQ,oBAAmB,MAAM;AACtD,uBAAA,aAAA,mBAAU,UAAV,mBAAiB;AAAA,IACxB;AAAA,EACF;AAAA,EAEQ,iBAAuB;AAC7B,QACE,CAAC,KAAK,WACN,CAAC,KAAK,YACN,KAAK,kBAAkB,UACvB,CAAC,KAAK,SAAS,OACf;AACA;AAAA,IACF;AACA,UAAM,SACJ,KAAK,gBAAgB,eACjB,KAAK,SAAS,MAAM,aAAa,KAAK,SAAS,MAAM,cACrD,KAAK;AAEX,SAAK,MAAM,YAAY,6BAA6B,GAAG,MAAM,IAAI;AAAA,EACnE;AAAA,EAEQ,2BAA+C;AACjD,QAAA,KAAK,kBAAkB,QAAW;AACpC;AAAA,IACF;AACA,QAAI,SAAS;AACF,eAAA,QAAQ,KAAK,OAAO;AACzB,UAAA,SAAS,KAAK,UAAU;AAC1B;AAAA,MACF;AACS,eAAA,KAAK,MAAO,eAAe;AAAA,IACtC;AACA,WACE,SACA,KAAK,SAAU,MAAO,eACtB,WAAW,iBAAiB,IAAI,EAAE,iBAAiB,wBAAwB,CAAC,IAC1E,KACA,KAAK;AAAA,EAEX;AAAA,EAEQ,aAAmB;AACzB,UAAM,QAAQ,KAAK;AACnB,UAAM,QAAQ,CAAC,MAAM,EAAE,UAAU,KAAK,OAAO,CAAC;AAC9C,UACG,OAAO,CAAC,MAAM,EAAE,KAAK,EACrB,IAAI,CAAC,MAAM,EAAE,KAAM,EACnB,QAAQ,CAAC,OAAO,GAAG,UAAU;AAC5B,YAAM,UAAU,IAAI,GAAG,MAAM,QAAQ,KAAK,OAAO;AAAA,IAAA,CAClD;AACH,SAAK,QAAQ,KAAK,YAAY,KAAK,cAAc,CAAC,CAAC;AACnD,SAAK,WAAW;AAAA,EAClB;AAAA,EAEQ,gBAAsB;AACvB,SAAA,MAAM,QAAQ,CAAC,SAAS;;AAC3B,WAAK,OAAO,KAAK,gBAAgB,eAAe,SAAS;AACpD,WAAA,aAAa,oBAAoB,KAAK,WAAW;AACtD,iBAAK,UAAL,mBAAY,aAAa,oBAAoB,KAAK;AAAA,IAAW,CAC9D;AAAA,EACH;AAAA,EAEQ,oBAA0B;AAChC,QAAI,KAAK,gBAAgB;AACvB,WAAK,cAAc,aAAa,KAAK,cAAc,IAAI,eAAe;AACtE,WAAK,cAAc;AAAA,IACrB;AAEA,eAAW,MAAM,KAAK,eAAe,GAAG,CAAC;AAAA,EAC3C;AAAA,EAEQ,mBAAyB;AAC/B,SAAK,kBAAkB;AACvB,iBAAa,KAAK,sBAAuB;AACpC,SAAA,gBAAgB,0BAA0B,IAAI;AAGnD,SAAK,yBAAyB;AAAA,MAC5B,MAAM,KAAK,gBAAgB,0BAA0B,KAAK;AAAA,MAC1D;AAAA,IAAA;AAAA,EAEJ;AAAA,EAEQ,uBAA6B;AACnC,SAAK,MAAM,QAAQ,CAAC,MAAM,UAAU;;AAClC,iBAAK,UAAL,mBAAY;AAAA,QACV;AAAA,QACC,KAAK,UAAU,QAAQ,KAAK,iBAC1B,CAAC,KAAK,UAAU,KAAK,MAAM,aAAa,eAAe;AAAA;AAAA,IAC5D,CACD;AAAA,EACH;AAAA,EAEgB,oBAA0B;AACxC,UAAM,kBAAkB;AAClB,UAAA,SAAS,KAAK,OAAO;AACtB,SAAA,iBAAiB,WAAW,CAAC,MAAM,KAAK,eAAe,CAAC,GAAG,EAAE,OAAA,CAAQ;AAC1E,WAAO,iBAAiB,UAAU,MAAM,KAAK,oBAAoB;AAAA,MAC/D;AAAA,MACA,SAAS;AAAA,IAAA,CACV;AACD,SAAK,gBAAgB,0BAA0B,CAAC,KAAK,OAAO;AAAA,EAC9D;AAAA,EAEA,MAAyB,aAAa,mBAAwD;AAC5F,UAAM,aAAa,iBAAiB;AACpC,UAAM,KAAK;AACX,SAAK,UAAU;AACV,SAAA,gBAAgB,CAAC,KAAK,SAAS,OAAO,KAAK,aAAa,gBAAgB,CAAC,KAAK,IAAI;AACvF,SAAK,kBAAkB;AAEvB,eAAW,MAAM,KAAK,gBAAgB,0BAA0B,KAAK,GAAG,aAAa;AAAA,EACvF;AAAA,EAEmB,WAAW,mBAA+C;AAC3E,UAAM,WAAW,iBAAiB;AAClC,QAAI,kBAAkB,IAAI,aAAa,KAAK,CAAC,KAAK,gBAAgB;AAChE,WAAK,cAAc;AACnB,WAAK,eAAe;AAAA,IACtB;AACA,QAAI,kBAAkB,IAAI,QAAQ,KAAK,KAAK,SAAS;AACnD,WAAK,qBAAqB;AAAA,IAC5B;AAEI,QAAA,kBAAkB,IAAI,MAAM,GAAG;AACjC,WAAK,WAAW;AAChB,WAAK,eAAe;AAAA,IACtB;AAAA,EACF;AAAA,EAEQ,aAAmB;AACpB,SAAA,MAAM,QAAQ,CAAC,SAAS;;AAC3B,iBAAK,UAAL,mBAAY,aAAa,aAAa,KAAK;AAAA,IAAI,CAChD;AAAA,EACH;AAAA,EAEQ,eAAe,KAA0B;AAC/C,UAAM,eAAiC,KAAK;AAE5C,QACE,CAAC;AAAA,IAEC,IAAI,WAA2B,QAAS,IAAI,OAAuB,kBAAkB,MACvF;AACA;AAAA,IACF;AAEI,QAAA,kBAAkB,GAAG,GAAG;AAC1B,YAAM,UAAkB,aAAa,QAAQ,KAAK,QAAS;AAC3D,YAAM,YAAoB,oBAAoB,KAAK,SAAS,aAAa,MAAM;AAC1E,WAAA,QAAQ,aAAa,SAAS,CAAC;AACpC,UAAI,eAAe;AAAA,IACrB;AAAA,EACF;AAAA,EAEmB,SAAyB;AACnC,WAAA;AAAA;AAAA;AAAA,gDAGqC,KAAK,UAAU;AAAA;AAAA;AAAA,0CAGrB,KAAK,UAAU;AAAA;AAAA;AAAA;AAAA,EAIvD;AACF;AAtSa,kBACY,SAAyB;AAGZ,gBAAA;AAAA,EAAnC,SAAS,EAAE,MAAM,SAAS;AAAA,GAJhB,kBAIyB,WAAA,UAAA,CAAA;AAIzB,gBAAA;AAAA,EADV,SAAS,EAAE,WAAW,mBAAmB,SAAS,MAAM;AAAA,GAP9C,kBAQA,WAAA,kBAAA,CAAA;AAaJ,gBAAA;AAAA,EADN,SAAS,EAAE,SAAS,MAAM;AAAA,GApBhB,kBAqBJ,WAAA,eAAA,CAAA;AAG6B,gBAAA;AAAA,EAAnC,SAAS,EAAE,SAAS,MAAM;AAAA,GAxBhB,kBAwByB,WAAA,QAAA,CAAA;AAIzB,gBAAA;AAAA,EADV,SAAS,EAAE,WAAW,OAAO;AAAA,GA3BnB,kBA4BA,WAAA,YAAA,CAAA;AAWA,gBAAA;AAAA,EADV,SAAS,EAAE,WAAW,kBAAkB,MAAM,QAAQ;AAAA,GAtC5C,kBAuCA,WAAA,iBAAA,CAAA;AAvCA,oBAAN,gBAAA;AAAA,EADN,cAAc,aAAa;AAAA,GACf,iBAAA;"}
@@ -1 +1 @@
1
- {"version":3,"file":"toggle-option.d.ts","sourceRoot":"","sources":["../../../../../src/elements/toggle/toggle-option/toggle-option.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAQ,UAAU,EAAW,MAAM,KAAK,CAAC;;AAWhD;;;;;GAKG;AACH,qBAKa,sBAAuB,SAAQ,2BAA4B;IACtE,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,4CAA4C;IAErC,OAAO,UAAS;IAEvB,6CAA6C;IAEtC,QAAQ,EAAE,OAAO,CAAS;IAEjC,8BAA8B;IAC9B,IACW,KAAK,CAAC,KAAK,EAAE,MAAM,EAE7B;IACD,IAAW,KAAK,IAAI,MAAM,CAEzB;IACD,OAAO,CAAC,MAAM,CAAc;IAE5B,OAAO,CAAC,OAAO,CAAC,CAAmB;IACnC,OAAO,CAAC,MAAM,CAAyC;IAEvC,iBAAiB,IAAI,IAAI;cAetB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAe5E,OAAO,CAAC,oBAAoB;IAK5B,OAAO,CAAC,qBAAqB;IAc7B,OAAO,CAAC,YAAY;IAQpB,OAAO,CAAC,eAAe;cAIJ,MAAM,IAAI,cAAc;CAoB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,mBAAmB,EAAE,sBAAsB,CAAC;KAC7C;CACF"}
1
+ {"version":3,"file":"toggle-option.d.ts","sourceRoot":"","sources":["../../../../../src/elements/toggle/toggle-option/toggle-option.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAQ,UAAU,EAAW,MAAM,KAAK,CAAC;;AAWhD;;;;;GAKG;AACH,qBAKa,sBAAuB,SAAQ,2BAA4B;IACtE,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,4CAA4C;IAErC,OAAO,UAAS;IAEvB,6CAA6C;IAEtC,QAAQ,EAAE,OAAO,CAAS;IAEjC,8BAA8B;IAC9B,IACW,KAAK,CAAC,KAAK,EAAE,MAAM,EAE7B;IACD,IAAW,KAAK,IAAI,MAAM,CAEzB;IACD,OAAO,CAAC,MAAM,CAAc;IAE5B,OAAO,CAAC,OAAO,CAAC,CAAmB;IACnC,OAAO,CAAC,MAAM,CAAyC;IAEvC,iBAAiB,IAAI,IAAI;cAetB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAe5E,OAAO,CAAC,oBAAoB;IAK5B,OAAO,CAAC,qBAAqB;IAc7B,OAAO,CAAC,YAAY;IAQpB,OAAO,CAAC,eAAe;cAIJ,MAAM,IAAI,cAAc;CAqB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,mBAAmB,EAAE,sBAAsB,CAAC;KAC7C;CACF"}
@@ -190,6 +190,7 @@ let SbbToggleOptionElement = class extends SbbIconNameMixin(LitElement) {
190
190
  id="sbb-toggle-option-id"
191
191
  aria-hidden="true"
192
192
  tabindex="-1"
193
+ .inert=${this.checked}
193
194
  ?disabled=${this.disabled}
194
195
  .checked=${this.checked || nothing}
195
196
  .value=${this.value || nothing}
@@ -224,4 +225,4 @@ SbbToggleOptionElement = __decorateClass([
224
225
  export {
225
226
  SbbToggleOptionElement
226
227
  };
227
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"toggle-option.js","sources":["../../../../src/elements/toggle/toggle-option/toggle-option.ts"],"sourcesContent":["import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, LitElement, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { SbbConnectedAbortController } from '../../core/controllers.js';\nimport { hostAttributes, slotState } from '../../core/decorators.js';\nimport { setOrRemoveAttribute } from '../../core/dom.js';\nimport { SbbIconNameMixin } from '../../icon.js';\nimport type { SbbToggleElement } from '../toggle.js';\n\nimport style from './toggle-option.scss?lit&inline';\n\n/**\n * It displays a toggle option within a `sbb-toggle`.\n *\n * @slot - Use the unnamed slot to add content to the label of the toggle option.\n * @slot icon - Slot used to render the `sbb-icon`.\n */\n@customElement('sbb-toggle-option')\n@hostAttributes({\n  role: 'radio',\n})\n@slotState()\nexport class SbbToggleOptionElement extends SbbIconNameMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n\n  /** Whether the toggle-option is checked. */\n  @property({ reflect: true, type: Boolean })\n  public checked = false;\n\n  /** Whether the toggle option is disabled. */\n  @property({ reflect: true, type: Boolean })\n  public disabled: boolean = false;\n\n  /** Value of toggle-option. */\n  @property()\n  public set value(value: string) {\n    this._value = `${value}`;\n  }\n  public get value(): string {\n    return this._value;\n  }\n  private _value: string = '';\n\n  private _toggle?: SbbToggleElement;\n  private _abort = new SbbConnectedAbortController(this);\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    const signal = this._abort.signal;\n\n    // We need to listen input event on host as with keyboard navigation\n    // the Input Event is triggered from sbb-toggle.\n    this.addEventListener('input', () => this._handleInput(), { signal });\n    this.addEventListener('click', () => this.shadowRoot!.querySelector('label')?.click(), {\n      signal,\n    });\n    // We can use closest here, as we expect the parent sbb-toggle to be in light DOM.\n    this._toggle = this.closest?.('sbb-toggle') ?? undefined;\n    this._verifyTabindex();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('checked')) {\n      this.setAttribute('aria-checked', `${this.checked}`);\n      this._verifyTabindex();\n      if (this.checked) {\n        this._uncheckOtherOptions();\n      }\n    }\n    if (changedProperties.has('disabled')) {\n      this._handleDisabledChange();\n    }\n  }\n\n  private _uncheckOtherOptions(): void {\n    this._toggle?.options.filter((o) => o !== this).forEach((o) => (o.checked = false));\n    this._toggle?.updatePillPosition(false);\n  }\n\n  private _handleDisabledChange(): void {\n    // Enforce disabled state from parent.\n    if (!this._toggle) {\n      // Ignore illegal state. Our expectation  is that a sbb-toggle-option\n      // always has a parent sbb-toggle.\n    } else if (this._toggle.disabled && !this.disabled) {\n      this.disabled = true;\n    } else if (!this._toggle.disabled && this.disabled) {\n      this.disabled = false;\n    }\n    setOrRemoveAttribute(this, 'aria-disabled', this.disabled ? `true` : null);\n    this._verifyTabindex();\n  }\n\n  private _handleInput(): void {\n    if (this.disabled) {\n      return;\n    }\n    this.checked = true;\n    this._uncheckOtherOptions();\n  }\n\n  private _verifyTabindex(): void {\n    this.tabIndex = this.checked && !this.disabled ? 0 : -1;\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <input\n        type=\"radio\"\n        id=\"sbb-toggle-option-id\"\n        aria-hidden=\"true\"\n        tabindex=\"-1\"\n        ?disabled=${this.disabled}\n        .checked=${this.checked || nothing}\n        .value=${this.value || nothing}\n        @click=${(event: PointerEvent) => event.stopPropagation()}\n      />\n      <label class=\"sbb-toggle-option\" for=\"sbb-toggle-option-id\">\n        ${this.renderIconSlot()}\n        <span class=\"sbb-toggle-option__label\">\n          <slot></slot>\n        </span>\n      </label>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-toggle-option': SbbToggleOptionElement;\n  }\n}\n"],"names":["_a"],"mappings":"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"}
228
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"toggle-option.js","sources":["../../../../src/elements/toggle/toggle-option/toggle-option.ts"],"sourcesContent":["import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, LitElement, nothing } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { SbbConnectedAbortController } from '../../core/controllers.js';\nimport { hostAttributes, slotState } from '../../core/decorators.js';\nimport { setOrRemoveAttribute } from '../../core/dom.js';\nimport { SbbIconNameMixin } from '../../icon.js';\nimport type { SbbToggleElement } from '../toggle.js';\n\nimport style from './toggle-option.scss?lit&inline';\n\n/**\n * It displays a toggle option within a `sbb-toggle`.\n *\n * @slot - Use the unnamed slot to add content to the label of the toggle option.\n * @slot icon - Slot used to render the `sbb-icon`.\n */\n@customElement('sbb-toggle-option')\n@hostAttributes({\n  role: 'radio',\n})\n@slotState()\nexport class SbbToggleOptionElement extends SbbIconNameMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n\n  /** Whether the toggle-option is checked. */\n  @property({ reflect: true, type: Boolean })\n  public checked = false;\n\n  /** Whether the toggle option is disabled. */\n  @property({ reflect: true, type: Boolean })\n  public disabled: boolean = false;\n\n  /** Value of toggle-option. */\n  @property()\n  public set value(value: string) {\n    this._value = `${value}`;\n  }\n  public get value(): string {\n    return this._value;\n  }\n  private _value: string = '';\n\n  private _toggle?: SbbToggleElement;\n  private _abort = new SbbConnectedAbortController(this);\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    const signal = this._abort.signal;\n\n    // We need to listen input event on host as with keyboard navigation\n    // the Input Event is triggered from sbb-toggle.\n    this.addEventListener('input', () => this._handleInput(), { signal });\n    this.addEventListener('click', () => this.shadowRoot!.querySelector('label')?.click(), {\n      signal,\n    });\n    // We can use closest here, as we expect the parent sbb-toggle to be in light DOM.\n    this._toggle = this.closest?.('sbb-toggle') ?? undefined;\n    this._verifyTabindex();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('checked')) {\n      this.setAttribute('aria-checked', `${this.checked}`);\n      this._verifyTabindex();\n      if (this.checked) {\n        this._uncheckOtherOptions();\n      }\n    }\n    if (changedProperties.has('disabled')) {\n      this._handleDisabledChange();\n    }\n  }\n\n  private _uncheckOtherOptions(): void {\n    this._toggle?.options.filter((o) => o !== this).forEach((o) => (o.checked = false));\n    this._toggle?.updatePillPosition(false);\n  }\n\n  private _handleDisabledChange(): void {\n    // Enforce disabled state from parent.\n    if (!this._toggle) {\n      // Ignore illegal state. Our expectation  is that a sbb-toggle-option\n      // always has a parent sbb-toggle.\n    } else if (this._toggle.disabled && !this.disabled) {\n      this.disabled = true;\n    } else if (!this._toggle.disabled && this.disabled) {\n      this.disabled = false;\n    }\n    setOrRemoveAttribute(this, 'aria-disabled', this.disabled ? `true` : null);\n    this._verifyTabindex();\n  }\n\n  private _handleInput(): void {\n    if (this.disabled) {\n      return;\n    }\n    this.checked = true;\n    this._uncheckOtherOptions();\n  }\n\n  private _verifyTabindex(): void {\n    this.tabIndex = this.checked && !this.disabled ? 0 : -1;\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <input\n        type=\"radio\"\n        id=\"sbb-toggle-option-id\"\n        aria-hidden=\"true\"\n        tabindex=\"-1\"\n        .inert=${this.checked}\n        ?disabled=${this.disabled}\n        .checked=${this.checked || nothing}\n        .value=${this.value || nothing}\n        @click=${(event: PointerEvent) => event.stopPropagation()}\n      />\n      <label class=\"sbb-toggle-option\" for=\"sbb-toggle-option-id\">\n        ${this.renderIconSlot()}\n        <span class=\"sbb-toggle-option__label\">\n          <slot></slot>\n        </span>\n      </label>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-toggle-option': SbbToggleOptionElement;\n  }\n}\n"],"names":["_a"],"mappings":"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"}
package/lists.css CHANGED
@@ -83,6 +83,7 @@
83
83
  --sbb-step-list-padding-block: var(--sbb-spacing-fixed-3x);
84
84
  --sbb-step-list-padding-inline: var(--sbb-spacing-responsive-xxs);
85
85
  --sbb-step-list-marker-to-text-gap: var(--sbb-spacing-responsive-xxxs);
86
+ --sbb-step-list-border-radius: var(--sbb-border-radius-4x);
86
87
  --sbb-step-list-text-to-marker-block-offset: calc(
87
88
  0.5 *
88
89
  (
@@ -112,11 +113,18 @@
112
113
  position: relative;
113
114
  counter-increment: steps;
114
115
  background-color: var(--sbb-color-milk);
115
- border-radius: var(--sbb-border-radius-4x);
116
116
  padding-block: calc(var(--sbb-step-list-padding-block) + var(--sbb-step-list-text-to-marker-block-offset)) var(--sbb-step-list-padding-block);
117
117
  padding-inline: calc(var(--sbb-step-list-padding-inline) + var(--sbb-step-list-marker-dimensions) + var(--sbb-step-list-marker-to-text-gap)) var(--sbb-step-list-padding-inline);
118
118
  min-height: calc(var(--sbb-step-list-marker-dimensions) + 2 * var(--sbb-step-list-padding-block));
119
119
  }
120
+ .sbb-step-list > li:first-of-type {
121
+ border-start-start-radius: var(--sbb-step-list-border-radius);
122
+ border-start-end-radius: var(--sbb-step-list-border-radius);
123
+ }
124
+ .sbb-step-list > li:last-of-type {
125
+ border-end-start-radius: var(--sbb-step-list-border-radius);
126
+ border-end-end-radius: var(--sbb-step-list-border-radius);
127
+ }
120
128
  .sbb-step-list > li::before {
121
129
  --sbb-text-font-size: var(--sbb-font-size-text-xxs);
122
130
  font-family: var(--sbb-typo-font-family);
package/overlay.js CHANGED
@@ -89,7 +89,7 @@ B([
89
89
  b({ attribute: "accessibility-label" })
90
90
  ], m.prototype, "accessibilityLabel");
91
91
  let F = m;
92
- const H = u`*,:before,:after{box-sizing:border-box}:host{--sbb-scrollbar-thumb-width: .125rem;--sbb-scrollbar-thumb-width-hover: .25rem;--sbb-scrollbar-width-firefox: thin;--sbb-scrollbar-color: var(--sbb-color-black-alpha-30);--sbb-scrollbar-color-hover: var(--sbb-color-black-alpha-60);--sbb-scrollbar-track-color: transparent;--sbb-overlay-background-color: var(--sbb-color-milk);--sbb-overlay-height: 100%;--sbb-overlay-inset: 0 auto auto 0;--sbb-overlay-padding-block: calc( var(--sbb-spacing-responsive-xxl) + var(--sbb-spacing-responsive-l) );--sbb-overlay-animation-duration: var( --sbb-disable-animation-zero-time, var(--sbb-animation-duration-6x) );--sbb-overlay-animation-easing: ease;--sbb-overlay-pointer-events: none;display:block;position:fixed;inset:var(--sbb-overlay-inset);z-index:var(--sbb-overlay-z-index, var(--sbb-overlay-default-z-index))}@media (min-width: 64rem){:host{--sbb-overlay-padding-block: var(--sbb-spacing-responsive-xl)}}:host(:is([data-state=opened],[data-state=opening])){--sbb-overlay-pointer-events: all}:host([negative]){--sbb-scrollbar-color: var(--sbb-color-white-alpha-30);--sbb-scrollbar-color-hover: var(--sbb-color-white-alpha-60);--sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);--sbb-overlay-color: var(--sbb-color-white);--sbb-overlay-background-color: var(--sbb-color-midnight)}:host(:not([data-state=closed])){--sbb-overlay-inset: 0}.sbb-overlay__container{background-color:var(--sbb-overlay-background-color);pointer-events:var(--sbb-overlay-pointer-events);display:none;align-items:center;position:fixed;inset:var(--sbb-overlay-inset)}:host([data-state]:not([data-state=closed])) .sbb-overlay__container{display:flex;animation-name:open;animation-duration:var(--sbb-overlay-animation-duration);animation-timing-function:var(--sbb-overlay-animation-easing)}:host([data-state][data-state=closing]) .sbb-overlay__container{pointer-events:none;animation-name:close}.sbb-overlay{position:absolute;inset-inline:0;margin:auto;padding:0;border:none;height:var(--sbb-overlay-height);overflow:auto;color:var(--sbb-overlay-color)}:host([data-state]:not([data-state=closed])) .sbb-overlay{animation-name:open-move-in;animation-duration:var(--sbb-overlay-animation-duration);animation-timing-function:var(--sbb-overlay-animation-easing)}:host([data-state][data-state=closing]) .sbb-overlay{animation-name:close-move-out}.sbb-overlay__wrapper{display:flex;flex-direction:column;width:100%;height:var(--sbb-overlay-height);outline:none;position:fixed}@media (min-width: 52.5rem){.sbb-overlay__wrapper{position:sticky;inset-block-start:0;height:auto}}.sbb-overlay__header{position:absolute;inset-inline-start:0;display:flex;pointer-events:none;align-items:start;justify-content:space-between;width:100%;padding:var(--sbb-spacing-responsive-xs);padding-block-end:0;z-index:1}.sbb-overlay__header *{pointer-events:all}.sbb-overlay__close{margin-inline-start:auto}.sbb-overlay__content{--sbb-scrollbar-width: var(--sbb-spacing-fixed-3x)}.sbb-overlay__content::-webkit-scrollbar{width:var(--sbb-scrollbar-width);height:var(--sbb-scrollbar-width);background-color:var(--sbb-scrollbar-track-color, transparent)}.sbb-overlay__content::-webkit-scrollbar-corner{background-color:var(--sbb-scrollbar-track-color, transparent)}.sbb-overlay__content::-webkit-scrollbar-thumb{background-color:var(--sbb-scrollbar-color, currentcolor);border:calc(.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width))) solid transparent;border-radius:var(--sbb-border-radius-4x);background-clip:padding-box}.sbb-overlay__content::-webkit-scrollbar-thumb:hover{background-color:var(--sbb-scrollbar-color-hover, currentcolor);border-width:calc(.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width-hover)))}.sbb-overlay__content::-webkit-scrollbar-button,.sbb-overlay__content::-webkit-scrollbar-corner{display:none}@supports not selector(::-webkit-scrollbar){.sbb-overlay__content{scrollbar-width:var(--sbb-scrollbar-width-firefox);scrollbar-color:var(--sbb-scrollbar-color, currentcolor) var(--sbb-scrollbar-track-color, transparent)}}.sbb-overlay__content{height:100vh;overflow:auto;-webkit-overflow-scrolling:touch}.sbb-overlay__content-container{padding-block:var(--sbb-overlay-padding-block)}@keyframes open{0%{opacity:0}to{opacity:1}}@keyframes open-move-in{0%{transform:translateY(var(--sbb-spacing-fixed-4x))}to{transform:translateY(0)}}@keyframes close{0%{opacity:1}to{opacity:0}}@keyframes close-move-out{0%{transform:translateY(0)}to{transform:translateY(var(--sbb-spacing-fixed-4x))}}`;
92
+ const H = u`*,:before,:after{box-sizing:border-box}:host{--sbb-scrollbar-thumb-width: .125rem;--sbb-scrollbar-thumb-width-hover: .25rem;--sbb-scrollbar-width-firefox: thin;--sbb-scrollbar-color: var(--sbb-color-black-alpha-30);--sbb-scrollbar-color-hover: var(--sbb-color-black-alpha-60);--sbb-scrollbar-track-color: transparent;--sbb-overlay-background-color: var(--sbb-color-milk);--sbb-overlay-height: 100%;--sbb-overlay-inset: 0 auto auto 0;--sbb-overlay-padding-block: calc(var(--sbb-spacing-fixed-14x) + var(--sbb-spacing-responsive-l));--sbb-overlay-animation-duration: var( --sbb-disable-animation-zero-time, var(--sbb-animation-duration-6x) );--sbb-overlay-animation-easing: ease;--sbb-overlay-pointer-events: none;display:block;position:fixed;inset:var(--sbb-overlay-inset);z-index:var(--sbb-overlay-z-index, var(--sbb-overlay-default-z-index))}:host(:is([data-state=opened],[data-state=opening])){--sbb-overlay-pointer-events: all}:host([negative]){--sbb-scrollbar-color: var(--sbb-color-white-alpha-30);--sbb-scrollbar-color-hover: var(--sbb-color-white-alpha-60);--sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);--sbb-overlay-color: var(--sbb-color-white);--sbb-overlay-background-color: var(--sbb-color-midnight)}:host(:not([data-state=closed])){--sbb-overlay-inset: 0}.sbb-overlay__container{background-color:var(--sbb-overlay-background-color);pointer-events:var(--sbb-overlay-pointer-events);display:none;align-items:center;position:fixed;inset:var(--sbb-overlay-inset)}:host([data-state]:not([data-state=closed])) .sbb-overlay__container{display:flex;animation-name:open;animation-duration:var(--sbb-overlay-animation-duration);animation-timing-function:var(--sbb-overlay-animation-easing)}:host([data-state][data-state=closing]) .sbb-overlay__container{pointer-events:none;animation-name:close}.sbb-overlay{position:absolute;inset-inline:0;margin:auto;padding:0;border:none;height:var(--sbb-overlay-height);overflow:auto;color:var(--sbb-overlay-color)}:host([data-state]:not([data-state=closed])) .sbb-overlay{animation-name:open-move-in;animation-duration:var(--sbb-overlay-animation-duration);animation-timing-function:var(--sbb-overlay-animation-easing)}:host([data-state][data-state=closing]) .sbb-overlay{animation-name:close-move-out}.sbb-overlay__wrapper{display:flex;flex-direction:column;width:100%;height:var(--sbb-overlay-height);outline:none;position:fixed}@media (min-width: 52.5rem){.sbb-overlay__wrapper{position:sticky;inset-block-start:0;height:auto}}.sbb-overlay__header{position:absolute;inset-inline-start:0;display:flex;pointer-events:none;align-items:start;justify-content:space-between;width:100%;padding:var(--sbb-spacing-responsive-xs);padding-block-end:0;z-index:1}.sbb-overlay__header *{pointer-events:all}.sbb-overlay__close{margin-inline-start:auto}.sbb-overlay__content{--sbb-scrollbar-width: var(--sbb-spacing-fixed-3x)}.sbb-overlay__content::-webkit-scrollbar{width:var(--sbb-scrollbar-width);height:var(--sbb-scrollbar-width);background-color:var(--sbb-scrollbar-track-color, transparent)}.sbb-overlay__content::-webkit-scrollbar-corner{background-color:var(--sbb-scrollbar-track-color, transparent)}.sbb-overlay__content::-webkit-scrollbar-thumb{background-color:var(--sbb-scrollbar-color, currentcolor);border:calc(.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width))) solid transparent;border-radius:var(--sbb-border-radius-4x);background-clip:padding-box}.sbb-overlay__content::-webkit-scrollbar-thumb:hover{background-color:var(--sbb-scrollbar-color-hover, currentcolor);border-width:calc(.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width-hover)))}.sbb-overlay__content::-webkit-scrollbar-button,.sbb-overlay__content::-webkit-scrollbar-corner{display:none}@supports not selector(::-webkit-scrollbar){.sbb-overlay__content{scrollbar-width:var(--sbb-scrollbar-width-firefox);scrollbar-color:var(--sbb-scrollbar-color, currentcolor) var(--sbb-scrollbar-track-color, transparent)}}.sbb-overlay__content{height:100vh;overflow:auto;-webkit-overflow-scrolling:touch}.sbb-overlay__content-container{padding-block:var(--sbb-overlay-padding-block)}@keyframes open{0%{opacity:0}to{opacity:1}}@keyframes open-move-in{0%{transform:translateY(var(--sbb-spacing-fixed-4x))}to{transform:translateY(0)}}@keyframes close{0%{opacity:1}to{opacity:0}}@keyframes close-move-out{0%{transform:translateY(0)}to{transform:translateY(var(--sbb-spacing-fixed-4x))}}`;
93
93
  var T = Object.defineProperty, z = Object.getOwnPropertyDescriptor, c = (t, e, o, a) => {
94
94
  for (var r = a > 1 ? void 0 : a ? z(e, o) : e, n = t.length - 1, i; n >= 0; n--)
95
95
  (i = t[n]) && (r = (a ? i(e, o, r) : i(r)) || r);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements",
3
- "version": "1.8.0",
3
+ "version": "1.9.0",
4
4
  "description": "Lyne Design System",
5
5
  "keywords": [
6
6
  "design system",
@@ -4,7 +4,7 @@ export interface SelectChange {
4
4
  type: 'value';
5
5
  value: string | string[];
6
6
  }
7
- declare const SbbSelectElement_base: import('../core/mixins.js').AbstractConstructor<import('../core/mixins.js').SbbUpdateSchedulerMixinType> & import('../core/mixins.js').AbstractConstructor<import('../core/mixins.js').SbbDisabledMixinType> & import('../core/mixins.js').AbstractConstructor<import('../core/mixins.js').SbbNegativeMixinType> & typeof SbbOpenCloseBaseElement;
7
+ declare const SbbSelectElement_base: import('../core/mixins.js').AbstractConstructor<import('../core/mixins.js').SbbUpdateSchedulerMixinType> & import('../core/mixins.js').AbstractConstructor<import('../core/mixins.js').SbbDisabledMixinType> & import('../core/mixins.js').AbstractConstructor<import('../core/mixins.js').SbbNegativeMixinType> & import('../core/mixins.js').AbstractConstructor<import('../core/mixins.js').SbbHydrationMixinType> & typeof SbbOpenCloseBaseElement;
8
8
  /**
9
9
  * It displays a panel with selectable options.
10
10
  *
@@ -128,6 +128,8 @@ export declare class SbbSelectElement extends SbbSelectElement_base {
128
128
  private _closeOnBackdropClick;
129
129
  private _setValueFromSelectedOption;
130
130
  private _toggleOpening;
131
+ private _spreadDeferredDisplayValue;
132
+ private _deferredDisplayValue;
131
133
  protected render(): TemplateResult;
132
134
  }
133
135
  declare global {
@@ -1 +1 @@
1
- {"version":3,"file":"select.d.ts","sourceRoot":"","sources":["../../../src/elements/select/select.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"select.d.ts","sourceRoot":"","sources":["../../../src/elements/select/select.ts"],"names":[],"mappings":"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"}
package/select.js CHANGED
@@ -1,23 +1,24 @@
1
- import { css as _, html as b, nothing as c } from "lit";
2
- import { property as d, state as g, customElement as m } from "lit/decorators.js";
1
+ import { css as g, html as d, nothing as c } from "lit";
2
+ import { property as b, state as m, customElement as w } from "lit/decorators.js";
3
3
  import { ref as v } from "lit/directives/ref.js";
4
- import { getNextElementIndex as w } from "./core/a11y.js";
5
- import { SbbOpenCloseBaseElement as y } from "./core/base-elements.js";
6
- import { SbbConnectedAbortController as x } from "./core/controllers.js";
7
- import { hostAttributes as E } from "./core/decorators.js";
8
- import { isNextjs as u, getDocumentWritingMode as O, isSafari as k } from "./core/dom.js";
4
+ import { until as u } from "lit/directives/until.js";
5
+ import { getNextElementIndex as y } from "./core/a11y.js";
6
+ import { SbbOpenCloseBaseElement as x } from "./core/base-elements.js";
7
+ import { SbbConnectedAbortController as E } from "./core/controllers.js";
8
+ import { hostAttributes as O } from "./core/decorators.js";
9
+ import { isNextjs as f, getDocumentWritingMode as k, isSafari as C } from "./core/dom.js";
9
10
  import { EventEmitter as p } from "./core/eventing.js";
10
- import { SbbUpdateSchedulerMixin as C, SbbDisabledMixin as A, SbbNegativeMixin as S } from "./core/mixins.js";
11
- import { isEventOnElement as f, setOverlayPosition as I, overlayGapFixCorners as P } from "./core/overlay.js";
12
- const $ = _`*,:before,:after{box-sizing:border-box}.sbb-gap-fix-wrapper{position:relative;overflow:hidden;width:var(--sbb-options-panel-border-radius);height:var(--sbb-options-panel-border-radius);background-color:transparent}.sbb-gap-fix-corner{position:absolute;border-radius:50%;border:calc(var(--sbb-options-panel-border-radius) / 2) solid var(--sbb-options-panel-background-color);width:calc(var(--sbb-options-panel-border-radius) * 3);height:calc(var(--sbb-options-panel-border-radius) * 3);bottom:calc(var(--sbb-options-panel-border-radius) / 2 * -1)}.sbb-gap-fix-corner#left{left:calc(var(--sbb-options-panel-border-radius) / 2 * -1)}:host([dir=rtl]) .sbb-gap-fix-corner#left{right:calc(var(--sbb-options-panel-border-radius) / 2 * -1);left:unset}.sbb-gap-fix-corner#right{right:calc(var(--sbb-options-panel-border-radius) / 2 * -1)}:host([dir=rtl]) .sbb-gap-fix-corner#right{left:calc(var(--sbb-options-panel-border-radius) / 2 * -1);right:unset}:host{--sbb-scrollbar-thumb-width: .125rem;--sbb-scrollbar-thumb-width-hover: .25rem;--sbb-scrollbar-width-firefox: thin;--sbb-scrollbar-color: var(--sbb-color-black-alpha-30);--sbb-scrollbar-color-hover: var(--sbb-color-black-alpha-60);--sbb-scrollbar-track-color: transparent;--sbb-options-panel-position-x: 0;--sbb-options-panel-position-y: 0;--sbb-options-panel-active-option-y: 0;--sbb-options-panel-max-height: calc(85vh - var(--sbb-spacing-fixed-8x));--sbb-options-panel-min-height: var(--sbb-options-panel-origin-height);--sbb-options-panel-visibility: visible;--sbb-options-panel-width: fit-content;--sbb-options-panel-border-radius: var(--sbb-border-radius-4x);--sbb-options-panel-options-border-radius: 0 0 var(--sbb-options-panel-border-radius) var(--sbb-options-panel-border-radius);--sbb-options-panel-animation-duration: var( --sbb-disable-animation-time, var(--sbb-animation-duration-4x) );--sbb-options-panel-animation-timing-function: ease;--sbb-options-panel-gap-fix-opacity: 0;--sbb-options-panel-gap-fix-transform: none;--sbb-options-panel-gap-fix-top: calc( var(--sbb-options-panel-position-y) - var(--sbb-options-panel-border-radius) );--sbb-options-panel-background-color: var(--sbb-color-white);--sbb-focus-outline-color: var(--sbb-focus-outline-color-default);--sbb-options-panel-internal-z-index: var( --sbb-select-z-index, var(--sbb-overlay-default-z-index) );display:block}:host([negative]){--sbb-scrollbar-color: var(--sbb-color-white-alpha-30);--sbb-scrollbar-color-hover: var(--sbb-color-white-alpha-60);--sbb-options-panel-background-color: var(--sbb-color-midnight);--sbb-focus-outline-color: var(--sbb-focus-outline-color-dark)}:host(:not([data-state])),:host([data-state=closed]){--sbb-options-panel-visibility: hidden}:host([data-state=opening]){--sbb-options-panel-animation-name: open}:host([data-state=closing]){--sbb-options-panel-animation-name: close}:host([data-state=opened]),:host([data-state=opening]){--sbb-options-panel-gap-fix-opacity: 1}:host([data-options-panel-position=below]){--sbb-options-panel-animation-transform: translateY( calc((var(--sbb-options-panel-origin-height) / 2) * -1) )}:host([data-options-panel-position=above]){--sbb-options-panel-options-border-radius: var(--sbb-options-panel-border-radius) var(--sbb-options-panel-border-radius) 0 0;--sbb-options-panel-gap-fix-top: var(--sbb-options-panel-max-height);--sbb-options-panel-gap-fix-transform: rotate(180deg);--sbb-options-panel-animation-transform: translateY( calc(var(--sbb-options-panel-origin-height) / 2) )}::slotted(sbb-divider){margin-block:var(--sbb-spacing-fixed-3x)}:host([preserve-icon-space]){--sbb-option-icon-container-display: block}.sbb-select__trigger{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;height:calc(1em * var(--sbb-typo-line-height-body-text))}.sbb-select__trigger--placeholder{color:var(--sbb-select-placeholder-color, var(--sbb-color-metal));-webkit-text-fill-color:var(--sbb-select-placeholder-color, var(--sbb-color-metal))}.sbb-select__container{position:fixed;pointer-events:none;top:0;right:0;bottom:0;left:0;z-index:var(--sbb-options-panel-internal-z-index)}.sbb-select__gap-fix{display:flex;justify-content:space-between;position:fixed;visibility:var(--sbb-options-panel-visibility);opacity:var(--sbb-options-panel-gap-fix-opacity);background-color:transparent;width:var(--sbb-options-panel-width);height:var(--sbb-options-panel-border-radius);top:var(--sbb-options-panel-gap-fix-top);left:var(--sbb-options-panel-position-x);transform:var(--sbb-options-panel-gap-fix-transform);transition:opacity var(--sbb-options-panel-animation-duration) var(--sbb-options-panel-animation-timing-function)}.sbb-select__panel{display:block;position:absolute;visibility:var(--sbb-options-panel-visibility);overflow:hidden;background-color:transparent;border:none;border-radius:var(--sbb-options-panel-border-radius);top:var(--sbb-options-panel-position-y);left:var(--sbb-options-panel-position-x);width:var(--sbb-options-panel-width);transition:box-shadow var(--sbb-options-panel-animation-duration) var(--sbb-options-panel-animation-timing-function)}.sbb-select__panel:before,.sbb-select__panel:after{content:"";display:none;position:relative;width:100%;height:var(--sbb-options-panel-origin-height);background-color:transparent;border-radius:var(--sbb-options-panel-border-radius);pointer-events:none;transition:box-shadow var(--sbb-options-panel-animation-duration) var(--sbb-options-panel-animation-timing-function);z-index:1}:host([data-options-panel-position=below]) .sbb-select__panel{inset-block-start:calc(var(--sbb-options-panel-position-y) - var(--sbb-options-panel-origin-height))}:host(:is([data-state=opened],[data-state=opening])) .sbb-select__panel{box-shadow:var(--sbb-shadow-elevation-level-5-shadow-2-offset-x) var(--sbb-shadow-elevation-level-5-shadow-2-offset-y) var(--sbb-shadow-elevation-level-5-shadow-2-blur) var(--sbb-shadow-elevation-level-5-shadow-2-spread) var(--sbb-shadow-elevation-level-5-hard-2-color),var(--sbb-shadow-elevation-level-5-shadow-1-offset-x) var(--sbb-shadow-elevation-level-5-shadow-1-offset-y) var(--sbb-shadow-elevation-level-5-shadow-1-blur) var(--sbb-shadow-elevation-level-5-shadow-1-spread) var(--sbb-shadow-elevation-level-5-hard-1-color)}:host(:is([data-state=opened],[data-state=opening])[negative]) .sbb-select__panel{box-shadow:var(--sbb-shadow-elevation-level-5-shadow-2-offset-x) var(--sbb-shadow-elevation-level-5-shadow-2-offset-y) var(--sbb-shadow-elevation-level-5-shadow-2-blur) var(--sbb-shadow-elevation-level-5-shadow-2-spread) var(--sbb-shadow-elevation-level-5-hard-negative-2-color),var(--sbb-shadow-elevation-level-5-shadow-1-offset-x) var(--sbb-shadow-elevation-level-5-shadow-1-offset-y) var(--sbb-shadow-elevation-level-5-shadow-1-blur) var(--sbb-shadow-elevation-level-5-shadow-1-spread) var(--sbb-shadow-elevation-level-5-hard-negative-1-color)}:host([data-options-panel-position=below]) .sbb-select__panel:before{display:block}:host([data-options-panel-position=above]) .sbb-select__panel:after{display:block}:host(:is([data-state=opened],[data-state=opening])[data-option-panel-origin-borderless]) .sbb-select__panel:before,:host(:is([data-state=opened],[data-state=opening])[data-option-panel-origin-borderless]) .sbb-select__panel:after{box-shadow:var(--sbb-shadow-elevation-level-5-shadow-2-offset-x) var(--sbb-shadow-elevation-level-5-shadow-2-offset-y) var(--sbb-shadow-elevation-level-5-shadow-2-blur) var(--sbb-shadow-elevation-level-5-shadow-2-spread) var(--sbb-shadow-elevation-level-5-hard-2-color),var(--sbb-shadow-elevation-level-5-shadow-1-offset-x) var(--sbb-shadow-elevation-level-5-shadow-1-offset-y) var(--sbb-shadow-elevation-level-5-shadow-1-blur) var(--sbb-shadow-elevation-level-5-shadow-1-spread) var(--sbb-shadow-elevation-level-5-hard-1-color)}:host(:is([data-state=opened],[data-state=opening])[data-option-panel-origin-borderless][negative]) .sbb-select__panel:before,:host(:is([data-state=opened],[data-state=opening])[data-option-panel-origin-borderless][negative]) .sbb-select__panel:after{box-shadow:var(--sbb-shadow-elevation-level-5-shadow-2-offset-x) var(--sbb-shadow-elevation-level-5-shadow-2-offset-y) var(--sbb-shadow-elevation-level-5-shadow-2-blur) var(--sbb-shadow-elevation-level-5-shadow-2-spread) var(--sbb-shadow-elevation-level-5-hard-negative-2-color),var(--sbb-shadow-elevation-level-5-shadow-1-offset-x) var(--sbb-shadow-elevation-level-5-shadow-1-offset-y) var(--sbb-shadow-elevation-level-5-shadow-1-blur) var(--sbb-shadow-elevation-level-5-shadow-1-spread) var(--sbb-shadow-elevation-level-5-hard-negative-1-color)}.sbb-select__wrapper{overflow:hidden}.sbb-select__options{background-color:var(--sbb-options-panel-background-color);padding-block:var(--sbb-spacing-fixed-3x);padding-inline:0;border-radius:var(--sbb-options-panel-options-border-radius);max-height:var(--sbb-options-panel-max-height);min-height:var(--sbb-options-panel-min-height);pointer-events:all;overflow-y:auto;animation-name:var(--sbb-options-panel-animation-name);animation-duration:var(--sbb-options-panel-animation-duration);animation-timing-function:var(--sbb-options-panel-animation-timing-function);--sbb-scrollbar-width: var(--sbb-spacing-fixed-3x)}.sbb-select__options::-webkit-scrollbar{width:var(--sbb-scrollbar-width);height:var(--sbb-scrollbar-width);background-color:var(--sbb-scrollbar-track-color, transparent)}.sbb-select__options::-webkit-scrollbar-corner{background-color:var(--sbb-scrollbar-track-color, transparent)}.sbb-select__options::-webkit-scrollbar-thumb{background-color:var(--sbb-scrollbar-color, currentcolor);border:calc(.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width))) solid transparent;border-radius:var(--sbb-border-radius-4x);background-clip:padding-box}.sbb-select__options::-webkit-scrollbar-thumb:hover{background-color:var(--sbb-scrollbar-color-hover, currentcolor);border-width:calc(.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width-hover)))}.sbb-select__options::-webkit-scrollbar-button,.sbb-select__options::-webkit-scrollbar-corner{display:none}@supports not selector(::-webkit-scrollbar){.sbb-select__options{scrollbar-width:var(--sbb-scrollbar-width-firefox);scrollbar-color:var(--sbb-scrollbar-color, currentcolor) var(--sbb-scrollbar-track-color, transparent)}}.sbb-select__options{padding-block:var(--sbb-spacing-fixed-2x)}@media (forced-colors: active){.sbb-select__options{border:var(--sbb-border-width-1x) solid CanvasText;border-block-start:none}}@keyframes open{0%{transform:var(--sbb-options-panel-animation-transform);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes close{0%{transform:translateY(0);opacity:1}to{transform:var(--sbb-options-panel-animation-transform);opacity:0}}`;
13
- var D = Object.defineProperty, L = Object.getOwnPropertyDescriptor, r = (e, t, i, s) => {
14
- for (var o = s > 1 ? void 0 : s ? L(t, i) : t, n = e.length - 1, l; n >= 0; n--)
15
- (l = e[n]) && (o = (s ? l(t, i, o) : l(o)) || o);
16
- return s && o && D(t, i, o), o;
11
+ import { SbbUpdateSchedulerMixin as A, SbbDisabledMixin as S, SbbNegativeMixin as I, SbbHydrationMixin as D } from "./core/mixins.js";
12
+ import { isEventOnElement as _, setOverlayPosition as P, overlayGapFixCorners as $ } from "./core/overlay.js";
13
+ const L = g`*,:before,:after{box-sizing:border-box}.sbb-gap-fix-wrapper{position:relative;overflow:hidden;width:var(--sbb-options-panel-border-radius);height:var(--sbb-options-panel-border-radius);background-color:transparent}.sbb-gap-fix-corner{position:absolute;border-radius:50%;border:calc(var(--sbb-options-panel-border-radius) / 2) solid var(--sbb-options-panel-background-color);width:calc(var(--sbb-options-panel-border-radius) * 3);height:calc(var(--sbb-options-panel-border-radius) * 3);bottom:calc(var(--sbb-options-panel-border-radius) / 2 * -1)}.sbb-gap-fix-corner#left{left:calc(var(--sbb-options-panel-border-radius) / 2 * -1)}:host([dir=rtl]) .sbb-gap-fix-corner#left{right:calc(var(--sbb-options-panel-border-radius) / 2 * -1);left:unset}.sbb-gap-fix-corner#right{right:calc(var(--sbb-options-panel-border-radius) / 2 * -1)}:host([dir=rtl]) .sbb-gap-fix-corner#right{left:calc(var(--sbb-options-panel-border-radius) / 2 * -1);right:unset}:host{--sbb-scrollbar-thumb-width: .125rem;--sbb-scrollbar-thumb-width-hover: .25rem;--sbb-scrollbar-width-firefox: thin;--sbb-scrollbar-color: var(--sbb-color-black-alpha-30);--sbb-scrollbar-color-hover: var(--sbb-color-black-alpha-60);--sbb-scrollbar-track-color: transparent;--sbb-options-panel-position-x: 0;--sbb-options-panel-position-y: 0;--sbb-options-panel-active-option-y: 0;--sbb-options-panel-max-height: calc(85vh - var(--sbb-spacing-fixed-8x));--sbb-options-panel-min-height: var(--sbb-options-panel-origin-height);--sbb-options-panel-visibility: visible;--sbb-options-panel-width: fit-content;--sbb-options-panel-border-radius: var(--sbb-border-radius-4x);--sbb-options-panel-options-border-radius: 0 0 var(--sbb-options-panel-border-radius) var(--sbb-options-panel-border-radius);--sbb-options-panel-animation-duration: var( --sbb-disable-animation-time, var(--sbb-animation-duration-4x) );--sbb-options-panel-animation-timing-function: ease;--sbb-options-panel-gap-fix-opacity: 0;--sbb-options-panel-gap-fix-transform: none;--sbb-options-panel-gap-fix-top: calc( var(--sbb-options-panel-position-y) - var(--sbb-options-panel-border-radius) );--sbb-options-panel-background-color: var(--sbb-color-white);--sbb-focus-outline-color: var(--sbb-focus-outline-color-default);--sbb-options-panel-internal-z-index: var( --sbb-select-z-index, var(--sbb-overlay-default-z-index) );display:block}:host([negative]){--sbb-scrollbar-color: var(--sbb-color-white-alpha-30);--sbb-scrollbar-color-hover: var(--sbb-color-white-alpha-60);--sbb-options-panel-background-color: var(--sbb-color-midnight);--sbb-focus-outline-color: var(--sbb-focus-outline-color-dark)}:host(:not([data-state])),:host([data-state=closed]){--sbb-options-panel-visibility: hidden}:host([data-state=opening]){--sbb-options-panel-animation-name: open}:host([data-state=closing]){--sbb-options-panel-animation-name: close}:host([data-state=opened]),:host([data-state=opening]){--sbb-options-panel-gap-fix-opacity: 1}:host([data-options-panel-position=below]){--sbb-options-panel-animation-transform: translateY( calc((var(--sbb-options-panel-origin-height) / 2) * -1) )}:host([data-options-panel-position=above]){--sbb-options-panel-options-border-radius: var(--sbb-options-panel-border-radius) var(--sbb-options-panel-border-radius) 0 0;--sbb-options-panel-gap-fix-top: var(--sbb-options-panel-max-height);--sbb-options-panel-gap-fix-transform: rotate(180deg);--sbb-options-panel-animation-transform: translateY( calc(var(--sbb-options-panel-origin-height) / 2) )}::slotted(sbb-divider){margin-block:var(--sbb-spacing-fixed-3x)}:host([preserve-icon-space]){--sbb-option-icon-container-display: block}.sbb-select__trigger{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;height:calc(1em * var(--sbb-typo-line-height-body-text))}.sbb-select__trigger--placeholder{color:var(--sbb-select-placeholder-color, var(--sbb-color-metal));-webkit-text-fill-color:var(--sbb-select-placeholder-color, var(--sbb-color-metal))}.sbb-select__container{position:fixed;pointer-events:none;top:0;right:0;bottom:0;left:0;z-index:var(--sbb-options-panel-internal-z-index)}.sbb-select__gap-fix{display:flex;justify-content:space-between;position:fixed;visibility:var(--sbb-options-panel-visibility);opacity:var(--sbb-options-panel-gap-fix-opacity);background-color:transparent;width:var(--sbb-options-panel-width);height:var(--sbb-options-panel-border-radius);top:var(--sbb-options-panel-gap-fix-top);left:var(--sbb-options-panel-position-x);transform:var(--sbb-options-panel-gap-fix-transform);transition:opacity var(--sbb-options-panel-animation-duration) var(--sbb-options-panel-animation-timing-function)}.sbb-select__panel{display:block;position:absolute;visibility:var(--sbb-options-panel-visibility);overflow:hidden;background-color:transparent;border:none;border-radius:var(--sbb-options-panel-border-radius);top:var(--sbb-options-panel-position-y);left:var(--sbb-options-panel-position-x);width:var(--sbb-options-panel-width);transition:box-shadow var(--sbb-options-panel-animation-duration) var(--sbb-options-panel-animation-timing-function)}.sbb-select__panel:before,.sbb-select__panel:after{content:"";display:none;position:relative;width:100%;height:var(--sbb-options-panel-origin-height);background-color:transparent;border-radius:var(--sbb-options-panel-border-radius);pointer-events:none;transition:box-shadow var(--sbb-options-panel-animation-duration) var(--sbb-options-panel-animation-timing-function);z-index:1}:host([data-options-panel-position=below]) .sbb-select__panel{inset-block-start:calc(var(--sbb-options-panel-position-y) - var(--sbb-options-panel-origin-height))}:host(:is([data-state=opened],[data-state=opening])) .sbb-select__panel{box-shadow:var(--sbb-shadow-elevation-level-5-shadow-2-offset-x) var(--sbb-shadow-elevation-level-5-shadow-2-offset-y) var(--sbb-shadow-elevation-level-5-shadow-2-blur) var(--sbb-shadow-elevation-level-5-shadow-2-spread) var(--sbb-shadow-elevation-level-5-hard-2-color),var(--sbb-shadow-elevation-level-5-shadow-1-offset-x) var(--sbb-shadow-elevation-level-5-shadow-1-offset-y) var(--sbb-shadow-elevation-level-5-shadow-1-blur) var(--sbb-shadow-elevation-level-5-shadow-1-spread) var(--sbb-shadow-elevation-level-5-hard-1-color)}:host(:is([data-state=opened],[data-state=opening])[negative]) .sbb-select__panel{box-shadow:var(--sbb-shadow-elevation-level-5-shadow-2-offset-x) var(--sbb-shadow-elevation-level-5-shadow-2-offset-y) var(--sbb-shadow-elevation-level-5-shadow-2-blur) var(--sbb-shadow-elevation-level-5-shadow-2-spread) var(--sbb-shadow-elevation-level-5-hard-negative-2-color),var(--sbb-shadow-elevation-level-5-shadow-1-offset-x) var(--sbb-shadow-elevation-level-5-shadow-1-offset-y) var(--sbb-shadow-elevation-level-5-shadow-1-blur) var(--sbb-shadow-elevation-level-5-shadow-1-spread) var(--sbb-shadow-elevation-level-5-hard-negative-1-color)}:host([data-options-panel-position=below]) .sbb-select__panel:before{display:block}:host([data-options-panel-position=above]) .sbb-select__panel:after{display:block}:host(:is([data-state=opened],[data-state=opening])[data-option-panel-origin-borderless]) .sbb-select__panel:before,:host(:is([data-state=opened],[data-state=opening])[data-option-panel-origin-borderless]) .sbb-select__panel:after{box-shadow:var(--sbb-shadow-elevation-level-5-shadow-2-offset-x) var(--sbb-shadow-elevation-level-5-shadow-2-offset-y) var(--sbb-shadow-elevation-level-5-shadow-2-blur) var(--sbb-shadow-elevation-level-5-shadow-2-spread) var(--sbb-shadow-elevation-level-5-hard-2-color),var(--sbb-shadow-elevation-level-5-shadow-1-offset-x) var(--sbb-shadow-elevation-level-5-shadow-1-offset-y) var(--sbb-shadow-elevation-level-5-shadow-1-blur) var(--sbb-shadow-elevation-level-5-shadow-1-spread) var(--sbb-shadow-elevation-level-5-hard-1-color)}:host(:is([data-state=opened],[data-state=opening])[data-option-panel-origin-borderless][negative]) .sbb-select__panel:before,:host(:is([data-state=opened],[data-state=opening])[data-option-panel-origin-borderless][negative]) .sbb-select__panel:after{box-shadow:var(--sbb-shadow-elevation-level-5-shadow-2-offset-x) var(--sbb-shadow-elevation-level-5-shadow-2-offset-y) var(--sbb-shadow-elevation-level-5-shadow-2-blur) var(--sbb-shadow-elevation-level-5-shadow-2-spread) var(--sbb-shadow-elevation-level-5-hard-negative-2-color),var(--sbb-shadow-elevation-level-5-shadow-1-offset-x) var(--sbb-shadow-elevation-level-5-shadow-1-offset-y) var(--sbb-shadow-elevation-level-5-shadow-1-blur) var(--sbb-shadow-elevation-level-5-shadow-1-spread) var(--sbb-shadow-elevation-level-5-hard-negative-1-color)}.sbb-select__wrapper{overflow:hidden}.sbb-select__options{background-color:var(--sbb-options-panel-background-color);padding-block:var(--sbb-spacing-fixed-3x);padding-inline:0;border-radius:var(--sbb-options-panel-options-border-radius);max-height:var(--sbb-options-panel-max-height);min-height:var(--sbb-options-panel-min-height);pointer-events:all;overflow-y:auto;animation-name:var(--sbb-options-panel-animation-name);animation-duration:var(--sbb-options-panel-animation-duration);animation-timing-function:var(--sbb-options-panel-animation-timing-function);--sbb-scrollbar-width: var(--sbb-spacing-fixed-3x)}.sbb-select__options::-webkit-scrollbar{width:var(--sbb-scrollbar-width);height:var(--sbb-scrollbar-width);background-color:var(--sbb-scrollbar-track-color, transparent)}.sbb-select__options::-webkit-scrollbar-corner{background-color:var(--sbb-scrollbar-track-color, transparent)}.sbb-select__options::-webkit-scrollbar-thumb{background-color:var(--sbb-scrollbar-color, currentcolor);border:calc(.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width))) solid transparent;border-radius:var(--sbb-border-radius-4x);background-clip:padding-box}.sbb-select__options::-webkit-scrollbar-thumb:hover{background-color:var(--sbb-scrollbar-color-hover, currentcolor);border-width:calc(.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width-hover)))}.sbb-select__options::-webkit-scrollbar-button,.sbb-select__options::-webkit-scrollbar-corner{display:none}@supports not selector(::-webkit-scrollbar){.sbb-select__options{scrollbar-width:var(--sbb-scrollbar-width-firefox);scrollbar-color:var(--sbb-scrollbar-color, currentcolor) var(--sbb-scrollbar-track-color, transparent)}}.sbb-select__options{padding-block:var(--sbb-spacing-fixed-2x)}@media (forced-colors: active){.sbb-select__options{border:var(--sbb-border-width-1x) solid CanvasText;border-block-start:none}}@keyframes open{0%{transform:var(--sbb-options-panel-animation-transform);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes close{0%{transform:translateY(0);opacity:1}to{transform:var(--sbb-options-panel-animation-transform);opacity:0}}`;
14
+ var V = Object.defineProperty, T = Object.getOwnPropertyDescriptor, n = (e, t, i, s) => {
15
+ for (var o = s > 1 ? void 0 : s ? T(t, i) : t, r = e.length - 1, l; r >= 0; r--)
16
+ (l = e[r]) && (o = (s ? l(t, i, o) : l(o)) || o);
17
+ return s && o && V(t, i, o), o;
17
18
  };
18
- const h = k;
19
- let T = 0, a = class extends C(
20
- A(S(y))
19
+ const h = C;
20
+ let N = 0, a = class extends A(
21
+ S(I(D(x)))
21
22
  ) {
22
23
  constructor() {
23
24
  super(...arguments), this.multiple = !1, this.required = !1, this.readonly = !1, this._displayValue = null, this._didChange = new p(this, a.events.didChange), this._change = new p(this, a.events.change), this._input = new p(this, a.events.input), this._stateChange = new p(
@@ -26,10 +27,10 @@ let T = 0, a = class extends C(
26
27
  {
27
28
  composed: !1
28
29
  }
29
- ), this._overlayId = `sbb-select-${++T}`, this._activeItemIndex = -1, this._searchString = "", this._didLoad = !1, this._isPointerDownEventOnMenu = !1, this._abort = new x(this), this._pointerDownListener = (e) => {
30
- this._isPointerDownEventOnMenu = f(this._overlay, e);
30
+ ), this._overlayId = `sbb-select-${++N}`, this._activeItemIndex = -1, this._searchString = "", this._didLoad = !1, this._isPointerDownEventOnMenu = !1, this._abort = new E(this), this._pointerDownListener = (e) => {
31
+ this._isPointerDownEventOnMenu = _(this._overlay, e);
31
32
  }, this._closeOnBackdropClick = async (e) => {
32
- !this._isPointerDownEventOnMenu && !f(this._overlay, e) && await this.close();
33
+ !this._isPointerDownEventOnMenu && !_(this._overlay, e) && await this.close();
33
34
  };
34
35
  }
35
36
  /**
@@ -59,7 +60,7 @@ let T = 0, a = class extends C(
59
60
  }
60
61
  /** Gets the current displayed value. */
61
62
  getDisplayValue() {
62
- return this._displayValue ? this._displayValue : "";
63
+ return this._displayValue ?? "";
63
64
  }
64
65
  /** Listens to option changes. */
65
66
  _onOptionChanged(e) {
@@ -86,7 +87,7 @@ let T = 0, a = class extends C(
86
87
  this._stateChange.emit({ type: "value", value: e });
87
88
  }
88
89
  firstUpdated(e) {
89
- super.firstUpdated(e), this.focus = () => this._triggerElement.focus(), this.blur = () => this._triggerElement.blur(), u() || (this.startUpdate(), this._setupSelect());
90
+ super.firstUpdated(e), this.focus = () => this._triggerElement.focus(), this.blur = () => this._triggerElement.blur(), f() || (this.startUpdate(), this._setupSelect());
90
91
  }
91
92
  /**
92
93
  * Removes element's first attribute whose qualified name is qualifiedName.
@@ -95,7 +96,7 @@ let T = 0, a = class extends C(
95
96
  * @internal We need to override this due to a hydration issue with Next.js.
96
97
  */
97
98
  removeAttribute(e) {
98
- u() && e === "defer-hydration" && !this._didLoad && this.updateComplete.then(() => this._setupSelect()), super.removeAttribute(e);
99
+ f() && e === "defer-hydration" && !this._didLoad && this.updateComplete.then(() => this._setupSelect()), super.removeAttribute(e);
99
100
  }
100
101
  connectedCallback() {
101
102
  var i, s;
@@ -152,7 +153,7 @@ let T = 0, a = class extends C(
152
153
  this._triggerElement.style.top = "0px", this._triggerElement.style.height = `${e.offsetHeight}px`, this._triggerElement.style.width = `${e.offsetWidth}px`;
153
154
  }
154
155
  _setOverlayPosition() {
155
- I(
156
+ P(
156
157
  this._overlay,
157
158
  this._originElement,
158
159
  this._optionContainer,
@@ -247,17 +248,17 @@ let T = 0, a = class extends C(
247
248
  ...this._filteredOptions.slice(0, t)
248
249
  ], s = i.find(
249
250
  (o) => {
250
- var n;
251
- return ((n = o.textContent) == null ? void 0 : n.toLowerCase().indexOf(this._searchString.toLowerCase())) === 0;
251
+ var r;
252
+ return ((r = o.textContent) == null ? void 0 : r.toLowerCase().indexOf(this._searchString.toLowerCase())) === 0;
252
253
  }
253
254
  );
254
255
  if (s)
255
256
  await this._setNextActiveOption(e, this._filteredOptions.indexOf(s));
256
257
  else if (this._searchString.length > 1 && new RegExp(`^${this._searchString.charAt(0)}*$`).test(this._searchString)) {
257
258
  const o = i.find(
258
- (n) => {
259
+ (r) => {
259
260
  var l;
260
- return ((l = n.textContent) == null ? void 0 : l.toLowerCase().indexOf(this._searchString[0].toLowerCase())) === 0;
261
+ return ((l = r.textContent) == null ? void 0 : l.toLowerCase().indexOf(this._searchString[0].toLowerCase())) === 0;
261
262
  }
262
263
  );
263
264
  o && await this._setNextActiveOption(e, this._filteredOptions.indexOf(o));
@@ -269,7 +270,7 @@ let T = 0, a = class extends C(
269
270
  this.multiple ? await e.setSelectedViaUserInteraction(!e.selected) : await this.close();
270
271
  }
271
272
  async _setNextActiveOption(e, t) {
272
- const i = t ?? w(e, this._activeItemIndex, this._filteredOptions.length), s = this._filteredOptions[i], o = this._filteredOptions[this._activeItemIndex];
273
+ const i = t ?? y(e, this._activeItemIndex, this._filteredOptions.length), s = this._filteredOptions[i], o = this._filteredOptions[this._activeItemIndex];
273
274
  this._setActiveElement(s, o), this.multiple ? e != null && e.shiftKey && await s.setSelectedViaUserInteraction(!s.selected) : await this._setSelectedElement(s, o), this._activeItemIndex = i;
274
275
  }
275
276
  _setActiveElement(e, t = null, i = !0) {
@@ -312,8 +313,14 @@ let T = 0, a = class extends C(
312
313
  }
313
314
  }
314
315
  }
316
+ _spreadDeferredDisplayValue(e) {
317
+ return [this._deferredDisplayValue(e), e];
318
+ }
319
+ async _deferredDisplayValue(e) {
320
+ return this.hydrationRequired && await this.hydrationComplete, this._displayValue ? d`${this._displayValue}` : e;
321
+ }
315
322
  render() {
316
- return b`
323
+ return d`
317
324
  <!-- This element is visually hidden and will be appended to the light DOM to allow screen
318
325
  readers to work properly -->
319
326
  <div
@@ -329,17 +336,21 @@ let T = 0, a = class extends C(
329
336
  @click=${this._toggleOpening}
330
337
  ${v((e) => this._triggerElement = e)}
331
338
  >
332
- ${this._displayValue ? b`${this._displayValue}` : b`<span>${this.placeholder}</span>`}
339
+ ${u(...this._spreadDeferredDisplayValue(d`<span>${this.placeholder}</span>`))}
333
340
  </div>
334
341
 
335
342
  <!-- Visually display the value -->
336
343
  <div class="sbb-select__trigger" aria-hidden="true">
337
- ${this._displayValue ? b`${this._displayValue}` : b`<span class="sbb-select__trigger--placeholder">${this.placeholder}</span>`}
344
+ ${u(
345
+ ...this._spreadDeferredDisplayValue(
346
+ d`<span class="sbb-select__trigger--placeholder">${this.placeholder}</span>`
347
+ )
348
+ )}
338
349
  </div>
339
350
 
340
351
  <div class="sbb-select__gap-fix"></div>
341
352
  <div class="sbb-select__container">
342
- <div class="sbb-select__gap-fix">${P()}</div>
353
+ <div class="sbb-select__gap-fix">${$()}</div>
343
354
  <div
344
355
  @animationend=${this._onAnimationEnd}
345
356
  class="sbb-select__panel"
@@ -361,7 +372,7 @@ let T = 0, a = class extends C(
361
372
  `;
362
373
  }
363
374
  };
364
- a.styles = $;
375
+ a.styles = L;
365
376
  a.events = {
366
377
  didChange: "didChange",
367
378
  change: "change",
@@ -372,28 +383,28 @@ a.events = {
372
383
  willClose: "willClose",
373
384
  didClose: "didClose"
374
385
  };
375
- r([
376
- d()
386
+ n([
387
+ b()
377
388
  ], a.prototype, "value", 2);
378
- r([
379
- d()
389
+ n([
390
+ b()
380
391
  ], a.prototype, "placeholder", 2);
381
- r([
382
- d({ type: Boolean, reflect: !0 })
392
+ n([
393
+ b({ type: Boolean, reflect: !0 })
383
394
  ], a.prototype, "multiple", 2);
384
- r([
385
- d({ reflect: !0, type: Boolean })
395
+ n([
396
+ b({ reflect: !0, type: Boolean })
386
397
  ], a.prototype, "required", 2);
387
- r([
388
- d({ type: Boolean })
398
+ n([
399
+ b({ type: Boolean })
389
400
  ], a.prototype, "readonly", 2);
390
- r([
391
- g()
401
+ n([
402
+ m()
392
403
  ], a.prototype, "_displayValue", 2);
393
- a = r([
394
- m("sbb-select"),
395
- E({
396
- dir: O(),
404
+ a = n([
405
+ w("sbb-select"),
406
+ O({
407
+ dir: k(),
397
408
  role: h ? "listbox" : null
398
409
  })
399
410
  ], a);
@@ -1321,6 +1321,7 @@ summary {
1321
1321
  --sbb-train-formation-wagon-gap: var(--sbb-spacing-fixed-1x);
1322
1322
  --sbb-header-height: var(--sbb-spacing-fixed-14x);
1323
1323
  --sbb-time-input-max-width: 3.625rem;
1324
+ --sbb-time-input-s-max-width: 3.1875rem;
1324
1325
  --sbb-overlay-default-z-index: 1000;
1325
1326
  --sbb-border-radius-infinity: 10000000em;
1326
1327
  }
@@ -1328,6 +1329,7 @@ summary {
1328
1329
  :root {
1329
1330
  --sbb-header-height: var(--sbb-spacing-fixed-24x);
1330
1331
  --sbb-time-input-max-width: 4.0625rem;
1332
+ --sbb-time-input-s-max-width: 3.625rem;
1331
1333
  }
1332
1334
  }
1333
1335
 
@@ -1486,6 +1488,9 @@ sbb-title + p {
1486
1488
  input[data-sbb-time-input] {
1487
1489
  max-width: var(--sbb-time-input-max-width);
1488
1490
  }
1491
+ sbb-form-field[size=s] input[data-sbb-time-input] {
1492
+ max-width: var(--sbb-time-input-s-max-width);
1493
+ }
1489
1494
 
1490
1495
  sub {
1491
1496
  bottom: -0.36em;
@@ -1685,6 +1690,7 @@ sup {
1685
1690
  --sbb-step-list-padding-block: var(--sbb-spacing-fixed-3x);
1686
1691
  --sbb-step-list-padding-inline: var(--sbb-spacing-responsive-xxs);
1687
1692
  --sbb-step-list-marker-to-text-gap: var(--sbb-spacing-responsive-xxxs);
1693
+ --sbb-step-list-border-radius: var(--sbb-border-radius-4x);
1688
1694
  --sbb-step-list-text-to-marker-block-offset: calc(
1689
1695
  0.5 *
1690
1696
  (
@@ -1714,11 +1720,18 @@ sup {
1714
1720
  position: relative;
1715
1721
  counter-increment: steps;
1716
1722
  background-color: var(--sbb-color-milk);
1717
- border-radius: var(--sbb-border-radius-4x);
1718
1723
  padding-block: calc(var(--sbb-step-list-padding-block) + var(--sbb-step-list-text-to-marker-block-offset)) var(--sbb-step-list-padding-block);
1719
1724
  padding-inline: calc(var(--sbb-step-list-padding-inline) + var(--sbb-step-list-marker-dimensions) + var(--sbb-step-list-marker-to-text-gap)) var(--sbb-step-list-padding-inline);
1720
1725
  min-height: calc(var(--sbb-step-list-marker-dimensions) + 2 * var(--sbb-step-list-padding-block));
1721
1726
  }
1727
+ .sbb-step-list > li:first-of-type {
1728
+ border-start-start-radius: var(--sbb-step-list-border-radius);
1729
+ border-start-end-radius: var(--sbb-step-list-border-radius);
1730
+ }
1731
+ .sbb-step-list > li:last-of-type {
1732
+ border-end-start-radius: var(--sbb-step-list-border-radius);
1733
+ border-end-end-radius: var(--sbb-step-list-border-radius);
1734
+ }
1722
1735
  .sbb-step-list > li::before {
1723
1736
  --sbb-text-font-size: var(--sbb-font-size-text-xxs);
1724
1737
  font-family: var(--sbb-typo-font-family);