@sbb-esta/lyne-elements-dev 5.0.0-next.2-dev.1777962297 → 5.0.0-next.2-dev.1777979422

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (39) hide show
  1. package/core.css +1 -12
  2. package/custom-elements.json +228 -180
  3. package/development/optgroup-base-element-Cq8DMPk9.js +147 -0
  4. package/development/option/optgroup/optgroup-base-element.d.ts +2 -1
  5. package/development/option/optgroup/optgroup-base-element.d.ts.map +1 -1
  6. package/development/option/optgroup/optgroup-base-element.js +1 -1
  7. package/development/option/optgroup/optgroup.component.js +1 -1
  8. package/development/option/option/option-base-element.d.ts +2 -1
  9. package/development/option/option/option-base-element.d.ts.map +1 -1
  10. package/development/option/option/option-base-element.js +9 -3
  11. package/development/option/option/option.component.d.ts.map +1 -1
  12. package/development/option/option/option.component.js +1 -1
  13. package/development/option/option-hint/option-hint.component.d.ts +2 -0
  14. package/development/option/option-hint/option-hint.component.d.ts.map +1 -1
  15. package/development/option/option-hint/option-hint.component.js +1 -1
  16. package/development/option-hint.component-B4PxB3BW.js +39 -0
  17. package/development/option.component-CV6cZnJe.js +131 -0
  18. package/development/option.js +3 -3
  19. package/development/option.pure.js +3 -3
  20. package/off-brand-theme.css +1 -12
  21. package/optgroup-base-element-CrO_ydA8.js +108 -0
  22. package/option/optgroup/optgroup-base-element.js +1 -1
  23. package/option/optgroup/optgroup.component.js +1 -1
  24. package/option/option/option-base-element.js +27 -25
  25. package/option/option/option.component.js +1 -1
  26. package/option/option-hint/option-hint.component.js +1 -1
  27. package/option-hint.component-BEXndgG-.js +26 -0
  28. package/option.component-BeorlZT0.js +100 -0
  29. package/option.js +3 -3
  30. package/option.pure.js +3 -3
  31. package/package.json +2 -2
  32. package/safety-theme.css +1 -12
  33. package/standard-theme.css +1 -12
  34. package/development/optgroup-base-element-BEG1P4gK.js +0 -140
  35. package/development/option-hint.component-CcSUSwjN.js +0 -31
  36. package/development/option.component-BEbIEh5o.js +0 -132
  37. package/optgroup-base-element-C6KwbQ0N.js +0 -106
  38. package/option-hint.component-Bayihbh1.js +0 -21
  39. package/option.component-C-GGTcqF.js +0 -100
@@ -1,4 +1,4 @@
1
- import { t as SbbOptgroupBaseElement } from "../../optgroup-base-element-BEG1P4gK.js";
1
+ import { t as SbbOptgroupBaseElement } from "../../optgroup-base-element-Cq8DMPk9.js";
2
2
  import { SbbPropertyWatcherController } from "../../core.js";
3
3
  //#region src/elements/option/optgroup/optgroup.component.ts
4
4
  /**
@@ -28,7 +28,8 @@ export declare abstract class SbbOptionBaseElement<T = string> extends SbbOption
28
28
  /** The portion of the highlighted label. */
29
29
  private accessor _highlightString;
30
30
  private accessor _inertAriaGroups;
31
- constructor();
31
+ private _previousSize;
32
+ protected constructor();
32
33
  attributeChangedCallback(name: string, old: string | null, value: string | null): void;
