@sbb-esta/lyne-elements 1.11.2 → 1.12.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/_index.scss +1 -1
- package/core/a11y/focus.d.ts.map +1 -1
- package/core/a11y.js +1 -1
- package/core/i18n/i18n.d.ts +5 -0
- package/core/i18n/i18n.d.ts.map +1 -1
- package/core/i18n.js +85 -55
- package/core/styles/lists.scss +4 -0
- package/core/styles/mixins/lists.scss +128 -76
- package/custom-elements.json +774 -76
- package/development/core/a11y/focus.d.ts.map +1 -1
- package/development/core/a11y.js +2 -2
- package/development/core/i18n/i18n.d.ts +5 -0
- package/development/core/i18n/i18n.d.ts.map +1 -1
- package/development/core/i18n.js +36 -1
- package/development/paginator/index.d.ts +2 -0
- package/development/paginator/index.d.ts.map +1 -0
- package/development/paginator/paginator.d.ts +91 -0
- package/development/paginator/paginator.d.ts.map +1 -0
- package/development/paginator.d.ts +2 -0
- package/development/paginator.d.ts.map +1 -0
- package/development/paginator.js +526 -0
- package/development/radio-button/radio-button-group/radio-button-group.d.ts +1 -1
- package/development/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
- package/development/radio-button/radio-button-group.js +16 -12
- package/development/select/select.d.ts +6 -0
- package/development/select/select.d.ts.map +1 -1
- package/development/select.js +22 -2
- package/development/slider/slider.d.ts +35 -16
- package/development/slider/slider.d.ts.map +1 -1
- package/development/slider.js +102 -81
- package/index.d.ts +2 -0
- package/index.js +2 -0
- package/lists.css +102 -36
- package/package.json +6 -1
- package/paginator/index.d.ts +2 -0
- package/paginator/index.d.ts.map +1 -0
- package/paginator/paginator.d.ts +91 -0
- package/paginator/paginator.d.ts.map +1 -0
- package/paginator.d.ts +2 -0
- package/paginator.d.ts.map +1 -0
- package/paginator.js +263 -0
- package/radio-button/radio-button-group/radio-button-group.d.ts +1 -1
- package/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
- package/radio-button/radio-button-group.js +11 -7
- package/select/select.d.ts +6 -0
- package/select/select.d.ts.map +1 -1
- package/select.js +40 -24
- package/slider/slider.d.ts +35 -16
- package/slider/slider.d.ts.map +1 -1
- package/slider.js +111 -78
- package/standard-theme.css +102 -36
|
@@ -190,7 +190,7 @@ let SbbRadioButtonGroupElement = class extends SbbDisabledMixin(LitElement) {
|
|
|
190
190
|
const signal = this._abort.signal;
|
|
191
191
|
this.addEventListener(
|
|
192
192
|
"stateChange",
|
|
193
|
-
(e) => this.
|
|
193
|
+
(e) => this._onRadioButtonChange(e),
|
|
194
194
|
{
|
|
195
195
|
signal,
|
|
196
196
|
passive: true
|
|
@@ -248,20 +248,24 @@ let SbbRadioButtonGroupElement = class extends SbbDisabledMixin(LitElement) {
|
|
|
248
248
|
disconnectedCallback() {
|
|
249
249
|
super.disconnectedCallback();
|
|
250
250
|
}
|
|
251
|
-
|
|
251
|
+
_onRadioButtonChange(event) {
|
|
252
252
|
var _a;
|
|
253
253
|
event.stopPropagation();
|
|
254
|
-
if (
|
|
254
|
+
if (!this._didLoad) {
|
|
255
255
|
return;
|
|
256
256
|
}
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
257
|
+
if (event.detail.type === "disabled") {
|
|
258
|
+
this._updateRadios(this.value);
|
|
259
|
+
} else if (event.detail.type === "checked") {
|
|
260
|
+
const radioButton = event.target;
|
|
261
|
+
if (event.detail.checked) {
|
|
262
|
+
this.value = radioButton.value;
|
|
263
|
+
this._emitChange(radioButton, this.value);
|
|
264
|
+
} else if (this.allowEmptySelection) {
|
|
265
|
+
this.value = (_a = this.radioButtons.find((radio) => radio.checked)) == null ? void 0 : _a.value;
|
|
266
|
+
if (!this.value) {
|
|
267
|
+
this._emitChange(radioButton);
|
|
268
|
+
}
|
|
265
269
|
}
|
|
266
270
|
}
|
|
267
271
|
}
|
|
@@ -359,4 +363,4 @@ SbbRadioButtonGroupElement = __decorateClass([
|
|
|
359
363
|
export {
|
|
360
364
|
SbbRadioButtonGroupElement
|
|
361
365
|
};
|
|
362
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"radio-button-group.js","sources":["../../../../src/elements/radio-button/radio-button-group/radio-button-group.ts"],"sourcesContent":["import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { LitElement, html } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { getNextElementIndex, isArrowKeyPressed } from '../../core/a11y.js';\nimport { SbbConnectedAbortController } from '../../core/controllers.js';\nimport { hostAttributes, slotState } from '../../core/decorators.js';\nimport { EventEmitter } from '../../core/eventing.js';\nimport type { SbbHorizontalFrom, SbbOrientation, SbbStateChange } from '../../core/interfaces.js';\nimport { SbbDisabledMixin } from '../../core/mixins.js';\nimport type { SbbRadioButtonStateChange, SbbRadioButtonSize } from '../common.js';\nimport type { SbbRadioButtonPanelElement } from '../radio-button-panel.js';\nimport type { SbbRadioButtonElement } from '../radio-button.js';\n\nimport style from './radio-button-group.scss?lit&inline';\n\nexport type SbbRadioButtonGroupEventDetail = {\n  value: any | null;\n  radioButton: SbbRadioButtonElement | SbbRadioButtonPanelElement;\n};\n\n/**\n * It can be used as a container for one or more `sbb-radio-button`.\n *\n * @slot - Use the unnamed slot to add `sbb-radio-button` elements to the `sbb-radio-button-group`.\n * @slot error - Use this to provide a `sbb-form-error` to show an error message.\n * @event {CustomEvent<SbbRadioButtonGroupEventDetail>} didChange - Deprecated. Only used for React. Will probably be removed once React 19 is available. Emits whenever the `sbb-radio-group` value changes.\n * @event {CustomEvent<SbbRadioButtonGroupEventDetail>} change - Emits whenever the `sbb-radio-group` value changes.\n * @event {CustomEvent<SbbRadioButtonGroupEventDetail>} input - Emits whenever the `sbb-radio-group` value changes.\n */\n@customElement('sbb-radio-button-group')\n@hostAttributes({\n  role: 'radiogroup',\n})\n@slotState()\nexport class SbbRadioButtonGroupElement extends SbbDisabledMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    didChange: 'didChange',\n    change: 'change',\n    input: 'input',\n  } as const;\n\n  /**\n   * Whether the radios can be deselected.\n   */\n  @property({ attribute: 'allow-empty-selection', type: Boolean })\n  public allowEmptySelection: boolean = false;\n\n  /**\n   * Whether the radio group is required.\n   */\n  @property({ type: Boolean }) public required: boolean = false;\n\n  /**\n   * The value of the radio group.\n   */\n  @property() public value?: any | null;\n\n  /**\n   * Size variant.\n   */\n  @property() public size: SbbRadioButtonSize = 'm';\n\n  /**\n   * Overrides the behaviour of `orientation` property.\n   */\n  @property({ attribute: 'horizontal-from', reflect: true })\n  public horizontalFrom?: SbbHorizontalFrom;\n\n  /**\n   * Radio group's orientation, either horizontal or vertical.\n   */\n  @property({ reflect: true })\n  public orientation: SbbOrientation = 'horizontal';\n\n  /**\n   * List of contained radio buttons.\n   */\n  public get radioButtons(): (SbbRadioButtonElement | SbbRadioButtonPanelElement)[] {\n    return (\n      Array.from(this.querySelectorAll?.('sbb-radio-button, sbb-radio-button-panel') ?? []) as (\n        | SbbRadioButtonElement\n        | SbbRadioButtonPanelElement\n      )[]\n    ).filter((el) => el.closest?.('sbb-radio-button-group') === this);\n  }\n\n  private get _enabledRadios(): (SbbRadioButtonElement | SbbRadioButtonPanelElement)[] | undefined {\n    if (!this.disabled) {\n      return this.radioButtons.filter((r) => !r.disabled);\n    }\n  }\n\n  private _hasSelectionExpansionPanelElement: boolean = false;\n  private _didLoad = false;\n  private _abort = new SbbConnectedAbortController(this);\n\n  /**\n   * Emits whenever the `sbb-radio-group` value changes.\n   * @deprecated only used for React. Will probably be removed once React 19 is available.\n   */\n  private _didChange: EventEmitter = new EventEmitter<SbbRadioButtonGroupEventDetail>(\n    this,\n    SbbRadioButtonGroupElement.events.didChange,\n  );\n\n  /**\n   * Emits whenever the `sbb-radio-group` value changes.\n   */\n  private _change: EventEmitter = new EventEmitter<SbbRadioButtonGroupEventDetail>(\n    this,\n    SbbRadioButtonGroupElement.events.change,\n  );\n\n  /**\n   * Emits whenever the `sbb-radio-group` value changes.\n   */\n  private _input: EventEmitter = new EventEmitter<SbbRadioButtonGroupEventDetail>(\n    this,\n    SbbRadioButtonGroupElement.events.input,\n  );\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    const signal = this._abort.signal;\n    this.addEventListener(\n      'stateChange',\n      (e: CustomEvent<SbbStateChange>) =>\n        this._onRadioButtonSelect(e as CustomEvent<SbbRadioButtonStateChange>),\n      {\n        signal,\n        passive: true,\n      },\n    );\n    this.addEventListener('keydown', (e) => this._handleKeyDown(e), { signal });\n    this._hasSelectionExpansionPanelElement = !!this.querySelector?.(\n      'sbb-selection-expansion-panel',\n    );\n    this.toggleAttribute(\n      'data-has-panel',\n      !!this.querySelector?.('sbb-selection-expansion-panel, sbb-radio-button-panel'),\n    );\n    this._updateRadios(this.value);\n  }\n\n  public override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('value')) {\n      this._valueChanged(this.value);\n    }\n    if (changedProperties.has('disabled')) {\n      for (const radio of this.radioButtons) {\n        radio.tabIndex = this._getRadioTabIndex(radio);\n        radio.requestUpdate?.('disabled');\n      }\n      this._setFocusableRadio();\n    }\n    if (changedProperties.has('required')) {\n      this.radioButtons.forEach((r) => r.requestUpdate?.('required'));\n    }\n    if (changedProperties.has('size')) {\n      this.radioButtons.forEach((r) => r.requestUpdate?.('size'));\n    }\n  }\n\n  private _valueChanged(value: any | undefined): void {\n    for (const radio of this.radioButtons) {\n      radio.checked = radio.value === value;\n      radio.tabIndex = this._getRadioTabIndex(radio);\n    }\n    this._setFocusableRadio();\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._didLoad = true;\n    this._updateRadios(this.value);\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n  }\n\n  private _onRadioButtonSelect(event: CustomEvent<SbbRadioButtonStateChange>): void {\n    event.stopPropagation();\n    if (event.detail.type !== 'checked' || !this._didLoad) {\n      return;\n    }\n\n    const radioButton = event.target as SbbRadioButtonElement;\n\n    if (event.detail.checked) {\n      this.value = radioButton.value;\n      this._emitChange(radioButton, this.value);\n    } else if (this.allowEmptySelection) {\n      this.value = this.radioButtons.find((radio) => radio.checked)?.value;\n      if (!this.value) {\n        this._emitChange(radioButton);\n      }\n    }\n  }\n\n  private _emitChange(radioButton: SbbRadioButtonElement, value?: string): void {\n    this._change.emit({ value, radioButton });\n    this._input.emit({ value, radioButton });\n    this._didChange.emit({ value, radioButton });\n  }\n\n  private _updateRadios(initValue?: string): void {\n    if (!this._didLoad) {\n      return;\n    }\n\n    const radioButtons = this.radioButtons;\n\n    this.value = initValue ?? radioButtons.find((radio) => radio.checked)?.value ?? this.value;\n\n    for (const radio of radioButtons) {\n      radio.checked = radio.value === this.value;\n      radio.tabIndex = this._getRadioTabIndex(radio);\n    }\n\n    this._setFocusableRadio();\n  }\n\n  private _setFocusableRadio(): void {\n    const checked = this.radioButtons.find((radio) => radio.checked && !radio.disabled);\n\n    const enabledRadios = this._enabledRadios;\n    if (!checked && enabledRadios?.length) {\n      enabledRadios[0].tabIndex = 0;\n    }\n  }\n\n  private _getRadioTabIndex(radio: SbbRadioButtonElement | SbbRadioButtonPanelElement): number {\n    const isSelected: boolean = radio.checked && !radio.disabled && !this.disabled;\n\n    return isSelected || this._hasSelectionExpansionPanelElement ? 0 : -1;\n  }\n\n  private _handleKeyDown(evt: KeyboardEvent): void {\n    const enabledRadios = this._enabledRadios;\n\n    if (\n      !enabledRadios ||\n      !enabledRadios.length ||\n      // don't trap nested handling\n      ((evt.target as HTMLElement) !== this &&\n        (evt.target as HTMLElement).parentElement !== this &&\n        (evt.target as HTMLElement).parentElement?.localName !== 'sbb-selection-expansion-panel')\n    ) {\n      return;\n    }\n\n    if (!isArrowKeyPressed(evt)) {\n      return;\n    }\n\n    const current: number = enabledRadios.findIndex(\n      (e: SbbRadioButtonElement | SbbRadioButtonPanelElement) => e === evt.target,\n    );\n    const nextIndex: number = getNextElementIndex(evt, current, enabledRadios.length);\n\n    if (!this._hasSelectionExpansionPanelElement) {\n      enabledRadios[nextIndex].select();\n    }\n\n    enabledRadios[nextIndex].focus();\n    evt.preventDefault();\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-radio-group\">\n        <slot @slotchange=${() => this._updateRadios()}></slot>\n      </div>\n      <div class=\"sbb-radio-group__error\">\n        <slot name=\"error\"></slot>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-radio-button-group': SbbRadioButtonGroupElement;\n  }\n}\n"],"names":["_a"],"mappings":"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"}
|
|
366
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"radio-button-group.js","sources":["../../../../src/elements/radio-button/radio-button-group/radio-button-group.ts"],"sourcesContent":["import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { LitElement, html } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { getNextElementIndex, isArrowKeyPressed } from '../../core/a11y.js';\nimport { SbbConnectedAbortController } from '../../core/controllers.js';\nimport { hostAttributes, slotState } from '../../core/decorators.js';\nimport { EventEmitter } from '../../core/eventing.js';\nimport type { SbbHorizontalFrom, SbbOrientation, SbbStateChange } from '../../core/interfaces.js';\nimport { SbbDisabledMixin } from '../../core/mixins.js';\nimport type { SbbRadioButtonStateChange, SbbRadioButtonSize } from '../common.js';\nimport type { SbbRadioButtonPanelElement } from '../radio-button-panel.js';\nimport type { SbbRadioButtonElement } from '../radio-button.js';\n\nimport style from './radio-button-group.scss?lit&inline';\n\nexport type SbbRadioButtonGroupEventDetail = {\n  value: any | null;\n  radioButton: SbbRadioButtonElement | SbbRadioButtonPanelElement;\n};\n\n/**\n * It can be used as a container for one or more `sbb-radio-button`.\n *\n * @slot - Use the unnamed slot to add `sbb-radio-button` elements to the `sbb-radio-button-group`.\n * @slot error - Use this to provide a `sbb-form-error` to show an error message.\n * @event {CustomEvent<SbbRadioButtonGroupEventDetail>} didChange - Deprecated. Only used for React. Will probably be removed once React 19 is available. Emits whenever the `sbb-radio-group` value changes.\n * @event {CustomEvent<SbbRadioButtonGroupEventDetail>} change - Emits whenever the `sbb-radio-group` value changes.\n * @event {CustomEvent<SbbRadioButtonGroupEventDetail>} input - Emits whenever the `sbb-radio-group` value changes.\n */\n@customElement('sbb-radio-button-group')\n@hostAttributes({\n  role: 'radiogroup',\n})\n@slotState()\nexport class SbbRadioButtonGroupElement extends SbbDisabledMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    didChange: 'didChange',\n    change: 'change',\n    input: 'input',\n  } as const;\n\n  /**\n   * Whether the radios can be deselected.\n   */\n  @property({ attribute: 'allow-empty-selection', type: Boolean })\n  public allowEmptySelection: boolean = false;\n\n  /**\n   * Whether the radio group is required.\n   */\n  @property({ type: Boolean }) public required: boolean = false;\n\n  /**\n   * The value of the radio group.\n   */\n  @property() public value?: any | null;\n\n  /**\n   * Size variant.\n   */\n  @property() public size: SbbRadioButtonSize = 'm';\n\n  /**\n   * Overrides the behaviour of `orientation` property.\n   */\n  @property({ attribute: 'horizontal-from', reflect: true })\n  public horizontalFrom?: SbbHorizontalFrom;\n\n  /**\n   * Radio group's orientation, either horizontal or vertical.\n   */\n  @property({ reflect: true })\n  public orientation: SbbOrientation = 'horizontal';\n\n  /**\n   * List of contained radio buttons.\n   */\n  public get radioButtons(): (SbbRadioButtonElement | SbbRadioButtonPanelElement)[] {\n    return (\n      Array.from(this.querySelectorAll?.('sbb-radio-button, sbb-radio-button-panel') ?? []) as (\n        | SbbRadioButtonElement\n        | SbbRadioButtonPanelElement\n      )[]\n    ).filter((el) => el.closest?.('sbb-radio-button-group') === this);\n  }\n\n  private get _enabledRadios(): (SbbRadioButtonElement | SbbRadioButtonPanelElement)[] | undefined {\n    if (!this.disabled) {\n      return this.radioButtons.filter((r) => !r.disabled);\n    }\n  }\n\n  private _hasSelectionExpansionPanelElement: boolean = false;\n  private _didLoad = false;\n  private _abort = new SbbConnectedAbortController(this);\n\n  /**\n   * Emits whenever the `sbb-radio-group` value changes.\n   * @deprecated only used for React. Will probably be removed once React 19 is available.\n   */\n  private _didChange: EventEmitter = new EventEmitter<SbbRadioButtonGroupEventDetail>(\n    this,\n    SbbRadioButtonGroupElement.events.didChange,\n  );\n\n  /**\n   * Emits whenever the `sbb-radio-group` value changes.\n   */\n  private _change: EventEmitter = new EventEmitter<SbbRadioButtonGroupEventDetail>(\n    this,\n    SbbRadioButtonGroupElement.events.change,\n  );\n\n  /**\n   * Emits whenever the `sbb-radio-group` value changes.\n   */\n  private _input: EventEmitter = new EventEmitter<SbbRadioButtonGroupEventDetail>(\n    this,\n    SbbRadioButtonGroupElement.events.input,\n  );\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    const signal = this._abort.signal;\n    this.addEventListener(\n      'stateChange',\n      (e: CustomEvent<SbbStateChange>) =>\n        this._onRadioButtonChange(e as CustomEvent<SbbRadioButtonStateChange>),\n      {\n        signal,\n        passive: true,\n      },\n    );\n    this.addEventListener('keydown', (e) => this._handleKeyDown(e), { signal });\n    this._hasSelectionExpansionPanelElement = !!this.querySelector?.(\n      'sbb-selection-expansion-panel',\n    );\n    this.toggleAttribute(\n      'data-has-panel',\n      !!this.querySelector?.('sbb-selection-expansion-panel, sbb-radio-button-panel'),\n    );\n    this._updateRadios(this.value);\n  }\n\n  public override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('value')) {\n      this._valueChanged(this.value);\n    }\n    if (changedProperties.has('disabled')) {\n      for (const radio of this.radioButtons) {\n        radio.tabIndex = this._getRadioTabIndex(radio);\n        radio.requestUpdate?.('disabled');\n      }\n      this._setFocusableRadio();\n    }\n    if (changedProperties.has('required')) {\n      this.radioButtons.forEach((r) => r.requestUpdate?.('required'));\n    }\n    if (changedProperties.has('size')) {\n      this.radioButtons.forEach((r) => r.requestUpdate?.('size'));\n    }\n  }\n\n  private _valueChanged(value: any | undefined): void {\n    for (const radio of this.radioButtons) {\n      radio.checked = radio.value === value;\n      radio.tabIndex = this._getRadioTabIndex(radio);\n    }\n    this._setFocusableRadio();\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._didLoad = true;\n    this._updateRadios(this.value);\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n  }\n\n  private _onRadioButtonChange(event: CustomEvent<SbbRadioButtonStateChange>): void {\n    event.stopPropagation();\n\n    if (!this._didLoad) {\n      return;\n    }\n\n    if (event.detail.type === 'disabled') {\n      this._updateRadios(this.value);\n    } else if (event.detail.type === 'checked') {\n      const radioButton = event.target as SbbRadioButtonElement;\n\n      if (event.detail.checked) {\n        this.value = radioButton.value;\n        this._emitChange(radioButton, this.value);\n      } else if (this.allowEmptySelection) {\n        this.value = this.radioButtons.find((radio) => radio.checked)?.value;\n        if (!this.value) {\n          this._emitChange(radioButton);\n        }\n      }\n    }\n  }\n\n  private _emitChange(radioButton: SbbRadioButtonElement, value?: string): void {\n    this._change.emit({ value, radioButton });\n    this._input.emit({ value, radioButton });\n    this._didChange.emit({ value, radioButton });\n  }\n\n  private _updateRadios(initValue?: string): void {\n    if (!this._didLoad) {\n      return;\n    }\n\n    const radioButtons = this.radioButtons;\n\n    this.value = initValue ?? radioButtons.find((radio) => radio.checked)?.value ?? this.value;\n\n    for (const radio of radioButtons) {\n      radio.checked = radio.value === this.value;\n      radio.tabIndex = this._getRadioTabIndex(radio);\n    }\n\n    this._setFocusableRadio();\n  }\n\n  private _setFocusableRadio(): void {\n    const checked = this.radioButtons.find((radio) => radio.checked && !radio.disabled);\n\n    const enabledRadios = this._enabledRadios;\n    if (!checked && enabledRadios?.length) {\n      enabledRadios[0].tabIndex = 0;\n    }\n  }\n\n  private _getRadioTabIndex(radio: SbbRadioButtonElement | SbbRadioButtonPanelElement): number {\n    const isSelected: boolean = radio.checked && !radio.disabled && !this.disabled;\n\n    return isSelected || this._hasSelectionExpansionPanelElement ? 0 : -1;\n  }\n\n  private _handleKeyDown(evt: KeyboardEvent): void {\n    const enabledRadios = this._enabledRadios;\n\n    if (\n      !enabledRadios ||\n      !enabledRadios.length ||\n      // don't trap nested handling\n      ((evt.target as HTMLElement) !== this &&\n        (evt.target as HTMLElement).parentElement !== this &&\n        (evt.target as HTMLElement).parentElement?.localName !== 'sbb-selection-expansion-panel')\n    ) {\n      return;\n    }\n\n    if (!isArrowKeyPressed(evt)) {\n      return;\n    }\n\n    const current: number = enabledRadios.findIndex(\n      (e: SbbRadioButtonElement | SbbRadioButtonPanelElement) => e === evt.target,\n    );\n    const nextIndex: number = getNextElementIndex(evt, current, enabledRadios.length);\n\n    if (!this._hasSelectionExpansionPanelElement) {\n      enabledRadios[nextIndex].select();\n    }\n\n    enabledRadios[nextIndex].focus();\n    evt.preventDefault();\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-radio-group\">\n        <slot @slotchange=${() => this._updateRadios()}></slot>\n      </div>\n      <div class=\"sbb-radio-group__error\">\n        <slot name=\"error\"></slot>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-radio-button-group': SbbRadioButtonGroupElement;\n  }\n}\n"],"names":["_a"],"mappings":"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"}
|
|
@@ -74,6 +74,12 @@ export declare class SbbSelectElement extends SbbSelectElement_base {
|
|
|
74
74
|
/** Gets all the SbbOptionElement projected in the select. */
|
|
75
75
|
private get _options();
|
|
76
76
|
private get _filteredOptions();
|
|
77
|
+
constructor();
|
|
78
|
+
/**
|
|
79
|
+
* TODO: Accessibility fix required to correctly read the label;
|
|
80
|
+
* can be possibly removed after the merge of https://github.com/sbb-design-systems/lyne-components/issues/3062
|
|
81
|
+
*/
|
|
82
|
+
private _onSelectAttributesChange;
|
|
77
83
|
/** Opens the selection panel. */
|
|
78
84
|
open(): void;
|
|
79
85
|
/** Closes the selection panel. */
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"select.d.ts","sourceRoot":"","sources":["../../../../src/elements/select/select.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"select.d.ts","sourceRoot":"","sources":["../../../../src/elements/select/select.ts"],"names":[],"mappings":"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"}
|
package/development/select.js
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { MutationController } from "@lit-labs/observers/mutation-controller.js";
|
|
1
2
|
import { css, html, nothing } from "lit";
|
|
2
3
|
import { property, state, customElement } from "lit/decorators.js";
|
|
3
4
|
import { ref } from "lit/directives/ref.js";
|
|
@@ -323,7 +324,7 @@ let SbbSelectElement = class extends SbbUpdateSchedulerMixin(
|
|
|
323
324
|
SbbDisabledMixin(SbbNegativeMixin(SbbHydrationMixin(SbbOpenCloseBaseElement)))
|
|
324
325
|
) {
|
|
325
326
|
constructor() {
|
|
326
|
-
super(
|
|
327
|
+
super();
|
|
327
328
|
this.multiple = false;
|
|
328
329
|
this.required = false;
|
|
329
330
|
this.readonly = false;
|
|
@@ -352,6 +353,10 @@ let SbbSelectElement = class extends SbbUpdateSchedulerMixin(
|
|
|
352
353
|
this.close();
|
|
353
354
|
}
|
|
354
355
|
};
|
|
356
|
+
new MutationController(this, {
|
|
357
|
+
config: { attributeFilter: ["aria-labelledby"] },
|
|
358
|
+
callback: (mutationsList) => this._onSelectAttributesChange(mutationsList)
|
|
359
|
+
});
|
|
355
360
|
}
|
|
356
361
|
/**
|
|
357
362
|
* The 'combobox' input element
|
|
@@ -370,6 +375,21 @@ let SbbSelectElement = class extends SbbUpdateSchedulerMixin(
|
|
|
370
375
|
(opt) => !opt.disabled && !opt.hasAttribute("data-group-disabled")
|
|
371
376
|
);
|
|
372
377
|
}
|
|
378
|
+
/**
|
|
379
|
+
* TODO: Accessibility fix required to correctly read the label;
|
|
380
|
+
* can be possibly removed after the merge of https://github.com/sbb-design-systems/lyne-components/issues/3062
|
|
381
|
+
*/
|
|
382
|
+
_onSelectAttributesChange(mutationsList) {
|
|
383
|
+
var _a;
|
|
384
|
+
for (const mutation of mutationsList) {
|
|
385
|
+
if (mutation.attributeName === "aria-labelledby") {
|
|
386
|
+
(_a = this._triggerElement) == null ? void 0 : _a.setAttribute(
|
|
387
|
+
"aria-labelledby",
|
|
388
|
+
this.getAttribute("aria-labelledby")
|
|
389
|
+
);
|
|
390
|
+
}
|
|
391
|
+
}
|
|
392
|
+
}
|
|
373
393
|
/** Opens the selection panel. */
|
|
374
394
|
open() {
|
|
375
395
|
if (this.state !== "closed" || !this._overlay || this._options.length === 0) {
|
|
@@ -896,4 +916,4 @@ SbbSelectElement = __decorateClass([
|
|
|
896
916
|
export {
|
|
897
917
|
SbbSelectElement
|
|
898
918
|
};
|
|
899
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"select.js","sources":["../../../src/elements/select/select.ts"],"sourcesContent":["import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, 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 { SbbConnectedAbortController } from '../core/controllers.js';\nimport { hostAttributes } from '../core/decorators.js';\nimport { isNextjs, isSafari } from '../core/dom.js';\nimport { EventEmitter } from '../core/eventing.js';\nimport {\n  SbbDisabledMixin,\n  SbbHydrationMixin,\n  SbbNegativeMixin,\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>} didChange - Deprecated. used for React. Will probably be removed once React 19 is available.\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 */\n@customElement('sbb-select')\n@hostAttributes({\n  role: ariaRoleOnHost ? 'listbox' : null,\n})\nexport class SbbSelectElement extends SbbUpdateSchedulerMixin(\n  SbbDisabledMixin(SbbNegativeMixin(SbbHydrationMixin(SbbOpenCloseBaseElement))),\n) {\n  public static override styles: CSSResultGroup = style;\n\n  // FIXME using ...super.events requires: https://github.com/sbb-design-systems/lyne-components/issues/2600\n  public static override readonly events = {\n    didChange: 'didChange',\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 value of the select component. If `multiple` is true, it's an array. */\n  @property() public value?: string | string[];\n\n  /** The placeholder used if no value has been selected. */\n  @property() public placeholder?: string;\n\n  /** Whether the select allows for multiple selection. */\n  @property({ type: Boolean, reflect: true }) public multiple = false;\n\n  /** Whether the select is required. */\n  @property({ reflect: true, type: Boolean }) public required = false;\n\n  /** Whether the select is readonly. */\n  @property({ type: Boolean }) public readonly = false;\n\n  /** The value displayed by the component. */\n  @state() private _displayValue: string | null = null;\n\n  /**\n   * @deprecated only used for React. Will probably be removed once React 19 is available.\n   */\n  private _didChange: EventEmitter = new EventEmitter(this, SbbSelectElement.events.didChange);\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 _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 _abort = new SbbConnectedAbortController(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  /** Opens the selection panel. */\n  public open(): void {\n    if (this.state !== 'closed' || !this._overlay || this._options.length === 0) {\n      return;\n    }\n\n    if (!this.willOpen.emit()) {\n      return;\n    }\n    this.state = 'opening';\n    this._setOverlayPosition();\n  }\n\n  /** Closes the selection panel. */\n  public close(): void {\n    if (this.state !== 'opened') {\n      return;\n    }\n\n    if (!this.willClose.emit()) {\n      return;\n    }\n    this.state = 'closing';\n    this._openPanelEventsController.abort();\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  private _onOptionClick(event: MouseEvent): void {\n    const target = event.target as SbbSelectElement | SbbOptionElement;\n    if (target.localName !== 'sbb-option' || target.disabled) {\n      return;\n    }\n\n    if (!this.multiple) {\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 = options.find((o) => (o.value ?? o.getAttribute('value')) === newValue);\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._displayValue = optionElement?.textContent || null;\n    } else {\n      options\n        .filter((o) => !newValue.includes(o.value ?? o.getAttribute('value')))\n        .forEach((e) => (e.selected = false));\n      const selectedOptionElements = options.filter((o) =>\n        newValue.includes(o.value ?? o.getAttribute('value')),\n      );\n      selectedOptionElements.forEach((o) => (o.selected = true));\n      this._displayValue = selectedOptionElements.map((o) => o.textContent).join(', ') || null;\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 signal = this._abort.signal;\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\n    if (this._didLoad) {\n      this._setupOrigin();\n      this._setupTrigger();\n    }\n    if (this.value) {\n      this._onValueChanged(this.value);\n    }\n\n    this.addEventListener(\n      'optionSelectionChange',\n      (e: CustomEvent<void>) => this._onOptionChanged(e),\n      { signal },\n    );\n    this.addEventListener(\n      'click',\n      (e: MouseEvent) => {\n        this._onOptionClick(e);\n        this._toggleOpening();\n      },\n      { signal },\n    );\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('value')) {\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  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\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._onOpenAnimationEnd();\n    } else if (event.animationName === 'close' && this.state === 'closing') {\n      this._onCloseAnimationEnd();\n    }\n  }\n\n  private _onOpenAnimationEnd(): void {\n    this.state = 'opened';\n    this._attachOpenPanelEvents();\n    this._triggerElement.setAttribute('aria-expanded', 'true');\n\n    this.didOpen.emit();\n  }\n\n  private _onCloseAnimationEnd(): void {\n    this.state = 'closed';\n    this._triggerElement.setAttribute('aria-expanded', 'false');\n    this._resetActiveElement();\n    this._optionContainer.scrollTop = 0;\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    this._didChange.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      this._didChange.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    });\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.disabled || this.readonly) {\n      return;\n    }\n\n    if (this.state === 'opened') {\n      this._openedPanelKeyboardInteraction(event);\n    }\n    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.disabled || 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 'Escape':\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 _setValueFromSelectedOption(): void {\n    if (!this.multiple) {\n      const selectedOption = this._filteredOptions.find((option) => option.selected);\n      if (selectedOption) {\n        this._activeItemIndex = this._filteredOptions.findIndex(\n          (option) => option === selectedOption,\n        );\n        this.value = selectedOption.value;\n      }\n    } else {\n      const options = this._filteredOptions.filter((option) => option.selected);\n      if (options && options.length > 0) {\n        const value: string[] = [];\n        for (const option of options) {\n          value.push(option.value!);\n        }\n        this.value = value;\n      }\n    }\n  }\n\n  private _toggleOpening(): void {\n    if (this.disabled || 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 ? 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\">\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._setValueFromSelectedOption}></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":["ref"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA2BA,MAAM,iBAAiB;AAEvB,IAAI,SAAS;AA0BN,IAAM,mBAAN,cAA+B;AAAA,EACpC,iBAAiB,iBAAiB,kBAAkB,uBAAuB,CAAC,CAAC;AAC/E,EAAE;AAAA,EAFK,cAAA;AAAA,UAAA,GAAA,SAAA;AAwBuC,SAAO,WAAW;AAGlB,SAAO,WAAW;AAGjC,SAAO,WAAW;AAGtC,SAAQ,gBAA+B;AAKhD,SAAQ,aAA2B,IAAI,aAAa,MAAM,iBAAiB,OAAO,SAAS;AAG3F,SAAQ,UAAwB,IAAI,aAAa,MAAM,iBAAiB,OAAO,MAAM;AAGrF,SAAQ,SAAuB,IAAI,aAAa,MAAM,iBAAiB,OAAO,KAAK;AAGnF,SAAQ,eAA2C,IAAI;AAAA,MACrD;AAAA,MACA,iBAAiB,OAAO;AAAA,MACxB;AAAA,QACE,UAAU;AAAA,MACZ;AAAA,IAAA;AAQM,SAAA,aAAa,cAAc,EAAE,MAAM;AAC3C,SAAQ,mBAAmB;AAE3B,SAAQ,gBAAgB;AACxB,SAAQ,WAAW;AACnB,SAAQ,4BAAqC;AACrC,SAAA,SAAS,IAAI,4BAA4B,IAAI;AAigB7C,SAAA,uBAAuB,CAAC,UAA8B;AAC5D,WAAK,4BAA4B,iBAAiB,KAAK,UAAU,KAAK;AAAA,IAAA;AAIhE,SAAA,wBAAwB,CAAC,UAA8B;AACzD,UAAA,CAAC,KAAK,6BAA6B,CAAC,iBAAiB,KAAK,UAAU,KAAK,GAAG;AAC9E,aAAK,MAAM;AAAA,MACb;AAAA,IAAA;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA,EApgBA,IAAW,eAA4B;AACrC,WAAO,KAAK;AAAA,EACd;AAAA;AAAA,EAGA,IAAY,WAA+B;;AACzC,WAAO,MAAM,OAAK,UAAK,qBAAL,8BAAwB,kBAAiB,CAAA,CAAE;AAAA,EAC/D;AAAA,EAEA,IAAY,mBAAuC;AACjD,WAAO,KAAK,SAAS;AAAA,MACnB,CAAC,QAA0B,CAAC,IAAI,YAAY,CAAC,IAAI,aAAa,qBAAqB;AAAA,IAAA;AAAA,EAEvF;AAAA;AAAA,EAGO,OAAa;AACd,QAAA,KAAK,UAAU,YAAY,CAAC,KAAK,YAAY,KAAK,SAAS,WAAW,GAAG;AAC3E;AAAA,IACF;AAEA,QAAI,CAAC,KAAK,SAAS,QAAQ;AACzB;AAAA,IACF;AACA,SAAK,QAAQ;AACb,SAAK,oBAAoB;AAAA,EAC3B;AAAA;AAAA,EAGO,QAAc;AACf,QAAA,KAAK,UAAU,UAAU;AAC3B;AAAA,IACF;AAEA,QAAI,CAAC,KAAK,UAAU,QAAQ;AAC1B;AAAA,IACF;AACA,SAAK,QAAQ;AACb,SAAK,2BAA2B;EAClC;AAAA;AAAA,EAGO,kBAA0B;AAC/B,WAAO,KAAK,iBAAiB;AAAA,EAC/B;AAAA;AAAA,EAGQ,iBAAiB,OAAoB;AAC3C,UAAM,SAAS,MAAM;AACrB,QAAI,OAAO,UAAU;AACnB,WAAK,kBAAkB,MAAM;AAAA,IAAA,OACxB;AACL,WAAK,oBAAoB,MAAM;AAAA,IACjC;AAAA,EACF;AAAA,EAEQ,eAAe,OAAyB;AAC9C,UAAM,SAAS,MAAM;AACrB,QAAI,OAAO,cAAc,gBAAgB,OAAO,UAAU;AACxD;AAAA,IACF;AAEI,QAAA,CAAC,KAAK,UAAU;AAClB,WAAK,MAAM;AAAA,IACb;AAAA,EACF;AAAA;AAAA,EAGQ,gBAAgB,UAAmC;AACzD,UAAM,UAAU,KAAK;AACrB,QAAI,CAAC,MAAM,QAAQ,QAAQ,GAAG;AACtB,YAAA,gBAAgB,QAAQ,KAAK,CAAC,OAAO,EAAE,SAAS,EAAE,aAAa,OAAO,OAAO,QAAQ;AAC3F,UAAI,eAAe;AACjB,sBAAc,WAAW;AAAA,MAC3B;AACA,cACG,OAAO,CAAC,OAAO,EAAE,SAAS,EAAE,aAAa,OAAO,OAAO,QAAQ,EAC/D,QAAQ,CAAC,MAAO,EAAE,WAAW,KAAM;AACjC,WAAA,iBAAgB,+CAAe,gBAAe;AAAA,IAAA,OAC9C;AACL,cACG,OAAO,CAAC,MAAM,CAAC,SAAS,SAAS,EAAE,SAAS,EAAE,aAAa,OAAO,CAAC,CAAC,EACpE,QAAQ,CAAC,MAAO,EAAE,WAAW,KAAM;AACtC,YAAM,yBAAyB,QAAQ;AAAA,QAAO,CAAC,MAC7C,SAAS,SAAS,EAAE,SAAS,EAAE,aAAa,OAAO,CAAC;AAAA,MAAA;AAEtD,6BAAuB,QAAQ,CAAC,MAAO,EAAE,WAAW,IAAK;AACpD,WAAA,gBAAgB,uBAAuB,IAAI,CAAC,MAAM,EAAE,WAAW,EAAE,KAAK,IAAI,KAAK;AAAA,IACtF;AACA,SAAK,aAAa,KAAK,EAAE,MAAM,SAAS,OAAO,UAAU;AAAA,EAC3D;AAAA,EAEmB,aAAa,mBAA+C;AAC7E,UAAM,aAAa,iBAAiB;AAGpC,SAAK,QAAQ,MAAM,KAAK,gBAAgB,MAAM;AAC9C,SAAK,OAAO,MAAM,KAAK,gBAAgB,KAAK;AAGxC,QAAA,CAAC,YAAY;AACf,WAAK,YAAY;AACjB,WAAK,aAAa;AAAA,IACpB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQgB,gBAAgB,eAA6B;AAO3D,QAAI,SAAc,KAAA,kBAAkB,qBAAqB,CAAC,KAAK,UAAU;AACvE,WAAK,eAAe,KAAK,MAAM,KAAK,aAAc,CAAA;AAAA,IACpD;AACA,UAAM,gBAAgB,aAAa;AAAA,EACrC;AAAA,EAEgB,oBAA0B;;AACxC,UAAM,kBAAkB;AAExB,QAAI,gBAAgB;AAClB,WAAK,OAAL,KAAK,KAAO,KAAK;AAAA,IACnB;AAEM,UAAA,SAAS,KAAK,OAAO;AAC3B,UAAM,cAAY,UAAK,YAAL,8BAAe,wBAAqB,UAAK,YAAL,8BAAe;AAErE,QAAI,WAAW;AACR,WAAA,WAAW,UAAU,aAAa,UAAU;AAAA,IACnD;AACA,SAAK,gBAAgB;AAErB,QAAI,KAAK,UAAU;AACjB,WAAK,aAAa;AAClB,WAAK,cAAc;AAAA,IACrB;AACA,QAAI,KAAK,OAAO;AACT,WAAA,gBAAgB,KAAK,KAAK;AAAA,IACjC;AAEK,SAAA;AAAA,MACH;AAAA,MACA,CAAC,MAAyB,KAAK,iBAAiB,CAAC;AAAA,MACjD,EAAE,OAAO;AAAA,IAAA;AAEN,SAAA;AAAA,MACH;AAAA,MACA,CAAC,MAAkB;AACjB,aAAK,eAAe,CAAC;AACrB,aAAK,eAAe;AAAA,MACtB;AAAA,MACA,EAAE,OAAO;AAAA,IAAA;AAAA,EAEb;AAAA,EAEmB,WAAW,mBAA+C;AAC3E,UAAM,WAAW,iBAAiB;AAE9B,QAAA,kBAAkB,IAAI,OAAO,GAAG;AAC7B,WAAA,gBAAgB,KAAK,KAAM;AAAA,IAClC;AACA,QAAI,kBAAkB,IAAI,UAAU,KAAK,kBAAkB,IAAI,UAAU,GAAG;AAC1E,WAAK,gBAAgB;AAAA,IACvB;AAAA,EACF;AAAA,EAEgB,uBAA6B;;AAC3C,UAAM,qBAAqB;AACtB,SAAA,QAAQ,KAAK,eAAe;AACjC,eAAK,+BAAL,mBAAiC;AAAA,EACnC;AAAA,EAEQ,kBAAwB;;AACzB,eAAA,qBAAA,8BAAmB,eAAe,QAAQ,CAAC,YAAa,QAAQ,WAAW,KAAK;AAEhF,eAAA,qBAAA;AAAA;AAAA,MACH;AAAA,MACA,QAAQ,CAAC,YAAmD;AACpD,cAAA,gBAAgB,iBAAiB,KAAK,QAAQ;AAC9C,cAAA,gBAAgB,iBAAiB,KAAK,QAAQ;AAAA,IAAA;AAAA,EAE1D;AAAA,EAEQ,eAAqB;AAC3B,SAAK,aAAa;AAClB,SAAK,cAAc;AACnB,SAAK,WAAW;AAChB,SAAK,eAAe;AAAA,EACtB;AAAA;AAAA,EAGQ,eAAqB;;AACrB,UAAA,aAAY,UAAK,YAAL,8BAAe;AACjC,SAAK,mBACH,kDAAW,eAAX,mBAAuB,kBAAvB,4BAAuC,uBAAsB,KAAK;AACpE,QAAI,KAAK,gBAAgB;AAClB,WAAA;AAAA,QACH;AAAA,QACA,CAAC,GAAC,4CAAW,iBAAX,mCAA0B;AAAA,MAAY;AAAA,IAE5C;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA,EAMQ,gBAAsB;;AAE5B,qBAAK,eAAe,iBAApB,4BAAmC,KAAK,iBAAiB;AAGzD,UAAM,qBAAmB,UAAK,YAAL,8BAAe,sBAAqB;AACxD,SAAA,gBAAgB,MAAM,MAAM;AACjC,SAAK,gBAAgB,MAAM,SAAS,GAAG,iBAAiB,YAAY;AACpE,SAAK,gBAAgB,MAAM,QAAQ,GAAG,iBAAiB,WAAW;AAAA,EACpE;AAAA,EAEQ,sBAA4B;AAClC;AAAA,MACE,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK,WAAY,cAAc,wBAAwB;AAAA,MACvD;AAAA,IAAA;AAAA,EAEJ;AAAA;AAAA;AAAA,EAIQ,gBAAgB,OAA6B;AACnD,QAAI,MAAM,kBAAkB,UAAU,KAAK,UAAU,WAAW;AAC9D,WAAK,oBAAoB;AAAA,IAAA,WAChB,MAAM,kBAAkB,WAAW,KAAK,UAAU,WAAW;AACtE,WAAK,qBAAqB;AAAA,IAC5B;AAAA,EACF;AAAA,EAEQ,sBAA4B;AAClC,SAAK,QAAQ;AACb,SAAK,uBAAuB;AACvB,SAAA,gBAAgB,aAAa,iBAAiB,MAAM;AAEzD,SAAK,QAAQ;EACf;AAAA,EAEQ,uBAA6B;AACnC,SAAK,QAAQ;AACR,SAAA,gBAAgB,aAAa,iBAAiB,OAAO;AAC1D,SAAK,oBAAoB;AACzB,SAAK,iBAAiB,YAAY;AAClC,SAAK,SAAS;EAChB;AAAA;AAAA,EAGQ,kBAAkB,uBAA+C;AACnE,QAAA,CAAC,KAAK,UAAU;AAClB,WAAK,iBACF,OAAO,CAAC,WAAW,OAAO,OAAO,sBAAsB,EAAE,EACzD,QAAQ,CAAC,WAAY,OAAO,WAAW,KAAM;AAChD,WAAK,QAAQ,sBAAsB;AAAA,IAAA,OAC9B;AACD,UAAA,CAAC,KAAK,OAAO;AACV,aAAA,QAAQ,CAAC,sBAAsB,KAAM;AAAA,MAAA,WACjC,CAAC,KAAK,MAAM,SAAS,sBAAsB,KAAM,GAAG;AAC7D,aAAK,QAAQ,CAAC,GAAG,KAAK,OAAO,sBAAsB,KAAM;AAAA,MAC3D;AAAA,IACF;AAEA,SAAK,OAAO;AACZ,SAAK,QAAQ;AACb,SAAK,WAAW;EAClB;AAAA;AAAA,EAGQ,oBAAoB,uBAA+C;AACzE,QAAI,KAAK,UAAU;AACZ,WAAA,QAAS,KAAK,MAAmB;AAAA,QACpC,CAAC,OAAe,OAAO,sBAAsB;AAAA,MAAA;AAG/C,WAAK,OAAO;AACZ,WAAK,QAAQ;AACb,WAAK,WAAW;IAClB;AAAA,EACF;AAAA,EAEQ,yBAA+B;AAChC,SAAA,6BAA6B,IAAI;AAGtC,aAAS,iBAAiB,UAAU,MAAM,KAAK,uBAAuB;AAAA,MACpE,SAAS;AAAA,MACT,QAAQ,KAAK,2BAA2B;AAAA,IAAA,CACzC;AACD,WAAO,iBAAiB,UAAU,MAAM,KAAK,uBAAuB;AAAA,MAClE,SAAS;AAAA,MACT,QAAQ,KAAK,2BAA2B;AAAA,IAAA,CACzC;AAGD,WAAO,iBAAiB,eAAe,CAAC,OAAO,KAAK,qBAAqB,EAAE,GAAG;AAAA,MAC5E,QAAQ,KAAK,2BAA2B;AAAA,IAAA,CACzC;AACD,WAAO,iBAAiB,aAAa,CAAC,OAAO,KAAK,sBAAsB,EAAE,GAAG;AAAA,MAC3E,QAAQ,KAAK,2BAA2B;AAAA,IAAA,CACzC;AAAA,EACH;AAAA,EAEQ,WAAW,OAA4B;AACzC,QAAA,KAAK,YAAY,KAAK,UAAU;AAClC;AAAA,IACF;AAEI,QAAA,KAAK,UAAU,UAAU;AAC3B,WAAK,gCAAgC,KAAK;AAAA,IAC5C;AACI,QAAA,KAAK,UAAU,UAAU;AAC3B,WAAK,gCAAgC,KAAK;AAAA,IAC5C;AAAA,EACF;AAAA,EAEQ,gCAAgC,OAA4B;AAC9D,QAAA,KAAK,yBAAyB,KAAK,GAAG;AACjC,aAAA,KAAK,2BAA2B,KAAK;AAAA,IAC9C;AAEA,YAAQ,MAAM,KAAK;AAAA,MACjB,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AACH,cAAM,eAAe;AACrB,aAAK,KAAK;AACV;AAAA,IACJ;AAAA,EACF;AAAA,EAEQ,gCAAgC,OAA4B;AAClE,QAAI,KAAK,YAAY,KAAK,YAAY,KAAK,UAAU,UAAU;AAC7D;AAAA,IACF;AAEI,QAAA,KAAK,yBAAyB,KAAK,GAAG;AACjC,aAAA,KAAK,2BAA2B,KAAK;AAAA,IAC9C;AAEA,YAAQ,MAAM,KAAK;AAAA,MACjB,KAAK;AAAA,MACL,KAAK;AACH,aAAK,MAAM;AACX;AAAA,MAEF,KAAK;AAAA,MACL,KAAK;AACH,cAAM,eAAe;AACrB,aAAK,kBAAkB;AACvB;AAAA,MAEF,KAAK;AAAA,MACL,KAAK;AACH,cAAM,eAAe;AACrB,aAAK,qBAAqB,KAAK;AAC/B;AAAA,MAEF,KAAK;AAAA,MACL,KAAK;AACH,cAAM,eAAe;AAChB,aAAA,qBAAqB,OAAO,CAAC;AAClC;AAAA,MAEF,KAAK;AAAA,MACL,KAAK;AACH,cAAM,eAAe;AACrB,aAAK,qBAAqB,OAAO,KAAK,iBAAiB,SAAS,CAAC;AACjE;AAAA,IACJ;AAAA,EACF;AAAA,EAEQ,yBAAyB,OAA+B;AAE5D,WAAA,MAAM,QAAQ,eACd,MAAM,QAAQ,WACb,MAAM,IAAI,WAAW,KACpB,MAAM,QAAQ,OACd,CAAC,MAAM,UACP,CAAC,MAAM,WACP,CAAC,MAAM;AAAA,EAEb;AAAA,EAEQ,2BAA2B,OAA4B;AAE7D,QAAI,OAAO,KAAK,mBAAmB,OAAO,YAAY;AACpD,mBAAa,KAAK,cAAc;AAAA,IAClC;AACA,SAAK,iBAAiB,WAAW,MAAO,KAAK,gBAAgB,IAAK,GAAI;AACtE,SAAK,iBAAiB,MAAM;AAGtB,UAAA,gBAAwB,KAAK,mBAAmB;AACtD,UAAM,wBAA4C;AAAA,MAChD,GAAG,KAAK,iBAAiB,MAAM,aAAa;AAAA,MAC5C,GAAG,KAAK,iBAAiB,MAAM,GAAG,aAAa;AAAA,IAAA;AAGjD,UAAM,QAAQ,sBAAsB;AAAA,MAClC,CAAC,WACC;;AAAA,6BAAO,gBAAP,mBAAoB,cAAc,QAAQ,KAAK,cAAc,YAAa,QAAM;AAAA;AAAA,IAAA;AAEpF,QAAI,OAAO;AAET,WAAK,qBAAqB,OAAO,KAAK,iBAAiB,QAAQ,KAAK,CAAC;AAAA,IAAA,WAErE,KAAK,cAAc,SAAS,KAC5B,IAAI,OAAO,IAAI,KAAK,cAAc,OAAO,CAAC,CAAC,IAAI,EAAE,KAAK,KAAK,aAAa,GACxE;AAGA,YAAM,aAAa,sBAAsB;AAAA,QACvC,CAAC,WACC;;AAAA,+BAAO,gBAAP,mBAAoB,cAAc,QAAQ,KAAK,cAAc,CAAC,EAAE,YAAA,QAAmB;AAAA;AAAA,MAAA;AAEvF,UAAI,YAAY;AACd,aAAK,qBAAqB,OAAO,KAAK,iBAAiB,QAAQ,UAAU,CAAC;AAAA,MAC5E;AAAA,IAAA,OACK;AAEL,mBAAa,KAAK,cAAc;AAChC,WAAK,gBAAgB;AAAA,IACvB;AAAA,EACF;AAAA,EAEQ,oBAA0B;AAChC,UAAM,eAAiC,KAAK,iBAAiB,KAAK,gBAAgB;AAElF,QAAI,KAAK,UAAU;AACJ,mBAAA,8BAA8B,CAAC,aAAa,QAAQ;AAAA,IAAA,OAC5D;AACL,WAAK,MAAM;AAAA,IACb;AAAA,EACF;AAAA,EAEQ,qBAAqB,OAAsB,OAAsB;AACjE,UAAA,YACJ,SAAS,oBAAoB,OAAO,KAAK,kBAAkB,KAAK,iBAAiB,MAAM;AACnF,UAAA,aAAa,KAAK,iBAAiB,SAAS;AAClD,UAAM,eAAe,KAAK,iBAAiB,KAAK,gBAAgB;AAE3D,SAAA,kBAAkB,YAAY,YAAY;AAE3C,QAAA,CAAC,KAAK,UAAU;AACb,WAAA,oBAAoB,YAAY,YAAY;AAAA,IAAA,WACxC,+BAAO,UAAU;AACf,iBAAA,8BAA8B,CAAC,WAAW,QAAQ;AAAA,IAC/D;AACA,SAAK,mBAAmB;AAAA,EAC1B;AAAA,EAEQ,kBACN,kBACA,mBAA4C,MAC5C,sBAAsB,MAChB;AACN,qBAAiB,UAAU,IAAI;AAC/B,qBAAiB,eAAe,EAAE,OAAO,UAAW,CAAA;AAEpD,QAAI,qBAAqB;AACvB,WAAK,gBAAgB,aAAa,yBAAyB,iBAAiB,EAAE;AAAA,IAChF;AAGI,QAAA,oBAAoB,qBAAqB,kBAAkB;AAC7D,uBAAiB,UAAU,KAAK;AAAA,IAClC;AAAA,EACF;AAAA,EAEQ,oBACN,kBACA,kBACM;AACN,qBAAiB,8BAA8B,IAAI;AAE/C,QAAA,oBAAoB,qBAAqB,kBAAkB;AAC7D,uBAAiB,8BAA8B,KAAK;AAAA,IACtD;AAAA,EACF;AAAA,EAEQ,sBAA4B;AAClC,UAAM,gBAAgB,KAAK,iBAAiB,KAAK,gBAAgB;AAEjE,QAAI,eAAe;AACjB,oBAAc,UAAU,KAAK;AAAA,IAC/B;AACA,SAAK,mBAAmB;AACnB,SAAA,gBAAgB,gBAAgB,uBAAuB;AAAA,EAC9D;AAAA,EAcQ,8BAAoC;AACtC,QAAA,CAAC,KAAK,UAAU;AAClB,YAAM,iBAAiB,KAAK,iBAAiB,KAAK,CAAC,WAAW,OAAO,QAAQ;AAC7E,UAAI,gBAAgB;AACb,aAAA,mBAAmB,KAAK,iBAAiB;AAAA,UAC5C,CAAC,WAAW,WAAW;AAAA,QAAA;AAEzB,aAAK,QAAQ,eAAe;AAAA,MAC9B;AAAA,IAAA,OACK;AACL,YAAM,UAAU,KAAK,iBAAiB,OAAO,CAAC,WAAW,OAAO,QAAQ;AACpE,UAAA,WAAW,QAAQ,SAAS,GAAG;AACjC,cAAM,QAAkB,CAAA;AACxB,mBAAW,UAAU,SAAS;AACtB,gBAAA,KAAK,OAAO,KAAM;AAAA,QAC1B;AACA,aAAK,QAAQ;AAAA,MACf;AAAA,IACF;AAAA,EACF;AAAA,EAEQ,iBAAuB;;AACzB,QAAA,KAAK,YAAY,KAAK,UAAU;AAClC;AAAA,IACF;AACA,eAAK,oBAAL,mBAAsB;AAEtB,YAAQ,KAAK,OAAO;AAAA,MAClB,KAAK,UAAU;AACb,aAAK,MAAM;AACX;AAAA,MACF;AAAA,MACA,KAAK,UAAU;AACb,aAAK,KAAK;AACV;AAAA,MACF;AAAA,IAGF;AAAA,EACF;AAAA,EAEQ,4BACN,aAC8C;AAC9C,WAAO,CAAC,KAAK,sBAAsB,WAAW,GAAG,WAAW;AAAA,EAC9D;AAAA,EAEA,MAAc,sBAAsB,aAAsD;AACxF,QAAI,KAAK,mBAAmB;AAC1B,YAAM,KAAK;AAAA,IACb;AACA,WAAO,KAAK,gBAAgB,OAAO,KAAK,aAAa,KAAK;AAAA,EAC5D;AAAA,EAEmB,SAAyB;AACnC,WAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAKQ,KAAK,WAAW,UAAU,GAAG;AAAA;AAAA;AAAA;AAAA,wBAIxB,KAAK,SAAS,UAAU;AAAA,wBACxB,KAAK,UAAU;AAAA,oBACnB,KAAK,UAAU;AAAA,mBAChB,KAAK,UAAU;AAAA,iBACjB,KAAK,cAAc;AAAA,UAC1B,IAAI,CAACA,SAAS,KAAK,kBAAkBA,IAAmB,CAAC;AAAA;AAAA,UAEzD,MAAM,GAAG,KAAK,4BAA4B,aAAa,KAAK,WAAW,SAAS,CAAC,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,UAKlF;AAAA,MACA,GAAG,KAAK;AAAA,QACN,sDAAsD,KAAK,WAAW;AAAA,MACxE;AAAA,IAAA,CACD;AAAA;AAAA;AAAA;AAAA;AAAA,2CAKkC,sBAAsB;AAAA;AAAA,0BAEvC,KAAK,eAAe;AAAA;AAAA,YAElC,IAAI,CAAC,cAAe,KAAK,WAAW,SAAyB,CAAC;AAAA;AAAA;AAAA;AAAA,mBAIvD,CAAC,iBAAiB,KAAK,aAAa,OAAO;AAAA;AAAA,qBAEzC,CAAC,iBAAiB,YAAY,OAAO;AAAA,sCACpB,KAAK,QAAQ;AAAA,gBACnC,IAAI,CAAC,iBAAkB,KAAK,mBAAmB,YAA4B,CAAC;AAAA;AAAA,kCAE1D,KAAK,2BAA2B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAMhE;AACF;AAxrBa,iBAGY,SAAyB;AAHrC,iBAMqB,SAAS;AAAA,EACvC,WAAW;AAAA,EACX,QAAQ;AAAA,EACR,OAAO;AAAA,EACP,aAAa;AAAA,EACb,UAAU;AAAA,EACV,SAAS;AAAA,EACT,WAAW;AAAA,EACX,UAAU;AACZ;AAGmB,gBAAA;AAAA,EAAlB,SAAS;AAAA,GAlBC,iBAkBQ,WAAA,SAAA,CAAA;AAGA,gBAAA;AAAA,EAAlB,SAAS;AAAA,GArBC,iBAqBQ,WAAA,eAAA,CAAA;AAGgC,gBAAA;AAAA,EAAlD,SAAS,EAAE,MAAM,SAAS,SAAS,MAAM;AAAA,GAxB/B,iBAwBwC,WAAA,YAAA,CAAA;AAGA,gBAAA;AAAA,EAAlD,SAAS,EAAE,SAAS,MAAM,MAAM,SAAS;AAAA,GA3B/B,iBA2BwC,WAAA,YAAA,CAAA;AAGf,gBAAA;AAAA,EAAnC,SAAS,EAAE,MAAM,SAAS;AAAA,GA9BhB,iBA8ByB,WAAA,YAAA,CAAA;AAGnB,gBAAA;AAAA,EAAhB,MAAM;AAAA,GAjCI,iBAiCM,WAAA,iBAAA,CAAA;AAjCN,mBAAN,gBAAA;AAAA,EAJN,cAAc,YAAY;AAAA,EAC1B,eAAe;AAAA,IACd,MAAM,iBAAiB,YAAY;AAAA,EAAA,CACpC;AAAA,GACY,gBAAA;"}
|
|
919
|
+
//# 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, PropertyValues, TemplateResult } from 'lit';\nimport { html, 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 { SbbConnectedAbortController } from '../core/controllers.js';\nimport { hostAttributes } from '../core/decorators.js';\nimport { isNextjs, isSafari } from '../core/dom.js';\nimport { EventEmitter } from '../core/eventing.js';\nimport {\n  SbbDisabledMixin,\n  SbbHydrationMixin,\n  SbbNegativeMixin,\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>} didChange - Deprecated. used for React. Will probably be removed once React 19 is available.\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 */\n@customElement('sbb-select')\n@hostAttributes({\n  role: ariaRoleOnHost ? 'listbox' : null,\n})\nexport class SbbSelectElement extends SbbUpdateSchedulerMixin(\n  SbbDisabledMixin(SbbNegativeMixin(SbbHydrationMixin(SbbOpenCloseBaseElement))),\n) {\n  public static override styles: CSSResultGroup = style;\n\n  // FIXME using ...super.events requires: https://github.com/sbb-design-systems/lyne-components/issues/2600\n  public static override readonly events = {\n    didChange: 'didChange',\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 value of the select component. If `multiple` is true, it's an array. */\n  @property() public value?: string | string[];\n\n  /** The placeholder used if no value has been selected. */\n  @property() public placeholder?: string;\n\n  /** Whether the select allows for multiple selection. */\n  @property({ type: Boolean, reflect: true }) public multiple = false;\n\n  /** Whether the select is required. */\n  @property({ reflect: true, type: Boolean }) public required = false;\n\n  /** Whether the select is readonly. */\n  @property({ type: Boolean }) public readonly = false;\n\n  /** The value displayed by the component. */\n  @state() private _displayValue: string | null = null;\n\n  /**\n   * @deprecated only used for React. Will probably be removed once React 19 is available.\n   */\n  private _didChange: EventEmitter = new EventEmitter(this, SbbSelectElement.events.didChange);\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 _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 _abort = new SbbConnectedAbortController(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\n    new MutationController(this, {\n      config: { attributeFilter: ['aria-labelledby'] },\n      callback: (mutationsList: MutationRecord[]) => this._onSelectAttributesChange(mutationsList),\n    });\n  }\n\n  /**\n   * TODO: Accessibility fix required to correctly read the label;\n   * can be possibly removed after the merge of https://github.com/sbb-design-systems/lyne-components/issues/3062\n   */\n  private _onSelectAttributesChange(mutationsList: MutationRecord[]): void {\n    for (const mutation of mutationsList) {\n      if (mutation.attributeName === 'aria-labelledby') {\n        this._triggerElement?.setAttribute(\n          'aria-labelledby',\n          this.getAttribute('aria-labelledby')!,\n        );\n      }\n    }\n  }\n\n  /** Opens the selection panel. */\n  public open(): void {\n    if (this.state !== 'closed' || !this._overlay || this._options.length === 0) {\n      return;\n    }\n\n    if (!this.willOpen.emit()) {\n      return;\n    }\n    this.state = 'opening';\n    this._setOverlayPosition();\n  }\n\n  /** Closes the selection panel. */\n  public close(): void {\n    if (this.state !== 'opened') {\n      return;\n    }\n\n    if (!this.willClose.emit()) {\n      return;\n    }\n    this.state = 'closing';\n    this._openPanelEventsController.abort();\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  private _onOptionClick(event: MouseEvent): void {\n    const target = event.target as SbbSelectElement | SbbOptionElement;\n    if (target.localName !== 'sbb-option' || target.disabled) {\n      return;\n    }\n\n    if (!this.multiple) {\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 = options.find((o) => (o.value ?? o.getAttribute('value')) === newValue);\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._displayValue = optionElement?.textContent || null;\n    } else {\n      options\n        .filter((o) => !newValue.includes(o.value ?? o.getAttribute('value')))\n        .forEach((e) => (e.selected = false));\n      const selectedOptionElements = options.filter((o) =>\n        newValue.includes(o.value ?? o.getAttribute('value')),\n      );\n      selectedOptionElements.forEach((o) => (o.selected = true));\n      this._displayValue = selectedOptionElements.map((o) => o.textContent).join(', ') || null;\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 signal = this._abort.signal;\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\n    if (this._didLoad) {\n      this._setupOrigin();\n      this._setupTrigger();\n    }\n    if (this.value) {\n      this._onValueChanged(this.value);\n    }\n\n    this.addEventListener(\n      'optionSelectionChange',\n      (e: CustomEvent<void>) => this._onOptionChanged(e),\n      { signal },\n    );\n    this.addEventListener(\n      'click',\n      (e: MouseEvent) => {\n        this._onOptionClick(e);\n        this._toggleOpening();\n      },\n      { signal },\n    );\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('value')) {\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  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\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._onOpenAnimationEnd();\n    } else if (event.animationName === 'close' && this.state === 'closing') {\n      this._onCloseAnimationEnd();\n    }\n  }\n\n  private _onOpenAnimationEnd(): void {\n    this.state = 'opened';\n    this._attachOpenPanelEvents();\n    this._triggerElement.setAttribute('aria-expanded', 'true');\n\n    this.didOpen.emit();\n  }\n\n  private _onCloseAnimationEnd(): void {\n    this.state = 'closed';\n    this._triggerElement.setAttribute('aria-expanded', 'false');\n    this._resetActiveElement();\n    this._optionContainer.scrollTop = 0;\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    this._didChange.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      this._didChange.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    });\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.disabled || this.readonly) {\n      return;\n    }\n\n    if (this.state === 'opened') {\n      this._openedPanelKeyboardInteraction(event);\n    }\n    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.disabled || 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 'Escape':\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 _setValueFromSelectedOption(): void {\n    if (!this.multiple) {\n      const selectedOption = this._filteredOptions.find((option) => option.selected);\n      if (selectedOption) {\n        this._activeItemIndex = this._filteredOptions.findIndex(\n          (option) => option === selectedOption,\n        );\n        this.value = selectedOption.value;\n      }\n    } else {\n      const options = this._filteredOptions.filter((option) => option.selected);\n      if (options && options.length > 0) {\n        const value: string[] = [];\n        for (const option of options) {\n          value.push(option.value!);\n        }\n        this.value = value;\n      }\n    }\n  }\n\n  private _toggleOpening(): void {\n    if (this.disabled || 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 ? 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\">\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._setValueFromSelectedOption}></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":["ref"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA4BA,MAAM,iBAAiB;AAEvB,IAAI,SAAS;AA0BN,IAAM,mBAAN,cAA+B;AAAA,EACpC,iBAAiB,iBAAiB,kBAAkB,uBAAuB,CAAC,CAAC;AAC/E,EAAE;AAAA,EAqFO,cAAc;AACb;AAhEoC,SAAO,WAAW;AAGlB,SAAO,WAAW;AAGjC,SAAO,WAAW;AAGtC,SAAQ,gBAA+B;AAKhD,SAAQ,aAA2B,IAAI,aAAa,MAAM,iBAAiB,OAAO,SAAS;AAG3F,SAAQ,UAAwB,IAAI,aAAa,MAAM,iBAAiB,OAAO,MAAM;AAGrF,SAAQ,SAAuB,IAAI,aAAa,MAAM,iBAAiB,OAAO,KAAK;AAGnF,SAAQ,eAA2C,IAAI;AAAA,MACrD;AAAA,MACA,iBAAiB,OAAO;AAAA,MACxB;AAAA,QACE,UAAU;AAAA,MACZ;AAAA,IAAA;AAQM,SAAA,aAAa,cAAc,EAAE,MAAM;AAC3C,SAAQ,mBAAmB;AAE3B,SAAQ,gBAAgB;AACxB,SAAQ,WAAW;AACnB,SAAQ,4BAAqC;AACrC,SAAA,SAAS,IAAI,4BAA4B,IAAI;AAyhB7C,SAAA,uBAAuB,CAAC,UAA8B;AAC5D,WAAK,4BAA4B,iBAAiB,KAAK,UAAU,KAAK;AAAA,IAAA;AAIhE,SAAA,wBAAwB,CAAC,UAA8B;AACzD,UAAA,CAAC,KAAK,6BAA6B,CAAC,iBAAiB,KAAK,UAAU,KAAK,GAAG;AAC9E,aAAK,MAAM;AAAA,MACb;AAAA,IAAA;AAzgBA,QAAI,mBAAmB,MAAM;AAAA,MAC3B,QAAQ,EAAE,iBAAiB,CAAC,iBAAiB,EAAE;AAAA,MAC/C,UAAU,CAAC,kBAAoC,KAAK,0BAA0B,aAAa;AAAA,IAAA,CAC5F;AAAA,EACH;AAAA;AAAA;AAAA;AAAA;AAAA,EAtBA,IAAW,eAA4B;AACrC,WAAO,KAAK;AAAA,EACd;AAAA;AAAA,EAGA,IAAY,WAA+B;;AACzC,WAAO,MAAM,OAAK,UAAK,qBAAL,8BAAwB,kBAAiB,CAAA,CAAE;AAAA,EAC/D;AAAA,EAEA,IAAY,mBAAuC;AACjD,WAAO,KAAK,SAAS;AAAA,MACnB,CAAC,QAA0B,CAAC,IAAI,YAAY,CAAC,IAAI,aAAa,qBAAqB;AAAA,IAAA;AAAA,EAEvF;AAAA;AAAA;AAAA;AAAA;AAAA,EAeQ,0BAA0B,eAAuC;;AACvE,eAAW,YAAY,eAAe;AAChC,UAAA,SAAS,kBAAkB,mBAAmB;AAChD,mBAAK,oBAAL,mBAAsB;AAAA,UACpB;AAAA,UACA,KAAK,aAAa,iBAAiB;AAAA;AAAA,MAEvC;AAAA,IACF;AAAA,EACF;AAAA;AAAA,EAGO,OAAa;AACd,QAAA,KAAK,UAAU,YAAY,CAAC,KAAK,YAAY,KAAK,SAAS,WAAW,GAAG;AAC3E;AAAA,IACF;AAEA,QAAI,CAAC,KAAK,SAAS,QAAQ;AACzB;AAAA,IACF;AACA,SAAK,QAAQ;AACb,SAAK,oBAAoB;AAAA,EAC3B;AAAA;AAAA,EAGO,QAAc;AACf,QAAA,KAAK,UAAU,UAAU;AAC3B;AAAA,IACF;AAEA,QAAI,CAAC,KAAK,UAAU,QAAQ;AAC1B;AAAA,IACF;AACA,SAAK,QAAQ;AACb,SAAK,2BAA2B;EAClC;AAAA;AAAA,EAGO,kBAA0B;AAC/B,WAAO,KAAK,iBAAiB;AAAA,EAC/B;AAAA;AAAA,EAGQ,iBAAiB,OAAoB;AAC3C,UAAM,SAAS,MAAM;AACrB,QAAI,OAAO,UAAU;AACnB,WAAK,kBAAkB,MAAM;AAAA,IAAA,OACxB;AACL,WAAK,oBAAoB,MAAM;AAAA,IACjC;AAAA,EACF;AAAA,EAEQ,eAAe,OAAyB;AAC9C,UAAM,SAAS,MAAM;AACrB,QAAI,OAAO,cAAc,gBAAgB,OAAO,UAAU;AACxD;AAAA,IACF;AAEI,QAAA,CAAC,KAAK,UAAU;AAClB,WAAK,MAAM;AAAA,IACb;AAAA,EACF;AAAA;AAAA,EAGQ,gBAAgB,UAAmC;AACzD,UAAM,UAAU,KAAK;AACrB,QAAI,CAAC,MAAM,QAAQ,QAAQ,GAAG;AACtB,YAAA,gBAAgB,QAAQ,KAAK,CAAC,OAAO,EAAE,SAAS,EAAE,aAAa,OAAO,OAAO,QAAQ;AAC3F,UAAI,eAAe;AACjB,sBAAc,WAAW;AAAA,MAC3B;AACA,cACG,OAAO,CAAC,OAAO,EAAE,SAAS,EAAE,aAAa,OAAO,OAAO,QAAQ,EAC/D,QAAQ,CAAC,MAAO,EAAE,WAAW,KAAM;AACjC,WAAA,iBAAgB,+CAAe,gBAAe;AAAA,IAAA,OAC9C;AACL,cACG,OAAO,CAAC,MAAM,CAAC,SAAS,SAAS,EAAE,SAAS,EAAE,aAAa,OAAO,CAAC,CAAC,EACpE,QAAQ,CAAC,MAAO,EAAE,WAAW,KAAM;AACtC,YAAM,yBAAyB,QAAQ;AAAA,QAAO,CAAC,MAC7C,SAAS,SAAS,EAAE,SAAS,EAAE,aAAa,OAAO,CAAC;AAAA,MAAA;AAEtD,6BAAuB,QAAQ,CAAC,MAAO,EAAE,WAAW,IAAK;AACpD,WAAA,gBAAgB,uBAAuB,IAAI,CAAC,MAAM,EAAE,WAAW,EAAE,KAAK,IAAI,KAAK;AAAA,IACtF;AACA,SAAK,aAAa,KAAK,EAAE,MAAM,SAAS,OAAO,UAAU;AAAA,EAC3D;AAAA,EAEmB,aAAa,mBAA+C;AAC7E,UAAM,aAAa,iBAAiB;AAGpC,SAAK,QAAQ,MAAM,KAAK,gBAAgB,MAAM;AAC9C,SAAK,OAAO,MAAM,KAAK,gBAAgB,KAAK;AAGxC,QAAA,CAAC,YAAY;AACf,WAAK,YAAY;AACjB,WAAK,aAAa;AAAA,IACpB;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQgB,gBAAgB,eAA6B;AAO3D,QAAI,SAAc,KAAA,kBAAkB,qBAAqB,CAAC,KAAK,UAAU;AACvE,WAAK,eAAe,KAAK,MAAM,KAAK,aAAc,CAAA;AAAA,IACpD;AACA,UAAM,gBAAgB,aAAa;AAAA,EACrC;AAAA,EAEgB,oBAA0B;;AACxC,UAAM,kBAAkB;AAExB,QAAI,gBAAgB;AAClB,WAAK,OAAL,KAAK,KAAO,KAAK;AAAA,IACnB;AAEM,UAAA,SAAS,KAAK,OAAO;AAC3B,UAAM,cAAY,UAAK,YAAL,8BAAe,wBAAqB,UAAK,YAAL,8BAAe;AAErE,QAAI,WAAW;AACR,WAAA,WAAW,UAAU,aAAa,UAAU;AAAA,IACnD;AACA,SAAK,gBAAgB;AAErB,QAAI,KAAK,UAAU;AACjB,WAAK,aAAa;AAClB,WAAK,cAAc;AAAA,IACrB;AACA,QAAI,KAAK,OAAO;AACT,WAAA,gBAAgB,KAAK,KAAK;AAAA,IACjC;AAEK,SAAA;AAAA,MACH;AAAA,MACA,CAAC,MAAyB,KAAK,iBAAiB,CAAC;AAAA,MACjD,EAAE,OAAO;AAAA,IAAA;AAEN,SAAA;AAAA,MACH;AAAA,MACA,CAAC,MAAkB;AACjB,aAAK,eAAe,CAAC;AACrB,aAAK,eAAe;AAAA,MACtB;AAAA,MACA,EAAE,OAAO;AAAA,IAAA;AAAA,EAEb;AAAA,EAEmB,WAAW,mBAA+C;AAC3E,UAAM,WAAW,iBAAiB;AAE9B,QAAA,kBAAkB,IAAI,OAAO,GAAG;AAC7B,WAAA,gBAAgB,KAAK,KAAM;AAAA,IAClC;AACA,QAAI,kBAAkB,IAAI,UAAU,KAAK,kBAAkB,IAAI,UAAU,GAAG;AAC1E,WAAK,gBAAgB;AAAA,IACvB;AAAA,EACF;AAAA,EAEgB,uBAA6B;;AAC3C,UAAM,qBAAqB;AACtB,SAAA,QAAQ,KAAK,eAAe;AACjC,eAAK,+BAAL,mBAAiC;AAAA,EACnC;AAAA,EAEQ,kBAAwB;;AACzB,eAAA,qBAAA,8BAAmB,eAAe,QAAQ,CAAC,YAAa,QAAQ,WAAW,KAAK;AAEhF,eAAA,qBAAA;AAAA;AAAA,MACH;AAAA,MACA,QAAQ,CAAC,YAAmD;AACpD,cAAA,gBAAgB,iBAAiB,KAAK,QAAQ;AAC9C,cAAA,gBAAgB,iBAAiB,KAAK,QAAQ;AAAA,IAAA;AAAA,EAE1D;AAAA,EAEQ,eAAqB;AAC3B,SAAK,aAAa;AAClB,SAAK,cAAc;AACnB,SAAK,WAAW;AAChB,SAAK,eAAe;AAAA,EACtB;AAAA;AAAA,EAGQ,eAAqB;;AACrB,UAAA,aAAY,UAAK,YAAL,8BAAe;AACjC,SAAK,mBACH,kDAAW,eAAX,mBAAuB,kBAAvB,4BAAuC,uBAAsB,KAAK;AACpE,QAAI,KAAK,gBAAgB;AAClB,WAAA;AAAA,QACH;AAAA,QACA,CAAC,GAAC,4CAAW,iBAAX,mCAA0B;AAAA,MAAY;AAAA,IAE5C;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA,EAMQ,gBAAsB;;AAE5B,qBAAK,eAAe,iBAApB,4BAAmC,KAAK,iBAAiB;AAGzD,UAAM,qBAAmB,UAAK,YAAL,8BAAe,sBAAqB;AACxD,SAAA,gBAAgB,MAAM,MAAM;AACjC,SAAK,gBAAgB,MAAM,SAAS,GAAG,iBAAiB,YAAY;AACpE,SAAK,gBAAgB,MAAM,QAAQ,GAAG,iBAAiB,WAAW;AAAA,EACpE;AAAA,EAEQ,sBAA4B;AAClC;AAAA,MACE,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK,WAAY,cAAc,wBAAwB;AAAA,MACvD;AAAA,IAAA;AAAA,EAEJ;AAAA;AAAA;AAAA,EAIQ,gBAAgB,OAA6B;AACnD,QAAI,MAAM,kBAAkB,UAAU,KAAK,UAAU,WAAW;AAC9D,WAAK,oBAAoB;AAAA,IAAA,WAChB,MAAM,kBAAkB,WAAW,KAAK,UAAU,WAAW;AACtE,WAAK,qBAAqB;AAAA,IAC5B;AAAA,EACF;AAAA,EAEQ,sBAA4B;AAClC,SAAK,QAAQ;AACb,SAAK,uBAAuB;AACvB,SAAA,gBAAgB,aAAa,iBAAiB,MAAM;AAEzD,SAAK,QAAQ;EACf;AAAA,EAEQ,uBAA6B;AACnC,SAAK,QAAQ;AACR,SAAA,gBAAgB,aAAa,iBAAiB,OAAO;AAC1D,SAAK,oBAAoB;AACzB,SAAK,iBAAiB,YAAY;AAClC,SAAK,SAAS;EAChB;AAAA;AAAA,EAGQ,kBAAkB,uBAA+C;AACnE,QAAA,CAAC,KAAK,UAAU;AAClB,WAAK,iBACF,OAAO,CAAC,WAAW,OAAO,OAAO,sBAAsB,EAAE,EACzD,QAAQ,CAAC,WAAY,OAAO,WAAW,KAAM;AAChD,WAAK,QAAQ,sBAAsB;AAAA,IAAA,OAC9B;AACD,UAAA,CAAC,KAAK,OAAO;AACV,aAAA,QAAQ,CAAC,sBAAsB,KAAM;AAAA,MAAA,WACjC,CAAC,KAAK,MAAM,SAAS,sBAAsB,KAAM,GAAG;AAC7D,aAAK,QAAQ,CAAC,GAAG,KAAK,OAAO,sBAAsB,KAAM;AAAA,MAC3D;AAAA,IACF;AAEA,SAAK,OAAO;AACZ,SAAK,QAAQ;AACb,SAAK,WAAW;EAClB;AAAA;AAAA,EAGQ,oBAAoB,uBAA+C;AACzE,QAAI,KAAK,UAAU;AACZ,WAAA,QAAS,KAAK,MAAmB;AAAA,QACpC,CAAC,OAAe,OAAO,sBAAsB;AAAA,MAAA;AAG/C,WAAK,OAAO;AACZ,WAAK,QAAQ;AACb,WAAK,WAAW;IAClB;AAAA,EACF;AAAA,EAEQ,yBAA+B;AAChC,SAAA,6BAA6B,IAAI;AAGtC,aAAS,iBAAiB,UAAU,MAAM,KAAK,uBAAuB;AAAA,MACpE,SAAS;AAAA,MACT,QAAQ,KAAK,2BAA2B;AAAA,IAAA,CACzC;AACD,WAAO,iBAAiB,UAAU,MAAM,KAAK,uBAAuB;AAAA,MAClE,SAAS;AAAA,MACT,QAAQ,KAAK,2BAA2B;AAAA,IAAA,CACzC;AAGD,WAAO,iBAAiB,eAAe,CAAC,OAAO,KAAK,qBAAqB,EAAE,GAAG;AAAA,MAC5E,QAAQ,KAAK,2BAA2B;AAAA,IAAA,CACzC;AACD,WAAO,iBAAiB,aAAa,CAAC,OAAO,KAAK,sBAAsB,EAAE,GAAG;AAAA,MAC3E,QAAQ,KAAK,2BAA2B;AAAA,IAAA,CACzC;AAAA,EACH;AAAA,EAEQ,WAAW,OAA4B;AACzC,QAAA,KAAK,YAAY,KAAK,UAAU;AAClC;AAAA,IACF;AAEI,QAAA,KAAK,UAAU,UAAU;AAC3B,WAAK,gCAAgC,KAAK;AAAA,IAC5C;AACI,QAAA,KAAK,UAAU,UAAU;AAC3B,WAAK,gCAAgC,KAAK;AAAA,IAC5C;AAAA,EACF;AAAA,EAEQ,gCAAgC,OAA4B;AAC9D,QAAA,KAAK,yBAAyB,KAAK,GAAG;AACjC,aAAA,KAAK,2BAA2B,KAAK;AAAA,IAC9C;AAEA,YAAQ,MAAM,KAAK;AAAA,MACjB,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AAAA,MACL,KAAK;AACH,cAAM,eAAe;AACrB,aAAK,KAAK;AACV;AAAA,IACJ;AAAA,EACF;AAAA,EAEQ,gCAAgC,OAA4B;AAClE,QAAI,KAAK,YAAY,KAAK,YAAY,KAAK,UAAU,UAAU;AAC7D;AAAA,IACF;AAEI,QAAA,KAAK,yBAAyB,KAAK,GAAG;AACjC,aAAA,KAAK,2BAA2B,KAAK;AAAA,IAC9C;AAEA,YAAQ,MAAM,KAAK;AAAA,MACjB,KAAK;AAAA,MACL,KAAK;AACH,aAAK,MAAM;AACX;AAAA,MAEF,KAAK;AAAA,MACL,KAAK;AACH,cAAM,eAAe;AACrB,aAAK,kBAAkB;AACvB;AAAA,MAEF,KAAK;AAAA,MACL,KAAK;AACH,cAAM,eAAe;AACrB,aAAK,qBAAqB,KAAK;AAC/B;AAAA,MAEF,KAAK;AAAA,MACL,KAAK;AACH,cAAM,eAAe;AAChB,aAAA,qBAAqB,OAAO,CAAC;AAClC;AAAA,MAEF,KAAK;AAAA,MACL,KAAK;AACH,cAAM,eAAe;AACrB,aAAK,qBAAqB,OAAO,KAAK,iBAAiB,SAAS,CAAC;AACjE;AAAA,IACJ;AAAA,EACF;AAAA,EAEQ,yBAAyB,OAA+B;AAE5D,WAAA,MAAM,QAAQ,eACd,MAAM,QAAQ,WACb,MAAM,IAAI,WAAW,KACpB,MAAM,QAAQ,OACd,CAAC,MAAM,UACP,CAAC,MAAM,WACP,CAAC,MAAM;AAAA,EAEb;AAAA,EAEQ,2BAA2B,OAA4B;AAE7D,QAAI,OAAO,KAAK,mBAAmB,OAAO,YAAY;AACpD,mBAAa,KAAK,cAAc;AAAA,IAClC;AACA,SAAK,iBAAiB,WAAW,MAAO,KAAK,gBAAgB,IAAK,GAAI;AACtE,SAAK,iBAAiB,MAAM;AAGtB,UAAA,gBAAwB,KAAK,mBAAmB;AACtD,UAAM,wBAA4C;AAAA,MAChD,GAAG,KAAK,iBAAiB,MAAM,aAAa;AAAA,MAC5C,GAAG,KAAK,iBAAiB,MAAM,GAAG,aAAa;AAAA,IAAA;AAGjD,UAAM,QAAQ,sBAAsB;AAAA,MAClC,CAAC,WACC;;AAAA,6BAAO,gBAAP,mBAAoB,cAAc,QAAQ,KAAK,cAAc,YAAa,QAAM;AAAA;AAAA,IAAA;AAEpF,QAAI,OAAO;AAET,WAAK,qBAAqB,OAAO,KAAK,iBAAiB,QAAQ,KAAK,CAAC;AAAA,IAAA,WAErE,KAAK,cAAc,SAAS,KAC5B,IAAI,OAAO,IAAI,KAAK,cAAc,OAAO,CAAC,CAAC,IAAI,EAAE,KAAK,KAAK,aAAa,GACxE;AAGA,YAAM,aAAa,sBAAsB;AAAA,QACvC,CAAC,WACC;;AAAA,+BAAO,gBAAP,mBAAoB,cAAc,QAAQ,KAAK,cAAc,CAAC,EAAE,YAAA,QAAmB;AAAA;AAAA,MAAA;AAEvF,UAAI,YAAY;AACd,aAAK,qBAAqB,OAAO,KAAK,iBAAiB,QAAQ,UAAU,CAAC;AAAA,MAC5E;AAAA,IAAA,OACK;AAEL,mBAAa,KAAK,cAAc;AAChC,WAAK,gBAAgB;AAAA,IACvB;AAAA,EACF;AAAA,EAEQ,oBAA0B;AAChC,UAAM,eAAiC,KAAK,iBAAiB,KAAK,gBAAgB;AAElF,QAAI,KAAK,UAAU;AACJ,mBAAA,8BAA8B,CAAC,aAAa,QAAQ;AAAA,IAAA,OAC5D;AACL,WAAK,MAAM;AAAA,IACb;AAAA,EACF;AAAA,EAEQ,qBAAqB,OAAsB,OAAsB;AACjE,UAAA,YACJ,SAAS,oBAAoB,OAAO,KAAK,kBAAkB,KAAK,iBAAiB,MAAM;AACnF,UAAA,aAAa,KAAK,iBAAiB,SAAS;AAClD,UAAM,eAAe,KAAK,iBAAiB,KAAK,gBAAgB;AAE3D,SAAA,kBAAkB,YAAY,YAAY;AAE3C,QAAA,CAAC,KAAK,UAAU;AACb,WAAA,oBAAoB,YAAY,YAAY;AAAA,IAAA,WACxC,+BAAO,UAAU;AACf,iBAAA,8BAA8B,CAAC,WAAW,QAAQ;AAAA,IAC/D;AACA,SAAK,mBAAmB;AAAA,EAC1B;AAAA,EAEQ,kBACN,kBACA,mBAA4C,MAC5C,sBAAsB,MAChB;AACN,qBAAiB,UAAU,IAAI;AAC/B,qBAAiB,eAAe,EAAE,OAAO,UAAW,CAAA;AAEpD,QAAI,qBAAqB;AACvB,WAAK,gBAAgB,aAAa,yBAAyB,iBAAiB,EAAE;AAAA,IAChF;AAGI,QAAA,oBAAoB,qBAAqB,kBAAkB;AAC7D,uBAAiB,UAAU,KAAK;AAAA,IAClC;AAAA,EACF;AAAA,EAEQ,oBACN,kBACA,kBACM;AACN,qBAAiB,8BAA8B,IAAI;AAE/C,QAAA,oBAAoB,qBAAqB,kBAAkB;AAC7D,uBAAiB,8BAA8B,KAAK;AAAA,IACtD;AAAA,EACF;AAAA,EAEQ,sBAA4B;AAClC,UAAM,gBAAgB,KAAK,iBAAiB,KAAK,gBAAgB;AAEjE,QAAI,eAAe;AACjB,oBAAc,UAAU,KAAK;AAAA,IAC/B;AACA,SAAK,mBAAmB;AACnB,SAAA,gBAAgB,gBAAgB,uBAAuB;AAAA,EAC9D;AAAA,EAcQ,8BAAoC;AACtC,QAAA,CAAC,KAAK,UAAU;AAClB,YAAM,iBAAiB,KAAK,iBAAiB,KAAK,CAAC,WAAW,OAAO,QAAQ;AAC7E,UAAI,gBAAgB;AACb,aAAA,mBAAmB,KAAK,iBAAiB;AAAA,UAC5C,CAAC,WAAW,WAAW;AAAA,QAAA;AAEzB,aAAK,QAAQ,eAAe;AAAA,MAC9B;AAAA,IAAA,OACK;AACL,YAAM,UAAU,KAAK,iBAAiB,OAAO,CAAC,WAAW,OAAO,QAAQ;AACpE,UAAA,WAAW,QAAQ,SAAS,GAAG;AACjC,cAAM,QAAkB,CAAA;AACxB,mBAAW,UAAU,SAAS;AACtB,gBAAA,KAAK,OAAO,KAAM;AAAA,QAC1B;AACA,aAAK,QAAQ;AAAA,MACf;AAAA,IACF;AAAA,EACF;AAAA,EAEQ,iBAAuB;;AACzB,QAAA,KAAK,YAAY,KAAK,UAAU;AAClC;AAAA,IACF;AACA,eAAK,oBAAL,mBAAsB;AAEtB,YAAQ,KAAK,OAAO;AAAA,MAClB,KAAK,UAAU;AACb,aAAK,MAAM;AACX;AAAA,MACF;AAAA,MACA,KAAK,UAAU;AACb,aAAK,KAAK;AACV;AAAA,MACF;AAAA,IAGF;AAAA,EACF;AAAA,EAEQ,4BACN,aAC8C;AAC9C,WAAO,CAAC,KAAK,sBAAsB,WAAW,GAAG,WAAW;AAAA,EAC9D;AAAA,EAEA,MAAc,sBAAsB,aAAsD;AACxF,QAAI,KAAK,mBAAmB;AAC1B,YAAM,KAAK;AAAA,IACb;AACA,WAAO,KAAK,gBAAgB,OAAO,KAAK,aAAa,KAAK;AAAA,EAC5D;AAAA,EAEmB,SAAyB;AACnC,WAAA;AAAA;AAAA;AAAA;AAAA;AAAA,mBAKQ,KAAK,WAAW,UAAU,GAAG;AAAA;AAAA;AAAA;AAAA,wBAIxB,KAAK,SAAS,UAAU;AAAA,wBACxB,KAAK,UAAU;AAAA,oBACnB,KAAK,UAAU;AAAA,mBAChB,KAAK,UAAU;AAAA,iBACjB,KAAK,cAAc;AAAA,UAC1B,IAAI,CAACA,SAAS,KAAK,kBAAkBA,IAAmB,CAAC;AAAA;AAAA,UAEzD,MAAM,GAAG,KAAK,4BAA4B,aAAa,KAAK,WAAW,SAAS,CAAC,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA,UAKlF;AAAA,MACA,GAAG,KAAK;AAAA,QACN,sDAAsD,KAAK,WAAW;AAAA,MACxE;AAAA,IAAA,CACD;AAAA;AAAA;AAAA;AAAA;AAAA,2CAKkC,sBAAsB;AAAA;AAAA,0BAEvC,KAAK,eAAe;AAAA;AAAA,YAElC,IAAI,CAAC,cAAe,KAAK,WAAW,SAAyB,CAAC;AAAA;AAAA;AAAA;AAAA,mBAIvD,CAAC,iBAAiB,KAAK,aAAa,OAAO;AAAA;AAAA,qBAEzC,CAAC,iBAAiB,YAAY,OAAO;AAAA,sCACpB,KAAK,QAAQ;AAAA,gBACnC,IAAI,CAAC,iBAAkB,KAAK,mBAAmB,YAA4B,CAAC;AAAA;AAAA,kCAE1D,KAAK,2BAA2B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAMhE;AACF;AAhtBa,iBAGY,SAAyB;AAHrC,iBAMqB,SAAS;AAAA,EACvC,WAAW;AAAA,EACX,QAAQ;AAAA,EACR,OAAO;AAAA,EACP,aAAa;AAAA,EACb,UAAU;AAAA,EACV,SAAS;AAAA,EACT,WAAW;AAAA,EACX,UAAU;AACZ;AAGmB,gBAAA;AAAA,EAAlB,SAAS;AAAA,GAlBC,iBAkBQ,WAAA,SAAA,CAAA;AAGA,gBAAA;AAAA,EAAlB,SAAS;AAAA,GArBC,iBAqBQ,WAAA,eAAA,CAAA;AAGgC,gBAAA;AAAA,EAAlD,SAAS,EAAE,MAAM,SAAS,SAAS,MAAM;AAAA,GAxB/B,iBAwBwC,WAAA,YAAA,CAAA;AAGA,gBAAA;AAAA,EAAlD,SAAS,EAAE,SAAS,MAAM,MAAM,SAAS;AAAA,GA3B/B,iBA2BwC,WAAA,YAAA,CAAA;AAGf,gBAAA;AAAA,EAAnC,SAAS,EAAE,MAAM,SAAS;AAAA,GA9BhB,iBA8ByB,WAAA,YAAA,CAAA;AAGnB,gBAAA;AAAA,EAAhB,MAAM;AAAA,GAjCI,iBAiCM,WAAA,iBAAA,CAAA;AAjCN,mBAAN,gBAAA;AAAA,EAJN,cAAc,YAAY;AAAA,EAC1B,eAAe;AAAA,IACd,MAAM,iBAAiB,YAAY;AAAA,EAAA,CACpC;AAAA,GACY,gBAAA;"}
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { CSSResultGroup, PropertyValues, TemplateResult, LitElement } from 'lit';
|
|
2
|
-
|
|
2
|
+
import { FormRestoreReason, FormRestoreState } from '../core/mixins.js';
|
|
3
|
+
declare const SbbSliderElement_base: import('../core/mixins.js').AbstractConstructor<import('../core/mixins.js').SbbDisabledMixinType> & import('../core/mixins.js').Constructor<import('../core/mixins.js').SbbFormAssociatedMixinType> & typeof LitElement;
|
|
3
4
|
/**
|
|
4
5
|
* It displays an input knob that can be moved in a range.
|
|
5
6
|
*
|
|
@@ -12,18 +13,23 @@ export declare class SbbSliderElement extends SbbSliderElement_base {
|
|
|
12
13
|
static readonly events: {
|
|
13
14
|
readonly didChange: "didChange";
|
|
14
15
|
};
|
|
15
|
-
/**
|
|
16
|
-
|
|
16
|
+
/**
|
|
17
|
+
* Value of the form element.
|
|
18
|
+
* If no value is provided, default is the middle point between min and max.
|
|
19
|
+
*/
|
|
20
|
+
set value(value: string | null);
|
|
21
|
+
get value(): string;
|
|
17
22
|
/** Numeric value for the inner HTMLInputElement. */
|
|
18
|
-
valueAsNumber
|
|
19
|
-
|
|
20
|
-
name?: string;
|
|
21
|
-
/** The <form> element to associate the inner HTMLInputElement with. */
|
|
22
|
-
form?: string;
|
|
23
|
+
set valueAsNumber(value: number);
|
|
24
|
+
get valueAsNumber(): number | null;
|
|
23
25
|
/** Minimum acceptable value for the inner HTMLInputElement. */
|
|
24
|
-
min
|
|
26
|
+
set min(value: string);
|
|
27
|
+
get min(): string;
|
|
28
|
+
private _min;
|
|
25
29
|
/** Maximum acceptable value for the inner HTMLInputElement. */
|
|
26
|
-
max
|
|
30
|
+
set max(value: string);
|
|
31
|
+
get max(): string;
|
|
32
|
+
private _max;
|
|
27
33
|
/**
|
|
28
34
|
* Readonly state for the inner HTMLInputElement.
|
|
29
35
|
* Since the input range does not allow this attribute, it will be merged with the `disabled` one.
|
|
@@ -45,16 +51,29 @@ export declare class SbbSliderElement extends SbbSliderElement_base {
|
|
|
45
51
|
/** Reference to the inner HTMLInputElement with type='range'. */
|
|
46
52
|
private _rangeInput;
|
|
47
53
|
private _abort;
|
|
54
|
+
constructor();
|
|
48
55
|
connectedCallback(): void;
|
|
49
56
|
protected willUpdate(changedProperties: PropertyValues<this>): void;
|
|
50
|
-
private _syncValues;
|
|
51
57
|
/**
|
|
52
|
-
*
|
|
53
|
-
*
|
|
54
|
-
|
|
55
|
-
|
|
58
|
+
* The reset value is the attribute value (the setup value). If not present, calculates the default.
|
|
59
|
+
* @internal
|
|
60
|
+
*/
|
|
61
|
+
formResetCallback(): void;
|
|
62
|
+
/**
|
|
63
|
+
* @internal
|
|
64
|
+
*/
|
|
65
|
+
formStateRestoreCallback(state: FormRestoreState | null, _reason: FormRestoreReason): void;
|
|
66
|
+
/**
|
|
67
|
+
* If no value is provided, default is the middle point between min and max
|
|
68
|
+
* (see https://developer.mozilla.org/en-US/docs/Web/HTML/Element/input/range#value)
|
|
69
|
+
*/
|
|
70
|
+
private _getDefaultValue;
|
|
71
|
+
private _isValidNumber;
|
|
72
|
+
/**
|
|
73
|
+
* Restrains the value between the min and max
|
|
56
74
|
*/
|
|
57
|
-
private
|
|
75
|
+
private _boundBetweenMinMax;
|
|
76
|
+
private _calculateValueFraction;
|
|
58
77
|
private _handleKeydown;
|
|
59
78
|
/** Emits the change event. */
|
|
60
79
|
private _emitChange;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"slider.d.ts","sourceRoot":"","sources":["../../../../src/elements/slider/slider.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAQ,UAAU,EAAW,MAAM,KAAK,CAAC;
|
|
1
|
+
{"version":3,"file":"slider.d.ts","sourceRoot":"","sources":["../../../../src/elements/slider/slider.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAQ,UAAU,EAAW,MAAM,KAAK,CAAC;AAQhD,OAAO,EACL,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,EAGtB,MAAM,mBAAmB,CAAC;AAI3B,OAAO,YAAY,CAAC;;AAEpB;;;;;;GAMG;AACH,qBAIa,gBAAiB,SAAQ,qBAAoD;IACxF,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;MAElB;IAEX;;;OAGG;IACH,IACoB,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,EAQ7C;IACD,IAAoB,KAAK,IAAI,MAAM,CAElC;IAED,oDAAoD;IACpD,IACW,aAAa,CAAC,KAAK,EAAE,MAAM,EAErC;IACD,IAAW,aAAa,IAAI,MAAM,GAAG,IAAI,CAExC;IAED,+DAA+D;IAC/D,IACW,GAAG,CAAC,KAAK,EAAE,MAAM,EAO3B;IACD,IAAW,GAAG,IAAI,MAAM,CAEvB;IACD,OAAO,CAAC,IAAI,CAAe;IAE3B,+DAA+D;IAC/D,IACW,GAAG,CAAC,KAAK,EAAE,MAAM,EAO3B;IACD,IAAW,GAAG,IAAI,MAAM,CAEvB;IACD,OAAO,CAAC,IAAI,CAAiB;IAE7B;;;OAGG;IACiC,QAAQ,CAAC,EAAE,OAAO,CAAS;IAE/D,6FAA6F;IAC/C,SAAS,CAAC,EAAE,MAAM,CAAC;IAEjE,2FAA2F;IAC/C,OAAO,CAAC,EAAE,MAAM,CAAC;IAE7D;;;OAGG;IACM,OAAO,CAAC,cAAc,CAAK;IAEpC;;OAEG;IACH,OAAO,CAAC,UAAU,CAGf;IAEH,iEAAiE;IACjE,OAAO,CAAC,WAAW,CAAoB;IAEvC,OAAO,CAAC,MAAM,CAAyC;;IAQvC,iBAAiB,IAAI,IAAI;cAUtB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAc5E;;;OAGG;IACI,iBAAiB,IAAI,IAAI;IAIhC;;OAEG;IACI,wBAAwB,CAC7B,KAAK,EAAE,gBAAgB,GAAG,IAAI,EAC9B,OAAO,EAAE,iBAAiB,GACzB,IAAI;IAIP;;;OAGG;IACH,OAAO,CAAC,gBAAgB;IAIxB,OAAO,CAAC,cAAc;IAItB;;OAEG;IACH,OAAO,CAAC,mBAAmB;IAI3B,OAAO,CAAC,uBAAuB;YASjB,cAAc;IAgC5B,8BAA8B;IAC9B,OAAO,CAAC,WAAW;cAKA,MAAM,IAAI,cAAc;CAmC5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,YAAY,EAAE,gBAAgB,CAAC;KAChC;CACF"}
|