@sbb-esta/lyne-elements 2.5.0 → 2.5.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 (46) hide show
  1. package/autocomplete/autocomplete-base-element.d.ts +0 -1
  2. package/autocomplete/autocomplete-base-element.d.ts.map +1 -1
  3. package/autocomplete.js +13 -13
  4. package/core/base-elements/button-base-element.d.ts +5 -0
  5. package/core/base-elements/button-base-element.d.ts.map +1 -1
  6. package/core/base-elements.js +94 -79
  7. package/core/dom/platform.d.ts +5 -0
  8. package/core/dom/platform.d.ts.map +1 -1
  9. package/core/dom.js +10 -9
  10. package/core/mixins/form-associated-input-mixin.d.ts.map +1 -1
  11. package/core/mixins/form-associated-radio-button-mixin.d.ts.map +1 -1
  12. package/core/mixins.js +16 -13
  13. package/custom-elements.json +992 -102
  14. package/development/autocomplete/autocomplete-base-element.d.ts +0 -1
  15. package/development/autocomplete/autocomplete-base-element.d.ts.map +1 -1
  16. package/development/autocomplete.js +2 -4
  17. package/development/core/base-elements/button-base-element.d.ts +5 -0
  18. package/development/core/base-elements/button-base-element.d.ts.map +1 -1
  19. package/development/core/base-elements.js +38 -10
  20. package/development/core/dom/platform.d.ts +5 -0
  21. package/development/core/dom/platform.d.ts.map +1 -1
  22. package/development/core/dom.js +3 -1
  23. package/development/core/mixins/form-associated-input-mixin.d.ts.map +1 -1
  24. package/development/core/mixins/form-associated-radio-button-mixin.d.ts.map +1 -1
  25. package/development/core/mixins.js +8 -4
  26. package/development/form-field/form-field.js +2 -2
  27. package/development/radio-button/radio-button-group/radio-button-group.d.ts +0 -1
  28. package/development/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
  29. package/development/radio-button/radio-button-group.js +3 -5
  30. package/development/select/select.d.ts +5 -2
  31. package/development/select/select.d.ts.map +1 -1
  32. package/development/select.js +6 -4
  33. package/development/stepper/step/step.d.ts +1 -3
  34. package/development/stepper/step/step.d.ts.map +1 -1
  35. package/development/stepper/step.js +2 -7
  36. package/form-field/form-field.js +1 -1
  37. package/package.json +1 -1
  38. package/radio-button/radio-button-group/radio-button-group.d.ts +0 -1
  39. package/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
  40. package/radio-button/radio-button-group.js +8 -8
  41. package/select/select.d.ts +5 -2
  42. package/select/select.d.ts.map +1 -1
  43. package/select.js +8 -9
  44. package/stepper/step/step.d.ts +1 -3
  45. package/stepper/step/step.d.ts.map +1 -1
  46. package/stepper/step.js +11 -14
