@sbb-esta/lyne-elements-dev 4.9.0-dev.1775120423 → 4.9.0-dev.1775122363

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.
@@ -233,6 +233,9 @@ $theme: 'standard' !default;
233
233
  @use '../../tabs/tab-nav-bar/tab-nav-bar.global' as tab-nav-bar with (
234
234
  $theme: $theme
235
235
  );
236
+ @use '../../tag/tag/tag.global' as tag with (
237
+ $theme: $theme
238
+ );
236
239
  @use '../../visual-checkbox/visual-checkbox.global' as visual-checkbox with (
237
240
  $theme: $theme
238
241
  );
@@ -310,6 +313,7 @@ $theme: 'standard' !default;
310
313
  @include stepper.base;
311
314
  @include tab-group-common.base;
312
315
  @include tab-label-common.base;
316
+ @include tag.base;
313
317
  @include visual-checkbox.base;
314
318
 
315
319
  @include a11y.if-forced-colors {
@@ -328,6 +332,7 @@ $theme: 'standard' !default;
328
332
  @include signet.base-forced-colors;
329
333
  @include slider.base-forced-colors;
330
334
  @include step-label.base-forced-colors;
335
+ @include tag.base-forced-colors;
331
336
  }
332
337
 
333
338
  // Train formation
package/core.css CHANGED
@@ -1723,6 +1723,17 @@ slot[name=error]::slotted(*) {
1723
1723
  --sbb-tab-label-amount-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));
1724
1724
  --sbb-tab-label-line-color: var(--sbb-border-color-4-inverted);
1725
1725
  --sbb-tab-label-cursor: var(--sbb-cursor-pointer);
1726
+ --sbb-tag-animation-easing: var(--sbb-animation-easing);
1727
+ --sbb-tag-background-color: var(--sbb-background-color-1);
1728
+ --sbb-tag-border-color: var(--sbb-border-color-4-inverted);
1729
+ --sbb-tag-border-style: solid;
1730
+ --sbb-tag-border-width: var(--sbb-border-width-1x);
1731
+ --sbb-tag-border-radius: var(--sbb-border-radius-infinity);
1732
+ --sbb-tag-gap: var(--sbb-spacing-fixed-2x);
1733
+ --sbb-tag-text-color: var(--sbb-color-2);
1734
+ --sbb-tag-amount-color: var(--sbb-color-metal);
1735
+ --sbb-tag-amount-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));
1736
+ --sbb-tag-height: var(--sbb-size-element-xs);
1726
1737
  --sbb-visual-checkbox-dimension: var(--sbb-checkbox-dimension-m);
1727
1738
  --sbb-visual-checkbox-selection-color: var(--sbb-color-primary);
1728
1739
  --sbb-visual-checkbox-selection-color-negative: var(--sbb-color-primary85);
@@ -1780,6 +1791,11 @@ slot[name=error]::slotted(*) {
1780
1791
  --sbb-slider-line-color: CanvasText;
1781
1792
  --sbb-step-label-color: ButtonText;
1782
1793
  --sbb-step-label-prefix-border-color: ButtonText;
1794
+ --sbb-tag-amount-color: ButtonText;
1795
+ --sbb-tag-background-color: Canvas !important;
1796
+ --sbb-tag-text-color: ButtonText;
1797
+ --sbb-tag-border-color: CanvasText;
1798
+ --sbb-tag-border-width: var(--sbb-border-width-2x);
1783
1799
  }
1784
1800
  }
