@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.
- package/core/styles/core.scss +5 -0
- package/core.css +16 -0
- package/development/tag/tag/tag.component.js +1 -1
- package/development/tag/tag-group/tag-group.component.d.ts.map +1 -1
- package/development/tag/tag-group/tag-group.component.js +1 -1
- package/development/tag/tag-group.js +1 -1
- package/development/tag/tag.js +1 -1
- package/development/{tag-group.component-B7bBirrj.js → tag-group.component-Cw46bt0E.js} +2 -4
- package/development/tag.component-CnNPL6aI.js +245 -0
- package/development/tag.js +2 -2
- package/development/tag.pure.js +2 -2
- package/off-brand-theme.css +16 -0
- package/package.json +2 -2
- package/safety-theme.css +16 -0
- package/standard-theme.css +16 -0
- package/tag/tag/tag.component.js +1 -1
- package/tag/tag-group/tag-group.component.js +1 -1
- package/tag/tag-group.js +1 -1
- package/tag/tag.js +1 -1
- package/{tag-group.component-DyEB8c6w.js → tag-group.component-DkQVBbQY.js} +1 -3
- package/tag.component-CzYJZuFT.js +170 -0
- package/tag.js +2 -2
- package/tag.pure.js +2 -2
- package/development/tag.component-0vKnvMOm.js +0 -245
- package/tag.component-C3ogN9Th.js +0 -170
package/core/styles/core.scss
CHANGED
|
@@ -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-
|
|
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;
|
|
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-
|
|
1
|
+
import { t as SbbTagGroupElement } from "../../tag-group.component-Cw46bt0E.js";
|
|
2
2
|
export { SbbTagGroupElement };
|
package/development/tag/tag.js
CHANGED
|
@@ -186,12 +186,10 @@ var SbbTagGroupElement = (() => {
|
|
|
186
186
|
}
|
|
187
187
|
render() {
|
|
188
188
|
return html`
|
|
189
|
-
|
|
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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"}
|
package/development/tag.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { t as SbbTagGroupElement } from "./tag-group.component-
|
|
2
|
-
import { t as SbbTagElement } from "./tag.component-
|
|
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 */
|
package/development/tag.pure.js
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import { t as SbbTagGroupElement } from "./tag-group.component-
|
|
2
|
-
import { t as SbbTagElement } from "./tag.component-
|
|
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 };
|
package/off-brand-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 {
|
package/package.json
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@sbb-esta/lyne-elements-dev",
|
|
3
|
-
"version": "4.9.0-dev.
|
|
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/
|
|
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 {
|
package/standard-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 {
|
package/tag/tag/tag.component.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as e } from "../../tag.component-
|
|
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-
|
|
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-
|
|
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-
|
|
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
|
-
|
|
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-
|
|
2
|
-
import { t } from "./tag.component-
|
|
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-
|
|
2
|
-
import { t } from "./tag.component-
|
|
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":"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"}
|
|
@@ -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 };
|