@sbb-esta/lyne-elements 4.2.0 → 4.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (109) hide show
  1. package/accordion/accordion.component.d.ts.map +1 -1
  2. package/accordion/accordion.component.js +12 -16
  3. package/action-group/action-group.component.d.ts.map +1 -1
  4. package/action-group/action-group.component.js +18 -21
  5. package/autocomplete/autocomplete-base-element.d.ts.map +1 -1
  6. package/autocomplete/autocomplete-base-element.js +25 -26
  7. package/autocomplete/autocomplete.component.d.ts.map +1 -1
  8. package/autocomplete/autocomplete.component.js +1 -1
  9. package/breadcrumb/breadcrumb-group/breadcrumb-group.component.d.ts +3 -1
  10. package/breadcrumb/breadcrumb-group/breadcrumb-group.component.d.ts.map +1 -1
  11. package/breadcrumb/breadcrumb-group/breadcrumb-group.component.js +45 -52
  12. package/button/common.d.ts.map +1 -1
  13. package/button/common.js +5 -4
  14. package/button/mini-button/mini-button.component.d.ts +2 -2
  15. package/button/mini-button/mini-button.component.d.ts.map +1 -1
  16. package/button/mini-button/mini-button.component.js +22 -20
  17. package/button/mini-button-group/mini-button-group.component.d.ts.map +1 -1
  18. package/button/mini-button-group/mini-button-group.component.js +14 -10
  19. package/button/mini-button-link/mini-button-link.component.d.ts +21 -0
  20. package/button/mini-button-link/mini-button-link.component.d.ts.map +1 -0
  21. package/button/mini-button-link/mini-button-link.component.js +35 -0
  22. package/button/mini-button-link.d.ts +5 -0
  23. package/button/mini-button-link.d.ts.map +1 -0
  24. package/button/mini-button-link.js +4 -0
  25. package/button.d.ts +1 -0
  26. package/button.d.ts.map +1 -1
  27. package/button.js +28 -25
  28. package/chip/chip-group/chip-group.component.d.ts +2 -5
  29. package/chip/chip-group/chip-group.component.d.ts.map +1 -1
  30. package/chip/chip-group/chip-group.component.js +70 -68
  31. package/core/controllers/media-matchers-controller.js +2 -2
  32. package/core/styles/core.scss +19 -0
  33. package/core.css +28 -0
  34. package/custom-elements.json +1003 -312
  35. package/development/accordion/accordion.component.d.ts.map +1 -1
  36. package/development/accordion/accordion.component.js +2 -6
  37. package/development/action-group/action-group.component.d.ts.map +1 -1
  38. package/development/action-group/action-group.component.js +13 -22
  39. package/development/autocomplete/autocomplete-base-element.d.ts.map +1 -1
  40. package/development/autocomplete/autocomplete-base-element.js +4 -2
  41. package/development/autocomplete/autocomplete.component.d.ts.map +1 -1
  42. package/development/autocomplete/autocomplete.component.js +2 -2
  43. package/development/breadcrumb/breadcrumb-group/breadcrumb-group.component.d.ts +3 -1
  44. package/development/breadcrumb/breadcrumb-group/breadcrumb-group.component.d.ts.map +1 -1
  45. package/development/breadcrumb/breadcrumb-group/breadcrumb-group.component.js +26 -29
  46. package/development/button/common.d.ts.map +1 -1
  47. package/development/button/common.js +3 -2
  48. package/development/button/mini-button/mini-button.component.d.ts +2 -2
  49. package/development/button/mini-button/mini-button.component.d.ts.map +1 -1
  50. package/development/button/mini-button/mini-button.component.js +7 -35
  51. package/development/button/mini-button-group/mini-button-group.component.d.ts.map +1 -1
  52. package/development/button/mini-button-group/mini-button-group.component.js +8 -4
  53. package/development/button/mini-button-link/mini-button-link.component.d.ts +21 -0
  54. package/development/button/mini-button-link/mini-button-link.component.d.ts.map +1 -0
  55. package/development/button/mini-button-link/mini-button-link.component.js +47 -0
  56. package/development/button/mini-button-link.d.ts +5 -0
  57. package/development/button/mini-button-link.d.ts.map +1 -0
  58. package/development/button/mini-button-link.js +5 -0
  59. package/development/button.d.ts +1 -0
  60. package/development/button.d.ts.map +1 -1
  61. package/development/button.js +6 -3
  62. package/development/chip/chip-group/chip-group.component.d.ts +2 -5
  63. package/development/chip/chip-group/chip-group.component.d.ts.map +1 -1
  64. package/development/chip/chip-group/chip-group.component.js +78 -14
  65. package/development/core/controllers/media-matchers-controller.js +1 -1
  66. package/development/dialog/dialog-actions/dialog-actions.component.js +2 -1
  67. package/development/divider/divider.component.d.ts +2 -2
  68. package/development/divider/divider.component.d.ts.map +1 -1
  69. package/development/divider/divider.component.js +4 -6
  70. package/development/expansion-panel/expansion-panel/expansion-panel.component.d.ts.map +1 -1
  71. package/development/expansion-panel/expansion-panel/expansion-panel.component.js +39 -34
  72. package/development/expansion-panel/expansion-panel-content/expansion-panel-content.component.d.ts.map +1 -1
  73. package/development/expansion-panel/expansion-panel-content/expansion-panel-content.component.js +15 -13
  74. package/development/expansion-panel/expansion-panel-header/expansion-panel-header.component.js +23 -21
  75. package/development/form-field/form-field/form-field.component.d.ts +2 -0
  76. package/development/form-field/form-field/form-field.component.d.ts.map +1 -1
  77. package/development/form-field/form-field/form-field.component.js +6 -2
  78. package/development/image/image.component.js +1 -1
  79. package/development/lead-container/lead-container.component.d.ts +3 -1
  80. package/development/lead-container/lead-container.component.d.ts.map +1 -1
  81. package/development/lead-container/lead-container.component.js +7 -2
  82. package/development/{mini-button-common-CWTMR_Lu.js → mini-button-label-common-DzMdb-kV.js} +37 -3
  83. package/development/navigation/navigation-section/navigation-section.component.js +4 -4
  84. package/development/{sbb-tokens-CZCt5L4q.js → sbb-tokens-DQT_xEIZ.js} +7 -7
  85. package/dialog/dialog-actions/dialog-actions.component.js +1 -1
  86. package/divider/divider.component.d.ts +2 -2
  87. package/divider/divider.component.d.ts.map +1 -1
  88. package/divider/divider.component.js +12 -12
  89. package/expansion-panel/expansion-panel/expansion-panel.component.d.ts.map +1 -1
  90. package/expansion-panel/expansion-panel/expansion-panel.component.js +31 -31
  91. package/expansion-panel/expansion-panel-content/expansion-panel-content.component.d.ts.map +1 -1
  92. package/expansion-panel/expansion-panel-content/expansion-panel-content.component.js +10 -14
  93. package/expansion-panel/expansion-panel-header/expansion-panel-header.component.js +19 -19
  94. package/form-field/form-field/form-field.component.d.ts +2 -0
  95. package/form-field/form-field/form-field.component.d.ts.map +1 -1
  96. package/form-field/form-field/form-field.component.js +5 -1
  97. package/image/image.component.js +1 -1
  98. package/index.d.ts +2 -0
  99. package/index.js +2 -0
  100. package/lead-container/lead-container.component.d.ts +3 -1
  101. package/lead-container/lead-container.component.d.ts.map +1 -1
  102. package/lead-container/lead-container.component.js +9 -8
  103. package/{mini-button-common-Bb4ri3Rn.js → mini-button-label-common-ps7PVXtB.js} +4 -3
  104. package/navigation/navigation-section/navigation-section.component.js +1 -1
  105. package/off-brand-theme.css +28 -0
  106. package/package.json +6 -1
  107. package/safety-theme.css +28 -0
  108. package/{sbb-tokens-DruExozg.js → sbb-tokens-HiNSQasB.js} +6 -6
  109. package/standard-theme.css +28 -0
@@ -9,14 +9,16 @@ import { __esDecorate, __runInitializers } from "tslib";
9
9
  import { css, LitElement, isServer, html } from "lit";
10
10
  import { customElement, property } from "lit/decorators.js";
11
11
  import { isArrowKeyPressed, getNextElementIndex } from "../../core/a11y.js";
12
- import { SbbLanguageController } from "../../core/controllers.js";
13
- import { isLean } from "../../core/dom.js";
12
+ import { SbbLanguageController, SbbPropertyWatcherController } from "../../core/controllers.js";
13
+ import { isLean } from "../../core/dom/lean-context.js";
14
14
  import { i18nSelectionRequired, i18nChipGroupInputDescription } from "../../core/i18n.js";
15
15
  import { SbbRequiredMixin, SbbDisabledMixin, SbbNegativeMixin, SbbFormAssociatedMixin, SbbElementInternalsMixin } from "../../core/mixins.js";
16
16
  import { boxSizingStyles } from "../../core/styles.js";
17
17
  import { SbbChipElement } from "../chip.js";
18
18
  const style = css`:host {
19
19
  --sbb-chip-group-input-min-width: 9.375rem;
20
+ --_sbb-chip-group-margin-block-start-default: 0.125rem;
21
+ --_sbb-chip-group-margin-block-start-default-large: 0.21875rem;
20
22
  max-width: 100%;
21
23
  }
22
24
 
@@ -29,8 +31,69 @@ const style = css`:host {
29
31
  }
30
32
  }
31
33
 
34
+ :host(:is(:state(without-label),[state--without-label]):is(:state(size-s),[state--size-s]):not(:is(:state(empty),[state--empty]))) {
35
+ --sbb-chip-group-margin-block: 0 0.4375rem;
36
+ }
37
+ @media (min-width: calc(64rem)) {
38
+ :host(:is(:state(without-label),[state--without-label]):is(:state(size-s),[state--size-s]):not(:is(:state(empty),[state--empty]))) {
39
+ --sbb-chip-group-margin-block: 0 0.3125rem;
40
+ }
41
+ }
42
+
43
+ :host(:is(:is(:state(size-l),[state--size-l]), :is(:state(size-m),[state--size-m]))) {
44
+ --sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default) var(0);
45
+ }
46
+ @media (min-width: calc(64rem)) {
47
+ :host(:is(:is(:state(size-l),[state--size-l]), :is(:state(size-m),[state--size-m]))) {
48
+ --sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default-large) var(0);
49
+ }
50
+ }
51
+
52
+ :host(:is(:state(without-label),[state--without-label]):is(:state(size-m),[state--size-m]):not(:is(:state(empty),[state--empty]))) {
53
+ --sbb-chip-group-margin-block: 0.1875rem 0.6875rem;
54
+ }
55
+ @media (min-width: calc(64rem)) {
56
+ :host(:is(:state(without-label),[state--without-label]):is(:state(size-m),[state--size-m]):not(:is(:state(empty),[state--empty]))) {
57
+ --sbb-chip-group-margin-block: 0.1875rem 0.875rem;
58
+ }
59
+ }
60
+
61
+ :host(:not(:is(:state(without-label),[state--without-label])):is(:state(size-m),[state--size-m]):not(:is(:state(empty),[state--empty]))) {
62
+ --sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default)
63
+ var(--_sbb-chip-group-margin-block-start-default-large);
64
+ }
65
+ @media (min-width: calc(64rem)) {
66
+ :host(:not(:is(:state(without-label),[state--without-label])):is(:state(size-m),[state--size-m]):not(:is(:state(empty),[state--empty]))) {
67
+ --sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default-large)
68
+ var(--_sbb-chip-group-margin-block-start-default-large);
69
+ }
70
+ }
71
+
72
+ :host(:is(:state(without-label),[state--without-label]):is(:state(size-l),[state--size-l]):not(:is(:state(empty),[state--empty]))) {
73
+ --sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default)
74
+ 1rem;
75
+ }
76
+ @media (min-width: calc(64rem)) {
77
+ :host(:is(:state(without-label),[state--without-label]):is(:state(size-l),[state--size-l]):not(:is(:state(empty),[state--empty]))) {
78
+ --sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default-large)
79
+ 1.25rem;
80
+ }
81
+ }
82
+
83
+ :host(:not(:is(:state(without-label),[state--without-label])):is(:state(size-l),[state--size-l]):not(:is(:state(empty),[state--empty]))) {
84
+ --sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default)
85
+ 0.46875rem;
86
+ }
87
+ @media (min-width: calc(64rem)) {
88
+ :host(:not(:is(:state(without-label),[state--without-label])):is(:state(size-l),[state--size-l]):not(:is(:state(empty),[state--empty]))) {
89
+ --sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default-large)
90
+ 0.46875rem;
91
+ }
92
+ }
93
+
32
94
  ::slotted(input) {
33
95
  flex: 1 1 var(--sbb-chip-group-input-min-width);
96
+ max-height: 1.5rem;
34
97
  }
35
98
 
