@sbb-esta/lyne-elements 1.15.1 → 1.16.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/README.md CHANGED
@@ -22,12 +22,12 @@ Lyne Design Tokens and Lyne Components are available for developers and designer
22
22
 
23
23
  ## 🔗 Packages
24
24
 
25
- | Package | Description |
26
- | ---------------------------------- | --------------------------------------------------------------------------- |
27
- | `@lyne-esta/elements` | Web components built on top of the Lyne Design System |
28
- | `@lyne-esta/elements-experimental` | Web components that do not yet align with our architecture or testing goals |
29
- | `@lyne-esta/react` | React wrappers for `@lyne-esta/elements` |
30
- | `@lyne-esta/react-experimental` | React wrappers for `@lyne-esta/elements-experimental` |
25
+ | Package | Description |
26
+ | -------------------------------------- | --------------------------------------------------------------------------- |
27
+ | `@sbb-esta/lyne-elements` | Web components built on top of the Lyne Design System |
28
+ | `@sbb-esta/lyne-elements-experimental` | Web components that do not yet align with our architecture or testing goals |
29
+ | `@sbb-esta/lyne-react` | React wrappers for `@sbb-esta/lyne-elements` |
30
+ | `@sbb-esta/lyne-react-experimental` | React wrappers for `@sbb-esta/lyne-elements-experimental` |
31
31
 
32
32
  - [NPM Packages](https://www.npmjs.com/search?q=%40sbb-esta%2Flyne-)
33
33
 
@@ -0,0 +1,44 @@
1
+ @use './mixins/scrollbar';
2
+
3
+ .sbb-scrollbar,
4
+ .sbb-scrollbar-negative,
5
+ .sbb-scrollbar-thick,
6
+ .sbb-scrollbar-thick-negative,
7
+ .sbb-scrollbar-track-visible,
8
+ .sbb-scrollbar-negative-track-visible,
9
+ .sbb-scrollbar-thick-track-visible,
10
+ .sbb-scrollbar-thick-negative-track-visible {
11
+ @include scrollbar.scrollbar-rules;
12
+ }
13
+
14
+ .sbb-scrollbar {
15
+ @include scrollbar.scrollbar-variables($size: thin, $negative: false, $track-visible: false);
16
+ }
17
+
18
+ .sbb-scrollbar-negative {
19
+ @include scrollbar.scrollbar-variables($size: thin, $negative: true, $track-visible: false);
20
+ }
21
+
22
+ .sbb-scrollbar-thick {
23
+ @include scrollbar.scrollbar-variables($size: thick, $negative: false, $track-visible: false);
24
+ }
25
+
26
+ .sbb-scrollbar-thick-negative {
27
+ @include scrollbar.scrollbar-variables($size: thick, $negative: true, $track-visible: false);
28
+ }
29
+
30
+ .sbb-scrollbar-track-visible {
31
+ @include scrollbar.scrollbar-variables($size: thin, $negative: false, $track-visible: true);
32
+ }
33
+
34
+ .sbb-scrollbar-negative-track-visible {
35
+ @include scrollbar.scrollbar-variables($size: thin, $negative: true, $track-visible: true);
36
+ }
37
+
38
+ .sbb-scrollbar-thick-track-visible {
39
+ @include scrollbar.scrollbar-variables($size: thick, $negative: false, $track-visible: true);
40
+ }
41
+
42
+ .sbb-scrollbar-thick-negative-track-visible {
43
+ @include scrollbar.scrollbar-variables($size: thick, $negative: true, $track-visible: true);
44
+ }
@@ -7,4 +7,5 @@
7
7
  @use './animation';
8
8
  @use './layout';
9
9
  @use './lists';
10
+ @use './scrollbar';
10
11
  @use './table';
@@ -42888,6 +42888,26 @@
42888
42888
  }
42889
42889
  }
42890
42890
  },