33
34
  /**
34
35
  * Highlight the label of the option
@@ -1 +1 @@
1
- {"version":3,"file":"option-base-element.d.ts","sourceRoot":"","sources":["../../../../../src/elements/option/option/option-base-element.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,cAAc,EAEnB,OAAO,EACP,KAAK,mBAAmB,EACxB,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAGb,OAAO,EAKL,UAAU,EAGX,MAAM,eAAe,CAAC;;AAmBvB,8BAAsB,oBAAoB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,yBAE9D;IACC,gBAAuB,MAAM;;MAElB;IACX,OAAuB,MAAM,EAAE,cAAc,CAA4B;IAEzE,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAEpC;;;;;OAKG;IACH,IACW,KAAK,CAAC,KAAK,EAAE,CAAC,EAUxB;IACD,IAAW,KAAK,IAAI,CAAC,CAEpB;IACD,OAAO,CAAC,MAAM,CAAkB;IAEhC,sCAAsC;IACtC,IACW,QAAQ,CAAC,KAAK,EAAE,OAAO,EAGjC;IACD,IAAW,QAAQ,IAAI,OAAO,CAE7B;IAED,yFAAyF;IAChF,SAAS,CAAC,QAAQ,CAAC,iBAAiB,UAAS;IAE7C,SAAS,CAAC,QAAQ,CAAC,UAAU,SAAM;IAEnC,SAAS,CAAC,QAAQ,CAAC,KAAK,EAAG,MAAM,CAAC;IAE3C,0CAA0C;IACjC,SAAS,CAAC,QAAQ,CAAC,qBAAqB,EAAE,OAAO,CAAS;IAEnE,4CAA4C;IACnC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAuB;IAExD,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAS;;IA4BnC,wBAAwB,CACtC,IAAI,EAAE,MAAM,EACZ,GAAG,EAAE,MAAM,GAAG,IAAI,EAClB,KAAK,EAAE,MAAM,GAAG,IAAI,GACnB,IAAI;IAMP;;;;OAIG;IACI,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAIrC,SAAS,CAAC,wBAAwB,CAAC,QAAQ,EAAE,OAAO,GAAG,IAAI;IAQ3C,iBAAiB,IAAI,IAAI;IAKzB,aAAa,CAC3B,IAAI,CAAC,EAAE,WAAW,EAClB,QAAQ,CAAC,EAAE,OAAO,EAClB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,IAAI;cAaY,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAO9E,SAAS,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;IAEzD,SAAS,CAAC,sBAAsB,CAAC,QAAQ,EAAE,OAAO,GAAG,IAAI;IAKzD;;;OAGG;IACI,SAAS,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI;IAItC,SAAS,CAAC,kBAAkB,IAAI,IAAI;IAQpC,OAAO,CAAC,mBAAmB;IAI3B,SAAS,CAAC,oBAAoB,IAAI,IAAI;IAuBtC,SAAS,CAAC,mBAAmB,IAAI,cAAc;IAwB/C,SAAS,CAAC,UAAU,IAAI,cAAc;IAItC,SAAS,CAAC,WAAW,IAAI,cAAc,GAAG,OAAO,OAAO;IAIxD,SAAS,CAAC,UAAU,IAAI,cAAc,GAAG,OAAO,OAAO;cAIpC,MAAM,IAAI,cAAc;CA2B5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,2BAA2B;QACnC,cAAc,EAAE,KAAK,CAAC;KACvB;CACF"}
1
+ {"version":3,"file":"option-base-element.d.ts","sourceRoot":"","sources":["../../../../../src/elements/option/option/option-base-element.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,cAAc,EAEnB,OAAO,EACP,KAAK,mBAAmB,EACxB,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAIb,OAAO,EAKL,UAAU,EAIX,MAAM,eAAe,CAAC;;AAoBvB,8BAAsB,oBAAoB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,yBAE9D;IACC,gBAAuB,MAAM;;MAElB;IACX,OAAuB,MAAM,EAAE,cAAc,CAA4B;IAEzE,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAEpC;;;;;OAKG;IACH,IACW,KAAK,CAAC,KAAK,EAAE,CAAC,EAUxB;IACD,IAAW,KAAK,IAAI,CAAC,CAEpB;IACD,OAAO,CAAC,MAAM,CAAkB;IAEhC,sCAAsC;IACtC,IACW,QAAQ,CAAC,KAAK,EAAE,OAAO,EAGjC;IACD,IAAW,QAAQ,IAAI,OAAO,CAE7B;IAED,yFAAyF;IAChF,SAAS,CAAC,QAAQ,CAAC,iBAAiB,UAAS;IAE7C,SAAS,CAAC,QAAQ,CAAC,UAAU,SAAM;IAEnC,SAAS,CAAC,QAAQ,CAAC,KAAK,EAAG,MAAM,CAAC;IAE3C,0CAA0C;IACjC,SAAS,CAAC,QAAQ,CAAC,qBAAqB,EAAE,OAAO,CAAS;IAEnE,4CAA4C;IACnC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAuB;IAExD,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAS;IAEnD,OAAO,CAAC,aAAa,CAAqB;IAE1C,SAAS;IAsDO,wBAAwB,CACtC,IAAI,EAAE,MAAM,EACZ,GAAG,EAAE,MAAM,GAAG,IAAI,EAClB,KAAK,EAAE,MAAM,GAAG,IAAI,GACnB,IAAI;IAMP;;;;OAIG;IACI,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAIrC,SAAS,CAAC,wBAAwB,CAAC,QAAQ,EAAE,OAAO,GAAG,IAAI;IAQ3C,iBAAiB,IAAI,IAAI;IAKzB,aAAa,CAC3B,IAAI,CAAC,EAAE,WAAW,EAClB,QAAQ,CAAC,EAAE,OAAO,EAClB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,IAAI;cAaY,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAO9E,SAAS,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;IAEzD,SAAS,CAAC,sBAAsB,CAAC,QAAQ,EAAE,OAAO,GAAG,IAAI;IAKzD;;;OAGG;IACI,SAAS,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI;IAItC,SAAS,CAAC,kBAAkB,IAAI,IAAI;IAQpC,OAAO,CAAC,mBAAmB;IAI3B,SAAS,CAAC,oBAAoB,IAAI,IAAI;IAuBtC,SAAS,CAAC,mBAAmB,IAAI,cAAc;IAwB/C,SAAS,CAAC,UAAU,IAAI,cAAc;IAItC,SAAS,CAAC,WAAW,IAAI,cAAc,GAAG,OAAO,OAAO;IAIxD,SAAS,CAAC,UAAU,IAAI,cAAc,GAAG,OAAO,OAAO;cAIpC,MAAM,IAAI,cAAc;CA2B5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,2BAA2B;QACnC,cAAc,EAAE,KAAK,CAAC;KACvB;CACF"}
@@ -1,7 +1,7 @@
1
1
  import { __esDecorate, __runInitializers } from "tslib";
2
2
  import { html, nothing } from "lit";
3
3
  import { property, state } from "lit/decorators.js";
4
- import { SbbDisabledMixin, SbbElement, isAndroid, isBlink, isSafari, screenReaderOnlyStyles, setOrRemoveAttribute } from "../../core.js";
4
+ import { SbbDisabledMixin, SbbElement, SbbPropertyWatcherController, isAndroid, isBlink, isSafari, screenReaderOnlyStyles, setOrRemoveAttribute } from "../../core.js";
5
5
  import { SbbIconNameMixin } from "../../icon.pure.js";
6
6
  import { MutationController } from "@lit-labs/observers/mutation-controller.js";
7
7
  //#region src/elements/option/option/option-base-element.ts
@@ -254,7 +254,7 @@ var SbbOptionBaseElement = (() => {
254
254
  this.#disableLabelHighlight_accessor_storage = (__runInitializers(this, _label_extraInitializers), __runInitializers(this, _disableLabelHighlight_initializers, false));
255
255
  this.#_highlightString_accessor_storage = (__runInitializers(this, _disableLabelHighlight_extraInitializers), __runInitializers(this, __highlightString_initializers, null));
256
256
  this.#_inertAriaGroups_accessor_storage = (__runInitializers(this, __highlightString_extraInitializers), __runInitializers(this, __inertAriaGroups_initializers, false));
257
- __runInitializers(this, __inertAriaGroups_extraInitializers);
257
+ this._previousSize = __runInitializers(this, __inertAriaGroups_extraInitializers);
258
258
  this.addEventListener?.("click", (e) => this.selectByClick(e), { passive: true });
259
259
  this.addController(new MutationController(this, {
260
260
  config: optionObserverConfig,
@@ -264,6 +264,12 @@ var SbbOptionBaseElement = (() => {
264
264
  this.dispatchEvent(new Event("optionLabelChanged", { bubbles: true }));
265
265
  }
266
266
  }));
267
+ this.addController(new SbbPropertyWatcherController(this, () => this.closest("sbb-autocomplete, sbb-autocomplete-grid"), { negative: (e) => this.toggleState("negative", e.negative) }));
268
+ this.addController(new SbbPropertyWatcherController(this, () => this.closest("sbb-autocomplete, sbb-autocomplete-grid, sbb-select"), { size: (e) => {
269
+ if (this._previousSize) this.internals.states.delete(`size-${this._previousSize}`);
270
+ this._previousSize = e.size;
271
+ if (this._previousSize) this.internals.states.add(`size-${this._previousSize}`);
272
+ } }));
267
273
  if (inertAriaGroups) if (this.hydrationRequired) this.hydrationComplete.then(() => this._inertAriaGroups = inertAriaGroups);
268
274
  else this._inertAriaGroups = inertAriaGroups;
269
275
  }
@@ -371,4 +377,4 @@ var SbbOptionBaseElement = (() => {
371
377
  //#endregion
372
378
  export { SbbOptionBaseElement };
373
379
 
374
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"option-base-element.js","names":[],"sources":["../../../../../src/elements/option/option/option-base-element.ts"],"sourcesContent":["import { MutationController } from '@lit-labs/observers/mutation-controller.js';\nimport {\n  type CSSResultGroup,\n  html,\n  nothing,\n  type PropertyDeclaration,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { property, state } from 'lit/decorators.js';\n\nimport {\n  isAndroid,\n  isBlink,\n  isSafari,\n  SbbDisabledMixin,\n  SbbElement,\n  screenReaderOnlyStyles,\n  setOrRemoveAttribute,\n} from '../../core.ts';\nimport { SbbIconNameMixin } from '../../icon.pure.ts';\n\nlet nextId = 0;\n\n/**\n * On Safari, the groups labels are not read by VoiceOver.\n * To solve the problem, we remove the role=\"group\" and add an hidden span containing the group name\n * TODO: We should periodically check if it has been solved and, if so, remove the property.\n */\nconst inertAriaGroups = isSafari;\n\n/** Configuration for the attribute to look at if component is nested in an option group */\nconst optionObserverConfig: MutationObserverInit = {\n  childList: true,\n  subtree: true,\n  characterData: true,\n};\n\nexport abstract class SbbOptionBaseElement<T = string> extends SbbDisabledMixin(\n  SbbIconNameMixin(SbbElement),\n) {\n  public static readonly events = {\n    optionselected: 'optionselected',\n  } as const;\n  public static override styles: CSSResultGroup = [screenReaderOnlyStyles];\n\n  protected abstract optionId: string;\n\n  /**\n   * Value of the option.\n   *\n   * @description Developer note: In this case updating the attribute must be synchronous.\n   * Due to this, it is implemented as a getter/setter and the attributeChangedCallback() handles the diff check.\n   */\n  @property()\n  public set value(value: T) {\n    if (typeof value === 'string') {\n      this.setAttribute('value', `${value}`);\n      this._value = null;\n    } else {\n      this._value = value;\n    }\n    // Notify the sbb-select to re-check its value against the option's one.\n    /** @internal */\n    this.dispatchEvent(new Event('ɵoptionvaluechange', { bubbles: true }));\n  }\n  public get value(): T {\n    return (this._value ?? this.getAttribute('value')) as T;\n  }\n  private _value: T | null = null;\n\n  /** Whether the option is selected. */\n  @property({ type: Boolean })\n  public set selected(value: boolean) {\n    this.toggleAttribute('selected', value);\n    this._updateAriaSelected();\n  }\n  public get selected(): boolean {\n    return this.hasAttribute('selected');\n  }\n\n  /** Whether the component must be set disabled due disabled attribute on sbb-optgroup. */\n  @state() protected accessor disabledFromGroup = false;\n\n  @state() protected accessor groupLabel = '';\n\n  @state() protected accessor label!: string;\n\n  /** Disable the highlight of the label. */\n  @state() protected accessor disableLabelHighlight: boolean = false;\n\n  /** The portion of the highlighted label. */\n  @state() private accessor _highlightString: string | null = null;\n\n  @state() private accessor _inertAriaGroups = false;\n\n  public constructor() {\n    super();\n    this.addEventListener?.('click', (e: MouseEvent) => this.selectByClick(e), {\n      passive: true,\n    });\n\n    this.addController(\n      new MutationController(this, {\n        config: optionObserverConfig,\n        callback: () => {\n          this.handleHighlightState();\n          /** @internal */\n          this.dispatchEvent(new Event('optionLabelChanged', { bubbles: true }));\n        },\n      }),\n    );\n\n    if (inertAriaGroups) {\n      if (this.hydrationRequired) {\n        this.hydrationComplete.then(() => (this._inertAriaGroups = inertAriaGroups));\n      } else {\n        this._inertAriaGroups = inertAriaGroups;\n      }\n    }\n  }\n\n  public override attributeChangedCallback(\n    name: string,\n    old: string | null,\n    value: string | null,\n  ): void {\n    if (name !== 'value' || old !== value) {\n      super.attributeChangedCallback(name, old, value);\n    }\n  }\n\n  /**\n   * Highlight the label of the option\n   * @param value the highlighted portion of the label\n   * @internal\n   */\n  public highlight(value: string): void {\n    this._highlightString = value;\n  }\n\n  protected selectViaUserInteraction(selected: boolean): void {\n    this.selected = selected;\n    if (this.selected) {\n      /** Emits when an option was selected by user. */\n      this.dispatchEvent(new Event('optionselected', { bubbles: true, composed: true }));\n    }\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.id ||= `${this.optionId}-${nextId++}`;\n  }\n\n  public override requestUpdate(\n    name?: PropertyKey,\n    oldValue?: unknown,\n    options?: PropertyDeclaration,\n  ): void {\n    super.requestUpdate(name, oldValue, options);\n    if (name === 'disabled' || name === 'disabledFromGroup') {\n      this.toggleState('disabled', this.disabled || this.disabledFromGroup);\n      setOrRemoveAttribute(\n        this,\n        'tabindex',\n        isAndroid && !this.disabled && !this.disabledFromGroup ? 0 : null,\n      );\n      this.updateAriaDisabled();\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    // Init first select state because false would not call setter of selected property.\n    this._updateAriaSelected();\n  }\n\n  protected abstract selectByClick(event: MouseEvent): void;\n\n  protected updateDisableHighlight(disabled: boolean): void {\n    this.disableLabelHighlight = disabled;\n    this.toggleState('disable-highlight', disabled);\n  }\n\n  /**\n   * Whether the option is currently active.\n   * @internal\n   */\n  public setActive(value: boolean): void {\n    this.toggleState('active', value);\n  }\n\n  protected updateAriaDisabled(): void {\n    this.internals.ariaDisabled = this.disabled || this.disabledFromGroup ? 'true' : null;\n\n    // Listened by autocomplete\n    /** @internal */\n    this.dispatchEvent(new Event('ɵdisabledchange', { bubbles: true }));\n  }\n\n  private _updateAriaSelected(): void {\n    this.internals.ariaSelected = `${this.selected}`;\n  }\n\n  protected handleHighlightState(): void {\n    const slotNodes = Array.from(this.childNodes ?? []).filter(\n      (n) => n.nodeType !== Node.COMMENT_NODE && (!(n instanceof Element) || n.slot !== 'icon'),\n    );\n    const labelNodes = slotNodes.filter((el) => el.nodeType === Node.TEXT_NODE) as Text[];\n\n    // Disable the highlight if the slot contain more than just text nodes.\n    // We need to ignore template elements, as SSR adds a declarative shadow DOM\n    // in the form of a template element.\n    if (\n      labelNodes.length === 0 ||\n      slotNodes.filter((n) => !(n instanceof Element) || n.localName !== 'template').length !==\n        labelNodes.length\n    ) {\n      this.updateDisableHighlight(true);\n      return;\n    }\n    this.label = labelNodes\n      .map((l) => l.wholeText)\n      .filter((l) => l.trim())\n      .join('');\n  }\n\n  protected getHighlightedLabel(): TemplateResult {\n    if (!this._highlightString || !this._highlightString.trim()) {\n      return html`${this.label}`;\n    }\n\n    const matchIndex = this.label!.toLowerCase().indexOf(this._highlightString.toLowerCase());\n\n    if (matchIndex === -1) {\n      return html`${this.label}`;\n    }\n\n    const prefix = this.label!.substring(0, matchIndex);\n    const highlighted = this.label!.substring(\n      matchIndex,\n      matchIndex + this._highlightString.length,\n    );\n    const postfix = this.label!.substring(matchIndex + this._highlightString.length);\n\n    return html`\n      <span class=\"sbb-option__label--highlight\">${prefix}</span><span>${highlighted}</span\n      ><span class=\"sbb-option__label--highlight\">${postfix}</span>\n    `;\n  }\n\n  protected renderIcon(): TemplateResult {\n    return html`<span class=\"sbb-option__icon\"> ${this.renderIconSlot()} </span>`;\n  }\n\n  protected renderLabel(): TemplateResult | typeof nothing {\n    return this.label && !this.disableLabelHighlight ? this.getHighlightedLabel() : nothing;\n  }\n\n  protected renderTick(): TemplateResult | typeof nothing {\n    return nothing;\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-option\">\n        ${this.renderIcon()}\n        <span class=\"sbb-option__label\">\n          <slot @slotchange=${this.handleHighlightState}></slot>\n          <span\n            aria-hidden=${\n              /**\n               * Screen readers with Chromium read the option twice.\n               * We therefore have to hide the option for the screen readers.\n               * TODO: Recheck periodically if this is still necessary.\n               * https://issues.chromium.org/issues/460165741\n               */\n              isBlink ? 'true' : nothing\n            }\n          >\n            ${this.renderLabel()}\n          </span>\n          ${this._inertAriaGroups && this.groupLabel\n            ? html`<span class=\"sbb-screen-reader-only\"> (${this.groupLabel})</span>`\n            : nothing}\n        </span>\n        ${this.renderTick()}\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface GlobalEventHandlersEventMap {\n    optionselected: Event;\n  }\n}\n"],"mappings":"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"}
380
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"option-base-element.js","names":[],"sources":["../../../../../src/elements/option/option/option-base-element.ts"],"sourcesContent":["import { MutationController } from '@lit-labs/observers/mutation-controller.js';\nimport {\n  type CSSResultGroup,\n  html,\n  nothing,\n  type PropertyDeclaration,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { property, state } from 'lit/decorators.js';\n\nimport type { SbbAutocompleteBaseElement } from '../../autocomplete.pure.ts';\nimport {\n  isAndroid,\n  isBlink,\n  isSafari,\n  SbbDisabledMixin,\n  SbbElement,\n  SbbPropertyWatcherController,\n  screenReaderOnlyStyles,\n  setOrRemoveAttribute,\n} from '../../core.ts';\nimport { SbbIconNameMixin } from '../../icon.pure.ts';\nimport type { SbbSelectElement } from '../../select.pure.ts';\n\nlet nextId = 0;\n\n/**\n * On Safari, the groups labels are not read by VoiceOver.\n * To solve the problem, we remove the role=\"group\" and add an hidden span containing the group name\n * TODO: We should periodically check if it has been solved and, if so, remove the property.\n */\nconst inertAriaGroups = isSafari;\n\n/** Configuration for the attribute to look at if component is nested in an option group */\nconst optionObserverConfig: MutationObserverInit = {\n  childList: true,\n  subtree: true,\n  characterData: true,\n};\n\nexport abstract class SbbOptionBaseElement<T = string> extends SbbDisabledMixin(\n  SbbIconNameMixin(SbbElement),\n) {\n  public static readonly events = {\n    optionselected: 'optionselected',\n  } as const;\n  public static override styles: CSSResultGroup = [screenReaderOnlyStyles];\n\n  protected abstract optionId: string;\n\n  /**\n   * Value of the option.\n   *\n   * @description Developer note: In this case updating the attribute must be synchronous.\n   * Due to this, it is implemented as a getter/setter and the attributeChangedCallback() handles the diff check.\n   */\n  @property()\n  public set value(value: T) {\n    if (typeof value === 'string') {\n      this.setAttribute('value', `${value}`);\n      this._value = null;\n    } else {\n      this._value = value;\n    }\n    // Notify the sbb-select to re-check its value against the option's one.\n    /** @internal */\n    this.dispatchEvent(new Event('ɵoptionvaluechange', { bubbles: true }));\n  }\n  public get value(): T {\n    return (this._value ?? this.getAttribute('value')) as T;\n  }\n  private _value: T | null = null;\n\n  /** Whether the option is selected. */\n  @property({ type: Boolean })\n  public set selected(value: boolean) {\n    this.toggleAttribute('selected', value);\n    this._updateAriaSelected();\n  }\n  public get selected(): boolean {\n    return this.hasAttribute('selected');\n  }\n\n  /** Whether the component must be set disabled due disabled attribute on sbb-optgroup. */\n  @state() protected accessor disabledFromGroup = false;\n\n  @state() protected accessor groupLabel = '';\n\n  @state() protected accessor label!: string;\n\n  /** Disable the highlight of the label. */\n  @state() protected accessor disableLabelHighlight: boolean = false;\n\n  /** The portion of the highlighted label. */\n  @state() private accessor _highlightString: string | null = null;\n\n  @state() private accessor _inertAriaGroups = false;\n\n  private _previousSize: string | undefined;\n\n  protected constructor() {\n    super();\n    this.addEventListener?.('click', (e: MouseEvent) => this.selectByClick(e), {\n      passive: true,\n    });\n\n    this.addController(\n      new MutationController(this, {\n        config: optionObserverConfig,\n        callback: () => {\n          this.handleHighlightState();\n          /** @internal */\n          this.dispatchEvent(new Event('optionLabelChanged', { bubbles: true }));\n        },\n      }),\n    );\n\n    this.addController(\n      new SbbPropertyWatcherController(\n        this,\n        () => this.closest('sbb-autocomplete, sbb-autocomplete-grid') as SbbAutocompleteBaseElement,\n        {\n          negative: (e) => this.toggleState('negative', e.negative),\n        },\n      ),\n    );\n\n    this.addController(\n      new SbbPropertyWatcherController<SbbAutocompleteBaseElement | SbbSelectElement>(\n        this,\n        () => this.closest('sbb-autocomplete, sbb-autocomplete-grid, sbb-select'),\n        {\n          size: (e) => {\n            if (this._previousSize) {\n              this.internals.states.delete(`size-${this._previousSize}`);\n            }\n            this._previousSize = e.size;\n            if (this._previousSize) {\n              this.internals.states.add(`size-${this._previousSize}`);\n            }\n          },\n        },\n      ),\n    );\n\n    if (inertAriaGroups) {\n      if (this.hydrationRequired) {\n        this.hydrationComplete.then(() => (this._inertAriaGroups = inertAriaGroups));\n      } else {\n        this._inertAriaGroups = inertAriaGroups;\n      }\n    }\n  }\n\n  public override attributeChangedCallback(\n    name: string,\n    old: string | null,\n    value: string | null,\n  ): void {\n    if (name !== 'value' || old !== value) {\n      super.attributeChangedCallback(name, old, value);\n    }\n  }\n\n  /**\n   * Highlight the label of the option\n   * @param value the highlighted portion of the label\n   * @internal\n   */\n  public highlight(value: string): void {\n    this._highlightString = value;\n  }\n\n  protected selectViaUserInteraction(selected: boolean): void {\n    this.selected = selected;\n    if (this.selected) {\n      /** Emits when an option was selected by user. */\n      this.dispatchEvent(new Event('optionselected', { bubbles: true, composed: true }));\n    }\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.id ||= `${this.optionId}-${nextId++}`;\n  }\n\n  public override requestUpdate(\n    name?: PropertyKey,\n    oldValue?: unknown,\n    options?: PropertyDeclaration,\n  ): void {\n    super.requestUpdate(name, oldValue, options);\n    if (name === 'disabled' || name === 'disabledFromGroup') {\n      this.toggleState('disabled', this.disabled || this.disabledFromGroup);\n      setOrRemoveAttribute(\n        this,\n        'tabindex',\n        isAndroid && !this.disabled && !this.disabledFromGroup ? 0 : null,\n      );\n      this.updateAriaDisabled();\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    // Init first select state because false would not call setter of selected property.\n    this._updateAriaSelected();\n  }\n\n  protected abstract selectByClick(event: MouseEvent): void;\n\n  protected updateDisableHighlight(disabled: boolean): void {\n    this.disableLabelHighlight = disabled;\n    this.toggleState('disable-highlight', disabled);\n  }\n\n  /**\n   * Whether the option is currently active.\n   * @internal\n   */\n  public setActive(value: boolean): void {\n    this.toggleState('active', value);\n  }\n\n  protected updateAriaDisabled(): void {\n    this.internals.ariaDisabled = this.disabled || this.disabledFromGroup ? 'true' : null;\n\n    // Listened by autocomplete\n    /** @internal */\n    this.dispatchEvent(new Event('ɵdisabledchange', { bubbles: true }));\n  }\n\n  private _updateAriaSelected(): void {\n    this.internals.ariaSelected = `${this.selected}`;\n  }\n\n  protected handleHighlightState(): void {\n    const slotNodes = Array.from(this.childNodes ?? []).filter(\n      (n) => n.nodeType !== Node.COMMENT_NODE && (!(n instanceof Element) || n.slot !== 'icon'),\n    );\n    const labelNodes = slotNodes.filter((el) => el.nodeType === Node.TEXT_NODE) as Text[];\n\n    // Disable the highlight if the slot contain more than just text nodes.\n    // We need to ignore template elements, as SSR adds a declarative shadow DOM\n    // in the form of a template element.\n    if (\n      labelNodes.length === 0 ||\n      slotNodes.filter((n) => !(n instanceof Element) || n.localName !== 'template').length !==\n        labelNodes.length\n    ) {\n      this.updateDisableHighlight(true);\n      return;\n    }\n    this.label = labelNodes\n      .map((l) => l.wholeText)\n      .filter((l) => l.trim())\n      .join('');\n  }\n\n  protected getHighlightedLabel(): TemplateResult {\n    if (!this._highlightString || !this._highlightString.trim()) {\n      return html`${this.label}`;\n    }\n\n    const matchIndex = this.label!.toLowerCase().indexOf(this._highlightString.toLowerCase());\n\n    if (matchIndex === -1) {\n      return html`${this.label}`;\n    }\n\n    const prefix = this.label!.substring(0, matchIndex);\n    const highlighted = this.label!.substring(\n      matchIndex,\n      matchIndex + this._highlightString.length,\n    );\n    const postfix = this.label!.substring(matchIndex + this._highlightString.length);\n\n    return html`\n      <span class=\"sbb-option__label--highlight\">${prefix}</span><span>${highlighted}</span\n      ><span class=\"sbb-option__label--highlight\">${postfix}</span>\n    `;\n  }\n\n  protected renderIcon(): TemplateResult {\n    return html`<span class=\"sbb-option__icon\"> ${this.renderIconSlot()} </span>`;\n  }\n\n  protected renderLabel(): TemplateResult | typeof nothing {\n    return this.label && !this.disableLabelHighlight ? this.getHighlightedLabel() : nothing;\n  }\n\n  protected renderTick(): TemplateResult | typeof nothing {\n    return nothing;\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-option\">\n        ${this.renderIcon()}\n        <span class=\"sbb-option__label\">\n          <slot @slotchange=${this.handleHighlightState}></slot>\n          <span\n            aria-hidden=${\n              /**\n               * Screen readers with Chromium read the option twice.\n               * We therefore have to hide the option for the screen readers.\n               * TODO: Recheck periodically if this is still necessary.\n               * https://issues.chromium.org/issues/460165741\n               */\n              isBlink ? 'true' : nothing\n            }\n          >\n            ${this.renderLabel()}\n          </span>\n          ${this._inertAriaGroups && this.groupLabel\n            ? html`<span class=\"sbb-screen-reader-only\"> (${this.groupLabel})</span>`\n            : nothing}\n        </span>\n        ${this.renderTick()}\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface GlobalEventHandlersEventMap {\n    optionselected: Event;\n  }\n}\n"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"option.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/option/option/option.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAQ,OAAO,EAAE,KAAK,cAAc,EAAa,MAAM,KAAK,CAAC;AAGzF,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAKpD,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAGhE,MAAM,MAAM,gBAAgB,GAAG,cAAc,GAAG,QAAQ,GAAG,IAAI,CAAC;AAEhE;;;;;;;;GAQG;AACH,qBAAa,gBAAgB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,oBAAoB,CAAC,CAAC,CAAC;IACvE,gBAAgC,WAAW,EAAE,MAAM,CAAgB;IACnE,OAAuB,mBAAmB,EAAE,cAAc,EAAE,CAA8B;IAC1F,gBAAgC,IAAI,YAAY;IAChD,OAAuB,MAAM,EAAE,cAAc,CAAsB;IACnE,gBAAgC,MAAM;;;MAG3B;IAEX,SAAS,CAAC,QAAQ,SAAgB;IAElC,OAAO,KAAK,QAAQ,QAQnB;IACD,OAAO,KAAK,QAAQ,GAEnB;IACD,OAAO,CAAC,gBAAgB,CAAC,CAAmB;;IA8B5C,OAAO,CAAC,WAAW;IAInB,OAAO,CAAC,qBAAqB;IAOb,iBAAiB,IAAI,IAAI;IAazC,OAAO,CAAC,KAAK;IAKb,SAAS,CAAC,aAAa,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;cAc7B,wBAAwB,CAAC,QAAQ,EAAE,OAAO,GAAG,IAAI;IAMpE,OAAO,CAAC,oBAAoB;cAQT,oBAAoB,IAAI,IAAI;cAS5B,UAAU,IAAI,cAAc;cAoB5B,WAAW,IAAI,cAAc,GAAG,OAAO,OAAO;cAO9C,UAAU,IAAI,cAAc,GAAG,OAAO,OAAO;CAKjE;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,YAAY,EAAE,gBAAgB,CAAC;KAChC;IAED,UAAU,2BAA2B;QACnC,qBAAqB,EAAE,KAAK,CAAC;KAC9B;CACF"}
1
+ {"version":3,"file":"option.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/option/option/option.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAQ,OAAO,EAAE,KAAK,cAAc,EAAa,MAAM,KAAK,CAAC;AAGzF,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAKpD,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAGhE,MAAM,MAAM,gBAAgB,GAAG,cAAc,GAAG,QAAQ,GAAG,IAAI,CAAC;AAEhE;;;;;;;;GAQG;AACH,qBAAa,gBAAgB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,oBAAoB,CAAC,CAAC,CAAC;IACvE,gBAAgC,WAAW,EAAE,MAAM,CAAgB;IACnE,OAAuB,mBAAmB,EAAE,cAAc,EAAE,CAA8B;IAC1F,gBAAgC,IAAI,YAAY;IAChD,OAAuB,MAAM,EAAE,cAAc,CAAsB;IACnE,gBAAgC,MAAM;;;MAG3B;IAEX,SAAS,CAAC,QAAQ,SAAgB;IAElC,OAAO,KAAK,QAAQ,QAQnB;IACD,OAAO,KAAK,QAAQ,GAEnB;IACD,OAAO,CAAC,gBAAgB,CAAC,CAAmB;;IAwB5C,OAAO,CAAC,WAAW;IAInB,OAAO,CAAC,qBAAqB;IAOb,iBAAiB,IAAI,IAAI;IAazC,OAAO,CAAC,KAAK;IAKb,SAAS,CAAC,aAAa,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;cAc7B,wBAAwB,CAAC,QAAQ,EAAE,OAAO,GAAG,IAAI;IAMpE,OAAO,CAAC,oBAAoB;cAQT,oBAAoB,IAAI,IAAI;cAS5B,UAAU,IAAI,cAAc;cAoB5B,WAAW,IAAI,cAAc,GAAG,OAAO,OAAO;cAO9C,UAAU,IAAI,cAAc,GAAG,OAAO,OAAO;CAKjE;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,YAAY,EAAE,gBAAgB,CAAC;KAChC;IAED,UAAU,2BAA2B;QACnC,qBAAqB,EAAE,KAAK,CAAC;KAC9B;CACF"}
@@ -1,2 +1,2 @@
1
- import { t as SbbOptionElement } from "../../option.component-BEbIEh5o.js";
1
+ import { t as SbbOptionElement } from "../../option.component-CV6cZnJe.js";
2
2
  export { SbbOptionElement };
@@ -9,6 +9,8 @@ declare const SbbOptionHintElement_base: import('../../core.ts').AbstractConstru
9
9
  export declare class SbbOptionHintElement extends SbbOptionHintElement_base {
10
10
  static readonly elementName: string;
11
11
  static styles: CSSResultGroup;
12
+ private _previousSize;
13
+ constructor();
12
14
  protected render(): TemplateResult;
13
15
  }
14
16
  declare global {
@@ -1 +1 @@
1
- {"version":3,"file":"option-hint.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/option/option-hint/option-hint.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAQ,KAAK,cAAc,EAAa,MAAM,KAAK,CAAC;AAEhF,OAAO,EAAE,UAAU,EAAoB,MAAM,eAAe,CAAC;;AAI7D;;;;GAIG;AACH,qBAAa,oBAAqB,SAAQ,yBAA4B;IACpE,gBAAgC,WAAW,EAAE,MAAM,CAAqB;IACxE,OAAuB,MAAM,EAAE,cAAc,CAAsB;cAEhD,MAAM,IAAI,cAAc;CAQ5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,iBAAiB,EAAE,oBAAoB,CAAC;KACzC;CACF"}
1
+ {"version":3,"file":"option-hint.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/option/option-hint/option-hint.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAQ,KAAK,cAAc,EAAa,MAAM,KAAK,CAAC;AAGhF,OAAO,EAAE,UAAU,EAAkD,MAAM,eAAe,CAAC;;AAK3F;;;;GAIG;AACH,qBAAa,oBAAqB,SAAQ,yBAA4B;IACpE,gBAAgC,WAAW,EAAE,MAAM,CAAqB;IACxE,OAAuB,MAAM,EAAE,cAAc,CAAsB;IAEnE,OAAO,CAAC,aAAa,CAAqB;;cAwBvB,MAAM,IAAI,cAAc;CAQ5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,iBAAiB,EAAE,oBAAoB,CAAC;KACzC;CACF"}
@@ -1,2 +1,2 @@
1
- import { t as SbbOptionHintElement } from "../../option-hint.component-CcSUSwjN.js";
1
+ import { t as SbbOptionHintElement } from "../../option-hint.component-B4PxB3BW.js";
2
2
  export { SbbOptionHintElement };
@@ -0,0 +1,39 @@
1
+ import { html, unsafeCSS } from "lit";
2
+ import { SbbElement, SbbNegativeMixin, SbbPropertyWatcherController } from "./core.js";
3
+ //#region src/elements/option/option-hint/option-hint.scss?inline
4
+ var option_hint_default = ":host {\n display: flex;\n column-gap: var(--sbb-option-hint-column-gap);\n padding-inline: var(--sbb-option-hint-padding-inline);\n padding-block-end: var(--sbb-option-hint-padding-block-end);\n font-size: var(--sbb-option-hint-font-size);\n letter-spacing: var(--sbb-typo-letter-spacing-text);\n}\n\n:host([negative]) {\n --sbb-option-hint-color: var(--sbb-color-5);\n}\n\n:host(:is(:state(size-s),[state--size-s])) {\n --sbb-option-hint-padding-block-end: var(--sbb-spacing-fixed-1x);\n}\n\n:host(:is(:state(size-m),[state--size-m])) {\n --sbb-option-hint-padding-block-end: var(--sbb-spacing-fixed-2x);\n}\n\n.sbb-optgroup__icon-space {\n display: var(--sbb-option-icon-container-display, none);\n min-width: var(--sbb-size-icon-ui-small);\n}\n\n.sbb-option-hint {\n color: var(--sbb-option-hint-color);\n -webkit-text-fill-color: var(--sbb-option-hint-color);\n flex-grow: 1;\n}";
5
+ //#endregion
6
+ //#region src/elements/option/option-hint/option-hint.component.ts
7
+ /**
8
+ * Display a textual hint inside a `sbb-autocomplete` or a `sbb-select`.
9
+ *
10
+ * @slot - Use the unnamed slot to display the hint message.
11
+ */
12
+ var SbbOptionHintElement = class extends SbbNegativeMixin(SbbElement) {
13
+ static {
14
+ this.elementName = "sbb-option-hint";
15
+ }
16
+ static {
17
+ this.styles = [unsafeCSS(option_hint_default)];
18
+ }
19
+ constructor() {
20
+ super();
21
+ this.addController(new SbbPropertyWatcherController(this, () => this.closest("sbb-autocomplete, sbb-autocomplete-grid, sbb-select"), { size: (e) => {
22
+ if (this._previousSize) this.internals.states.delete(`size-${this._previousSize}`);
23
+ this._previousSize = e.size;
24
+ if (this._previousSize) this.internals.states.add(`size-${this._previousSize}`);
25
+ } }));
26
+ }
27
+ render() {
28
+ return html`
29
+ <div class="sbb-optgroup__icon-space"></div>
30
+ <span class="sbb-option-hint">
31
+ <slot></slot>
32
+ </span>
33
+ `;
34
+ }
35
+ };
36
+ //#endregion
37
+ export { SbbOptionHintElement as t };
38
+
39
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9uLWhpbnQuY29tcG9uZW50LUI0UHhCM0JXLmpzIiwibmFtZXMiOltdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9lbGVtZW50cy9vcHRpb24vb3B0aW9uLWhpbnQvb3B0aW9uLWhpbnQuc2Nzcz9pbmxpbmUiLCIuLi8uLi8uLi9zcmMvZWxlbWVudHMvb3B0aW9uL29wdGlvbi1oaW50L29wdGlvbi1oaW50LmNvbXBvbmVudC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJAdXNlICcuLi8uLi9jb3JlL3N0eWxlcycgYXMgc2JiO1xuXG46aG9zdCB7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGNvbHVtbi1nYXA6IHZhcigtLXNiYi1vcHRpb24taGludC1jb2x1bW4tZ2FwKTtcbiAgcGFkZGluZy1pbmxpbmU6IHZhcigtLXNiYi1vcHRpb24taGludC1wYWRkaW5nLWlubGluZSk7XG4gIHBhZGRpbmctYmxvY2stZW5kOiB2YXIoLS1zYmItb3B0aW9uLWhpbnQtcGFkZGluZy1ibG9jay1lbmQpO1xuICBmb250LXNpemU6IHZhcigtLXNiYi1vcHRpb24taGludC1mb250LXNpemUpO1xuICBsZXR0ZXItc3BhY2luZzogdmFyKC0tc2JiLXR5cG8tbGV0dGVyLXNwYWNpbmctdGV4dCk7XG59XG5cbjpob3N0KFtuZWdhdGl2ZV0pIHtcbiAgLS1zYmItb3B0aW9uLWhpbnQtY29sb3I6IHZhcigtLXNiYi1jb2xvci01KTtcbn1cblxuOmhvc3QoOnN0YXRlKHNpemUtcykpIHtcbiAgLS1zYmItb3B0aW9uLWhpbnQtcGFkZGluZy1ibG9jay1lbmQ6IHZhcigtLXNiYi1zcGFjaW5nLWZpeGVkLTF4KTtcbn1cblxuOmhvc3QoOnN0YXRlKHNpemUtbSkpIHtcbiAgLS1zYmItb3B0aW9uLWhpbnQtcGFkZGluZy1ibG9jay1lbmQ6IHZhcigtLXNiYi1zcGFjaW5nLWZpeGVkLTJ4KTtcbn1cblxuLnNiYi1vcHRncm91cF9faWNvbi1zcGFjZSB7XG4gIC8vIENhbiBiZSBvdmVycmlkZGVuIGJ5IHRoZSAncHJlc2VydmUtaWNvbi1zcGFjZScgb24gdGhlIGF1dG9jb21wbGV0ZVxuICBkaXNwbGF5OiB2YXIoLS1zYmItb3B0aW9uLWljb24tY29udGFpbmVyLWRpc3BsYXksIG5vbmUpO1xuICBtaW4td2lkdGg6IHZhcigtLXNiYi1zaXplLWljb24tdWktc21hbGwpO1xufVxuXG4uc2JiLW9wdGlvbi1oaW50IHtcbiAgY29sb3I6IHZhcigtLXNiYi1vcHRpb24taGludC1jb2xvcik7XG4gIC13ZWJraXQtdGV4dC1maWxsLWNvbG9yOiB2YXIoLS1zYmItb3B0aW9uLWhpbnQtY29sb3IpO1xuICBmbGV4LWdyb3c6IDE7XG59XG4iLCJpbXBvcnQgeyB0eXBlIENTU1Jlc3VsdEdyb3VwLCBodG1sLCB0eXBlIFRlbXBsYXRlUmVzdWx0LCB1bnNhZmVDU1MgfSBmcm9tICdsaXQnO1xuXG5pbXBvcnQgdHlwZSB7IFNiYkF1dG9jb21wbGV0ZUJhc2VFbGVtZW50IH0gZnJvbSAnLi4vLi4vYXV0b2NvbXBsZXRlLnB1cmUudHMnO1xuaW1wb3J0IHsgU2JiRWxlbWVudCwgU2JiTmVnYXRpdmVNaXhpbiwgU2JiUHJvcGVydHlXYXRjaGVyQ29udHJvbGxlciB9IGZyb20gJy4uLy4uL2NvcmUudHMnO1xuaW1wb3J0IHR5cGUgeyBTYmJTZWxlY3RFbGVtZW50IH0gZnJvbSAnLi4vLi4vc2VsZWN0LnB1cmUudHMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9vcHRpb24taGludC5zY3NzP2lubGluZSc7XG5cbi8qKlxuICogRGlzcGxheSBhIHRleHR1YWwgaGludCBpbnNpZGUgYSBgc2JiLWF1dG9jb21wbGV0ZWAgb3IgYSBgc2JiLXNlbGVjdGAuXG4gKlxuICogQHNsb3QgLSBVc2UgdGhlIHVubmFtZWQgc2xvdCB0byBkaXNwbGF5IHRoZSBoaW50IG1lc3NhZ2UuXG4gKi9cbmV4cG9ydCBjbGFzcyBTYmJPcHRpb25IaW50RWxlbWVudCBleHRlbmRzIFNiYk5lZ2F0aXZlTWl4aW4oU2JiRWxlbWVudCkge1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHJlYWRvbmx5IGVsZW1lbnROYW1lOiBzdHJpbmcgPSAnc2JiLW9wdGlvbi1oaW50JztcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gW3Vuc2FmZUNTUyhzdHlsZSldO1xuXG4gIHByaXZhdGUgX3ByZXZpb3VzU2l6ZTogc3RyaW5nIHwgdW5kZWZpbmVkO1xuXG4gIHB1YmxpYyBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcigpO1xuXG4gICAgdGhpcy5hZGRDb250cm9sbGVyKFxuICAgICAgbmV3IFNiYlByb3BlcnR5V2F0Y2hlckNvbnRyb2xsZXI8U2JiQXV0b2NvbXBsZXRlQmFzZUVsZW1lbnQgfCBTYmJTZWxlY3RFbGVtZW50PihcbiAgICAgICAgdGhpcyxcbiAgICAgICAgKCkgPT4gdGhpcy5jbG9zZXN0KCdzYmItYXV0b2NvbXBsZXRlLCBzYmItYXV0b2NvbXBsZXRlLWdyaWQsIHNiYi1zZWxlY3QnKSxcbiAgICAgICAge1xuICAgICAgICAgIHNpemU6IChlKSA9PiB7XG4gICAgICAgICAgICBpZiAodGhpcy5fcHJldmlvdXNTaXplKSB7XG4gICAgICAgICAgICAgIHRoaXMuaW50ZXJuYWxzLnN0YXRlcy5kZWxldGUoYHNpemUtJHt0aGlzLl9wcmV2aW91c1NpemV9YCk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgICB0aGlzLl9wcmV2aW91c1NpemUgPSBlLnNpemU7XG4gICAgICAgICAgICBpZiAodGhpcy5fcHJldmlvdXNTaXplKSB7XG4gICAgICAgICAgICAgIHRoaXMuaW50ZXJuYWxzLnN0YXRlcy5hZGQoYHNpemUtJHt0aGlzLl9wcmV2aW91c1NpemV9YCk7XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfSxcbiAgICAgICAgfSxcbiAgICAgICksXG4gICAgKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBvdmVycmlkZSByZW5kZXIoKTogVGVtcGxhdGVSZXN1bHQge1xuICAgIHJldHVybiBodG1sYFxuICAgICAgPGRpdiBjbGFzcz1cInNiYi1vcHRncm91cF9faWNvbi1zcGFjZVwiPjwvZGl2PlxuICAgICAgPHNwYW4gY2xhc3M9XCJzYmItb3B0aW9uLWhpbnRcIj5cbiAgICAgICAgPHNsb3Q+PC9zbG90PlxuICAgICAgPC9zcGFuPlxuICAgIGA7XG4gIH1cbn1cblxuZGVjbGFyZSBnbG9iYWwge1xuICBpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25hbWluZy1jb252ZW50aW9uXG4gICAgJ3NiYi1vcHRpb24taGludCc6IFNiYk9wdGlvbkhpbnRFbGVtZW50O1xuICB9XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7O0FDYUEsSUFBYSx1QkFBYixjQUEwQyxpQkFBaUIsV0FBVyxDQUFBOztBQUNwQyxPQUFBLGNBQXNCOzs7QUFDL0IsT0FBQSxTQUF5QixDQUFDLFVBQVUsb0JBQU0sQ0FBQzs7Q0FJbEUsY0FBQTtBQUNFLFNBQU87QUFFUCxPQUFLLGNBQ0gsSUFBSSw2QkFDRixZQUNNLEtBQUssUUFBUSxzREFBc0QsRUFDekUsRUFDRSxPQUFPLE1BQUs7QUFDVixPQUFJLEtBQUssY0FDUCxNQUFLLFVBQVUsT0FBTyxPQUFPLFFBQVEsS0FBSyxnQkFBZ0I7QUFFNUQsUUFBSyxnQkFBZ0IsRUFBRTtBQUN2QixPQUFJLEtBQUssY0FDUCxNQUFLLFVBQVUsT0FBTyxJQUFJLFFBQVEsS0FBSyxnQkFBZ0I7S0FHNUQsQ0FDRixDQUNGOztDQUdnQixTQUFNO0FBQ3ZCLFNBQU8sSUFBSSJ9
@@ -0,0 +1,131 @@
1
+ import { SbbOptionBaseElement } from "./option/option/option-base-element.js";
2
+ import { html, nothing, unsafeCSS } from "lit";
3
+ import { SbbPropertyWatcherController } from "./core.js";
4
+ import { SbbVisualCheckboxElement } from "./visual-checkbox.pure.js";
5
+ //#region src/elements/option/option/option.scss?inline
6
+ var option_default = ":host {\n --sbb-focus-outline-offset: var(--sbb-option-focus-outline-offset);\n display: block;\n background-color: var(--sbb-option-background-color);\n font-size: var(--sbb-option-font-size);\n letter-spacing: var(--sbb-typo-letter-spacing-text);\n}\n\n:host(:is(:state(negative),[state--negative])) {\n --sbb-option-color: var(--sbb-color-3-negative);\n --sbb-option-icon-color: var(--sbb-color-5);\n --sbb-option-background-color-hover: var(--sbb-color-midnight);\n --sbb-option-background-color-active: var(--sbb-background-color-4-negative);\n --sbb-option-disabled-border-color: var(--sbb-border-color-5);\n --sbb-option-disabled-background-color: var(--sbb-background-color-3-negative);\n --sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);\n}\n\n:host(:is(:state(size-s),[state--size-s])) {\n --sbb-option-min-height: var(--sbb-size-element-xxs);\n --sbb-option-focus-outline-offset: calc(-1 * var(--sbb-spacing-fixed-1x));\n --sbb-option-focus-outline-inset: 0 var(--sbb-spacing-fixed-1x);\n}\n\n:host(:is(:state(size-m),[state--size-m])) {\n --sbb-option-min-height: var(--sbb-size-element-s);\n --sbb-option-focus-outline-offset: inherit;\n --sbb-option-focus-outline-inset: var(--sbb-spacing-fixed-1x);\n}\n\n@media (any-hover: hover) {\n :host(:hover:not(:is(:state(disabled),[state--disabled]))) {\n --sbb-option-background-color: var(--sbb-option-background-color-hover);\n }\n}\n\n:host(:active:not(:is(:state(disabled),[state--disabled]))) {\n --sbb-option-background-color: var(--sbb-option-background-color-active);\n}\n\n:host(:not(:is(:state(disable-highlight),[state--disable-highlight]))) .sbb-option__label slot {\n display: none;\n}\n\n:host(:is(:state(disabled),[state--disabled])) {\n --sbb-option-cursor: var(--sbb-cursor-default);\n}\n@media (forced-colors: active) {\n :host(:is(:state(disabled),[state--disabled])) {\n --sbb-option-color: GrayText;\n }\n}\n\n:host(:is(:state(variant-select),[state--variant-select])) {\n --sbb-option-column-gap: var(--sbb-spacing-fixed-2x);\n --sbb-option-justify-content: space-between;\n}\n\n:host(:is(:state(variant-select),[state--variant-select]):is(:state(multiple),[state--multiple])) {\n --sbb-option-justify-content: start;\n}\n\n:host(:is(:state(active),[state--active])) {\n --sbb-option-focus-outline-color: var(--sbb-focus-outline-color);\n}\n\n:host(:not(:is(:is(:state(disabled),[state--disabled])))) .sbb-option__label--highlight {\n font-weight: bold;\n}\n@media (forced-colors: active) {\n :host(:not(:is(:is(:state(disabled),[state--disabled])))) .sbb-option__label--highlight {\n color: Highlight;\n }\n}\n\n.sbb-option {\n position: relative;\n display: flex;\n min-height: var(--sbb-option-min-height);\n align-items: center;\n column-gap: var(--sbb-option-column-gap);\n padding-inline: var(--sbb-option-padding-inline);\n justify-content: var(--sbb-option-justify-content);\n color: var(--sbb-option-color);\n cursor: var(--sbb-option-cursor);\n -webkit-tap-highlight-color: transparent;\n -webkit-text-fill-color: var(--sbb-option-color);\n}\n.sbb-option::after {\n content: \"\";\n display: block;\n position: absolute;\n inset: var(--sbb-option-focus-outline-inset);\n pointer-events: none;\n border: var(--sbb-focus-outline-width) solid var(--sbb-option-focus-outline-color);\n border-radius: var(--sbb-option-border-radius);\n}\n:host(:is(:state(disabled),[state--disabled]):not(:is(:state(multiple),[state--multiple]))) .sbb-option {\n position: relative;\n z-index: 0;\n}\n:host(:is(:state(disabled),[state--disabled]):not(:is(:state(multiple),[state--multiple]))) .sbb-option::before {\n content: \"\";\n display: block;\n position: absolute;\n inset: 0.375rem;\n border: var(--sbb-border-width-1x) dashed var(--sbb-option-disabled-border-color);\n border-radius: var(--sbb-border-radius-2x);\n background-color: var(--sbb-option-disabled-background-color);\n z-index: -1;\n}\n@media (forced-colors: active) {\n :host(:is(:state(disabled),[state--disabled]):not(:is(:state(multiple),[state--multiple]))) .sbb-option::before {\n border-color: GrayText;\n }\n}\n\n.sbb-option__icon {\n display: flex;\n min-width: var(--sbb-size-icon-ui-small);\n min-height: var(--sbb-size-icon-ui-small);\n color: var(--sbb-option-icon-color);\n}\n:host(:not(:is(:state(slotted-icon),[state--slotted-icon]), :is(:state(has-icon-name),[state--has-icon-name]))) .sbb-option__icon {\n display: var(--sbb-option-icon-container-display, none);\n}\n\n.sbb-option__label {\n text-overflow: var(--sbb-option-text-overflow);\n overflow: var(--sbb-option-overflow);\n white-space: var(--sbb-option-white-space, initial);\n}";
7
+ //#endregion
8
+ //#region src/elements/option/option/option.component.ts
9
+ /**
10
+ * It displays on option item which can be used in `sbb-select` or `sbb-autocomplete`.
11
+ *
12
+ * @slot - Use the unnamed slot to add content to the option label.
13
+ * @slot icon - Use this slot to provide an icon. If `icon-name` is set, a sbb-icon will be used.
14
+ * @cssprop [--sbb-option-icon-container-display=none] - Can be used to reserve space even
15
+ * when preserve-icon-space on autocomplete is not set or iconName is not set.
16
+ * @overrideType value - (T = string) | null
17
+ */
18
+ var SbbOptionElement = class extends SbbOptionBaseElement {
19
+ static {
20
+ this.elementName = "sbb-option";
21
+ }
22
+ static {
23
+ this.elementDependencies = [SbbVisualCheckboxElement];
24
+ }
25
+ static {
26
+ this.role = "option";
27
+ }
28
+ static {
29
+ this.styles = [unsafeCSS(option_default)];
30
+ }
31
+ static {
32
+ this.events = {
33
+ optionselectionchange: "optionselectionchange",
34
+ optionselected: "optionselected"
35
+ };
36
+ }
37
+ set _variant(variant) {
38
+ if (this._variantInternal) this.internals.states.delete(`variant-${this._variantInternal}`);
39
+ this._variantInternal = variant;
40
+ if (this._variantInternal) this.internals.states.add(`variant-${this._variantInternal}`);
41
+ }
42
+ get _variant() {
43
+ return this._variantInternal ?? null;
44
+ }
45
+ constructor() {
46
+ super();
47
+ this.optionId = `sbb-option`;
48
+ this.addController(new SbbPropertyWatcherController(this, () => this.closest("sbb-optgroup"), {
49
+ disabled: (p) => this.disabledFromGroup = p.disabled,
50
+ label: (p) => this.groupLabel = p.label
51
+ }));
52
+ this.addController(new SbbPropertyWatcherController(this, () => this.closest("sbb-select"), {
53
+ multiple: (ancestor) => {
54
+ this.toggleState("multiple", ancestor.multiple);
55
+ this.requestUpdate();
56
+ },
57
+ negative: (e) => this._handleNegativeChange(e)
58
+ }));
59
+ }
60
+ _isMultiple() {
61
+ return !this.hydrationRequired && this.matches?.(":is(:state(multiple),[state--multiple])");
62
+ }
63
+ _handleNegativeChange(ancestor) {
64
+ this.toggleState("negative", ancestor.negative);
65
+ this.requestUpdate();
66
+ }
67
+ connectedCallback() {
68
+ super.connectedCallback();
69
+ if (this.hydrationRequired) this.hydrationComplete.then(() => this._init());
70
+ else this._init();
71
+ }
72
+ _init() {
73
+ this._setVariantByContext();
74
+ this.handleHighlightState();
75
+ }
76
+ selectByClick(event) {
77
+ if (this.disabled || this.disabledFromGroup) {
78
+ event.stopPropagation();
79
+ return;
80
+ }
81
+ if (this._isMultiple()) {
82
+ event.stopPropagation();
83
+ this.selectViaUserInteraction(!this.selected);
84
+ } else this.selectViaUserInteraction(true);
85
+ }
86
+ selectViaUserInteraction(selected) {
87
+ super.selectViaUserInteraction(selected);
88
+ /** The optionselectionchange event is dispatched when the option selection status changes. */
89
+ this.dispatchEvent(new Event("optionselectionchange", {
90
+ bubbles: true,
91
+ composed: true
92
+ }));
93
+ }
94
+ _setVariantByContext() {
95
+ if (this.closest?.("sbb-autocomplete")) this._variant = "autocomplete";
96
+ else if (this.closest?.("sbb-select")) this._variant = "select";
97
+ }
98
+ handleHighlightState() {
99
+ if (this._variant !== "autocomplete") {
100
+ this.updateDisableHighlight(true);
101
+ return;
102
+ }
103
+ super.handleHighlightState();
104
+ }
105
+ renderIcon() {
106
+ return html`
107
+ <!-- Icon -->
108
+ ${!this._isMultiple() ? html` <span class="sbb-option__icon"> ${this.renderIconSlot()} </span>` : nothing}
109
+
110
+ <!-- Checkbox -->
111
+ ${this._isMultiple() ? html`
112
+ <sbb-visual-checkbox
113
+ ?checked=${this.selected}
114
+ ?disabled=${this.disabled || this.disabledFromGroup}
115
+ ?negative=${this.matches?.(":is(:state(negative),[state--negative])")}
116
+ ></sbb-visual-checkbox>
117
+ ` : nothing}
118
+ `;
119
+ }
120
+ renderLabel() {
121
+ if (this._variant !== "autocomplete") return nothing;
122
+ return super.renderLabel();
123
+ }
124
+ renderTick() {
125
+ return this._variant === "select" && !this._isMultiple() && this.selected ? html`<sbb-icon name="tick-small"></sbb-icon>` : nothing;
126
+ }
127
+ };
128
+ //#endregion
129
+ export { SbbOptionElement as t };
130
+
131
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"option.component-CV6cZnJe.js","names":[],"sources":["../../../src/elements/option/option/option.scss?inline","../../../src/elements/option/option/option.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-focus-outline-offset: var(--sbb-option-focus-outline-offset);\n\n  display: block;\n  background-color: var(--sbb-option-background-color);\n  font-size: var(--sbb-option-font-size);\n  letter-spacing: var(--sbb-typo-letter-spacing-text);\n}\n\n:host(:state(negative)) {\n  --sbb-option-color: var(--sbb-color-3-negative);\n  --sbb-option-icon-color: var(--sbb-color-5);\n  --sbb-option-background-color-hover: var(--sbb-color-midnight);\n  --sbb-option-background-color-active: var(--sbb-background-color-4-negative);\n  --sbb-option-disabled-border-color: var(--sbb-border-color-5);\n  --sbb-option-disabled-background-color: var(--sbb-background-color-3-negative);\n  --sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);\n}\n\n:host(:state(size-s)) {\n  --sbb-option-min-height: var(--sbb-size-element-xxs);\n  --sbb-option-focus-outline-offset: calc(-1 * var(--sbb-spacing-fixed-1x));\n  --sbb-option-focus-outline-inset: 0 var(--sbb-spacing-fixed-1x);\n}\n\n:host(:state(size-m)) {\n  --sbb-option-min-height: var(--sbb-size-element-s);\n  --sbb-option-focus-outline-offset: inherit;\n  --sbb-option-focus-outline-inset: var(--sbb-spacing-fixed-1x);\n}\n\n:host(:hover:not(:state(disabled))) {\n  @include sbb.hover-mq($hover: true) {\n    --sbb-option-background-color: var(--sbb-option-background-color-hover);\n  }\n}\n\n:host(:active:not(:state(disabled))) {\n  --sbb-option-background-color: var(--sbb-option-background-color-active);\n}\n\n// If highlighting is enabled, hide the original slot content\n:host(:not(:state(disable-highlight))) {\n  .sbb-option__label slot {\n    display: none;\n  }\n}\n\n:host(:state(disabled)) {\n  --sbb-option-cursor: var(--sbb-cursor-default);\n\n  @include sbb.if-forced-colors {\n    --sbb-option-color: GrayText;\n  }\n}\n\n:host(:state(variant-select)) {\n  --sbb-option-column-gap: var(--sbb-spacing-fixed-2x);\n  --sbb-option-justify-content: space-between;\n}\n\n:host(:state(variant-select):state(multiple)) {\n  --sbb-option-justify-content: start;\n}\n\n:host(:state(active)) {\n  --sbb-option-focus-outline-color: var(--sbb-focus-outline-color);\n}\n\n.sbb-option__label--highlight {\n  :host(:not(:is(:state(disabled)))) & {\n    @include sbb.text--bold;\n    @include sbb.if-forced-colors {\n      color: Highlight;\n    }\n  }\n}\n\n.sbb-option {\n  position: relative;\n  display: flex;\n  min-height: var(--sbb-option-min-height);\n  align-items: center;\n  column-gap: var(--sbb-option-column-gap);\n  padding-inline: var(--sbb-option-padding-inline);\n  justify-content: var(--sbb-option-justify-content);\n  color: var(--sbb-option-color);\n  cursor: var(--sbb-option-cursor);\n  -webkit-tap-highlight-color: transparent;\n  -webkit-text-fill-color: var(--sbb-option-color);\n\n  // We use the pseudo element to display the focus outline (inline in this case)\n  &::after {\n    content: '';\n    display: block;\n    position: absolute;\n    inset: var(--sbb-option-focus-outline-inset);\n    pointer-events: none;\n    border: var(--sbb-focus-outline-width) solid var(--sbb-option-focus-outline-color);\n    border-radius: var(--sbb-option-border-radius);\n  }\n\n  // Add inner border and background for disabled option when it's not multiple\n  :host(:state(disabled):not(:state(multiple))) & {\n    position: relative;\n    z-index: 0;\n\n    &::before {\n      content: '';\n      display: block;\n      position: absolute;\n      inset: #{sbb.px-to-rem-build(6)};\n      border: var(--sbb-border-width-1x) dashed var(--sbb-option-disabled-border-color);\n      border-radius: var(--sbb-border-radius-2x);\n      background-color: var(--sbb-option-disabled-background-color);\n      z-index: -1;\n\n      @include sbb.if-forced-colors {\n        border-color: GrayText;\n      }\n    }\n  }\n}\n\n.sbb-option__icon {\n  display: flex;\n  min-width: var(--sbb-size-icon-ui-small);\n  min-height: var(--sbb-size-icon-ui-small);\n  color: var(--sbb-option-icon-color);\n\n  :host(:not(:state(slotted-icon), :state(has-icon-name))) & {\n    // Can be overridden by the 'preserve-icon-space' on the autocomplete\n    display: var(--sbb-option-icon-container-display, none);\n  }\n}\n\n.sbb-option__label {\n  text-overflow: var(--sbb-option-text-overflow);\n  overflow: var(--sbb-option-overflow);\n  white-space: var(--sbb-option-white-space, initial);\n}\n","import { type CSSResultGroup, html, nothing, type TemplateResult, unsafeCSS } from 'lit';\n\nimport type { SbbAutocompleteElement } from '../../autocomplete.pure.ts';\nimport type { SbbElementType } from '../../core.ts';\nimport { SbbPropertyWatcherController } from '../../core.ts';\nimport type { SbbSelectElement } from '../../select.pure.ts';\nimport { SbbVisualCheckboxElement } from '../../visual-checkbox.pure.ts';\n\nimport { SbbOptionBaseElement } from './option-base-element.ts';\nimport style from './option.scss?inline';\n\nexport type SbbOptionVariant = 'autocomplete' | 'select' | null;\n\n/**\n * It displays on option item which can be used in `sbb-select` or `sbb-autocomplete`.\n *\n * @slot - Use the unnamed slot to add content to the option label.\n * @slot icon - Use this slot to provide an icon. If `icon-name` is set, a sbb-icon will be used.\n * @cssprop [--sbb-option-icon-container-display=none] - Can be used to reserve space even\n * when preserve-icon-space on autocomplete is not set or iconName is not set.\n * @overrideType value - (T = string) | null\n */\nexport class SbbOptionElement<T = string> extends SbbOptionBaseElement<T> {\n  public static override readonly elementName: string = 'sbb-option';\n  public static override elementDependencies: SbbElementType[] = [SbbVisualCheckboxElement];\n  public static override readonly role = 'option';\n  public static override styles: CSSResultGroup = [unsafeCSS(style)];\n  public static override readonly events = {\n    optionselectionchange: 'optionselectionchange',\n    optionselected: 'optionselected',\n  } as const;\n\n  protected optionId = `sbb-option`;\n\n  private set _variant(variant: SbbOptionVariant) {\n    if (this._variantInternal) {\n      this.internals.states.delete(`variant-${this._variantInternal}`);\n    }\n    this._variantInternal = variant;\n    if (this._variantInternal) {\n      this.internals.states.add(`variant-${this._variantInternal}`);\n    }\n  }\n  private get _variant(): SbbOptionVariant {\n    return this._variantInternal ?? null;\n  }\n  private _variantInternal?: SbbOptionVariant;\n\n  public constructor() {\n    super();\n    this.addController(\n      new SbbPropertyWatcherController(this, () => this.closest('sbb-optgroup'), {\n        disabled: (p) => (this.disabledFromGroup = p.disabled),\n        label: (p) => (this.groupLabel = p.label),\n      }),\n    );\n\n    this.addController(\n      new SbbPropertyWatcherController(this, () => this.closest('sbb-select'), {\n        multiple: (ancestor) => {\n          this.toggleState('multiple', ancestor.multiple);\n\n          // Multiple has to be propagated to sbb-visual-checkbox inside the option.\n          this.requestUpdate();\n        },\n        negative: (e) => this._handleNegativeChange(e),\n      }),\n    );\n  }\n\n  private _isMultiple(): boolean {\n    return !this.hydrationRequired && this.matches?.(':state(multiple)');\n  }\n\n  private _handleNegativeChange(ancestor: SbbAutocompleteElement | SbbSelectElement): void {\n    this.toggleState('negative', ancestor.negative);\n\n    // Negative has to be propagated to sbb-visual-checkbox inside the option.\n    this.requestUpdate();\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n\n    // We need to check highlight state both on slot change, but also when connecting\n    // the element to the DOM. The slot change events might be swallowed when using declarative\n    // shadow DOM with SSR or if the DOM is changed when disconnected.\n    if (this.hydrationRequired) {\n      this.hydrationComplete.then(() => this._init());\n    } else {\n      this._init();\n    }\n  }\n\n  private _init(): void {\n    this._setVariantByContext();\n    this.handleHighlightState();\n  }\n\n  protected selectByClick(event: MouseEvent): void {\n    if (this.disabled || this.disabledFromGroup) {\n      event.stopPropagation();\n      return;\n    }\n\n    if (this._isMultiple()) {\n      event.stopPropagation();\n      this.selectViaUserInteraction(!this.selected);\n    } else {\n      this.selectViaUserInteraction(true);\n    }\n  }\n\n  protected override selectViaUserInteraction(selected: boolean): void {\n    super.selectViaUserInteraction(selected);\n    /** The optionselectionchange event is dispatched when the option selection status changes. */\n    this.dispatchEvent(new Event('optionselectionchange', { bubbles: true, composed: true }));\n  }\n\n  private _setVariantByContext(): void {\n    if (this.closest?.('sbb-autocomplete')) {\n      this._variant = 'autocomplete';\n    } else if (this.closest?.('sbb-select')) {\n      this._variant = 'select';\n    }\n  }\n\n  protected override handleHighlightState(): void {\n    if (this._variant !== 'autocomplete') {\n      this.updateDisableHighlight(true);\n      return;\n    }\n\n    super.handleHighlightState();\n  }\n\n  protected override renderIcon(): TemplateResult {\n    return html`\n      <!-- Icon -->\n      ${!this._isMultiple()\n        ? html` <span class=\"sbb-option__icon\"> ${this.renderIconSlot()} </span>`\n        : nothing}\n\n      <!-- Checkbox -->\n      ${this._isMultiple()\n        ? html`\n            <sbb-visual-checkbox\n              ?checked=${this.selected}\n              ?disabled=${this.disabled || this.disabledFromGroup}\n              ?negative=${this.matches?.(':state(negative)')}\n            ></sbb-visual-checkbox>\n          `\n        : nothing}\n    `;\n  }\n\n  protected override renderLabel(): TemplateResult | typeof nothing {\n    if (this._variant !== 'autocomplete') {\n      return nothing;\n    }\n    return super.renderLabel();\n  }\n\n  protected override renderTick(): TemplateResult | typeof nothing {\n    return this._variant === 'select' && !this._isMultiple() && this.selected\n      ? html`<sbb-icon name=\"tick-small\"></sbb-icon>`\n      : nothing;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-option': SbbOptionElement;\n  }\n\n  interface GlobalEventHandlersEventMap {\n    optionselectionchange: Event;\n  }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;ACsBA,IAAa,mBAAb,cAAkD,qBAAuB;;AACvC,OAAA,cAAsB;;;AAC/B,OAAA,sBAAwC,CAAC,yBAAyB;;;AACzD,OAAA,OAAO;;;AAChB,OAAA,SAAyB,CAAC,UAAU,eAAM,CAAC;;;AAClC,OAAA,SAAS;GACvC,uBAAuB;GACvB,gBAAgB;GACR;;CAIV,IAAY,SAAS,SAAyB;AAC5C,MAAI,KAAK,iBACP,MAAK,UAAU,OAAO,OAAO,WAAW,KAAK,mBAAmB;AAElE,OAAK,mBAAmB;AACxB,MAAI,KAAK,iBACP,MAAK,UAAU,OAAO,IAAI,WAAW,KAAK,mBAAmB;;CAGjE,IAAY,WAAQ;AAClB,SAAO,KAAK,oBAAoB;;CAIlC,cAAA;AACE,SAAO;AAjBC,OAAA,WAAW;AAkBnB,OAAK,cACH,IAAI,6BAA6B,YAAY,KAAK,QAAQ,eAAe,EAAE;GACzE,WAAW,MAAO,KAAK,oBAAoB,EAAE;GAC7C,QAAQ,MAAO,KAAK,aAAa,EAAE;GACpC,CAAC,CACH;AAED,OAAK,cACH,IAAI,6BAA6B,YAAY,KAAK,QAAQ,aAAa,EAAE;GACvE,WAAW,aAAY;AACrB,SAAK,YAAY,YAAY,SAAS,SAAS;AAG/C,SAAK,eAAe;;GAEtB,WAAW,MAAM,KAAK,sBAAsB,EAAA;GAC7C,CAAC,CACH;;CAGK,cAAW;AACjB,SAAO,CAAC,KAAK,qBAAqB,KAAK,UAAU,0CAAmB;;CAG9D,sBAAsB,UAAmD;AAC/E,OAAK,YAAY,YAAY,SAAS,SAAS;AAG/C,OAAK,eAAe;;CAGN,oBAAiB;AAC/B,QAAM,mBAAmB;AAKzB,MAAI,KAAK,kBACP,MAAK,kBAAkB,WAAW,KAAK,OAAO,CAAC;MAE/C,MAAK,OAAO;;CAIR,QAAK;AACX,OAAK,sBAAsB;AAC3B,OAAK,sBAAsB;;CAGnB,cAAc,OAAiB;AACvC,MAAI,KAAK,YAAY,KAAK,mBAAmB;AAC3C,SAAM,iBAAiB;AACvB;;AAGF,MAAI,KAAK,aAAa,EAAE;AACtB,SAAM,iBAAiB;AACvB,QAAK,yBAAyB,CAAC,KAAK,SAAS;QAE7C,MAAK,yBAAyB,KAAK;;CAIpB,yBAAyB,UAAiB;AAC3D,QAAM,yBAAyB,SAAS;;AAExC,OAAK,cAAc,IAAI,MAAM,yBAAyB;GAAE,SAAS;GAAM,UAAU;GAAM,CAAC,CAAC;;CAGnF,uBAAoB;AAC1B,MAAI,KAAK,UAAU,mBAAmB,CACpC,MAAK,WAAW;WACP,KAAK,UAAU,aAAa,CACrC,MAAK,WAAW;;CAID,uBAAoB;AACrC,MAAI,KAAK,aAAa,gBAAgB;AACpC,QAAK,uBAAuB,KAAK;AACjC;;AAGF,QAAM,sBAAsB;;CAGX,aAAU;AAC3B,SAAO,IAAI;;QAEP,CAAC,KAAK,aAAa,GACjB,IAAI,oCAAoC,KAAK,gBAAgB,CAAA,YAC7D,QAAA;;;QAGF,KAAK,aAAa,GAChB,IAAI;;yBAEW,KAAK,SAAA;0BACJ,KAAK,YAAY,KAAK,kBAAA;0BACtB,KAAK,UAAU,0CAAmB,CAAA;;cAGlD,QAAA;;;CAIW,cAAW;AAC5B,MAAI,KAAK,aAAa,eACpB,QAAO;AAET,SAAO,MAAM,aAAa;;CAGT,aAAU;AAC3B,SAAO,KAAK,aAAa,YAAY,CAAC,KAAK,aAAa,IAAI,KAAK,WAC7D,IAAI,4CACJ"}
@@ -1,8 +1,8 @@
1
- import { t as SbbOptgroupBaseElement } from "./optgroup-base-element-BEG1P4gK.js";
1
+ import { t as SbbOptgroupBaseElement } from "./optgroup-base-element-Cq8DMPk9.js";
2
2
  import { SbbOptGroupElement } from "./option/optgroup/optgroup.component.js";
3
- import { t as SbbOptionHintElement } from "./option-hint.component-CcSUSwjN.js";
3
+ import { t as SbbOptionHintElement } from "./option-hint.component-B4PxB3BW.js";
4
4
  import { SbbOptionBaseElement } from "./option/option/option-base-element.js";
5
- import { t as SbbOptionElement } from "./option.component-BEbIEh5o.js";
5
+ import { t as SbbOptionElement } from "./option.component-CV6cZnJe.js";
6
6
  import "./option.pure.js";
7
7
  //#region src/elements/option.ts
8
8
  /** @entrypoint */
@@ -1,6 +1,6 @@
1
- import { t as SbbOptgroupBaseElement } from "./optgroup-base-element-BEG1P4gK.js";
1
+ import { t as SbbOptgroupBaseElement } from "./optgroup-base-element-Cq8DMPk9.js";
2
2
  import { SbbOptGroupElement } from "./option/optgroup/optgroup.component.js";
3
- import { t as SbbOptionHintElement } from "./option-hint.component-CcSUSwjN.js";
3
+ import { t as SbbOptionHintElement } from "./option-hint.component-B4PxB3BW.js";
4
4
  import { SbbOptionBaseElement } from "./option/option/option-base-element.js";
5
- import { t as SbbOptionElement } from "./option.component-BEbIEh5o.js";
5
+ import { t as SbbOptionElement } from "./option.component-CV6cZnJe.js";
6
6
  export { SbbOptGroupElement, SbbOptgroupBaseElement, SbbOptionBaseElement, SbbOptionElement, SbbOptionHintElement };
@@ -1757,6 +1757,7 @@ slot[name=error]::slotted(*) {
1757
1757
  --sbb-option-border-radius: var(--sbb-border-radius-4x);
1758
1758
  --sbb-option-icon-color: var(--sbb-color-metal);
1759
1759
  --sbb-option-icon-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));
1760
+ --sbb-option-focus-outline-offset: inherit;
1760
1761
  --sbb-option-focus-outline-color: transparent;
1761
1762
  --sbb-option-focus-outline-inset: var(--sbb-spacing-fixed-1x);
1762
1763
  --sbb-option-font-size: var(--sbb-text-font-size-s);
@@ -2595,18 +2596,6 @@ sbb-message > [slot=image] :is(sbb-image, img):not(.sbb-figure-overlap-image) {
2595
2596
  border-radius: var(--sbb-message-image-border-radius);
2596
2597
  }
2597
2598
 
2598
- :where(sbb-select, sbb-autocomplete, sbb-autocomplete-grid)[size=s] :where(sbb-option, sbb-autocomplete-grid-option) {
2599
- --sbb-option-min-height: var(--sbb-size-element-xxs);
2600
- --sbb-focus-outline-offset: calc(-1 * var(--sbb-spacing-fixed-1x));
2601
- --sbb-option-focus-outline-inset: 0 var(--sbb-spacing-fixed-1x);
2602
- }
2603
- :where(sbb-select, sbb-autocomplete, sbb-autocomplete-grid)[size=s] sbb-optgroup {
2604
- --sbb-optgroup-label-padding-end: var(--sbb-spacing-fixed-1x);
2605
- }
2606
- :where(sbb-select, sbb-autocomplete, sbb-autocomplete-grid)[size=s] sbb-option-hint {
2607
- --sbb-option-hint-padding-block-end: var(--sbb-spacing-fixed-1x);
2608
- }
2609
-
2610
2599
  .sbb-options-nowrap {
2611
2600
  --sbb-option-text-overflow: ellipsis;
2612
2601
  --sbb-option-overflow: hidden;
@@ -0,0 +1,108 @@
1
+ import { __esDecorate as e, __runInitializers as t } from "tslib";
2
+ import { html as n, nothing as r, unsafeCSS as i } from "lit";
3
+ import { property as a, state as o } from "lit/decorators.js";
4
+ import { SbbDisabledMixin as s, SbbElement as c, SbbPropertyWatcherController as l, forceType as u, isSafari as d } from "./core.js";
5
+ import { SbbDividerElement as f } from "./divider.pure.js";
6
+ //#region src/elements/option/optgroup/optgroup-base-element.scss?inline
7
+ var p = ":host{display:block}:host(:first-child){--sbb-optgroup-divider-display: none}:host(:is(:state(size-s),[state--size-s])){--sbb-optgroup-label-padding-end: var(--sbb-spacing-fixed-1x)}:host(:is(:state(size-m),[state--size-m])){--sbb-optgroup-label-padding-end: var(--sbb-spacing-fixed-2x)}:host(:is(:state(negative),[state--negative])){--sbb-optgroup-label-color: var(--sbb-color-5)}.sbb-optgroup{margin-block:var(--sbb-spacing-fixed-4x);margin-inline:var(--sbb-spacing-fixed-4x)}.sbb-optgroup__label{display:flex;column-gap:var(--sbb-spacing-responsive-xxxs);font-size:var(--sbb-optgroup-label-font-size);letter-spacing:var(--sbb-typo-letter-spacing-text);color:var(--sbb-optgroup-label-color);-webkit-text-fill-color:var(--sbb-optgroup-label-color);padding-inline:var(--sbb-optgroup-label-padding-inline);padding-block-end:var(--sbb-optgroup-label-padding-end)}.sbb-optgroup__divider{display:var(--sbb-optgroup-divider-display, block);padding-block:var(--sbb-options-panel-divider-margin-block)}.sbb-optgroup__icon-space{display:var(--sbb-option-icon-container-display, none);min-width:var(--sbb-size-icon-ui-small)}::slotted(sbb-divider){margin-block:var(--sbb-options-panel-divider-margin-block)}", m = d, h = (() => {
8
+ let d = s(c), h, g = [], _ = [], v, y = [], b = [];
9
+ return class extends d {
10
+ static {
11
+ let t = typeof Symbol == "function" && Symbol.metadata ? Object.create(d[Symbol.metadata] ?? null) : void 0;
12
+ h = [u(), a()], v = [o()], e(this, null, h, {
13
+ kind: "accessor",
14
+ name: "label",
15
+ static: !1,
16
+ private: !1,
17
+ access: {
18
+ has: (e) => "label" in e,
19
+ get: (e) => e.label,
20
+ set: (e, t) => {
21
+ e.label = t;
22
+ }
23
+ },
24
+ metadata: t
25
+ }, g, _), e(this, null, v, {
26
+ kind: "accessor",
27
+ name: "_inertAriaGroups",
28
+ static: !1,
29
+ private: !1,
30
+ access: {
31
+ has: (e) => "_inertAriaGroups" in e,
32
+ get: (e) => e._inertAriaGroups,
33
+ set: (e, t) => {
34
+ e._inertAriaGroups = t;
35
+ }
36
+ },
37
+ metadata: t
38
+ }, y, b), t && Object.defineProperty(this, Symbol.metadata, {
39
+ enumerable: !0,
40
+ configurable: !0,
41
+ writable: !0,
42
+ value: t
43
+ });
44
+ }
45
+ static {
46
+ this.role = m ? null : "group";
47
+ }
48
+ static {
49
+ this.elementDependencies = [f];
50
+ }
51
+ static {
52
+ this.styles = [i(p)];
53
+ }
54
+ #e;
55
+ get label() {
56
+ return this.#e;
57
+ }
58
+ set label(e) {
59
+ this.#e = e;
60
+ }
61
+ #t;
62
+ get _inertAriaGroups() {
63
+ return this.#t;
64
+ }
65
+ set _inertAriaGroups(e) {
66
+ this.#t = e;
67
+ }
68
+ constructor() {
69
+ super(), this.#e = t(this, g, ""), this.#t = (t(this, _), t(this, y, !1)), this._previousSize = t(this, b), this.addController(new l(this, () => this.closest("sbb-autocomplete, sbb-autocomplete-grid, sbb-select"), { size: (e) => {
70
+ this._previousSize && this.internals.states.delete(`size-${this._previousSize}`), this._previousSize = e.size, this._previousSize && this.internals.states.add(`size-${this._previousSize}`);
71
+ } })), m && (this.hydrationRequired ? this.hydrationComplete.then(() => this._inertAriaGroups = m) : this._inertAriaGroups = m);
72
+ }
73
+ connectedCallback() {
74
+ super.connectedCallback(), this._updateAriaLabel();
75
+ }
76
+ willUpdate(e) {
77
+ super.willUpdate(e), e.has("disabled") && (this._inertAriaGroups || (this.internals.ariaDisabled = this.disabled ? "true" : null)), e.has("label") && this._updateAriaLabel();
78
+ }
79
+ _handleSlotchange() {
80
+ this._updateAriaLabel(), this._highlightOptions(), this.dispatchEvent(new Event("ɵoptgroupslotchange"));
81
+ }
82
+ _updateAriaLabel() {
83
+ this.internals.ariaLabel = this._inertAriaGroups ? null : this.label;
84
+ }
85
+ _highlightOptions() {
86
+ let e = this.getAutocompleteParent();
87
+ if (!e) return;
88
+ let t = e.triggerElement?.value;
89
+ t && this.options.forEach((e) => e.highlight(t));
90
+ }
91
+ render() {
92
+ return n`
93
+ <div class="sbb-optgroup__divider">
94
+ <sbb-divider ?negative=${this.matches?.(":is(:state(negative),[state--negative])")}></sbb-divider>
95
+ </div>
96
+ ${this.label ? n`
97
+ <div class="sbb-optgroup__label" aria-hidden="true">
98
+ <div class="sbb-optgroup__icon-space"></div>
99
+ <span>${this.label}</span>
100
+ </div>
101
+ ` : r}
102
+ <slot @slotchange=${this._handleSlotchange}></slot>
103
+ `;
104
+ }
105
+ };
106
+ })();
107
+ //#endregion
108
+ export { h as t };
@@ -1,2 +1,2 @@
1
- import { t as e } from "../../optgroup-base-element-C6KwbQ0N.js";
1
+ import { t as e } from "../../optgroup-base-element-CrO_ydA8.js";
2
2
  export { e as SbbOptgroupBaseElement };
@@ -1,4 +1,4 @@
1
- import { t as e } from "../../optgroup-base-element-C6KwbQ0N.js";
1
+ import { t as e } from "../../optgroup-base-element-CrO_ydA8.js";
2
2
  import { SbbPropertyWatcherController as t } from "../../core.js";
3
3
  //#region src/elements/option/optgroup/optgroup.component.ts
4
4
  var n = class extends e {