1785
1801
  :root {
@@ -1,2 +1,2 @@
1
- import { t as SbbTagElement } from "../../tag.component-0vKnvMOm.js";
1
+ import { t as SbbTagElement } from "../../tag.component-CnNPL6aI.js";
2
2
  export { SbbTagElement };
@@ -1 +1 @@
1
- {"version":3,"file":"tag-group.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/tag/tag-group/tag-group.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAGnB,KAAK,cAAc,EACnB,KAAK,cAAc,EAEpB,MAAM,KAAK,CAAC;AAGb,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AAGzD,OAAO,EAGL,KAAK,gBAAgB,EACtB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,KAAK,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;;AAIzE;;;;;GAKG;AACH,qBAAa,kBAAkB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,uBAEnD;IACC,gBAAgC,WAAW,EAAE,MAAM,CAAmB;IACtE,OAAuB,MAAM,EAAE,cAAc,CAAuC;IAEpF,mBAA4B,mBAAmB,WAAsB;IAErE;;OAEG;IACH,SAEgB,sBAAsB,EAAE,MAAM,CAAM;IAEpD;;;;;OAKG;IACH,SAEgB,QAAQ,EAAE,OAAO,CAAS;IAE1C;;;OAGG;IACH,SAA6C,IAAI,EAAE,UAAU,CAAwB;IAErF;;;;OAIG;IACH,IACW,KAAK,CAAC,KAAK,EAAE,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,EAM9C;IACD,IAAW,KAAK,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,CAM1C;IACD,OAAO,CAAC,MAAM,CAAiC;IAE/C,kDAAkD;IAClD,IAAW,IAAI,IAAI,aAAa,CAAC,CAAC,CAAC,EAAE,CAEpC;cAEkB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI;IAkC9F,OAAO,CAAC,iBAAiB;cA0BN,MAAM,IAAI,cAAc;CAU5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,eAAe,EAAE,kBAAkB,CAAC;KACrC;CACF"}
1
+ {"version":3,"file":"tag-group.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/tag/tag-group/tag-group.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAGnB,KAAK,cAAc,EACnB,KAAK,cAAc,EAEpB,MAAM,KAAK,CAAC;AAGb,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AAGzD,OAAO,EAGL,KAAK,gBAAgB,EACtB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,KAAK,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;;AAIzE;;;;;GAKG;AACH,qBAAa,kBAAkB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,uBAEnD;IACC,gBAAgC,WAAW,EAAE,MAAM,CAAmB;IACtE,OAAuB,MAAM,EAAE,cAAc,CAAuC;IAEpF,mBAA4B,mBAAmB,WAAsB;IAErE;;OAEG;IACH,SAEgB,sBAAsB,EAAE,MAAM,CAAM;IAEpD;;;;;OAKG;IACH,SAEgB,QAAQ,EAAE,OAAO,CAAS;IAE1C;;;OAGG;IACH,SAA6C,IAAI,EAAE,UAAU,CAAwB;IAErF;;;;OAIG;IACH,IACW,KAAK,CAAC,KAAK,EAAE,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,EAM9C;IACD,IAAW,KAAK,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,CAM1C;IACD,OAAO,CAAC,MAAM,CAAiC;IAE/C,kDAAkD;IAClD,IAAW,IAAI,IAAI,aAAa,CAAC,CAAC,CAAC,EAAE,CAEpC;cAEkB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI;IAkC9F,OAAO,CAAC,iBAAiB;cA0BN,MAAM,IAAI,cAAc;CAQ5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,eAAe,EAAE,kBAAkB,CAAC;KACrC;CACF"}
@@ -1,2 +1,2 @@
1
- import { t as SbbTagGroupElement } from "../../tag-group.component-B7bBirrj.js";
1
+ import { t as SbbTagGroupElement } from "../../tag-group.component-Cw46bt0E.js";
2
2
  export { SbbTagGroupElement };
@@ -1,4 +1,4 @@
1
- import { t as SbbTagGroupElement } from "../tag-group.component-B7bBirrj.js";
1
+ import { t as SbbTagGroupElement } from "../tag-group.component-Cw46bt0E.js";
2
2
  //#region src/elements/tag/tag-group.ts
3
3
  /** @entrypoint */
4
4
  SbbTagGroupElement.define();
@@ -1,4 +1,4 @@
1
- import { t as SbbTagElement } from "../tag.component-0vKnvMOm.js";
1
+ import { t as SbbTagElement } from "../tag.component-CnNPL6aI.js";
2
2
  //#region src/elements/tag/tag.ts
3
3
  /** @entrypoint */
4
4
  SbbTagElement.define();
@@ -186,12 +186,10 @@ var SbbTagGroupElement = (() => {
186
186
  }
187
187
  render() {
188
188
  return html`
189
- <div class="sbb-tag-group">
190
- ${this.renderList({
189
+ ${this.renderList({
191
190
  class: "sbb-tag-group__list",
192
191
  ariaLabel: this.listAccessibilityLabel
193
192
  })}
194
- </div>
195
193
  `;
196
194
  }
197
195
  };
@@ -199,4 +197,4 @@ var SbbTagGroupElement = (() => {
199
197
  //#endregion
200
198
  export { SbbTagGroupElement as t };
201
199
 
202
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"tag-group.component-B7bBirrj.js","names":[],"sources":["../../../src/elements/tag/tag-group/tag-group.scss?inline","../../../src/elements/tag/tag-group/tag-group.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  display: block;\n}\n\n.sbb-tag-group__list {\n  @include sbb.list-reset;\n\n  display: flex;\n  flex-wrap: wrap;\n  gap: var(--sbb-spacing-fixed-3x);\n}\n\n// Using ... li selector, because the li generation\n// is handled in the component base class.\n.sbb-tag-group__list > :is(li, span) {\n  display: flex;\n  max-width: 100%;\n}\n","import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  type PropertyValues,\n  type TemplateResult,\n  unsafeCSS,\n} from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbElement } from '../../core/base-elements.ts';\nimport { forceType } from '../../core/decorators.ts';\nimport { isLean, setOrRemoveAttribute } from '../../core/dom.ts';\nimport {\n  SbbDisabledMixin,\n  SbbNamedSlotListMixin,\n  type WithListChildren,\n} from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbTagElement, SbbTagSize } from '../tag/tag.component.ts';\n\nimport style from './tag-group.scss?inline';\n\n/**\n * It can be used as a container for one or more `sbb-tag`.\n *\n * @slot - Use the unnamed slot to add one or more 'sbb-tag' elements to the `sbb-tag-group`.\n * @overrideType value - (T = string | (string | null)[]) | null\n */\nexport class SbbTagGroupElement<T = string> extends SbbDisabledMixin(\n  SbbNamedSlotListMixin<SbbTagElement, typeof SbbElement>(SbbElement),\n) {\n  public static override readonly elementName: string = 'sbb-tag-group';\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(style)];\n  // DIV is added here due to special requirements from sbb.ch.\n  protected override readonly listChildLocalNames = ['sbb-tag', 'div'];\n\n  /**\n   * This will be forwarded as aria-label to the inner list.\n   */\n  @forceType()\n  @property({ attribute: 'list-accessibility-label' })\n  public accessor listAccessibilityLabel: string = '';\n\n  /**\n   * If set multiple to false, the selection is exclusive and the value is a string (or null).\n   * If set multiple to true, the selection can have multiple values and therefore value is an array.\n   *\n   * Changing multiple during run time is not supported.\n   */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor multiple: boolean = false;\n\n  /**\n   * Tag group size, either s or m.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true }) public accessor size: SbbTagSize = isLean() ? 's' : 'm';\n\n  /**\n   * Value of the sbb-tag-group.\n   * If set multiple to false, the value is a string (or null).\n   * If set multiple to true, the value is an array.\n   */\n  @property()\n  public set value(value: T | (T | null)[] | null) {\n    if (isServer || !this.hasUpdated) {\n      this._value = value;\n      return;\n    }\n    this._applyValueToTags(value);\n  }\n  public get value(): T | (T | null)[] | null {\n    return isServer || !this.hasUpdated\n      ? this._value\n      : this.multiple\n        ? this.tags.filter((t) => t.checked).map((t) => t.value)\n        : (this.tags.find((t) => t.checked)?.value ?? null);\n  }\n  private _value: T | (T | null)[] | null = null;\n\n  /** The child instances of sbb-tag as an array. */\n  public get tags(): SbbTagElement<T>[] {\n    return Array.from(this.querySelectorAll?.<SbbTagElement<T>>('sbb-tag') ?? []);\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<WithListChildren<this>>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('value') && !this.hasUpdated && this._value) {\n      this._applyValueToTags(this.value);\n    }\n\n    if (changedProperties.has('size')) {\n      this.tags.forEach((t) => t.requestUpdate?.('size'));\n    }\n\n    if (changedProperties.has('disabled')) {\n      this.tags.forEach((r) => r.requestUpdate?.('disabled'));\n    }\n\n    if (\n      (changedProperties.has('listChildren') || changedProperties.has('multiple')) &&\n      !this.multiple\n    ) {\n      // Ensure only one tag checked\n      this.tags\n        .filter((tag) => tag.checked)\n        .slice(1)\n        .forEach((tag) => (tag.checked = false));\n    }\n    setOrRemoveAttribute(\n      this,\n      'role',\n      changedProperties.has('listAccessibilityLabel') && this.listAccessibilityLabel\n        ? null\n        : 'group',\n    );\n  }\n\n  private _applyValueToTags(value: any): void {\n    const tags = this.tags;\n\n    if (value === null) {\n      tags.forEach((t) => (t.checked = false));\n    } else if (this.multiple) {\n      if (!Array.isArray(value) && tags.every((t) => t.value !== value)) {\n        try {\n          // If it is multiple mode and no tag matches the value, we try to parse the value as JSON.\n          // This allows server side rendering to use array values to be passed to the client side.\n          value = JSON.parse(value as string);\n        } catch {\n          /* empty */\n        }\n      }\n      const valueAsArray = Array.isArray(value) ? value : [value];\n      tags.forEach((t) => (t.checked = valueAsArray.includes(t.value)));\n    } else {\n      if (!Array.isArray(value)) {\n        tags.forEach((t) => (t.checked = t.value === value));\n      } else if (import.meta.env.DEV) {\n        console.warn('value must not be set as an array in singular mode.', value);\n      }\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-tag-group\">\n        ${this.renderList({\n          class: 'sbb-tag-group__list',\n          ariaLabel: this.listAccessibilityLabel,\n        })}\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-tag-group': SbbTagGroupElement;\n  }\n}\n"],"mappings":"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"}
200
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"tag-group.component-Cw46bt0E.js","names":[],"sources":["../../../src/elements/tag/tag-group/tag-group.scss?inline","../../../src/elements/tag/tag-group/tag-group.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  display: block;\n}\n\n.sbb-tag-group__list {\n  @include sbb.list-reset;\n\n  display: flex;\n  flex-wrap: wrap;\n  gap: var(--sbb-spacing-fixed-3x);\n}\n\n// Using ... li selector, because the li generation\n// is handled in the component base class.\n.sbb-tag-group__list > :is(li, span) {\n  display: flex;\n  max-width: 100%;\n}\n","import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  type PropertyValues,\n  type TemplateResult,\n  unsafeCSS,\n} from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbElement } from '../../core/base-elements.ts';\nimport { forceType } from '../../core/decorators.ts';\nimport { isLean, setOrRemoveAttribute } from '../../core/dom.ts';\nimport {\n  SbbDisabledMixin,\n  SbbNamedSlotListMixin,\n  type WithListChildren,\n} from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbTagElement, SbbTagSize } from '../tag/tag.component.ts';\n\nimport style from './tag-group.scss?inline';\n\n/**\n * It can be used as a container for one or more `sbb-tag`.\n *\n * @slot - Use the unnamed slot to add one or more 'sbb-tag' elements to the `sbb-tag-group`.\n * @overrideType value - (T = string | (string | null)[]) | null\n */\nexport class SbbTagGroupElement<T = string> extends SbbDisabledMixin(\n  SbbNamedSlotListMixin<SbbTagElement, typeof SbbElement>(SbbElement),\n) {\n  public static override readonly elementName: string = 'sbb-tag-group';\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(style)];\n  // DIV is added here due to special requirements from sbb.ch.\n  protected override readonly listChildLocalNames = ['sbb-tag', 'div'];\n\n  /**\n   * This will be forwarded as aria-label to the inner list.\n   */\n  @forceType()\n  @property({ attribute: 'list-accessibility-label' })\n  public accessor listAccessibilityLabel: string = '';\n\n  /**\n   * If set multiple to false, the selection is exclusive and the value is a string (or null).\n   * If set multiple to true, the selection can have multiple values and therefore value is an array.\n   *\n   * Changing multiple during run time is not supported.\n   */\n  @forceType()\n  @property({ type: Boolean })\n  public accessor multiple: boolean = false;\n\n  /**\n   * Tag group size, either s or m.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true }) public accessor size: SbbTagSize = isLean() ? 's' : 'm';\n\n  /**\n   * Value of the sbb-tag-group.\n   * If set multiple to false, the value is a string (or null).\n   * If set multiple to true, the value is an array.\n   */\n  @property()\n  public set value(value: T | (T | null)[] | null) {\n    if (isServer || !this.hasUpdated) {\n      this._value = value;\n      return;\n    }\n    this._applyValueToTags(value);\n  }\n  public get value(): T | (T | null)[] | null {\n    return isServer || !this.hasUpdated\n      ? this._value\n      : this.multiple\n        ? this.tags.filter((t) => t.checked).map((t) => t.value)\n        : (this.tags.find((t) => t.checked)?.value ?? null);\n  }\n  private _value: T | (T | null)[] | null = null;\n\n  /** The child instances of sbb-tag as an array. */\n  public get tags(): SbbTagElement<T>[] {\n    return Array.from(this.querySelectorAll?.<SbbTagElement<T>>('sbb-tag') ?? []);\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<WithListChildren<this>>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('value') && !this.hasUpdated && this._value) {\n      this._applyValueToTags(this.value);\n    }\n\n    if (changedProperties.has('size')) {\n      this.tags.forEach((t) => t.requestUpdate?.('size'));\n    }\n\n    if (changedProperties.has('disabled')) {\n      this.tags.forEach((r) => r.requestUpdate?.('disabled'));\n    }\n\n    if (\n      (changedProperties.has('listChildren') || changedProperties.has('multiple')) &&\n      !this.multiple\n    ) {\n      // Ensure only one tag checked\n      this.tags\n        .filter((tag) => tag.checked)\n        .slice(1)\n        .forEach((tag) => (tag.checked = false));\n    }\n    setOrRemoveAttribute(\n      this,\n      'role',\n      changedProperties.has('listAccessibilityLabel') && this.listAccessibilityLabel\n        ? null\n        : 'group',\n    );\n  }\n\n  private _applyValueToTags(value: any): void {\n    const tags = this.tags;\n\n    if (value === null) {\n      tags.forEach((t) => (t.checked = false));\n    } else if (this.multiple) {\n      if (!Array.isArray(value) && tags.every((t) => t.value !== value)) {\n        try {\n          // If it is multiple mode and no tag matches the value, we try to parse the value as JSON.\n          // This allows server side rendering to use array values to be passed to the client side.\n          value = JSON.parse(value as string);\n        } catch {\n          /* empty */\n        }\n      }\n      const valueAsArray = Array.isArray(value) ? value : [value];\n      tags.forEach((t) => (t.checked = valueAsArray.includes(t.value)));\n    } else {\n      if (!Array.isArray(value)) {\n        tags.forEach((t) => (t.checked = t.value === value));\n      } else if (import.meta.env.DEV) {\n        console.warn('value must not be set as an array in singular mode.', value);\n      }\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      ${this.renderList({\n        class: 'sbb-tag-group__list',\n        ariaLabel: this.listAccessibilityLabel,\n      })}\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-tag-group': SbbTagGroupElement;\n  }\n}\n"],"mappings":"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"}
@@ -0,0 +1,245 @@
1
+ import { __esDecorate, __runInitializers } from "tslib";
2
+ import { html, unsafeCSS } from "lit";
3
+ import { property } from "lit/decorators.js";
4
+ import { SbbButtonLikeBaseElement } from "./core/base-elements.js";
5
+ import { forceType, getOverride, omitEmptyConverter } from "./core/decorators.js";
6
+ import { isLean } from "./core/dom.js";
7
+ import { SbbDisabledTabIndexActionMixin } from "./core/mixins.js";
8
+ import { boxSizingStyles } from "./core/styles.js";
9
+ import { SbbIconNameMixin } from "./icon.js";
10
+ //#region src/elements/tag/tag/tag.scss?inline
11
+ var tag_default = ":host {\n --sbb-tag-animation-duration: var(\n --sbb-disable-animation-duration,\n var(--sbb-animation-duration-2x)\n );\n display: inline-block;\n max-width: 100%;\n outline: none !important;\n}\n\n:host(:is(:state(checked),[state--checked])) {\n --sbb-tag-border-color: var(--sbb-border-color-3);\n --sbb-tag-border-width: var(--sbb-border-width-2x);\n}\n@media (forced-colors: active) {\n :host(:is(:state(checked),[state--checked])) {\n --sbb-tag-border-color: Highlight !important;\n --sbb-tag-border-width: var(--sbb-border-width-4x);\n }\n}\n\n:host(:is(:disabled, [disabled-interactive])) {\n --sbb-tag-text-color: var(--sbb-color-granite);\n --sbb-tag-text-color: light-dark(var(--sbb-color-granite), var(--sbb-color-aluminium));\n --sbb-tag-amount-color: var(--sbb-tag-text-color);\n --sbb-tag-background-color: var(--sbb-background-color-3);\n --sbb-tag-border-color: var(--sbb-color-cement);\n --sbb-tag-border-color: light-dark(var(--sbb-color-cement), var(--sbb-color-smoke));\n --sbb-tag-border-style: dashed;\n --sbb-tag-cursor: unset;\n --sbb-tag-pointer-events: none;\n}\n@media (forced-colors: active) {\n :host(:is(:disabled, [disabled-interactive])) {\n --sbb-tag-text-color: GrayText;\n --sbb-tag-amount-color: GrayText;\n --sbb-tag-border-color: GrayText;\n }\n}\n\n:host(:is(:state(checked),[state--checked]):is(:disabled, [disabled-interactive])) {\n --sbb-tag-border-color: var(--sbb-color-metal);\n --sbb-tag-border-color: light-dark(var(--sbb-color-metal), var(--sbb-color-cement));\n --sbb-tag-border-style: dashed;\n}\n\n@media (any-hover: hover) {\n :host(:hover:not(:disabled, [disabled-interactive], :active, :is(:state(active),[state--active]))) {\n --sbb-tag-background-color: var(--sbb-background-color-3);\n --sbb-tag-inset: calc(var(--sbb-border-width-2x) * -1);\n --sbb-tag-content-shift: translateY(calc(var(--sbb-border-width-1x) * -1));\n }\n}\n@media (any-hover: hover) and (forced-colors: active) {\n :host(:hover:not(:disabled, [disabled-interactive], :active, :is(:state(active),[state--active]))) {\n --sbb-tag-border-color: Highlight;\n }\n}\n\n:host(:is(:active, :is(:state(active),[state--active])):not(:disabled, [disabled-interactive])) {\n --sbb-tag-background-color: var(--sbb-background-color-3);\n --sbb-tag-border-color: var(--sbb-color-iron);\n --sbb-tag-border-color: light-dark(var(--sbb-color-iron), var(--sbb-color-storm));\n --sbb-tag-border-width: var(--sbb-border-width-2x);\n --sbb-tag-text-color: var(--sbb-color-4);\n}\n@media (forced-colors: active) {\n :host(:is(:active, :is(:state(active),[state--active])):not(:disabled, [disabled-interactive])) {\n --sbb-tag-border-color: Highlight;\n --sbb-tag-text-color: ButtonText;\n }\n}\n\n:host([size=m]) {\n --sbb-tag-height: var(--sbb-size-element-xs);\n --sbb-tag-padding-inline: var(--sbb-spacing-fixed-5x);\n}\n\n:host([size=s]) {\n --sbb-tag-height: var(--sbb-size-element-xxxs);\n --sbb-tag-padding-inline: var(--sbb-spacing-fixed-3x);\n}\n\n.sbb-tag {\n position: relative;\n display: flex;\n align-items: center;\n height: var(--sbb-tag-height);\n max-width: 100%;\n font-size: var(--sbb-text-font-size-xs);\n letter-spacing: var(--sbb-typo-letter-spacing-text);\n gap: var(--sbb-tag-gap);\n padding-inline: var(--sbb-tag-padding-inline);\n cursor: var(--sbb-tag-cursor, var(--sbb-cursor-pointer));\n border-radius: var(--sbb-tag-border-radius);\n color: var(--sbb-tag-text-color);\n transition: color var(--sbb-tag-animation-duration) var(--sbb-tag-animation-easing);\n -webkit-tap-highlight-color: transparent;\n user-select: none;\n pointer-events: var(--sbb-tag-pointer-events, unset);\n}\n.sbb-tag::before {\n content: \"\";\n position: absolute;\n inset: var(--sbb-tag-inset, 0);\n background-color: var(--sbb-tag-background-color);\n border: var(--sbb-tag-border-width) var(--sbb-tag-border-style) var(--sbb-tag-border-color);\n border-radius: var(--sbb-tag-border-radius);\n transition-duration: var(--sbb-tag-animation-duration);\n transition-timing-function: var(--sbb-tag-animation-easing);\n transition-property: inset, background-color, border-color, box-shadow;\n}\n:host(:focus-visible) .sbb-tag::before {\n outline-offset: var(--sbb-focus-outline-offset);\n outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);\n}\n\n.sbb-tag__icon {\n display: flex;\n align-items: center;\n height: calc(var(--sbb-typo-line-height-text) * 1em);\n flex-shrink: 0;\n}\n:host(:not(:is(:state(slotted-icon),[state--slotted-icon]), :is(:state(has-icon-name),[state--has-icon-name]))) .sbb-tag__icon {\n display: none;\n}\n\n.sbb-tag__text {\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n font-weight: bold;\n}\n\n.sbb-tag__amount {\n color: var(--sbb-tag-amount-color);\n}\n:host(:not(:is(:state(slotted-amount),[state--slotted-amount]), [amount])) .sbb-tag__amount {\n display: none;\n}\n\n.sbb-tag--shift {\n transition: transform var(--sbb-tag-animation-duration) var(--sbb-tag-animation-easing);\n transform: var(--sbb-tag-content-shift, 0);\n will-change: transform;\n}";
12
+ //#endregion
13
+ //#region src/elements/tag/tag/tag.component.ts
14
+ /**
15
+ * It displays a selectable element which can be used as a filter.
16
+ *
17
+ * @slot - Use the unnamed slot to add content to the tag label.
18
+ * @slot icon - Use this slot to display an icon at the component start, by providing a `sbb-icon` component.
19
+ * @slot amount - Provide an amount to show it at the component end.
20
+ * @overrideType value - (T = string) | null
21
+ */
22
+ var SbbTagElement = (() => {
23
+ let _classSuper = SbbIconNameMixin(SbbDisabledTabIndexActionMixin(SbbButtonLikeBaseElement));
24
+ let _value_decorators;
25
+ let _value_initializers = [];
26
+ let _value_extraInitializers = [];
27
+ let _amount_decorators;
28
+ let _amount_initializers = [];
29
+ let _amount_extraInitializers = [];
30
+ let _checked_decorators;
31
+ let _checked_initializers = [];
32
+ let _checked_extraInitializers = [];
33
+ let _size_decorators;
34
+ let _size_initializers = [];
35
+ let _size_extraInitializers = [];
36
+ return class SbbTagElement extends _classSuper {
37
+ static {
38
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
39
+ _value_decorators = [property()];
40
+ _amount_decorators = [forceType(), property({
41
+ reflect: true,
42
+ converter: omitEmptyConverter
43
+ })];
44
+ _checked_decorators = [forceType(), property({
45
+ reflect: false,
46
+ type: Boolean
47
+ })];
48
+ _size_decorators = [property({ reflect: true }), getOverride((i, v) => i._group?.size ?? v)];
49
+ __esDecorate(this, null, _value_decorators, {
50
+ kind: "accessor",
51
+ name: "value",
52
+ static: false,
53
+ private: false,
54
+ access: {
55
+ has: (obj) => "value" in obj,
56
+ get: (obj) => obj.value,
57
+ set: (obj, value) => {
58
+ obj.value = value;
59
+ }
60
+ },
61
+ metadata: _metadata
62
+ }, _value_initializers, _value_extraInitializers);
63
+ __esDecorate(this, null, _amount_decorators, {
64
+ kind: "accessor",
65
+ name: "amount",
66
+ static: false,
67
+ private: false,
68
+ access: {
69
+ has: (obj) => "amount" in obj,
70
+ get: (obj) => obj.amount,
71
+ set: (obj, value) => {
72
+ obj.amount = value;
73
+ }
74
+ },
75
+ metadata: _metadata
76
+ }, _amount_initializers, _amount_extraInitializers);
77
+ __esDecorate(this, null, _checked_decorators, {
78
+ kind: "accessor",
79
+ name: "checked",
80
+ static: false,
81
+ private: false,
82
+ access: {
83
+ has: (obj) => "checked" in obj,
84
+ get: (obj) => obj.checked,
85
+ set: (obj, value) => {
86
+ obj.checked = value;
87
+ }
88
+ },
89
+ metadata: _metadata
90
+ }, _checked_initializers, _checked_extraInitializers);
91
+ __esDecorate(this, null, _size_decorators, {
92
+ kind: "accessor",
93
+ name: "size",
94
+ static: false,
95
+ private: false,
96
+ access: {
97
+ has: (obj) => "size" in obj,
98
+ get: (obj) => obj.size,
99
+ set: (obj, value) => {
100
+ obj.size = value;
101
+ }
102
+ },
103
+ metadata: _metadata
104
+ }, _size_initializers, _size_extraInitializers);
105
+ if (_metadata) Object.defineProperty(this, Symbol.metadata, {
106
+ enumerable: true,
107
+ configurable: true,
108
+ writable: true,
109
+ value: _metadata
110
+ });
111
+ }
112
+ static {
113
+ this.elementName = "sbb-tag";
114
+ }
115
+ static {
116
+ this.styles = [boxSizingStyles, unsafeCSS(tag_default)];
117
+ }
118
+ static {
119
+ this.events = {
120
+ input: "input",
121
+ didChange: "didChange",
122
+ change: "change"
123
+ };
124
+ }
125
+ #value_accessor_storage;
126
+ /** Value of the form element. */
127
+ get value() {
128
+ return this.#value_accessor_storage;
129
+ }
130
+ set value(value) {
131
+ this.#value_accessor_storage = value;
132
+ }
133
+ #amount_accessor_storage;
134
+ /** Amount displayed inside the tag. */
135
+ get amount() {
136
+ return this.#amount_accessor_storage;
137
+ }
138
+ set amount(value) {
139
+ this.#amount_accessor_storage = value;
140
+ }
141
+ #checked_accessor_storage;
142
+ /** Whether the tag is checked. */
143
+ get checked() {
144
+ return this.#checked_accessor_storage;
145
+ }
146
+ set checked(value) {
147
+ this.#checked_accessor_storage = value;
148
+ }
149
+ #size_accessor_storage;
150
+ /**
151
+ * Tag size, either s or m.
152
+ * @default 'm' / 's' (lean)
153
+ */
154
+ get size() {
155
+ return this.#size_accessor_storage;
156
+ }
157
+ set size(value) {
158
+ this.#size_accessor_storage = value;
159
+ }
160
+ constructor() {
161
+ super();
162
+ this.#value_accessor_storage = __runInitializers(this, _value_initializers, null);
163
+ this.#amount_accessor_storage = (__runInitializers(this, _value_extraInitializers), __runInitializers(this, _amount_initializers, ""));
164
+ this.#checked_accessor_storage = (__runInitializers(this, _amount_extraInitializers), __runInitializers(this, _checked_initializers, false));
165
+ this.#size_accessor_storage = (__runInitializers(this, _checked_extraInitializers), __runInitializers(this, _size_initializers, isLean() ? "s" : "m"));
166
+ /** Reference to the connected tag group. */
167
+ this._group = (__runInitializers(this, _size_extraInitializers), null);
168
+ this.addEventListener?.("click", () => this._handleClick());
169
+ }
170
+ connectedCallback() {
171
+ super.connectedCallback();
172
+ this._group = this.closest("sbb-tag-group");
173
+ }
174
+ isDisabledExternally() {
175
+ return this._group?.disabled ?? false;
176
+ }
177
+ /** Method triggered on button click. Inverts the checked value and emits events. */
178
+ _handleClick() {
179
+ if (this.disabled) return;
180
+ const tagGroup = this.closest("sbb-tag-group");
181
+ if (tagGroup && !tagGroup.multiple && this.checked) return;
182
+ this.checked = !this.checked;
183
+ /** The input event fires when the value has been changed as a direct result of a user action. */
184
+ this.dispatchEvent(new InputEvent("input", {
185
+ bubbles: true,
186
+ composed: true
187
+ }));
188
+ /**
189
+ * The change event is fired when the user modifies the element's value.
190
+ * Unlike the input event, the change event is not necessarily fired
191
+ * for each alteration to an element's value.
192
+ */
193
+ this.dispatchEvent(new Event("change", { bubbles: true }));
194
+ /**
195
+ * Deprecated. Mirrors change event for React. Will be removed once React properly supports change events.
196
+ * @deprecated
197
+ */
198
+ this.dispatchEvent(new Event("didChange", { bubbles: true }));
199
+ }
200
+ willUpdate(changedProperties) {
201
+ super.willUpdate(changedProperties);
202
+ if (changedProperties.has("checked")) {
203
+ this.internals.ariaPressed = `${this.checked}`;
204
+ this.toggleState("checked", this.checked);
205
+ this.updateFormValue();
206
+ }
207
+ const tagGroup = this.closest?.("sbb-tag-group");
208
+ if (tagGroup && !tagGroup.multiple && changedProperties.has("checked") && this.checked) tagGroup?.tags.filter((t) => t !== this).forEach((t) => t.checked = false);
209
+ }
210
+ /**
211
+ * @internal
212
+ */
213
+ formResetCallback() {
214
+ this.checked = this.hasAttribute("checked");
215
+ }
216
+ /**
217
+ * @internal
218
+ */
219
+ formStateRestoreCallback(state, _reason) {
220
+ if (state) this.checked = state === "true";
221
+ }
222
+ updateFormValue() {
223
+ if (this.checked) super.updateFormValue();
224
+ else this.internals.setFormValue(null);
225
+ }
226
+ formState() {
227
+ return `${this.checked}`;
228
+ }
229
+ renderTemplate() {
230
+ return html`
231
+ <span class="sbb-tag__icon sbb-tag--shift"> ${this.renderIconSlot()} </span>
232
+ <span class="sbb-tag__text sbb-tag--shift">
233
+ <slot></slot>
234
+ </span>
235
+ <span class="sbb-tag__amount sbb-tag--shift">
236
+ <slot name="amount">${this.amount}</slot>
237
+ </span>
238
+ `;
239
+ }
240
+ };
241
+ })();
242
+ //#endregion
243
+ export { SbbTagElement as t };
244
+
245
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"tag.component-CnNPL6aI.js","names":[],"sources":["../../../src/elements/tag/tag/tag.scss?inline","../../../src/elements/tag/tag/tag.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n$disabled: ':disabled, [disabled-interactive]';\n$active: ':active, :state(active)';\n\n:host {\n  --sbb-tag-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-2x)\n  );\n\n  display: inline-block;\n  max-width: 100%;\n\n  // Use !important here to not interfere with Firefox focus ring definition\n  // which appears in normalize CSS of several frameworks.\n  outline: none !important;\n}\n\n// Active state\n:host(:state(checked)) {\n  --sbb-tag-border-color: var(--sbb-border-color-3);\n  --sbb-tag-border-width: var(--sbb-border-width-2x);\n\n  @include sbb.if-forced-colors {\n    --sbb-tag-border-color: Highlight !important;\n    --sbb-tag-border-width: var(--sbb-border-width-4x);\n  }\n}\n\n:host(:is(#{$disabled})) {\n  --sbb-tag-text-color: light-dark(var(--sbb-color-granite), var(--sbb-color-aluminium));\n  --sbb-tag-amount-color: var(--sbb-tag-text-color);\n  --sbb-tag-background-color: var(--sbb-background-color-3);\n  --sbb-tag-border-color: light-dark(var(--sbb-color-cement), var(--sbb-color-smoke));\n  --sbb-tag-border-style: dashed;\n  --sbb-tag-cursor: unset;\n  --sbb-tag-pointer-events: none;\n\n  @include sbb.if-forced-colors {\n    --sbb-tag-text-color: GrayText;\n    --sbb-tag-amount-color: GrayText;\n    --sbb-tag-border-color: GrayText;\n  }\n}\n\n:host(:state(checked):is(#{$disabled})) {\n  --sbb-tag-border-color: light-dark(var(--sbb-color-metal), var(--sbb-color-cement));\n  --sbb-tag-border-style: dashed;\n}\n\n:host(:hover:not(#{$disabled}, #{$active})) {\n  @include sbb.hover-mq($hover: true) {\n    --sbb-tag-background-color: var(--sbb-background-color-3);\n    --sbb-tag-inset: calc(var(--sbb-border-width-2x) * -1);\n    --sbb-tag-content-shift: translateY(calc(var(--sbb-border-width-1x) * -1));\n\n    @include sbb.if-forced-colors {\n      --sbb-tag-border-color: Highlight;\n    }\n  }\n}\n\n// Pressed state\n:host(:is(#{$active}):not(#{$disabled})) {\n  --sbb-tag-background-color: var(--sbb-background-color-3);\n  --sbb-tag-border-color: light-dark(var(--sbb-color-iron), var(--sbb-color-storm));\n  --sbb-tag-border-width: var(--sbb-border-width-2x);\n  --sbb-tag-text-color: var(--sbb-color-4);\n\n  @include sbb.if-forced-colors {\n    --sbb-tag-border-color: Highlight;\n    --sbb-tag-text-color: ButtonText;\n  }\n}\n\n:host([size='m']) {\n  --sbb-tag-height: var(--sbb-size-element-xs);\n  --sbb-tag-padding-inline: var(--sbb-spacing-fixed-5x);\n}\n\n:host([size='s']) {\n  --sbb-tag-height: var(--sbb-size-element-xxxs);\n  --sbb-tag-padding-inline: var(--sbb-spacing-fixed-3x);\n}\n\n.sbb-tag {\n  position: relative;\n  display: flex;\n  align-items: center;\n  height: var(--sbb-tag-height);\n  max-width: 100%;\n  font-size: var(--sbb-text-font-size-xs);\n  letter-spacing: var(--sbb-typo-letter-spacing-text);\n  gap: var(--sbb-tag-gap);\n  padding-inline: var(--sbb-tag-padding-inline);\n  cursor: var(--sbb-tag-cursor, var(--sbb-cursor-pointer));\n  border-radius: var(--sbb-tag-border-radius);\n  color: var(--sbb-tag-text-color);\n  transition: color var(--sbb-tag-animation-duration) var(--sbb-tag-animation-easing);\n  -webkit-tap-highlight-color: transparent;\n  user-select: none;\n  pointer-events: var(--sbb-tag-pointer-events, unset);\n\n  &::before {\n    content: '';\n    position: absolute;\n    inset: var(--sbb-tag-inset, 0);\n    background-color: var(--sbb-tag-background-color);\n    border: var(--sbb-tag-border-width) var(--sbb-tag-border-style) var(--sbb-tag-border-color);\n    border-radius: var(--sbb-tag-border-radius);\n    transition-duration: var(--sbb-tag-animation-duration);\n    transition-timing-function: var(--sbb-tag-animation-easing);\n    transition-property: inset, background-color, border-color, box-shadow;\n\n    :host(:focus-visible) & {\n      @include sbb.focus-outline;\n    }\n  }\n}\n\n.sbb-tag__icon {\n  display: flex;\n  align-items: center;\n  height: calc(var(--sbb-typo-line-height-text) * 1em);\n  flex-shrink: 0;\n\n  :host(:not(:state(slotted-icon), :state(has-icon-name))) & {\n    display: none;\n  }\n}\n\n.sbb-tag__text {\n  @include sbb.ellipsis;\n\n  font-weight: bold;\n}\n\n.sbb-tag__amount {\n  color: var(--sbb-tag-amount-color);\n\n  :host(:not(:state(slotted-amount), [amount])) & {\n    display: none;\n  }\n}\n\n.sbb-tag--shift {\n  transition: transform var(--sbb-tag-animation-duration) var(--sbb-tag-animation-easing);\n  transform: var(--sbb-tag-content-shift, 0);\n  will-change: transform;\n}\n","import {\n  html,\n  unsafeCSS,\n  type CSSResultGroup,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbButtonLikeBaseElement } from '../../core/base-elements.ts';\nimport { forceType, getOverride, omitEmptyConverter } from '../../core/decorators.ts';\nimport { isLean } from '../../core/dom.ts';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbDisabledTabIndexActionMixin,\n} from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport { SbbIconNameMixin } from '../../icon.ts';\nimport type { SbbTagGroupElement } from '../tag-group/tag-group.component.ts';\n\nimport style from './tag.scss?inline';\n\nexport type SbbTagSize = 's' | 'm';\n\n/**\n * It displays a selectable element which can be used as a filter.\n *\n * @slot - Use the unnamed slot to add content to the tag label.\n * @slot icon - Use this slot to display an icon at the component start, by providing a `sbb-icon` component.\n * @slot amount - Provide an amount to show it at the component end.\n * @overrideType value - (T = string) | null\n */\nexport class SbbTagElement<T = string> extends SbbIconNameMixin(\n  SbbDisabledTabIndexActionMixin(SbbButtonLikeBaseElement),\n) {\n  public static override readonly elementName: string = 'sbb-tag';\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(style)];\n  public static readonly events = {\n    input: 'input',\n    didChange: 'didChange',\n    change: 'change',\n  } as const;\n\n  /** Value of the form element. */\n  @property()\n  public accessor value: T | null = null;\n\n  /** Amount displayed inside the tag. */\n  @forceType()\n  @property({ reflect: true, converter: omitEmptyConverter })\n  public accessor amount: string = '';\n\n  /** Whether the tag is checked. */\n  @forceType()\n  @property({ reflect: false, type: Boolean })\n  public accessor checked: boolean = false;\n\n  /**\n   * Tag size, either s or m.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true })\n  @getOverride((i, v) => i._group?.size ?? v)\n  public accessor size: SbbTagSize = isLean() ? 's' : 'm';\n\n  /** Reference to the connected tag group. */\n  private _group: SbbTagGroupElement | null = null;\n\n  public constructor() {\n    super();\n    this.addEventListener?.('click', () => this._handleClick());\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this._group = this.closest('sbb-tag-group') as SbbTagGroupElement;\n  }\n\n  protected override isDisabledExternally(): boolean {\n    return this._group?.disabled ?? false;\n  }\n\n  /** Method triggered on button click. Inverts the checked value and emits events. */\n  private _handleClick(): void {\n    if (this.disabled) {\n      return;\n    }\n\n    // Prevent deactivating on exclusive / radio mode\n    const tagGroup = this.closest('sbb-tag-group');\n    if (tagGroup && !tagGroup.multiple && this.checked) {\n      return;\n    }\n    this.checked = !this.checked;\n\n    /** The input event fires when the value has been changed as a direct result of a user action. */\n    this.dispatchEvent(\n      new InputEvent('input', {\n        bubbles: true,\n        composed: true,\n      }),\n    );\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     * Deprecated. Mirrors change event for React. Will be removed once React properly supports change events.\n     * @deprecated\n     */\n    this.dispatchEvent(new Event('didChange', { bubbles: true }));\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('checked')) {\n      this.internals.ariaPressed = `${this.checked}`;\n      this.toggleState('checked', this.checked);\n      this.updateFormValue();\n    }\n\n    const tagGroup = this.closest?.('sbb-tag-group');\n    if (tagGroup && !tagGroup.multiple && changedProperties.has('checked') && this.checked) {\n      tagGroup?.tags.filter((t) => t !== this).forEach((t) => (t.checked = false));\n    }\n  }\n\n  /**\n   * @internal\n   */\n  public override formResetCallback(): void {\n    this.checked = this.hasAttribute('checked');\n  }\n\n  /**\n   * @internal\n   */\n  public override formStateRestoreCallback(\n    state: FormRestoreState | null,\n    _reason: FormRestoreReason,\n  ): void {\n    if (state) {\n      this.checked = state === 'true';\n    }\n  }\n\n  protected override updateFormValue(): void {\n    if (this.checked) {\n      super.updateFormValue();\n    } else {\n      this.internals.setFormValue(null);\n    }\n  }\n\n  protected override formState(): FormRestoreState {\n    return `${this.checked}`;\n  }\n\n  protected override renderTemplate(): TemplateResult {\n    return html`\n      <span class=\"sbb-tag__icon sbb-tag--shift\"> ${this.renderIconSlot()} </span>\n      <span class=\"sbb-tag__text sbb-tag--shift\">\n        <slot></slot>\n      </span>\n      <span class=\"sbb-tag__amount sbb-tag--shift\">\n        <slot name=\"amount\">${this.amount}</slot>\n      </span>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-tag': SbbTagElement;\n  }\n}\n"],"mappings":"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"}
@@ -1,5 +1,5 @@
1
- import { t as SbbTagGroupElement } from "./tag-group.component-B7bBirrj.js";
2
- import { t as SbbTagElement } from "./tag.component-0vKnvMOm.js";
1
+ import { t as SbbTagGroupElement } from "./tag-group.component-Cw46bt0E.js";
2
+ import { t as SbbTagElement } from "./tag.component-CnNPL6aI.js";
3
3
  import "./tag.pure.js";