42891
+ {
42892
+ "kind": "method",
42893
+ "name": "_patchInputValue",
42894
+ "privacy": "private",
42895
+ "return": {
42896
+ "type": {
42897
+ "text": "void"
42898
+ }
42899
+ }
42900
+ },
42901
+ {
42902
+ "kind": "method",
42903
+ "name": "_unpatchInputValue",
42904
+ "privacy": "private",
42905
+ "return": {
42906
+ "type": {
42907
+ "text": "void"
42908
+ }
42909
+ }
42910
+ },
42891
42911
  {
42892
42912
  "kind": "method",
42893
42913
  "name": "_checkAndUpdateInputEmpty",
@@ -68,6 +68,8 @@ export declare class SbbFormFieldElement extends SbbFormFieldElement_base {
68
68
  private _syncLabelInputReferences;
69
69
  private _registerInputListener;
70
70
  private _getInputForm;
71
+ private _patchInputValue;
72
+ private _unpatchInputValue;
71
73
  private _checkAndUpdateInputEmpty;
72
74
  private _isInputEmpty;
73
75
  private _isInputValueEmpty;
@@ -1 +1 @@
1
- {"version":3,"file":"form-field.d.ts","sourceRoot":"","sources":["../../../../../src/elements/form-field/form-field/form-field.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAY,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAC9F,OAAO,EAAQ,UAAU,EAAW,MAAM,KAAK,CAAC;AAchD,OAAO,eAAe,CAAC;;AAOvB;;;;;;;;GAQG;AACH,qBAGM,mBAAoB,SAAQ,wBAA+C;IAC/E,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,OAAO,CAAC,QAAQ,CAAC,6BAA6B,CAAmC;IAEjF,OAAO,CAAC,QAAQ,CAAC,uBAAuB,CAItC;IAEF,OAAO,CAAC,QAAQ,CAAC,sBAAsB,CAA6B;IAEpE,OAAO,CAAC,QAAQ,CAAC,oCAAoC,CAKnD;IAEF,OAAO,CAAC,QAAQ,CAAC,iCAAiC,CAQhD;IAEF;;;;OAIG;IACH,SACgB,UAAU,EAAE,MAAM,GAAG,SAAS,CAAU;IAExD,+CAA+C;IAC/C,SAEgB,QAAQ,EAAE,OAAO,CAAS;IAE1C,mCAAmC;IACnC,SAA6C,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,CAAO;IAEzE,0DAA0D;IAC1D,SAEgB,UAAU,EAAE,OAAO,CAAS;IAE5C;;+EAE2E;IAC3E,SAA6C,KAAK,EAAE,SAAS,GAAG,UAAU,CAAa;IAEvF,wFAAwF;IACxF,SAEgB,WAAW,EAAE,OAAO,CAAS;IAE7C,4FAA4F;IAC5F,SAEgB,aAAa,EAAE,OAAO,CAAS;IAE/C,qDAAqD;IAC5C,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAiB;IAEzD,oEAAoE;IACpE,OAAO,CAAC,6BAA6B,CAAC,CAAgB;IAEtD,8CAA8C;IACrC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAkE;IAElG,+CAA+C;IACtC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAoB;IAEpD,iCAAiC;IACjC,IAAW,YAAY,IAAI,gBAAgB,GAAG,iBAAiB,GAAG,WAAW,GAAG,SAAS,CAExF;IAED,OAAO,CAAC,MAAM,CAAyC;IACvD,OAAO,CAAC,SAAS,CAAmC;IAEpD;;OAEG;IACH,OAAO,CAAC,2BAA2B,CAM1B;IAET,OAAO,CAAC,qBAAqB,CAAyB;IAEtC,iBAAiB,IAAI,IAAI;cAStB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAQ5D,oBAAoB,IAAI,IAAI;IAM5C,OAAO,CAAC,YAAY;IAMpB,OAAO,CAAC,aAAa;IAMrB,OAAO,CAAC,mBAAmB;IAa3B,OAAO,CAAC,gBAAgB;IAUxB,OAAO,CAAC,kBAAkB;IAW1B;;OAEG;IACH,OAAO,CAAC,kBAAkB;IA4B1B,OAAO,CAAC,yBAAyB;IA4BjC,OAAO,CAAC,sBAAsB;IAuD9B,OAAO,CAAC,aAAa;IAOrB,OAAO,CAAC,yBAAyB;IAQjC,OAAO,CAAC,aAAa;IAerB,OAAO,CAAC,kBAAkB;IAK1B,OAAO,CAAC,YAAY;IAOpB,OAAO,CAAC,eAAe;IAevB;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAsB1B,OAAO,CAAC,qBAAqB;IAiB7B,qFAAqF;IAC9E,KAAK,IAAI,IAAI;IAIpB,4FAA4F;IACrF,KAAK,IAAI,IAAI;IAQpB;;;OAGG;IACI,eAAe,IAAI,gBAAgB,GAAG,iBAAiB,GAAG,WAAW,GAAG,SAAS;IAIxF,OAAO,CAAC,aAAa;cAMF,MAAM,IAAI,cAAc;CAmC5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gBAAgB,EAAE,mBAAmB,CAAC;KACvC;CACF"}
1
+ {"version":3,"file":"form-field.d.ts","sourceRoot":"","sources":["../../../../../src/elements/form-field/form-field/form-field.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAY,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAC9F,OAAO,EAAQ,UAAU,EAAW,MAAM,KAAK,CAAC;AAchD,OAAO,eAAe,CAAC;;AASvB;;;;;;;;GAQG;AACH,qBAGM,mBAAoB,SAAQ,wBAA+C;IAC/E,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,OAAO,CAAC,QAAQ,CAAC,6BAA6B,CAAmC;IAEjF,OAAO,CAAC,QAAQ,CAAC,uBAAuB,CAItC;IAEF,OAAO,CAAC,QAAQ,CAAC,sBAAsB,CAA6B;IAEpE,OAAO,CAAC,QAAQ,CAAC,oCAAoC,CAKnD;IAEF,OAAO,CAAC,QAAQ,CAAC,iCAAiC,CAQhD;IAEF;;;;OAIG;IACH,SACgB,UAAU,EAAE,MAAM,GAAG,SAAS,CAAU;IAExD,+CAA+C;IAC/C,SAEgB,QAAQ,EAAE,OAAO,CAAS;IAE1C,mCAAmC;IACnC,SAA6C,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,CAAO;IAEzE,0DAA0D;IAC1D,SAEgB,UAAU,EAAE,OAAO,CAAS;IAE5C;;+EAE2E;IAC3E,SAA6C,KAAK,EAAE,SAAS,GAAG,UAAU,CAAa;IAEvF,wFAAwF;IACxF,SAEgB,WAAW,EAAE,OAAO,CAAS;IAE7C,4FAA4F;IAC5F,SAEgB,aAAa,EAAE,OAAO,CAAS;IAE/C,qDAAqD;IAC5C,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAiB;IAEzD,oEAAoE;IACpE,OAAO,CAAC,6BAA6B,CAAC,CAAgB;IAEtD,8CAA8C;IACrC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAkE;IAElG,+CAA+C;IACtC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAoB;IAEpD,iCAAiC;IACjC,IAAW,YAAY,IAAI,gBAAgB,GAAG,iBAAiB,GAAG,WAAW,GAAG,SAAS,CAExF;IAED,OAAO,CAAC,MAAM,CAAyC;IACvD,OAAO,CAAC,SAAS,CAAmC;IAEpD;;OAEG;IACH,OAAO,CAAC,2BAA2B,CAM1B;IAET,OAAO,CAAC,qBAAqB,CAAyB;IAEtC,iBAAiB,IAAI,IAAI;cAStB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAQ5D,oBAAoB,IAAI,IAAI;IAS5C,OAAO,CAAC,YAAY;IAMpB,OAAO,CAAC,aAAa;IAMrB,OAAO,CAAC,mBAAmB;IAa3B,OAAO,CAAC,gBAAgB;IAUxB,OAAO,CAAC,kBAAkB;IAW1B;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAkC1B,OAAO,CAAC,yBAAyB;IA4BjC,OAAO,CAAC,sBAAsB;IAyD9B,OAAO,CAAC,aAAa;IASrB,OAAO,CAAC,gBAAgB;IA4BxB,OAAO,CAAC,kBAAkB;IAS1B,OAAO,CAAC,yBAAyB;IAQjC,OAAO,CAAC,aAAa;IAerB,OAAO,CAAC,kBAAkB;IAK1B,OAAO,CAAC,YAAY;IAOpB,OAAO,CAAC,eAAe;IAevB;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAsB1B,OAAO,CAAC,qBAAqB;IAiB7B,qFAAqF;IAC9E,KAAK,IAAI,IAAI;IAIpB,4FAA4F;IACrF,KAAK,IAAI,IAAI;IAQpB;;;OAGG;IACI,eAAe,IAAI,gBAAgB,GAAG,iBAAiB,GAAG,WAAW,GAAG,SAAS;IAIxF,OAAO,CAAC,aAAa;cAMF,MAAM,IAAI,cAAc;CAmC5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gBAAgB,EAAE,mBAAmB,CAAC;KACvC;CACF"}
@@ -539,6 +539,7 @@ const style = css`@charset "UTF-8";
539
539
  let nextId = 0;
540
540
  let nextFormFieldErrorId = 0;
541
541
  const supportedPopupTagNames = ["sbb-autocomplete", "sbb-autocomplete-grid", "sbb-select"];
542
+ const patchedInputs = /* @__PURE__ */ new WeakMap();
542
543
  let SbbFormFieldElement = (() => {
543
544
  var _errorSpace_accessor_storage, _optional_accessor_storage, _size_accessor_storage, _borderless_accessor_storage, _width_accessor_storage, _hiddenLabel_accessor_storage, _floatingLabel_accessor_storage, __errorElements_accessor_storage, __input_accessor_storage, __label_accessor_storage, _a;
544
545
  let _classDecorators = [customElement("sbb-form-field"), slotState()];
@@ -726,10 +727,13 @@ let SbbFormFieldElement = (() => {
726
727
  }
727
728
  }
728
729
  disconnectedCallback() {
729
- var _a2;
730
+ var _a2, _b;
730
731
  super.disconnectedCallback();
731
732
  (_a2 = this._formFieldAttributeObserver) == null ? void 0 : _a2.disconnect();
732
733
  this._inputAbortController.abort();
734
+ if (((_b = this._input) == null ? void 0 : _b.localName) === "input") {
735
+ this._unpatchInputValue();
736
+ }
733
737
  }
734
738
  _onPopupOpen({ target }) {
735
739
  if (supportedPopupTagNames.includes(target.localName)) {
@@ -769,8 +773,12 @@ let SbbFormFieldElement = (() => {
769
773
  */
770
774
  _onSlotInputChange(event) {
771
775
  var _a2, _b;
772
- this._input = event.target.assignedElements().find((e) => this._supportedInputElements.includes(e.localName));
776
+ const newInput = event.target.assignedElements().find((e) => this._supportedInputElements.includes(e.localName));
773
777
  this._assignSlots();
778
+ if (this._input && this._input.localName === "input" && newInput !== this._input) {
779
+ this._unpatchInputValue();
780
+ }
781
+ this._input = newInput;
774
782
  if (!this._input) {
775
783
  return;
776
784
  }
@@ -825,7 +833,9 @@ let SbbFormFieldElement = (() => {
825
833
  signal: this._inputAbortController.signal
826
834
  });
827
835
  let inputFocusElement = this._input;
828
- if (this._input.localName === "sbb-select") {
836
+ if (this._input.localName === "input") {
837
+ this._patchInputValue();
838
+ } else if (this._input.localName === "sbb-select") {
829
839
  this._input.addEventListener("stateChange", () => this._checkAndUpdateInputEmpty(), {
830
840
  signal: this._inputAbortController.signal
831
841
  });
@@ -848,6 +858,36 @@ let SbbFormFieldElement = (() => {
848
858
  }
849
859
  return (_a2 = this._input) == null ? void 0 : _a2.closest("form");
850
860
  }
861
+ // We need to patch the value property of the HTMLInputElement in order
862
+ // to be able to reset the floating label in the empty state.
863
+ _patchInputValue() {
864
+ const inputElement = this._input;
865
+ const originalDescriptor = Object.getOwnPropertyDescriptor(Object.getPrototypeOf(inputElement), "value");
866
+ if (!originalDescriptor || !originalDescriptor.set || !originalDescriptor.get) {
867
+ return;
868
+ }
869
+ patchedInputs.set(inputElement, originalDescriptor);
870
+ const { get: getter, set: setter } = originalDescriptor;
871
+ const checkAndUpdateInputEmpty = () => this._checkAndUpdateInputEmpty();
872
+ Object.defineProperty(inputElement, "value", {
873
+ ...originalDescriptor,
874
+ get() {
875
+ return getter.call(this);
876
+ },
877
+ set(newValue) {
878
+ setter.call(this, newValue);
879
+ checkAndUpdateInputEmpty();
880
+ }
881
+ });
882
+ }
883
+ _unpatchInputValue() {
884
+ const inputElement = this._input;
885
+ const originalDescriptor = patchedInputs.get(inputElement);
886
+ if (originalDescriptor) {
887
+ Object.defineProperty(inputElement, "value", originalDescriptor);
888
+ patchedInputs.delete(inputElement);
889
+ }
890
+ }
851
891
  _checkAndUpdateInputEmpty() {
852
892
  var _a2;
853
893
  this.toggleAttribute("data-input-empty", this._floatingLabelSupportedInputElements.includes((_a2 = this._input) == null ? void 0 : _a2.localName) && this._isInputEmpty());
@@ -1021,4 +1061,4 @@ let SbbFormFieldElement = (() => {
1021
1061
  export {
1022
1062
  SbbFormFieldElement
1023
1063
  };
1024
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"form-field.js","sources":["../../../../src/elements/form-field/form-field/form-field.ts"],"sourcesContent":["import { type CSSResultGroup, isServer, type PropertyValues, type TemplateResult } from 'lit';\nimport { html, LitElement, nothing } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\n\nimport type { SbbInputModality } from '../../core/a11y.js';\nimport { sbbInputModalityDetector } from '../../core/a11y.js';\nimport { SbbConnectedAbortController, SbbLanguageController } from '../../core/controllers.js';\nimport { forceType, slotState } from '../../core/decorators.js';\nimport { isFirefox, setOrRemoveAttribute } from '../../core/dom.js';\nimport { i18nOptional } from '../../core/i18n.js';\nimport { SbbHydrationMixin, SbbNegativeMixin } from '../../core/mixins.js';\nimport type { SbbSelectElement } from '../../select.js';\n\nimport style from './form-field.scss?lit&inline';\n\nimport '../../icon.js';\n\nlet nextId = 0;\nlet nextFormFieldErrorId = 0;\n\nconst supportedPopupTagNames = ['sbb-autocomplete', 'sbb-autocomplete-grid', 'sbb-select'];\n\n/**\n * It wraps an input element adding label, errors, icon, etc.\n *\n * @slot - Use this slot to render an input/select or a supported non-native element.\n * @slot label - Use this slot to render a label.\n * @slot prefix - Use this slot to render an icon on the left side of the input.\n * @slot suffix - Use this slot to render an icon on the right side of the input.\n * @slot error - Use this slot to render an error.\n */\nexport\n@customElement('sbb-form-field')\n@slotState()\nclass SbbFormFieldElement extends SbbNegativeMixin(SbbHydrationMixin(LitElement)) {\n  public static override styles: CSSResultGroup = style;\n\n  private readonly _supportedNativeInputElements = ['input', 'select', 'textarea'];\n  // List of supported element selectors in unnamed slot\n  private readonly _supportedInputElements = [\n    ...this._supportedNativeInputElements,\n    'sbb-select',\n    'sbb-slider',\n  ];\n  // List of elements that should not focus input on click\n  private readonly _excludedFocusElements = ['button', 'sbb-popover'];\n\n  private readonly _floatingLabelSupportedInputElements = [\n    'input',\n    'select',\n    'sbb-select',\n    'textarea',\n  ];\n\n  private readonly _floatingLabelSupportedInputTypes = [\n    'email',\n    'number',\n    'password',\n    'search',\n    'tel',\n    'text',\n    'url',\n  ];\n\n  /**\n   * Whether to reserve space for an error message.\n   * `none` does not reserve any space.\n   * `reserve` does reserve one row for an error message.\n   */\n  @property({ attribute: 'error-space', reflect: true })\n  public accessor errorSpace: 'none' | 'reserve' = 'none';\n\n  /** Indicates whether the input is optional. */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor optional: boolean = false;\n\n  /** Size variant, either l or m. */\n  @property({ reflect: true }) public accessor size: 'l' | 'm' | 's' = 'm';\n\n  /** Whether to display the form field without a border. */\n  @forceType()\n  @property({ reflect: true, type: Boolean })\n  public accessor borderless: boolean = false;\n\n  /** Defines the width of the component:\n   * - `default`: the component has defined width and min-width;\n   * - `collapse`: the component adapts itself to its inner input content. */\n  @property({ reflect: true }) public accessor width: 'default' | 'collapse' = 'default';\n\n  /** Whether to visually hide the label. If hidden, screen readers will still read it. */\n  @forceType()\n  @property({ attribute: 'hidden-label', reflect: true, type: Boolean })\n  public accessor hiddenLabel: boolean = false;\n\n  /** Whether the label should float. If activated, the placeholder of the input is hidden. */\n  @forceType()\n  @property({ attribute: 'floating-label', reflect: true, type: Boolean })\n  public accessor floatingLabel: boolean = false;\n\n  /** It is used internally to get the `error` slot. */\n  @state() private accessor _errorElements: Element[] = [];\n\n  /** Original aria-describedby value of the slotted input element. */\n  private _originalInputAriaDescribedby?: string | null;\n\n  /** Reference to the slotted input element. */\n  @state() private accessor _input!: HTMLInputElement | HTMLSelectElement | HTMLElement | undefined;\n\n  /** Reference to the slotted label elements. */\n  @state() private accessor _label!: HTMLLabelElement;\n\n  /** Returns the input element. */\n  public get inputElement(): HTMLInputElement | HTMLSelectElement | HTMLElement | undefined {\n    return this._input;\n  }\n\n  private _abort = new SbbConnectedAbortController(this);\n  private _language = new SbbLanguageController(this);\n\n  /**\n   * Listens to the changes on `readonly` and `disabled` attributes of `<input>`.\n   */\n  private _formFieldAttributeObserver = !isServer\n    ? new MutationObserver((mutations: MutationRecord[]) => {\n        if (mutations.some((m) => m.type === 'attributes')) {\n          this._readInputState();\n        }\n      })\n    : null;\n\n  private _inputAbortController = new AbortController();\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    const signal = this._abort.signal;\n    this.addEventListener('willOpen', (e: CustomEvent<void>) => this._onPopupOpen(e), { signal });\n    this.addEventListener('didClose', (e: CustomEvent<void>) => this._onPopupClose(e), { signal });\n    this._registerInputListener();\n    this._syncNegative();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('negative')) {\n      this._syncNegative();\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._formFieldAttributeObserver?.disconnect();\n    this._inputAbortController.abort();\n  }\n\n  private _onPopupOpen({ target }: CustomEvent<void>): void {\n    if (supportedPopupTagNames.includes((target as HTMLElement).localName)) {\n      this.toggleAttribute('data-has-popup-open', true);\n    }\n  }\n\n  private _onPopupClose({ target }: CustomEvent<void>): void {\n    if (supportedPopupTagNames.includes((target as HTMLElement).localName)) {\n      this.removeAttribute('data-has-popup-open');\n    }\n  }\n\n  private _handleWrapperClick(event: Event): void {\n    if (this._isButtonOrPopup(event)) {\n      return;\n    }\n\n    if (this._input?.localName === 'sbb-select') {\n      this._input.click();\n      this._input.focus();\n    } else if ((event.target as Element).localName !== 'label') {\n      this._input?.focus();\n    }\n  }\n\n  private _isButtonOrPopup(event: Event): boolean {\n    return event\n      .composedPath()\n      .some(\n        (el) =>\n          (el instanceof window.HTMLElement && el.getAttribute('role') === 'button') ||\n          this._excludedFocusElements.includes((el as HTMLElement).localName),\n      );\n  }\n\n  private _onSlotLabelChange(): void {\n    const labels = Array.from(this.querySelectorAll('label'));\n    if (import.meta.env.DEV && labels.length > 1) {\n      console.warn(\n        `Detected more than one label in sbb-form-field#${this.id}. Only one label is supported.`,\n      );\n    }\n    this._label = labels[0];\n    this._syncLabelInputReferences();\n  }\n\n  /**\n   * It is used internally to assign the attributes of `<input>` to `_id` and `_input` and to observe the native readonly and disabled attributes.\n   */\n  private _onSlotInputChange(event: Event): void {\n    this._input = (event.target as HTMLSlotElement)\n      .assignedElements()\n      .find((e): e is HTMLElement => this._supportedInputElements.includes(e.localName));\n    this._assignSlots();\n\n    if (!this._input) {\n      return;\n    }\n\n    this._originalInputAriaDescribedby = this._input.getAttribute('aria-describedby');\n    this._applyAriaDescribedby();\n    this._readInputState();\n    this._registerInputListener();\n\n    if (this._input.localName === 'textarea') {\n      this._input.setAttribute('rows', this._input.getAttribute('rows') || '3');\n    }\n\n    this._formFieldAttributeObserver?.disconnect();\n    this._formFieldAttributeObserver?.observe(this._input, {\n      attributes: true,\n      attributeFilter: ['readonly', 'disabled', 'class', 'data-sbb-invalid'],\n    });\n    this.setAttribute('data-input-type', this._input.localName);\n    this._syncLabelInputReferences();\n  }\n\n  private _syncLabelInputReferences(): void {\n    if (!this._input || !this._label) {\n      return;\n    }\n\n    if (this._supportedNativeInputElements.includes(this._input.localName)) {\n      // For native input elements we use the `for` attribute on the label to reference the input\n      // via id reference.\n      if (!this._input.id) {\n        this._input.id = `sbb-form-field-input-${nextId++}`;\n      }\n\n      this._label.htmlFor = this._input.id;\n    } else {\n      // For non-native input elements, that do not support references via the label for attribute,\n      // we use aria-labelledby on the input element to reference the label element via id.\n      if (!this._label.id) {\n        this._label.id = `sbb-form-field-label-${nextId++}`;\n      }\n      const labelledby =\n        this._input\n          .getAttribute('aria-labelledby')\n          ?.split(' ')\n          .filter((l) => !!l && l !== this._label!.id) ?? [];\n      this._input.setAttribute('aria-labelledby', [...labelledby, this._label.id].join(' '));\n    }\n  }\n\n  private _registerInputListener(): void {\n    if (!this._input) {\n      return;\n    }\n    this._inputAbortController.abort();\n    this._inputAbortController = new AbortController();\n    this._checkAndUpdateInputEmpty();\n\n    // Timeout needed to have value updated\n    this._getInputForm()?.addEventListener('reset', () => setTimeout(() => this.reset()), {\n      signal: this._inputAbortController.signal,\n    });\n\n    this._input.addEventListener('input', () => this._checkAndUpdateInputEmpty(), {\n      signal: this._inputAbortController.signal,\n    });\n\n    this._input.addEventListener('blur', () => this._checkAndUpdateInputEmpty(), {\n      signal: this._inputAbortController.signal,\n    });\n\n    let inputFocusElement = this._input;\n\n    if (this._input.localName === 'sbb-select') {\n      this._input.addEventListener('stateChange', () => this._checkAndUpdateInputEmpty(), {\n        signal: this._inputAbortController.signal,\n      });\n\n      inputFocusElement = (this._input as SbbSelectElement).inputElement;\n    }\n\n    inputFocusElement.addEventListener(\n      'focusin',\n      () => {\n        this.toggleAttribute('data-input-focused', true);\n        this.setAttribute(\n          'data-focus-origin',\n          (sbbInputModalityDetector.mostRecentModality as SbbInputModality) ?? '',\n        );\n      },\n      {\n        signal: this._inputAbortController.signal,\n      },\n    );\n\n    inputFocusElement.addEventListener(\n      'focusout',\n      () =>\n        ['data-focus-origin', 'data-input-focused'].forEach((name) => this.removeAttribute(name)),\n      {\n        signal: this._inputAbortController.signal,\n      },\n    );\n  }\n\n  private _getInputForm(): HTMLFormElement | null | undefined {\n    if (this._input instanceof HTMLInputElement || this._input instanceof HTMLSelectElement) {\n      return this._input.form;\n    }\n    return this._input?.closest('form');\n  }\n\n  private _checkAndUpdateInputEmpty(): void {\n    this.toggleAttribute(\n      'data-input-empty',\n      this._floatingLabelSupportedInputElements.includes(this._input?.localName as string) &&\n        this._isInputEmpty(),\n    );\n  }\n\n  private _isInputEmpty(): boolean {\n    if (this._input instanceof HTMLInputElement) {\n      return (\n        this._floatingLabelSupportedInputTypes.includes(this._input.type) &&\n        this._isInputValueEmpty()\n      );\n    } else if (this._input instanceof HTMLSelectElement) {\n      return this._input.selectedOptions?.item(0)?.label?.trim() === '';\n    } else if (this._input?.localName === 'sbb-select') {\n      return (this._input as SbbSelectElement).getDisplayValue()?.trim() === '';\n    } else {\n      return this._isInputValueEmpty();\n    }\n  }\n\n  private _isInputValueEmpty(): boolean {\n    const value = (this._input as { value: string }).value;\n    return ['', undefined, null].includes(value) || (Array.isArray(value) && value.length === 0);\n  }\n\n  private _assignSlots(): void {\n    this.querySelectorAll('label:not([slot])').forEach((e) => e.setAttribute('slot', 'label'));\n    this.querySelectorAll('sbb-form-error:not([slot])').forEach((e) =>\n      e.setAttribute('slot', 'error'),\n    );\n  }\n\n  private _readInputState(): void {\n    if (!this._input) {\n      return;\n    }\n    this.toggleAttribute('data-readonly', this._input.hasAttribute('readonly'));\n    this.toggleAttribute('data-disabled', this._input.hasAttribute('disabled'));\n    this.toggleAttribute(\n      'data-invalid',\n      this._input.hasAttribute('data-sbb-invalid') ||\n        this._input.classList.contains('sbb-invalid') ||\n        (this._input.classList.contains('ng-touched') &&\n          this._input.classList.contains('ng-invalid')),\n    );\n  }\n\n  /**\n   * It is used internally to set the aria-describedby attribute for the slotted input referencing available <sbb-form-error> instances.\n   */\n  private _onSlotErrorChange(event: Event): void {\n    this._errorElements = (event.target as HTMLSlotElement).assignedElements();\n\n    for (const el of this._errorElements) {\n      // Although a form error assigns an id itself, we need to be earlier by creating one here\n      if (!el.id) {\n        el.id = `sbb-form-field-error-${++nextFormFieldErrorId}`;\n      }\n      if (!el.role) {\n        // Instead of defining a container with an aria-live region as expected, we had to change\n        // setting it for every slotted element to properly work in all browsers and screen reader combinations.\n        el.role = 'status';\n        if (isFirefox) {\n          el.setAttribute('role', 'status');\n        }\n      }\n    }\n    this._applyAriaDescribedby();\n    this.toggleAttribute('data-has-error', !!this._errorElements.length);\n    this._syncNegative();\n  }\n\n  private _applyAriaDescribedby(): void {\n    const ids = [];\n\n    if (this._originalInputAriaDescribedby) {\n      ids.push(this._originalInputAriaDescribedby);\n    }\n\n    if (this._errorElements.length) {\n      this._errorElements.forEach((e) => ids.push(e.id));\n    }\n\n    const ariaDescribedby = ids.join(' ');\n    if (this._input) {\n      setOrRemoveAttribute(this._input, 'aria-describedby', ariaDescribedby);\n    }\n  }\n\n  /** Manually reset the form field. Currently, this only resets the floating label. */\n  public reset(): void {\n    this._checkAndUpdateInputEmpty();\n  }\n\n  /** Manually clears the input value. It only works for inputs, selects are not supported. */\n  public clear(): void {\n    if ((this._input?.localName as string) !== 'input') {\n      return;\n    }\n    (this._input as { value: string }).value = '';\n    this._checkAndUpdateInputEmpty();\n  }\n\n  /**\n   * Returns the input element.\n   * @deprecated Use the 'inputElement' property instead\n   */\n  public getInputElement(): HTMLInputElement | HTMLSelectElement | HTMLElement | undefined {\n    return this._input;\n  }\n\n  private _syncNegative(): void {\n    this.querySelectorAll?.(\n      'sbb-form-error,sbb-mini-button,sbb-popover-trigger,sbb-form-field-clear,sbb-datepicker-next-day,sbb-datepicker-previous-day,sbb-datepicker-toggle,sbb-select,sbb-autocomplete,sbb-autocomplete-grid',\n    ).forEach((element) => element.toggleAttribute('negative', this.negative));\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-form-field__space-wrapper\">\n        ${/* Queried by id from the autocomplete/select to be used as the anchor element */ ''}\n        <div @click=${this._handleWrapperClick} class=\"sbb-form-field__wrapper\" id=\"overlay-anchor\">\n          <slot name=\"prefix\" @slotchange=${this._syncNegative}></slot>\n          <div class=\"sbb-form-field__input-container\">\n            <span class=\"sbb-form-field__label-spacer\" aria-hidden=\"true\"></span>\n            <span class=\"sbb-form-field__label\">\n              <span class=\"sbb-form-field__label-ellipsis\">\n                <slot name=\"label\" @slotchange=${this._onSlotLabelChange}></slot>\n                ${this.optional\n                  ? html` <span aria-hidden=\"true\"> ${i18nOptional[this._language.current]} </span>`\n                  : nothing}\n              </span>\n            </span>\n            <div class=\"sbb-form-field__input\">\n              <slot @slotchange=${this._onSlotInputChange}></slot>\n            </div>\n            ${['select', 'sbb-select'].includes(this._input?.localName as string)\n              ? html`<sbb-icon\n                  name=\"chevron-small-down-small\"\n                  class=\"sbb-form-field__select-input-icon\"\n                ></sbb-icon>`\n              : nothing}\n          </div>\n          <slot name=\"suffix\" @slotchange=${this._syncNegative}></slot>\n        </div>\n\n        <div class=\"sbb-form-field__error\">\n          <slot name=\"error\" @slotchange=${this._onSlotErrorChange}></slot>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-form-field': SbbFormFieldElement;\n  }\n}\n"],"names":["_a"],"mappings":"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"}
1064
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"form-field.js","sources":["../../../../src/elements/form-field/form-field/form-field.ts"],"sourcesContent":["import { type CSSResultGroup, isServer, type PropertyValues, type TemplateResult } from 'lit';\nimport { html, LitElement, nothing } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\n\nimport type { SbbInputModality } from '../../core/a11y.js';\nimport { sbbInputModalityDetector } from '../../core/a11y.js';\nimport { SbbConnectedAbortController, SbbLanguageController } from '../../core/controllers.js';\nimport { forceType, slotState } from '../../core/decorators.js';\nimport { isFirefox, setOrRemoveAttribute } from '../../core/dom.js';\nimport { i18nOptional } from '../../core/i18n.js';\nimport { SbbHydrationMixin, SbbNegativeMixin } from '../../core/mixins.js';\nimport type { SbbSelectElement } from '../../select.js';\n\nimport style from './form-field.scss?lit&inline';\n\nimport '../../icon.js';\n\nlet nextId = 0;\nlet nextFormFieldErrorId = 0;\n\nconst supportedPopupTagNames = ['sbb-autocomplete', 'sbb-autocomplete-grid', 'sbb-select'];\n\nconst patchedInputs = new WeakMap<HTMLInputElement, PropertyDescriptor>();\n\n/**\n * It wraps an input element adding label, errors, icon, etc.\n *\n * @slot - Use this slot to render an input/select or a supported non-native element.\n * @slot label - Use this slot to render a label.\n * @slot prefix - Use this slot to render an icon on the left side of the input.\n * @slot suffix - Use this slot to render an icon on the right side of the input.\n * @slot error - Use this slot to render an error.\n */\nexport\n@customElement('sbb-form-field')\n@slotState()\nclass SbbFormFieldElement extends SbbNegativeMixin(SbbHydrationMixin(LitElement)) {\n  public static override styles: CSSResultGroup = style;\n\n  private readonly _supportedNativeInputElements = ['input', 'select', 'textarea'];\n  // List of supported element selectors in unnamed slot\n  private readonly _supportedInputElements = [\n    ...this._supportedNativeInputElements,\n    'sbb-select',\n    'sbb-slider',\n  ];\n  // List of elements that should not focus input on click\n  private readonly _excludedFocusElements = ['button', 'sbb-popover'];\n\n  private readonly _floatingLabelSupportedInputElements = [\n    'input',\n    'select',\n    'sbb-select',\n    'textarea',\n  ];\n\n  private readonly _floatingLabelSupportedInputTypes = [\n    'email',\n    'number',\n    'password',\n    'search',\n    'tel',\n    'text',\n    'url',\n  ];\n\n  /**\n   * Whether to reserve space for an error message.\n   * `none` does not reserve any space.\n   * `reserve` does reserve one row for an error message.\n   */\n  @property({ attribute: 'error-space', reflect: true })\n  public accessor errorSpace: 'none' | 'reserve' = 'none';\n\n  /** Indicates whether the input is optional. */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor optional: boolean = false;\n\n  /** Size variant, either l or m. */\n  @property({ reflect: true }) public accessor size: 'l' | 'm' | 's' = 'm';\n\n  /** Whether to display the form field without a border. */\n  @forceType()\n  @property({ reflect: true, type: Boolean })\n  public accessor borderless: boolean = false;\n\n  /** Defines the width of the component:\n   * - `default`: the component has defined width and min-width;\n   * - `collapse`: the component adapts itself to its inner input content. */\n  @property({ reflect: true }) public accessor width: 'default' | 'collapse' = 'default';\n\n  /** Whether to visually hide the label. If hidden, screen readers will still read it. */\n  @forceType()\n  @property({ attribute: 'hidden-label', reflect: true, type: Boolean })\n  public accessor hiddenLabel: boolean = false;\n\n  /** Whether the label should float. If activated, the placeholder of the input is hidden. */\n  @forceType()\n  @property({ attribute: 'floating-label', reflect: true, type: Boolean })\n  public accessor floatingLabel: boolean = false;\n\n  /** It is used internally to get the `error` slot. */\n  @state() private accessor _errorElements: Element[] = [];\n\n  /** Original aria-describedby value of the slotted input element. */\n  private _originalInputAriaDescribedby?: string | null;\n\n  /** Reference to the slotted input element. */\n  @state() private accessor _input!: HTMLInputElement | HTMLSelectElement | HTMLElement | undefined;\n\n  /** Reference to the slotted label elements. */\n  @state() private accessor _label!: HTMLLabelElement;\n\n  /** Returns the input element. */\n  public get inputElement(): HTMLInputElement | HTMLSelectElement | HTMLElement | undefined {\n    return this._input;\n  }\n\n  private _abort = new SbbConnectedAbortController(this);\n  private _language = new SbbLanguageController(this);\n\n  /**\n   * Listens to the changes on `readonly` and `disabled` attributes of `<input>`.\n   */\n  private _formFieldAttributeObserver = !isServer\n    ? new MutationObserver((mutations: MutationRecord[]) => {\n        if (mutations.some((m) => m.type === 'attributes')) {\n          this._readInputState();\n        }\n      })\n    : null;\n\n  private _inputAbortController = new AbortController();\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    const signal = this._abort.signal;\n    this.addEventListener('willOpen', (e: CustomEvent<void>) => this._onPopupOpen(e), { signal });\n    this.addEventListener('didClose', (e: CustomEvent<void>) => this._onPopupClose(e), { signal });\n    this._registerInputListener();\n    this._syncNegative();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('negative')) {\n      this._syncNegative();\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._formFieldAttributeObserver?.disconnect();\n    this._inputAbortController.abort();\n    if (this._input?.localName === 'input') {\n      this._unpatchInputValue();\n    }\n  }\n\n  private _onPopupOpen({ target }: CustomEvent<void>): void {\n    if (supportedPopupTagNames.includes((target as HTMLElement).localName)) {\n      this.toggleAttribute('data-has-popup-open', true);\n    }\n  }\n\n  private _onPopupClose({ target }: CustomEvent<void>): void {\n    if (supportedPopupTagNames.includes((target as HTMLElement).localName)) {\n      this.removeAttribute('data-has-popup-open');\n    }\n  }\n\n  private _handleWrapperClick(event: Event): void {\n    if (this._isButtonOrPopup(event)) {\n      return;\n    }\n\n    if (this._input?.localName === 'sbb-select') {\n      this._input.click();\n      this._input.focus();\n    } else if ((event.target as Element).localName !== 'label') {\n      this._input?.focus();\n    }\n  }\n\n  private _isButtonOrPopup(event: Event): boolean {\n    return event\n      .composedPath()\n      .some(\n        (el) =>\n          (el instanceof window.HTMLElement && el.getAttribute('role') === 'button') ||\n          this._excludedFocusElements.includes((el as HTMLElement).localName),\n      );\n  }\n\n  private _onSlotLabelChange(): void {\n    const labels = Array.from(this.querySelectorAll('label'));\n    if (import.meta.env.DEV && labels.length > 1) {\n      console.warn(\n        `Detected more than one label in sbb-form-field#${this.id}. Only one label is supported.`,\n      );\n    }\n    this._label = labels[0];\n    this._syncLabelInputReferences();\n  }\n\n  /**\n   * It is used internally to assign the attributes of `<input>` to `_id` and `_input` and to observe the native readonly and disabled attributes.\n   */\n  private _onSlotInputChange(event: Event): void {\n    const newInput = (event.target as HTMLSlotElement)\n      .assignedElements()\n      .find((e): e is HTMLElement => this._supportedInputElements.includes(e.localName));\n    this._assignSlots();\n\n    if (this._input && this._input.localName === 'input' && newInput !== this._input) {\n      this._unpatchInputValue();\n    }\n\n    this._input = newInput;\n\n    if (!this._input) {\n      return;\n    }\n\n    this._originalInputAriaDescribedby = this._input.getAttribute('aria-describedby');\n    this._applyAriaDescribedby();\n    this._readInputState();\n    this._registerInputListener();\n\n    if (this._input.localName === 'textarea') {\n      this._input.setAttribute('rows', this._input.getAttribute('rows') || '3');\n    }\n\n    this._formFieldAttributeObserver?.disconnect();\n    this._formFieldAttributeObserver?.observe(this._input, {\n      attributes: true,\n      attributeFilter: ['readonly', 'disabled', 'class', 'data-sbb-invalid'],\n    });\n    this.setAttribute('data-input-type', this._input.localName);\n    this._syncLabelInputReferences();\n  }\n\n  private _syncLabelInputReferences(): void {\n    if (!this._input || !this._label) {\n      return;\n    }\n\n    if (this._supportedNativeInputElements.includes(this._input.localName)) {\n      // For native input elements we use the `for` attribute on the label to reference the input\n      // via id reference.\n      if (!this._input.id) {\n        this._input.id = `sbb-form-field-input-${nextId++}`;\n      }\n\n      this._label.htmlFor = this._input.id;\n    } else {\n      // For non-native input elements, that do not support references via the label for attribute,\n      // we use aria-labelledby on the input element to reference the label element via id.\n      if (!this._label.id) {\n        this._label.id = `sbb-form-field-label-${nextId++}`;\n      }\n      const labelledby =\n        this._input\n          .getAttribute('aria-labelledby')\n          ?.split(' ')\n          .filter((l) => !!l && l !== this._label!.id) ?? [];\n      this._input.setAttribute('aria-labelledby', [...labelledby, this._label.id].join(' '));\n    }\n  }\n\n  private _registerInputListener(): void {\n    if (!this._input) {\n      return;\n    }\n    this._inputAbortController.abort();\n    this._inputAbortController = new AbortController();\n    this._checkAndUpdateInputEmpty();\n\n    // Timeout needed to have value updated\n    this._getInputForm()?.addEventListener('reset', () => setTimeout(() => this.reset()), {\n      signal: this._inputAbortController.signal,\n    });\n\n    this._input.addEventListener('input', () => this._checkAndUpdateInputEmpty(), {\n      signal: this._inputAbortController.signal,\n    });\n\n    this._input.addEventListener('blur', () => this._checkAndUpdateInputEmpty(), {\n      signal: this._inputAbortController.signal,\n    });\n\n    let inputFocusElement = this._input;\n\n    if (this._input.localName === 'input') {\n      this._patchInputValue();\n    } else if (this._input.localName === 'sbb-select') {\n      this._input.addEventListener('stateChange', () => this._checkAndUpdateInputEmpty(), {\n        signal: this._inputAbortController.signal,\n      });\n\n      inputFocusElement = (this._input as SbbSelectElement).inputElement;\n    }\n\n    inputFocusElement.addEventListener(\n      'focusin',\n      () => {\n        this.toggleAttribute('data-input-focused', true);\n        this.setAttribute(\n          'data-focus-origin',\n          (sbbInputModalityDetector.mostRecentModality as SbbInputModality) ?? '',\n        );\n      },\n      {\n        signal: this._inputAbortController.signal,\n      },\n    );\n\n    inputFocusElement.addEventListener(\n      'focusout',\n      () =>\n        ['data-focus-origin', 'data-input-focused'].forEach((name) => this.removeAttribute(name)),\n      {\n        signal: this._inputAbortController.signal,\n      },\n    );\n  }\n\n  private _getInputForm(): HTMLFormElement | null | undefined {\n    if (this._input instanceof HTMLInputElement || this._input instanceof HTMLSelectElement) {\n      return this._input.form;\n    }\n    return this._input?.closest('form');\n  }\n\n  // We need to patch the value property of the HTMLInputElement in order\n  // to be able to reset the floating label in the empty state.\n  private _patchInputValue(): void {\n    const inputElement = this._input as HTMLInputElement;\n    const originalDescriptor = Object.getOwnPropertyDescriptor(\n      Object.getPrototypeOf(inputElement),\n      'value',\n    );\n\n    if (!originalDescriptor || !originalDescriptor.set || !originalDescriptor.get) {\n      return;\n    }\n\n    patchedInputs.set(inputElement, originalDescriptor);\n\n    const { get: getter, set: setter } = originalDescriptor;\n    const checkAndUpdateInputEmpty = (): void => this._checkAndUpdateInputEmpty();\n\n    Object.defineProperty(inputElement, 'value', {\n      ...originalDescriptor,\n      get() {\n        return getter.call(this);\n      },\n      set(newValue) {\n        setter.call(this, newValue);\n        checkAndUpdateInputEmpty();\n      },\n    });\n  }\n\n  private _unpatchInputValue(): void {\n    const inputElement = this._input as HTMLInputElement;\n    const originalDescriptor = patchedInputs.get(inputElement);\n    if (originalDescriptor) {\n      Object.defineProperty(inputElement, 'value', originalDescriptor);\n      patchedInputs.delete(inputElement);\n    }\n  }\n\n  private _checkAndUpdateInputEmpty(): void {\n    this.toggleAttribute(\n      'data-input-empty',\n      this._floatingLabelSupportedInputElements.includes(this._input?.localName as string) &&\n        this._isInputEmpty(),\n    );\n  }\n\n  private _isInputEmpty(): boolean {\n    if (this._input instanceof HTMLInputElement) {\n      return (\n        this._floatingLabelSupportedInputTypes.includes(this._input.type) &&\n        this._isInputValueEmpty()\n      );\n    } else if (this._input instanceof HTMLSelectElement) {\n      return this._input.selectedOptions?.item(0)?.label?.trim() === '';\n    } else if (this._input?.localName === 'sbb-select') {\n      return (this._input as SbbSelectElement).getDisplayValue()?.trim() === '';\n    } else {\n      return this._isInputValueEmpty();\n    }\n  }\n\n  private _isInputValueEmpty(): boolean {\n    const value = (this._input as { value: string }).value;\n    return ['', undefined, null].includes(value) || (Array.isArray(value) && value.length === 0);\n  }\n\n  private _assignSlots(): void {\n    this.querySelectorAll('label:not([slot])').forEach((e) => e.setAttribute('slot', 'label'));\n    this.querySelectorAll('sbb-form-error:not([slot])').forEach((e) =>\n      e.setAttribute('slot', 'error'),\n    );\n  }\n\n  private _readInputState(): void {\n    if (!this._input) {\n      return;\n    }\n    this.toggleAttribute('data-readonly', this._input.hasAttribute('readonly'));\n    this.toggleAttribute('data-disabled', this._input.hasAttribute('disabled'));\n    this.toggleAttribute(\n      'data-invalid',\n      this._input.hasAttribute('data-sbb-invalid') ||\n        this._input.classList.contains('sbb-invalid') ||\n        (this._input.classList.contains('ng-touched') &&\n          this._input.classList.contains('ng-invalid')),\n    );\n  }\n\n  /**\n   * It is used internally to set the aria-describedby attribute for the slotted input referencing available <sbb-form-error> instances.\n   */\n  private _onSlotErrorChange(event: Event): void {\n    this._errorElements = (event.target as HTMLSlotElement).assignedElements();\n\n    for (const el of this._errorElements) {\n      // Although a form error assigns an id itself, we need to be earlier by creating one here\n      if (!el.id) {\n        el.id = `sbb-form-field-error-${++nextFormFieldErrorId}`;\n      }\n      if (!el.role) {\n        // Instead of defining a container with an aria-live region as expected, we had to change\n        // setting it for every slotted element to properly work in all browsers and screen reader combinations.\n        el.role = 'status';\n        if (isFirefox) {\n          el.setAttribute('role', 'status');\n        }\n      }\n    }\n    this._applyAriaDescribedby();\n    this.toggleAttribute('data-has-error', !!this._errorElements.length);\n    this._syncNegative();\n  }\n\n  private _applyAriaDescribedby(): void {\n    const ids = [];\n\n    if (this._originalInputAriaDescribedby) {\n      ids.push(this._originalInputAriaDescribedby);\n    }\n\n    if (this._errorElements.length) {\n      this._errorElements.forEach((e) => ids.push(e.id));\n    }\n\n    const ariaDescribedby = ids.join(' ');\n    if (this._input) {\n      setOrRemoveAttribute(this._input, 'aria-describedby', ariaDescribedby);\n    }\n  }\n\n  /** Manually reset the form field. Currently, this only resets the floating label. */\n  public reset(): void {\n    this._checkAndUpdateInputEmpty();\n  }\n\n  /** Manually clears the input value. It only works for inputs, selects are not supported. */\n  public clear(): void {\n    if ((this._input?.localName as string) !== 'input') {\n      return;\n    }\n    (this._input as { value: string }).value = '';\n    this._checkAndUpdateInputEmpty();\n  }\n\n  /**\n   * Returns the input element.\n   * @deprecated Use the 'inputElement' property instead\n   */\n  public getInputElement(): HTMLInputElement | HTMLSelectElement | HTMLElement | undefined {\n    return this._input;\n  }\n\n  private _syncNegative(): void {\n    this.querySelectorAll?.(\n      'sbb-form-error,sbb-mini-button,sbb-popover-trigger,sbb-form-field-clear,sbb-datepicker-next-day,sbb-datepicker-previous-day,sbb-datepicker-toggle,sbb-select,sbb-autocomplete,sbb-autocomplete-grid',\n    ).forEach((element) => element.toggleAttribute('negative', this.negative));\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-form-field__space-wrapper\">\n        ${/* Queried by id from the autocomplete/select to be used as the anchor element */ ''}\n        <div @click=${this._handleWrapperClick} class=\"sbb-form-field__wrapper\" id=\"overlay-anchor\">\n          <slot name=\"prefix\" @slotchange=${this._syncNegative}></slot>\n          <div class=\"sbb-form-field__input-container\">\n            <span class=\"sbb-form-field__label-spacer\" aria-hidden=\"true\"></span>\n            <span class=\"sbb-form-field__label\">\n              <span class=\"sbb-form-field__label-ellipsis\">\n                <slot name=\"label\" @slotchange=${this._onSlotLabelChange}></slot>\n                ${this.optional\n                  ? html` <span aria-hidden=\"true\"> ${i18nOptional[this._language.current]} </span>`\n                  : nothing}\n              </span>\n            </span>\n            <div class=\"sbb-form-field__input\">\n              <slot @slotchange=${this._onSlotInputChange}></slot>\n            </div>\n            ${['select', 'sbb-select'].includes(this._input?.localName as string)\n              ? html`<sbb-icon\n                  name=\"chevron-small-down-small\"\n                  class=\"sbb-form-field__select-input-icon\"\n                ></sbb-icon>`\n              : nothing}\n          </div>\n          <slot name=\"suffix\" @slotchange=${this._syncNegative}></slot>\n        </div>\n\n        <div class=\"sbb-form-field__error\">\n          <slot name=\"error\" @slotchange=${this._onSlotErrorChange}></slot>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-form-field': SbbFormFieldElement;\n  }\n}\n"],"names":["_a"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"tab-group.d.ts","sourceRoot":"","sources":["../../../../../src/elements/tabs/tab-group/tab-group.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AASvC,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAI1C,MAAM,MAAM,yBAAyB,GAAG;IACtC,WAAW,EAAE,MAAM,CAAC;IACpB,cAAc,EAAE,kBAAkB,CAAC;IACnC,SAAS,EAAE,aAAa,CAAC;IACzB,aAAa,EAAE,MAAM,CAAC;IACtB,gBAAgB,EAAE,kBAAkB,GAAG,SAAS,CAAC;IACjD,WAAW,EAAE,aAAa,GAAG,SAAS,CAAC;CACxC,CAAC;AAEF,MAAM,WAAW,2BAA2B;IAC1C,QAAQ,IAAI,IAAI,CAAC;IACjB,UAAU,IAAI,IAAI,CAAC;IACnB,MAAM,IAAI,IAAI,CAAC;IACf,OAAO,IAAI,IAAI,CAAC;IAChB,MAAM,IAAI,IAAI,CAAC;CAChB;AAED,MAAM,WAAW,uBAAwB,SAAQ,kBAAkB;IACjE,MAAM,EAAE,OAAO,CAAC;IAChB,QAAQ,EAAE,OAAO,CAAC;IAClB,GAAG,CAAC,EAAE,aAAa,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,eAAe,CAAC,EAAE,2BAA2B,CAAC;IAC9C,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC;CACxB;;AAQD;;;;;;GAMG;AACH,qBAEM,kBAAmB,SAAQ,uBAA6B;IAC5D,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;MAElB;IAEX,OAAO,CAAC,KAAK,CAAiC;IAC9C,OAAO,CAAC,YAAY,CAAC,CAA0B;IAC/C,OAAO,CAAC,gBAAgB,CAAe;IACvC,OAAO,CAAC,kBAAkB,CAAe;IACzC,OAAO,CAAC,MAAM,CAAyC;IACvD,OAAO,CAAC,qBAAqB,CAI1B;IACH,OAAO,CAAC,uBAAuB,CAI5B;IACH,OAAO,CAAC,yBAAyB,CAI9B;IAEH,uCAAuC;IACvC,IACW,IAAI,CAAC,KAAK,EAAE,uBAAuB,CAAC,MAAM,CAAC,EAGrD;IACD,IAAW,IAAI,IAAI,uBAAuB,CAAC,MAAM,CAAC,CAEjD;IACD,OAAO,CAAC,KAAK,CAAwC;IAErD;;;OAGG;IACH,SAEgB,oBAAoB,EAAE,MAAM,CAAK;IAEjD,6CAA6C;IAC7C,OAAO,CAAC,mBAAmB,CAGzB;IAEc,iBAAiB,IAAI,IAAI;cAMtB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAS9E;;;OAGG;IACI,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAIzC;;;OAGG;IACI,SAAS,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAIxC;;;OAGG;IACI,WAAW,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAI1C,OAAO,CAAC,QAAQ;IAMhB,OAAO,CAAC,YAAY;IAIpB,OAAO,CAAC,WAAW;IAMnB,OAAO,CAAC,oBAAoB,CAS1B;IAEF,OAAO,CAAC,iBAAiB,CAavB;IAEF,OAAO,CAAC,SAAS;IAIjB,OAAO,CAAC,cAAc;IAYtB,OAAO,CAAC,sBAAsB;IAwB9B,OAAO,CAAC,wBAAwB;IAgBhC,OAAO,CAAC,0BAA0B;IAQlC,OAAO,CAAC,UAAU;IAkGlB,OAAO,CAAC,cAAc;cAoBH,MAAM,IAAI,cAAc;CAe5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,eAAe,EAAE,kBAAkB,CAAC;KACrC;CACF"}
1
+ {"version":3,"file":"tab-group.d.ts","sourceRoot":"","sources":["../../../../../src/elements/tabs/tab-group/tab-group.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AASvC,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAI1C,MAAM,MAAM,yBAAyB,GAAG;IACtC,WAAW,EAAE,MAAM,CAAC;IACpB,cAAc,EAAE,kBAAkB,CAAC;IACnC,SAAS,EAAE,aAAa,CAAC;IACzB,aAAa,EAAE,MAAM,CAAC;IACtB,gBAAgB,EAAE,kBAAkB,GAAG,SAAS,CAAC;IACjD,WAAW,EAAE,aAAa,GAAG,SAAS,CAAC;CACxC,CAAC;AAEF,MAAM,WAAW,2BAA2B;IAC1C,QAAQ,IAAI,IAAI,CAAC;IACjB,UAAU,IAAI,IAAI,CAAC;IACnB,MAAM,IAAI,IAAI,CAAC;IACf,OAAO,IAAI,IAAI,CAAC;IAChB,MAAM,IAAI,IAAI,CAAC;CAChB;AAED,MAAM,WAAW,uBAAwB,SAAQ,kBAAkB;IACjE,MAAM,EAAE,OAAO,CAAC;IAChB,QAAQ,EAAE,OAAO,CAAC;IAClB,GAAG,CAAC,EAAE,aAAa,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,eAAe,CAAC,EAAE,2BAA2B,CAAC;IAC9C,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC;CACxB;;AAQD;;;;;;GAMG;AACH,qBAEM,kBAAmB,SAAQ,uBAA6B;IAC5D,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;MAElB;IAEX,OAAO,CAAC,KAAK,CAAiC;IAC9C,OAAO,CAAC,YAAY,CAAC,CAA0B;IAC/C,OAAO,CAAC,gBAAgB,CAAe;IACvC,OAAO,CAAC,kBAAkB,CAAe;IACzC,OAAO,CAAC,MAAM,CAAyC;IACvD,OAAO,CAAC,qBAAqB,CAI1B;IACH,OAAO,CAAC,uBAAuB,CAI5B;IACH,OAAO,CAAC,yBAAyB,CAI9B;IAEH,uCAAuC;IACvC,IACW,IAAI,CAAC,KAAK,EAAE,uBAAuB,CAAC,MAAM,CAAC,EAGrD;IACD,IAAW,IAAI,IAAI,uBAAuB,CAAC,MAAM,CAAC,CAEjD;IACD,OAAO,CAAC,KAAK,CAAwC;IAErD;;;OAGG;IACH,SAEgB,oBAAoB,EAAE,MAAM,CAAK;IAEjD,6CAA6C;IAC7C,OAAO,CAAC,mBAAmB,CAGzB;IAEc,iBAAiB,IAAI,IAAI;cAMtB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAS9E;;;OAGG;IACI,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAIzC;;;OAGG;IACI,SAAS,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAIxC;;;OAGG;IACI,WAAW,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAI1C,OAAO,CAAC,QAAQ;IAMhB,OAAO,CAAC,YAAY;IAIpB,OAAO,CAAC,WAAW;IAMnB,OAAO,CAAC,oBAAoB,CAY1B;IAEF,OAAO,CAAC,iBAAiB,CAavB;IAEF,OAAO,CAAC,SAAS;IAIjB,OAAO,CAAC,cAAc;IAYtB,OAAO,CAAC,sBAAsB;IAwB9B,OAAO,CAAC,wBAAwB;IAgBhC,OAAO,CAAC,0BAA0B;IAWlC,OAAO,CAAC,UAAU;IAmGlB,OAAO,CAAC,cAAc;cAoBH,MAAM,IAAI,cAAc;CAe5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,eAAe,EAAE,kBAAkB,CAAC;KACrC;CACF"}
@@ -102,11 +102,13 @@ let SbbTabGroupElement = (() => {
102
102
  __privateSet(this, _initialSelectedIndex_accessor_storage, __runInitializers(this, _initialSelectedIndex_initializers, 0));
103
103
  this._selectedTabChanged = (__runInitializers(this, _initialSelectedIndex_extraInitializers), new EventEmitter(this, SbbTabGroupElement2.events.didChange));
104
104
  this._onContentSlotChange = () => {
105
+ var _a2, _b;
105
106
  this._tabContentElement = this.shadowRoot.querySelector("div.tab-content");
106
107
  const loadedTabs = this._getTabs().filter((tab) => !this._tabs.includes(tab));
107
108
  if (loadedTabs.length) {
108
109
  loadedTabs.forEach((tab) => this._configure(tab));
109
110
  this._tabs = this._tabs.concat(loadedTabs);
111
+ (_b = (_a2 = loadedTabs.find((tab) => tab.active)) == null ? void 0 : _a2.tabGroupActions) == null ? void 0 : _b.select();
110
112
  }
111
113
  };
112
114
  this._onTabsSlotChange = () => {
@@ -231,6 +233,9 @@ let SbbTabGroupElement = (() => {
231
233
  }
232
234
  }
233
235
  _onTabContentElementResize(entries) {
236
+ if (!this._tabContentElement) {
237
+ return;
238
+ }
234
239
  for (const entry of entries) {
235
240
  const contentHeight = Math.floor(entry.contentRect.height);
236
241
  this._tabContentElement.style.height = `${contentHeight}px`;
@@ -320,7 +325,7 @@ let SbbTabGroupElement = (() => {
320
325
  tabLabel.disabled = tabLabel.hasAttribute("disabled");
321
326
  tabLabel.active = tabLabel.hasAttribute("active") && !tabLabel.disabled;
322
327
  tabLabel.setAttribute("role", "tab");
323
- tabLabel.setAttribute("aria-selected", "false");
328
+ tabLabel.setAttribute("aria-selected", String(tabLabel.active));
324
329
  tabLabel.addEventListener("click", () => {
325
330
  var _a3;
326
331
  (_a3 = tabLabel.tabGroupActions) == null ? void 0 : _a3.select();
@@ -384,4 +389,4 @@ let SbbTabGroupElement = (() => {
384
389
  export {
385
390
  SbbTabGroupElement
386
391
  };
387
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"tab-group.js","sources":["../../../../src/elements/tabs/tab-group/tab-group.ts"],"sourcesContent":["import { MutationController } from '@lit-labs/observers/mutation-controller.js';\nimport { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport { getNextElementIndex, isArrowKeyPressed } from '../../core/a11y.js';\nimport { SbbConnectedAbortController } from '../../core/controllers.js';\nimport { forceType } from '../../core/decorators.js';\nimport { EventEmitter, throttle } from '../../core/eventing.js';\nimport { SbbHydrationMixin } from '../../core/mixins.js';\nimport type { SbbTabLabelElement } from '../tab-label.js';\nimport { SbbTabElement } from '../tab.js';\n\nimport style from './tab-group.scss?lit&inline';\n\nexport type SbbTabChangedEventDetails = {\n  activeIndex: number;\n  activeTabLabel: SbbTabLabelElement;\n  activeTab: SbbTabElement;\n  previousIndex: number;\n  previousTabLabel: SbbTabLabelElement | undefined;\n  previousTab: SbbTabElement | undefined;\n};\n\nexport interface InterfaceSbbTabGroupActions {\n  activate(): void;\n  deactivate(): void;\n  enable(): void;\n  disable(): void;\n  select(): void;\n}\n\nexport interface InterfaceSbbTabGroupTab extends SbbTabLabelElement {\n  active: boolean;\n  disabled: boolean;\n  tab?: SbbTabElement;\n  index?: number;\n  tabGroupActions?: InterfaceSbbTabGroupActions;\n  size: 's' | 'l' | 'xl';\n}\n\nconst tabObserverConfig: MutationObserverInit = {\n  attributeFilter: ['active', 'disabled'],\n};\n\nlet nextId = 0;\n\n/**\n * It displays one or more tabs, each one with a label and a content.\n *\n * @slot - Use the unnamed slot to add content to the `sbb-tab-group` via\n * `sbb-tab-label` and `sbb-tab` instances.\n * @event {CustomEvent<SbbTabChangedEventDetails>} didChange - Emits an event on selected tab change.\n */\nexport\n@customElement('sbb-tab-group')\nclass SbbTabGroupElement extends SbbHydrationMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    didChange: 'didChange',\n  } as const;\n\n  private _tabs: InterfaceSbbTabGroupTab[] = [];\n  private _selectedTab?: InterfaceSbbTabGroupTab;\n  private _tabGroupElement!: HTMLElement;\n  private _tabContentElement!: HTMLElement;\n  private _abort = new SbbConnectedAbortController(this);\n  private _tabAttributeObserver = new MutationController(this, {\n    target: null,\n    config: tabObserverConfig,\n    callback: (mutationsList) => this._onTabAttributesChange(mutationsList),\n  });\n  private _tabGroupResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: (entries) => this._onTabGroupElementResize(entries),\n  });\n  private _tabContentResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: (entries) => this._onTabContentElementResize(entries),\n  });\n\n  /** Size variant, either s, l or xl. */\n  @property()\n  public set size(value: InterfaceSbbTabGroupTab['size']) {\n    this._size = value;\n    this._updateSize();\n  }\n  public get size(): InterfaceSbbTabGroupTab['size'] {\n    return this._size;\n  }\n  private _size: InterfaceSbbTabGroupTab['size'] = 'l';\n\n  /**\n   * Sets the initial tab. If it matches a disabled tab or exceeds the length of\n   * the tab group, the first enabled tab will be selected.\n   */\n  @forceType()\n  @property({ attribute: 'initial-selected-index', type: Number })\n  public accessor initialSelectedIndex: number = 0;\n\n  /** Emits an event on selected tab change. */\n  private _selectedTabChanged: EventEmitter<SbbTabChangedEventDetails> = new EventEmitter(\n    this,\n    SbbTabGroupElement.events.didChange,\n  );\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    const signal = this._abort.signal;\n    this.addEventListener('keydown', (e) => this._handleKeyDown(e), { signal });\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._tabs = this._getTabs();\n    this._tabs.forEach((tab) => this._configure(tab));\n    this._initSelection();\n    this._tabGroupResizeObserver.observe(this._tabGroupElement);\n  }\n\n  /**\n   * Disables a tab by index.\n   * @param tabIndex The index of the tab you want to disable.\n   */\n  public disableTab(tabIndex: number): void {\n    this._tabs[tabIndex]?.tabGroupActions?.disable();\n  }\n\n  /**\n   * Enables a tab by index.\n   * @param tabIndex The index of the tab you want to enable.\n   */\n  public enableTab(tabIndex: number): void {\n    this._tabs[tabIndex]?.tabGroupActions?.enable();\n  }\n\n  /**\n   * Activates a tab by index.\n   * @param tabIndex The index of the tab you want to activate.\n   */\n  public activateTab(tabIndex: number): void {\n    this._tabs[tabIndex]?.tabGroupActions?.select();\n  }\n\n  private _getTabs(): InterfaceSbbTabGroupTab[] {\n    return Array.from(this.children ?? []).filter((child) =>\n      /^sbb-tab-label$/u.test(child.localName),\n    ) as InterfaceSbbTabGroupTab[];\n  }\n\n  private _enabledTabs(): InterfaceSbbTabGroupTab[] {\n    return this._tabs.filter((t) => !t.hasAttribute('disabled'));\n  }\n\n  private _updateSize(): void {\n    for (const tab of this._tabs) {\n      tab.setAttribute('data-size', this.size);\n    }\n  }\n\n  private _onContentSlotChange = (): void => {\n    this._tabContentElement = this.shadowRoot!.querySelector('div.tab-content')!;\n    const loadedTabs = this._getTabs().filter((tab) => !this._tabs.includes(tab));\n\n    // if a new tab/content is added to the tab group\n    if (loadedTabs.length) {\n      loadedTabs.forEach((tab) => this._configure(tab));\n      this._tabs = this._tabs.concat(loadedTabs);\n    }\n  };\n\n  private _onTabsSlotChange = (): void => {\n    const tabs = this._getTabs();\n\n    // if a tab is removed from the tab group\n    if (tabs.length < this._tabs.length) {\n      const removedTabs = this._tabs.filter((tab) => !tabs.includes(tab));\n\n      removedTabs.forEach((removedTab) => {\n        removedTab.tab?.remove();\n      });\n      this._tabs = tabs;\n    }\n    this._tabs.forEach((tab: InterfaceSbbTabGroupTab) => tab.setAttribute('data-size', this.size));\n  };\n\n  private _assignId(): string {\n    return `sbb-tab-panel-${++nextId}`;\n  }\n\n  private _initSelection(): void {\n    if (\n      this.initialSelectedIndex >= 0 &&\n      this.initialSelectedIndex < this._tabs.length &&\n      !this._tabs[this.initialSelectedIndex].disabled\n    ) {\n      this._tabs[this.initialSelectedIndex].tabGroupActions?.select();\n    } else {\n      this._enabledTabs()[0]?.tabGroupActions?.select();\n    }\n  }\n\n  private _onTabAttributesChange(mutationsList: MutationRecord[]): void {\n    for (const mutation of mutationsList) {\n      if (mutation.type !== 'attributes') {\n        return;\n      }\n      const tab = mutation.target as InterfaceSbbTabGroupTab;\n\n      if (mutation.attributeName === 'disabled') {\n        if (tab.hasAttribute('disabled') && tab !== this._selectedTab) {\n          tab.tabGroupActions?.disable();\n        } else if (tab.disabled) {\n          tab.tabGroupActions?.enable();\n        }\n      }\n      if (mutation.attributeName === 'active') {\n        if (tab.hasAttribute('active') && !tab.disabled) {\n          tab.tabGroupActions?.select();\n        } else if (tab === this._selectedTab) {\n          tab.toggleAttribute('active', true);\n        }\n      }\n    }\n  }\n\n  private _onTabGroupElementResize(entries: ResizeObserverEntry[]): void {\n    for (const entry of entries) {\n      const tabTitles = (\n        entry.target.firstElementChild as HTMLSlotElement\n      ).assignedElements() as SbbTabLabelElement[];\n\n      for (const tab of tabTitles) {\n        tab.toggleAttribute(\n          'data-has-divider',\n          tab === tabTitles[0] || tab.offsetLeft === tabTitles[0].offsetLeft,\n        );\n        this.style.setProperty('--sbb-tab-group-width', `${this._tabGroupElement.clientWidth}px`);\n      }\n    }\n  }\n\n  private _onTabContentElementResize(entries: ResizeObserverEntry[]): void {\n    for (const entry of entries) {\n      const contentHeight = Math.floor(entry.contentRect.height);\n\n      (this._tabContentElement as HTMLElement).style.height = `${contentHeight}px`;\n    }\n  }\n\n  private _configure(tabLabel: InterfaceSbbTabGroupTab): void {\n    tabLabel.tabGroupActions = {\n      activate: (): void => {\n        tabLabel.toggleAttribute('active', true);\n        tabLabel.active = true;\n        tabLabel.tabIndex = 0;\n        tabLabel.setAttribute('aria-selected', 'true');\n        tabLabel.tab?.toggleAttribute('active', true);\n      },\n      deactivate: (): void => {\n        tabLabel.removeAttribute('active');\n        tabLabel.active = false;\n        tabLabel.tabIndex = -1;\n        tabLabel.setAttribute('aria-selected', 'false');\n        tabLabel.tab?.removeAttribute('active');\n      },\n      disable: (): void => {\n        if (tabLabel.disabled) {\n          return;\n        }\n        if (!tabLabel.hasAttribute('disabled')) {\n          tabLabel.toggleAttribute('disabled', true);\n        }\n        tabLabel.disabled = true;\n        tabLabel.tabIndex = -1;\n        tabLabel.setAttribute('aria-selected', 'false');\n        tabLabel.tab?.removeAttribute('active');\n        if (tabLabel.active) {\n          tabLabel.removeAttribute('active');\n          tabLabel.active = false;\n          this._enabledTabs()[0]?.tabGroupActions?.select();\n        }\n      },\n      enable: (): void => {\n        if (tabLabel.disabled) {\n          tabLabel.removeAttribute('disabled');\n          tabLabel.disabled = false;\n        }\n      },\n      select: (): void => {\n        if (tabLabel !== this._selectedTab && !tabLabel.disabled) {\n          const prevTab = this._selectedTab;\n\n          if (prevTab) {\n            prevTab.tabGroupActions?.deactivate();\n            this._tabContentResizeObserver.unobserve(prevTab.tab!);\n          }\n\n          tabLabel.tabGroupActions?.activate();\n          this._selectedTab = tabLabel;\n\n          this._tabContentResizeObserver.observe(tabLabel.tab!);\n          const tabs = this._tabs;\n          this._selectedTabChanged.emit({\n            activeIndex: tabs.findIndex((e) => e === tabLabel),\n            activeTabLabel: tabLabel,\n            activeTab: tabLabel.tab as SbbTabElement,\n            previousIndex: tabs.findIndex((e) => e === prevTab),\n            previousTabLabel: prevTab,\n            previousTab: prevTab?.tab as SbbTabElement,\n          });\n        } else if (import.meta.env.DEV && tabLabel.disabled) {\n          console.warn('You cannot activate a disabled tab');\n        }\n      },\n    };\n    if (tabLabel.nextElementSibling?.localName === 'sbb-tab') {\n      tabLabel.tab = tabLabel.nextElementSibling as SbbTabElement;\n      tabLabel.tab.id = this._assignId();\n      if (tabLabel.tab instanceof SbbTabElement) {\n        tabLabel.tab.tabIndex = 0;\n        tabLabel.tab.configure();\n      }\n    } else if (import.meta.env.DEV) {\n      tabLabel.insertAdjacentHTML('afterend', '<sbb-tab>No content.</sbb-tab>');\n      tabLabel.tab = tabLabel.nextElementSibling as SbbTabElement;\n      console.warn(\n        `Missing content: you should provide a related content for the tab ${tabLabel.outerHTML}.`,\n      );\n    }\n    tabLabel.tabIndex = -1;\n    tabLabel.disabled = tabLabel.hasAttribute('disabled');\n    tabLabel.active = tabLabel.hasAttribute('active') && !tabLabel.disabled;\n    tabLabel.setAttribute('role', 'tab');\n    tabLabel.setAttribute('aria-selected', 'false');\n    tabLabel.addEventListener('click', () => {\n      tabLabel.tabGroupActions?.select();\n    });\n    if (tabLabel.tab) {\n      tabLabel.setAttribute('aria-controls', tabLabel.tab.id);\n      tabLabel.tab.setAttribute('role', 'tabpanel');\n      tabLabel.tab.toggleAttribute('active', tabLabel.active);\n    }\n\n    this._tabAttributeObserver.observe(tabLabel);\n    tabLabel.slot = 'tab-bar';\n  }\n\n  private _handleKeyDown(evt: KeyboardEvent): void {\n    const enabledTabs: InterfaceSbbTabGroupTab[] = this._enabledTabs();\n\n    if (\n      !enabledTabs ||\n      // don't trap nested handling\n      ((evt.target as HTMLElement) !== this && (evt.target as HTMLElement).parentElement !== this)\n    ) {\n      return;\n    }\n\n    if (isArrowKeyPressed(evt)) {\n      const current: number = enabledTabs.findIndex((t: InterfaceSbbTabGroupTab) => t.active);\n      const nextIndex: number = getNextElementIndex(evt, current, enabledTabs.length);\n      enabledTabs[nextIndex]?.tabGroupActions?.select();\n      enabledTabs[nextIndex]?.focus();\n      evt.preventDefault();\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div\n        class=\"tab-group\"\n        role=\"tablist\"\n        ${ref((el?: Element) => (this._tabGroupElement = el as HTMLElement))}\n      >\n        <slot name=\"tab-bar\" @slotchange=${this._onTabsSlotChange}></slot>\n      </div>\n\n      <div class=\"tab-content\">\n        <slot @slotchange=${throttle(this._onContentSlotChange, 150)}></slot>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-tab-group': SbbTabGroupElement;\n  }\n}\n"],"names":["SbbTabGroupElement","_a"],"mappings":"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"}
392
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"tab-group.js","sources":["../../../../src/elements/tabs/tab-group/tab-group.ts"],"sourcesContent":["import { MutationController } from '@lit-labs/observers/mutation-controller.js';\nimport { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport { getNextElementIndex, isArrowKeyPressed } from '../../core/a11y.js';\nimport { SbbConnectedAbortController } from '../../core/controllers.js';\nimport { forceType } from '../../core/decorators.js';\nimport { EventEmitter, throttle } from '../../core/eventing.js';\nimport { SbbHydrationMixin } from '../../core/mixins.js';\nimport type { SbbTabLabelElement } from '../tab-label.js';\nimport { SbbTabElement } from '../tab.js';\n\nimport style from './tab-group.scss?lit&inline';\n\nexport type SbbTabChangedEventDetails = {\n  activeIndex: number;\n  activeTabLabel: SbbTabLabelElement;\n  activeTab: SbbTabElement;\n  previousIndex: number;\n  previousTabLabel: SbbTabLabelElement | undefined;\n  previousTab: SbbTabElement | undefined;\n};\n\nexport interface InterfaceSbbTabGroupActions {\n  activate(): void;\n  deactivate(): void;\n  enable(): void;\n  disable(): void;\n  select(): void;\n}\n\nexport interface InterfaceSbbTabGroupTab extends SbbTabLabelElement {\n  active: boolean;\n  disabled: boolean;\n  tab?: SbbTabElement;\n  index?: number;\n  tabGroupActions?: InterfaceSbbTabGroupActions;\n  size: 's' | 'l' | 'xl';\n}\n\nconst tabObserverConfig: MutationObserverInit = {\n  attributeFilter: ['active', 'disabled'],\n};\n\nlet nextId = 0;\n\n/**\n * It displays one or more tabs, each one with a label and a content.\n *\n * @slot - Use the unnamed slot to add content to the `sbb-tab-group` via\n * `sbb-tab-label` and `sbb-tab` instances.\n * @event {CustomEvent<SbbTabChangedEventDetails>} didChange - Emits an event on selected tab change.\n */\nexport\n@customElement('sbb-tab-group')\nclass SbbTabGroupElement extends SbbHydrationMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    didChange: 'didChange',\n  } as const;\n\n  private _tabs: InterfaceSbbTabGroupTab[] = [];\n  private _selectedTab?: InterfaceSbbTabGroupTab;\n  private _tabGroupElement!: HTMLElement;\n  private _tabContentElement!: HTMLElement;\n  private _abort = new SbbConnectedAbortController(this);\n  private _tabAttributeObserver = new MutationController(this, {\n    target: null,\n    config: tabObserverConfig,\n    callback: (mutationsList) => this._onTabAttributesChange(mutationsList),\n  });\n  private _tabGroupResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: (entries) => this._onTabGroupElementResize(entries),\n  });\n  private _tabContentResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: (entries) => this._onTabContentElementResize(entries),\n  });\n\n  /** Size variant, either s, l or xl. */\n  @property()\n  public set size(value: InterfaceSbbTabGroupTab['size']) {\n    this._size = value;\n    this._updateSize();\n  }\n  public get size(): InterfaceSbbTabGroupTab['size'] {\n    return this._size;\n  }\n  private _size: InterfaceSbbTabGroupTab['size'] = 'l';\n\n  /**\n   * Sets the initial tab. If it matches a disabled tab or exceeds the length of\n   * the tab group, the first enabled tab will be selected.\n   */\n  @forceType()\n  @property({ attribute: 'initial-selected-index', type: Number })\n  public accessor initialSelectedIndex: number = 0;\n\n  /** Emits an event on selected tab change. */\n  private _selectedTabChanged: EventEmitter<SbbTabChangedEventDetails> = new EventEmitter(\n    this,\n    SbbTabGroupElement.events.didChange,\n  );\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    const signal = this._abort.signal;\n    this.addEventListener('keydown', (e) => this._handleKeyDown(e), { signal });\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._tabs = this._getTabs();\n    this._tabs.forEach((tab) => this._configure(tab));\n    this._initSelection();\n    this._tabGroupResizeObserver.observe(this._tabGroupElement);\n  }\n\n  /**\n   * Disables a tab by index.\n   * @param tabIndex The index of the tab you want to disable.\n   */\n  public disableTab(tabIndex: number): void {\n    this._tabs[tabIndex]?.tabGroupActions?.disable();\n  }\n\n  /**\n   * Enables a tab by index.\n   * @param tabIndex The index of the tab you want to enable.\n   */\n  public enableTab(tabIndex: number): void {\n    this._tabs[tabIndex]?.tabGroupActions?.enable();\n  }\n\n  /**\n   * Activates a tab by index.\n   * @param tabIndex The index of the tab you want to activate.\n   */\n  public activateTab(tabIndex: number): void {\n    this._tabs[tabIndex]?.tabGroupActions?.select();\n  }\n\n  private _getTabs(): InterfaceSbbTabGroupTab[] {\n    return Array.from(this.children ?? []).filter((child) =>\n      /^sbb-tab-label$/u.test(child.localName),\n    ) as InterfaceSbbTabGroupTab[];\n  }\n\n  private _enabledTabs(): InterfaceSbbTabGroupTab[] {\n    return this._tabs.filter((t) => !t.hasAttribute('disabled'));\n  }\n\n  private _updateSize(): void {\n    for (const tab of this._tabs) {\n      tab.setAttribute('data-size', this.size);\n    }\n  }\n\n  private _onContentSlotChange = (): void => {\n    this._tabContentElement = this.shadowRoot!.querySelector('div.tab-content')!;\n    const loadedTabs = this._getTabs().filter((tab) => !this._tabs.includes(tab));\n\n    // if a new tab/content is added to the tab group\n    if (loadedTabs.length) {\n      loadedTabs.forEach((tab) => this._configure(tab));\n      this._tabs = this._tabs.concat(loadedTabs);\n\n      // If there is an active tab in the new batch, it becomes the new selected\n      loadedTabs.find((tab) => tab.active)?.tabGroupActions?.select();\n    }\n  };\n\n  private _onTabsSlotChange = (): void => {\n    const tabs = this._getTabs();\n\n    // if a tab is removed from the tab group\n    if (tabs.length < this._tabs.length) {\n      const removedTabs = this._tabs.filter((tab) => !tabs.includes(tab));\n\n      removedTabs.forEach((removedTab) => {\n        removedTab.tab?.remove();\n      });\n      this._tabs = tabs;\n    }\n    this._tabs.forEach((tab: InterfaceSbbTabGroupTab) => tab.setAttribute('data-size', this.size));\n  };\n\n  private _assignId(): string {\n    return `sbb-tab-panel-${++nextId}`;\n  }\n\n  private _initSelection(): void {\n    if (\n      this.initialSelectedIndex >= 0 &&\n      this.initialSelectedIndex < this._tabs.length &&\n      !this._tabs[this.initialSelectedIndex].disabled\n    ) {\n      this._tabs[this.initialSelectedIndex].tabGroupActions?.select();\n    } else {\n      this._enabledTabs()[0]?.tabGroupActions?.select();\n    }\n  }\n\n  private _onTabAttributesChange(mutationsList: MutationRecord[]): void {\n    for (const mutation of mutationsList) {\n      if (mutation.type !== 'attributes') {\n        return;\n      }\n      const tab = mutation.target as InterfaceSbbTabGroupTab;\n\n      if (mutation.attributeName === 'disabled') {\n        if (tab.hasAttribute('disabled') && tab !== this._selectedTab) {\n          tab.tabGroupActions?.disable();\n        } else if (tab.disabled) {\n          tab.tabGroupActions?.enable();\n        }\n      }\n      if (mutation.attributeName === 'active') {\n        if (tab.hasAttribute('active') && !tab.disabled) {\n          tab.tabGroupActions?.select();\n        } else if (tab === this._selectedTab) {\n          tab.toggleAttribute('active', true);\n        }\n      }\n    }\n  }\n\n  private _onTabGroupElementResize(entries: ResizeObserverEntry[]): void {\n    for (const entry of entries) {\n      const tabTitles = (\n        entry.target.firstElementChild as HTMLSlotElement\n      ).assignedElements() as SbbTabLabelElement[];\n\n      for (const tab of tabTitles) {\n        tab.toggleAttribute(\n          'data-has-divider',\n          tab === tabTitles[0] || tab.offsetLeft === tabTitles[0].offsetLeft,\n        );\n        this.style.setProperty('--sbb-tab-group-width', `${this._tabGroupElement.clientWidth}px`);\n      }\n    }\n  }\n\n  private _onTabContentElementResize(entries: ResizeObserverEntry[]): void {\n    if (!this._tabContentElement) {\n      return;\n    }\n    for (const entry of entries) {\n      const contentHeight = Math.floor(entry.contentRect.height);\n\n      this._tabContentElement.style.height = `${contentHeight}px`;\n    }\n  }\n\n  private _configure(tabLabel: InterfaceSbbTabGroupTab): void {\n    tabLabel.tabGroupActions = {\n      activate: (): void => {\n        tabLabel.toggleAttribute('active', true);\n        tabLabel.active = true;\n        tabLabel.tabIndex = 0;\n        tabLabel.setAttribute('aria-selected', 'true');\n        tabLabel.tab?.toggleAttribute('active', true);\n      },\n      deactivate: (): void => {\n        tabLabel.removeAttribute('active');\n        tabLabel.active = false;\n        tabLabel.tabIndex = -1;\n        tabLabel.setAttribute('aria-selected', 'false');\n        tabLabel.tab?.removeAttribute('active');\n      },\n      disable: (): void => {\n        if (tabLabel.disabled) {\n          return;\n        }\n        if (!tabLabel.hasAttribute('disabled')) {\n          tabLabel.toggleAttribute('disabled', true);\n        }\n        tabLabel.disabled = true;\n        tabLabel.tabIndex = -1;\n        tabLabel.setAttribute('aria-selected', 'false');\n        tabLabel.tab?.removeAttribute('active');\n        if (tabLabel.active) {\n          tabLabel.removeAttribute('active');\n          tabLabel.active = false;\n          this._enabledTabs()[0]?.tabGroupActions?.select();\n        }\n      },\n      enable: (): void => {\n        if (tabLabel.disabled) {\n          tabLabel.removeAttribute('disabled');\n          tabLabel.disabled = false;\n        }\n      },\n      select: (): void => {\n        if (tabLabel !== this._selectedTab && !tabLabel.disabled) {\n          const prevTab = this._selectedTab;\n\n          if (prevTab) {\n            prevTab.tabGroupActions?.deactivate();\n            this._tabContentResizeObserver.unobserve(prevTab.tab!);\n          }\n\n          tabLabel.tabGroupActions?.activate();\n          this._selectedTab = tabLabel;\n\n          this._tabContentResizeObserver.observe(tabLabel.tab!);\n          const tabs = this._tabs;\n          this._selectedTabChanged.emit({\n            activeIndex: tabs.findIndex((e) => e === tabLabel),\n            activeTabLabel: tabLabel,\n            activeTab: tabLabel.tab as SbbTabElement,\n            previousIndex: tabs.findIndex((e) => e === prevTab),\n            previousTabLabel: prevTab,\n            previousTab: prevTab?.tab as SbbTabElement,\n          });\n        } else if (import.meta.env.DEV && tabLabel.disabled) {\n          console.warn('You cannot activate a disabled tab');\n        }\n      },\n    };\n\n    if (tabLabel.nextElementSibling?.localName === 'sbb-tab') {\n      tabLabel.tab = tabLabel.nextElementSibling as SbbTabElement;\n      tabLabel.tab.id = this._assignId();\n      if (tabLabel.tab instanceof SbbTabElement) {\n        tabLabel.tab.tabIndex = 0;\n        tabLabel.tab.configure();\n      }\n    } else if (import.meta.env.DEV) {\n      tabLabel.insertAdjacentHTML('afterend', '<sbb-tab>No content.</sbb-tab>');\n      tabLabel.tab = tabLabel.nextElementSibling as SbbTabElement;\n      console.warn(\n        `Missing content: you should provide a related content for the tab ${tabLabel.outerHTML}.`,\n      );\n    }\n    tabLabel.tabIndex = -1;\n    tabLabel.disabled = tabLabel.hasAttribute('disabled');\n    tabLabel.active = tabLabel.hasAttribute('active') && !tabLabel.disabled;\n    tabLabel.setAttribute('role', 'tab');\n    tabLabel.setAttribute('aria-selected', String(tabLabel.active));\n    tabLabel.addEventListener('click', () => {\n      tabLabel.tabGroupActions?.select();\n    });\n    if (tabLabel.tab) {\n      tabLabel.setAttribute('aria-controls', tabLabel.tab.id);\n      tabLabel.tab.setAttribute('role', 'tabpanel');\n      tabLabel.tab.toggleAttribute('active', tabLabel.active);\n    }\n\n    this._tabAttributeObserver.observe(tabLabel);\n    tabLabel.slot = 'tab-bar';\n  }\n\n  private _handleKeyDown(evt: KeyboardEvent): void {\n    const enabledTabs: InterfaceSbbTabGroupTab[] = this._enabledTabs();\n\n    if (\n      !enabledTabs ||\n      // don't trap nested handling\n      ((evt.target as HTMLElement) !== this && (evt.target as HTMLElement).parentElement !== this)\n    ) {\n      return;\n    }\n\n    if (isArrowKeyPressed(evt)) {\n      const current: number = enabledTabs.findIndex((t: InterfaceSbbTabGroupTab) => t.active);\n      const nextIndex: number = getNextElementIndex(evt, current, enabledTabs.length);\n      enabledTabs[nextIndex]?.tabGroupActions?.select();\n      enabledTabs[nextIndex]?.focus();\n      evt.preventDefault();\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div\n        class=\"tab-group\"\n        role=\"tablist\"\n        ${ref((el?: Element) => (this._tabGroupElement = el as HTMLElement))}\n      >\n        <slot name=\"tab-bar\" @slotchange=${this._onTabsSlotChange}></slot>\n      </div>\n\n      <div class=\"tab-content\">\n        <slot @slotchange=${throttle(this._onContentSlotChange, 150)}></slot>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-tab-group': SbbTabGroupElement;\n  }\n}\n"],"names":["SbbTabGroupElement","_a"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA2CA,MAAM,oBAA0C;AAAA,EAC9C,iBAAiB,CAAC,UAAU,UAAU;;AAGxC,IAAI,SAAS;IAWP,sBAAkB,MAAA;;0BADvB,cAAc,eAAe,CAAC;;;;oBACE,kBAAkB,UAAU;;;;;;AAApCA,MAAAA,uBAAA,mBAAQ,YAA6B;AAAA;;AA4C5D;AAtCQ,WAAA,SANJ,kBAAA,MAAA,0BAAA,GAMuC,CAAA;AAInC,WAAA,SAAS,IAAI,4BAA4B,IAAI;AAC7C,WAAA,wBAAwB,IAAI,mBAAmB,MAAM;AAAA,QAC3D,QAAQ;AAAA,QACR,QAAQ;AAAA,QACR,UAAU,CAAC,kBAAkB,KAAK,uBAAuB,aAAa;AAAA,MAAA,CACvE;AACO,WAAA,0BAA0B,IAAI,iBAAiB,MAAM;AAAA,QAC3D,QAAQ;AAAA,QACR,aAAa;AAAA,QACb,UAAU,CAAC,YAAY,KAAK,yBAAyB,OAAO;AAAA,MAAA,CAC7D;AACO,WAAA,4BAA4B,IAAI,iBAAiB,MAAM;AAAA,QAC7D,QAAQ;AAAA,QACR,aAAa;AAAA,QACb,UAAU,CAAC,YAAY,KAAK,2BAA2B,OAAO;AAAA,MAAA,CAC/D;AAWO,WAAK,QAAoC;AAQjC,yBAAA,wCAAA,kBAAA,MAAA,oCAA+B,CAAC;AAGxC,WAAA,uBAA+D,kBAAA,MAAA,uCAAA,GAAA,IAAI,aACzE,MACAA,oBAAmB,OAAO,SAAS;AA0D7B,WAAoB,uBAAG,MAAW;;AACxC,aAAK,qBAAqB,KAAK,WAAY,cAAc,iBAAiB;AAC1E,cAAM,aAAa,KAAK,WAAW,OAAO,CAAC,QAAQ,CAAC,KAAK,MAAM,SAAS,GAAG,CAAC;AAG5E,YAAI,WAAW,QAAQ;AACrB,qBAAW,QAAQ,CAAC,QAAQ,KAAK,WAAW,GAAG,CAAC;AAChD,eAAK,QAAQ,KAAK,MAAM,OAAO,UAAU;AAGzC,iBAAAC,MAAA,WAAW,KAAK,CAAC,QAAQ,IAAI,MAAM,MAAnC,gBAAAA,IAAsC,oBAAtC,mBAAuD;AAAA;MAE3D;AAEQ,WAAiB,oBAAG,MAAW;AAC/B,cAAA,OAAO,KAAK;AAGlB,YAAI,KAAK,SAAS,KAAK,MAAM,QAAQ;AAC7B,gBAAA,cAAc,KAAK,MAAM,OAAO,CAAC,QAAQ,CAAC,KAAK,SAAS,GAAG,CAAC;AAEtD,sBAAA,QAAQ,CAAC,eAAc;;AACjC,aAAAA,MAAA,WAAW,QAAX,gBAAAA,IAAgB;AAAA,WACjB;AACD,eAAK,QAAQ;AAAA,QAAA;AAEV,aAAA,MAAM,QAAQ,CAAC,QAAiC,IAAI,aAAa,aAAa,KAAK,IAAI,CAAC;AAAA,MAC/F;AAAA,IAAA;AAAA;AAAA,IAzGA,IAAW,KAAK,OAAsC;AACpD,WAAK,QAAQ;AACb,WAAK,YAAW;AAAA,IAAA;AAAA,IAElB,IAAW,OAAI;AACb,aAAO,KAAK;AAAA,IAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAUd,IAAgB,uBAAiC;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAAjD,IAAgB,qBAAiC,OAAA;AAAA,yBAAA,wCAAA;AAAA,IAAA;AAAA,IAQjC,oBAAiB;AAC/B,YAAM,kBAAiB;AACjB,YAAA,SAAS,KAAK,OAAO;AACtB,WAAA,iBAAiB,WAAW,CAAC,MAAM,KAAK,eAAe,CAAC,GAAG,EAAE,QAAQ;AAAA,IAAA;AAAA,IAGzD,aAAa,mBAAuC;AACrE,YAAM,aAAa,iBAAiB;AAE/B,WAAA,QAAQ,KAAK;AAClB,WAAK,MAAM,QAAQ,CAAC,QAAQ,KAAK,WAAW,GAAG,CAAC;AAChD,WAAK,eAAc;AACd,WAAA,wBAAwB,QAAQ,KAAK,gBAAgB;AAAA,IAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAOrD,WAAW,UAAgB;;AAChC,aAAAA,MAAA,KAAK,MAAM,QAAQ,MAAnB,gBAAAA,IAAsB,oBAAtB,mBAAuC;AAAA,IAAO;AAAA;AAAA;AAAA;AAAA;AAAA,IAOzC,UAAU,UAAgB;;AAC/B,aAAAA,MAAA,KAAK,MAAM,QAAQ,MAAnB,gBAAAA,IAAsB,oBAAtB,mBAAuC;AAAA,IAAM;AAAA;AAAA;AAAA;AAAA;AAAA,IAOxC,YAAY,UAAgB;;AACjC,aAAAA,MAAA,KAAK,MAAM,QAAQ,MAAnB,gBAAAA,IAAsB,oBAAtB,mBAAuC;AAAA,IAAM;AAAA,IAGvC,WAAQ;AACd,aAAO,MAAM,KAAK,KAAK,YAAY,CAAA,CAAE,EAAE,OAAO,CAAC,UAC7C,mBAAmB,KAAK,MAAM,SAAS,CAAC;AAAA,IAAA;AAAA,IAIpC,eAAY;AACX,aAAA,KAAK,MAAM,OAAO,CAAC,MAAM,CAAC,EAAE,aAAa,UAAU,CAAC;AAAA,IAAA;AAAA,IAGrD,cAAW;AACN,iBAAA,OAAO,KAAK,OAAO;AACxB,YAAA,aAAa,aAAa,KAAK,IAAI;AAAA,MAAA;AAAA,IACzC;AAAA,IAgCM,YAAS;AACR,aAAA,iBAAiB,EAAE,MAAM;AAAA,IAAA;AAAA,IAG1B,iBAAc;;AACpB,UACE,KAAK,wBAAwB,KAC7B,KAAK,uBAAuB,KAAK,MAAM,UACvC,CAAC,KAAK,MAAM,KAAK,oBAAoB,EAAE,UACvC;AACA,SAAAA,MAAA,KAAK,MAAM,KAAK,oBAAoB,EAAE,oBAAtC,gBAAAA,IAAuD;AAAA,MAAM,OACxD;AACL,yBAAK,aAAY,EAAG,CAAC,MAArB,mBAAwB,oBAAxB,mBAAyC;AAAA,MAAM;AAAA,IACjD;AAAA,IAGM,uBAAuB,eAA+B;;AAC5D,iBAAW,YAAY,eAAe;AAChC,YAAA,SAAS,SAAS,cAAc;AAClC;AAAA,QAAA;AAEF,cAAM,MAAM,SAAS;AAEjB,YAAA,SAAS,kBAAkB,YAAY;AACzC,cAAI,IAAI,aAAa,UAAU,KAAK,QAAQ,KAAK,cAAc;AAC7D,aAAAA,MAAA,IAAI,oBAAJ,gBAAAA,IAAqB;AAAA,qBACZ,IAAI,UAAU;AACvB,sBAAI,oBAAJ,mBAAqB;AAAA;QACvB;AAEE,YAAA,SAAS,kBAAkB,UAAU;AACvC,cAAI,IAAI,aAAa,QAAQ,KAAK,CAAC,IAAI,UAAU;AAC/C,sBAAI,oBAAJ,mBAAqB;AAAA,qBACZ,QAAQ,KAAK,cAAc;AAChC,gBAAA,gBAAgB,UAAU,IAAI;AAAA,UAAA;AAAA,QACpC;AAAA,MACF;AAAA,IACF;AAAA,IAGM,yBAAyB,SAA8B;AAC7D,iBAAW,SAAS,SAAS;AAC3B,cAAM,YACJ,MAAM,OAAO,kBACb,iBAAgB;AAElB,mBAAW,OAAO,WAAW;AACvB,cAAA,gBACF,oBACA,QAAQ,UAAU,CAAC,KAAK,IAAI,eAAe,UAAU,CAAC,EAAE,UAAU;AAEpE,eAAK,MAAM,YAAY,yBAAyB,GAAG,KAAK,iBAAiB,WAAW,IAAI;AAAA,QAAA;AAAA,MAC1F;AAAA,IACF;AAAA,IAGM,2BAA2B,SAA8B;AAC3D,UAAA,CAAC,KAAK,oBAAoB;AAC5B;AAAA,MAAA;AAEF,iBAAW,SAAS,SAAS;AAC3B,cAAM,gBAAgB,KAAK,MAAM,MAAM,YAAY,MAAM;AAEzD,aAAK,mBAAmB,MAAM,SAAS,GAAG,aAAa;AAAA,MAAA;AAAA,IACzD;AAAA,IAGM,WAAW,UAAiC;;AAClD,eAAS,kBAAkB;AAAA,QACzB,UAAU,MAAW;;AACV,mBAAA,gBAAgB,UAAU,IAAI;AACvC,mBAAS,SAAS;AAClB,mBAAS,WAAW;AACX,mBAAA,aAAa,iBAAiB,MAAM;AACpC,WAAAA,MAAA,SAAA,QAAA,gBAAAA,IAAK,gBAAgB,UAAU;AAAA,QAC1C;AAAA,QACA,YAAY,MAAW;;AACrB,mBAAS,gBAAgB,QAAQ;AACjC,mBAAS,SAAS;AAClB,mBAAS,WAAW;AACX,mBAAA,aAAa,iBAAiB,OAAO;AACrC,WAAAA,MAAA,SAAA,QAAA,gBAAAA,IAAK,gBAAgB;AAAA,QAChC;AAAA,QACA,SAAS,MAAW;;AAClB,cAAI,SAAS,UAAU;AACrB;AAAA,UAAA;AAEF,cAAI,CAAC,SAAS,aAAa,UAAU,GAAG;AAC7B,qBAAA,gBAAgB,YAAY,IAAI;AAAA,UAAA;AAE3C,mBAAS,WAAW;AACpB,mBAAS,WAAW;AACX,mBAAA,aAAa,iBAAiB,OAAO;AACrC,WAAAA,MAAA,SAAA,QAAA,gBAAAA,IAAK,gBAAgB;AAC9B,cAAI,SAAS,QAAQ;AACnB,qBAAS,gBAAgB,QAAQ;AACjC,qBAAS,SAAS;AAClB,6BAAK,aAAY,EAAG,CAAC,MAArB,mBAAwB,oBAAxB,mBAAyC;AAAA,UAAM;AAAA,QAEnD;AAAA,QACA,QAAQ,MAAW;AACjB,cAAI,SAAS,UAAU;AACrB,qBAAS,gBAAgB,UAAU;AACnC,qBAAS,WAAW;AAAA,UAAA;AAAA,QAExB;AAAA,QACA,QAAQ,MAAW;;AACjB,cAAI,aAAa,KAAK,gBAAgB,CAAC,SAAS,UAAU;AACxD,kBAAM,UAAU,KAAK;AAErB,gBAAI,SAAS;AACX,eAAAA,MAAA,QAAQ,oBAAR,gBAAAA,IAAyB;AACpB,mBAAA,0BAA0B,UAAU,QAAQ,GAAI;AAAA,YAAA;AAGvD,2BAAS,oBAAT,mBAA0B;AAC1B,iBAAK,eAAe;AAEf,iBAAA,0BAA0B,QAAQ,SAAS,GAAI;AACpD,kBAAM,OAAO,KAAK;AAClB,iBAAK,oBAAoB,KAAK;AAAA,cAC5B,aAAa,KAAK,UAAU,CAAC,MAAM,MAAM,QAAQ;AAAA,cACjD,gBAAgB;AAAA,cAChB,WAAW,SAAS;AAAA,cACpB,eAAe,KAAK,UAAU,CAAC,MAAM,MAAM,OAAO;AAAA,cAClD,kBAAkB;AAAA,cAClB,aAAa,mCAAS;AAAA,YAAA,CACvB;AAAA,UAAA,WAC+B,SAAS,UAAU;AACnD,oBAAQ,KAAK,oCAAoC;AAAA,UAAA;AAAA,QACnD;AAAA;AAIA,YAAAA,MAAA,SAAS,uBAAT,gBAAAA,IAA6B,eAAc,WAAW;AACxD,iBAAS,MAAM,SAAS;AACf,iBAAA,IAAI,KAAK,KAAK,UAAS;AAC5B,YAAA,SAAS,eAAe,eAAe;AACzC,mBAAS,IAAI,WAAW;AACxB,mBAAS,IAAI;;MACf,OAC8B;AACrB,iBAAA,mBAAmB,YAAY,gCAAgC;AACxE,iBAAS,MAAM,SAAS;AACxB,gBAAQ,KACN,qEAAqE,SAAS,SAAS,GAAG;AAAA,MAAA;AAG9F,eAAS,WAAW;AACX,eAAA,WAAW,SAAS,aAAa,UAAU;AACpD,eAAS,SAAS,SAAS,aAAa,QAAQ,KAAK,CAAC,SAAS;AACtD,eAAA,aAAa,QAAQ,KAAK;AACnC,eAAS,aAAa,iBAAiB,OAAO,SAAS,MAAM,CAAC;AACrD,eAAA,iBAAiB,SAAS,MAAK;;AACtC,SAAAA,MAAA,SAAS,oBAAT,gBAAAA,IAA0B;AAAA,OAC3B;AACD,UAAI,SAAS,KAAK;AAChB,iBAAS,aAAa,iBAAiB,SAAS,IAAI,EAAE;AAC7C,iBAAA,IAAI,aAAa,QAAQ,UAAU;AAC5C,iBAAS,IAAI,gBAAgB,UAAU,SAAS,MAAM;AAAA,MAAA;AAGnD,WAAA,sBAAsB,QAAQ,QAAQ;AAC3C,eAAS,OAAO;AAAA,IAAA;AAAA,IAGV,eAAe,KAAkB;;AACjC,YAAA,cAAyC,KAAK;AAEpD,UACE,CAAC;AAAA,MAEC,IAAI,WAA2B,QAAS,IAAI,OAAuB,kBAAkB,MACvF;AACA;AAAA,MAAA;AAGE,UAAA,kBAAkB,GAAG,GAAG;AAC1B,cAAM,UAAkB,YAAY,UAAU,CAAC,MAA+B,EAAE,MAAM;AACtF,cAAM,YAAoB,oBAAoB,KAAK,SAAS,YAAY,MAAM;AAClE,eAAAA,MAAA,YAAA,SAAS,MAAT,gBAAAA,IAAY,oBAAZ,mBAA6B;AAC7B,0BAAA,SAAS,MAAT,mBAAY;AACxB,YAAI,eAAc;AAAA,MAAA;AAAA,IACpB;AAAA,IAGiB,SAAM;AAChB,aAAA;AAAA;AAAA;AAAA;AAAA,UAID,IAAI,CAAC,OAAkB,KAAK,mBAAmB,EAAkB,CAAC;AAAA;AAAA,2CAEjC,KAAK,iBAAiB;AAAA;AAAA;AAAA;AAAA,4BAIrC,SAAS,KAAK,sBAAsB,GAAG,CAAC;AAAA;AAAA;AAAA,IAAA;AAAA,KAjSlE;;AAhBC,2BAAA,CAAA,UAAU;AAcV,uCAAA,CAAA,UAAW,GACX,SAAS,EAAE,WAAW,0BAA0B,MAAM,QAAQ,CAAC;AAdhE,iBAAA,IAAA,MAAA,sBAAA,EAAA,MAAA,UAAA,MAAA,QAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,UAAA,KAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAW,OAGV;AAAA,SAAA,UAAA,aAAA,MAAA,0BAAA;AAYe,iBAAA,IAAA,MAAA,kCAAA,EAAA,MAAA,YAAA,MAAA,wBAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,0BAAA,KAAA,KAAA,CAAA,QAAA,IAAA,sBAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAA,uBAAiC;AAAA,SAAA,UAAA,aAAA,oCAAA,uCAAA;AA5CnD,iBAiVC,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;QAhVwB,GAAM,SAAmB,OACzB,GAAA,SAAS;AAAA,IAC9B,WAAW;AAAA,EACH,GAJN,kBAAkB,YAAA,uBAAA,GAAC;;;"}
@@ -68,6 +68,8 @@ export declare class SbbFormFieldElement extends SbbFormFieldElement_base {
68
68
  private _syncLabelInputReferences;
69
69
  private _registerInputListener;
70
70
  private _getInputForm;
71
+ private _patchInputValue;
72
+ private _unpatchInputValue;
71
73
  private _checkAndUpdateInputEmpty;
72
74
  private _isInputEmpty;
73
75
  private _isInputValueEmpty;
@@ -1 +1 @@
1
- {"version":3,"file":"form-field.d.ts","sourceRoot":"","sources":["../../../../src/elements/form-field/form-field/form-field.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAY,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAC9F,OAAO,EAAQ,UAAU,EAAW,MAAM,KAAK,CAAC;AAchD,OAAO,eAAe,CAAC;;AAOvB;;;;;;;;GAQG;AACH,qBAGM,mBAAoB,SAAQ,wBAA+C;IAC/E,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,OAAO,CAAC,QAAQ,CAAC,6BAA6B,CAAmC;IAEjF,OAAO,CAAC,QAAQ,CAAC,uBAAuB,CAItC;IAEF,OAAO,CAAC,QAAQ,CAAC,sBAAsB,CAA6B;IAEpE,OAAO,CAAC,QAAQ,CAAC,oCAAoC,CAKnD;IAEF,OAAO,CAAC,QAAQ,CAAC,iCAAiC,CAQhD;IAEF;;;;OAIG;IACH,SACgB,UAAU,EAAE,MAAM,GAAG,SAAS,CAAU;IAExD,+CAA+C;IAC/C,SAEgB,QAAQ,EAAE,OAAO,CAAS;IAE1C,mCAAmC;IACnC,SAA6C,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,CAAO;IAEzE,0DAA0D;IAC1D,SAEgB,UAAU,EAAE,OAAO,CAAS;IAE5C;;+EAE2E;IAC3E,SAA6C,KAAK,EAAE,SAAS,GAAG,UAAU,CAAa;IAEvF,wFAAwF;IACxF,SAEgB,WAAW,EAAE,OAAO,CAAS;IAE7C,4FAA4F;IAC5F,SAEgB,aAAa,EAAE,OAAO,CAAS;IAE/C,qDAAqD;IAC5C,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAiB;IAEzD,oEAAoE;IACpE,OAAO,CAAC,6BAA6B,CAAC,CAAgB;IAEtD,8CAA8C;IACrC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAkE;IAElG,+CAA+C;IACtC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAoB;IAEpD,iCAAiC;IACjC,IAAW,YAAY,IAAI,gBAAgB,GAAG,iBAAiB,GAAG,WAAW,GAAG,SAAS,CAExF;IAED,OAAO,CAAC,MAAM,CAAyC;IACvD,OAAO,CAAC,SAAS,CAAmC;IAEpD;;OAEG;IACH,OAAO,CAAC,2BAA2B,CAM1B;IAET,OAAO,CAAC,qBAAqB,CAAyB;IAEtC,iBAAiB,IAAI,IAAI;cAStB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAQ5D,oBAAoB,IAAI,IAAI;IAM5C,OAAO,CAAC,YAAY;IAMpB,OAAO,CAAC,aAAa;IAMrB,OAAO,CAAC,mBAAmB;IAa3B,OAAO,CAAC,gBAAgB;IAUxB,OAAO,CAAC,kBAAkB;IAW1B;;OAEG;IACH,OAAO,CAAC,kBAAkB;IA4B1B,OAAO,CAAC,yBAAyB;IA4BjC,OAAO,CAAC,sBAAsB;IAuD9B,OAAO,CAAC,aAAa;IAOrB,OAAO,CAAC,yBAAyB;IAQjC,OAAO,CAAC,aAAa;IAerB,OAAO,CAAC,kBAAkB;IAK1B,OAAO,CAAC,YAAY;IAOpB,OAAO,CAAC,eAAe;IAevB;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAsB1B,OAAO,CAAC,qBAAqB;IAiB7B,qFAAqF;IAC9E,KAAK,IAAI,IAAI;IAIpB,4FAA4F;IACrF,KAAK,IAAI,IAAI;IAQpB;;;OAGG;IACI,eAAe,IAAI,gBAAgB,GAAG,iBAAiB,GAAG,WAAW,GAAG,SAAS;IAIxF,OAAO,CAAC,aAAa;cAMF,MAAM,IAAI,cAAc;CAmC5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gBAAgB,EAAE,mBAAmB,CAAC;KACvC;CACF"}
1
+ {"version":3,"file":"form-field.d.ts","sourceRoot":"","sources":["../../../../src/elements/form-field/form-field/form-field.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAY,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAC9F,OAAO,EAAQ,UAAU,EAAW,MAAM,KAAK,CAAC;AAchD,OAAO,eAAe,CAAC;;AASvB;;;;;;;;GAQG;AACH,qBAGM,mBAAoB,SAAQ,wBAA+C;IAC/E,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,OAAO,CAAC,QAAQ,CAAC,6BAA6B,CAAmC;IAEjF,OAAO,CAAC,QAAQ,CAAC,uBAAuB,CAItC;IAEF,OAAO,CAAC,QAAQ,CAAC,sBAAsB,CAA6B;IAEpE,OAAO,CAAC,QAAQ,CAAC,oCAAoC,CAKnD;IAEF,OAAO,CAAC,QAAQ,CAAC,iCAAiC,CAQhD;IAEF;;;;OAIG;IACH,SACgB,UAAU,EAAE,MAAM,GAAG,SAAS,CAAU;IAExD,+CAA+C;IAC/C,SAEgB,QAAQ,EAAE,OAAO,CAAS;IAE1C,mCAAmC;IACnC,SAA6C,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,CAAO;IAEzE,0DAA0D;IAC1D,SAEgB,UAAU,EAAE,OAAO,CAAS;IAE5C;;+EAE2E;IAC3E,SAA6C,KAAK,EAAE,SAAS,GAAG,UAAU,CAAa;IAEvF,wFAAwF;IACxF,SAEgB,WAAW,EAAE,OAAO,CAAS;IAE7C,4FAA4F;IAC5F,SAEgB,aAAa,EAAE,OAAO,CAAS;IAE/C,qDAAqD;IAC5C,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAiB;IAEzD,oEAAoE;IACpE,OAAO,CAAC,6BAA6B,CAAC,CAAgB;IAEtD,8CAA8C;IACrC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAkE;IAElG,+CAA+C;IACtC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAoB;IAEpD,iCAAiC;IACjC,IAAW,YAAY,IAAI,gBAAgB,GAAG,iBAAiB,GAAG,WAAW,GAAG,SAAS,CAExF;IAED,OAAO,CAAC,MAAM,CAAyC;IACvD,OAAO,CAAC,SAAS,CAAmC;IAEpD;;OAEG;IACH,OAAO,CAAC,2BAA2B,CAM1B;IAET,OAAO,CAAC,qBAAqB,CAAyB;IAEtC,iBAAiB,IAAI,IAAI;cAStB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAQ5D,oBAAoB,IAAI,IAAI;IAS5C,OAAO,CAAC,YAAY;IAMpB,OAAO,CAAC,aAAa;IAMrB,OAAO,CAAC,mBAAmB;IAa3B,OAAO,CAAC,gBAAgB;IAUxB,OAAO,CAAC,kBAAkB;IAW1B;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAkC1B,OAAO,CAAC,yBAAyB;IA4BjC,OAAO,CAAC,sBAAsB;IAyD9B,OAAO,CAAC,aAAa;IASrB,OAAO,CAAC,gBAAgB;IA4BxB,OAAO,CAAC,kBAAkB;IAS1B,OAAO,CAAC,yBAAyB;IAQjC,OAAO,CAAC,aAAa;IAerB,OAAO,CAAC,kBAAkB;IAK1B,OAAO,CAAC,YAAY;IAOpB,OAAO,CAAC,eAAe;IAevB;;OAEG;IACH,OAAO,CAAC,kBAAkB;IAsB1B,OAAO,CAAC,qBAAqB;IAiB7B,qFAAqF;IAC9E,KAAK,IAAI,IAAI;IAIpB,4FAA4F;IACrF,KAAK,IAAI,IAAI;IAQpB;;;OAGG;IACI,eAAe,IAAI,gBAAgB,GAAG,iBAAiB,GAAG,WAAW,GAAG,SAAS;IAIxF,OAAO,CAAC,aAAa;cAMF,MAAM,IAAI,cAAc;CAmC5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gBAAgB,EAAE,mBAAmB,CAAC;KACvC;CACF"}