@sbb-esta/lyne-elements-dev 4.9.0-dev.1775120732 → 4.9.0-dev.1775125441
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 +9 -1
- package/core.css +25 -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/development/teaser/teaser.component.js +1 -1
- package/development/teaser.component-Cky6kKU0.js +118 -0
- package/development/teaser.js +1 -1
- package/development/teaser.pure.js +1 -1
- package/off-brand-theme.css +25 -0
- package/package.json +2 -2
- package/safety-theme.css +25 -0
- package/standard-theme.css +25 -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/teaser/teaser.component.js +1 -1
- package/teaser.component-WZL0vAo9.js +91 -0
- package/teaser.js +1 -1
- package/teaser.pure.js +1 -1
- package/development/tag.component-0vKnvMOm.js +0 -245
- package/development/teaser.component-C63t0z1I.js +0 -118
- package/tag.component-C3ogN9Th.js +0 -170
- package/teaser.component-u1uLVhwo.js +0 -91
package/core/styles/core.scss
CHANGED
|
@@ -233,6 +233,12 @@ $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
|
+
);
|
|
239
|
+
@use '../../teaser/teaser.global' as teaser with (
|
|
240
|
+
$theme: $theme
|
|
241
|
+
);
|
|
236
242
|
@use '../../visual-checkbox/visual-checkbox.global' as visual-checkbox with (
|
|
237
243
|
$theme: $theme
|
|
238
244
|
);
|
|
@@ -310,6 +316,8 @@ $theme: 'standard' !default;
|
|
|
310
316
|
@include stepper.base;
|
|
311
317
|
@include tab-group-common.base;
|
|
312
318
|
@include tab-label-common.base;
|
|
319
|
+
@include tag.base;
|
|
320
|
+
@include teaser.base;
|
|
313
321
|
@include visual-checkbox.base;
|
|
314
322
|
|
|
315
323
|
@include a11y.if-forced-colors {
|
|
@@ -328,6 +336,7 @@ $theme: 'standard' !default;
|
|
|
328
336
|
@include signet.base-forced-colors;
|
|
329
337
|
@include slider.base-forced-colors;
|
|
330
338
|
@include step-label.base-forced-colors;
|
|
339
|
+
@include tag.base-forced-colors;
|
|
331
340
|
}
|
|
332
341
|
|
|
333
342
|
// Train formation
|
|
@@ -576,7 +585,6 @@ img {
|
|
|
576
585
|
}
|
|
577
586
|
}
|
|
578
587
|
|
|
579
|
-
// TODO: Move back to the teaser components when the global CSS refactoring happens
|
|
580
588
|
sbb-teaser :is(sbb-image, img):not(.sbb-figure-overlap-image) {
|
|
581
589
|
--sbb-image-object-fit: cover;
|
|
582
590
|
--sbb-image-aspect-ratio: 4 / 3;
|
package/core.css
CHANGED
|
@@ -1723,6 +1723,26 @@ 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);
|
|
1737
|
+
--sbb-teaser-scale-hover: 1.02;
|
|
1738
|
+
--sbb-teaser-description-color: var(--sbb-color-granite);
|
|
1739
|
+
--sbb-teaser-description-color: light-dark(var(--sbb-color-granite), var(--sbb-color-silver));
|
|
1740
|
+
--sbb-teaser-flex-direction: row;
|
|
1741
|
+
--sbb-teaser-align-items: center;
|
|
1742
|
+
--sbb-teaser-font-size: var(--sbb-text-font-size-s);
|
|
1743
|
+
--sbb-teaser-gap: var(--sbb-spacing-fixed-4x);
|
|
1744
|
+
--sbb-teaser-border-radius: var(--sbb-border-radius-4x);
|
|
1745
|
+
--sbb-teaser-image-width: 18.75rem;
|
|
1726
1746
|
--sbb-visual-checkbox-dimension: var(--sbb-checkbox-dimension-m);
|
|
1727
1747
|
--sbb-visual-checkbox-selection-color: var(--sbb-color-primary);
|
|
1728
1748
|
--sbb-visual-checkbox-selection-color-negative: var(--sbb-color-primary85);
|
|
@@ -1780,6 +1800,11 @@ slot[name=error]::slotted(*) {
|
|
|
1780
1800
|
--sbb-slider-line-color: CanvasText;
|
|
1781
1801
|
--sbb-step-label-color: ButtonText;
|
|
1782
1802
|
--sbb-step-label-prefix-border-color: ButtonText;
|
|
1803
|
+
--sbb-tag-amount-color: ButtonText;
|
|
1804
|
+
--sbb-tag-background-color: Canvas !important;
|
|
1805
|
+
--sbb-tag-text-color: ButtonText;
|
|
1806
|
+
--sbb-tag-border-color: CanvasText;
|
|
1807
|
+
--sbb-tag-border-width: var(--sbb-border-width-2x);
|
|
1783
1808
|
}
|
|
1784
1809
|
}
|
|
1785
1810
|
: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":";;;;;;;;;;;;;;;;;;IC6Ba,4BAAkB;mBAAqB,iBAClD,sBAAwD,WAAW,CACpE;;;;;;;;;;;;cAFY,2BAAuC,YAEnD;;;AAI6B,QAAA,uBANjB,kBAAA,MAAA,2BAAkB,EAMqB,CAAC,WAAW,MAAM;AAOpD,SAAA,0CAAA,kBAAA,MAAA,sCAAiC,GAAE;AAUnC,SAAA,6BAAA,kBAAA,MAAA,0CAAA,EAAA,kBAAA,MAAA,wBAAoB,MAAK;AAMI,SAAA,yBAAA,kBAAA,MAAA,4BAAA,EAAA,kBAAA,MAAA,oBAAmB,QAAQ,GAAG,MAAM,IAAG;AAsB5E,QAAA,UAAM,kBAAA,MAAA,wBAAA,EAA4B;;;;yCAxCzC,WAAW,EACX,SAAS,EAAE,WAAW,4BAA4B,CAAC,CAAA;2BASnD,WAAW,EACX,SAAS,EAAE,MAAM,SAAS,CAAC,CAAA;uBAO3B,SAAS,EAAE,SAAS,MAAM,CAAC,CAAA;4BAO3B,UAAU,CAAA;AAvBX,gBAAA,MAAA,MAAA,oCAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,4BAAA;KAAA,MAAA,QAAA,IAAgB;KAAsB,MAAA,KAAA,UAAA;AAAA,UAAtB,yBAAsB;;KAAA;IAAA,UAAA;IAAA,EAAA,sCAAA,0CAAA;AAUtC,gBAAA,MAAA,MAAA,sBAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,cAAA;KAAA,MAAA,QAAA,IAAgB;KAAQ,MAAA,KAAA,UAAA;AAAA,UAAR,WAAQ;;KAAA;IAAA,UAAA;IAAA,EAAA,wBAAA,4BAAA;AAMK,gBAAA,MAAA,MAAA,kBAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,UAAA;KAAA,MAAA,QAAA,IAAgB;KAAI,MAAA,KAAA,UAAA;AAAA,UAAJ,OAAI;;KAAA;IAAA,UAAA;IAAA,EAAA,oBAAA,wBAAA;AAQjD,gBAAA,MAAA,MAAA,uBAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,WAAA;KAAA,MAAA,KAAA,UAAA;AAAA,UAAW,QAAK;;KAAA;IAAA,UAAA;IAAA,EAAA,MAAA,2BAAA;;;;;;;;;AAlCgB,QAAA,cAAsB;;;AAC/B,QAAA,SAAyB,CAAC,iBAAiB,UAAU,kBAAM,CAAC;;EASnF;;;;EAAA,IAAgB,yBAAsB;AAAA,UAAA,MAAA;;EAAtC,IAAgB,uBAAsB,OAAA;AAAA,SAAA,0CAAA;;EAUtC;;;;;;;EAAA,IAAgB,WAAQ;AAAA,UAAA,MAAA;;EAAxB,IAAgB,SAAQ,OAAA;AAAA,SAAA,4BAAA;;EAMK;;;;;EAAA,IAAgB,OAAI;AAAA,UAAA,MAAA;;EAApB,IAAgB,KAAI,OAAA;AAAA,SAAA,wBAAA;;;;;;;EAQjD,IAAW,MAAM,OAA8B;AAC7C,OAAI,YAAY,CAAC,KAAK,YAAY;AAChC,SAAK,SAAS;AACd;;AAEF,QAAK,kBAAkB,MAAM;;EAE/B,IAAW,QAAK;AACd,UAAO,YAAY,CAAC,KAAK,aACrB,KAAK,SACL,KAAK,WACH,KAAK,KAAK,QAAQ,MAAM,EAAE,QAAQ,CAAC,KAAK,MAAM,EAAE,MAAM,GACrD,KAAK,KAAK,MAAM,MAAM,EAAE,QAAQ,EAAE,SAAS;;;EAKpD,IAAW,OAAI;AACb,UAAO,MAAM,KAAK,KAAK,mBAAqC,UAAU,IAAI,EAAE,CAAC;;EAG5D,WAAW,mBAAyD;AACrF,SAAM,WAAW,kBAAkB;AAEnC,OAAI,kBAAkB,IAAI,QAAQ,IAAI,CAAC,KAAK,cAAc,KAAK,OAC7D,MAAK,kBAAkB,KAAK,MAAM;AAGpC,OAAI,kBAAkB,IAAI,OAAO,CAC/B,MAAK,KAAK,SAAS,MAAM,EAAE,gBAAgB,OAAO,CAAC;AAGrD,OAAI,kBAAkB,IAAI,WAAW,CACnC,MAAK,KAAK,SAAS,MAAM,EAAE,gBAAgB,WAAW,CAAC;AAGzD,QACG,kBAAkB,IAAI,eAAe,IAAI,kBAAkB,IAAI,WAAW,KAC3E,CAAC,KAAK,SAGN,MAAK,KACF,QAAQ,QAAQ,IAAI,QAAQ,CAC5B,MAAM,EAAE,CACR,SAAS,QAAS,IAAI,UAAU,MAAO;AAE5C,wBACE,MACA,QACA,kBAAkB,IAAI,yBAAyB,IAAI,KAAK,yBACpD,OACA,QACL;;EAGK,kBAAkB,OAAU;GAClC,MAAM,OAAO,KAAK;AAElB,OAAI,UAAU,KACZ,MAAK,SAAS,MAAO,EAAE,UAAU,MAAO;YAC/B,KAAK,UAAU;AACxB,QAAI,CAAC,MAAM,QAAQ,MAAM,IAAI,KAAK,OAAO,MAAM,EAAE,UAAU,MAAM,CAC/D,KAAI;AAGF,aAAQ,KAAK,MAAM,MAAgB;YAC7B;IAIV,MAAM,eAAe,MAAM,QAAQ,MAAM,GAAG,QAAQ,CAAC,MAAM;AAC3D,SAAK,SAAS,MAAO,EAAE,UAAU,aAAa,SAAS,EAAE,MAAM,CAAE;cAE7D,CAAC,MAAM,QAAQ,MAAM,CACvB,MAAK,SAAS,MAAO,EAAE,UAAU,EAAE,UAAU,MAAO;;EAOvC,SAAM;AACvB,UAAO,IAAI;;UAEL,KAAK,WAAW;IAChB,OAAO;IACP,WAAW,KAAK;IACjB,CAAC,CAAA"}
|
|
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 };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as SbbTeaserElement } from "../teaser.component-
|
|
1
|
+
import { t as SbbTeaserElement } from "../teaser.component-Cky6kKU0.js";
|
|
2
2
|
export { SbbTeaserElement };
|
|
@@ -0,0 +1,118 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
import { unsafeCSS } from "lit";
|
|
3
|
+
import { property } from "lit/decorators.js";
|
|
4
|
+
import { SbbLinkBaseElement } from "./core/base-elements.js";
|
|
5
|
+
import { boxSizingStyles } from "./core/styles.js";
|
|
6
|
+
import { html as html$1 } from "lit/static-html.js";
|
|
7
|
+
import "./screen-reader-only.js";
|
|
8
|
+
//#region src/elements/teaser/teaser.scss?inline
|
|
9
|
+
var teaser_default = "@charset \"UTF-8\";\n:host {\n --_sbb-teaser-forced-colors-inset: calc(-1 * var(--sbb-focus-outline-offset));\n --_sbb-teaser-forced-colors-outline-offset: calc(2 * var(--sbb-focus-outline-offset));\n --_sbb-teaser-forced-colors-border-radius: calc(\n var(--sbb-teaser-border-radius) + var(--sbb-focus-outline-offset)\n );\n display: inline-block;\n outline: none !important;\n}\n@media (forced-colors: active) {\n :host {\n --sbb-teaser-description-color: LinkText;\n --sbb-title-text-color-normal-override: LinkText !important;\n }\n}\n\n:host([alignment=after]) {\n --sbb-teaser-align-items: start;\n}\n\n:host([alignment=below]) {\n --sbb-teaser-flex-direction: column;\n --sbb-teaser-align-items: baseline;\n --sbb-teaser-gap: var(--sbb-spacing-fixed-3x);\n}\n\n@media (any-hover: hover) {\n :host(:hover) {\n --sbb-teaser-scale: var(--sbb-teaser-scale-hover);\n }\n}\n.sbb-teaser__wrapper {\n display: flex;\n position: relative;\n cursor: var(--sbb-cursor-pointer);\n}\n.sbb-teaser__wrapper::before {\n content: \"\";\n user-select: none;\n width: 0;\n height: 0;\n}\n\n.sbb-teaser {\n text-decoration: none;\n position: absolute;\n inset: 0;\n}\n.sbb-teaser:focus-visible {\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 border-radius: var(--sbb-teaser-border-radius);\n}\n@media (forced-colors: active) {\n .sbb-teaser:focus-visible {\n outline-offset: var(--_sbb-teaser-forced-colors-outline-offset);\n }\n}\n@media (forced-colors: active) {\n .sbb-teaser::before {\n content: \"\";\n position: absolute;\n inset: var(--_sbb-teaser-forced-colors-inset);\n pointer-events: none;\n border-radius: var(--_sbb-teaser-forced-colors-border-radius);\n border: var(--sbb-border-width-1x) solid CanvasText;\n }\n}\n\n.sbb-teaser__container {\n display: flex;\n flex-flow: var(--sbb-teaser-flex-direction) nowrap;\n align-items: var(--sbb-teaser-align-items);\n gap: var(--sbb-teaser-gap);\n max-width: 100%;\n width: 100%;\n pointer-events: none;\n}\n\n.sbb-teaser__text {\n color: var(--sbb-teaser-description-color);\n font-size: var(--sbb-teaser-font-size);\n letter-spacing: var(--sbb-typo-letter-spacing-text);\n overflow: hidden;\n max-width: 100%;\n}\n\n::slotted([slot=image]) {\n display: block;\n width: var(--sbb-teaser-image-width);\n}\n\n.sbb-teaser__image-wrapper {\n flex-shrink: 0;\n overflow: hidden;\n border-radius: var(--sbb-teaser-border-radius);\n transition: box-shadow var(--sbb-teaser-image-animation-duration) var(--sbb-animation-easing);\n}\n:host(:not(:is(:state(slotted-image),[state--slotted-image]))) .sbb-teaser__image-wrapper {\n display: none;\n}\n@media (any-hover: hover) {\n :host(:hover) .sbb-teaser__image-wrapper {\n box-shadow: var(--sbb-box-shadow-level-9-hard);\n }\n}\n\n.sbb-teaser__description {\n display: inline-block;\n margin: 0;\n padding: 0;\n}\n\n::slotted(sbb-chip-label) {\n display: block;\n max-width: fit-content;\n margin-block-end: var(--sbb-spacing-fixed-1x);\n}\n\n::slotted(sbb-title) {\n margin-block: 0;\n}";
|
|
10
|
+
//#endregion
|
|
11
|
+
//#region src/elements/teaser/teaser.component.ts
|
|
12
|
+
/**
|
|
13
|
+
* It displays an interactive image with caption.
|
|
14
|
+
*
|
|
15
|
+
* @slot image - Slot used to render the image.
|
|
16
|
+
* @slot chip - Slot for the `sbb-chip-label` element. The slot on the `sbb-chip-label` element is automatically assigned when slotted in the unnamed slot.
|
|
17
|
+
* @slot title - Slot for the title. For the standard `sbb-title` element, the slot is automatically assigned when slotted in the unnamed slot.
|
|
18
|
+
* @slot - Use the unnamed slot to render the description, the sbb-title and the sbb-chip-label.
|
|
19
|
+
*/
|
|
20
|
+
var SbbTeaserElement = (() => {
|
|
21
|
+
let _classSuper = SbbLinkBaseElement;
|
|
22
|
+
let _alignment_decorators;
|
|
23
|
+
let _alignment_initializers = [];
|
|
24
|
+
let _alignment_extraInitializers = [];
|
|
25
|
+
return class SbbTeaserElement extends _classSuper {
|
|
26
|
+
static {
|
|
27
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
28
|
+
_alignment_decorators = [property({ reflect: true })];
|
|
29
|
+
__esDecorate(this, null, _alignment_decorators, {
|
|
30
|
+
kind: "accessor",
|
|
31
|
+
name: "alignment",
|
|
32
|
+
static: false,
|
|
33
|
+
private: false,
|
|
34
|
+
access: {
|
|
35
|
+
has: (obj) => "alignment" in obj,
|
|
36
|
+
get: (obj) => obj.alignment,
|
|
37
|
+
set: (obj, value) => {
|
|
38
|
+
obj.alignment = value;
|
|
39
|
+
}
|
|
40
|
+
},
|
|
41
|
+
metadata: _metadata
|
|
42
|
+
}, _alignment_initializers, _alignment_extraInitializers);
|
|
43
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, {
|
|
44
|
+
enumerable: true,
|
|
45
|
+
configurable: true,
|
|
46
|
+
writable: true,
|
|
47
|
+
value: _metadata
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
static {
|
|
51
|
+
this.elementName = "sbb-teaser";
|
|
52
|
+
}
|
|
53
|
+
static {
|
|
54
|
+
this.styles = [boxSizingStyles, unsafeCSS(teaser_default)];
|
|
55
|
+
}
|
|
56
|
+
#alignment_accessor_storage = __runInitializers(this, _alignment_initializers, "after-centered");
|
|
57
|
+
/** Teaser variant - define the position and the alignment of the text block. */
|
|
58
|
+
get alignment() {
|
|
59
|
+
return this.#alignment_accessor_storage;
|
|
60
|
+
}
|
|
61
|
+
set alignment(value) {
|
|
62
|
+
this.#alignment_accessor_storage = value;
|
|
63
|
+
}
|
|
64
|
+
_handleSlotchange() {
|
|
65
|
+
const chip = Array.from(this.children).find((el) => el.localName === "sbb-chip-label");
|
|
66
|
+
if (chip) chip.slot = "chip";
|
|
67
|
+
const title = Array.from(this.children).find((el) => el.localName === "sbb-title");
|
|
68
|
+
if (title) title.slot = "title";
|
|
69
|
+
}
|
|
70
|
+
_configureChip(event) {
|
|
71
|
+
const chipLabel = event.target.assignedElements().find((e) => e.localName === "sbb-chip-label");
|
|
72
|
+
if (chipLabel) {
|
|
73
|
+
customElements.upgrade(chipLabel);
|
|
74
|
+
chipLabel.color = "charcoal";
|
|
75
|
+
chipLabel.size = "xxs";
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
_configureTitle(event) {
|
|
79
|
+
const title = event.target.assignedElements().find((e) => e.localName === "sbb-title");
|
|
80
|
+
if (title) {
|
|
81
|
+
customElements.upgrade(title);
|
|
82
|
+
title.visualLevel = "5";
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
render() {
|
|
86
|
+
return html$1`
|
|
87
|
+
<div class="sbb-teaser__wrapper">
|
|
88
|
+
${this.renderLink(html$1`<sbb-screen-reader-only>${this.accessibilityLabel}</sbb-screen-reader-only>`)}
|
|
89
|
+
${this.renderContent()}
|
|
90
|
+
</div>
|
|
91
|
+
`;
|
|
92
|
+
}
|
|
93
|
+
renderContent() {
|
|
94
|
+
return html$1`
|
|
95
|
+
<span class="sbb-teaser__container">
|
|
96
|
+
<span class="sbb-teaser__image-wrapper">
|
|
97
|
+
<slot name="image"></slot>
|
|
98
|
+
</span>
|
|
99
|
+
<span class="sbb-teaser__text">
|
|
100
|
+
<slot name="chip" @slotchange=${this._configureChip}></slot>
|
|
101
|
+
<slot name="title" @slotchange=${this._configureTitle}></slot>
|
|
102
|
+
<p class="sbb-teaser__description">
|
|
103
|
+
<slot @slotchange=${this._handleSlotchange}></slot>
|
|
104
|
+
</p>
|
|
105
|
+
</span>
|
|
106
|
+
</span>
|
|
107
|
+
`;
|
|
108
|
+
}
|
|
109
|
+
constructor() {
|
|
110
|
+
super(...arguments);
|
|
111
|
+
__runInitializers(this, _alignment_extraInitializers);
|
|
112
|
+
}
|
|
113
|
+
};
|
|
114
|
+
})();
|
|
115
|
+
//#endregion
|
|
116
|
+
export { SbbTeaserElement as t };
|
|
117
|
+
|
|
118
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"teaser.component-Cky6kKU0.js","names":[],"sources":["../../../src/elements/teaser/teaser.scss?inline","../../../src/elements/teaser/teaser.component.ts"],"sourcesContent":["@use '../core/styles' as sbb;\n\n:host {\n  --_sbb-teaser-forced-colors-inset: calc(-1 * var(--sbb-focus-outline-offset));\n  --_sbb-teaser-forced-colors-outline-offset: calc(2 * var(--sbb-focus-outline-offset));\n  --_sbb-teaser-forced-colors-border-radius: calc(\n    var(--sbb-teaser-border-radius) + var(--sbb-focus-outline-offset)\n  );\n\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\n  @include sbb.if-forced-colors {\n    --sbb-teaser-description-color: LinkText;\n    --sbb-title-text-color-normal-override: LinkText !important;\n  }\n}\n\n:host([alignment='after']) {\n  --sbb-teaser-align-items: start;\n}\n\n:host([alignment='below']) {\n  --sbb-teaser-flex-direction: column;\n  --sbb-teaser-align-items: baseline;\n  --sbb-teaser-gap: var(--sbb-spacing-fixed-3x);\n}\n\n@include sbb.hover-mq($hover: true) {\n  :host(:hover) {\n    --sbb-teaser-scale: var(--sbb-teaser-scale-hover);\n  }\n}\n\n.sbb-teaser__wrapper {\n  display: flex;\n  position: relative;\n  cursor: var(--sbb-cursor-pointer);\n\n  @include sbb.zero-width-space;\n}\n\n.sbb-teaser {\n  text-decoration: none;\n  position: absolute;\n  inset: 0;\n\n  &:focus-visible {\n    @include sbb.focus-outline;\n\n    border-radius: var(--sbb-teaser-border-radius);\n\n    // We move the focus outline further out to not overlap with the teaser border in forced colors\n    @include sbb.if-forced-colors {\n      outline-offset: var(--_sbb-teaser-forced-colors-outline-offset);\n    }\n  }\n\n  @include sbb.if-forced-colors {\n    &::before {\n      content: '';\n      position: absolute;\n      inset: var(--_sbb-teaser-forced-colors-inset);\n      pointer-events: none;\n      border-radius: var(--_sbb-teaser-forced-colors-border-radius);\n      border: var(--sbb-border-width-1x) solid CanvasText;\n    }\n  }\n}\n\n.sbb-teaser__container {\n  display: flex;\n  flex-flow: var(--sbb-teaser-flex-direction) nowrap;\n  align-items: var(--sbb-teaser-align-items);\n  gap: var(--sbb-teaser-gap);\n  max-width: 100%;\n  width: 100%;\n  pointer-events: none;\n}\n\n.sbb-teaser__text {\n  color: var(--sbb-teaser-description-color);\n  font-size: var(--sbb-teaser-font-size);\n  letter-spacing: var(--sbb-typo-letter-spacing-text);\n  overflow: hidden;\n  max-width: 100%;\n}\n\n::slotted([slot='image']) {\n  display: block;\n  width: var(--sbb-teaser-image-width);\n}\n\n.sbb-teaser__image-wrapper {\n  flex-shrink: 0;\n  overflow: hidden;\n  border-radius: var(--sbb-teaser-border-radius);\n  transition: box-shadow var(--sbb-teaser-image-animation-duration) var(--sbb-animation-easing);\n\n  :host(:not(:state(slotted-image))) & {\n    display: none;\n  }\n\n  @include sbb.hover-mq($hover: true) {\n    :host(:hover) & {\n      box-shadow: var(--sbb-box-shadow-level-9-hard);\n    }\n  }\n}\n\n.sbb-teaser__description {\n  // Reset paragraph styles\n  display: inline-block;\n  margin: 0;\n  padding: 0;\n}\n\n::slotted(sbb-chip-label) {\n  display: block;\n  max-width: fit-content;\n  margin-block-end: var(--sbb-spacing-fixed-1x);\n}\n\n::slotted(sbb-title) {\n  margin-block: 0;\n}\n","import { unsafeCSS, type CSSResultGroup, type TemplateResult } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { html } from 'lit/static-html.js';\n\nimport type { SbbChipLabelElement } from '../chip-label.ts';\nimport { SbbLinkBaseElement } from '../core/base-elements.ts';\nimport { boxSizingStyles } from '../core/styles.ts';\nimport type { SbbTitleElement } from '../title.ts';\n\nimport style from './teaser.scss?inline';\n\nimport '../screen-reader-only.ts';\n\n/**\n * It displays an interactive image with caption.\n *\n * @slot image - Slot used to render the image.\n * @slot chip - Slot for the `sbb-chip-label` element. The slot on the `sbb-chip-label` element is automatically assigned when slotted in the unnamed slot.\n * @slot title - Slot for the title. For the standard `sbb-title` element, the slot is automatically assigned when slotted in the unnamed slot.\n * @slot - Use the unnamed slot to render the description, the sbb-title and the sbb-chip-label.\n */\nexport class SbbTeaserElement extends SbbLinkBaseElement {\n  public static override readonly elementName: string = 'sbb-teaser';\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(style)];\n\n  /** Teaser variant - define the position and the alignment of the text block. */\n  @property({ reflect: true }) public accessor alignment: 'after-centered' | 'after' | 'below' =\n    'after-centered';\n\n  private _handleSlotchange(): void {\n    const chip = Array.from(this.children).find((el) => el.localName === 'sbb-chip-label');\n    if (chip) {\n      chip.slot = 'chip';\n    }\n\n    const title = Array.from(this.children).find((el) => el.localName === 'sbb-title');\n    if (title) {\n      title.slot = 'title';\n    }\n  }\n\n  private _configureChip(event: Event): void {\n    // We need to check assigned elements because in the image slot it can have labels as well.\n    const chipLabel = (event.target as HTMLSlotElement)\n      .assignedElements()\n      .find((e): e is SbbChipLabelElement => e.localName === 'sbb-chip-label');\n\n    if (chipLabel) {\n      customElements.upgrade(chipLabel);\n      chipLabel.color = 'charcoal';\n      chipLabel.size = 'xxs';\n    }\n  }\n\n  private _configureTitle(event: Event): void {\n    const title = (event.target as HTMLSlotElement)\n      .assignedElements()\n      .find((e): e is SbbTitleElement => e.localName === 'sbb-title');\n\n    if (title) {\n      customElements.upgrade(title);\n      title.visualLevel = '5';\n    }\n  }\n\n  protected override render(): TemplateResult {\n    // We render the content outside the anchor tag to allow screen readers to navigate through it\n    return html`\n      <div class=\"sbb-teaser__wrapper\">\n        ${this.renderLink(\n          // For SEO, we add the accessibility hidden as hidden content of the link\n          html`<sbb-screen-reader-only>${this.accessibilityLabel}</sbb-screen-reader-only>`,\n        )}\n        ${this.renderContent()}\n      </div>\n    `;\n  }\n\n  protected renderContent(): TemplateResult {\n    return html`\n      <span class=\"sbb-teaser__container\">\n        <span class=\"sbb-teaser__image-wrapper\">\n          <slot name=\"image\"></slot>\n        </span>\n        <span class=\"sbb-teaser__text\">\n          <slot name=\"chip\" @slotchange=${this._configureChip}></slot>\n          <slot name=\"title\" @slotchange=${this._configureTitle}></slot>\n          <p class=\"sbb-teaser__description\">\n            <slot @slotchange=${this._handleSlotchange}></slot>\n          </p>\n        </span>\n      </span>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-teaser': SbbTeaserElement;\n  }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;ICqBa,0BAAgB;mBAAS;;;;cAAzB,yBAAyB,YAAkB;;;4BAKrD,SAAS,EAAE,SAAS,MAAM,CAAC,CAAA;AAAC,gBAAA,MAAA,MAAA,uBAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,eAAA;KAAA,MAAA,QAAA,IAAgB;KAAS,MAAA,KAAA,UAAA;AAAA,UAAT,YAAS;;KAAA;IAAA,UAAA;IAAA,EAAA,yBAAA,6BAAA;;;;;;;;;AAJtB,QAAA,cAAsB;;;AAC/B,QAAA,SAAyB,CAAC,iBAAiB,UAAU,eAAM,CAAC;;EAGtD,8BAAA,kBAAA,MAAA,yBAC3B,iBAAgB;;EADW,IAAgB,YAAS;AAAA,UAAA,MAAA;;EAAzB,IAAgB,UAAS,OAAA;AAAA,SAAA,6BAAA;;EAG9C,oBAAiB;GACvB,MAAM,OAAO,MAAM,KAAK,KAAK,SAAS,CAAC,MAAM,OAAO,GAAG,cAAc,iBAAiB;AACtF,OAAI,KACF,MAAK,OAAO;GAGd,MAAM,QAAQ,MAAM,KAAK,KAAK,SAAS,CAAC,MAAM,OAAO,GAAG,cAAc,YAAY;AAClF,OAAI,MACF,OAAM,OAAO;;EAIT,eAAe,OAAY;GAEjC,MAAM,YAAa,MAAM,OACtB,kBAAkB,CAClB,MAAM,MAAgC,EAAE,cAAc,iBAAiB;AAE1E,OAAI,WAAW;AACb,mBAAe,QAAQ,UAAU;AACjC,cAAU,QAAQ;AAClB,cAAU,OAAO;;;EAIb,gBAAgB,OAAY;GAClC,MAAM,QAAS,MAAM,OAClB,kBAAkB,CAClB,MAAM,MAA4B,EAAE,cAAc,YAAY;AAEjE,OAAI,OAAO;AACT,mBAAe,QAAQ,MAAM;AAC7B,UAAM,cAAc;;;EAIL,SAAM;AAEvB,UAAO,MAAI;;UAEL,KAAK,WAEL,MAAI,2BAA2B,KAAK,mBAAkB,2BACvD,CAAA;UACC,KAAK,eAAe,CAAA;;;;EAKlB,gBAAa;AACrB,UAAO,MAAI;;;;;;0CAM2B,KAAK,eAAc;2CAClB,KAAK,gBAAe;;gCAE/B,KAAK,kBAAiB"}
|
package/development/teaser.js
CHANGED