4
4
  //#region src/elements/tag.ts
5
5
  /** @entrypoint */
@@ -1,3 +1,3 @@
1
- import { t as SbbTagGroupElement } from "./tag-group.component-B7bBirrj.js";
2
- import { t as SbbTagElement } from "./tag.component-0vKnvMOm.js";
1
+ import { t as SbbTagGroupElement } from "./tag-group.component-Cw46bt0E.js";
2
+ import { t as SbbTagElement } from "./tag.component-CnNPL6aI.js";
3
3
  export { SbbTagElement, SbbTagGroupElement };
@@ -1827,6 +1827,17 @@ slot[name=error]::slotted(*) {
1827
1827
  --sbb-tab-label-amount-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));
1828
1828
  --sbb-tab-label-line-color: var(--sbb-border-color-4-inverted);
1829
1829
  --sbb-tab-label-cursor: var(--sbb-cursor-pointer);
1830
+ --sbb-tag-animation-easing: var(--sbb-animation-easing);
1831
+ --sbb-tag-background-color: var(--sbb-background-color-1);
1832
+ --sbb-tag-border-color: var(--sbb-border-color-4-inverted);
1833
+ --sbb-tag-border-style: solid;
1834
+ --sbb-tag-border-width: var(--sbb-border-width-1x);
1835
+ --sbb-tag-border-radius: var(--sbb-border-radius-infinity);
1836
+ --sbb-tag-gap: var(--sbb-spacing-fixed-2x);
1837
+ --sbb-tag-text-color: var(--sbb-color-2);
1838
+ --sbb-tag-amount-color: var(--sbb-color-metal);
1839
+ --sbb-tag-amount-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));
1840
+ --sbb-tag-height: var(--sbb-size-element-xs);
1830
1841
  --sbb-visual-checkbox-dimension: var(--sbb-checkbox-dimension-m);