36
99
  ::slotted(sbb-chip) {
@@ -69,10 +132,14 @@ let SbbChipGroupElement = (() => {
69
132
  __privateSet(this, _displayWith_accessor_storage, (__runInitializers(this, _instanceExtraInitializers), __runInitializers(this, _displayWith_initializers, null)));
70
133
  __privateSet(this, _separatorKeys_accessor_storage, (__runInitializers(this, _displayWith_extraInitializers), __runInitializers(this, _separatorKeys_initializers, ["Enter"])));
71
134
  this._inputAttributeObserver = (__runInitializers(this, _separatorKeys_extraInitializers), !isServer ? new MutationObserver(() => this._reactToInputChanges()) : null);
72
- this._formFieldAttributeObserver = !isServer ? new MutationObserver(() => this._inheritSize()) : null;
73
135
  this._language = new SbbLanguageController(this);
74
136
  this.addEventListener?.(SbbChipElement.events.requestdelete, (ev) => this._deleteChip(ev.target));
75
137
  this.addEventListener?.("keydown", (ev) => this._onChipKeyDown(ev));
138
+ this.addController(new SbbPropertyWatcherController(this, () => this.closest("sbb-form-field"), {
139
+ size: (formField) => this._updateSize(formField.size),
140
+ label: (formField) => this._updateLabelState(formField),
141
+ hiddenLabel: (formField) => this._updateLabelState(formField)
142
+ }));
76
143
  }
77
144
  /** Value of the form element. */
78
145
  set value(value) {
@@ -110,6 +177,9 @@ let SbbChipGroupElement = (() => {
110
177
  set separatorKeys(value) {
111
178
  __privateSet(this, _separatorKeys_accessor_storage, value);
112
179
  }
180
+ _updateLabelState(formField) {
181
+ this.toggleState("without-label", !formField.label || formField.hiddenLabel);
182
+ }
113
183
  connectedCallback() {
114
184
  super.connectedCallback();
115
185
  this._setupComponent();
@@ -174,14 +244,8 @@ let SbbChipGroupElement = (() => {
174
244
  attributeFilter: ["readonly", "disabled"]
175
245
  });
176
246
  }
177
- this._inheritSize();
178
- this._formFieldAttributeObserver?.disconnect();
179
- const formField = this.closest("sbb-form-field");
180
- if (formField) {
181
- this._formFieldAttributeObserver?.observe(formField, {
182
- attributes: true,
183
- attributeFilter: ["size"]
184
- });
247
+ if (!this._previousSize || !this.closest("sbb-form-field")) {
248
+ this._updateSize(isLean() ? "s" : "m");
185
249
  }
186
250
  this.toggleState("empty", this.value.length === 0);
187
251
  this._reactToInputChanges();
@@ -314,11 +378,11 @@ let SbbChipGroupElement = (() => {
314
378
  c.negative = this.negative;
315
379
  });
316
380
  }
317
- _inheritSize() {
381
+ _updateSize(size) {
318
382
  if (this._previousSize) {
319
383
  this.internals.states.delete(`size-${this._previousSize}`);
320
384
  }
321
- this._previousSize = this.closest("sbb-form-field")?.size ?? (isLean() ? "s" : "m");
385
+ this._previousSize = size;
322
386
  if (this._previousSize) {
323
387
  this.internals.states.add(`size-${this._previousSize}`);
324
388
  }
@@ -363,4 +427,4 @@ let SbbChipGroupElement = (() => {
363
427
  export {
364
428
  SbbChipGroupElement
365
429
  };
366
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"chip-group.component.js","sources":["../../../../../src/elements/chip/chip-group/chip-group.component.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  LitElement,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { getNextElementIndex, isArrowKeyPressed } from '../../core/a11y.ts';\nimport { SbbLanguageController } from '../../core/controllers.ts';\nimport { isLean } from '../../core/dom.ts';\nimport { i18nChipGroupInputDescription, i18nSelectionRequired } from '../../core/i18n.ts';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbDisabledMixin,\n  SbbElementInternalsMixin,\n  SbbFormAssociatedMixin,\n  SbbNegativeMixin,\n  SbbRequiredMixin,\n} from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbFormFieldElement } from '../../form-field/form-field/form-field.component.ts';\nimport type { SbbOptionBaseElement } from '../../option/option/option-base-element.ts';\nimport { SbbChipElement } from '../chip.ts';\n\nimport style from './chip-group.scss?lit&inline';\n\nlet displayWithWarningLogged = false;\n\nexport interface SbbChipInputTokenEndEventDetails<T = string> {\n  /** The element that triggered the chip creation */\n  origin: 'input' | 'autocomplete';\n  /**\n   * The value of the new chip. Either the input or the option value depending on the origin.\n   * Either the value from the input which is always `string` or the value from the selected option\n   * from an autocomplete, which can be either a string or any other type.\n   */\n  value: T | string;\n  label?: string;\n  /** Set a new value for the chip that will be created */\n  setValue(value: T): void;\n  /** Set a label for the chip that will be created */\n  setLabel(value: string): void;\n}\n\n/**\n * The `sbb-chip-group` component is used as a container for one or multiple `sbb-chip`.\n *\n * @slot - Use the unnamed slot to add `sbb-chip` elements.\n * @overrideType value - (T = string[]) | null\n */\nexport\n@customElement('sbb-chip-group')\nclass SbbChipGroupElement<T = string> extends SbbRequiredMixin(\n  SbbDisabledMixin(SbbNegativeMixin(SbbFormAssociatedMixin(SbbElementInternalsMixin(LitElement)))),\n) {\n  public static override readonly role = 'listbox';\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  public static readonly events = {\n    input: 'input',\n    change: 'change',\n    chipinputtokenend: 'chipinputtokenend',\n  } as const;\n\n  /** Value of the form element. */\n  @property({ type: Array })\n  public set value(value: (T | null)[] | null) {\n    value = value ?? [];\n    const oldValue = this.value;\n\n    // Subtract from 'oldValue' the new 'value'\n    // The result are the chips to remove (handle duplicates)\n    const toRemove = [...oldValue];\n    for (const c of value) {\n      if (toRemove.includes(c)) {\n        toRemove.splice(toRemove.indexOf(c), 1);\n      }\n    }\n    toRemove.forEach((value) =>\n      this._chipElements()\n        .find((c) => c.value === value)\n        ?.remove(),\n    );\n\n    // Subtract from the new 'value' what was already present\n    // The result are the new chips to add (handle duplicates)\n    const toAdd = [...value];\n    for (const c of oldValue) {\n      if (toAdd.includes(c)) {\n        toAdd.splice(toAdd.indexOf(c), 1);\n      }\n    }\n    toAdd.forEach((c) => this._createChipElement(c));\n  }\n  public get value(): (T | null)[] {\n    return this._chipElements().map((c) => c.value);\n  }\n\n  /** Function that maps a chip's value to its display value. */\n  @property({ attribute: false })\n  public accessor displayWith: ((value: T) => string) | null = null;\n\n  /** The array of keys that will trigger a `chipinputtokenend` event. Default `['Enter']` */\n  @property({ attribute: 'separator-keys', type: Array })\n  public accessor separatorKeys: string[] = ['Enter'];\n\n  /**\n   * Listens to the changes on `readonly` and `disabled` attributes of `<input>`.\n   */\n  private _inputAttributeObserver = !isServer\n    ? new MutationObserver(() => this._reactToInputChanges())\n    : null;\n\n  /**\n   * Listens to the 'size' changes on the `sbb-form-field`.\n   */\n  private _formFieldAttributeObserver = !isServer\n    ? new MutationObserver(() => this._inheritSize())\n    : null;\n\n  private _inputElement: HTMLInputElement | undefined;\n  private _inputAbortController: AbortController | undefined;\n  private _language = new SbbLanguageController(this);\n  private _previousSize?: SbbFormFieldElement['size'];\n\n  public constructor() {\n    super();\n\n    this.addEventListener?.(SbbChipElement.events.requestdelete, (ev) =>\n      this._deleteChip(ev.target as SbbChipElement<T>),\n    );\n\n    this.addEventListener?.('keydown', (ev) => this._onChipKeyDown(ev));\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this._setupComponent();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues): void {\n    super.willUpdate(changedProperties);\n\n    if (\n      changedProperties.has('disabled') ||\n      changedProperties.has('formDisabled') ||\n      changedProperties.has('negative')\n    ) {\n      this._proxyStateToChips();\n    }\n  }\n\n  /** @internal */\n  public formResetCallback(): void {\n    this.value = null;\n  }\n\n  /** @internal */\n  public formStateRestoreCallback(\n    state: FormRestoreState | null,\n    _reason: FormRestoreReason,\n  ): void {\n    if (!state) {\n      this.value = null;\n      return;\n    }\n\n    this._readFormData(state as FormData).then((array) => (this.value = array));\n  }\n\n  private async _readFormData(formData: FormData): Promise<T[]> {\n    return Promise.all(\n      formData\n        .getAll(this.name)\n        .map(async (entry) =>\n          entry instanceof Blob ? JSON.parse(await entry.text()) : (entry as T),\n        ),\n    );\n  }\n\n  protected override shouldValidate(name: PropertyKey | undefined): boolean {\n    return super.shouldValidate(name) || name === 'required' || name === 'value';\n  }\n\n  protected override validate(): void {\n    super.validate();\n    if (this.required && this.value.length === 0) {\n      this.setValidityFlag('valueMissing', i18nSelectionRequired[this._language.current]);\n    } else {\n      this.removeValidityFlag('valueMissing');\n    }\n  }\n\n  /** Return the list of chip elements **/\n  private _chipElements(): SbbChipElement<T>[] {\n    return Array.from(this.querySelectorAll?.<SbbChipElement<T>>('sbb-chip') ?? []);\n  }\n\n  /** Return the list of enabled chip elements **/\n  private _enabledChipElements(): SbbChipElement<T>[] {\n    return Array.from(this.querySelectorAll?.('sbb-chip:not([disabled])') ?? []);\n  }\n\n  private _setupComponent(): void {\n    const input = this.querySelector('input');\n\n    // Connect to the input\n    if (input && input !== this._inputElement) {\n      this._inputAbortController?.abort();\n      this._inputAttributeObserver?.disconnect();\n      this._inputElement = input;\n\n      this._inputAbortController = new AbortController();\n      this._inputElement.addEventListener('keydown', (ev) => this._onInputKeyDown(ev), {\n        signal: this._inputAbortController.signal,\n      });\n      this._inputElement.addEventListener(\n        'inputAutocomplete',\n        (event: CustomEvent<{ option: SbbOptionBaseElement<T> }>) => {\n          this._createChipFromInput('autocomplete', event.detail?.option.value);\n        },\n        {\n          signal: this._inputAbortController.signal,\n        },\n      );\n\n      this._inputAttributeObserver?.observe(this._inputElement, {\n        attributes: true,\n        attributeFilter: ['readonly', 'disabled'],\n      });\n    }\n\n    // Inherit size from the form-field and observe for changes\n    this._inheritSize();\n    this._formFieldAttributeObserver?.disconnect();\n    const formField = this.closest('sbb-form-field');\n    if (formField) {\n      this._formFieldAttributeObserver?.observe(formField, {\n        attributes: true,\n        attributeFilter: ['size'],\n      });\n    }\n\n    this.toggleState('empty', this.value.length === 0);\n    this._reactToInputChanges();\n    this._updateInputDescription();\n    this.updateFormValue();\n  }\n\n  /**\n   * Listen for keyboard events on the chip elements\n   **/\n  private _onChipKeyDown(event: KeyboardEvent): void {\n    const eventTarget = event.target as SbbChipElement<T>;\n    if (eventTarget.localName !== 'sbb-chip') {\n      return;\n    }\n\n    // Arrow keys allow navigation between chips focus steps\n    if (isArrowKeyPressed(event)) {\n      const focusSteps = this._enabledChipElements();\n      const next = getNextElementIndex(event, focusSteps.indexOf(eventTarget), focusSteps.length);\n      focusSteps[next].focus();\n      return;\n    }\n\n    switch (event.key) {\n      case 'Backspace':\n      case 'Delete':\n        if (!eventTarget.readOnly && !eventTarget.disabled) {\n          event.preventDefault();\n          this._deleteChip(eventTarget);\n        }\n        break;\n    }\n  }\n\n  /**\n   * Listen for keyboard events on the input\n   **/\n  private _onInputKeyDown(event: KeyboardEvent): void {\n    switch (event.key) {\n      case 'Backspace':\n      case 'ArrowLeft':\n        if (!this._inputElement!.value) {\n          this._focusChip();\n        }\n        break;\n      case 'Enter':\n        event.preventDefault(); // Prevents the form submit\n        break;\n    }\n\n    // if the user typed one of the separator keys, trigger a 'chipinputtokenend' event\n    if (this.separatorKeys.includes(event.key)) {\n      event.preventDefault(); // prevent typing the separator key into the input\n      this._createChipFromInput('input');\n    }\n  }\n\n  /**\n   * If the input is not empty, create a chip with its value\n   */\n  private _createChipFromInput(origin: 'input' | 'autocomplete' = 'input', value?: T): void {\n    const inputValue = value ?? this._inputElement!.value.trim();\n    if (!inputValue) {\n      return;\n    }\n\n    const eventDetail: SbbChipInputTokenEndEventDetails<T> = {\n      origin: origin,\n      value: inputValue,\n      label: (value ? this.displayWith?.(value) : null) ?? undefined,\n      setValue: (value: T) => (eventDetail.value = value),\n      setLabel: (label: string) => (eventDetail.label = label),\n    };\n\n    if (!this._dispatchChipInputTokenEnd(eventDetail)) {\n      return; // event prevented; do nothing (the consumer has to create the chip)\n    }\n\n    this._createChipElement(eventDetail.value as T, eventDetail.label);\n    this._inputElement!.value = ''; // Empty the input\n    this._emitInputEvents();\n  }\n\n  private _dispatchChipInputTokenEnd(eventDetail: SbbChipInputTokenEndEventDetails<T>): boolean {\n    /**\n     * @type {CustomEvent<SbbChipInputTokenEndEventDetails>}\n     * Notifies that a chip is about to be created. Can be prevented.\n     */\n    return this.dispatchEvent(\n      new CustomEvent<SbbChipInputTokenEndEventDetails<T>>('chipinputtokenend', {\n        detail: eventDetail,\n        cancelable: true,\n        bubbles: true,\n        composed: true,\n      }),\n    );\n  }\n\n  private _deleteChip(chip: SbbChipElement<T>): void {\n    const chips = this._enabledChipElements();\n    chip.remove();\n    this._emitInputEvents();\n    this._focusChip(chips.indexOf(chip)); // Focus the next chip\n  }\n\n  /**\n   * Focus an enabled chip. If none are present, focus the input\n   * @param index The index of the enabled chip. If null, focus the last one.\n   */\n  private _focusChip(index?: number): void {\n    const enabledChips = this._enabledChipElements();\n\n    if (index !== undefined && enabledChips[index]) {\n      enabledChips[index].focus();\n      return;\n    }\n\n    if (enabledChips.length > 0) {\n      enabledChips[enabledChips.length - 1].focus();\n      return;\n    }\n\n    this._inputElement?.focus();\n  }\n\n  private _emitInputEvents(): void {\n    /** The input event fires when the value has been changed as a direct result of a user action. */\n    this.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n\n    /**\n     * The change event is fired when the user modifies the element's value.\n     * Unlike the input event, the change event is not necessarily fired\n     * for each alteration to an element's value.\n     */\n    this.dispatchEvent(new Event('change', { bubbles: true }));\n  }\n\n  private _createChipElement(value: T | null, label?: string): void {\n    if (isServer) {\n      return;\n    }\n    const newChip = document.createElement('sbb-chip') as SbbChipElement<T>;\n    newChip.value = value;\n    newChip.innerText = label ?? (value ? this.displayWith?.(value) : null) ?? '';\n    if (\n      import.meta.env.DEV &&\n      !displayWithWarningLogged &&\n      !label &&\n      typeof value === 'object' &&\n      !this.displayWith\n    ) {\n      console.warn(\n        `displayWith has not been set yet for sbb-chip-group and value is an object.\n         If you are using object values, you need to provide displayWidth before\n         setting or selecting any value.`,\n      );\n      displayWithWarningLogged = true;\n    }\n    this.insertBefore(newChip, this._inputElement ?? this.querySelector('input'));\n  }\n\n  private _reactToInputChanges(): void {\n    this.disabled = this._inputElement?.disabled ?? false;\n    this._proxyStateToChips();\n  }\n\n  private _proxyStateToChips(): void {\n    this._chipElements().forEach((c) => {\n      c.disabled = this.disabled || this.formDisabled;\n      c.readOnly = this._inputElement?.hasAttribute('readonly') ?? false;\n      c.negative = this.negative;\n    });\n  }\n\n  private _inheritSize(): void {\n    if (this._previousSize) {\n      this.internals.states.delete(`size-${this._previousSize}`);\n    }\n    this._previousSize = this.closest('sbb-form-field')?.size ?? (isLean() ? 's' : 'm');\n    if (this._previousSize) {\n      this.internals.states.add(`size-${this._previousSize}`);\n    }\n  }\n\n  private _updateInputDescription(): void {\n    if (!this._inputElement) {\n      return;\n    }\n    this._inputElement.setAttribute(\n      'aria-description',\n      `${i18nChipGroupInputDescription[this._language.current]} ${this.value.length}`,\n    );\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-chip-group\">\n        <slot @slotchange=${this._setupComponent}></slot>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-chip-group': SbbChipGroupElement;\n  }\n}\n\ndeclare global {\n  interface HTMLElementEventMap {\n    chipinputtokenend: CustomEvent<SbbChipInputTokenEndEventDetails<any>>;\n  }\n}\n"],"names":["value"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA8BA,IAAI,2BAA2B;IA0BzB,uBAAmB,MAAA;;0BADxB,cAAc,gBAAgB,CAAC;;;;AACc,MAAA,cAAA,iBAC5C,iBAAiB,iBAAiB,uBAAuB,yBAAyB,UAAU,CAAC,CAAC,CAAC,CAAC;;;;;;;;;AAD5D,EAAA,mBAAQ,YAE7C;AAAA,IAsEC,cAAA;AACE,YAAA;AA1BF;AAIA;AAJgB,yBAAA,gCA/CZ,kBAAA,MAAA,0BAAA,GAAmB,kBAAA,MAAA,2BA+CsC,IAAI;AAIjD,yBAAA,kCAAA,kBAAA,MAAA,8BAAA,GAAA,kBAAA,MAAA,6BAA0B,CAAC,OAAO,CAAC;AAK3C,WAAA,2BAAuB,kBAAA,MAAA,gCAAA,GAAG,CAAC,WAC/B,IAAI,iBAAiB,MAAM,KAAK,qBAAA,CAAsB,IACtD;AAKI,WAAA,8BAA8B,CAAC,WACnC,IAAI,iBAAiB,MAAM,KAAK,aAAA,CAAc,IAC9C;AAII,WAAA,YAAY,IAAI,sBAAsB,IAAI;AAMhD,WAAK,mBAAmB,eAAe,OAAO,eAAe,CAAC,OAC5D,KAAK,YAAY,GAAG,MAA2B,CAAC;AAGlD,WAAK,mBAAmB,WAAW,CAAC,OAAO,KAAK,eAAe,EAAE,CAAC;AAAA,IACpE;AAAA;AAAA,IAnEA,IAAW,MAAM,OAA0B;AACzC,cAAQ,SAAS,CAAA;AACjB,YAAM,WAAW,KAAK;AAItB,YAAM,WAAW,CAAC,GAAG,QAAQ;AAC7B,iBAAW,KAAK,OAAO;AACrB,YAAI,SAAS,SAAS,CAAC,GAAG;AACxB,mBAAS,OAAO,SAAS,QAAQ,CAAC,GAAG,CAAC;AAAA,QACxC;AAAA,MACF;AACA,eAAS,QAAQ,CAACA,WAChB,KAAK,gBACF,KAAK,CAAC,MAAM,EAAE,UAAUA,MAAK,GAC5B,QAAQ;AAKd,YAAM,QAAQ,CAAC,GAAG,KAAK;AACvB,iBAAW,KAAK,UAAU;AACxB,YAAI,MAAM,SAAS,CAAC,GAAG;AACrB,gBAAM,OAAO,MAAM,QAAQ,CAAC,GAAG,CAAC;AAAA,QAClC;AAAA,MACF;AACA,YAAM,QAAQ,CAAC,MAAM,KAAK,mBAAmB,CAAC,CAAC;AAAA,IACjD;AAAA,IACA,IAAW,QAAK;AACd,aAAO,KAAK,gBAAgB,IAAI,CAAC,MAAM,EAAE,KAAK;AAAA,IAChD;AAAA;AAAA,IAIA,IAAgB,cAAW;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA3B,IAAgB,YAAW,OAAA;AAAA,yBAAA,+BAAA;AAAA,IAAA;AAAA;AAAA,IAI3B,IAAgB,gBAAa;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA7B,IAAgB,cAAa,OAAA;AAAA,yBAAA,iCAAA;AAAA,IAAA;AAAA,IA+Bb,oBAAiB;AAC/B,YAAM,kBAAA;AACN,WAAK,gBAAA;AAAA,IACP;AAAA,IAEmB,WAAW,mBAAiC;AAC7D,YAAM,WAAW,iBAAiB;AAElC,UACE,kBAAkB,IAAI,UAAU,KAChC,kBAAkB,IAAI,cAAc,KACpC,kBAAkB,IAAI,UAAU,GAChC;AACA,aAAK,mBAAA;AAAA,MACP;AAAA,IACF;AAAA;AAAA,IAGO,oBAAiB;AACtB,WAAK,QAAQ;AAAA,IACf;AAAA;AAAA,IAGO,yBACL,OACA,SAA0B;AAE1B,UAAI,CAAC,OAAO;AACV,aAAK,QAAQ;AACb;AAAA,MACF;AAEA,WAAK,cAAc,KAAiB,EAAE,KAAK,CAAC,UAAW,KAAK,QAAQ,KAAM;AAAA,IAC5E;AAAA,IAEQ,MAAM,cAAc,UAAkB;AAC5C,aAAO,QAAQ,IACb,SACG,OAAO,KAAK,IAAI,EAChB,IAAI,OAAO,UACV,iBAAiB,OAAO,KAAK,MAAM,MAAM,MAAM,MAAM,IAAK,KAAW,CACtE;AAAA,IAEP;AAAA,IAEmB,eAAe,MAA6B;AAC7D,aAAO,MAAM,eAAe,IAAI,KAAK,SAAS,cAAc,SAAS;AAAA,IACvE;AAAA,IAEmB,WAAQ;AACzB,YAAM,SAAA;AACN,UAAI,KAAK,YAAY,KAAK,MAAM,WAAW,GAAG;AAC5C,aAAK,gBAAgB,gBAAgB,sBAAsB,KAAK,UAAU,OAAO,CAAC;AAAA,MACpF,OAAO;AACL,aAAK,mBAAmB,cAAc;AAAA,MACxC;AAAA,IACF;AAAA;AAAA,IAGQ,gBAAa;AACnB,aAAO,MAAM,KAAK,KAAK,mBAAsC,UAAU,KAAK,EAAE;AAAA,IAChF;AAAA;AAAA,IAGQ,uBAAoB;AAC1B,aAAO,MAAM,KAAK,KAAK,mBAAmB,0BAA0B,KAAK,EAAE;AAAA,IAC7E;AAAA,IAEQ,kBAAe;AACrB,YAAM,QAAQ,KAAK,cAAc,OAAO;AAGxC,UAAI,SAAS,UAAU,KAAK,eAAe;AACzC,aAAK,uBAAuB,MAAA;AAC5B,aAAK,yBAAyB,WAAA;AAC9B,aAAK,gBAAgB;AAErB,aAAK,wBAAwB,IAAI,gBAAA;AACjC,aAAK,cAAc,iBAAiB,WAAW,CAAC,OAAO,KAAK,gBAAgB,EAAE,GAAG;AAAA,UAC/E,QAAQ,KAAK,sBAAsB;AAAA,QAAA,CACpC;AACD,aAAK,cAAc,iBACjB,qBACA,CAAC,UAA2D;AAC1D,eAAK,qBAAqB,gBAAgB,MAAM,QAAQ,OAAO,KAAK;AAAA,QACtE,GACA;AAAA,UACE,QAAQ,KAAK,sBAAsB;AAAA,QAAA,CACpC;AAGH,aAAK,yBAAyB,QAAQ,KAAK,eAAe;AAAA,UACxD,YAAY;AAAA,UACZ,iBAAiB,CAAC,YAAY,UAAU;AAAA,QAAA,CACzC;AAAA,MACH;AAGA,WAAK,aAAA;AACL,WAAK,6BAA6B,WAAA;AAClC,YAAM,YAAY,KAAK,QAAQ,gBAAgB;AAC/C,UAAI,WAAW;AACb,aAAK,6BAA6B,QAAQ,WAAW;AAAA,UACnD,YAAY;AAAA,UACZ,iBAAiB,CAAC,MAAM;AAAA,QAAA,CACzB;AAAA,MACH;AAEA,WAAK,YAAY,SAAS,KAAK,MAAM,WAAW,CAAC;AACjD,WAAK,qBAAA;AACL,WAAK,wBAAA;AACL,WAAK,gBAAA;AAAA,IACP;AAAA;AAAA;AAAA;AAAA,IAKQ,eAAe,OAAoB;AACzC,YAAM,cAAc,MAAM;AAC1B,UAAI,YAAY,cAAc,YAAY;AACxC;AAAA,MACF;AAGA,UAAI,kBAAkB,KAAK,GAAG;AAC5B,cAAM,aAAa,KAAK,qBAAA;AACxB,cAAM,OAAO,oBAAoB,OAAO,WAAW,QAAQ,WAAW,GAAG,WAAW,MAAM;AAC1F,mBAAW,IAAI,EAAE,MAAA;AACjB;AAAA,MACF;AAEA,cAAQ,MAAM,KAAA;AAAA,QACZ,KAAK;AAAA,QACL,KAAK;AACH,cAAI,CAAC,YAAY,YAAY,CAAC,YAAY,UAAU;AAClD,kBAAM,eAAA;AACN,iBAAK,YAAY,WAAW;AAAA,UAC9B;AACA;AAAA,MAAA;AAAA,IAEN;AAAA;AAAA;AAAA;AAAA,IAKQ,gBAAgB,OAAoB;AAC1C,cAAQ,MAAM,KAAA;AAAA,QACZ,KAAK;AAAA,QACL,KAAK;AACH,cAAI,CAAC,KAAK,cAAe,OAAO;AAC9B,iBAAK,WAAA;AAAA,UACP;AACA;AAAA,QACF,KAAK;AACH,gBAAM,eAAA;AACN;AAAA,MAAA;AAIJ,UAAI,KAAK,cAAc,SAAS,MAAM,GAAG,GAAG;AAC1C,cAAM,eAAA;AACN,aAAK,qBAAqB,OAAO;AAAA,MACnC;AAAA,IACF;AAAA;AAAA;AAAA;AAAA,IAKQ,qBAAqB,SAAmC,SAAS,OAAS;AAChF,YAAM,aAAa,SAAS,KAAK,cAAe,MAAM,KAAA;AACtD,UAAI,CAAC,YAAY;AACf;AAAA,MACF;AAEA,YAAM,cAAmD;AAAA,QACvD;AAAA,QACA,OAAO;AAAA,QACP,QAAQ,QAAQ,KAAK,cAAc,KAAK,IAAI,SAAS;AAAA,QACrD,UAAU,CAACA,WAAc,YAAY,QAAQA;AAAAA,QAC7C,UAAU,CAAC,UAAmB,YAAY,QAAQ;AAAA,MAAA;AAGpD,UAAI,CAAC,KAAK,2BAA2B,WAAW,GAAG;AACjD;AAAA,MACF;AAEA,WAAK,mBAAmB,YAAY,OAAY,YAAY,KAAK;AACjE,WAAK,cAAe,QAAQ;AAC5B,WAAK,iBAAA;AAAA,IACP;AAAA,IAEQ,2BAA2B,aAAgD;AAKjF,aAAO,KAAK,cACV,IAAI,YAAiD,qBAAqB;AAAA,QACxE,QAAQ;AAAA,QACR,YAAY;AAAA,QACZ,SAAS;AAAA,QACT,UAAU;AAAA,MAAA,CACX,CAAC;AAAA,IAEN;AAAA,IAEQ,YAAY,MAAuB;AACzC,YAAM,QAAQ,KAAK,qBAAA;AACnB,WAAK,OAAA;AACL,WAAK,iBAAA;AACL,WAAK,WAAW,MAAM,QAAQ,IAAI,CAAC;AAAA,IACrC;AAAA;AAAA;AAAA;AAAA;AAAA,IAMQ,WAAW,OAAc;AAC/B,YAAM,eAAe,KAAK,qBAAA;AAE1B,UAAI,UAAU,UAAa,aAAa,KAAK,GAAG;AAC9C,qBAAa,KAAK,EAAE,MAAA;AACpB;AAAA,MACF;AAEA,UAAI,aAAa,SAAS,GAAG;AAC3B,qBAAa,aAAa,SAAS,CAAC,EAAE,MAAA;AACtC;AAAA,MACF;AAEA,WAAK,eAAe,MAAA;AAAA,IACtB;AAAA,IAEQ,mBAAgB;AAEtB,WAAK,cAAc,IAAI,WAAW,SAAS,EAAE,SAAS,MAAM,UAAU,KAAA,CAAM,CAAC;AAO7E,WAAK,cAAc,IAAI,MAAM,UAAU,EAAE,SAAS,KAAA,CAAM,CAAC;AAAA,IAC3D;AAAA,IAEQ,mBAAmB,OAAiB,OAAc;AACxD,UAAI,UAAU;AACZ;AAAA,MACF;AACA,YAAM,UAAU,SAAS,cAAc,UAAU;AACjD,cAAQ,QAAQ;AAChB,cAAQ,YAAY,UAAU,QAAQ,KAAK,cAAc,KAAK,IAAI,SAAS;AAC3E,UAEE,CAAC,4BACD,CAAC,SACD,OAAO,UAAU,YACjB,CAAC,KAAK,aACN;AACA,gBAAQ,KACN;AAAA;AAAA,yCAEiC;AAEnC,mCAA2B;AAAA,MAC7B;AACA,WAAK,aAAa,SAAS,KAAK,iBAAiB,KAAK,cAAc,OAAO,CAAC;AAAA,IAC9E;AAAA,IAEQ,uBAAoB;AAC1B,WAAK,WAAW,KAAK,eAAe,YAAY;AAChD,WAAK,mBAAA;AAAA,IACP;AAAA,IAEQ,qBAAkB;AACxB,WAAK,cAAA,EAAgB,QAAQ,CAAC,MAAK;AACjC,UAAE,WAAW,KAAK,YAAY,KAAK;AACnC,UAAE,WAAW,KAAK,eAAe,aAAa,UAAU,KAAK;AAC7D,UAAE,WAAW,KAAK;AAAA,MACpB,CAAC;AAAA,IACH;AAAA,IAEQ,eAAY;AAClB,UAAI,KAAK,eAAe;AACtB,aAAK,UAAU,OAAO,OAAO,QAAQ,KAAK,aAAa,EAAE;AAAA,MAC3D;AACA,WAAK,gBAAgB,KAAK,QAAQ,gBAAgB,GAAG,SAAS,OAAA,IAAW,MAAM;AAC/E,UAAI,KAAK,eAAe;AACtB,aAAK,UAAU,OAAO,IAAI,QAAQ,KAAK,aAAa,EAAE;AAAA,MACxD;AAAA,IACF;AAAA,IAEQ,0BAAuB;AAC7B,UAAI,CAAC,KAAK,eAAe;AACvB;AAAA,MACF;AACA,WAAK,cAAc,aACjB,oBACA,GAAG,8BAA8B,KAAK,UAAU,OAAO,CAAC,IAAI,KAAK,MAAM,MAAM,EAAE;AAAA,IAEnF;AAAA,IAEmB,SAAM;AACvB,aAAO;AAAA;AAAA,4BAEiB,KAAK,eAAe;AAAA;AAAA;AAAA,IAG9C;AAAA,KAvVA,+CAIA;;AAvCC,4BAAA,CAAA,SAAS,EAAE,MAAM,MAAA,CAAO,CAAC;AAkCzB,8BAAA,CAAA,SAAS,EAAE,WAAW,MAAA,CAAO,CAAC;iCAI9B,SAAS,EAAE,WAAW,kBAAkB,MAAM,MAAA,CAAO,CAAC;AArCvD,iBAAA,IAAA,MAAA,uBAAA,EAAA,MAAA,UAAA,MAAA,SAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,WAAA,KAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAW,QAAK;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,MAAA,0BAAA;AAkChB,iBAAA,IAAA,MAAA,yBAAA,EAAA,MAAA,YAAA,MAAA,eAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,iBAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,aAAW,KAAA,CAAA,KAAA,UAAA;AAAA,UAAX,cAAW;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,2BAAA,8BAAA;AAI3B,iBAAA,IAAA,MAAA,2BAAA,EAAA,MAAA,YAAA,MAAA,iBAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,mBAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,eAAa,KAAA,CAAA,KAAA,UAAA;AAAA,UAAb,gBAAa;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,6BAAA,gCAAA;AAnD/B,iBAAA,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;QAGkC,GAAA,OAAO,WAChB,GAAA,SAAyB,CAAC,iBAAiB,KAAK,GAChD,GAAA,SAAS;AAAA,IAC9B,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,mBAAmB;AAAA,EAAA,GARjB,kBAAA,YAAA,uBAAA,GAAgC;;;"}
430
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"chip-group.component.js","sources":["../../../../../src/elements/chip/chip-group/chip-group.component.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  LitElement,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { getNextElementIndex, isArrowKeyPressed } from '../../core/a11y.ts';\nimport { SbbLanguageController, SbbPropertyWatcherController } from '../../core/controllers.ts';\nimport { isLean } from '../../core/dom/lean-context.ts';\nimport { i18nChipGroupInputDescription, i18nSelectionRequired } from '../../core/i18n.ts';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbDisabledMixin,\n  SbbElementInternalsMixin,\n  SbbFormAssociatedMixin,\n  SbbNegativeMixin,\n  SbbRequiredMixin,\n} from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbFormFieldElement } from '../../form-field/form-field/form-field.component.ts';\nimport type { SbbOptionBaseElement } from '../../option/option/option-base-element.ts';\nimport { SbbChipElement } from '../chip.ts';\n\nimport style from './chip-group.scss?lit&inline';\n\nlet displayWithWarningLogged = false;\n\nexport interface SbbChipInputTokenEndEventDetails<T = string> {\n  /** The element that triggered the chip creation */\n  origin: 'input' | 'autocomplete';\n  /**\n   * The value of the new chip. Either the input or the option value depending on the origin.\n   * Either the value from the input which is always `string` or the value from the selected option\n   * from an autocomplete, which can be either a string or any other type.\n   */\n  value: T | string;\n  label?: string;\n  /** Set a new value for the chip that will be created */\n  setValue(value: T): void;\n  /** Set a label for the chip that will be created */\n  setLabel(value: string): void;\n}\n\n/**\n * The `sbb-chip-group` component is used as a container for one or multiple `sbb-chip`.\n *\n * @slot - Use the unnamed slot to add `sbb-chip` elements.\n * @overrideType value - (T = string[]) | null\n */\nexport\n@customElement('sbb-chip-group')\nclass SbbChipGroupElement<T = string> extends SbbRequiredMixin(\n  SbbDisabledMixin(SbbNegativeMixin(SbbFormAssociatedMixin(SbbElementInternalsMixin(LitElement)))),\n) {\n  public static override readonly role = 'listbox';\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  public static readonly events = {\n    input: 'input',\n    change: 'change',\n    chipinputtokenend: 'chipinputtokenend',\n  } as const;\n\n  /** Value of the form element. */\n  @property({ type: Array })\n  public set value(value: (T | null)[] | null) {\n    value = value ?? [];\n    const oldValue = this.value;\n\n    // Subtract from 'oldValue' the new 'value'\n    // The result are the chips to remove (handle duplicates)\n    const toRemove = [...oldValue];\n    for (const c of value) {\n      if (toRemove.includes(c)) {\n        toRemove.splice(toRemove.indexOf(c), 1);\n      }\n    }\n    toRemove.forEach((value) =>\n      this._chipElements()\n        .find((c) => c.value === value)\n        ?.remove(),\n    );\n\n    // Subtract from the new 'value' what was already present\n    // The result are the new chips to add (handle duplicates)\n    const toAdd = [...value];\n    for (const c of oldValue) {\n      if (toAdd.includes(c)) {\n        toAdd.splice(toAdd.indexOf(c), 1);\n      }\n    }\n    toAdd.forEach((c) => this._createChipElement(c));\n  }\n  public get value(): (T | null)[] {\n    return this._chipElements().map((c) => c.value);\n  }\n\n  /** Function that maps a chip's value to its display value. */\n  @property({ attribute: false })\n  public accessor displayWith: ((value: T) => string) | null = null;\n\n  /** The array of keys that will trigger a `chipinputtokenend` event. Default `['Enter']` */\n  @property({ attribute: 'separator-keys', type: Array })\n  public accessor separatorKeys: string[] = ['Enter'];\n\n  /**\n   * Listens to the changes on `readonly` and `disabled` attributes of `<input>`.\n   */\n  private _inputAttributeObserver = !isServer\n    ? new MutationObserver(() => this._reactToInputChanges())\n    : null;\n\n  private _inputElement: HTMLInputElement | undefined;\n  private _inputAbortController: AbortController | undefined;\n  private _language = new SbbLanguageController(this);\n  private _previousSize?: SbbFormFieldElement['size'];\n\n  public constructor() {\n    super();\n\n    this.addEventListener?.(SbbChipElement.events.requestdelete, (ev) =>\n      this._deleteChip(ev.target as SbbChipElement<T>),\n    );\n\n    this.addEventListener?.('keydown', (ev) => this._onChipKeyDown(ev));\n\n    this.addController(\n      new SbbPropertyWatcherController(this, () => this.closest('sbb-form-field'), {\n        size: (formField) => this._updateSize(formField.size),\n        label: (formField) => this._updateLabelState(formField),\n        hiddenLabel: (formField) => this._updateLabelState(formField),\n      }),\n    );\n  }\n\n  private _updateLabelState(formField: SbbFormFieldElement): void {\n    this.toggleState('without-label', !formField.label || formField.hiddenLabel);\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this._setupComponent();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues): void {\n    super.willUpdate(changedProperties);\n\n    if (\n      changedProperties.has('disabled') ||\n      changedProperties.has('formDisabled') ||\n      changedProperties.has('negative')\n    ) {\n      this._proxyStateToChips();\n    }\n  }\n\n  /** @internal */\n  public formResetCallback(): void {\n    this.value = null;\n  }\n\n  /** @internal */\n  public formStateRestoreCallback(\n    state: FormRestoreState | null,\n    _reason: FormRestoreReason,\n  ): void {\n    if (!state) {\n      this.value = null;\n      return;\n    }\n\n    this._readFormData(state as FormData).then((array) => (this.value = array));\n  }\n\n  private async _readFormData(formData: FormData): Promise<T[]> {\n    return Promise.all(\n      formData\n        .getAll(this.name)\n        .map(async (entry) =>\n          entry instanceof Blob ? JSON.parse(await entry.text()) : (entry as T),\n        ),\n    );\n  }\n\n  protected override shouldValidate(name: PropertyKey | undefined): boolean {\n    return super.shouldValidate(name) || name === 'required' || name === 'value';\n  }\n\n  protected override validate(): void {\n    super.validate();\n    if (this.required && this.value.length === 0) {\n      this.setValidityFlag('valueMissing', i18nSelectionRequired[this._language.current]);\n    } else {\n      this.removeValidityFlag('valueMissing');\n    }\n  }\n\n  /** Return the list of chip elements **/\n  private _chipElements(): SbbChipElement<T>[] {\n    return Array.from(this.querySelectorAll?.<SbbChipElement<T>>('sbb-chip') ?? []);\n  }\n\n  /** Return the list of enabled chip elements **/\n  private _enabledChipElements(): SbbChipElement<T>[] {\n    return Array.from(this.querySelectorAll?.('sbb-chip:not([disabled])') ?? []);\n  }\n\n  private _setupComponent(): void {\n    const input = this.querySelector('input');\n\n    // Connect to the input\n    if (input && input !== this._inputElement) {\n      this._inputAbortController?.abort();\n      this._inputAttributeObserver?.disconnect();\n      this._inputElement = input;\n\n      this._inputAbortController = new AbortController();\n      this._inputElement.addEventListener('keydown', (ev) => this._onInputKeyDown(ev), {\n        signal: this._inputAbortController.signal,\n      });\n      this._inputElement.addEventListener(\n        'inputAutocomplete',\n        (event: CustomEvent<{ option: SbbOptionBaseElement<T> }>) => {\n          this._createChipFromInput('autocomplete', event.detail?.option.value);\n        },\n        {\n          signal: this._inputAbortController.signal,\n        },\n      );\n\n      this._inputAttributeObserver?.observe(this._inputElement, {\n        attributes: true,\n        attributeFilter: ['readonly', 'disabled'],\n      });\n    }\n\n    // Inherit size from the form-field and observe for changes\n    if (!this._previousSize || !this.closest('sbb-form-field')) {\n      this._updateSize(isLean() ? 's' : 'm');\n    }\n\n    this.toggleState('empty', this.value.length === 0);\n    this._reactToInputChanges();\n    this._updateInputDescription();\n    this.updateFormValue();\n  }\n\n  /**\n   * Listen for keyboard events on the chip elements\n   **/\n  private _onChipKeyDown(event: KeyboardEvent): void {\n    const eventTarget = event.target as SbbChipElement<T>;\n    if (eventTarget.localName !== 'sbb-chip') {\n      return;\n    }\n\n    // Arrow keys allow navigation between chips focus steps\n    if (isArrowKeyPressed(event)) {\n      const focusSteps = this._enabledChipElements();\n      const next = getNextElementIndex(event, focusSteps.indexOf(eventTarget), focusSteps.length);\n      focusSteps[next].focus();\n      return;\n    }\n\n    switch (event.key) {\n      case 'Backspace':\n      case 'Delete':\n        if (!eventTarget.readOnly && !eventTarget.disabled) {\n          event.preventDefault();\n          this._deleteChip(eventTarget);\n        }\n        break;\n    }\n  }\n\n  /**\n   * Listen for keyboard events on the input\n   **/\n  private _onInputKeyDown(event: KeyboardEvent): void {\n    switch (event.key) {\n      case 'Backspace':\n      case 'ArrowLeft':\n        if (!this._inputElement!.value) {\n          this._focusChip();\n        }\n        break;\n      case 'Enter':\n        event.preventDefault(); // Prevents the form submit\n        break;\n    }\n\n    // if the user typed one of the separator keys, trigger a 'chipinputtokenend' event\n    if (this.separatorKeys.includes(event.key)) {\n      event.preventDefault(); // prevent typing the separator key into the input\n      this._createChipFromInput('input');\n    }\n  }\n\n  /**\n   * If the input is not empty, create a chip with its value\n   */\n  private _createChipFromInput(origin: 'input' | 'autocomplete' = 'input', value?: T): void {\n    const inputValue = value ?? this._inputElement!.value.trim();\n    if (!inputValue) {\n      return;\n    }\n\n    const eventDetail: SbbChipInputTokenEndEventDetails<T> = {\n      origin: origin,\n      value: inputValue,\n      label: (value ? this.displayWith?.(value) : null) ?? undefined,\n      setValue: (value: T) => (eventDetail.value = value),\n      setLabel: (label: string) => (eventDetail.label = label),\n    };\n\n    if (!this._dispatchChipInputTokenEnd(eventDetail)) {\n      return; // event prevented; do nothing (the consumer has to create the chip)\n    }\n\n    this._createChipElement(eventDetail.value as T, eventDetail.label);\n    this._inputElement!.value = ''; // Empty the input\n    this._emitInputEvents();\n  }\n\n  private _dispatchChipInputTokenEnd(eventDetail: SbbChipInputTokenEndEventDetails<T>): boolean {\n    /**\n     * @type {CustomEvent<SbbChipInputTokenEndEventDetails>}\n     * Notifies that a chip is about to be created. Can be prevented.\n     */\n    return this.dispatchEvent(\n      new CustomEvent<SbbChipInputTokenEndEventDetails<T>>('chipinputtokenend', {\n        detail: eventDetail,\n        cancelable: true,\n        bubbles: true,\n        composed: true,\n      }),\n    );\n  }\n\n  private _deleteChip(chip: SbbChipElement<T>): void {\n    const chips = this._enabledChipElements();\n    chip.remove();\n    this._emitInputEvents();\n    this._focusChip(chips.indexOf(chip)); // Focus the next chip\n  }\n\n  /**\n   * Focus an enabled chip. If none are present, focus the input\n   * @param index The index of the enabled chip. If null, focus the last one.\n   */\n  private _focusChip(index?: number): void {\n    const enabledChips = this._enabledChipElements();\n\n    if (index !== undefined && enabledChips[index]) {\n      enabledChips[index].focus();\n      return;\n    }\n\n    if (enabledChips.length > 0) {\n      enabledChips[enabledChips.length - 1].focus();\n      return;\n    }\n\n    this._inputElement?.focus();\n  }\n\n  private _emitInputEvents(): void {\n    /** The input event fires when the value has been changed as a direct result of a user action. */\n    this.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n\n    /**\n     * The change event is fired when the user modifies the element's value.\n     * Unlike the input event, the change event is not necessarily fired\n     * for each alteration to an element's value.\n     */\n    this.dispatchEvent(new Event('change', { bubbles: true }));\n  }\n\n  private _createChipElement(value: T | null, label?: string): void {\n    if (isServer) {\n      return;\n    }\n    const newChip = document.createElement('sbb-chip') as SbbChipElement<T>;\n    newChip.value = value;\n    newChip.innerText = label ?? (value ? this.displayWith?.(value) : null) ?? '';\n    if (\n      import.meta.env.DEV &&\n      !displayWithWarningLogged &&\n      !label &&\n      typeof value === 'object' &&\n      !this.displayWith\n    ) {\n      console.warn(\n        `displayWith has not been set yet for sbb-chip-group and value is an object.\n         If you are using object values, you need to provide displayWidth before\n         setting or selecting any value.`,\n      );\n      displayWithWarningLogged = true;\n    }\n    this.insertBefore(newChip, this._inputElement ?? this.querySelector('input'));\n  }\n\n  private _reactToInputChanges(): void {\n    this.disabled = this._inputElement?.disabled ?? false;\n    this._proxyStateToChips();\n  }\n\n  private _proxyStateToChips(): void {\n    this._chipElements().forEach((c) => {\n      c.disabled = this.disabled || this.formDisabled;\n      c.readOnly = this._inputElement?.hasAttribute('readonly') ?? false;\n      c.negative = this.negative;\n    });\n  }\n\n  private _updateSize(size: SbbFormFieldElement['size']): void {\n    if (this._previousSize) {\n      this.internals.states.delete(`size-${this._previousSize}`);\n    }\n    this._previousSize = size;\n    if (this._previousSize) {\n      this.internals.states.add(`size-${this._previousSize}`);\n    }\n  }\n\n  private _updateInputDescription(): void {\n    if (!this._inputElement) {\n      return;\n    }\n    this._inputElement.setAttribute(\n      'aria-description',\n      `${i18nChipGroupInputDescription[this._language.current]} ${this.value.length}`,\n    );\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-chip-group\">\n        <slot @slotchange=${this._setupComponent}></slot>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-chip-group': SbbChipGroupElement;\n  }\n}\n\ndeclare global {\n  interface HTMLElementEventMap {\n    chipinputtokenend: CustomEvent<SbbChipInputTokenEndEventDetails<any>>;\n  }\n}\n"],"names":["value"],"mappings":"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"}
@@ -1,4 +1,4 @@
1
- import { S as SbbBreakpointZeroMin, a as SbbBreakpointSmallMin, b as SbbBreakpointLargeMin, c as SbbBreakpointUltraMin, d as SbbBreakpointSmallMax, e as SbbBreakpointLargeMax } from "../../sbb-tokens-CZCt5L4q.js";
1
+ import { S as SbbBreakpointLargeMin, a as SbbBreakpointLargeMax, b as SbbBreakpointSmallMin, c as SbbBreakpointSmallMax, d as SbbBreakpointUltraMin, e as SbbBreakpointZeroMin } from "../../sbb-tokens-DQT_xEIZ.js";
2
2
  import { isServer } from "lit";
3
3
  import { ɵstateController as _stateController } from "../mixins/element-internals-mixin.js";
4
4
  const SbbMediaQueryForcedColors = "(forced-colors: active)";
@@ -16,6 +16,7 @@ const style = css`:host {
16
16
  content: "";
17
17
  display: block;
18
18
  position: absolute;
19
+ align-self: start;
19
20
  border-block-start: var(--sbb-border-width-1x) solid var(--sbb-dialog-actions-border-color);
20
21
  transition: border-color var(--sbb-animation-easing) var(--sbb-dialog-shadow-animation-duration);
21
22
  width: 100%;
@@ -51,4 +52,4 @@ let SbbDialogActionsElement = (() => {
51
52
  export {
52
53
  SbbDialogActionsElement
53
54
  };
54
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLWFjdGlvbnMuY29tcG9uZW50LmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvZWxlbWVudHMvZGlhbG9nL2RpYWxvZy1hY3Rpb25zL2RpYWxvZy1hY3Rpb25zLmNvbXBvbmVudC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENTU1Jlc3VsdEdyb3VwIH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQgfSBmcm9tICdsaXQvZGVjb3JhdG9ycy5qcyc7XG5cbmltcG9ydCB7IFNiYkFjdGlvbkdyb3VwRWxlbWVudCB9IGZyb20gJy4uLy4uL2FjdGlvbi1ncm91cC50cyc7XG5pbXBvcnQgeyBpc0xlYW4gfSBmcm9tICcuLi8uLi9jb3JlL2RvbS9sZWFuLWNvbnRleHQudHMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9kaWFsb2ctYWN0aW9ucy5zY3NzP2xpdCZpbmxpbmUnO1xuXG4vKipcbiAqIFVzZSB0aGlzIGNvbXBvbmVudCB0byBkaXNwbGF5IGEgZm9vdGVyIGludG8gYW4gYHNiYi1kaWFsb2dgIHdpdGggYW4gYWN0aW9uIGdyb3VwLlxuICpcbiAqIEBzbG90IC0gVXNlIHRoZSB1bm5hbWVkIHNsb3QgdG8gYWRkIGBzYmItYmxvY2stbGlua2Agb3IgYHNiYi1idXR0b25gIGVsZW1lbnRzIHRvIHRoZSBgc2JiLWRpYWxvZy1hY3Rpb25zYC5cbiAqL1xuZXhwb3J0XG5AY3VzdG9tRWxlbWVudCgnc2JiLWRpYWxvZy1hY3Rpb25zJylcbmNsYXNzIFNiYkRpYWxvZ0FjdGlvbnNFbGVtZW50IGV4dGVuZHMgU2JiQWN0aW9uR3JvdXBFbGVtZW50IHtcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gW1NiYkFjdGlvbkdyb3VwRWxlbWVudC5zdHlsZXMsIHN0eWxlXTtcblxuICBwdWJsaWMgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoKTtcbiAgICAvKiogQGRlZmF1bHQgJ20nIC8gJ3MnIChsZWFuKSAqL1xuICAgIHRoaXMuYnV0dG9uU2l6ZSA9IGlzTGVhbigpID8gJ3MnIDogJ20nO1xuXG4gICAgLyoqIEBkZWZhdWx0ICdzJyAvICd4cycgKGxlYW4pICovXG4gICAgdGhpcy5saW5rU2l6ZSA9IGlzTGVhbigpID8gJ3hzJyA6ICdzJztcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLWRpYWxvZy1hY3Rpb25zJzogU2JiRGlhbG9nQWN0aW9uc0VsZW1lbnQ7XG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztJQWVNLDJCQUF1QixNQUFBOzswQkFENUIsY0FBYyxvQkFBb0IsQ0FBQzs7OztvQkFDRTtBQUFSLEVBQUEsbUJBQVEsWUFBcUI7QUFBQSxJQUd6RCxjQUFBO0FBQ0UsWUFBQTtBQUVBLFdBQUssYUFBYSxPQUFBLElBQVcsTUFBTTtBQUduQyxXQUFLLFdBQVcsT0FBQSxJQUFXLE9BQU87QUFBQSxJQUNwQztBQUFBOztBQVZGLGlCQUFBLE1BQUEsbUJBQUEsRUFBQSxPQUFBLFdBQUEsR0FBQSxrQkFBQSxFQUFBLE1BQUEsU0FBQSxNQUFBLFdBQUEsTUFBQSxVQUFBLFVBQUEsR0FBQSxNQUFBLHVCQUFBOzs7UUFDeUIsR0FBQSxTQUF5QixDQUFDLHNCQUFzQixRQUFRLEtBQUssR0FEaEYsa0JBQUEsWUFBQSx1QkFBQSxHQUF3Qjs7OyJ9
55
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLWFjdGlvbnMuY29tcG9uZW50LmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvZWxlbWVudHMvZGlhbG9nL2RpYWxvZy1hY3Rpb25zL2RpYWxvZy1hY3Rpb25zLmNvbXBvbmVudC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENTU1Jlc3VsdEdyb3VwIH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQgfSBmcm9tICdsaXQvZGVjb3JhdG9ycy5qcyc7XG5cbmltcG9ydCB7IFNiYkFjdGlvbkdyb3VwRWxlbWVudCB9IGZyb20gJy4uLy4uL2FjdGlvbi1ncm91cC50cyc7XG5pbXBvcnQgeyBpc0xlYW4gfSBmcm9tICcuLi8uLi9jb3JlL2RvbS9sZWFuLWNvbnRleHQudHMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9kaWFsb2ctYWN0aW9ucy5zY3NzP2xpdCZpbmxpbmUnO1xuXG4vKipcbiAqIFVzZSB0aGlzIGNvbXBvbmVudCB0byBkaXNwbGF5IGEgZm9vdGVyIGludG8gYW4gYHNiYi1kaWFsb2dgIHdpdGggYW4gYWN0aW9uIGdyb3VwLlxuICpcbiAqIEBzbG90IC0gVXNlIHRoZSB1bm5hbWVkIHNsb3QgdG8gYWRkIGBzYmItYmxvY2stbGlua2Agb3IgYHNiYi1idXR0b25gIGVsZW1lbnRzIHRvIHRoZSBgc2JiLWRpYWxvZy1hY3Rpb25zYC5cbiAqL1xuZXhwb3J0XG5AY3VzdG9tRWxlbWVudCgnc2JiLWRpYWxvZy1hY3Rpb25zJylcbmNsYXNzIFNiYkRpYWxvZ0FjdGlvbnNFbGVtZW50IGV4dGVuZHMgU2JiQWN0aW9uR3JvdXBFbGVtZW50IHtcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gW1NiYkFjdGlvbkdyb3VwRWxlbWVudC5zdHlsZXMsIHN0eWxlXTtcblxuICBwdWJsaWMgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoKTtcbiAgICAvKiogQGRlZmF1bHQgJ20nIC8gJ3MnIChsZWFuKSAqL1xuICAgIHRoaXMuYnV0dG9uU2l6ZSA9IGlzTGVhbigpID8gJ3MnIDogJ20nO1xuXG4gICAgLyoqIEBkZWZhdWx0ICdzJyAvICd4cycgKGxlYW4pICovXG4gICAgdGhpcy5saW5rU2l6ZSA9IGlzTGVhbigpID8gJ3hzJyA6ICdzJztcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLWRpYWxvZy1hY3Rpb25zJzogU2JiRGlhbG9nQWN0aW9uc0VsZW1lbnQ7XG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7SUFlTSwyQkFBdUIsTUFBQTs7MEJBRDVCLGNBQWMsb0JBQW9CLENBQUM7Ozs7b0JBQ0U7QUFBUixFQUFBLG1CQUFRLFlBQXFCO0FBQUEsSUFHekQsY0FBQTtBQUNFLFlBQUE7QUFFQSxXQUFLLGFBQWEsT0FBQSxJQUFXLE1BQU07QUFHbkMsV0FBSyxXQUFXLE9BQUEsSUFBVyxPQUFPO0FBQUEsSUFDcEM7QUFBQTs7QUFWRixpQkFBQSxNQUFBLG1CQUFBLEVBQUEsT0FBQSxXQUFBLEdBQUEsa0JBQUEsRUFBQSxNQUFBLFNBQUEsTUFBQSxXQUFBLE1BQUEsVUFBQSxVQUFBLEdBQUEsTUFBQSx1QkFBQTs7O1FBQ3lCLEdBQUEsU0FBeUIsQ0FBQyxzQkFBc0IsUUFBUSxLQUFLLEdBRGhGLGtCQUFBLFlBQUEsdUJBQUEsR0FBd0I7OzsifQ==
@@ -1,8 +1,8 @@
1
- import { CSSResultGroup, PropertyValues, TemplateResult, LitElement } from 'lit';
1
+ import { CSSResultGroup, LitElement, PropertyValues, TemplateResult } from 'lit';
2
2
  import { SbbOrientation } from '../core/interfaces.ts';
3
3
  declare const SbbDividerElement_base: import('../core/mixins.ts').AbstractConstructor<import('../core/mixins.ts').SbbNegativeMixinType> & import('../core/mixins.ts').AbstractConstructor<import('../core/mixins.ts').SbbElementInternalsMixinType> & typeof LitElement & import('../core/mixins.ts').SbbElementInternalsConstructor;
4
4
  /**
5
- * It displays a divider between sections.
5
+ * Displays a divider between sections.
6
6
  */
7
7
  export declare class SbbDividerElement extends SbbDividerElement_base {
8
8
  static readonly role = "separator";
@@ -1 +1 @@
1
- {"version":3,"file":"divider.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/divider/divider.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AAGvC,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;;AAM5D;;GAEG;AACH,qBAEM,iBAAkB,SAAQ,sBAAsD;IACpF,gBAAgC,IAAI,eAAe;IACnD,OAAuB,MAAM,EAAE,cAAc,CAA4B;IAEzE,mGAAmG;IACnG,SAA6C,WAAW,EAAE,cAAc,CAAgB;cAErE,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAQzD,MAAM,IAAI,cAAc;CAG5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,aAAa,EAAE,iBAAiB,CAAC;KAClC;CACF"}
1
+ {"version":3,"file":"divider.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/divider/divider.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAEnB,UAAU,EACV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAGb,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;;AAM5D;;GAEG;AACH,qBAEM,iBAAkB,SAAQ,sBAAsD;IACpF,gBAAgC,IAAI,eAAe;IACnD,OAAuB,MAAM,EAAE,cAAc,CAA4B;IAEzE,mGAAmG;IACnG,SAA6C,WAAW,EAAE,cAAc,CAAgB;cAErE,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAQzD,MAAM,IAAI,cAAc;CAG5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,aAAa,EAAE,iBAAiB,CAAC;KAClC;CACF"}
@@ -11,8 +11,6 @@ import { customElement, property } from "lit/decorators.js";
11
11
  import { SbbNegativeMixin, SbbElementInternalsMixin } from "../core/mixins.js";
12
12
  import { boxSizingStyles } from "../core/styles.js";
13
13
  const style = css`:host {
14
- --sbb-divider-color: var(--sbb-background-color-4);
15
- --sbb-divider-border-width: var(--sbb-border-width-1x);
16
14
  display: block;
17
15
  }
18
16
 
@@ -21,10 +19,10 @@ const style = css`:host {
21
19
  }
22
20
 
23
21
  :host([negative]) {
24
- --sbb-divider-color: var(--sbb-background-color-4-negative);
22
+ --sbb-divider-color: var(--sbb-divider-color-negative);
25
23
  }
26
24
 
27
- :host([orientation=horizontal]) .sbb-divider {
25
+ :host(:is([orientation=horizontal], :not([orientation]))) .sbb-divider {
28
26
  border-top: var(--sbb-divider-border-width) solid var(--sbb-divider-color);
29
27
  }
30
28
  :host([orientation=vertical]) .sbb-divider {
@@ -61,7 +59,7 @@ let SbbDividerElement = (() => {
61
59
  }
62
60
  }
63
61
  render() {
64
- return html` <div class="sbb-divider"></div> `;
62
+ return html`<div class="sbb-divider"></div> `;
65
63
  }
66
64
  }, _orientation_accessor_storage = new WeakMap(), _classThis = _a, (() => {
67
65
  const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
@@ -78,4 +76,4 @@ let SbbDividerElement = (() => {
78
76
  export {
79
77
  SbbDividerElement
80
78
  };
81
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGl2aWRlci5jb21wb25lbnQuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9lbGVtZW50cy9kaXZpZGVyL2RpdmlkZXIuY29tcG9uZW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQ1NTUmVzdWx0R3JvdXAsIFByb3BlcnR5VmFsdWVzLCBUZW1wbGF0ZVJlc3VsdCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBodG1sLCBMaXRFbGVtZW50IH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQsIHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgdHlwZSB7IFNiYk9yaWVudGF0aW9uIH0gZnJvbSAnLi4vY29yZS9pbnRlcmZhY2VzLnRzJztcbmltcG9ydCB7IFNiYkVsZW1lbnRJbnRlcm5hbHNNaXhpbiwgU2JiTmVnYXRpdmVNaXhpbiB9IGZyb20gJy4uL2NvcmUvbWl4aW5zLnRzJztcbmltcG9ydCB7IGJveFNpemluZ1N0eWxlcyB9IGZyb20gJy4uL2NvcmUvc3R5bGVzLnRzJztcblxuaW1wb3J0IHN0eWxlIGZyb20gJy4vZGl2aWRlci5zY3NzP2xpdCZpbmxpbmUnO1xuXG4vKipcbiAqIEl0IGRpc3BsYXlzIGEgZGl2aWRlciBiZXR3ZWVuIHNlY3Rpb25zLlxuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItZGl2aWRlcicpXG5jbGFzcyBTYmJEaXZpZGVyRWxlbWVudCBleHRlbmRzIFNiYk5lZ2F0aXZlTWl4aW4oU2JiRWxlbWVudEludGVybmFsc01peGluKExpdEVsZW1lbnQpKSB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgcmVhZG9ubHkgcm9sZSA9ICdzZXBhcmF0b3InO1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHN0eWxlczogQ1NTUmVzdWx0R3JvdXAgPSBbYm94U2l6aW5nU3R5bGVzLCBzdHlsZV07XG5cbiAgLyoqIE9yaWVudGF0aW9uIHByb3BlcnR5IHdpdGggcG9zc2libGUgdmFsdWVzICdob3Jpem9udGFsJyB8ICd2ZXJ0aWNhbCcuIERlZmF1bHRzIHRvIGhvcml6b250YWwuICovXG4gIEBwcm9wZXJ0eSh7IHJlZmxlY3Q6IHRydWUgfSkgcHVibGljIGFjY2Vzc29yIG9yaWVudGF0aW9uOiBTYmJPcmllbnRhdGlvbiA9ICdob3Jpem9udGFsJztcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgd2lsbFVwZGF0ZShjaGFuZ2VkUHJvcGVydGllczogUHJvcGVydHlWYWx1ZXM8dGhpcz4pOiB2b2lkIHtcbiAgICBzdXBlci53aWxsVXBkYXRlKGNoYW5nZWRQcm9wZXJ0aWVzKTtcblxuICAgIGlmIChjaGFuZ2VkUHJvcGVydGllcy5oYXMoJ29yaWVudGF0aW9uJykpIHtcbiAgICAgIHRoaXMuaW50ZXJuYWxzLmFyaWFPcmllbnRhdGlvbiA9IHRoaXMub3JpZW50YXRpb247XG4gICAgfVxuICB9XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlcigpOiBUZW1wbGF0ZVJlc3VsdCB7XG4gICAgcmV0dXJuIGh0bWxgIDxkaXYgY2xhc3M9XCJzYmItZGl2aWRlclwiPjwvZGl2PiBgO1xuICB9XG59XG5cbmRlY2xhcmUgZ2xvYmFsIHtcbiAgaW50ZXJmYWNlIEhUTUxFbGVtZW50VGFnTmFtZU1hcCB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvblxuICAgICdzYmItZGl2aWRlcic6IFNiYkRpdmlkZXJFbGVtZW50O1xuICB9XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lBZU0scUJBQWlCLE1BQUE7OzBCQUR0QixjQUFjLGFBQWEsQ0FBQzs7OztBQUNHLE1BQUEsY0FBQSxpQkFBaUIseUJBQXlCLFVBQVUsQ0FBQzs7OztBQUE3RCxFQUFBLG1CQUFRLFlBQXNEO0FBQUE7O0FBS3ZELHdEQUFBLGtCQUFBLE1BQUEsMkJBQThDLFlBQVk7Ozs7SUFBMUQsSUFBZ0IsY0FBVztBQUFBLGFBQUEsbUJBQUE7QUFBQSxJQUFBO0FBQUEsSUFBM0IsSUFBZ0IsWUFBVyxPQUFBO0FBQUEseUJBQUEsK0JBQUE7QUFBQSxJQUFBO0FBQUEsSUFFckMsV0FBVyxtQkFBdUM7QUFDbkUsWUFBTSxXQUFXLGlCQUFpQjtBQUVsQyxVQUFJLGtCQUFrQixJQUFJLGFBQWEsR0FBRztBQUN4QyxhQUFLLFVBQVUsa0JBQWtCLEtBQUs7QUFBQSxNQUN4QztBQUFBLElBQ0Y7QUFBQSxJQUVtQixTQUFNO0FBQ3ZCLGFBQU87QUFBQSxJQUNUO0FBQUEsS0FaNkI7O0FBQTVCLDhCQUFBLENBQUEsU0FBUyxFQUFFLFNBQVMsS0FBQSxDQUFNLENBQUM7QUFBQyxpQkFBQSxJQUFBLE1BQUEseUJBQUEsRUFBQSxNQUFBLFlBQUEsTUFBQSxlQUFBLFFBQUEsT0FBQSxTQUFBLE9BQUEsUUFBQSxFQUFBLEtBQUEsQ0FBQSxRQUFBLGlCQUFBLEtBQUEsS0FBQSxDQUFBLFFBQUEsSUFBZ0IsYUFBVyxLQUFBLENBQUEsS0FBQSxVQUFBO0FBQUEsVUFBWCxjQUFXO0FBQUEsSUFBQSxLQUFBLFVBQUEsVUFBQSxHQUFBLDJCQUFBLDhCQUFBO0FBTDFELGlCQUFBLE1BQUEsbUJBQUEsRUFBQSxPQUFBLFdBQUEsR0FBQSxrQkFBQSxFQUFBLE1BQUEsU0FBQSxNQUFBLFdBQUEsTUFBQSxVQUFBLFVBQUEsR0FBQSxNQUFBLHVCQUFBOzs7UUFDa0MsR0FBQSxPQUFPLGFBQ2hCLEdBQUEsU0FBeUIsQ0FBQyxpQkFBaUIsS0FBSyxHQUZuRSxrQkFBQSxZQUFBLHVCQUFBLEdBQWtCOzs7In0=
79
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGl2aWRlci5jb21wb25lbnQuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9lbGVtZW50cy9kaXZpZGVyL2RpdmlkZXIuY29tcG9uZW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIHR5cGUgQ1NTUmVzdWx0R3JvdXAsXG4gIGh0bWwsXG4gIExpdEVsZW1lbnQsXG4gIHR5cGUgUHJvcGVydHlWYWx1ZXMsXG4gIHR5cGUgVGVtcGxhdGVSZXN1bHQsXG59IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50LCBwcm9wZXJ0eSB9IGZyb20gJ2xpdC9kZWNvcmF0b3JzLmpzJztcblxuaW1wb3J0IHR5cGUgeyBTYmJPcmllbnRhdGlvbiB9IGZyb20gJy4uL2NvcmUvaW50ZXJmYWNlcy50cyc7XG5pbXBvcnQgeyBTYmJFbGVtZW50SW50ZXJuYWxzTWl4aW4sIFNiYk5lZ2F0aXZlTWl4aW4gfSBmcm9tICcuLi9jb3JlL21peGlucy50cyc7XG5pbXBvcnQgeyBib3hTaXppbmdTdHlsZXMgfSBmcm9tICcuLi9jb3JlL3N0eWxlcy50cyc7XG5cbmltcG9ydCBzdHlsZSBmcm9tICcuL2RpdmlkZXIuc2Nzcz9saXQmaW5saW5lJztcblxuLyoqXG4gKiBEaXNwbGF5cyBhIGRpdmlkZXIgYmV0d2VlbiBzZWN0aW9ucy5cbiAqL1xuZXhwb3J0XG5AY3VzdG9tRWxlbWVudCgnc2JiLWRpdmlkZXInKVxuY2xhc3MgU2JiRGl2aWRlckVsZW1lbnQgZXh0ZW5kcyBTYmJOZWdhdGl2ZU1peGluKFNiYkVsZW1lbnRJbnRlcm5hbHNNaXhpbihMaXRFbGVtZW50KSkge1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHJlYWRvbmx5IHJvbGUgPSAnc2VwYXJhdG9yJztcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gW2JveFNpemluZ1N0eWxlcywgc3R5bGVdO1xuXG4gIC8qKiBPcmllbnRhdGlvbiBwcm9wZXJ0eSB3aXRoIHBvc3NpYmxlIHZhbHVlcyAnaG9yaXpvbnRhbCcgfCAndmVydGljYWwnLiBEZWZhdWx0cyB0byBob3Jpem9udGFsLiAqL1xuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pIHB1YmxpYyBhY2Nlc3NvciBvcmllbnRhdGlvbjogU2JiT3JpZW50YXRpb24gPSAnaG9yaXpvbnRhbCc7XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHdpbGxVcGRhdGUoY2hhbmdlZFByb3BlcnRpZXM6IFByb3BlcnR5VmFsdWVzPHRoaXM+KTogdm9pZCB7XG4gICAgc3VwZXIud2lsbFVwZGF0ZShjaGFuZ2VkUHJvcGVydGllcyk7XG5cbiAgICBpZiAoY2hhbmdlZFByb3BlcnRpZXMuaGFzKCdvcmllbnRhdGlvbicpKSB7XG4gICAgICB0aGlzLmludGVybmFscy5hcmlhT3JpZW50YXRpb24gPSB0aGlzLm9yaWVudGF0aW9uO1xuICAgIH1cbiAgfVxuXG4gIHByb3RlY3RlZCBvdmVycmlkZSByZW5kZXIoKTogVGVtcGxhdGVSZXN1bHQge1xuICAgIHJldHVybiBodG1sYDxkaXYgY2xhc3M9XCJzYmItZGl2aWRlclwiPjwvZGl2PiBgO1xuICB9XG59XG5cbmRlY2xhcmUgZ2xvYmFsIHtcbiAgaW50ZXJmYWNlIEhUTUxFbGVtZW50VGFnTmFtZU1hcCB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvblxuICAgICdzYmItZGl2aWRlcic6IFNiYkRpdmlkZXJFbGVtZW50O1xuICB9XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztJQW9CTSxxQkFBaUIsTUFBQTs7MEJBRHRCLGNBQWMsYUFBYSxDQUFDOzs7O0FBQ0csTUFBQSxjQUFBLGlCQUFpQix5QkFBeUIsVUFBVSxDQUFDOzs7O0FBQTdELEVBQUEsbUJBQVEsWUFBc0Q7QUFBQTs7QUFLdkQsd0RBQUEsa0JBQUEsTUFBQSwyQkFBOEMsWUFBWTs7OztJQUExRCxJQUFnQixjQUFXO0FBQUEsYUFBQSxtQkFBQTtBQUFBLElBQUE7QUFBQSxJQUEzQixJQUFnQixZQUFXLE9BQUE7QUFBQSx5QkFBQSwrQkFBQTtBQUFBLElBQUE7QUFBQSxJQUVyQyxXQUFXLG1CQUF1QztBQUNuRSxZQUFNLFdBQVcsaUJBQWlCO0FBRWxDLFVBQUksa0JBQWtCLElBQUksYUFBYSxHQUFHO0FBQ3hDLGFBQUssVUFBVSxrQkFBa0IsS0FBSztBQUFBLE1BQ3hDO0FBQUEsSUFDRjtBQUFBLElBRW1CLFNBQU07QUFDdkIsYUFBTztBQUFBLElBQ1Q7QUFBQSxLQVo2Qjs7QUFBNUIsOEJBQUEsQ0FBQSxTQUFTLEVBQUUsU0FBUyxLQUFBLENBQU0sQ0FBQztBQUFDLGlCQUFBLElBQUEsTUFBQSx5QkFBQSxFQUFBLE1BQUEsWUFBQSxNQUFBLGVBQUEsUUFBQSxPQUFBLFNBQUEsT0FBQSxRQUFBLEVBQUEsS0FBQSxDQUFBLFFBQUEsaUJBQUEsS0FBQSxLQUFBLENBQUEsUUFBQSxJQUFnQixhQUFXLEtBQUEsQ0FBQSxLQUFBLFVBQUE7QUFBQSxVQUFYLGNBQVc7QUFBQSxJQUFBLEtBQUEsVUFBQSxVQUFBLEdBQUEsMkJBQUEsOEJBQUE7QUFMMUQsaUJBQUEsTUFBQSxtQkFBQSxFQUFBLE9BQUEsV0FBQSxHQUFBLGtCQUFBLEVBQUEsTUFBQSxTQUFBLE1BQUEsV0FBQSxNQUFBLFVBQUEsVUFBQSxHQUFBLE1BQUEsdUJBQUE7OztRQUNrQyxHQUFBLE9BQU8sYUFDaEIsR0FBQSxTQUF5QixDQUFDLGlCQUFpQixLQUFLLEdBRm5FLGtCQUFBLFlBQUEsdUJBQUEsR0FBa0I7OzsifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"expansion-panel.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/expansion-panel/expansion-panel/expansion-panel.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAE,MAAM,KAAK,CAAC;AAajC,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;;AAQpD;;;;GAIG;AACH,qBAEM,wBAAyB,SAAQ,6BAAuD;IAC5F,OAAuB,MAAM,EAAE,cAAc,CAA4B;IACzE,gBAAuB,MAAM;;;;;MAKlB;IAEX,yDAAyD;IACzD,SAAwD,UAAU,EAAE,aAAa,GAAG,IAAI,CAAQ;IAEhG,yCAAyC;IACzC,SAA6C,KAAK,EAAE,OAAO,GAAG,MAAM,CAAW;IAE/E,qCAAqC;IACrC,IACW,QAAQ,CAAC,KAAK,EAAE,OAAO,EAGjC;IACD,IAAW,QAAQ,IAAI,OAAO,CAE7B;IACD,OAAO,CAAC,SAAS,CAAkB;IAEnC,6EAA6E;IAC7E,IACW,QAAQ,CAAC,KAAK,EAAE,OAAO,EAGjC;IACD,IAAW,QAAQ,IAAI,OAAO,CAE7B;IACD,OAAO,CAAC,SAAS,CAAkB;IAEnC,uCAAuC;IACvC,SAEgB,UAAU,EAAE,OAAO,CAAS;IAE5C;;;OAGG;IACH,SAA6C,IAAI,EAAE,GAAG,GAAG,GAAG,CAAwB;IAEpF,kCAAkC;IAClC,OAAO,KAAK,MAAM,QAQjB;IACD,OAAO,KAAK,MAAM,GAEjB;IACD,OAAO,CAAC,cAAc,CAAwB;IAE9C,OAAO,CAAC,cAAc,CAAkB;IACxC,OAAO,CAAC,UAAU,CAAC,CAAiC;IACpD,OAAO,CAAC,WAAW,CAAC,CAAkC;;IAStC,iBAAiB,IAAI,IAAI;IAKzB,oBAAoB,IAAI,IAAI;IAK5C,OAAO,CAAC,eAAe;IAIvB,OAAO,CAAC,iBAAiB;IAWzB,OAAO,CAAC,KAAK;IAYb,OAAO,CAAC,MAAM;IAYd,OAAO,CAAC,wBAAwB;IAIhC,OAAO,CAAC,cAAc;IAMtB,OAAO,CAAC,cAAc;IAMtB,OAAO,CAAC,uBAAuB;IAM/B,OAAO,CAAC,iBAAiB;IAiCzB,OAAO,CAAC,eAAe;cAQJ,MAAM,IAAI,cAAc;CAkB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,qBAAqB,EAAE,wBAAwB,CAAC;KACjD;CACF"}
1
+ {"version":3,"file":"expansion-panel.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/expansion-panel/expansion-panel/expansion-panel.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAE,UAAU,EAAE,MAAM,KAAK,CAAC;AAajC,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;;AAQpD;;;;GAIG;AACH,qBAEM,wBAAyB,SAAQ,6BAAuD;IAC5F,OAAuB,MAAM,EAAE,cAAc,CAA4B;IACzE,gBAAuB,MAAM;;;;;MAKlB;IAEX,yDAAyD;IACzD,SAAwD,UAAU,EAAE,aAAa,GAAG,IAAI,CAAQ;IAEhG,yCAAyC;IACzC,SAA6C,KAAK,EAAE,OAAO,GAAG,MAAM,CAAW;IAE/E,qCAAqC;IACrC,IACW,QAAQ,CAAC,KAAK,EAAE,OAAO,EAGjC;IACD,IAAW,QAAQ,IAAI,OAAO,CAE7B;IACD,OAAO,CAAC,SAAS,CAAkB;IAEnC,6EAA6E;IAC7E,IACW,QAAQ,CAAC,KAAK,EAAE,OAAO,EAGjC;IACD,IAAW,QAAQ,IAAI,OAAO,CAE7B;IACD,OAAO,CAAC,SAAS,CAAkB;IAEnC,uCAAuC;IACvC,SAEgB,UAAU,EAAE,OAAO,CAAS;IAE5C;;;OAGG;IACH,SAA6C,IAAI,EAAE,GAAG,GAAG,GAAG,CAAwB;IAEpF,kCAAkC;IAClC,OAAO,KAAK,MAAM,QAQjB;IACD,OAAO,KAAK,MAAM,GAEjB;IACD,OAAO,CAAC,cAAc,CAAwB;IAE9C,OAAO,CAAC,cAAc,CAAkB;IACxC,OAAO,CAAC,UAAU,CAAC,CAAiC;IACpD,OAAO,CAAC,WAAW,CAAC,CAAkC;;IAatC,iBAAiB,IAAI,IAAI;IAKzB,oBAAoB,IAAI,IAAI;IAK5C,OAAO,CAAC,eAAe;IAIvB,OAAO,CAAC,iBAAiB;IAWzB,OAAO,CAAC,KAAK;IAYb,OAAO,CAAC,MAAM;IAYd,OAAO,CAAC,wBAAwB;IAIhC,OAAO,CAAC,cAAc;IAMtB,OAAO,CAAC,cAAc;IAMtB,OAAO,CAAC,uBAAuB;IAM/B,OAAO,CAAC,iBAAiB;IAiCzB,OAAO,CAAC,eAAe;cAQJ,MAAM,IAAI,cAAc;CAgB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,qBAAqB,EAAE,wBAAwB,CAAC;KACjD;CACF"}
@@ -18,24 +18,34 @@ const style = css`:host {
18
18
  --sbb-disable-animation-duration,
19
19
  var(--sbb-animation-duration-4x)
20
20
  );
21
- --sbb-expansion-panel-background-color: var(--sbb-background-color-1);
22
- --sbb-expansion-panel-content-visibility: hidden;
23
- --sbb-expansion-panel-border-width: var(--sbb-border-width-1x);
24
21
  --sbb-expansion-panel-border-color: var(--sbb-border-color-4-inverted);
25
- --sbb-expansion-panel-border-block-start-width: var(--sbb-expansion-panel-border-width);
22
+ --sbb-expansion-panel-border-width: var(--sbb-border-width-1x);
26
23
  --sbb-expansion-panel-border-block-start-color: var(--sbb-expansion-panel-border-color);
27
- --sbb-expansion-panel-border-radius: var(--sbb-border-radius-4x);
24
+ --sbb-expansion-panel-border-block-start-width: var(--sbb-expansion-panel-border-width);
25
+ --sbb-expansion-panel-content-visibility: hidden;
28
26
  --sbb-expansion-panel-start-end-radius: var(--sbb-expansion-panel-border-radius);
29
27
  --sbb-expansion-panel-start-start-radius: var(--sbb-expansion-panel-border-radius);
30
28
  --sbb-expansion-panel-end-end-radius: var(--sbb-expansion-panel-border-radius);
31
29
  --sbb-expansion-panel-end-start-radius: var(--sbb-expansion-panel-border-radius);
32
- --sbb-expansion-panel-title-gap: var(--sbb-spacing-fixed-4x);
33
- --sbb-expansion-panel-icon-size: var(--sbb-size-icon-ui-medium);
34
30
  display: block;
31
+ background-color: var(--sbb-expansion-panel-background-color);
32
+ border: var(--sbb-expansion-panel-border-width) solid var(--sbb-expansion-panel-border-color);
33
+ border-block-start-color: var(--sbb-expansion-panel-border-block-start-color);
34
+ border-block-start-width: var(--sbb-expansion-panel-border-block-start-width);
35
+ border-radius: var(--sbb-expansion-panel-start-start-radius) var(--sbb-expansion-panel-start-end-radius) var(--sbb-expansion-panel-end-end-radius) var(--sbb-expansion-panel-end-start-radius);
36
+ background-clip: padding-box;
35
37
  }
36
38
 
37
39
  :host([size=s]) {
38
- --sbb-expansion-panel-title-gap: var(--sbb-spacing-fixed-2x);
40
+ --sbb-expansion-panel-title-gap: var(--sbb-expansion-panel-title-gap-s);
41
+ }
42
+
43
+ :host([size=l]) {
44
+ --sbb-expansion-panel-title-gap: var(--sbb-expansion-panel-title-gap-l);
45
+ }
46
+
47
+ :host(:not([size])) {
48
+ --sbb-expansion-panel-title-gap: var(--sbb-expansion-panel-title-gap-default);
39
49
  }
40
50
 
41
51
  @media (forced-colors: active) {
@@ -71,8 +81,14 @@ const style = css`:host {
71
81
  --sbb-expansion-panel-end-start-radius: 0;
72
82
  }
73
83
 
84
+ :host([color=white]) {
85
+ --sbb-expansion-panel-background-color: var(--sbb-background-color-1);
86
+ --sbb-expansion-panel-background-color-hover: var(--sbb-background-color-3);
87
+ }
88
+
74
89
  :host([color=milk]) {
75
90
  --sbb-expansion-panel-background-color: var(--sbb-background-color-3);
91
+ --sbb-expansion-panel-background-color-hover: var(--sbb-background-color-1);
76
92
  }
77
93
 
78
94
  :host([borderless]) {
@@ -98,7 +114,7 @@ const style = css`:host {
98
114
  }
99
115
 
100
116
  :host(:not([disabled]):is(:state(toggle-hover),[state--toggle-hover])) {
101
- --sbb-expansion-panel-background-color: var(--sbb-background-color-3);
117
+ background-color: var(--sbb-expansion-panel-background-color-hover);
102
118
  }
103
119
  @media (forced-colors: active) {
104
120
  :host(:not([disabled]):is(:state(toggle-hover),[state--toggle-hover])) {
@@ -107,19 +123,6 @@ const style = css`:host {
107
123
  }
108
124
  }
109
125
 
110
- :host(:not([disabled])[color=milk]:is(:state(toggle-hover),[state--toggle-hover])) {
111
- --sbb-expansion-panel-background-color: var(--sbb-background-color-1);
112
- }
113
-
114
- .sbb-expansion-panel {
115
- background-color: var(--sbb-expansion-panel-background-color);
116
- border: var(--sbb-expansion-panel-border-width) solid var(--sbb-expansion-panel-border-color);
117
- border-block-start-color: var(--sbb-expansion-panel-border-block-start-color);
118
- border-block-start-width: var(--sbb-expansion-panel-border-block-start-width);
119
- border-radius: var(--sbb-expansion-panel-start-start-radius) var(--sbb-expansion-panel-start-end-radius) var(--sbb-expansion-panel-end-end-radius) var(--sbb-expansion-panel-end-start-radius);
120
- background-clip: padding-box;
121
- }
122
-
123
126
  .sbb-expansion-panel__header {
124
127
  margin: 0;
125
128
  }
@@ -148,7 +151,7 @@ const style = css`:host {
148
151
  }
149
152
 
150
153
  .sbb-expansion-panel__content {
151
- overflow: hidden;
154
+ min-height: 0;
152
155
  }
153
156
 
154
157
  @keyframes open {
@@ -216,7 +219,11 @@ let SbbExpansionPanelElement = (() => {
216
219
  this._stateInternal = __runInitializers(this, _size_extraInitializers);
217
220
  this._progressiveId = `-${++nextId}`;
218
221
  this._state = "closed";
219
- this.addEventListener?.("toggleexpanded", () => this._toggleExpanded());
222
+ this.addEventListener?.("toggleexpanded", (ev) => {
223
+ if (ev.target === this._headerRef) {
224
+ this._toggleExpanded();
225
+ }
226
+ });
220
227
  }
221
228
  /** Heading level; if unset, a `div` will be rendered. */
222
229
  get titleLevel() {
@@ -362,15 +369,13 @@ let SbbExpansionPanelElement = (() => {
362
369
  render() {
363
370
  const TAGNAME = this.titleLevel ? `h${this.titleLevel}` : "div";
364
371
  return html`
365
- <div class="sbb-expansion-panel">
366
- <${unsafeStatic(TAGNAME)} class="sbb-expansion-panel__header">
367
- <slot name="header" @slotchange=${this._handleSlotchange}></slot>
368
- </${unsafeStatic(TAGNAME)}>
369
- <div class="sbb-expansion-panel__content-wrapper" @animationend=${this._onAnimationEnd}>
370
- <span class="sbb-expansion-panel__content">
371
- <slot name="content" @slotchange=${this._handleSlotchange}></slot>
372
- </span>
373
- </div>
372
+ <${unsafeStatic(TAGNAME)} class="sbb-expansion-panel__header">
373
+ <slot name="header" @slotchange=${this._handleSlotchange}></slot>
374
+ </${unsafeStatic(TAGNAME)}>
375
+ <div class="sbb-expansion-panel__content-wrapper" @animationend=${this._onAnimationEnd}>
376
+ <span class="sbb-expansion-panel__content">
377
+ <slot name="content" @slotchange=${this._handleSlotchange}></slot>
378
+ </span>
374
379
  </div>
375
380
  `;
376
381
  }
@@ -414,4 +419,4 @@ let SbbExpansionPanelElement = (() => {
414
419
  export {
415
420
  SbbExpansionPanelElement
416
421
  };
417
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"expansion-panel.component.js","sources":["../../../../../src/elements/expansion-panel/expansion-panel/expansion-panel.component.ts"],"sourcesContent":["import type { CSSResultGroup, TemplateResult } from 'lit';\nimport { LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { html, unsafeStatic } from 'lit/static-html.js';\n\nimport { forceType } from '../../core/decorators.ts';\nimport { isLean, isZeroAnimationDuration } from '../../core/dom.ts';\nimport type { SbbOpenedClosedState } from '../../core/interfaces.ts';\nimport {\n  SbbElementInternalsMixin,\n  SbbHydrationMixin,\n  ɵstateController,\n} from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbTitleLevel } from '../../title.ts';\nimport type { SbbExpansionPanelContentElement } from '../expansion-panel-content.ts';\nimport type { SbbExpansionPanelHeaderElement } from '../expansion-panel-header.ts';\n\nimport style from './expansion-panel.scss?lit&inline';\n\nlet nextId = 0;\n\n/**\n * It displays an expandable summary-details widget.\n *\n * @slot - Use the unnamed slot to add a `sbb-expansion-panel-header` and a `sbb-expansion-panel-content` element.\n */\nexport\n@customElement('sbb-expansion-panel')\nclass SbbExpansionPanelElement extends SbbHydrationMixin(SbbElementInternalsMixin(LitElement)) {\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  public static readonly events = {\n    beforeopen: 'beforeopen',\n    open: 'open',\n    beforeclose: 'beforeclose',\n    close: 'close',\n  } as const;\n\n  /** Heading level; if unset, a `div` will be rendered. */\n  @property({ attribute: 'title-level' }) public accessor titleLevel: SbbTitleLevel | null = null;\n\n  /** The background color of the panel. */\n  @property({ reflect: true }) public accessor color: 'white' | 'milk' = 'white';\n\n  /** Whether the panel is expanded. */\n  @property({ reflect: true, type: Boolean })\n  public set expanded(value: boolean) {\n    this._expanded = value;\n    this._onExpandedChange();\n  }\n  public get expanded(): boolean {\n    return this._expanded;\n  }\n  private _expanded: boolean = false;\n\n  /** Whether the panel is disabled, so its expanded state can't be changed. */\n  @property({ reflect: true, type: Boolean })\n  public set disabled(value: boolean) {\n    this._disabled = value;\n    this._updateDisabledOnHeader(this._disabled);\n  }\n  public get disabled(): boolean {\n    return this._disabled;\n  }\n  private _disabled: boolean = false;\n\n  /** Whether the panel has no border. */\n  @forceType()\n  @property({ reflect: true, type: Boolean })\n  public accessor borderless: boolean = false;\n\n  /**\n   * Size variant, either l or s.\n   * @default 'l' / 's' (lean)\n   */\n  @property({ reflect: true }) public accessor size: 's' | 'l' = isLean() ? 's' : 'l';\n\n  /** The state of the component. */\n  private set _state(state: SbbOpenedClosedState) {\n    if (this._stateInternal) {\n      this.internals.states.delete(`state-${this._stateInternal}`);\n    }\n    this._stateInternal = state;\n    if (this._stateInternal) {\n      this.internals.states.add(`state-${this._stateInternal}`);\n    }\n  }\n  private get _state(): SbbOpenedClosedState {\n    return this._stateInternal;\n  }\n  private _stateInternal!: SbbOpenedClosedState;\n\n  private _progressiveId = `-${++nextId}`;\n  private _headerRef?: SbbExpansionPanelHeaderElement;\n  private _contentRef?: SbbExpansionPanelContentElement;\n\n  public constructor() {\n    super();\n\n    this._state = 'closed';\n    this.addEventListener?.('toggleexpanded', () => this._toggleExpanded());\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.toggleState('accordion', !!this.closest?.('sbb-accordion'));\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this.internals.states.delete('accordion');\n  }\n\n  private _toggleExpanded(): void {\n    this.expanded = !this.expanded;\n  }\n\n  private _onExpandedChange(): void {\n    this._headerRef?.setAttribute('aria-expanded', String(this.expanded));\n    this._contentRef?.setAttribute('aria-hidden', String(!this.expanded));\n\n    if (this.expanded) {\n      this._open();\n    } else if (this._state === 'opened') {\n      this._close();\n    }\n  }\n\n  private _open(): void {\n    this._state = 'opening';\n    /** Emits whenever the `sbb-expansion-panel` starts the opening transition. */\n    this.dispatchEvent(new Event('beforeopen'));\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `opened` state.\n    if (!this.hasUpdated || this._isZeroAnimationDuration()) {\n      this._handleOpening();\n    }\n  }\n\n  private _close(): void {\n    this._state = 'closing';\n    /** Emits whenever the `sbb-expansion-panel` begins the closing transition. */\n    this.dispatchEvent(new Event('beforeclose'));\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `closed` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleClosing();\n    }\n  }\n\n  private _isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-expansion-panel-animation-duration');\n  }\n\n  private _handleOpening(): void {\n    this._state = 'opened';\n    /** Emits whenever the `sbb-expansion-panel` is opened. */\n    this.dispatchEvent(new Event('open'));\n  }\n\n  private _handleClosing(): void {\n    this._state = 'closed';\n    /** Emits whenever the `sbb-expansion-panel` is closed. */\n    this.dispatchEvent(new Event('close'));\n  }\n\n  private _updateDisabledOnHeader(newDisabledValue: boolean): void {\n    if (this._headerRef) {\n      this._headerRef.disabled = newDisabledValue;\n    }\n  }\n\n  private _handleSlotchange(): void {\n    const children = Array.from(this.children ?? []);\n    const header = children.find(\n      (e): e is SbbExpansionPanelHeaderElement => e.localName === 'sbb-expansion-panel-header',\n    );\n    const content = children.find(\n      (e): e is SbbExpansionPanelContentElement => e.localName === 'sbb-expansion-panel-content',\n    );\n    if (this._headerRef === header && this._contentRef === content) {\n      return;\n    }\n    if (header && this._headerRef !== header) {\n      header.id ||= `sbb-expansion-panel-header${this._progressiveId}`;\n      header.setAttribute('aria-expanded', String(this.expanded));\n      header.toggleAttribute('disabled', this.disabled);\n    }\n    if (content && this._contentRef !== content) {\n      content.id ||= `sbb-expansion-panel-content${this._progressiveId}`;\n      content.setAttribute('aria-hidden', String(!this.expanded));\n    }\n\n    this._headerRef = header;\n    this._contentRef = content;\n    if (this._headerRef && this._contentRef) {\n      this._headerRef.setAttribute('aria-controls', this._contentRef.id);\n      this._contentRef.setAttribute('aria-labelledby', this._headerRef.id);\n      ɵstateController(this._contentRef).toggle(\n        'icon-space',\n        ɵstateController(this._headerRef).has('icon'),\n      );\n    }\n  }\n\n  private _onAnimationEnd(event: AnimationEvent): void {\n    if (event.animationName === 'open-opacity' && this._state === 'opening') {\n      this._handleOpening();\n    } else if (event.animationName === 'close' && this._state === 'closing') {\n      this._handleClosing();\n    }\n  }\n\n  protected override render(): TemplateResult {\n    const TAGNAME = this.titleLevel ? `h${this.titleLevel}` : 'div';\n\n    /* eslint-disable lit/binding-positions */\n    return html`\n      <div class=\"sbb-expansion-panel\">\n        <${unsafeStatic(TAGNAME)} class=\"sbb-expansion-panel__header\">\n          <slot name=\"header\" @slotchange=${this._handleSlotchange}></slot>\n        </${unsafeStatic(TAGNAME)}>\n        <div class=\"sbb-expansion-panel__content-wrapper\" @animationend=${this._onAnimationEnd}>\n          <span class=\"sbb-expansion-panel__content\">\n            <slot name=\"content\" @slotchange=${this._handleSlotchange}></slot>\n          </span>\n        </div>\n      </div>\n    `;\n    /* eslint-enable lit/binding-positions */\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-expansion-panel': SbbExpansionPanelElement;\n  }\n}\n"],"names":["ɵstateController"],"mappings":"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"}
422
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"expansion-panel.component.js","sources":["../../../../../src/elements/expansion-panel/expansion-panel/expansion-panel.component.ts"],"sourcesContent":["import type { CSSResultGroup, TemplateResult } from 'lit';\nimport { LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { html, unsafeStatic } from 'lit/static-html.js';\n\nimport { forceType } from '../../core/decorators.ts';\nimport { isLean, isZeroAnimationDuration } from '../../core/dom.ts';\nimport type { SbbOpenedClosedState } from '../../core/interfaces.ts';\nimport {\n  SbbElementInternalsMixin,\n  SbbHydrationMixin,\n  ɵstateController,\n} from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbTitleLevel } from '../../title.ts';\nimport type { SbbExpansionPanelContentElement } from '../expansion-panel-content.ts';\nimport type { SbbExpansionPanelHeaderElement } from '../expansion-panel-header.ts';\n\nimport style from './expansion-panel.scss?lit&inline';\n\nlet nextId = 0;\n\n/**\n * It displays an expandable summary-details widget.\n *\n * @slot - Use the unnamed slot to add a `sbb-expansion-panel-header` and a `sbb-expansion-panel-content` element.\n */\nexport\n@customElement('sbb-expansion-panel')\nclass SbbExpansionPanelElement extends SbbHydrationMixin(SbbElementInternalsMixin(LitElement)) {\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  public static readonly events = {\n    beforeopen: 'beforeopen',\n    open: 'open',\n    beforeclose: 'beforeclose',\n    close: 'close',\n  } as const;\n\n  /** Heading level; if unset, a `div` will be rendered. */\n  @property({ attribute: 'title-level' }) public accessor titleLevel: SbbTitleLevel | null = null;\n\n  /** The background color of the panel. */\n  @property({ reflect: true }) public accessor color: 'white' | 'milk' = 'white';\n\n  /** Whether the panel is expanded. */\n  @property({ reflect: true, type: Boolean })\n  public set expanded(value: boolean) {\n    this._expanded = value;\n    this._onExpandedChange();\n  }\n  public get expanded(): boolean {\n    return this._expanded;\n  }\n  private _expanded: boolean = false;\n\n  /** Whether the panel is disabled, so its expanded state can't be changed. */\n  @property({ reflect: true, type: Boolean })\n  public set disabled(value: boolean) {\n    this._disabled = value;\n    this._updateDisabledOnHeader(this._disabled);\n  }\n  public get disabled(): boolean {\n    return this._disabled;\n  }\n  private _disabled: boolean = false;\n\n  /** Whether the panel has no border. */\n  @forceType()\n  @property({ reflect: true, type: Boolean })\n  public accessor borderless: boolean = false;\n\n  /**\n   * Size variant, either l or s.\n   * @default 'l' / 's' (lean)\n   */\n  @property({ reflect: true }) public accessor size: 's' | 'l' = isLean() ? 's' : 'l';\n\n  /** The state of the component. */\n  private set _state(state: SbbOpenedClosedState) {\n    if (this._stateInternal) {\n      this.internals.states.delete(`state-${this._stateInternal}`);\n    }\n    this._stateInternal = state;\n    if (this._stateInternal) {\n      this.internals.states.add(`state-${this._stateInternal}`);\n    }\n  }\n  private get _state(): SbbOpenedClosedState {\n    return this._stateInternal;\n  }\n  private _stateInternal!: SbbOpenedClosedState;\n\n  private _progressiveId = `-${++nextId}`;\n  private _headerRef?: SbbExpansionPanelHeaderElement;\n  private _contentRef?: SbbExpansionPanelContentElement;\n\n  public constructor() {\n    super();\n\n    this._state = 'closed';\n    this.addEventListener?.('toggleexpanded', (ev: Event) => {\n      if (ev.target === this._headerRef) {\n        this._toggleExpanded();\n      }\n    });\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.toggleState('accordion', !!this.closest?.('sbb-accordion'));\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this.internals.states.delete('accordion');\n  }\n\n  private _toggleExpanded(): void {\n    this.expanded = !this.expanded;\n  }\n\n  private _onExpandedChange(): void {\n    this._headerRef?.setAttribute('aria-expanded', String(this.expanded));\n    this._contentRef?.setAttribute('aria-hidden', String(!this.expanded));\n\n    if (this.expanded) {\n      this._open();\n    } else if (this._state === 'opened') {\n      this._close();\n    }\n  }\n\n  private _open(): void {\n    this._state = 'opening';\n    /** Emits whenever the `sbb-expansion-panel` starts the opening transition. */\n    this.dispatchEvent(new Event('beforeopen'));\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `opened` state.\n    if (!this.hasUpdated || this._isZeroAnimationDuration()) {\n      this._handleOpening();\n    }\n  }\n\n  private _close(): void {\n    this._state = 'closing';\n    /** Emits whenever the `sbb-expansion-panel` begins the closing transition. */\n    this.dispatchEvent(new Event('beforeclose'));\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `closed` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleClosing();\n    }\n  }\n\n  private _isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-expansion-panel-animation-duration');\n  }\n\n  private _handleOpening(): void {\n    this._state = 'opened';\n    /** Emits whenever the `sbb-expansion-panel` is opened. */\n    this.dispatchEvent(new Event('open'));\n  }\n\n  private _handleClosing(): void {\n    this._state = 'closed';\n    /** Emits whenever the `sbb-expansion-panel` is closed. */\n    this.dispatchEvent(new Event('close'));\n  }\n\n  private _updateDisabledOnHeader(newDisabledValue: boolean): void {\n    if (this._headerRef) {\n      this._headerRef.disabled = newDisabledValue;\n    }\n  }\n\n  private _handleSlotchange(): void {\n    const children = Array.from(this.children ?? []);\n    const header = children.find(\n      (e): e is SbbExpansionPanelHeaderElement => e.localName === 'sbb-expansion-panel-header',\n    );\n    const content = children.find(\n      (e): e is SbbExpansionPanelContentElement => e.localName === 'sbb-expansion-panel-content',\n    );\n    if (this._headerRef === header && this._contentRef === content) {\n      return;\n    }\n    if (header && this._headerRef !== header) {\n      header.id ||= `sbb-expansion-panel-header${this._progressiveId}`;\n      header.setAttribute('aria-expanded', String(this.expanded));\n      header.toggleAttribute('disabled', this.disabled);\n    }\n    if (content && this._contentRef !== content) {\n      content.id ||= `sbb-expansion-panel-content${this._progressiveId}`;\n      content.setAttribute('aria-hidden', String(!this.expanded));\n    }\n\n    this._headerRef = header;\n    this._contentRef = content;\n    if (this._headerRef && this._contentRef) {\n      this._headerRef.setAttribute('aria-controls', this._contentRef.id);\n      this._contentRef.setAttribute('aria-labelledby', this._headerRef.id);\n      ɵstateController(this._contentRef).toggle(\n        'icon-space',\n        ɵstateController(this._headerRef).has('icon'),\n      );\n    }\n  }\n\n  private _onAnimationEnd(event: AnimationEvent): void {\n    if (event.animationName === 'open-opacity' && this._state === 'opening') {\n      this._handleOpening();\n    } else if (event.animationName === 'close' && this._state === 'closing') {\n      this._handleClosing();\n    }\n  }\n\n  protected override render(): TemplateResult {\n    const TAGNAME = this.titleLevel ? `h${this.titleLevel}` : 'div';\n\n    /* eslint-disable lit/binding-positions */\n    return html`\n      <${unsafeStatic(TAGNAME)} class=\"sbb-expansion-panel__header\">\n        <slot name=\"header\" @slotchange=${this._handleSlotchange}></slot>\n      </${unsafeStatic(TAGNAME)}>\n      <div class=\"sbb-expansion-panel__content-wrapper\" @animationend=${this._onAnimationEnd}>\n        <span class=\"sbb-expansion-panel__content\">\n          <slot name=\"content\" @slotchange=${this._handleSlotchange}></slot>\n        </span>\n      </div>\n    `;\n    /* eslint-enable lit/binding-positions */\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-expansion-panel': SbbExpansionPanelElement;\n  }\n}\n"],"names":["ɵstateController"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAoBA,IAAI,SAAS;IASP,4BAAwB,MAAA;;0BAD7B,cAAc,qBAAqB,CAAC;;;;AACE,MAAA,cAAA,kBAAkB,yBAAyB,UAAU,CAAC;;;;;;;;;;;;;;;;AAA9D,EAAA,mBAAQ,YAAuD;AAAA,IAmE5F,cAAA;AACE,YAAA;AA1DsC;AAGX;AA2B7B;AAM6B;AApC2B,yBAAA,+BAVpD,kBAAA,MAAA,0BAAA,GAAwB,kBAAA,MAAA,0BAU+D,IAAI;AAGlD,yBAAA,0BAAA,kBAAA,MAAA,6BAAA,GAAA,kBAAA,MAAA,qBAA0B,OAAO;AAWtE,WAAA,aAAS,kBAAA,MAAA,wBAAA,GAAY;AAWrB,WAAA,YAAqB;AAKb,yBAAA,8BAAA,kBAAA,MAAA,0BAAsB,KAAK;AAME,yBAAA,yBAAA,kBAAA,MAAA,6BAAA,GAAA,kBAAA,MAAA,oBAAkB,OAAA,IAAW,MAAM,GAAG;AAe3E,WAAA,iBAAc,kBAAA,MAAA,uBAAA;AAEd,WAAA,iBAAiB,IAAI,EAAE,MAAM;AAOnC,WAAK,SAAS;AACd,WAAK,mBAAmB,kBAAkB,CAAC,OAAa;AACtD,YAAI,GAAG,WAAW,KAAK,YAAY;AACjC,eAAK,gBAAA;AAAA,QACP;AAAA,MACF,CAAC;AAAA,IACH;AAAA;AAAA,IAlEwC,IAAgB,aAAU;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA1B,IAAgB,WAAU,OAAA;AAAA,yBAAA,8BAAA;AAAA,IAAA;AAAA;AAAA,IAGrC,IAAgB,QAAK;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAArB,IAAgB,MAAK,OAAA;AAAA,yBAAA,yBAAA;AAAA,IAAA;AAAA;AAAA,IAIlD,IAAW,SAAS,OAAc;AAChC,WAAK,YAAY;AACjB,WAAK,kBAAA;AAAA,IACP;AAAA,IACA,IAAW,WAAQ;AACjB,aAAO,KAAK;AAAA,IACd;AAAA;AAAA,IAKA,IAAW,SAAS,OAAc;AAChC,WAAK,YAAY;AACjB,WAAK,wBAAwB,KAAK,SAAS;AAAA,IAC7C;AAAA,IACA,IAAW,WAAQ;AACjB,aAAO,KAAK;AAAA,IACd;AAAA;AAAA,IAMA,IAAgB,aAAU;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA1B,IAAgB,WAAU,OAAA;AAAA,yBAAA,8BAAA;AAAA,IAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAMG,IAAgB,OAAI;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAApB,IAAgB,KAAI,OAAA;AAAA,yBAAA,wBAAA;AAAA,IAAA;AAAA;AAAA,IAGjD,IAAY,OAAO,OAA2B;AAC5C,UAAI,KAAK,gBAAgB;AACvB,aAAK,UAAU,OAAO,OAAO,SAAS,KAAK,cAAc,EAAE;AAAA,MAC7D;AACA,WAAK,iBAAiB;AACtB,UAAI,KAAK,gBAAgB;AACvB,aAAK,UAAU,OAAO,IAAI,SAAS,KAAK,cAAc,EAAE;AAAA,MAC1D;AAAA,IACF;AAAA,IACA,IAAY,SAAM;AAChB,aAAO,KAAK;AAAA,IACd;AAAA,IAkBgB,oBAAiB;AAC/B,YAAM,kBAAA;AACN,WAAK,YAAY,aAAa,CAAC,CAAC,KAAK,UAAU,eAAe,CAAC;AAAA,IACjE;AAAA,IAEgB,uBAAoB;AAClC,YAAM,qBAAA;AACN,WAAK,UAAU,OAAO,OAAO,WAAW;AAAA,IAC1C;AAAA,IAEQ,kBAAe;AACrB,WAAK,WAAW,CAAC,KAAK;AAAA,IACxB;AAAA,IAEQ,oBAAiB;AACvB,WAAK,YAAY,aAAa,iBAAiB,OAAO,KAAK,QAAQ,CAAC;AACpE,WAAK,aAAa,aAAa,eAAe,OAAO,CAAC,KAAK,QAAQ,CAAC;AAEpE,UAAI,KAAK,UAAU;AACjB,aAAK,MAAA;AAAA,MACP,WAAW,KAAK,WAAW,UAAU;AACnC,aAAK,OAAA;AAAA,MACP;AAAA,IACF;AAAA,IAEQ,QAAK;AACX,WAAK,SAAS;AAEd,WAAK,cAAc,IAAI,MAAM,YAAY,CAAC;AAI1C,UAAI,CAAC,KAAK,cAAc,KAAK,4BAA4B;AACvD,aAAK,eAAA;AAAA,MACP;AAAA,IACF;AAAA,IAEQ,SAAM;AACZ,WAAK,SAAS;AAEd,WAAK,cAAc,IAAI,MAAM,aAAa,CAAC;AAI3C,UAAI,KAAK,4BAA4B;AACnC,aAAK,eAAA;AAAA,MACP;AAAA,IACF;AAAA,IAEQ,2BAAwB;AAC9B,aAAO,wBAAwB,MAAM,0CAA0C;AAAA,IACjF;AAAA,IAEQ,iBAAc;AACpB,WAAK,SAAS;AAEd,WAAK,cAAc,IAAI,MAAM,MAAM,CAAC;AAAA,IACtC;AAAA,IAEQ,iBAAc;AACpB,WAAK,SAAS;AAEd,WAAK,cAAc,IAAI,MAAM,OAAO,CAAC;AAAA,IACvC;AAAA,IAEQ,wBAAwB,kBAAyB;AACvD,UAAI,KAAK,YAAY;AACnB,aAAK,WAAW,WAAW;AAAA,MAC7B;AAAA,IACF;AAAA,IAEQ,oBAAiB;AACvB,YAAM,WAAW,MAAM,KAAK,KAAK,YAAY,CAAA,CAAE;AAC/C,YAAM,SAAS,SAAS,KACtB,CAAC,MAA2C,EAAE,cAAc,4BAA4B;AAE1F,YAAM,UAAU,SAAS,KACvB,CAAC,MAA4C,EAAE,cAAc,6BAA6B;AAE5F,UAAI,KAAK,eAAe,UAAU,KAAK,gBAAgB,SAAS;AAC9D;AAAA,MACF;AACA,UAAI,UAAU,KAAK,eAAe,QAAQ;AACxC,eAAO,OAAO,6BAA6B,KAAK,cAAc;AAC9D,eAAO,aAAa,iBAAiB,OAAO,KAAK,QAAQ,CAAC;AAC1D,eAAO,gBAAgB,YAAY,KAAK,QAAQ;AAAA,MAClD;AACA,UAAI,WAAW,KAAK,gBAAgB,SAAS;AAC3C,gBAAQ,OAAO,8BAA8B,KAAK,cAAc;AAChE,gBAAQ,aAAa,eAAe,OAAO,CAAC,KAAK,QAAQ,CAAC;AAAA,MAC5D;AAEA,WAAK,aAAa;AAClB,WAAK,cAAc;AACnB,UAAI,KAAK,cAAc,KAAK,aAAa;AACvC,aAAK,WAAW,aAAa,iBAAiB,KAAK,YAAY,EAAE;AACjE,aAAK,YAAY,aAAa,mBAAmB,KAAK,WAAW,EAAE;AACnEA,yBAAiB,KAAK,WAAW,EAAE,OACjC,cACAA,iBAAiB,KAAK,UAAU,EAAE,IAAI,MAAM,CAAC;AAAA,MAEjD;AAAA,IACF;AAAA,IAEQ,gBAAgB,OAAqB;AAC3C,UAAI,MAAM,kBAAkB,kBAAkB,KAAK,WAAW,WAAW;AACvE,aAAK,eAAA;AAAA,MACP,WAAW,MAAM,kBAAkB,WAAW,KAAK,WAAW,WAAW;AACvE,aAAK,eAAA;AAAA,MACP;AAAA,IACF;AAAA,IAEmB,SAAM;AACvB,YAAM,UAAU,KAAK,aAAa,IAAI,KAAK,UAAU,KAAK;AAG1D,aAAO;AAAA,SACF,aAAa,OAAO,CAAC;AAAA,0CACY,KAAK,iBAAiB;AAAA,UACtD,aAAa,OAAO,CAAC;AAAA,wEACyC,KAAK,eAAe;AAAA;AAAA,6CAE/C,KAAK,iBAAiB;AAAA;AAAA;AAAA;AAAA,IAKjE;AAAA,KAnMwC,8CAGX,yCA2B7B,8CAM6B;;AApC5B,6BAAA,CAAA,SAAS,EAAE,WAAW,cAAA,CAAe,CAAC;AAGtC,wBAAA,CAAA,SAAS,EAAE,SAAS,KAAA,CAAM,CAAC;gCAG3B,SAAS,EAAE,SAAS,MAAM,MAAM,QAAA,CAAS,CAAC;gCAW1C,SAAS,EAAE,SAAS,MAAM,MAAM,QAAA,CAAS,CAAC;AAW1C,6BAAA,CAAA,UAAA,GACA,SAAS,EAAE,SAAS,MAAM,MAAM,QAAA,CAAS,CAAC;AAO1C,uBAAA,CAAA,SAAS,EAAE,SAAS,KAAA,CAAM,CAAC;AApCY,iBAAA,IAAA,MAAA,wBAAA,EAAA,MAAA,YAAA,MAAA,cAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,gBAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,YAAU,KAAA,CAAA,KAAA,UAAA;AAAA,UAAV,aAAU;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,0BAAA,6BAAA;AAGrC,iBAAA,IAAA,MAAA,mBAAA,EAAA,MAAA,YAAA,MAAA,SAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,WAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,OAAK,KAAA,CAAA,KAAA,UAAA;AAAA,UAAL,QAAK;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,qBAAA,wBAAA;AAIlD,iBAAA,IAAA,MAAA,0BAAA,EAAA,MAAA,UAAA,MAAA,YAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,cAAA,KAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAW,WAAQ;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,MAAA,0BAAA;AAWnB,iBAAA,IAAA,MAAA,0BAAA,EAAA,MAAA,UAAA,MAAA,YAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,cAAA,KAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAW,WAAQ;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,MAAA,0BAAA;AAYnB,iBAAA,IAAA,MAAA,wBAAA,EAAA,MAAA,YAAA,MAAA,cAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,gBAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,YAAU,KAAA,CAAA,KAAA,UAAA;AAAA,UAAV,aAAU;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,0BAAA,6BAAA;AAMG,iBAAA,IAAA,MAAA,kBAAA,EAAA,MAAA,YAAA,MAAA,QAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,UAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,MAAI,KAAA,CAAA,KAAA,UAAA;AAAA,UAAJ,OAAI;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,oBAAA,uBAAA;AA9CnD,iBAAA,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;QACyB,GAAA,SAAyB,CAAC,iBAAiB,KAAK,GAChD,GAAA,SAAS;AAAA,IAC9B,YAAY;AAAA,IACZ,MAAM;AAAA,IACN,aAAa;AAAA,IACb,OAAO;AAAA,EAAA,GANL,kBAAA,YAAA,uBAAA,GAAyB;;;"}