@@ -352,7 +352,7 @@ let SbbSelectElement = (() => {
352
352
  __privateSet(this, __displayValue_accessor_storage, (__runInitializers(this, _readonly_extraInitializers), __runInitializers(this, __displayValue_initializers, null)));
353
353
  this._change = (__runInitializers(this, __displayValue_extraInitializers), new EventEmitter(this, SbbSelectElement2.events.change));
354
354
  this._input = new EventEmitter(this, SbbSelectElement2.events.input);
355
- this._stateChange = new EventEmitter(this, SbbSelectElement2.events.stateChange, {
355
+ this._displayValueChanged = new EventEmitter(this, SbbSelectElement2.events.displayValueChange, {
356
356
  composed: false
357
357
  });
358
358
  this._sbbEscapableOverlayController = new SbbEscapableOverlayController(this);
@@ -521,6 +521,7 @@ let SbbSelectElement = (() => {
521
521
  } else {
522
522
  this._displayValue = null;
523
523
  }
524
+ this._displayValueChanged.emit();
524
525
  }
525
526
  /**
526
527
  * The `value` property should be adapted when the `multiple` property changes:
@@ -558,7 +559,6 @@ let SbbSelectElement = (() => {
558
559
  selectedElements.forEach((o) => o.selected = true);
559
560
  this._updateDisplayValue(selectedElements);
560
561
  }
561
- this._stateChange.emit({ type: "value", value: newValue });
562
562
  }
563
563
  firstUpdated(changedProperties) {
564
564
  super.firstUpdated(changedProperties);
@@ -921,6 +921,8 @@ let SbbSelectElement = (() => {
921
921
  } else if (selected) {
922
922
  this._activeItemIndex = this._filteredOptions.findIndex((option) => option === selected);
923
923
  this.value = selected.value;
924
+ } else if (this.value) {
925
+ this._onValueChanged(this.value);
924
926
  }
925
927
  }
926
928
  _getSelected() {
@@ -1032,7 +1034,7 @@ let SbbSelectElement = (() => {
1032
1034
  })(), _a.styles = style, _a.events = {
1033
1035
  change: "change",
1034
1036
  input: "input",
1035
- stateChange: "stateChange",
1037
+ displayValueChange: "displayValueChange",
1036
1038
  willOpen: "willOpen",
1037
1039
  didOpen: "didOpen",
1038
1040
  willClose: "willClose",
@@ -1043,4 +1045,4 @@ let SbbSelectElement = (() => {
1043
1045
  export {
1044
1046
  SbbSelectElement
1045
1047
  };
1046
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"select.js","sources":["../../../src/elements/select/select.ts"],"sourcesContent":["import { MutationController } from '@lit-labs/observers/mutation-controller.js';\nimport type { CSSResultGroup, PropertyDeclaration, PropertyValues, TemplateResult } from 'lit';\nimport { html, isServer, nothing } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\nimport { until } from 'lit/directives/until.js';\n\nimport { getNextElementIndex } from '../core/a11y.js';\nimport { SbbOpenCloseBaseElement } from '../core/base-elements.js';\nimport { SbbLanguageController, SbbEscapableOverlayController } from '../core/controllers.js';\nimport {\n  forceType,\n  getOverride,\n  handleDistinctChange,\n  hostAttributes,\n} from '../core/decorators.js';\nimport { isNextjs, isSafari, isZeroAnimationDuration, setOrRemoveAttribute } from '../core/dom.js';\nimport { EventEmitter } from '../core/eventing.js';\nimport { i18nSelectionRequired } from '../core/i18n.js';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbDisabledMixin,\n  SbbFormAssociatedMixin,\n  SbbHydrationMixin,\n  SbbNegativeMixin,\n  SbbRequiredMixin,\n  SbbUpdateSchedulerMixin,\n} from '../core/mixins.js';\nimport { isEventOnElement, overlayGapFixCorners, setOverlayPosition } from '../core/overlay.js';\nimport type { SbbOptGroupElement, SbbOptionElement } from '../option.js';\n\nimport style from './select.scss?lit&inline';\n\n/**\n * On Safari, the aria role 'listbox' must be on the host element, or else VoiceOver won't work at all.\n * On the other hand, JAWS and NVDA need the role to be an \"immediate parent\" to the options, or else optgroups won't work.\n */\nconst ariaRoleOnHost = isSafari;\n\nlet nextId = 0;\n\nexport interface SelectChange {\n  type: 'value';\n  value: string | string[];\n}\n\n/**\n * It displays a panel with selectable options.\n *\n * @slot - Use the unnamed slot to add options.\n * @event {CustomEvent<void>} change - Notifies that the component's value has changed.\n * @event {CustomEvent<void>} input - Notifies that an option value has been selected.\n * @event {CustomEvent<void>} willOpen - Emits whenever the `sbb-select` starts the opening transition. Can be canceled.\n * @event {CustomEvent<void>} didOpen - Emits whenever the `sbb-select` is opened.\n * @event {CustomEvent<void>} willClose - Emits whenever the `sbb-select` begins the closing transition. Can be canceled.\n * @event {CustomEvent<void>} didClose - Emits whenever the `sbb-select` is closed.\n * @cssprop [--sbb-select-z-index=var(--sbb-overlay-default-z-index)] - To specify a custom stack order,\n * the `z-index` can be overridden by defining this CSS variable. The default `z-index` of the\n * component is set to `var(--sbb-overlay-default-z-index)` with a value of `1000`.\n * @overrideType value - string | string[] | null\n */\nexport\n@customElement('sbb-select')\n@hostAttributes({\n  role: ariaRoleOnHost ? 'listbox' : null,\n})\nclass SbbSelectElement extends SbbUpdateSchedulerMixin(\n  SbbDisabledMixin(\n    SbbNegativeMixin(\n      SbbHydrationMixin(\n        SbbRequiredMixin(\n          SbbFormAssociatedMixin<typeof SbbOpenCloseBaseElement, string | string[]>(\n            SbbOpenCloseBaseElement,\n          ),\n        ),\n      ),\n    ),\n  ),\n) {\n  public static override styles: CSSResultGroup = style;\n\n  // TODO: fix using ...super.events requires: https://github.com/sbb-design-systems/lyne-components/issues/2600\n  public static override readonly events = {\n    change: 'change',\n    input: 'input',\n    stateChange: 'stateChange',\n    willOpen: 'willOpen',\n    didOpen: 'didOpen',\n    willClose: 'willClose',\n    didClose: 'didClose',\n  } as const;\n\n  /** The placeholder used if no value has been selected. */\n  @forceType()\n  @property()\n  public accessor placeholder: string = '';\n\n  /** Whether the select allows for multiple selection. */\n  @forceType()\n  @handleDistinctChange((e: SbbSelectElement, newValue: boolean) => e._onMultipleChanged(newValue))\n  @property({ reflect: true, type: Boolean })\n  public accessor multiple: boolean = false;\n\n  @forceType()\n  @handleDistinctChange((e: SbbSelectElement, newValue: boolean) =>\n    e._closeOnDisabledReadonlyChanged(newValue),\n  )\n  @property({ reflect: true, type: Boolean })\n  @getOverride((e: SbbSelectElement, v: boolean): boolean => v || e.isDisabledExternally())\n  public override accessor disabled: boolean = false;\n\n  /** Whether the select is readonly. */\n  @forceType()\n  @handleDistinctChange((e: SbbSelectElement, newValue: boolean) =>\n    e._closeOnDisabledReadonlyChanged(newValue),\n  )\n  @property({ type: Boolean })\n  public accessor readonly: boolean = false;\n\n  /**\n   * Form type of element.\n   * @default 'select-one / select-multiple'\n   */\n  public override get type(): string {\n    return this.multiple ? 'select-multiple' : 'select-one';\n  }\n\n  /** The value displayed by the component. */\n  @state() private accessor _displayValue: string | null = null;\n\n  /** Notifies that the component's value has changed. */\n  private _change: EventEmitter = new EventEmitter(this, SbbSelectElement.events.change);\n\n  /** Notifies that an option value has been selected. */\n  private _input: EventEmitter = new EventEmitter(this, SbbSelectElement.events.input);\n\n  /** @internal */\n  private _stateChange: EventEmitter<SelectChange> = new EventEmitter(\n    this,\n    SbbSelectElement.events.stateChange,\n    {\n      composed: false,\n    },\n  );\n\n  private _overlay!: HTMLElement;\n  private _optionContainer!: HTMLElement;\n  private _originElement!: HTMLElement;\n  private _triggerElement!: HTMLElement;\n  private _openPanelEventsController!: AbortController;\n  private _sbbEscapableOverlayController = new SbbEscapableOverlayController(this);\n  private _overlayId = `sbb-select-${++nextId}`;\n  private _activeItemIndex = -1;\n  private _searchTimeout?: ReturnType<typeof setTimeout>;\n  private _searchString = '';\n  private _didLoad = false;\n  private _isPointerDownEventOnMenu: boolean = false;\n  private _languageController = new SbbLanguageController(this);\n\n  /**\n   * The 'combobox' input element\n   * @internal\n   */\n  public get inputElement(): HTMLElement {\n    return this._triggerElement;\n  }\n\n  /** Gets all the SbbOptionElement projected in the select. */\n  private get _options(): SbbOptionElement[] {\n    return Array.from(this.querySelectorAll?.('sbb-option') ?? []);\n  }\n\n  private get _filteredOptions(): SbbOptionElement[] {\n    return this._options.filter(\n      (opt: SbbOptionElement) => !opt.disabled && !opt.hasAttribute('data-group-disabled'),\n    );\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('optionSelectionChange', (e: CustomEvent<void>) =>\n      this._onOptionChanged(e),\n    );\n    this.addEventListener?.('optionLabelChanged', (e: Event) => this._onOptionLabelChanged(e));\n    this.addEventListener?.('click', (e: MouseEvent) => {\n      const target = e.target as SbbSelectElement | SbbOptionElement;\n      if (target.localName === 'sbb-option') {\n        // Option click\n        if (!this.multiple && !target.disabled) {\n          this.close();\n          this.focus();\n        }\n      } else {\n        this._toggleOpening();\n      }\n    });\n\n    new MutationController(this, {\n      config: { attributeFilter: ['aria-labelledby', 'aria-label', 'aria-describedby'] },\n      callback: () => this._syncAriaLabels(),\n    });\n  }\n\n  private _syncAriaLabels(): void {\n    if (!this._triggerElement || isServer) {\n      return;\n    }\n\n    setOrRemoveAttribute(\n      this._triggerElement,\n      'aria-labelledby',\n      this.getAttribute('aria-labelledby'),\n    );\n    setOrRemoveAttribute(this._triggerElement, 'aria-label', this.getAttribute('aria-label'));\n    setOrRemoveAttribute(\n      this._triggerElement,\n      'aria-describedby',\n      this.getAttribute('aria-describedby'),\n    );\n\n    // Using the associated labels is only a fallback.\n    // The drawback is, that it doesn't get updated automatically when the list of label changes.\n    if (\n      !this.getAttribute('aria-label') &&\n      !this.getAttribute('aria-labelledby') &&\n      this.internals.labels.length\n    ) {\n      this._triggerElement?.setAttribute(\n        'aria-label',\n        Array.from(this.internals.labels)\n          .map((label) => label.textContent)\n          .join(', '),\n      );\n    }\n  }\n\n  /** Opens the selection panel. */\n  public open(): void {\n    if (\n      this.state !== 'closed' ||\n      !this._overlay ||\n      this._options.length === 0 ||\n      this.disabled ||\n      this.formDisabled\n    ) {\n      return;\n    }\n\n    if (!this.willOpen.emit()) {\n      return;\n    }\n\n    this.shadowRoot?.querySelector<HTMLDivElement>('.sbb-select__container')?.showPopover?.();\n    this.state = 'opening';\n    this.toggleAttribute('data-expanded', true);\n    this._setOverlayPosition();\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `opened` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleOpening();\n    }\n  }\n\n  /** Closes the selection panel. */\n  public close(): void {\n    if (this.state !== 'opened') {\n      return;\n    }\n    if (!this.willClose.emit()) {\n      return;\n    }\n\n    this.state = 'closing';\n    this.toggleAttribute('data-expanded', false);\n    this._openPanelEventsController.abort();\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `closed` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleClosing();\n    }\n  }\n\n  private _isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-options-panel-animation-duration');\n  }\n\n  /** Gets the current displayed value. */\n  public getDisplayValue(): string {\n    return this._displayValue ?? '';\n  }\n\n  /** Listens to option changes. */\n  private _onOptionChanged(event: Event): void {\n    const target = event.target as SbbOptionElement;\n    if (target.selected) {\n      this._onOptionSelected(target);\n    } else {\n      this._onOptionDeselected(target);\n    }\n  }\n\n  /** Listens to option changes. */\n  private _onOptionLabelChanged(event: Event): void {\n    const target = event.target as SbbOptionElement;\n    const selected = this._getSelected();\n\n    if (\n      (!Array.isArray(selected) && target !== selected) ||\n      (Array.isArray(selected) && !selected.includes(target))\n    ) {\n      return;\n    }\n\n    this._updateDisplayValue(selected);\n  }\n\n  private _updateDisplayValue(selected: SbbOptionElement | SbbOptionElement[] | null): void {\n    if (Array.isArray(selected)) {\n      this._displayValue = selected.map((o) => o.textContent).join(', ') || null;\n    } else if (selected) {\n      this._displayValue = selected?.textContent || null;\n    } else {\n      this._displayValue = null;\n    }\n  }\n\n  /**\n   * The `value` property should be adapted when the `multiple` property changes:\n   *   - if it changes to true, the 'value' is set to an array;\n   *   - if it changes to false, the first available option is set as 'value' otherwise it's set to null.\n   */\n  private _onMultipleChanged(newValue: boolean): void {\n    if (newValue) {\n      this.value = this.value !== null ? [this.value as string] : [];\n    } else {\n      this.value = (this.value as string[]).length ? (this.value as string[])[0] : null;\n    }\n  }\n\n  /**\n   * If the `disabled` or the `readonly` properties are set, and the panel is open, close it.\n   */\n  private _closeOnDisabledReadonlyChanged(newValue: boolean): void {\n    if (this.isOpen && newValue) {\n      this.close();\n    }\n  }\n\n  /** Sets the _displayValue by checking the internal sbb-options and setting the correct `selected` value on them. */\n  private _onValueChanged(newValue: string | string[]): void {\n    const options = this._filteredOptions;\n    if (!Array.isArray(newValue)) {\n      const optionElement =\n        options.find((o) => (o.value ?? o.getAttribute('value')) === newValue) ?? null;\n      if (optionElement) {\n        optionElement.selected = true;\n      }\n      options\n        .filter((o) => (o.value ?? o.getAttribute('value')) !== newValue)\n        .forEach((o) => (o.selected = false));\n      this._updateDisplayValue(optionElement);\n    } else {\n      options\n        .filter((o) => !newValue.includes(o.value ?? o.getAttribute('value')))\n        .forEach((e) => (e.selected = false));\n      const selectedElements = options.filter((o) =>\n        newValue.includes(o.value ?? o.getAttribute('value')),\n      );\n      selectedElements.forEach((o) => (o.selected = true));\n      this._updateDisplayValue(selectedElements);\n    }\n    this._stateChange.emit({ type: 'value', value: newValue });\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    // Override the default focus behavior\n    this.focus = () => this._triggerElement.focus();\n    this.blur = () => this._triggerElement.blur();\n\n    // Wait for ssr hydration\n    if (!isNextjs()) {\n      this.startUpdate();\n      this._setupSelect();\n    }\n  }\n\n  /**\n   * Removes element's first attribute whose qualified name is qualifiedName.\n   *\n   * [MDN Reference](https://developer.mozilla.org/docs/Web/API/Element/removeAttribute)\n   * @internal We need to override this due to a hydration issue with Next.js.\n   */\n  public override removeAttribute(qualifiedName: string): void {\n    // In Next.js the hydration needs to finish before we can manipulate the light DOM.\n    // @lit/react calls removeAttribute('defer-hydration') in a useLayoutEffect,\n    // which is done after hydration is finished. Due to this we intercept this call\n    // in overriding removeAttribute to finish initialization of the sbb-select.\n    // https://github.com/lit/lit/blob/main/packages/react/src/create-component.ts#L293-L296\n    // We also need to wait for update complete in order to be sure that the shadow DOM has been rendered.\n    if (isNextjs() && qualifiedName === 'defer-hydration' && !this._didLoad) {\n      this.updateComplete.then(() => this._setupSelect());\n    }\n    super.removeAttribute(qualifiedName);\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n\n    if (ariaRoleOnHost) {\n      this.id ||= this._overlayId;\n    }\n\n    const formField = this.closest?.('sbb-form-field') ?? this.closest?.('[data-form-field]');\n\n    if (formField) {\n      this.negative = formField.hasAttribute('negative');\n    }\n    this._syncProperties();\n    this._syncAriaLabels();\n\n    if (this._didLoad) {\n      this._setupOrigin();\n      this._setupTrigger();\n    }\n    if (this.value) {\n      this._onValueChanged(this.value);\n    }\n  }\n\n  public override requestUpdate(\n    name?: PropertyKey,\n    oldValue?: unknown,\n    options?: PropertyDeclaration,\n  ): void {\n    super.requestUpdate(name, oldValue, options);\n    if (!name && this.hasUpdated) {\n      setTimeout(() => this._syncAriaLabels());\n    }\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    // On initialization, the '_onValueChanged' is called by the connectedCallback\n    if (changedProperties.has('value') && this._didLoad) {\n      this._onValueChanged(this.value!);\n    }\n    if (changedProperties.has('negative') || changedProperties.has('multiple')) {\n      this._syncProperties();\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this.prepend(this._triggerElement); // Take back the trigger element previously moved to the light DOM\n    this._openPanelEventsController?.abort();\n  }\n\n  protected override updateFormValue(): void {\n    if (this.multiple && this.value instanceof Array) {\n      const data = new FormData();\n      (this.value as string[]).forEach((el) => data.append(this.name, el));\n      this.internals.setFormValue(data);\n    } else {\n      this.internals.setFormValue(this.value as string | null);\n    }\n  }\n\n  /**\n   * The reset value is the attribute value (the setup value), null otherwise.\n   * @internal\n   */\n  public formResetCallback(): void {\n    this.value = this.hasAttribute('value') ? this.getAttribute('value') : null;\n  }\n\n  /**\n   * @internal\n   */\n  public formStateRestoreCallback(\n    state: FormRestoreState | null,\n    _reason: FormRestoreReason,\n  ): void {\n    if (!state) {\n      this.value = null;\n      return;\n    }\n\n    if (this.multiple) {\n      // if multiple, the state format is ['field-name', 'value'][]\n      this.value = (state as [string, string][]).map((entries) => entries[1]);\n    } else {\n      this.value = state as string;\n    }\n  }\n\n  private _syncProperties(): void {\n    this.querySelectorAll?.('sbb-divider').forEach((element) => (element.negative = this.negative));\n\n    this.querySelectorAll?.<SbbOptionElement | SbbOptGroupElement>(\n      'sbb-option, sbb-optgroup',\n    ).forEach((element: SbbOptionElement | SbbOptGroupElement) => {\n      element.toggleAttribute('data-negative', this.negative);\n      element.toggleAttribute('data-multiple', this.multiple);\n    });\n\n    this.querySelectorAll?.<SbbOptionElement | SbbOptGroupElement>(\n      'sbb-option, sbb-optgroup',\n    ).forEach((e) => e.requestUpdate?.());\n  }\n\n  protected override shouldValidate(name: PropertyKey | undefined): boolean {\n    return super.shouldValidate(name) || name === 'value' || name === 'required';\n  }\n\n  protected override validate(): void {\n    super.validate();\n    if (this.required && this._options.every((o) => o.value !== this.value)) {\n      this.setValidityFlag('valueMissing', i18nSelectionRequired[this._languageController.current]);\n    } else {\n      this.removeValidityFlag('valueMissing');\n    }\n  }\n\n  private _setupSelect(): void {\n    this._setupOrigin();\n    this._setupTrigger();\n    this._didLoad = true;\n    this.completeUpdate();\n  }\n\n  /** Sets the originElement; if the component is used in a sbb-form-field uses it, otherwise uses the parentElement. */\n  private _setupOrigin(): void {\n    const formField = this.closest?.('sbb-form-field');\n    this._originElement =\n      formField?.shadowRoot?.querySelector?.('#overlay-anchor') ?? this.parentElement!;\n    if (this._originElement) {\n      this.toggleAttribute(\n        'data-option-panel-origin-borderless',\n        !!formField?.hasAttribute?.('borderless'),\n      );\n    }\n  }\n\n  /**\n   * To assess screen-readers problems caused by the interaction between aria patterns and shadow DOM,\n   * we are forced to move the 'combobox' trigger element to the light DOM\n   */\n  private _setupTrigger(): void {\n    // Move the trigger before the sbb-select\n    this.parentElement!.insertBefore?.(this._triggerElement, this);\n\n    // Set the invisible trigger element dimension to match the parent (needed for screen readers)\n    const containerElement = this.closest?.('sbb-form-field') ?? this;\n    this._triggerElement.style.top = '0px';\n    this._triggerElement.style.height = `${containerElement.offsetHeight}px`;\n    this._triggerElement.style.width = `${containerElement.offsetWidth}px`;\n  }\n\n  private _setOverlayPosition(): void {\n    setOverlayPosition(\n      this._overlay,\n      this._originElement,\n      this._optionContainer,\n      this.shadowRoot!.querySelector('.sbb-select__container')!,\n      this,\n    );\n  }\n\n  // In rare cases it can be that the animationEnd event is triggered twice.\n  // To avoid entering a corrupt state, exit when state is not expected.\n  private _onAnimationEnd(event: AnimationEvent): void {\n    if (event.animationName === 'open' && this.state === 'opening') {\n      this._handleOpening();\n    } else if (event.animationName === 'close' && this.state === 'closing') {\n      this._handleClosing();\n    }\n  }\n\n  private _handleOpening(): void {\n    this.state = 'opened';\n    this._attachOpenPanelEvents();\n    this._triggerElement.setAttribute('aria-expanded', 'true');\n    this._sbbEscapableOverlayController.connect();\n    this.didOpen.emit();\n  }\n\n  private _handleClosing(): void {\n    this.state = 'closed';\n    this.shadowRoot?.querySelector<HTMLDivElement>('.sbb-select__container')?.hidePopover?.();\n    this._triggerElement.setAttribute('aria-expanded', 'false');\n    this._resetActiveElement();\n    this._optionContainer.scrollTop = 0;\n    this._sbbEscapableOverlayController.disconnect();\n    this.didClose.emit();\n  }\n\n  /** When an option is selected, updates the displayValue; it also closes the select if not `multiple`. */\n  private _onOptionSelected(optionSelectionChange: SbbOptionElement): void {\n    if (!this.multiple) {\n      this._filteredOptions\n        .filter((option) => option.id !== optionSelectionChange.id)\n        .forEach((option) => (option.selected = false));\n      this.value = optionSelectionChange.value;\n    } else {\n      if (!this.value) {\n        this.value = [optionSelectionChange.value!];\n      } else if (!this.value.includes(optionSelectionChange.value!)) {\n        this.value = [...this.value, optionSelectionChange.value!];\n      }\n    }\n\n    this._input.emit();\n    this._change.emit();\n  }\n\n  /** When an option is unselected in `multiple`, removes it from value and updates displayValue. */\n  private _onOptionDeselected(optionSelectionChange: SbbOptionElement): void {\n    if (this.multiple) {\n      this.value = (this.value as string[]).filter(\n        (el: string) => el !== optionSelectionChange.value,\n      );\n\n      this._input.emit();\n      this._change.emit();\n    }\n  }\n\n  private _attachOpenPanelEvents(): void {\n    this._openPanelEventsController = new AbortController();\n\n    // Recalculate the overlay position on scroll and window resize\n    document.addEventListener('scroll', () => this._setOverlayPosition(), {\n      passive: true,\n      signal: this._openPanelEventsController.signal,\n      // Without capture, other scroll contexts would not bubble to this event listener.\n      // Capture allows us to react to all scroll contexts in this DOM.\n      capture: true,\n    });\n    window.addEventListener('resize', () => this._setOverlayPosition(), {\n      passive: true,\n      signal: this._openPanelEventsController.signal,\n    });\n\n    // Close menu on backdrop click\n    window.addEventListener('pointerdown', (ev) => this._pointerDownListener(ev), {\n      signal: this._openPanelEventsController.signal,\n    });\n    window.addEventListener('pointerup', (ev) => this._closeOnBackdropClick(ev), {\n      signal: this._openPanelEventsController.signal,\n    });\n  }\n\n  private _onKeyDown(event: KeyboardEvent): void {\n    if (this.readonly) {\n      return;\n    }\n\n    if (this.state === 'opened') {\n      this._openedPanelKeyboardInteraction(event);\n    } else if (this.state === 'closed') {\n      this._closedPanelKeyboardInteraction(event);\n    }\n  }\n\n  private _closedPanelKeyboardInteraction(event: KeyboardEvent): void {\n    if (this._checkForLetterSelection(event)) {\n      return this._setNextActiveOptionByText(event);\n    }\n\n    switch (event.key) {\n      case 'Enter':\n      case ' ':\n      case 'ArrowDown':\n      case 'ArrowUp':\n        event.preventDefault();\n        this.open();\n        break;\n    }\n  }\n\n  private _openedPanelKeyboardInteraction(event: KeyboardEvent): void {\n    if (this.readonly || this.state !== 'opened') {\n      return;\n    }\n\n    if (this._checkForLetterSelection(event)) {\n      return this._setNextActiveOptionByText(event);\n    }\n\n    switch (event.key) {\n      case 'Tab':\n        this.close();\n        break;\n\n      case 'Enter':\n      case ' ':\n        event.preventDefault();\n        this._selectByKeyboard();\n        break;\n\n      case 'ArrowDown':\n      case 'ArrowUp':\n        event.preventDefault();\n        this._setNextActiveOption(event);\n        break;\n\n      case 'Home':\n      case 'PageUp':\n        event.preventDefault();\n        this._setNextActiveOption(event, 0);\n        break;\n\n      case 'End':\n      case 'PageDown':\n        event.preventDefault();\n        this._setNextActiveOption(event, this._filteredOptions.length - 1);\n        break;\n    }\n  }\n\n  private _checkForLetterSelection(event: KeyboardEvent): boolean {\n    return (\n      event.key === 'Backspace' ||\n      event.key === 'Clear' ||\n      (event.key.length === 1 &&\n        event.key !== ' ' &&\n        !event.altKey &&\n        !event.ctrlKey &&\n        !event.metaKey)\n    );\n  }\n\n  private _setNextActiveOptionByText(event: KeyboardEvent): void {\n    // Set timeout and the string to search.\n    if (typeof this._searchTimeout === typeof setTimeout) {\n      clearTimeout(this._searchTimeout);\n    }\n    this._searchTimeout = setTimeout(() => (this._searchString = ''), 1000);\n    this._searchString += event.key;\n\n    // Reorder the _filteredOption array to have the last selected element at the bottom.\n    const indexForSlice: number = this._activeItemIndex + 1;\n    const filteredOptionsSorted: SbbOptionElement[] = [\n      ...this._filteredOptions.slice(indexForSlice),\n      ...this._filteredOptions.slice(0, indexForSlice),\n    ];\n\n    const match = filteredOptionsSorted.find(\n      (option: SbbOptionElement) =>\n        option.textContent?.toLowerCase().indexOf(this._searchString.toLowerCase()) === 0,\n    );\n    if (match) {\n      // If an exact match has been found, go to that option.\n      this._setNextActiveOption(event, this._filteredOptions.indexOf(match));\n    } else if (\n      this._searchString.length > 1 &&\n      new RegExp(`^${this._searchString.charAt(0)}*$`).test(this._searchString)\n    ) {\n      // If no exact match has been found but the string to search is made by the same repeated letter,\n      // go to the first element, if exists, that matches the letter.\n      const firstMatch = filteredOptionsSorted.find(\n        (option: SbbOptionElement) =>\n          option.textContent?.toLowerCase().indexOf(this._searchString[0].toLowerCase()) === 0,\n      );\n      if (firstMatch) {\n        this._setNextActiveOption(event, this._filteredOptions.indexOf(firstMatch));\n      }\n    } else {\n      // No match found, clear the timeout and the search term.\n      clearTimeout(this._searchTimeout);\n      this._searchString = '';\n    }\n  }\n\n  private _selectByKeyboard(): void {\n    const activeOption: SbbOptionElement = this._filteredOptions[this._activeItemIndex];\n\n    if (this.multiple) {\n      activeOption.setSelectedViaUserInteraction(!activeOption.selected);\n    } else {\n      this.close();\n    }\n  }\n\n  private _setNextActiveOption(event: KeyboardEvent, index?: number): void {\n    const nextIndex =\n      index ?? getNextElementIndex(event, this._activeItemIndex, this._filteredOptions.length);\n    const nextOption = this._filteredOptions[nextIndex];\n    const activeOption = this._filteredOptions[this._activeItemIndex];\n\n    this._setActiveElement(nextOption, activeOption);\n\n    if (!this.multiple) {\n      this._setSelectedElement(nextOption, activeOption);\n    } else if (event?.shiftKey) {\n      nextOption.setSelectedViaUserInteraction(!nextOption.selected);\n    }\n    this._activeItemIndex = nextIndex;\n  }\n\n  private _setActiveElement(\n    nextActiveOption: SbbOptionElement,\n    lastActiveOption: SbbOptionElement | null = null,\n    setActiveDescendant = true,\n  ): void {\n    nextActiveOption.setActive(true);\n    nextActiveOption.scrollIntoView({ block: 'nearest' });\n\n    if (setActiveDescendant) {\n      this._triggerElement.setAttribute('aria-activedescendant', nextActiveOption.id);\n    }\n\n    // Reset the previous\n    if (lastActiveOption && lastActiveOption !== nextActiveOption) {\n      lastActiveOption.setActive(false);\n    }\n  }\n\n  private _setSelectedElement(\n    nextActiveOption: SbbOptionElement,\n    lastActiveOption: SbbOptionElement,\n  ): void {\n    nextActiveOption.setSelectedViaUserInteraction(true);\n\n    if (lastActiveOption && lastActiveOption !== nextActiveOption) {\n      lastActiveOption.setSelectedViaUserInteraction(false);\n    }\n  }\n\n  private _resetActiveElement(): void {\n    const activeElement = this._filteredOptions[this._activeItemIndex];\n\n    if (activeElement) {\n      activeElement.setActive(false);\n    }\n    this._activeItemIndex = -1;\n    this._triggerElement.removeAttribute('aria-activedescendant');\n  }\n\n  // Check if the pointerdown event target is triggered on the menu.\n  private _pointerDownListener = (event: PointerEvent): void => {\n    this._isPointerDownEventOnMenu = isEventOnElement(this._overlay, event);\n  };\n\n  // Close menu on backdrop click.\n  private _closeOnBackdropClick = (event: PointerEvent): void => {\n    if (!this._isPointerDownEventOnMenu && !isEventOnElement(this._overlay, event)) {\n      this.close();\n    }\n  };\n\n  private _setValueFromSelected(): void {\n    const selected = this._getSelected();\n\n    if (Array.isArray(selected)) {\n      if (selected && selected.length > 0) {\n        const value: string[] = [];\n        for (const option of selected) {\n          value.push(option.value!);\n        }\n        this.value = value;\n      }\n    } else if (selected) {\n      this._activeItemIndex = this._filteredOptions.findIndex((option) => option === selected);\n      this.value = selected.value;\n    }\n  }\n\n  private _getSelected(): SbbOptionElement | SbbOptionElement[] | null {\n    if (this.multiple) {\n      return this._filteredOptions.filter((option) => option.selected);\n    } else {\n      return this._filteredOptions.find((option) => option.selected) ?? null;\n    }\n  }\n\n  private _toggleOpening(): void {\n    if (this.disabled || this.formDisabled || this.readonly) {\n      return;\n    }\n    this._triggerElement?.focus();\n\n    switch (this.state) {\n      case 'opened': {\n        this.close();\n        break;\n      }\n      case 'closed': {\n        this.open();\n        break;\n      }\n      default:\n        break;\n    }\n  }\n\n  private _spreadDeferredDisplayValue(\n    placeholder: TemplateResult,\n  ): (TemplateResult | Promise<TemplateResult>)[] {\n    return [this._deferredDisplayValue(placeholder), placeholder];\n  }\n\n  private async _deferredDisplayValue(placeholder: TemplateResult): Promise<TemplateResult> {\n    if (this.hydrationRequired) {\n      await this.hydrationComplete;\n    }\n    return this._displayValue ? html`${this._displayValue}` : placeholder;\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <!-- This element is visually hidden and will be appended to the light DOM to allow screen\n      readers to work properly -->\n      <div\n        class=\"sbb-screen-reader-only\"\n        tabindex=${this.disabled || this.formDisabled ? nothing : '0'}\n        role=\"combobox\"\n        aria-haspopup=\"listbox\"\n        aria-expanded=\"false\"\n        aria-required=${this.required.toString()}\n        aria-controls=${this._overlayId}\n        aria-owns=${this._overlayId}\n        @keydown=${this._onKeyDown}\n        @click=${this._toggleOpening}\n        ${ref((ref) => (this._triggerElement = ref as HTMLElement))}\n      >\n        ${until(...this._spreadDeferredDisplayValue(html`<span>${this.placeholder}</span>`))}\n      </div>\n\n      <!-- Visually display the value -->\n      <div class=\"sbb-select__trigger\" aria-hidden=\"true\">\n        ${until(\n          ...this._spreadDeferredDisplayValue(\n            html`<span class=\"sbb-select__trigger--placeholder\">${this.placeholder}</span>`,\n          ),\n        )}\n      </div>\n\n      <div class=\"sbb-select__gap-fix\"></div>\n      <div class=\"sbb-select__container\" popover=\"manual\">\n        <div class=\"sbb-select__gap-fix\">${overlayGapFixCorners()}</div>\n        <div\n          @animationend=${this._onAnimationEnd}\n          class=\"sbb-select__panel\"\n          ${ref((dialogRef) => (this._overlay = dialogRef as HTMLElement))}\n        >\n          <div class=\"sbb-select__wrapper\">\n            <div\n              id=${!ariaRoleOnHost ? this._overlayId : nothing}\n              class=\"sbb-select__options\"\n              role=${!ariaRoleOnHost ? 'listbox' : nothing}\n              ?aria-multiselectable=${this.multiple}\n              ${ref((containerRef) => (this._optionContainer = containerRef as HTMLElement))}\n            >\n              <slot @slotchange=${this._setValueFromSelected}></slot>\n            </div>\n          </div>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-select': SbbSelectElement;\n  }\n}\n"],"names":["SbbSelectElement","_a","state","ref"],"mappings":"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"}
1048
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"select.js","sources":["../../../src/elements/select/select.ts"],"sourcesContent":["import { MutationController } from '@lit-labs/observers/mutation-controller.js';\nimport type { CSSResultGroup, PropertyDeclaration, PropertyValues, TemplateResult } from 'lit';\nimport { html, isServer, nothing } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\nimport { until } from 'lit/directives/until.js';\n\nimport { getNextElementIndex } from '../core/a11y.js';\nimport { SbbOpenCloseBaseElement } from '../core/base-elements.js';\nimport { SbbEscapableOverlayController, SbbLanguageController } from '../core/controllers.js';\nimport {\n  forceType,\n  getOverride,\n  handleDistinctChange,\n  hostAttributes,\n} from '../core/decorators.js';\nimport { isNextjs, isSafari, isZeroAnimationDuration, setOrRemoveAttribute } from '../core/dom.js';\nimport { EventEmitter } from '../core/eventing.js';\nimport { i18nSelectionRequired } from '../core/i18n.js';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbDisabledMixin,\n  SbbFormAssociatedMixin,\n  SbbHydrationMixin,\n  SbbNegativeMixin,\n  SbbRequiredMixin,\n  SbbUpdateSchedulerMixin,\n} from '../core/mixins.js';\nimport { isEventOnElement, overlayGapFixCorners, setOverlayPosition } from '../core/overlay.js';\nimport type { SbbOptGroupElement, SbbOptionElement } from '../option.js';\n\nimport style from './select.scss?lit&inline';\n\n/**\n * On Safari, the aria role 'listbox' must be on the host element, or else VoiceOver won't work at all.\n * On the other hand, JAWS and NVDA need the role to be an \"immediate parent\" to the options, or else optgroups won't work.\n */\nconst ariaRoleOnHost = isSafari;\n\nlet nextId = 0;\n\n/**\n * @deprecated will be removed with next major version\n */\nexport interface SelectChange {\n  type: 'value';\n  value: string | string[];\n}\n\n/**\n * It displays a panel with selectable options.\n *\n * @slot - Use the unnamed slot to add options.\n * @event {CustomEvent<void>} change - Notifies that the component's value has changed.\n * @event {CustomEvent<void>} input - Notifies that an option value has been selected.\n * @event {CustomEvent<void>} willOpen - Emits whenever the `sbb-select` starts the opening transition. Can be canceled.\n * @event {CustomEvent<void>} didOpen - Emits whenever the `sbb-select` is opened.\n * @event {CustomEvent<void>} willClose - Emits whenever the `sbb-select` begins the closing transition. Can be canceled.\n * @event {CustomEvent<void>} didClose - Emits whenever the `sbb-select` is closed.\n * @cssprop [--sbb-select-z-index=var(--sbb-overlay-default-z-index)] - To specify a custom stack order,\n * the `z-index` can be overridden by defining this CSS variable. The default `z-index` of the\n * component is set to `var(--sbb-overlay-default-z-index)` with a value of `1000`.\n * @overrideType value - string | string[] | null\n */\nexport\n@customElement('sbb-select')\n@hostAttributes({\n  role: ariaRoleOnHost ? 'listbox' : null,\n})\nclass SbbSelectElement extends SbbUpdateSchedulerMixin(\n  SbbDisabledMixin(\n    SbbNegativeMixin(\n      SbbHydrationMixin(\n        SbbRequiredMixin(\n          SbbFormAssociatedMixin<typeof SbbOpenCloseBaseElement, string | string[]>(\n            SbbOpenCloseBaseElement,\n          ),\n        ),\n      ),\n    ),\n  ),\n) {\n  public static override styles: CSSResultGroup = style;\n\n  // TODO: fix using ...super.events requires: https://github.com/sbb-design-systems/lyne-components/issues/2600\n  public static override readonly events = {\n    change: 'change',\n    input: 'input',\n    displayValueChange: 'displayValueChange',\n    willOpen: 'willOpen',\n    didOpen: 'didOpen',\n    willClose: 'willClose',\n    didClose: 'didClose',\n  } as const;\n\n  /** The placeholder used if no value has been selected. */\n  @forceType()\n  @property()\n  public accessor placeholder: string = '';\n\n  /** Whether the select allows for multiple selection. */\n  @forceType()\n  @handleDistinctChange((e: SbbSelectElement, newValue: boolean) => e._onMultipleChanged(newValue))\n  @property({ reflect: true, type: Boolean })\n  public accessor multiple: boolean = false;\n\n  @forceType()\n  @handleDistinctChange((e: SbbSelectElement, newValue: boolean) =>\n    e._closeOnDisabledReadonlyChanged(newValue),\n  )\n  @property({ reflect: true, type: Boolean })\n  @getOverride((e: SbbSelectElement, v: boolean): boolean => v || e.isDisabledExternally())\n  public override accessor disabled: boolean = false;\n\n  /** Whether the select is readonly. */\n  @forceType()\n  @handleDistinctChange((e: SbbSelectElement, newValue: boolean) =>\n    e._closeOnDisabledReadonlyChanged(newValue),\n  )\n  @property({ type: Boolean })\n  public accessor readonly: boolean = false;\n\n  /**\n   * Form type of element.\n   * @default 'select-one / select-multiple'\n   */\n  public override get type(): string {\n    return this.multiple ? 'select-multiple' : 'select-one';\n  }\n\n  /** The value displayed by the component. */\n  @state() private accessor _displayValue: string | null = null;\n\n  /** Notifies that the component's value has changed. */\n  private _change: EventEmitter = new EventEmitter(this, SbbSelectElement.events.change);\n\n  /** Notifies that an option value has been selected. */\n  private _input: EventEmitter = new EventEmitter(this, SbbSelectElement.events.input);\n\n  /** @internal */\n  private _displayValueChanged: EventEmitter<void> = new EventEmitter(\n    this,\n    SbbSelectElement.events.displayValueChange,\n    {\n      composed: false,\n    },\n  );\n\n  private _overlay!: HTMLElement;\n  private _optionContainer!: HTMLElement;\n  private _originElement!: HTMLElement;\n  private _triggerElement!: HTMLElement;\n  private _openPanelEventsController!: AbortController;\n  private _sbbEscapableOverlayController = new SbbEscapableOverlayController(this);\n  private _overlayId = `sbb-select-${++nextId}`;\n  private _activeItemIndex = -1;\n  private _searchTimeout?: ReturnType<typeof setTimeout>;\n  private _searchString = '';\n  private _didLoad = false;\n  private _isPointerDownEventOnMenu: boolean = false;\n  private _languageController = new SbbLanguageController(this);\n\n  /**\n   * The 'combobox' input element\n   * @internal\n   */\n  public get inputElement(): HTMLElement {\n    return this._triggerElement;\n  }\n\n  /** Gets all the SbbOptionElement projected in the select. */\n  private get _options(): SbbOptionElement[] {\n    return Array.from(this.querySelectorAll?.('sbb-option') ?? []);\n  }\n\n  private get _filteredOptions(): SbbOptionElement[] {\n    return this._options.filter(\n      (opt: SbbOptionElement) => !opt.disabled && !opt.hasAttribute('data-group-disabled'),\n    );\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('optionSelectionChange', (e: CustomEvent<void>) =>\n      this._onOptionChanged(e),\n    );\n    this.addEventListener?.('optionLabelChanged', (e: Event) => this._onOptionLabelChanged(e));\n    this.addEventListener?.('click', (e: MouseEvent) => {\n      const target = e.target as SbbSelectElement | SbbOptionElement;\n      if (target.localName === 'sbb-option') {\n        // Option click\n        if (!this.multiple && !target.disabled) {\n          this.close();\n          this.focus();\n        }\n      } else {\n        this._toggleOpening();\n      }\n    });\n\n    new MutationController(this, {\n      config: { attributeFilter: ['aria-labelledby', 'aria-label', 'aria-describedby'] },\n      callback: () => this._syncAriaLabels(),\n    });\n  }\n\n  private _syncAriaLabels(): void {\n    if (!this._triggerElement || isServer) {\n      return;\n    }\n\n    setOrRemoveAttribute(\n      this._triggerElement,\n      'aria-labelledby',\n      this.getAttribute('aria-labelledby'),\n    );\n    setOrRemoveAttribute(this._triggerElement, 'aria-label', this.getAttribute('aria-label'));\n    setOrRemoveAttribute(\n      this._triggerElement,\n      'aria-describedby',\n      this.getAttribute('aria-describedby'),\n    );\n\n    // Using the associated labels is only a fallback.\n    // The drawback is, that it doesn't get updated automatically when the list of label changes.\n    if (\n      !this.getAttribute('aria-label') &&\n      !this.getAttribute('aria-labelledby') &&\n      this.internals.labels.length\n    ) {\n      this._triggerElement?.setAttribute(\n        'aria-label',\n        Array.from(this.internals.labels)\n          .map((label) => label.textContent)\n          .join(', '),\n      );\n    }\n  }\n\n  /** Opens the selection panel. */\n  public open(): void {\n    if (\n      this.state !== 'closed' ||\n      !this._overlay ||\n      this._options.length === 0 ||\n      this.disabled ||\n      this.formDisabled\n    ) {\n      return;\n    }\n\n    if (!this.willOpen.emit()) {\n      return;\n    }\n\n    this.shadowRoot?.querySelector<HTMLDivElement>('.sbb-select__container')?.showPopover?.();\n    this.state = 'opening';\n    this.toggleAttribute('data-expanded', true);\n    this._setOverlayPosition();\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `opened` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleOpening();\n    }\n  }\n\n  /** Closes the selection panel. */\n  public close(): void {\n    if (this.state !== 'opened') {\n      return;\n    }\n    if (!this.willClose.emit()) {\n      return;\n    }\n\n    this.state = 'closing';\n    this.toggleAttribute('data-expanded', false);\n    this._openPanelEventsController.abort();\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `closed` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleClosing();\n    }\n  }\n\n  private _isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-options-panel-animation-duration');\n  }\n\n  /** Gets the current displayed value. */\n  public getDisplayValue(): string {\n    return this._displayValue ?? '';\n  }\n\n  /** Listens to option changes. */\n  private _onOptionChanged(event: Event): void {\n    const target = event.target as SbbOptionElement;\n    if (target.selected) {\n      this._onOptionSelected(target);\n    } else {\n      this._onOptionDeselected(target);\n    }\n  }\n\n  /** Listens to option changes. */\n  private _onOptionLabelChanged(event: Event): void {\n    const target = event.target as SbbOptionElement;\n    const selected = this._getSelected();\n\n    if (\n      (!Array.isArray(selected) && target !== selected) ||\n      (Array.isArray(selected) && !selected.includes(target))\n    ) {\n      return;\n    }\n\n    this._updateDisplayValue(selected);\n  }\n\n  private _updateDisplayValue(selected: SbbOptionElement | SbbOptionElement[] | null): void {\n    if (Array.isArray(selected)) {\n      this._displayValue = selected.map((o) => o.textContent).join(', ') || null;\n    } else if (selected) {\n      this._displayValue = selected?.textContent || null;\n    } else {\n      this._displayValue = null;\n    }\n    this._displayValueChanged.emit();\n  }\n\n  /**\n   * The `value` property should be adapted when the `multiple` property changes:\n   *   - if it changes to true, the 'value' is set to an array;\n   *   - if it changes to false, the first available option is set as 'value' otherwise it's set to null.\n   */\n  private _onMultipleChanged(newValue: boolean): void {\n    if (newValue) {\n      this.value = this.value !== null ? [this.value as string] : [];\n    } else {\n      this.value = (this.value as string[]).length ? (this.value as string[])[0] : null;\n    }\n  }\n\n  /**\n   * If the `disabled` or the `readonly` properties are set, and the panel is open, close it.\n   */\n  private _closeOnDisabledReadonlyChanged(newValue: boolean): void {\n    if (this.isOpen && newValue) {\n      this.close();\n    }\n  }\n\n  /** Sets the _displayValue by checking the internal sbb-options and setting the correct `selected` value on them. */\n  private _onValueChanged(newValue: string | string[]): void {\n    const options = this._filteredOptions;\n    if (!Array.isArray(newValue)) {\n      const optionElement =\n        options.find((o) => (o.value ?? o.getAttribute('value')) === newValue) ?? null;\n      if (optionElement) {\n        optionElement.selected = true;\n      }\n      options\n        .filter((o) => (o.value ?? o.getAttribute('value')) !== newValue)\n        .forEach((o) => (o.selected = false));\n      this._updateDisplayValue(optionElement);\n    } else {\n      options\n        .filter((o) => !newValue.includes(o.value ?? o.getAttribute('value')))\n        .forEach((e) => (e.selected = false));\n      const selectedElements = options.filter((o) =>\n        newValue.includes(o.value ?? o.getAttribute('value')),\n      );\n      selectedElements.forEach((o) => (o.selected = true));\n      this._updateDisplayValue(selectedElements);\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    // Override the default focus behavior\n    this.focus = () => this._triggerElement.focus();\n    this.blur = () => this._triggerElement.blur();\n\n    // Wait for ssr hydration\n    if (!isNextjs()) {\n      this.startUpdate();\n      this._setupSelect();\n    }\n  }\n\n  /**\n   * Removes element's first attribute whose qualified name is qualifiedName.\n   *\n   * [MDN Reference](https://developer.mozilla.org/docs/Web/API/Element/removeAttribute)\n   * @internal We need to override this due to a hydration issue with Next.js.\n   */\n  public override removeAttribute(qualifiedName: string): void {\n    // In Next.js the hydration needs to finish before we can manipulate the light DOM.\n    // @lit/react calls removeAttribute('defer-hydration') in a useLayoutEffect,\n    // which is done after hydration is finished. Due to this we intercept this call\n    // in overriding removeAttribute to finish initialization of the sbb-select.\n    // https://github.com/lit/lit/blob/main/packages/react/src/create-component.ts#L293-L296\n    // We also need to wait for update complete in order to be sure that the shadow DOM has been rendered.\n    if (isNextjs() && qualifiedName === 'defer-hydration' && !this._didLoad) {\n      this.updateComplete.then(() => this._setupSelect());\n    }\n    super.removeAttribute(qualifiedName);\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n\n    if (ariaRoleOnHost) {\n      this.id ||= this._overlayId;\n    }\n\n    const formField = this.closest?.('sbb-form-field') ?? this.closest?.('[data-form-field]');\n\n    if (formField) {\n      this.negative = formField.hasAttribute('negative');\n    }\n    this._syncProperties();\n    this._syncAriaLabels();\n\n    if (this._didLoad) {\n      this._setupOrigin();\n      this._setupTrigger();\n    }\n    if (this.value) {\n      this._onValueChanged(this.value);\n    }\n  }\n\n  public override requestUpdate(\n    name?: PropertyKey,\n    oldValue?: unknown,\n    options?: PropertyDeclaration,\n  ): void {\n    super.requestUpdate(name, oldValue, options);\n    if (!name && this.hasUpdated) {\n      setTimeout(() => this._syncAriaLabels());\n    }\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    // On initialization, the '_onValueChanged' is called by the connectedCallback\n    if (changedProperties.has('value') && this._didLoad) {\n      this._onValueChanged(this.value!);\n    }\n    if (changedProperties.has('negative') || changedProperties.has('multiple')) {\n      this._syncProperties();\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this.prepend(this._triggerElement); // Take back the trigger element previously moved to the light DOM\n    this._openPanelEventsController?.abort();\n  }\n\n  protected override updateFormValue(): void {\n    if (this.multiple && this.value instanceof Array) {\n      const data = new FormData();\n      (this.value as string[]).forEach((el) => data.append(this.name, el));\n      this.internals.setFormValue(data);\n    } else {\n      this.internals.setFormValue(this.value as string | null);\n    }\n  }\n\n  /**\n   * The reset value is the attribute value (the setup value), null otherwise.\n   * @internal\n   */\n  public formResetCallback(): void {\n    this.value = this.hasAttribute('value') ? this.getAttribute('value') : null;\n  }\n\n  /**\n   * @internal\n   */\n  public formStateRestoreCallback(\n    state: FormRestoreState | null,\n    _reason: FormRestoreReason,\n  ): void {\n    if (!state) {\n      this.value = null;\n      return;\n    }\n\n    if (this.multiple) {\n      // if multiple, the state format is ['field-name', 'value'][]\n      this.value = (state as [string, string][]).map((entries) => entries[1]);\n    } else {\n      this.value = state as string;\n    }\n  }\n\n  private _syncProperties(): void {\n    this.querySelectorAll?.('sbb-divider').forEach((element) => (element.negative = this.negative));\n\n    this.querySelectorAll?.<SbbOptionElement | SbbOptGroupElement>(\n      'sbb-option, sbb-optgroup',\n    ).forEach((element: SbbOptionElement | SbbOptGroupElement) => {\n      element.toggleAttribute('data-negative', this.negative);\n      element.toggleAttribute('data-multiple', this.multiple);\n    });\n\n    this.querySelectorAll?.<SbbOptionElement | SbbOptGroupElement>(\n      'sbb-option, sbb-optgroup',\n    ).forEach((e) => e.requestUpdate?.());\n  }\n\n  protected override shouldValidate(name: PropertyKey | undefined): boolean {\n    return super.shouldValidate(name) || name === 'value' || name === 'required';\n  }\n\n  protected override validate(): void {\n    super.validate();\n    if (this.required && this._options.every((o) => o.value !== this.value)) {\n      this.setValidityFlag('valueMissing', i18nSelectionRequired[this._languageController.current]);\n    } else {\n      this.removeValidityFlag('valueMissing');\n    }\n  }\n\n  private _setupSelect(): void {\n    this._setupOrigin();\n    this._setupTrigger();\n    this._didLoad = true;\n    this.completeUpdate();\n  }\n\n  /** Sets the originElement; if the component is used in a sbb-form-field uses it, otherwise uses the parentElement. */\n  private _setupOrigin(): void {\n    const formField = this.closest?.('sbb-form-field');\n    this._originElement =\n      formField?.shadowRoot?.querySelector?.('#overlay-anchor') ?? this.parentElement!;\n    if (this._originElement) {\n      this.toggleAttribute(\n        'data-option-panel-origin-borderless',\n        !!formField?.hasAttribute?.('borderless'),\n      );\n    }\n  }\n\n  /**\n   * To assess screen-readers problems caused by the interaction between aria patterns and shadow DOM,\n   * we are forced to move the 'combobox' trigger element to the light DOM\n   */\n  private _setupTrigger(): void {\n    // Move the trigger before the sbb-select\n    this.parentElement!.insertBefore?.(this._triggerElement, this);\n\n    // Set the invisible trigger element dimension to match the parent (needed for screen readers)\n    const containerElement = this.closest?.('sbb-form-field') ?? this;\n    this._triggerElement.style.top = '0px';\n    this._triggerElement.style.height = `${containerElement.offsetHeight}px`;\n    this._triggerElement.style.width = `${containerElement.offsetWidth}px`;\n  }\n\n  private _setOverlayPosition(): void {\n    setOverlayPosition(\n      this._overlay,\n      this._originElement,\n      this._optionContainer,\n      this.shadowRoot!.querySelector('.sbb-select__container')!,\n      this,\n    );\n  }\n\n  // In rare cases it can be that the animationEnd event is triggered twice.\n  // To avoid entering a corrupt state, exit when state is not expected.\n  private _onAnimationEnd(event: AnimationEvent): void {\n    if (event.animationName === 'open' && this.state === 'opening') {\n      this._handleOpening();\n    } else if (event.animationName === 'close' && this.state === 'closing') {\n      this._handleClosing();\n    }\n  }\n\n  private _handleOpening(): void {\n    this.state = 'opened';\n    this._attachOpenPanelEvents();\n    this._triggerElement.setAttribute('aria-expanded', 'true');\n    this._sbbEscapableOverlayController.connect();\n    this.didOpen.emit();\n  }\n\n  private _handleClosing(): void {\n    this.state = 'closed';\n    this.shadowRoot?.querySelector<HTMLDivElement>('.sbb-select__container')?.hidePopover?.();\n    this._triggerElement.setAttribute('aria-expanded', 'false');\n    this._resetActiveElement();\n    this._optionContainer.scrollTop = 0;\n    this._sbbEscapableOverlayController.disconnect();\n    this.didClose.emit();\n  }\n\n  /** When an option is selected, updates the displayValue; it also closes the select if not `multiple`. */\n  private _onOptionSelected(optionSelectionChange: SbbOptionElement): void {\n    if (!this.multiple) {\n      this._filteredOptions\n        .filter((option) => option.id !== optionSelectionChange.id)\n        .forEach((option) => (option.selected = false));\n      this.value = optionSelectionChange.value;\n    } else {\n      if (!this.value) {\n        this.value = [optionSelectionChange.value!];\n      } else if (!this.value.includes(optionSelectionChange.value!)) {\n        this.value = [...this.value, optionSelectionChange.value!];\n      }\n    }\n\n    this._input.emit();\n    this._change.emit();\n  }\n\n  /** When an option is unselected in `multiple`, removes it from value and updates displayValue. */\n  private _onOptionDeselected(optionSelectionChange: SbbOptionElement): void {\n    if (this.multiple) {\n      this.value = (this.value as string[]).filter(\n        (el: string) => el !== optionSelectionChange.value,\n      );\n\n      this._input.emit();\n      this._change.emit();\n    }\n  }\n\n  private _attachOpenPanelEvents(): void {\n    this._openPanelEventsController = new AbortController();\n\n    // Recalculate the overlay position on scroll and window resize\n    document.addEventListener('scroll', () => this._setOverlayPosition(), {\n      passive: true,\n      signal: this._openPanelEventsController.signal,\n      // Without capture, other scroll contexts would not bubble to this event listener.\n      // Capture allows us to react to all scroll contexts in this DOM.\n      capture: true,\n    });\n    window.addEventListener('resize', () => this._setOverlayPosition(), {\n      passive: true,\n      signal: this._openPanelEventsController.signal,\n    });\n\n    // Close menu on backdrop click\n    window.addEventListener('pointerdown', (ev) => this._pointerDownListener(ev), {\n      signal: this._openPanelEventsController.signal,\n    });\n    window.addEventListener('pointerup', (ev) => this._closeOnBackdropClick(ev), {\n      signal: this._openPanelEventsController.signal,\n    });\n  }\n\n  private _onKeyDown(event: KeyboardEvent): void {\n    if (this.readonly) {\n      return;\n    }\n\n    if (this.state === 'opened') {\n      this._openedPanelKeyboardInteraction(event);\n    } else if (this.state === 'closed') {\n      this._closedPanelKeyboardInteraction(event);\n    }\n  }\n\n  private _closedPanelKeyboardInteraction(event: KeyboardEvent): void {\n    if (this._checkForLetterSelection(event)) {\n      return this._setNextActiveOptionByText(event);\n    }\n\n    switch (event.key) {\n      case 'Enter':\n      case ' ':\n      case 'ArrowDown':\n      case 'ArrowUp':\n        event.preventDefault();\n        this.open();\n        break;\n    }\n  }\n\n  private _openedPanelKeyboardInteraction(event: KeyboardEvent): void {\n    if (this.readonly || this.state !== 'opened') {\n      return;\n    }\n\n    if (this._checkForLetterSelection(event)) {\n      return this._setNextActiveOptionByText(event);\n    }\n\n    switch (event.key) {\n      case 'Tab':\n        this.close();\n        break;\n\n      case 'Enter':\n      case ' ':\n        event.preventDefault();\n        this._selectByKeyboard();\n        break;\n\n      case 'ArrowDown':\n      case 'ArrowUp':\n        event.preventDefault();\n        this._setNextActiveOption(event);\n        break;\n\n      case 'Home':\n      case 'PageUp':\n        event.preventDefault();\n        this._setNextActiveOption(event, 0);\n        break;\n\n      case 'End':\n      case 'PageDown':\n        event.preventDefault();\n        this._setNextActiveOption(event, this._filteredOptions.length - 1);\n        break;\n    }\n  }\n\n  private _checkForLetterSelection(event: KeyboardEvent): boolean {\n    return (\n      event.key === 'Backspace' ||\n      event.key === 'Clear' ||\n      (event.key.length === 1 &&\n        event.key !== ' ' &&\n        !event.altKey &&\n        !event.ctrlKey &&\n        !event.metaKey)\n    );\n  }\n\n  private _setNextActiveOptionByText(event: KeyboardEvent): void {\n    // Set timeout and the string to search.\n    if (typeof this._searchTimeout === typeof setTimeout) {\n      clearTimeout(this._searchTimeout);\n    }\n    this._searchTimeout = setTimeout(() => (this._searchString = ''), 1000);\n    this._searchString += event.key;\n\n    // Reorder the _filteredOption array to have the last selected element at the bottom.\n    const indexForSlice: number = this._activeItemIndex + 1;\n    const filteredOptionsSorted: SbbOptionElement[] = [\n      ...this._filteredOptions.slice(indexForSlice),\n      ...this._filteredOptions.slice(0, indexForSlice),\n    ];\n\n    const match = filteredOptionsSorted.find(\n      (option: SbbOptionElement) =>\n        option.textContent?.toLowerCase().indexOf(this._searchString.toLowerCase()) === 0,\n    );\n    if (match) {\n      // If an exact match has been found, go to that option.\n      this._setNextActiveOption(event, this._filteredOptions.indexOf(match));\n    } else if (\n      this._searchString.length > 1 &&\n      new RegExp(`^${this._searchString.charAt(0)}*$`).test(this._searchString)\n    ) {\n      // If no exact match has been found but the string to search is made by the same repeated letter,\n      // go to the first element, if exists, that matches the letter.\n      const firstMatch = filteredOptionsSorted.find(\n        (option: SbbOptionElement) =>\n          option.textContent?.toLowerCase().indexOf(this._searchString[0].toLowerCase()) === 0,\n      );\n      if (firstMatch) {\n        this._setNextActiveOption(event, this._filteredOptions.indexOf(firstMatch));\n      }\n    } else {\n      // No match found, clear the timeout and the search term.\n      clearTimeout(this._searchTimeout);\n      this._searchString = '';\n    }\n  }\n\n  private _selectByKeyboard(): void {\n    const activeOption: SbbOptionElement = this._filteredOptions[this._activeItemIndex];\n\n    if (this.multiple) {\n      activeOption.setSelectedViaUserInteraction(!activeOption.selected);\n    } else {\n      this.close();\n    }\n  }\n\n  private _setNextActiveOption(event: KeyboardEvent, index?: number): void {\n    const nextIndex =\n      index ?? getNextElementIndex(event, this._activeItemIndex, this._filteredOptions.length);\n    const nextOption = this._filteredOptions[nextIndex];\n    const activeOption = this._filteredOptions[this._activeItemIndex];\n\n    this._setActiveElement(nextOption, activeOption);\n\n    if (!this.multiple) {\n      this._setSelectedElement(nextOption, activeOption);\n    } else if (event?.shiftKey) {\n      nextOption.setSelectedViaUserInteraction(!nextOption.selected);\n    }\n    this._activeItemIndex = nextIndex;\n  }\n\n  private _setActiveElement(\n    nextActiveOption: SbbOptionElement,\n    lastActiveOption: SbbOptionElement | null = null,\n    setActiveDescendant = true,\n  ): void {\n    nextActiveOption.setActive(true);\n    nextActiveOption.scrollIntoView({ block: 'nearest' });\n\n    if (setActiveDescendant) {\n      this._triggerElement.setAttribute('aria-activedescendant', nextActiveOption.id);\n    }\n\n    // Reset the previous\n    if (lastActiveOption && lastActiveOption !== nextActiveOption) {\n      lastActiveOption.setActive(false);\n    }\n  }\n\n  private _setSelectedElement(\n    nextActiveOption: SbbOptionElement,\n    lastActiveOption: SbbOptionElement,\n  ): void {\n    nextActiveOption.setSelectedViaUserInteraction(true);\n\n    if (lastActiveOption && lastActiveOption !== nextActiveOption) {\n      lastActiveOption.setSelectedViaUserInteraction(false);\n    }\n  }\n\n  private _resetActiveElement(): void {\n    const activeElement = this._filteredOptions[this._activeItemIndex];\n\n    if (activeElement) {\n      activeElement.setActive(false);\n    }\n    this._activeItemIndex = -1;\n    this._triggerElement.removeAttribute('aria-activedescendant');\n  }\n\n  // Check if the pointerdown event target is triggered on the menu.\n  private _pointerDownListener = (event: PointerEvent): void => {\n    this._isPointerDownEventOnMenu = isEventOnElement(this._overlay, event);\n  };\n\n  // Close menu on backdrop click.\n  private _closeOnBackdropClick = (event: PointerEvent): void => {\n    if (!this._isPointerDownEventOnMenu && !isEventOnElement(this._overlay, event)) {\n      this.close();\n    }\n  };\n\n  private _setValueFromSelected(): void {\n    const selected = this._getSelected();\n\n    if (Array.isArray(selected)) {\n      if (selected && selected.length > 0) {\n        const value: string[] = [];\n        for (const option of selected) {\n          value.push(option.value!);\n        }\n        this.value = value;\n      }\n    } else if (selected) {\n      this._activeItemIndex = this._filteredOptions.findIndex((option) => option === selected);\n      this.value = selected.value;\n    } else if (this.value) {\n      // If we arrive here without any options being selected,\n      // we should try to check the current value against the available options\n      // (and select it if any match is found).\n      this._onValueChanged(this.value);\n    }\n  }\n\n  private _getSelected(): SbbOptionElement | SbbOptionElement[] | null {\n    if (this.multiple) {\n      return this._filteredOptions.filter((option) => option.selected);\n    } else {\n      return this._filteredOptions.find((option) => option.selected) ?? null;\n    }\n  }\n\n  private _toggleOpening(): void {\n    if (this.disabled || this.formDisabled || this.readonly) {\n      return;\n    }\n    this._triggerElement?.focus();\n\n    switch (this.state) {\n      case 'opened': {\n        this.close();\n        break;\n      }\n      case 'closed': {\n        this.open();\n        break;\n      }\n      default:\n        break;\n    }\n  }\n\n  private _spreadDeferredDisplayValue(\n    placeholder: TemplateResult,\n  ): (TemplateResult | Promise<TemplateResult>)[] {\n    return [this._deferredDisplayValue(placeholder), placeholder];\n  }\n\n  private async _deferredDisplayValue(placeholder: TemplateResult): Promise<TemplateResult> {\n    if (this.hydrationRequired) {\n      await this.hydrationComplete;\n    }\n    return this._displayValue ? html`${this._displayValue}` : placeholder;\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <!-- This element is visually hidden and will be appended to the light DOM to allow screen\n      readers to work properly -->\n      <div\n        class=\"sbb-screen-reader-only\"\n        tabindex=${this.disabled || this.formDisabled ? nothing : '0'}\n        role=\"combobox\"\n        aria-haspopup=\"listbox\"\n        aria-expanded=\"false\"\n        aria-required=${this.required.toString()}\n        aria-controls=${this._overlayId}\n        aria-owns=${this._overlayId}\n        @keydown=${this._onKeyDown}\n        @click=${this._toggleOpening}\n        ${ref((ref) => (this._triggerElement = ref as HTMLElement))}\n      >\n        ${until(...this._spreadDeferredDisplayValue(html`<span>${this.placeholder}</span>`))}\n      </div>\n\n      <!-- Visually display the value -->\n      <div class=\"sbb-select__trigger\" aria-hidden=\"true\">\n        ${until(\n          ...this._spreadDeferredDisplayValue(\n            html`<span class=\"sbb-select__trigger--placeholder\">${this.placeholder}</span>`,\n          ),\n        )}\n      </div>\n\n      <div class=\"sbb-select__gap-fix\"></div>\n      <div class=\"sbb-select__container\" popover=\"manual\">\n        <div class=\"sbb-select__gap-fix\">${overlayGapFixCorners()}</div>\n        <div\n          @animationend=${this._onAnimationEnd}\n          class=\"sbb-select__panel\"\n          ${ref((dialogRef) => (this._overlay = dialogRef as HTMLElement))}\n        >\n          <div class=\"sbb-select__wrapper\">\n            <div\n              id=${!ariaRoleOnHost ? this._overlayId : nothing}\n              class=\"sbb-select__options\"\n              role=${!ariaRoleOnHost ? 'listbox' : nothing}\n              ?aria-multiselectable=${this.multiple}\n              ${ref((containerRef) => (this._optionContainer = containerRef as HTMLElement))}\n            >\n              <slot @slotchange=${this._setValueFromSelected}></slot>\n            </div>\n          </div>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-select': SbbSelectElement;\n  }\n}\n"],"names":["SbbSelectElement","_a","state","ref"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- import { CSSResultGroup, LitElement, PropertyValues, TemplateResult } from 'lit';
1
+ import { CSSResultGroup, LitElement, TemplateResult } from 'lit';
2
2
  import { SbbStepLabelElement } from '../step-label.js';
3
3
  export type SbbStepValidateEventDetails = {
4
4
  currentIndex: number | null;
@@ -19,7 +19,6 @@ export declare class SbbStepElement extends LitElement {
19
19
  };
20
20
  /** Emits whenever step switch is triggered. */
21
21
  private _validate;
22
- private _loaded;
23
22
  private _stepper;
24
23
  private _label;
25
24
  /** The label of the step. */
@@ -51,7 +50,6 @@ export declare class SbbStepElement extends LitElement {
51
50
  private _isGoPreviousElement;
52
51
  private _getStepLabel;
53
52
  connectedCallback(): void;
54
- protected firstUpdated(changedProperties: PropertyValues<this>): void;
55
53
  protected render(): TemplateResult;
56
54
  }
57
55
  declare global {
@@ -1 +1 @@
1
- {"version":3,"file":"step.d.ts","sourceRoot":"","sources":["../../../../../src/elements/stepper/step/step.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAEnB,UAAU,EACV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAKb,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAO5D,MAAM,MAAM,2BAA2B,GAAG;IACxC,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,WAAW,EAAE,cAAc,GAAG,IAAI,CAAC;IACnC,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,QAAQ,EAAE,cAAc,GAAG,IAAI,CAAC;CACjC,CAAC;AAEF;;;;;GAKG;AACH,qBAMM,cAAe,SAAQ,UAAU;IACrC,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;MAElB;IAEX,+CAA+C;IAC/C,OAAO,CAAC,SAAS,CAGf;IAEF,OAAO,CAAC,OAAO,CAAkB;IACjC,OAAO,CAAC,QAAQ,CAAkC;IAClD,OAAO,CAAC,MAAM,CAAoC;IAElD,6BAA6B;IAC7B,IAAW,KAAK,IAAI,mBAAmB,GAAG,IAAI,CAE7C;;IAOD;;;OAGG;IACI,MAAM,IAAI,IAAI;IAQrB;;;OAGG;IACI,QAAQ,IAAI,IAAI;IAQvB;;;OAGG;IACI,QAAQ,CAAC,SAAS,EAAE,2BAA2B,GAAG,OAAO;IAIhE;;;OAGG;IACI,SAAS,CAAC,aAAa,EAAE,OAAO,GAAG,IAAI;IAS9C,iGAAiG;IACjG,OAAO,CAAC,YAAY;IAWpB,OAAO,CAAC,gBAAgB;IAIxB,OAAO,CAAC,oBAAoB;IAI5B,OAAO,CAAC,aAAa;IAQL,iBAAiB,IAAI,IAAI;cAOtB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAK3D,MAAM,IAAI,cAAc;CAS5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,UAAU,EAAE,cAAc,CAAC;KAC5B;CACF"}
1
+ {"version":3,"file":"step.d.ts","sourceRoot":"","sources":["../../../../../src/elements/stepper/step/step.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAQ,UAAU,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAKjF,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAO5D,MAAM,MAAM,2BAA2B,GAAG;IACxC,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,WAAW,EAAE,cAAc,GAAG,IAAI,CAAC;IACnC,SAAS,EAAE,MAAM,GAAG,IAAI,CAAC;IACzB,QAAQ,EAAE,cAAc,GAAG,IAAI,CAAC;CACjC,CAAC;AAEF;;;;;GAKG;AACH,qBAMM,cAAe,SAAQ,UAAU;IACrC,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;MAElB;IAEX,+CAA+C;IAC/C,OAAO,CAAC,SAAS,CAGf;IAEF,OAAO,CAAC,QAAQ,CAAkC;IAClD,OAAO,CAAC,MAAM,CAAoC;IAElD,6BAA6B;IAC7B,IAAW,KAAK,IAAI,mBAAmB,GAAG,IAAI,CAE7C;;IAOD;;;OAGG;IACI,MAAM,IAAI,IAAI;IAQrB;;;OAGG;IACI,QAAQ,IAAI,IAAI;IAQvB;;;OAGG;IACI,QAAQ,CAAC,SAAS,EAAE,2BAA2B,GAAG,OAAO;IAIhE;;;OAGG;IACI,SAAS,CAAC,aAAa,EAAE,OAAO,GAAG,IAAI;IAS9C,iGAAiG;IACjG,OAAO,CAAC,YAAY;IAWpB,OAAO,CAAC,gBAAgB;IAIxB,OAAO,CAAC,oBAAoB;IAI5B,OAAO,CAAC,aAAa;IAQL,iBAAiB,IAAI,IAAI;cAOtB,MAAM,IAAI,cAAc;CAS5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,UAAU,EAAE,cAAc,CAAC;KAC5B;CACF"}
@@ -99,7 +99,6 @@ let SbbStepElement = (() => {
99
99
  var _a2;
100
100
  super();
101
101
  this._validate = new EventEmitter(this, SbbStepElement2.events.validate);
102
- this._loaded = false;
103
102
  this._stepper = null;
104
103
  this._label = null;
105
104
  (_a2 = this.addEventListener) == null ? void 0 : _a2.call(this, "click", (e) => this._handleClick(e));
@@ -109,7 +108,7 @@ let SbbStepElement = (() => {
109
108
  * @internal
110
109
  */
111
110
  select() {
112
- if (!this._loaded || !this.label) {
111
+ if (!this.hasUpdated || !this.label) {
113
112
  return;
114
113
  }
115
114
  this.toggleAttribute("data-selected", true);
@@ -174,10 +173,6 @@ let SbbStepElement = (() => {
174
173
  this._stepper = this.closest("sbb-stepper");
175
174
  this._label = this._getStepLabel();
176
175
  }
177
- firstUpdated(changedProperties) {
178
- super.firstUpdated(changedProperties);
179
- this._loaded = true;
180
- }
181
176
  render() {
182
177
  return html`
183
178
  <div class="sbb-step--wrapper">
@@ -200,4 +195,4 @@ let SbbStepElement = (() => {
200
195
  export {
201
196
  SbbStepElement
202
197
  };
203
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"step.js","sources":["../../../../src/elements/stepper/step/step.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  LitElement,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\nimport { hostAttributes } from '../../core/decorators.js';\nimport { EventEmitter } from '../../core/eventing.js';\nimport type { SbbStepLabelElement } from '../step-label.js';\nimport type { SbbStepperElement } from '../stepper.js';\n\nimport style from './step.scss?lit&inline';\n\nlet nextId = 0;\n\nexport type SbbStepValidateEventDetails = {\n  currentIndex: number | null;\n  currentStep: SbbStepElement | null;\n  nextIndex: number | null;\n  nextStep: SbbStepElement | null;\n};\n\n/**\n * Combined with a `sbb-stepper`, it displays a step's content.\n *\n * @slot - Use the unnamed slot to provide content.\n * @event {CustomEvent<SbbStepValidateEventDetails>} validate - Emits whenever step switch is triggered. Can be canceled.\n */\nexport\n@customElement('sbb-step')\n@hostAttributes({\n  slot: 'step',\n  role: 'tabpanel',\n})\nclass SbbStepElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    validate: 'validate',\n  } as const;\n\n  /** Emits whenever step switch is triggered. */\n  private _validate: EventEmitter<SbbStepValidateEventDetails> = new EventEmitter(\n    this,\n    SbbStepElement.events.validate,\n  );\n\n  private _loaded: boolean = false;\n  private _stepper: SbbStepperElement | null = null;\n  private _label: SbbStepLabelElement | null = null;\n\n  /** The label of the step. */\n  public get label(): SbbStepLabelElement | null {\n    return this._label;\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('click', (e) => this._handleClick(e));\n  }\n\n  /**\n   * Selects and configures the step.\n   * @internal\n   */\n  public select(): void {\n    if (!this._loaded || !this.label) {\n      return;\n    }\n    this.toggleAttribute('data-selected', true);\n    this.label.select();\n  }\n\n  /**\n   * Deselects and configures the step.\n   * @internal\n   */\n  public deselect(): void {\n    if (!this.label) {\n      return;\n    }\n    this.toggleAttribute('data-selected', false);\n    this.label.deselect();\n  }\n\n  /**\n   * Emits a validate event whenever step switch is triggered.\n   * @internal\n   */\n  public validate(eventData: SbbStepValidateEventDetails): boolean {\n    return !!this._validate.emit(eventData);\n  }\n\n  /**\n   * Configures the step.\n   * @internal\n   */\n  public configure(stepperLoaded: boolean): void {\n    if (stepperLoaded) {\n      this._label = this._getStepLabel();\n    }\n    if (this.label) {\n      this.setAttribute('aria-labelledby', this.label.id);\n    }\n  }\n\n  /** Watches for clicked elements with `sbb-stepper-next` or `sbb-stepper-previous` attributes. */\n  private _handleClick(event: Event): void {\n    const composedPathElements = event\n      .composedPath()\n      .filter((el) => el instanceof window.HTMLElement);\n    if (composedPathElements.some((el) => this._isGoNextElement(el as HTMLElement))) {\n      this._stepper?.next();\n    } else if (composedPathElements.some((el) => this._isGoPreviousElement(el as HTMLElement))) {\n      this._stepper?.previous();\n    }\n  }\n\n  private _isGoNextElement(element: HTMLElement): boolean {\n    return element.hasAttribute('sbb-stepper-next') && !element.hasAttribute('disabled');\n  }\n\n  private _isGoPreviousElement(element: HTMLElement): boolean {\n    return element.hasAttribute('sbb-stepper-previous') && !element.hasAttribute('disabled');\n  }\n\n  private _getStepLabel(): SbbStepLabelElement | null {\n    let previousSibling = this.previousElementSibling;\n    while (previousSibling && previousSibling.localName !== 'sbb-step-label') {\n      previousSibling = previousSibling.previousElementSibling;\n    }\n    return previousSibling as SbbStepLabelElement;\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.id = this.id || `sbb-step-${nextId++}`;\n    this._stepper = this.closest('sbb-stepper');\n    this._label = this._getStepLabel();\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n    this._loaded = true;\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-step--wrapper\">\n        <div class=\"sbb-step\">\n          <slot></slot>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-step': SbbStepElement;\n  }\n}\n"],"names":["SbbStepElement","_a"],"mappings":"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"}
198
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"step.js","sources":["../../../../src/elements/stepper/step/step.ts"],"sourcesContent":["import { type CSSResultGroup, html, LitElement, type TemplateResult } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\nimport { hostAttributes } from '../../core/decorators.js';\nimport { EventEmitter } from '../../core/eventing.js';\nimport type { SbbStepLabelElement } from '../step-label.js';\nimport type { SbbStepperElement } from '../stepper.js';\n\nimport style from './step.scss?lit&inline';\n\nlet nextId = 0;\n\nexport type SbbStepValidateEventDetails = {\n  currentIndex: number | null;\n  currentStep: SbbStepElement | null;\n  nextIndex: number | null;\n  nextStep: SbbStepElement | null;\n};\n\n/**\n * Combined with a `sbb-stepper`, it displays a step's content.\n *\n * @slot - Use the unnamed slot to provide content.\n * @event {CustomEvent<SbbStepValidateEventDetails>} validate - Emits whenever step switch is triggered. Can be canceled.\n */\nexport\n@customElement('sbb-step')\n@hostAttributes({\n  slot: 'step',\n  role: 'tabpanel',\n})\nclass SbbStepElement extends LitElement {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    validate: 'validate',\n  } as const;\n\n  /** Emits whenever step switch is triggered. */\n  private _validate: EventEmitter<SbbStepValidateEventDetails> = new EventEmitter(\n    this,\n    SbbStepElement.events.validate,\n  );\n\n  private _stepper: SbbStepperElement | null = null;\n  private _label: SbbStepLabelElement | null = null;\n\n  /** The label of the step. */\n  public get label(): SbbStepLabelElement | null {\n    return this._label;\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('click', (e) => this._handleClick(e));\n  }\n\n  /**\n   * Selects and configures the step.\n   * @internal\n   */\n  public select(): void {\n    if (!this.hasUpdated || !this.label) {\n      return;\n    }\n    this.toggleAttribute('data-selected', true);\n    this.label.select();\n  }\n\n  /**\n   * Deselects and configures the step.\n   * @internal\n   */\n  public deselect(): void {\n    if (!this.label) {\n      return;\n    }\n    this.toggleAttribute('data-selected', false);\n    this.label.deselect();\n  }\n\n  /**\n   * Emits a validate event whenever step switch is triggered.\n   * @internal\n   */\n  public validate(eventData: SbbStepValidateEventDetails): boolean {\n    return !!this._validate.emit(eventData);\n  }\n\n  /**\n   * Configures the step.\n   * @internal\n   */\n  public configure(stepperLoaded: boolean): void {\n    if (stepperLoaded) {\n      this._label = this._getStepLabel();\n    }\n    if (this.label) {\n      this.setAttribute('aria-labelledby', this.label.id);\n    }\n  }\n\n  /** Watches for clicked elements with `sbb-stepper-next` or `sbb-stepper-previous` attributes. */\n  private _handleClick(event: Event): void {\n    const composedPathElements = event\n      .composedPath()\n      .filter((el) => el instanceof window.HTMLElement);\n    if (composedPathElements.some((el) => this._isGoNextElement(el as HTMLElement))) {\n      this._stepper?.next();\n    } else if (composedPathElements.some((el) => this._isGoPreviousElement(el as HTMLElement))) {\n      this._stepper?.previous();\n    }\n  }\n\n  private _isGoNextElement(element: HTMLElement): boolean {\n    return element.hasAttribute('sbb-stepper-next') && !element.hasAttribute('disabled');\n  }\n\n  private _isGoPreviousElement(element: HTMLElement): boolean {\n    return element.hasAttribute('sbb-stepper-previous') && !element.hasAttribute('disabled');\n  }\n\n  private _getStepLabel(): SbbStepLabelElement | null {\n    let previousSibling = this.previousElementSibling;\n    while (previousSibling && previousSibling.localName !== 'sbb-step-label') {\n      previousSibling = previousSibling.previousElementSibling;\n    }\n    return previousSibling as SbbStepLabelElement;\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.id = this.id || `sbb-step-${nextId++}`;\n    this._stepper = this.closest('sbb-stepper');\n    this._label = this._getStepLabel();\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-step--wrapper\">\n        <div class=\"sbb-step\">\n          <slot></slot>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-step': SbbStepElement;\n  }\n}\n"],"names":["SbbStepElement","_a"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAUA,IAAI,SAAS;IAqBP,kBAAc,MAAA;;AALnB,MAAA,mBAAA,CAAA,cAAc,UAAU,GACxB,eAAe;AAAA,IACd,MAAM;AAAA,IACN,MAAM;AAAA,EAAA,CACP,CAAC;;;;oBAC2B;AAARA,MAAAA,mBAAA,mBAAQ,YAAU;AAAA;AAAA,IAgBrC,IAAW,QAAK;AACd,aAAO,KAAK;AAAA,IAAA;AAAA,IAGd,cAAA;;;AAbQ,WAAA,YAAuD,IAAI,aACjE,MACAA,gBAAe,OAAO,QAAQ;AAGxB,WAAQ,WAA6B;AACrC,WAAM,SAA+B;AAS3C,OAAAC,MAAA,KAAK,qBAAL,gBAAAA,IAAA,WAAwB,SAAS,CAAC,MAAM,KAAK,aAAa,CAAC;AAAA,IAAC;AAAA;AAAA;AAAA;AAAA;AAAA,IAOvD,SAAM;AACX,UAAI,CAAC,KAAK,cAAc,CAAC,KAAK,OAAO;AACnC;AAAA,MAAA;AAEG,WAAA,gBAAgB,iBAAiB,IAAI;AAC1C,WAAK,MAAM;;;;;;IAON,WAAQ;AACT,UAAA,CAAC,KAAK,OAAO;AACf;AAAA,MAAA;AAEG,WAAA,gBAAgB,iBAAiB,KAAK;AAC3C,WAAK,MAAM;;;;;;IAON,SAAS,WAAsC;AACpD,aAAO,CAAC,CAAC,KAAK,UAAU,KAAK,SAAS;AAAA,IAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOjC,UAAU,eAAsB;AACrC,UAAI,eAAe;AACZ,aAAA,SAAS,KAAK;;AAErB,UAAI,KAAK,OAAO;AACd,aAAK,aAAa,mBAAmB,KAAK,MAAM,EAAE;AAAA,MAAA;AAAA,IACpD;AAAA;AAAA,IAIM,aAAa,OAAY;;AACzB,YAAA,uBAAuB,MAC1B,eACA,OAAO,CAAC,OAAO,cAAc,OAAO,WAAW;AAC9C,UAAA,qBAAqB,KAAK,CAAC,OAAO,KAAK,iBAAiB,EAAiB,CAAC,GAAG;AAC/E,SAAAA,MAAA,KAAK,aAAL,gBAAAA,IAAe;AAAA,iBACN,qBAAqB,KAAK,CAAC,OAAO,KAAK,qBAAqB,EAAiB,CAAC,GAAG;AAC1F,mBAAK,aAAL,mBAAe;AAAA;IACjB;AAAA,IAGM,iBAAiB,SAAoB;AAC3C,aAAO,QAAQ,aAAa,kBAAkB,KAAK,CAAC,QAAQ,aAAa,UAAU;AAAA,IAAA;AAAA,IAG7E,qBAAqB,SAAoB;AAC/C,aAAO,QAAQ,aAAa,sBAAsB,KAAK,CAAC,QAAQ,aAAa,UAAU;AAAA,IAAA;AAAA,IAGjF,gBAAa;AACnB,UAAI,kBAAkB,KAAK;AACpB,aAAA,mBAAmB,gBAAgB,cAAc,kBAAkB;AACxE,0BAAkB,gBAAgB;AAAA,MAAA;AAE7B,aAAA;AAAA,IAAA;AAAA,IAGO,oBAAiB;AAC/B,YAAM,kBAAiB;AACvB,WAAK,KAAK,KAAK,MAAM,YAAY,QAAQ;AACpC,WAAA,WAAW,KAAK,QAAQ,aAAa;AACrC,WAAA,SAAS,KAAK;;IAGF,SAAM;AAChB,aAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAAA;AAAA;;AA1GX,iBAkHC,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;QAjHwB,GAAM,SAAmB,OACzB,GAAA,SAAS;AAAA,IAC9B,UAAU;AAAA,EACF,GAJN,kBAAc,YAAA,uBAAA,GAAC;;;"}
@@ -202,7 +202,7 @@ let Be = (() => {
202
202
  if (this._input.localName === "input")
203
203
  this._patchInputValue();
204
204
  else if (this._input.localName === "sbb-select") {
205
- this._input.addEventListener("stateChange", () => this._checkAndUpdateInputEmpty(), {
205
+ this._input.addEventListener("displayValueChange", () => this._checkAndUpdateInputEmpty(), {
206
206
  signal: this._inputAbortController.signal
207
207
  });
208
208
  const r = this._input;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements",
3
- "version": "2.5.0",
3
+ "version": "2.5.1",
4
4
  "description": "Lyne Design System",
5
5
  "keywords": [
6
6
  "design system",
@@ -53,7 +53,6 @@ export declare class SbbRadioButtonGroupElement extends SbbRadioButtonGroupEleme
53
53
  * List of contained radio buttons.
54
54
  */
55
55
  get radioButtons(): (SbbRadioButtonElement | SbbRadioButtonPanelElement)[];
56
- private _didLoad;
57
56
  /**
58
57
  * Emits whenever the `sbb-radio-group` value changes.
59
58
  * @deprecated only used for React. Will probably be removed once React 19 is available.
@@ -1 +1 @@
1
- {"version":3,"file":"radio-button-group.d.ts","sourceRoot":"","sources":["../../../../src/elements/radio-button/radio-button-group/radio-button-group.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AAMvC,OAAO,KAAK,EAAE,iBAAiB,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAElF,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AACvD,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,0BAA0B,CAAC;AAC3E,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,oBAAoB,CAAC;;AAMhE;;;;;;GAMG;AACH,qBAMM,0BAA2B,SAAQ,+BAA4B;IACnE,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;;;MAIlB;IAEX;;OAEG;IACH,SAEgB,mBAAmB,EAAE,OAAO,CAAS;IAErD;;OAEG;IACH,SAEgB,QAAQ,EAAE,OAAO,CAAS;IAE1C;;OAEG;IACH,IACW,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,EAalC;IACD,IAAW,KAAK,IAAI,MAAM,GAAG,IAAI,CAEhC;IACD;;OAEG;IACH,OAAO,CAAC,cAAc,CAAuB;IAE7C;;;OAGG;IACH,SAA4B,IAAI,EAAE,kBAAkB,CAAyB;IAE7E;;OAEG;IACH,SACgB,cAAc,EAAE,iBAAiB,GAAG,IAAI,CAAQ;IAEhE;;OAEG;IACH,SACgB,WAAW,EAAE,cAAc,CAAgB;IAE3D,SAEgB,IAAI,EAAE,MAAM,CAAwC;IAEpE;;OAEG;IACH,IAAW,YAAY,IAAI,CAAC,qBAAqB,GAAG,0BAA0B,CAAC,EAAE,CAOhF;IAED,OAAO,CAAC,QAAQ,CAAS;IAEzB;;;OAGG;IACH,OAAO,CAAC,UAAU,CAGhB;;IAOc,iBAAiB,IAAI,IAAI;IAKzB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAiBhD,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ7F,OAAO,CAAC,cAAc;IAetB;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAIzB;;;OAGG;IACH,OAAO,CAAC,iBAAiB;cAON,MAAM,IAAI,cAAc;CAe5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,wBAAwB,EAAE,0BAA0B,CAAC;KACtD;CACF"}
1
+ {"version":3,"file":"radio-button-group.d.ts","sourceRoot":"","sources":["../../../../src/elements/radio-button/radio-button-group/radio-button-group.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AAMvC,OAAO,KAAK,EAAE,iBAAiB,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAElF,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AACvD,OAAO,KAAK,EAAE,0BAA0B,EAAE,MAAM,0BAA0B,CAAC;AAC3E,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,oBAAoB,CAAC;;AAMhE;;;;;;GAMG;AACH,qBAMM,0BAA2B,SAAQ,+BAA4B;IACnE,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;;;MAIlB;IAEX;;OAEG;IACH,SAEgB,mBAAmB,EAAE,OAAO,CAAS;IAErD;;OAEG;IACH,SAEgB,QAAQ,EAAE,OAAO,CAAS;IAE1C;;OAEG;IACH,IACW,KAAK,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,EAalC;IACD,IAAW,KAAK,IAAI,MAAM,GAAG,IAAI,CAEhC;IACD;;OAEG;IACH,OAAO,CAAC,cAAc,CAAuB;IAE7C;;;OAGG;IACH,SAA4B,IAAI,EAAE,kBAAkB,CAAyB;IAE7E;;OAEG;IACH,SACgB,cAAc,EAAE,iBAAiB,GAAG,IAAI,CAAQ;IAEhE;;OAEG;IACH,SACgB,WAAW,EAAE,cAAc,CAAgB;IAE3D,SAEgB,IAAI,EAAE,MAAM,CAAwC;IAEpE;;OAEG;IACH,IAAW,YAAY,IAAI,CAAC,qBAAqB,GAAG,0BAA0B,CAAC,EAAE,CAOhF;IAED;;;OAGG;IACH,OAAO,CAAC,UAAU,CAGhB;;IAOc,iBAAiB,IAAI,IAAI;IAKzB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAiBhD,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAO7F,OAAO,CAAC,cAAc;IAetB;;OAEG;IACH,OAAO,CAAC,iBAAiB;IAIzB;;;OAGG;IACH,OAAO,CAAC,iBAAiB;cAON,MAAM,IAAI,cAAc;CAe5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,wBAAwB,EAAE,0BAA0B,CAAC;KACtD;CACF"}
@@ -15,7 +15,7 @@ let et = 0, ut = (() => {
15
15
  var m, p, f, _, g, z, r;
16
16
  let o = [Q("sbb-radio-button-group"), W({
17
17
  role: "radiogroup"
18
- }), X()], i, n = [], d, x = P(J), y = [], E, S = [], k = [], q, B = [], C = [], F, I, R = [], U = [], L, N = [], V = [], A, D = [], j = [], G, O = [], T = [];
18
+ }), X()], i, n = [], d, x = P(J), y = [], E, S = [], k = [], q, B = [], C = [], F, I, R = [], U = [], N, V = [], A = [], D, L = [], j = [], G, O = [], T = [];
19
19
  var v = (r = class extends x {
20
20
  constructor() {
21
21
  var e;
@@ -26,7 +26,7 @@ let et = 0, ut = (() => {
26
26
  b(this, _);
27
27
  b(this, g);
28
28
  b(this, z);
29
- l(this, m, (s(this, y), s(this, S, !1))), l(this, p, (s(this, k), s(this, B, !1))), this._fallbackValue = (s(this, C), null), l(this, f, s(this, R, Y() ? "xs" : "m")), l(this, _, (s(this, U), s(this, N, null))), l(this, g, (s(this, V), s(this, D, "horizontal"))), l(this, z, (s(this, j), s(this, O, `sbb-radio-button-group-${++et}`))), this._didLoad = (s(this, T), !1), this._didChange = new Z(this, v.events.didChange), (e = this.addEventListener) == null || e.call(this, "change", (t) => this._onRadioChange(t));
29
+ l(this, m, (s(this, y), s(this, S, !1))), l(this, p, (s(this, k), s(this, B, !1))), this._fallbackValue = (s(this, C), null), l(this, f, s(this, R, Y() ? "xs" : "m")), l(this, _, (s(this, U), s(this, V, null))), l(this, g, (s(this, A), s(this, L, "horizontal"))), l(this, z, (s(this, j), s(this, O, `sbb-radio-button-group-${++et}`))), this._didChange = (s(this, T), new Z(this, v.events.didChange)), (e = this.addEventListener) == null || e.call(this, "change", (t) => this._onRadioChange(t));
30
30
  }
31
31
  /**
32
32
  * Whether the radios can be deselected.
@@ -50,7 +50,7 @@ let et = 0, ut = (() => {
50
50
  * The value of the radio group.
51
51
  */
52
52
  set value(e) {
53
- if (this._fallbackValue = e, !this._didLoad)
53
+ if (this._fallbackValue = e, !this.hasUpdated)
54
54
  return;
55
55
  if (e == null) {
56
56
  this.radioButtons.forEach((a) => a.checked = !1);
@@ -124,7 +124,7 @@ let et = 0, ut = (() => {
124
124
  }), e.has("name") && this._updateRadiosName();
125
125
  }
126
126
  async firstUpdated(e) {
127
- super.firstUpdated(e), this._didLoad = !0, await this.updateComplete, this._updateRadioState();
127
+ super.firstUpdated(e), await this.updateComplete, this._updateRadioState();
128
128
  }
129
129
  _onRadioChange(e) {
130
130
  const t = e.target;
@@ -159,7 +159,7 @@ let et = 0, ut = (() => {
159
159
  }
160
160
  }, m = new WeakMap(), p = new WeakMap(), f = new WeakMap(), _ = new WeakMap(), g = new WeakMap(), z = new WeakMap(), d = r, (() => {
161
161
  const e = typeof Symbol == "function" && Symbol.metadata ? Object.create(x[Symbol.metadata] ?? null) : void 0;
162
- E = [w(), c({ attribute: "allow-empty-selection", type: Boolean })], q = [w(), c({ type: Boolean })], F = [c()], I = [c()], L = [c({ attribute: "horizontal-from", reflect: !0 })], A = [c({ reflect: !0 })], G = [w(), c()], h(r, null, E, { kind: "accessor", name: "allowEmptySelection", static: !1, private: !1, access: { has: (t) => "allowEmptySelection" in t, get: (t) => t.allowEmptySelection, set: (t, a) => {
162
+ E = [w(), c({ attribute: "allow-empty-selection", type: Boolean })], q = [w(), c({ type: Boolean })], F = [c()], I = [c()], N = [c({ attribute: "horizontal-from", reflect: !0 })], D = [c({ reflect: !0 })], G = [w(), c()], h(r, null, E, { kind: "accessor", name: "allowEmptySelection", static: !1, private: !1, access: { has: (t) => "allowEmptySelection" in t, get: (t) => t.allowEmptySelection, set: (t, a) => {
163
163
  t.allowEmptySelection = a;
164
164
  } }, metadata: e }, S, k), h(r, null, q, { kind: "accessor", name: "required", static: !1, private: !1, access: { has: (t) => "required" in t, get: (t) => t.required, set: (t, a) => {
165
165
  t.required = a;
@@ -167,11 +167,11 @@ let et = 0, ut = (() => {
167
167
  t.value = a;
168
168
  } }, metadata: e }, null, y), h(r, null, I, { kind: "accessor", name: "size", static: !1, private: !1, access: { has: (t) => "size" in t, get: (t) => t.size, set: (t, a) => {
169
169
  t.size = a;
170
- } }, metadata: e }, R, U), h(r, null, L, { kind: "accessor", name: "horizontalFrom", static: !1, private: !1, access: { has: (t) => "horizontalFrom" in t, get: (t) => t.horizontalFrom, set: (t, a) => {
170
+ } }, metadata: e }, R, U), h(r, null, N, { kind: "accessor", name: "horizontalFrom", static: !1, private: !1, access: { has: (t) => "horizontalFrom" in t, get: (t) => t.horizontalFrom, set: (t, a) => {
171
171
  t.horizontalFrom = a;
172
- } }, metadata: e }, N, V), h(r, null, A, { kind: "accessor", name: "orientation", static: !1, private: !1, access: { has: (t) => "orientation" in t, get: (t) => t.orientation, set: (t, a) => {
172
+ } }, metadata: e }, V, A), h(r, null, D, { kind: "accessor", name: "orientation", static: !1, private: !1, access: { has: (t) => "orientation" in t, get: (t) => t.orientation, set: (t, a) => {
173
173
  t.orientation = a;
174
- } }, metadata: e }, D, j), h(r, null, G, { kind: "accessor", name: "name", static: !1, private: !1, access: { has: (t) => "name" in t, get: (t) => t.name, set: (t, a) => {
174
+ } }, metadata: e }, L, j), h(r, null, G, { kind: "accessor", name: "name", static: !1, private: !1, access: { has: (t) => "name" in t, get: (t) => t.name, set: (t, a) => {
175
175
  t.name = a;
176
176
  } }, metadata: e }, O, T), h(null, i = { value: d }, o, { kind: "class", name: d.name, metadata: e }, null, n), v = d = i.value, e && Object.defineProperty(d, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: e });
177
177
  })(), r.styles = tt, r.events = {
@@ -1,6 +1,9 @@
1
1
  import { CSSResultGroup, PropertyDeclaration, PropertyValues, TemplateResult } from 'lit';
2
2
  import { SbbOpenCloseBaseElement } from '../core/base-elements.js';
3
3
  import { FormRestoreReason, FormRestoreState } from '../core/mixins.js';
4
+ /**
5
+ * @deprecated will be removed with next major version
6
+ */
4
7
  export interface SelectChange {
5
8
  type: 'value';
6
9
  value: string | string[];
@@ -26,7 +29,7 @@ export declare class SbbSelectElement extends SbbSelectElement_base {
26
29
  static readonly events: {
27
30
  readonly change: "change";
28
31
  readonly input: "input";
29
- readonly stateChange: "stateChange";
32
+ readonly displayValueChange: "displayValueChange";
30
33
  readonly willOpen: "willOpen";
31
34
  readonly didOpen: "didOpen";
32
35
  readonly willClose: "willClose";
@@ -51,7 +54,7 @@ export declare class SbbSelectElement extends SbbSelectElement_base {
51
54
  /** Notifies that an option value has been selected. */
52
55
  private _input;
53
56
  /** @internal */
54
- private _stateChange;
57
+ private _displayValueChanged;
55
58
  private _overlay;
56
59
  private _optionContainer;
57
60
  private _originElement;
@@ -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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"}