1831
1842
  --sbb-visual-checkbox-selection-color: var(--sbb-color-primary);
1832
1843
  --sbb-visual-checkbox-selection-color-negative: var(--sbb-color-primary85);
@@ -1884,6 +1895,11 @@ slot[name=error]::slotted(*) {
1884
1895
  --sbb-slider-line-color: CanvasText;
1885
1896
  --sbb-step-label-color: ButtonText;
1886
1897
  --sbb-step-label-prefix-border-color: ButtonText;
1898
+ --sbb-tag-amount-color: ButtonText;
1899
+ --sbb-tag-background-color: Canvas !important;
1900
+ --sbb-tag-text-color: ButtonText;
1901
+ --sbb-tag-border-color: CanvasText;
1902
+ --sbb-tag-border-width: var(--sbb-border-width-2x);
1887
1903
  }
1888
1904
  }
1889
1905
  :root {
package/package.json CHANGED
@@ -1,12 +1,12 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements-dev",
3
- "version": "4.9.0-dev.1775120423",
3
+ "version": "4.9.0-dev.1775122363",
4
4
  "description": "Lyne Design System",
5
5
  "keywords": [
6
6
  "design system",
7
7
  "web components",
8
8
  "lit",
9
- "https://github.com/sbb-design-systems/lyne-components/commit/791daf9e9368915fe15c870fb048b2054b1f08f2"
9
+ "https://github.com/sbb-design-systems/lyne-components/commit/1d7d5b53274606711e17771379a5a25d3c9cc99e"
10
10
  ],
11
11
  "type": "module",
12
12
  "exports": {
package/safety-theme.css CHANGED
@@ -1827,6 +1827,17 @@ slot[name=error]::slotted(*) {
1827
1827
  --sbb-tab-label-amount-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));
1828
1828
  --sbb-tab-label-line-color: var(--sbb-border-color-4-inverted);
1829
1829
  --sbb-tab-label-cursor: var(--sbb-cursor-pointer);
1830
+ --sbb-tag-animation-easing: var(--sbb-animation-easing);
1831
+ --sbb-tag-background-color: var(--sbb-background-color-1);
1832
+ --sbb-tag-border-color: var(--sbb-border-color-4-inverted);
1833
+ --sbb-tag-border-style: solid;
1834
+ --sbb-tag-border-width: var(--sbb-border-width-1x);
1835
+ --sbb-tag-border-radius: var(--sbb-border-radius-infinity);
1836
+ --sbb-tag-gap: var(--sbb-spacing-fixed-2x);
1837
+ --sbb-tag-text-color: var(--sbb-color-2);
1838
+ --sbb-tag-amount-color: var(--sbb-color-metal);
1839
+ --sbb-tag-amount-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));
1840
+ --sbb-tag-height: var(--sbb-size-element-xs);
1830
1841
  --sbb-visual-checkbox-dimension: var(--sbb-checkbox-dimension-m);
1831
1842
  --sbb-visual-checkbox-selection-color: var(--sbb-color-primary);
1832
1843
  --sbb-visual-checkbox-selection-color-negative: var(--sbb-color-primary85);
@@ -1884,6 +1895,11 @@ slot[name=error]::slotted(*) {
1884
1895
  --sbb-slider-line-color: CanvasText;
1885
1896
  --sbb-step-label-color: ButtonText;
1886
1897
  --sbb-step-label-prefix-border-color: ButtonText;
1898
+ --sbb-tag-amount-color: ButtonText;
1899
+ --sbb-tag-background-color: Canvas !important;
1900
+ --sbb-tag-text-color: ButtonText;
1901
+ --sbb-tag-border-color: CanvasText;
1902
+ --sbb-tag-border-width: var(--sbb-border-width-2x);
1887
1903
  }
1888
1904
  }
1889
1905
  :root {
@@ -1827,6 +1827,17 @@ slot[name=error]::slotted(*) {
1827
1827
  --sbb-tab-label-amount-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));
1828
1828
  --sbb-tab-label-line-color: var(--sbb-border-color-4-inverted);
1829
1829
  --sbb-tab-label-cursor: var(--sbb-cursor-pointer);
1830
+ --sbb-tag-animation-easing: var(--sbb-animation-easing);
1831
+ --sbb-tag-background-color: var(--sbb-background-color-1);
1832
+ --sbb-tag-border-color: var(--sbb-border-color-4-inverted);
1833
+ --sbb-tag-border-style: solid;
1834
+ --sbb-tag-border-width: var(--sbb-border-width-1x);
1835
+ --sbb-tag-border-radius: var(--sbb-border-radius-infinity);
1836
+ --sbb-tag-gap: var(--sbb-spacing-fixed-2x);
1837
+ --sbb-tag-text-color: var(--sbb-color-2);
1838
+ --sbb-tag-amount-color: var(--sbb-color-metal);
1839
+ --sbb-tag-amount-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));
1840
+ --sbb-tag-height: var(--sbb-size-element-xs);
1830
1841
  --sbb-visual-checkbox-dimension: var(--sbb-checkbox-dimension-m);
1831
1842
  --sbb-visual-checkbox-selection-color: var(--sbb-color-primary);
1832
1843
  --sbb-visual-checkbox-selection-color-negative: var(--sbb-color-primary85);
@@ -1884,6 +1895,11 @@ slot[name=error]::slotted(*) {
1884
1895
  --sbb-slider-line-color: CanvasText;
1885
1896
  --sbb-step-label-color: ButtonText;
1886
1897
  --sbb-step-label-prefix-border-color: ButtonText;
1898
+ --sbb-tag-amount-color: ButtonText;
1899
+ --sbb-tag-background-color: Canvas !important;
1900
+ --sbb-tag-text-color: ButtonText;
1901
+ --sbb-tag-border-color: CanvasText;
1902
+ --sbb-tag-border-width: var(--sbb-border-width-2x);
1887
1903
  }
1888
1904
  }
1889
1905
  :root {
@@ -1,2 +1,2 @@
1
- import { t as e } from "../../tag.component-C3ogN9Th.js";
1
+ import { t as e } from "../../tag.component-CzYJZuFT.js";
2
2
  export { e as SbbTagElement };
@@ -1,2 +1,2 @@
1
- import { t as e } from "../../tag-group.component-DyEB8c6w.js";
1
+ import { t as e } from "../../tag-group.component-DkQVBbQY.js";
2
2
  export { e as SbbTagGroupElement };
package/tag/tag-group.js CHANGED
@@ -1,4 +1,4 @@
1
- import { t as e } from "../tag-group.component-DyEB8c6w.js";
1
+ import { t as e } from "../tag-group.component-DkQVBbQY.js";
2
2
  e.define(), console.warn("The entrypoint '@sbb-esta/elements/tag/tag-group.js' has been deprecated.\nUse either '@sbb-esta/elements/tag.js' or '@sbb-esta/elements/tag.pure.js' instead.");
3
3
  //#endregion
4
4
  export { e as SbbTagGroupElement };
package/tag/tag.js CHANGED
@@ -1,4 +1,4 @@
1
- import { t as e } from "../tag.component-C3ogN9Th.js";
1
+ import { t as e } from "../tag.component-CzYJZuFT.js";
2
2
  e.define(), console.warn("The entrypoint '@sbb-esta/elements/tag/tag.js' has been deprecated.\nUse either '@sbb-esta/elements/tag.js' or '@sbb-esta/elements/tag.pure.js' instead.");
3
3
  //#endregion
4
4
  export { e as SbbTagElement };
@@ -129,12 +129,10 @@ var p = ":host{display:block}.sbb-tag-group__list{list-style:none;margin:0;paddi
129
129
  }
130
130
  render() {
131
131
  return n`
132
- <div class="sbb-tag-group">
133
- ${this.renderList({
132
+ ${this.renderList({
134
133
  class: "sbb-tag-group__list",
135
134
  ariaLabel: this.listAccessibilityLabel
136
135
  })}
137
- </div>
138
136
  `;
139
137
  }
140
138
  };
@@ -0,0 +1,170 @@
1
+ import { __esDecorate as e, __runInitializers as t } from "tslib";
2
+ import { html as n, unsafeCSS as r } from "lit";
3
+ import { property as i } from "lit/decorators.js";
4
+ import { SbbButtonLikeBaseElement as a } from "./core/base-elements.js";
5
+ import { forceType as o, getOverride as s, omitEmptyConverter as c } from "./core/decorators.js";
6
+ import { isLean as l } from "./core/dom.js";
7
+ import { SbbDisabledTabIndexActionMixin as u } from "./core/mixins.js";
8
+ import { boxSizingStyles as d } from "./core/styles.js";
9
+ import { SbbIconNameMixin as f } from "./icon.js";
10
+ //#region src/elements/tag/tag/tag.scss?inline
11
+ var p = ":host{--sbb-tag-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-2x) );display:inline-block;max-width:100%;outline:none!important}:host(:is(:state(checked),[state--checked])){--sbb-tag-border-color: var(--sbb-border-color-3);--sbb-tag-border-width: var(--sbb-border-width-2x)}@media(forced-colors:active){:host(:is(:state(checked),[state--checked])){--sbb-tag-border-color: Highlight !important;--sbb-tag-border-width: var(--sbb-border-width-4x)}}:host(:is(:disabled,[disabled-interactive])){--sbb-tag-text-color: var(--sbb-color-granite);--sbb-tag-text-color: light-dark(var(--sbb-color-granite), var(--sbb-color-aluminium));--sbb-tag-amount-color: var(--sbb-tag-text-color);--sbb-tag-background-color: var(--sbb-background-color-3);--sbb-tag-border-color: var(--sbb-color-cement);--sbb-tag-border-color: light-dark(var(--sbb-color-cement), var(--sbb-color-smoke));--sbb-tag-border-style: dashed;--sbb-tag-cursor: unset;--sbb-tag-pointer-events: none}@media(forced-colors:active){:host(:is(:disabled,[disabled-interactive])){--sbb-tag-text-color: GrayText;--sbb-tag-amount-color: GrayText;--sbb-tag-border-color: GrayText}}:host(:is(:state(checked),[state--checked]):is(:disabled,[disabled-interactive])){--sbb-tag-border-color: var(--sbb-color-metal);--sbb-tag-border-color: light-dark(var(--sbb-color-metal), var(--sbb-color-cement));--sbb-tag-border-style: dashed}@media(any-hover:hover){:host(:hover:not(:disabled,[disabled-interactive],:active,:is(:state(active),[state--active]))){--sbb-tag-background-color: var(--sbb-background-color-3);--sbb-tag-inset: calc(var(--sbb-border-width-2x) * -1);--sbb-tag-content-shift: translateY(calc(var(--sbb-border-width-1x) * -1))}}@media(any-hover:hover)and (forced-colors:active){:host(:hover:not(:disabled,[disabled-interactive],:active,:is(:state(active),[state--active]))){--sbb-tag-border-color: Highlight}}:host(:is(:active,:is(:state(active),[state--active])):not(:disabled,[disabled-interactive])){--sbb-tag-background-color: var(--sbb-background-color-3);--sbb-tag-border-color: var(--sbb-color-iron);--sbb-tag-border-color: light-dark(var(--sbb-color-iron), var(--sbb-color-storm));--sbb-tag-border-width: var(--sbb-border-width-2x);--sbb-tag-text-color: var(--sbb-color-4)}@media(forced-colors:active){:host(:is(:active,:is(:state(active),[state--active])):not(:disabled,[disabled-interactive])){--sbb-tag-border-color: Highlight;--sbb-tag-text-color: ButtonText}}:host([size=m]){--sbb-tag-height: var(--sbb-size-element-xs);--sbb-tag-padding-inline: var(--sbb-spacing-fixed-5x)}:host([size=s]){--sbb-tag-height: var(--sbb-size-element-xxxs);--sbb-tag-padding-inline: var(--sbb-spacing-fixed-3x)}.sbb-tag{position:relative;display:flex;align-items:center;height:var(--sbb-tag-height);max-width:100%;font-size:var(--sbb-text-font-size-xs);letter-spacing:var(--sbb-typo-letter-spacing-text);gap:var(--sbb-tag-gap);padding-inline:var(--sbb-tag-padding-inline);cursor:var(--sbb-tag-cursor, var(--sbb-cursor-pointer));border-radius:var(--sbb-tag-border-radius);color:var(--sbb-tag-text-color);transition:color var(--sbb-tag-animation-duration) var(--sbb-tag-animation-easing);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;pointer-events:var(--sbb-tag-pointer-events, unset)}.sbb-tag:before{content:\"\";position:absolute;inset:var(--sbb-tag-inset, 0);background-color:var(--sbb-tag-background-color);border:var(--sbb-tag-border-width) var(--sbb-tag-border-style) var(--sbb-tag-border-color);border-radius:var(--sbb-tag-border-radius);transition-duration:var(--sbb-tag-animation-duration);transition-timing-function:var(--sbb-tag-animation-easing);transition-property:inset,background-color,border-color,box-shadow}:host(:focus-visible) .sbb-tag:before{outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width)}.sbb-tag__icon{display:flex;align-items:center;height:calc(var(--sbb-typo-line-height-text) * 1em);flex-shrink:0}:host(:not(:is(:state(slotted-icon),[state--slotted-icon]),:is(:state(has-icon-name),[state--has-icon-name]))) .sbb-tag__icon{display:none}.sbb-tag__text{overflow:hidden;white-space:nowrap;text-overflow:ellipsis;font-weight:700}.sbb-tag__amount{color:var(--sbb-tag-amount-color)}:host(:not(:is(:state(slotted-amount),[state--slotted-amount]),[amount])) .sbb-tag__amount{display:none}.sbb-tag--shift{transition:transform var(--sbb-tag-animation-duration) var(--sbb-tag-animation-easing);transform:var(--sbb-tag-content-shift, 0);will-change:transform}", m = (() => {
12
+ let m = f(u(a)), h, g = [], _ = [], v, y = [], b = [], x, S = [], C = [], w, T = [], E = [];
13
+ return class extends m {
14
+ static {
15
+ let t = typeof Symbol == "function" && Symbol.metadata ? Object.create(m[Symbol.metadata] ?? null) : void 0;
16
+ h = [i()], v = [o(), i({
17
+ reflect: !0,
18
+ converter: c
19
+ })], x = [o(), i({
20
+ reflect: !1,
21
+ type: Boolean
22
+ })], w = [i({ reflect: !0 }), s((e, t) => e._group?.size ?? t)], e(this, null, h, {
23
+ kind: "accessor",
24
+ name: "value",
25
+ static: !1,
26
+ private: !1,
27
+ access: {
28
+ has: (e) => "value" in e,
29
+ get: (e) => e.value,
30
+ set: (e, t) => {
31
+ e.value = t;
32
+ }
33
+ },
34
+ metadata: t
35
+ }, g, _), e(this, null, v, {
36
+ kind: "accessor",
37
+ name: "amount",
38
+ static: !1,
39
+ private: !1,
40
+ access: {
41
+ has: (e) => "amount" in e,
42
+ get: (e) => e.amount,
43
+ set: (e, t) => {
44
+ e.amount = t;
45
+ }
46
+ },
47
+ metadata: t
48
+ }, y, b), e(this, null, x, {
49
+ kind: "accessor",
50
+ name: "checked",
51
+ static: !1,
52
+ private: !1,
53
+ access: {
54
+ has: (e) => "checked" in e,
55
+ get: (e) => e.checked,
56
+ set: (e, t) => {
57
+ e.checked = t;
58
+ }
59
+ },
60
+ metadata: t
61
+ }, S, C), e(this, null, w, {
62
+ kind: "accessor",
63
+ name: "size",
64
+ static: !1,
65
+ private: !1,
66
+ access: {
67
+ has: (e) => "size" in e,
68
+ get: (e) => e.size,
69
+ set: (e, t) => {
70
+ e.size = t;
71
+ }
72
+ },
73
+ metadata: t
74
+ }, T, E), t && Object.defineProperty(this, Symbol.metadata, {
75
+ enumerable: !0,
76
+ configurable: !0,
77
+ writable: !0,
78
+ value: t
79
+ });
80
+ }
81
+ static {
82
+ this.elementName = "sbb-tag";
83
+ }
84
+ static {
85
+ this.styles = [d, r(p)];
86
+ }
87
+ static {
88
+ this.events = {
89
+ input: "input",
90
+ didChange: "didChange",
91
+ change: "change"
92
+ };
93
+ }
94
+ #e;
95
+ get value() {
96
+ return this.#e;
97
+ }
98
+ set value(e) {
99
+ this.#e = e;
100
+ }
101
+ #t;
102
+ get amount() {
103
+ return this.#t;
104
+ }
105
+ set amount(e) {
106
+ this.#t = e;
107
+ }
108
+ #n;
109
+ get checked() {
110
+ return this.#n;
111
+ }
112
+ set checked(e) {
113
+ this.#n = e;
114
+ }
115
+ #r;
116
+ get size() {
117
+ return this.#r;
118
+ }
119
+ set size(e) {
120
+ this.#r = e;
121
+ }
122
+ constructor() {
123
+ super(), this.#e = t(this, g, null), this.#t = (t(this, _), t(this, y, "")), this.#n = (t(this, b), t(this, S, !1)), this.#r = (t(this, C), t(this, T, l() ? "s" : "m")), this._group = (t(this, E), null), this.addEventListener?.("click", () => this._handleClick());
124
+ }
125
+ connectedCallback() {
126
+ super.connectedCallback(), this._group = this.closest("sbb-tag-group");
127
+ }
128
+ isDisabledExternally() {
129
+ return this._group?.disabled ?? !1;
130
+ }
131
+ _handleClick() {
132
+ if (this.disabled) return;
133
+ let e = this.closest("sbb-tag-group");
134
+ e && !e.multiple && this.checked || (this.checked = !this.checked, this.dispatchEvent(new InputEvent("input", {
135
+ bubbles: !0,
136
+ composed: !0
137
+ })), this.dispatchEvent(new Event("change", { bubbles: !0 })), this.dispatchEvent(new Event("didChange", { bubbles: !0 })));
138
+ }
139
+ willUpdate(e) {
140
+ super.willUpdate(e), e.has("checked") && (this.internals.ariaPressed = `${this.checked}`, this.toggleState("checked", this.checked), this.updateFormValue());
141
+ let t = this.closest?.("sbb-tag-group");
142
+ t && !t.multiple && e.has("checked") && this.checked && t?.tags.filter((e) => e !== this).forEach((e) => e.checked = !1);
143
+ }
144
+ formResetCallback() {
145
+ this.checked = this.hasAttribute("checked");
146
+ }
147
+ formStateRestoreCallback(e, t) {
148
+ e && (this.checked = e === "true");
149
+ }
150
+ updateFormValue() {
151
+ this.checked ? super.updateFormValue() : this.internals.setFormValue(null);
152
+ }
153
+ formState() {
154
+ return `${this.checked}`;
155
+ }
156
+ renderTemplate() {
157
+ return n`
158
+ <span class="sbb-tag__icon sbb-tag--shift"> ${this.renderIconSlot()} </span>
159
+ <span class="sbb-tag__text sbb-tag--shift">
160
+ <slot></slot>
161
+ </span>
162
+ <span class="sbb-tag__amount sbb-tag--shift">
163
+ <slot name="amount">${this.amount}</slot>
164
+ </span>
165
+ `;
166
+ }
167
+ };
168
+ })();
169
+ //#endregion
170
+ export { m as t };
package/tag.js CHANGED
@@ -1,5 +1,5 @@
1
- import { t as e } from "./tag-group.component-DyEB8c6w.js";
2
- import { t } from "./tag.component-C3ogN9Th.js";
1
+ import { t as e } from "./tag-group.component-DkQVBbQY.js";
2
+ import { t } from "./tag.component-CzYJZuFT.js";
3
3
  import "./tag.pure.js";
4
4
  t.define(), e.define();
5
5
  //#endregion
package/tag.pure.js CHANGED
@@ -1,3 +1,3 @@
1
- import { t as e } from "./tag-group.component-DyEB8c6w.js";
2
- import { t } from "./tag.component-C3ogN9Th.js";
1
+ import { t as e } from "./tag-group.component-DkQVBbQY.js";
2
+ import { t } from "./tag.component-CzYJZuFT.js";
3
3
  export { t as SbbTagElement, e as SbbTagGroupElement };
@@ -1,245 +0,0 @@
1
- import { __esDecorate, __runInitializers } from "tslib";
2
- import { html, unsafeCSS } from "lit";
3
- import { property } from "lit/decorators.js";
4
- import { SbbButtonLikeBaseElement } from "./core/base-elements.js";
5
- import { forceType, getOverride, omitEmptyConverter } from "./core/decorators.js";
6
- import { isLean } from "./core/dom.js";
7
- import { SbbDisabledTabIndexActionMixin } from "./core/mixins.js";
8
- import { boxSizingStyles } from "./core/styles.js";
9
- import { SbbIconNameMixin } from "./icon.js";
10
- //#region src/elements/tag/tag/tag.scss?inline
11
- var tag_default = ":host {\n display: inline-block;\n outline: none !important;\n max-width: 100%;\n --sbb-tag-border-radius: var(--sbb-border-radius-infinity);\n --sbb-tag-background-color: var(--sbb-background-color-1);\n --sbb-tag-border-color: var(--sbb-border-color-4-inverted);\n --sbb-tag-border-style: solid;\n --sbb-tag-border-width: var(--sbb-border-width-1x);\n --sbb-tag-text-color: var(--sbb-color-2);\n --sbb-tag-amount-color: var(--sbb-color-metal);\n --sbb-tag-amount-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));\n --sbb-tag-height: var(--sbb-size-element-xs);\n --sbb-tag-inset: 0;\n --sbb-tag-cursor: var(--sbb-cursor-pointer);\n --sbb-tag-content-shift: translateY(0);\n --sbb-tag-animation-duration: var(\n --sbb-disable-animation-duration,\n var(--sbb-animation-duration-2x)\n );\n --sbb-tag-animation-easing: var(--sbb-animation-easing);\n --sbb-tag-padding-inline: var(--sbb-spacing-fixed-5x);\n --sbb-tag-gap: var(--sbb-spacing-fixed-2x);\n}\n@media (forced-colors: active) {\n :host {\n --sbb-tag-background-color: Canvas !important;\n --sbb-tag-text-color: ButtonText;\n --sbb-tag-amount-color: ButtonText;\n --sbb-tag-border-color: CanvasText;\n --sbb-tag-border-width: var(--sbb-border-width-2x);\n }\n}\n\n:host(:is(:state(checked),[state--checked])) {\n --sbb-tag-border-color: var(--sbb-border-color-3);\n --sbb-tag-border-width: var(--sbb-border-width-2x);\n}\n@media (forced-colors: active) {\n :host(:is(:state(checked),[state--checked])) {\n --sbb-tag-border-color: Highlight !important;\n --sbb-tag-border-width: var(--sbb-border-width-4x);\n }\n}\n\n:host(:is(:disabled, [disabled-interactive])) {\n --sbb-tag-text-color: var(--sbb-color-granite);\n --sbb-tag-text-color: light-dark(var(--sbb-color-granite), var(--sbb-color-aluminium));\n --sbb-tag-amount-color: var(--sbb-tag-text-color);\n --sbb-tag-background-color: var(--sbb-background-color-3);\n --sbb-tag-border-color: var(--sbb-color-cement);\n --sbb-tag-border-color: light-dark(var(--sbb-color-cement), var(--sbb-color-smoke));\n --sbb-tag-border-style: dashed;\n --sbb-tag-cursor: unset;\n --sbb-tag-pointer-events: none;\n}\n@media (forced-colors: active) {\n :host(:is(:disabled, [disabled-interactive])) {\n --sbb-tag-text-color: GrayText;\n --sbb-tag-amount-color: GrayText;\n --sbb-tag-border-color: GrayText;\n }\n}\n\n:host(:is(:state(checked),[state--checked]):is(:disabled, [disabled-interactive])) {\n --sbb-tag-border-color: var(--sbb-color-metal);\n --sbb-tag-border-color: light-dark(var(--sbb-color-metal), var(--sbb-color-cement));\n --sbb-tag-border-style: dashed;\n}\n\n@media (any-hover: hover) {\n :host(:hover:not(:disabled, [disabled-interactive], :active, :is(:state(active),[state--active]))) {\n --sbb-tag-background-color: var(--sbb-background-color-3);\n --sbb-tag-inset: calc(var(--sbb-border-width-2x) * -1);\n --sbb-tag-content-shift: translateY(calc(var(--sbb-border-width-1x) * -1));\n }\n}\n@media (any-hover: hover) and (forced-colors: active) {\n :host(:hover:not(:disabled, [disabled-interactive], :active, :is(:state(active),[state--active]))) {\n --sbb-tag-border-color: Highlight;\n }\n}\n\n:host(:is(:active, :is(:state(active),[state--active])):not(:disabled, [disabled-interactive])) {\n --sbb-tag-background-color: var(--sbb-background-color-3);\n --sbb-tag-border-color: var(--sbb-color-iron);\n --sbb-tag-border-color: light-dark(var(--sbb-color-iron), var(--sbb-color-storm));\n --sbb-tag-border-width: var(--sbb-border-width-2x);\n --sbb-tag-text-color: var(--sbb-color-4);\n}\n@media (forced-colors: active) {\n :host(:is(:active, :is(:state(active),[state--active])):not(:disabled, [disabled-interactive])) {\n --sbb-tag-border-color: Highlight;\n --sbb-tag-text-color: ButtonText;\n }\n}\n\n:host([size=s]) {\n --sbb-tag-height: var(--sbb-size-element-xxxs);\n --sbb-tag-padding-inline: var(--sbb-spacing-fixed-3x);\n}\n\n.sbb-tag {\n --sbb-text-font-size: var(--sbb-text-font-size-xs);\n font-family: var(--sbb-typo-font-family);\n font-weight: normal;\n line-height: var(--sbb-typo-line-height-text);\n letter-spacing: var(--sbb-typo-letter-spacing-text);\n font-size: var(--sbb-text-font-size);\n font-weight: bold;\n position: relative;\n display: flex;\n align-items: center;\n height: var(--sbb-tag-height);\n max-width: 100%;\n gap: var(--sbb-tag-gap);\n padding-inline: var(--sbb-tag-padding-inline);\n cursor: var(--sbb-tag-cursor);\n border-radius: var(--sbb-tag-border-radius);\n color: var(--sbb-tag-text-color);\n transition: color var(--sbb-tag-animation-duration) var(--sbb-tag-animation-easing);\n -webkit-tap-highlight-color: transparent;\n user-select: none;\n pointer-events: var(--sbb-tag-pointer-events, unset);\n}\n.sbb-tag::before {\n content: \"\";\n position: absolute;\n inset: var(--sbb-tag-inset);\n background-color: var(--sbb-tag-background-color);\n border: var(--sbb-tag-border-width) var(--sbb-tag-border-style) var(--sbb-tag-border-color);\n border-radius: var(--sbb-tag-border-radius);\n transition-duration: var(--sbb-tag-animation-duration);\n transition-timing-function: var(--sbb-tag-animation-easing);\n transition-property: inset, background-color, border-color, box-shadow;\n}\n:host(:focus-visible) .sbb-tag::before {\n outline-offset: var(--sbb-focus-outline-offset);\n outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);\n}\n\n.sbb-tag__icon {\n display: flex;\n align-items: center;\n height: calc(var(--sbb-typo-line-height-text) * 1em);\n flex-shrink: 0;\n}\n:host(:not(:is(:state(slotted-icon),[state--slotted-icon]), :is(:state(has-icon-name),[state--has-icon-name]))) .sbb-tag__icon {\n display: none;\n}\n\n.sbb-tag__text {\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n}\n\n.sbb-tag__amount {\n --sbb-text-font-size: var(--sbb-text-font-size-xs);\n font-family: var(--sbb-typo-font-family);\n font-weight: normal;\n line-height: var(--sbb-typo-line-height-text);\n letter-spacing: var(--sbb-typo-letter-spacing-text);\n font-size: var(--sbb-text-font-size);\n color: var(--sbb-tag-amount-color);\n}\n:host(:not(:is(:state(slotted-amount),[state--slotted-amount]), [amount])) .sbb-tag__amount {\n display: none;\n}\n\n.sbb-tag--shift {\n transition: transform var(--sbb-tag-animation-duration) var(--sbb-tag-animation-easing);\n transform: var(--sbb-tag-content-shift);\n will-change: transform;\n}";
12
- //#endregion
13
- //#region src/elements/tag/tag/tag.component.ts
14
- /**
15
- * It displays a selectable element which can be used as a filter.
16
- *
17
- * @slot - Use the unnamed slot to add content to the tag label.
18
- * @slot icon - Use this slot to display an icon at the component start, by providing a `sbb-icon` component.
19
- * @slot amount - Provide an amount to show it at the component end.
20
- * @overrideType value - (T = string) | null
21
- */
22
- var SbbTagElement = (() => {
23
- let _classSuper = SbbIconNameMixin(SbbDisabledTabIndexActionMixin(SbbButtonLikeBaseElement));
24
- let _value_decorators;
25
- let _value_initializers = [];
26
- let _value_extraInitializers = [];
27
- let _amount_decorators;
28
- let _amount_initializers = [];
29
- let _amount_extraInitializers = [];
30
- let _checked_decorators;
31
- let _checked_initializers = [];
32
- let _checked_extraInitializers = [];
33
- let _size_decorators;
34
- let _size_initializers = [];
35
- let _size_extraInitializers = [];
36
- return class SbbTagElement extends _classSuper {
37
- static {
38
- const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
39
- _value_decorators = [property()];
40
- _amount_decorators = [forceType(), property({
41
- reflect: true,
42
- converter: omitEmptyConverter
43
- })];
44
- _checked_decorators = [forceType(), property({
45
- reflect: false,
46
- type: Boolean
47
- })];
48
- _size_decorators = [property({ reflect: true }), getOverride((i, v) => i._group?.size ?? v)];
49
- __esDecorate(this, null, _value_decorators, {
50
- kind: "accessor",
51
- name: "value",
52
- static: false,
53
- private: false,
54
- access: {
55
- has: (obj) => "value" in obj,
56
- get: (obj) => obj.value,
57
- set: (obj, value) => {
58
- obj.value = value;
59
- }
60
- },
61
- metadata: _metadata
62
- }, _value_initializers, _value_extraInitializers);
63
- __esDecorate(this, null, _amount_decorators, {
64
- kind: "accessor",
65
- name: "amount",
66
- static: false,
67
- private: false,
68
- access: {
69
- has: (obj) => "amount" in obj,
70
- get: (obj) => obj.amount,
71
- set: (obj, value) => {
72
- obj.amount = value;
73
- }
74
- },
75
- metadata: _metadata
76
- }, _amount_initializers, _amount_extraInitializers);
77
- __esDecorate(this, null, _checked_decorators, {
78
- kind: "accessor",
79
- name: "checked",
80
- static: false,
81
- private: false,
82
- access: {
83
- has: (obj) => "checked" in obj,
84
- get: (obj) => obj.checked,
85
- set: (obj, value) => {
86
- obj.checked = value;
87
- }
88
- },
89
- metadata: _metadata
90
- }, _checked_initializers, _checked_extraInitializers);
91
- __esDecorate(this, null, _size_decorators, {
92
- kind: "accessor",
93
- name: "size",
94
- static: false,
95
- private: false,
96
- access: {
97
- has: (obj) => "size" in obj,
98
- get: (obj) => obj.size,
99
- set: (obj, value) => {
100
- obj.size = value;
101
- }
102
- },
103
- metadata: _metadata
104
- }, _size_initializers, _size_extraInitializers);
105
- if (_metadata) Object.defineProperty(this, Symbol.metadata, {
106
- enumerable: true,
107
- configurable: true,
108
- writable: true,
109
- value: _metadata
110
- });
111
- }
112
- static {
113
- this.elementName = "sbb-tag";
114
- }
115
- static {
116
- this.styles = [boxSizingStyles, unsafeCSS(tag_default)];
117
- }
118
- static {
119
- this.events = {
120
- input: "input",
121
- didChange: "didChange",
122
- change: "change"
123
- };
124
- }
125
- #value_accessor_storage;
126
- /** Value of the form element. */
127
- get value() {
128
- return this.#value_accessor_storage;
129
- }
130
- set value(value) {
131
- this.#value_accessor_storage = value;
132
- }
133
- #amount_accessor_storage;
134
- /** Amount displayed inside the tag. */
135
- get amount() {
136
- return this.#amount_accessor_storage;
137
- }
138
- set amount(value) {
139
- this.#amount_accessor_storage = value;
140
- }
141
- #checked_accessor_storage;
142
- /** Whether the tag is checked. */
143
- get checked() {
144
- return this.#checked_accessor_storage;
145
- }
146
- set checked(value) {
147
- this.#checked_accessor_storage = value;
148
- }
149
- #size_accessor_storage;
150
- /**
151
- * Tag size, either s or m.
152
- * @default 'm' / 's' (lean)
153
- */
154
- get size() {
155
- return this.#size_accessor_storage;
156
- }
157
- set size(value) {
158
- this.#size_accessor_storage = value;
159
- }
160
- constructor() {
161
- super();
162
- this.#value_accessor_storage = __runInitializers(this, _value_initializers, null);
163
- this.#amount_accessor_storage = (__runInitializers(this, _value_extraInitializers), __runInitializers(this, _amount_initializers, ""));
164
- this.#checked_accessor_storage = (__runInitializers(this, _amount_extraInitializers), __runInitializers(this, _checked_initializers, false));
165
- this.#size_accessor_storage = (__runInitializers(this, _checked_extraInitializers), __runInitializers(this, _size_initializers, isLean() ? "s" : "m"));
166
- /** Reference to the connected tag group. */
167
- this._group = (__runInitializers(this, _size_extraInitializers), null);
168
- this.addEventListener?.("click", () => this._handleClick());
169
- }
170
- connectedCallback() {
171
- super.connectedCallback();
172
- this._group = this.closest("sbb-tag-group");
173
- }
174
- isDisabledExternally() {
175
- return this._group?.disabled ?? false;
176
- }
177
- /** Method triggered on button click. Inverts the checked value and emits events. */
178
- _handleClick() {
179
- if (this.disabled) return;
180
- const tagGroup = this.closest("sbb-tag-group");
181
- if (tagGroup && !tagGroup.multiple && this.checked) return;
182
- this.checked = !this.checked;
183
- /** The input event fires when the value has been changed as a direct result of a user action. */
184
- this.dispatchEvent(new InputEvent("input", {
185
- bubbles: true,
186
- composed: true
187
- }));
188
- /**
189
- * The change event is fired when the user modifies the element's value.
190
- * Unlike the input event, the change event is not necessarily fired
191
- * for each alteration to an element's value.
192
- */
193
- this.dispatchEvent(new Event("change", { bubbles: true }));
194
- /**
195
- * Deprecated. Mirrors change event for React. Will be removed once React properly supports change events.
196
- * @deprecated
197
- */
198
- this.dispatchEvent(new Event("didChange", { bubbles: true }));
199
- }
200
- willUpdate(changedProperties) {
201
- super.willUpdate(changedProperties);
202
- if (changedProperties.has("checked")) {
203
- this.internals.ariaPressed = `${this.checked}`;
204
- this.toggleState("checked", this.checked);
205
- this.updateFormValue();
206
- }
207
- const tagGroup = this.closest?.("sbb-tag-group");
208
- if (tagGroup && !tagGroup.multiple && changedProperties.has("checked") && this.checked) tagGroup?.tags.filter((t) => t !== this).forEach((t) => t.checked = false);
209
- }
210
- /**
211
- * @internal
212
- */
213
- formResetCallback() {
214
- this.checked = this.hasAttribute("checked");
215
- }
216
- /**
217
- * @internal
218
- */
219
- formStateRestoreCallback(state, _reason) {
220
- if (state) this.checked = state === "true";
221
- }
222
- updateFormValue() {
223
- if (this.checked) super.updateFormValue();
224
- else this.internals.setFormValue(null);
225
- }
226
- formState() {
227
- return `${this.checked}`;
228
- }
229
- renderTemplate() {
230
- return html`
231
- <span class="sbb-tag__icon sbb-tag--shift"> ${this.renderIconSlot()} </span>
232
- <span class="sbb-tag__text sbb-tag--shift">
233
- <slot></slot>
234
- </span>
235
- <span class="sbb-tag__amount sbb-tag--shift">
236
- <slot name="amount">${this.amount}</slot>
237
- </span>
238
- `;
239
- }
240
- };
241
- })();
242
- //#endregion
243
- export { SbbTagElement as t };
244
-
245
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"tag.component-0vKnvMOm.js","names":[],"sources":["../../../src/elements/tag/tag/tag.scss?inline","../../../src/elements/tag/tag/tag.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n$disabled: ':disabled, [disabled-interactive]';\n$active: ':active, :state(active)';\n\n:host {\n  display: inline-block;\n\n  // Use !important here to not interfere with Firefox focus ring definition\n  // which appears in normalize CSS of several frameworks.\n  outline: none !important;\n  max-width: 100%;\n\n  --sbb-tag-border-radius: var(--sbb-border-radius-infinity);\n  --sbb-tag-background-color: var(--sbb-background-color-1);\n  --sbb-tag-border-color: var(--sbb-border-color-4-inverted);\n  --sbb-tag-border-style: solid;\n  --sbb-tag-border-width: var(--sbb-border-width-1x);\n  --sbb-tag-text-color: var(--sbb-color-2);\n  --sbb-tag-amount-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));\n  --sbb-tag-height: var(--sbb-size-element-xs);\n  --sbb-tag-inset: 0;\n  --sbb-tag-cursor: var(--sbb-cursor-pointer);\n  --sbb-tag-content-shift: translateY(0);\n  --sbb-tag-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-2x)\n  );\n  --sbb-tag-animation-easing: var(--sbb-animation-easing);\n  --sbb-tag-padding-inline: var(--sbb-spacing-fixed-5x);\n  --sbb-tag-gap: var(--sbb-spacing-fixed-2x);\n\n  @include sbb.if-forced-colors {\n    --sbb-tag-background-color: Canvas !important;\n    --sbb-tag-text-color: ButtonText;\n    --sbb-tag-amount-color: ButtonText;\n    --sbb-tag-border-color: CanvasText;\n    --sbb-tag-border-width: var(--sbb-border-width-2x);\n  }\n}\n\n// Active state\n:host(:state(checked)) {\n  --sbb-tag-border-color: var(--sbb-border-color-3);\n  --sbb-tag-border-width: var(--sbb-border-width-2x);\n\n  @include sbb.if-forced-colors {\n    --sbb-tag-border-color: Highlight !important;\n    --sbb-tag-border-width: var(--sbb-border-width-4x);\n  }\n}\n\n:host(:is(#{$disabled})) {\n  --sbb-tag-text-color: light-dark(var(--sbb-color-granite), var(--sbb-color-aluminium));\n  --sbb-tag-amount-color: var(--sbb-tag-text-color);\n  --sbb-tag-background-color: var(--sbb-background-color-3);\n  --sbb-tag-border-color: light-dark(var(--sbb-color-cement), var(--sbb-color-smoke));\n  --sbb-tag-border-style: dashed;\n  --sbb-tag-cursor: unset;\n  --sbb-tag-pointer-events: none;\n\n  @include sbb.if-forced-colors {\n    --sbb-tag-text-color: GrayText;\n    --sbb-tag-amount-color: GrayText;\n    --sbb-tag-border-color: GrayText;\n  }\n}\n\n:host(:state(checked):is(#{$disabled})) {\n  --sbb-tag-border-color: light-dark(var(--sbb-color-metal), var(--sbb-color-cement));\n  --sbb-tag-border-style: dashed;\n}\n\n:host(:hover:not(#{$disabled}, #{$active})) {\n  @include sbb.hover-mq($hover: true) {\n    --sbb-tag-background-color: var(--sbb-background-color-3);\n    --sbb-tag-inset: calc(var(--sbb-border-width-2x) * -1);\n    --sbb-tag-content-shift: translateY(calc(var(--sbb-border-width-1x) * -1));\n\n    @include sbb.if-forced-colors {\n      --sbb-tag-border-color: Highlight;\n    }\n  }\n}\n\n// Pressed state\n:host(:is(#{$active}):not(#{$disabled})) {\n  --sbb-tag-background-color: var(--sbb-background-color-3);\n  --sbb-tag-border-color: light-dark(var(--sbb-color-iron), var(--sbb-color-storm));\n  --sbb-tag-border-width: var(--sbb-border-width-2x);\n  --sbb-tag-text-color: var(--sbb-color-4);\n\n  @include sbb.if-forced-colors {\n    --sbb-tag-border-color: Highlight;\n    --sbb-tag-text-color: ButtonText;\n  }\n}\n\n:host([size='s']) {\n  --sbb-tag-height: var(--sbb-size-element-xxxs);\n  --sbb-tag-padding-inline: var(--sbb-spacing-fixed-3x);\n}\n\n.sbb-tag {\n  @include sbb.text-xs--bold;\n\n  position: relative;\n  display: flex;\n  align-items: center;\n  height: var(--sbb-tag-height);\n  max-width: 100%;\n  gap: var(--sbb-tag-gap);\n  padding-inline: var(--sbb-tag-padding-inline);\n  cursor: var(--sbb-tag-cursor);\n  border-radius: var(--sbb-tag-border-radius);\n  color: var(--sbb-tag-text-color);\n  transition: color var(--sbb-tag-animation-duration) var(--sbb-tag-animation-easing);\n  -webkit-tap-highlight-color: transparent;\n  user-select: none;\n  pointer-events: var(--sbb-tag-pointer-events, unset);\n\n  &::before {\n    content: '';\n    position: absolute;\n    inset: var(--sbb-tag-inset);\n    background-color: var(--sbb-tag-background-color);\n    border: var(--sbb-tag-border-width) var(--sbb-tag-border-style) var(--sbb-tag-border-color);\n    border-radius: var(--sbb-tag-border-radius);\n    transition-duration: var(--sbb-tag-animation-duration);\n    transition-timing-function: var(--sbb-tag-animation-easing);\n    transition-property: inset, background-color, border-color, box-shadow;\n\n    :host(:focus-visible) & {\n      @include sbb.focus-outline;\n    }\n  }\n}\n\n.sbb-tag__icon {\n  display: flex;\n  align-items: center;\n  height: calc(var(--sbb-typo-line-height-text) * 1em);\n  flex-shrink: 0;\n\n  :host(:not(:state(slotted-icon), :state(has-icon-name))) & {\n    display: none;\n  }\n}\n\n.sbb-tag__text {\n  @include sbb.ellipsis;\n}\n\n.sbb-tag__amount {\n  @include sbb.text-xs--regular;\n\n  color: var(--sbb-tag-amount-color);\n\n  :host(:not(:state(slotted-amount), [amount])) & {\n    display: none;\n  }\n}\n\n.sbb-tag--shift {\n  transition: transform var(--sbb-tag-animation-duration) var(--sbb-tag-animation-easing);\n  transform: var(--sbb-tag-content-shift);\n  will-change: transform;\n}\n","import {\n  html,\n  unsafeCSS,\n  type CSSResultGroup,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbButtonLikeBaseElement } from '../../core/base-elements.ts';\nimport { forceType, getOverride, omitEmptyConverter } from '../../core/decorators.ts';\nimport { isLean } from '../../core/dom.ts';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbDisabledTabIndexActionMixin,\n} from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport { SbbIconNameMixin } from '../../icon.ts';\nimport type { SbbTagGroupElement } from '../tag-group/tag-group.component.ts';\n\nimport style from './tag.scss?inline';\n\nexport type SbbTagSize = 's' | 'm';\n\n/**\n * It displays a selectable element which can be used as a filter.\n *\n * @slot - Use the unnamed slot to add content to the tag label.\n * @slot icon - Use this slot to display an icon at the component start, by providing a `sbb-icon` component.\n * @slot amount - Provide an amount to show it at the component end.\n * @overrideType value - (T = string) | null\n */\nexport class SbbTagElement<T = string> extends SbbIconNameMixin(\n  SbbDisabledTabIndexActionMixin(SbbButtonLikeBaseElement),\n) {\n  public static override readonly elementName: string = 'sbb-tag';\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(style)];\n  public static readonly events = {\n    input: 'input',\n    didChange: 'didChange',\n    change: 'change',\n  } as const;\n\n  /** Value of the form element. */\n  @property()\n  public accessor value: T | null = null;\n\n  /** Amount displayed inside the tag. */\n  @forceType()\n  @property({ reflect: true, converter: omitEmptyConverter })\n  public accessor amount: string = '';\n\n  /** Whether the tag is checked. */\n  @forceType()\n  @property({ reflect: false, type: Boolean })\n  public accessor checked: boolean = false;\n\n  /**\n   * Tag size, either s or m.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true })\n  @getOverride((i, v) => i._group?.size ?? v)\n  public accessor size: SbbTagSize = isLean() ? 's' : 'm';\n\n  /** Reference to the connected tag group. */\n  private _group: SbbTagGroupElement | null = null;\n\n  public constructor() {\n    super();\n    this.addEventListener?.('click', () => this._handleClick());\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this._group = this.closest('sbb-tag-group') as SbbTagGroupElement;\n  }\n\n  protected override isDisabledExternally(): boolean {\n    return this._group?.disabled ?? false;\n  }\n\n  /** Method triggered on button click. Inverts the checked value and emits events. */\n  private _handleClick(): void {\n    if (this.disabled) {\n      return;\n    }\n\n    // Prevent deactivating on exclusive / radio mode\n    const tagGroup = this.closest('sbb-tag-group');\n    if (tagGroup && !tagGroup.multiple && this.checked) {\n      return;\n    }\n    this.checked = !this.checked;\n\n    /** The input event fires when the value has been changed as a direct result of a user action. */\n    this.dispatchEvent(\n      new InputEvent('input', {\n        bubbles: true,\n        composed: true,\n      }),\n    );\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     * Deprecated. Mirrors change event for React. Will be removed once React properly supports change events.\n     * @deprecated\n     */\n    this.dispatchEvent(new Event('didChange', { bubbles: true }));\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('checked')) {\n      this.internals.ariaPressed = `${this.checked}`;\n      this.toggleState('checked', this.checked);\n      this.updateFormValue();\n    }\n\n    const tagGroup = this.closest?.('sbb-tag-group');\n    if (tagGroup && !tagGroup.multiple && changedProperties.has('checked') && this.checked) {\n      tagGroup?.tags.filter((t) => t !== this).forEach((t) => (t.checked = false));\n    }\n  }\n\n  /**\n   * @internal\n   */\n  public override formResetCallback(): void {\n    this.checked = this.hasAttribute('checked');\n  }\n\n  /**\n   * @internal\n   */\n  public override formStateRestoreCallback(\n    state: FormRestoreState | null,\n    _reason: FormRestoreReason,\n  ): void {\n    if (state) {\n      this.checked = state === 'true';\n    }\n  }\n\n  protected override updateFormValue(): void {\n    if (this.checked) {\n      super.updateFormValue();\n    } else {\n      this.internals.setFormValue(null);\n    }\n  }\n\n  protected override formState(): FormRestoreState {\n    return `${this.checked}`;\n  }\n\n  protected override renderTemplate(): TemplateResult {\n    return html`\n      <span class=\"sbb-tag__icon sbb-tag--shift\"> ${this.renderIconSlot()} </span>\n      <span class=\"sbb-tag__text sbb-tag--shift\">\n        <slot></slot>\n      </span>\n      <span class=\"sbb-tag__amount sbb-tag--shift\">\n        <slot name=\"amount\">${this.amount}</slot>\n      </span>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-tag': SbbTagElement;\n  }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;ICiCa,uBAAa;mBAAqB,iBAC7C,+BAA+B,yBAAyB,CACzD;;;;;;;;;;;;;cAFY,sBAAkC,YAE9C;;;wBAUE,UAAU,CAAA;yBAIV,WAAW,EACX,SAAS;IAAE,SAAS;IAAM,WAAW;IAAoB,CAAC,CAAA;0BAI1D,WAAW,EACX,SAAS;IAAE,SAAS;IAAO,MAAM;IAAS,CAAC,CAAA;uBAO3C,SAAS,EAAE,SAAS,MAAM,CAAC,EAC3B,aAAa,GAAG,MAAM,EAAE,QAAQ,QAAQ,EAAE,CAAA;AAjB3C,gBAAA,MAAA,MAAA,mBAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,WAAA;KAAA,MAAA,QAAA,IAAgB;KAAK,MAAA,KAAA,UAAA;AAAA,UAAL,QAAK;;KAAA;IAAA,UAAA;IAAA,EAAA,qBAAA,yBAAA;AAKrB,gBAAA,MAAA,MAAA,oBAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,YAAA;KAAA,MAAA,QAAA,IAAgB;KAAM,MAAA,KAAA,UAAA;AAAA,UAAN,SAAM;;KAAA;IAAA,UAAA;IAAA,EAAA,sBAAA,0BAAA;AAKtB,gBAAA,MAAA,MAAA,qBAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,aAAA;KAAA,MAAA,QAAA,IAAgB;KAAO,MAAA,KAAA,UAAA;AAAA,UAAP,UAAO;;KAAA;IAAA,UAAA;IAAA,EAAA,uBAAA,2BAAA;AAQvB,gBAAA,MAAA,MAAA,kBAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,UAAA;KAAA,MAAA,QAAA,IAAgB;KAAI,MAAA,KAAA,UAAA;AAAA,UAAJ,OAAI;;KAAA;IAAA,UAAA;IAAA,EAAA,oBAAA,wBAAA;;;;;;;;;AA5BY,QAAA,cAAsB;;;AAC/B,QAAA,SAAyB,CAAC,iBAAiB,UAAU,YAAM,CAAC;;;AAC5D,QAAA,SAAS;IAC9B,OAAO;IACP,WAAW;IACX,QAAQ;IACA;;EAIV;;EAAA,IAAgB,QAAK;AAAA,UAAA,MAAA;;EAArB,IAAgB,MAAK,OAAA;AAAA,SAAA,yBAAA;;EAKrB;;EAAA,IAAgB,SAAM;AAAA,UAAA,MAAA;;EAAtB,IAAgB,OAAM,OAAA;AAAA,SAAA,0BAAA;;EAKtB;;EAAA,IAAgB,UAAO;AAAA,UAAA,MAAA;;EAAvB,IAAgB,QAAO,OAAA;AAAA,SAAA,2BAAA;;EAQvB;;;;;EAAA,IAAgB,OAAI;AAAA,UAAA,MAAA;;EAApB,IAAgB,KAAI,OAAA;AAAA,SAAA,wBAAA;;EAKpB,cAAA;AACE,UAAO;AAxBO,SAAA,yBAAA,kBAAA,MAAA,qBAAkB,KAAI;AAKtB,SAAA,2BAAA,kBAAA,MAAA,yBAAA,EAAA,kBAAA,MAAA,sBAAiB,GAAE;AAKnB,SAAA,4BAAA,kBAAA,MAAA,0BAAA,EAAA,kBAAA,MAAA,uBAAmB,MAAK;AAQxB,SAAA,yBAAA,kBAAA,MAAA,2BAAA,EAAA,kBAAA,MAAA,oBAAmB,QAAQ,GAAG,MAAM,IAAG;;AAG/C,QAAA,UAAM,kBAAA,MAAA,wBAAA,EAA8B;AAI1C,QAAK,mBAAmB,eAAe,KAAK,cAAc,CAAC;;EAG7C,oBAAiB;AAC/B,SAAM,mBAAmB;AACzB,QAAK,SAAS,KAAK,QAAQ,gBAAsC;;EAGhD,uBAAoB;AACrC,UAAO,KAAK,QAAQ,YAAY;;;EAI1B,eAAY;AAClB,OAAI,KAAK,SACP;GAIF,MAAM,WAAW,KAAK,QAAQ,gBAAgB;AAC9C,OAAI,YAAY,CAAC,SAAS,YAAY,KAAK,QACzC;AAEF,QAAK,UAAU,CAAC,KAAK;;AAGrB,QAAK,cACH,IAAI,WAAW,SAAS;IACtB,SAAS;IACT,UAAU;IACX,CAAC,CACH;;;;;;AAOD,QAAK,cAAc,IAAI,MAAM,UAAU,EAAE,SAAS,MAAM,CAAC,CAAC;;;;;AAM1D,QAAK,cAAc,IAAI,MAAM,aAAa,EAAE,SAAS,MAAM,CAAC,CAAC;;EAG5C,WAAW,mBAAuC;AACnE,SAAM,WAAW,kBAAkB;AAEnC,OAAI,kBAAkB,IAAI,UAAU,EAAE;AACpC,SAAK,UAAU,cAAc,GAAG,KAAK;AACrC,SAAK,YAAY,WAAW,KAAK,QAAQ;AACzC,SAAK,iBAAiB;;GAGxB,MAAM,WAAW,KAAK,UAAU,gBAAgB;AAChD,OAAI,YAAY,CAAC,SAAS,YAAY,kBAAkB,IAAI,UAAU,IAAI,KAAK,QAC7E,WAAU,KAAK,QAAQ,MAAM,MAAM,KAAK,CAAC,SAAS,MAAO,EAAE,UAAU,MAAO;;;;;EAOhE,oBAAiB;AAC/B,QAAK,UAAU,KAAK,aAAa,UAAU;;;;;EAM7B,yBACd,OACA,SAA0B;AAE1B,OAAI,MACF,MAAK,UAAU,UAAU;;EAIV,kBAAe;AAChC,OAAI,KAAK,QACP,OAAM,iBAAiB;OAEvB,MAAK,UAAU,aAAa,KAAK;;EAIlB,YAAS;AAC1B,UAAO,GAAG,KAAK;;EAGE,iBAAc;AAC/B,UAAO,IAAI;oDACqC,KAAK,gBAAgB,CAAA;;;;;8BAK3C,KAAK,OAAM"}
@@ -1,170 +0,0 @@
1
- import { __esDecorate as e, __runInitializers as t } from "tslib";
2
- import { html as n, unsafeCSS as r } from "lit";
3
- import { property as i } from "lit/decorators.js";
4
- import { SbbButtonLikeBaseElement as a } from "./core/base-elements.js";
5
- import { forceType as o, getOverride as s, omitEmptyConverter as c } from "./core/decorators.js";
6
- import { isLean as l } from "./core/dom.js";
7
- import { SbbDisabledTabIndexActionMixin as u } from "./core/mixins.js";
8
- import { boxSizingStyles as d } from "./core/styles.js";
9
- import { SbbIconNameMixin as f } from "./icon.js";
10
- //#region src/elements/tag/tag/tag.scss?inline
11
- var p = ":host{display:inline-block;outline:none!important;max-width:100%;--sbb-tag-border-radius: var(--sbb-border-radius-infinity);--sbb-tag-background-color: var(--sbb-background-color-1);--sbb-tag-border-color: var(--sbb-border-color-4-inverted);--sbb-tag-border-style: solid;--sbb-tag-border-width: var(--sbb-border-width-1x);--sbb-tag-text-color: var(--sbb-color-2);--sbb-tag-amount-color: var(--sbb-color-metal);--sbb-tag-amount-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));--sbb-tag-height: var(--sbb-size-element-xs);--sbb-tag-inset: 0;--sbb-tag-cursor: var(--sbb-cursor-pointer);--sbb-tag-content-shift: translateY(0);--sbb-tag-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-2x) );--sbb-tag-animation-easing: var(--sbb-animation-easing);--sbb-tag-padding-inline: var(--sbb-spacing-fixed-5x);--sbb-tag-gap: var(--sbb-spacing-fixed-2x)}@media(forced-colors:active){:host{--sbb-tag-background-color: Canvas !important;--sbb-tag-text-color: ButtonText;--sbb-tag-amount-color: ButtonText;--sbb-tag-border-color: CanvasText;--sbb-tag-border-width: var(--sbb-border-width-2x)}}:host(:is(:state(checked),[state--checked])){--sbb-tag-border-color: var(--sbb-border-color-3);--sbb-tag-border-width: var(--sbb-border-width-2x)}@media(forced-colors:active){:host(:is(:state(checked),[state--checked])){--sbb-tag-border-color: Highlight !important;--sbb-tag-border-width: var(--sbb-border-width-4x)}}:host(:is(:disabled,[disabled-interactive])){--sbb-tag-text-color: var(--sbb-color-granite);--sbb-tag-text-color: light-dark(var(--sbb-color-granite), var(--sbb-color-aluminium));--sbb-tag-amount-color: var(--sbb-tag-text-color);--sbb-tag-background-color: var(--sbb-background-color-3);--sbb-tag-border-color: var(--sbb-color-cement);--sbb-tag-border-color: light-dark(var(--sbb-color-cement), var(--sbb-color-smoke));--sbb-tag-border-style: dashed;--sbb-tag-cursor: unset;--sbb-tag-pointer-events: none}@media(forced-colors:active){:host(:is(:disabled,[disabled-interactive])){--sbb-tag-text-color: GrayText;--sbb-tag-amount-color: GrayText;--sbb-tag-border-color: GrayText}}:host(:is(:state(checked),[state--checked]):is(:disabled,[disabled-interactive])){--sbb-tag-border-color: var(--sbb-color-metal);--sbb-tag-border-color: light-dark(var(--sbb-color-metal), var(--sbb-color-cement));--sbb-tag-border-style: dashed}@media(any-hover:hover){:host(:hover:not(:disabled,[disabled-interactive],:active,:is(:state(active),[state--active]))){--sbb-tag-background-color: var(--sbb-background-color-3);--sbb-tag-inset: calc(var(--sbb-border-width-2x) * -1);--sbb-tag-content-shift: translateY(calc(var(--sbb-border-width-1x) * -1))}}@media(any-hover:hover)and (forced-colors:active){:host(:hover:not(:disabled,[disabled-interactive],:active,:is(:state(active),[state--active]))){--sbb-tag-border-color: Highlight}}:host(:is(:active,:is(:state(active),[state--active])):not(:disabled,[disabled-interactive])){--sbb-tag-background-color: var(--sbb-background-color-3);--sbb-tag-border-color: var(--sbb-color-iron);--sbb-tag-border-color: light-dark(var(--sbb-color-iron), var(--sbb-color-storm));--sbb-tag-border-width: var(--sbb-border-width-2x);--sbb-tag-text-color: var(--sbb-color-4)}@media(forced-colors:active){:host(:is(:active,:is(:state(active),[state--active])):not(:disabled,[disabled-interactive])){--sbb-tag-border-color: Highlight;--sbb-tag-text-color: ButtonText}}:host([size=s]){--sbb-tag-height: var(--sbb-size-element-xxxs);--sbb-tag-padding-inline: var(--sbb-spacing-fixed-3x)}.sbb-tag{--sbb-text-font-size: var(--sbb-text-font-size-xs);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-text);letter-spacing:var(--sbb-typo-letter-spacing-text);font-size:var(--sbb-text-font-size);font-weight:700;position:relative;display:flex;align-items:center;height:var(--sbb-tag-height);max-width:100%;gap:var(--sbb-tag-gap);padding-inline:var(--sbb-tag-padding-inline);cursor:var(--sbb-tag-cursor);border-radius:var(--sbb-tag-border-radius);color:var(--sbb-tag-text-color);transition:color var(--sbb-tag-animation-duration) var(--sbb-tag-animation-easing);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;pointer-events:var(--sbb-tag-pointer-events, unset)}.sbb-tag:before{content:\"\";position:absolute;inset:var(--sbb-tag-inset);background-color:var(--sbb-tag-background-color);border:var(--sbb-tag-border-width) var(--sbb-tag-border-style) var(--sbb-tag-border-color);border-radius:var(--sbb-tag-border-radius);transition-duration:var(--sbb-tag-animation-duration);transition-timing-function:var(--sbb-tag-animation-easing);transition-property:inset,background-color,border-color,box-shadow}:host(:focus-visible) .sbb-tag:before{outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width)}.sbb-tag__icon{display:flex;align-items:center;height:calc(var(--sbb-typo-line-height-text) * 1em);flex-shrink:0}:host(:not(:is(:state(slotted-icon),[state--slotted-icon]),:is(:state(has-icon-name),[state--has-icon-name]))) .sbb-tag__icon{display:none}.sbb-tag__text{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.sbb-tag__amount{--sbb-text-font-size: var(--sbb-text-font-size-xs);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-text);letter-spacing:var(--sbb-typo-letter-spacing-text);font-size:var(--sbb-text-font-size);color:var(--sbb-tag-amount-color)}:host(:not(:is(:state(slotted-amount),[state--slotted-amount]),[amount])) .sbb-tag__amount{display:none}.sbb-tag--shift{transition:transform var(--sbb-tag-animation-duration) var(--sbb-tag-animation-easing);transform:var(--sbb-tag-content-shift);will-change:transform}", m = (() => {
12
- let m = f(u(a)), h, g = [], _ = [], v, y = [], b = [], x, S = [], C = [], w, T = [], E = [];
13
- return class extends m {
14
- static {
15
- let t = typeof Symbol == "function" && Symbol.metadata ? Object.create(m[Symbol.metadata] ?? null) : void 0;
16
- h = [i()], v = [o(), i({
17
- reflect: !0,
18
- converter: c
19
- })], x = [o(), i({
20
- reflect: !1,
21
- type: Boolean
22
- })], w = [i({ reflect: !0 }), s((e, t) => e._group?.size ?? t)], e(this, null, h, {
23
- kind: "accessor",
24
- name: "value",
25
- static: !1,
26
- private: !1,
27
- access: {
28
- has: (e) => "value" in e,
29
- get: (e) => e.value,
30
- set: (e, t) => {
31
- e.value = t;
32
- }
33
- },
34
- metadata: t
35
- }, g, _), e(this, null, v, {
36
- kind: "accessor",
37
- name: "amount",
38
- static: !1,
39
- private: !1,
40
- access: {
41
- has: (e) => "amount" in e,
42
- get: (e) => e.amount,
43
- set: (e, t) => {
44
- e.amount = t;
45
- }
46
- },
47
- metadata: t
48
- }, y, b), e(this, null, x, {
49
- kind: "accessor",
50
- name: "checked",
51
- static: !1,
52
- private: !1,
53
- access: {
54
- has: (e) => "checked" in e,
55
- get: (e) => e.checked,
56
- set: (e, t) => {
57
- e.checked = t;
58
- }
59
- },
60
- metadata: t
61
- }, S, C), e(this, null, w, {
62
- kind: "accessor",
63
- name: "size",
64
- static: !1,
65
- private: !1,
66
- access: {
67
- has: (e) => "size" in e,
68
- get: (e) => e.size,
69
- set: (e, t) => {
70
- e.size = t;
71
- }
72
- },
73
- metadata: t
74
- }, T, E), t && Object.defineProperty(this, Symbol.metadata, {
75
- enumerable: !0,
76
- configurable: !0,
77
- writable: !0,
78
- value: t
79
- });
80
- }
81
- static {
82
- this.elementName = "sbb-tag";
83
- }
84
- static {
85
- this.styles = [d, r(p)];
86
- }
87
- static {
88
- this.events = {
89
- input: "input",
90
- didChange: "didChange",
91
- change: "change"
92
- };
93
- }
94
- #e;
95
- get value() {
96
- return this.#e;
97
- }
98
- set value(e) {
99
- this.#e = e;
100
- }
101
- #t;
102
- get amount() {
103
- return this.#t;
104
- }
105
- set amount(e) {
106
- this.#t = e;
107
- }
108
- #n;
109
- get checked() {
110
- return this.#n;
111
- }
112
- set checked(e) {
113
- this.#n = e;
114
- }
115
- #r;
116
- get size() {
117
- return this.#r;
118
- }
119
- set size(e) {
120
- this.#r = e;
121
- }
122
- constructor() {
123
- super(), this.#e = t(this, g, null), this.#t = (t(this, _), t(this, y, "")), this.#n = (t(this, b), t(this, S, !1)), this.#r = (t(this, C), t(this, T, l() ? "s" : "m")), this._group = (t(this, E), null), this.addEventListener?.("click", () => this._handleClick());
124
- }
125
- connectedCallback() {
126
- super.connectedCallback(), this._group = this.closest("sbb-tag-group");
127
- }
128
- isDisabledExternally() {
129
- return this._group?.disabled ?? !1;
130
- }
131
- _handleClick() {
132
- if (this.disabled) return;
133
- let e = this.closest("sbb-tag-group");
134
- e && !e.multiple && this.checked || (this.checked = !this.checked, this.dispatchEvent(new InputEvent("input", {
135
- bubbles: !0,
136
- composed: !0
137
- })), this.dispatchEvent(new Event("change", { bubbles: !0 })), this.dispatchEvent(new Event("didChange", { bubbles: !0 })));
138
- }
139
- willUpdate(e) {
140
- super.willUpdate(e), e.has("checked") && (this.internals.ariaPressed = `${this.checked}`, this.toggleState("checked", this.checked), this.updateFormValue());
141
- let t = this.closest?.("sbb-tag-group");
142
- t && !t.multiple && e.has("checked") && this.checked && t?.tags.filter((e) => e !== this).forEach((e) => e.checked = !1);
143
- }
144
- formResetCallback() {
145
- this.checked = this.hasAttribute("checked");
146
- }
147
- formStateRestoreCallback(e, t) {
148
- e && (this.checked = e === "true");
149
- }
150
- updateFormValue() {
151
- this.checked ? super.updateFormValue() : this.internals.setFormValue(null);
152
- }
153
- formState() {
154
- return `${this.checked}`;
155
- }
156
- renderTemplate() {
157
- return n`
158
- <span class="sbb-tag__icon sbb-tag--shift"> ${this.renderIconSlot()} </span>
159
- <span class="sbb-tag__text sbb-tag--shift">
160
- <slot></slot>
161
- </span>
162
- <span class="sbb-tag__amount sbb-tag--shift">
163
- <slot name="amount">${this.amount}</slot>
164
- </span>
165
- `;
166
- }
167
- };
168
- })();
169
- //#endregion
170
- export { m as t };