@sbb-esta/lyne-elements-dev 4.9.0-dev.1775122363 → 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.
@@ -236,6 +236,9 @@ $theme: 'standard' !default;
236
236
  @use '../../tag/tag/tag.global' as tag with (
237
237
  $theme: $theme
238
238
  );
239
+ @use '../../teaser/teaser.global' as teaser with (
240
+ $theme: $theme
241
+ );
239
242
  @use '../../visual-checkbox/visual-checkbox.global' as visual-checkbox with (
240
243
  $theme: $theme
241
244
  );
@@ -314,6 +317,7 @@ $theme: 'standard' !default;
314
317
  @include tab-group-common.base;
315
318
  @include tab-label-common.base;
316
319
  @include tag.base;
320
+ @include teaser.base;
317
321
  @include visual-checkbox.base;
318
322
 
319
323
  @include a11y.if-forced-colors {
@@ -581,7 +585,6 @@ img {
581
585
  }
582
586
  }
583
587
 
584
- // TODO: Move back to the teaser components when the global CSS refactoring happens
585
588
  sbb-teaser :is(sbb-image, img):not(.sbb-figure-overlap-image) {
586
589
  --sbb-image-object-fit: cover;
587
590
  --sbb-image-aspect-ratio: 4 / 3;
package/core.css CHANGED
@@ -1734,6 +1734,15 @@ slot[name=error]::slotted(*) {
1734
1734
  --sbb-tag-amount-color: var(--sbb-color-metal);
1735
1735
  --sbb-tag-amount-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));
1736
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;
1737
1746
  --sbb-visual-checkbox-dimension: var(--sbb-checkbox-dimension-m);
1738
1747
  --sbb-visual-checkbox-selection-color: var(--sbb-color-primary);
1739
1748
  --sbb-visual-checkbox-selection-color-negative: var(--sbb-color-primary85);
@@ -1,2 +1,2 @@
1
- import { t as SbbTeaserElement } from "../teaser.component-C63t0z1I.js";
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"}
@@ -1,4 +1,4 @@
1
- import { t as SbbTeaserElement } from "./teaser.component-C63t0z1I.js";
1
+ import { t as SbbTeaserElement } from "./teaser.component-Cky6kKU0.js";
2
2
  import "./teaser.pure.js";
3
3
  //#region src/elements/teaser.ts
4
4
  /** @entrypoint */
@@ -1,2 +1,2 @@
1
- import { t as SbbTeaserElement } from "./teaser.component-C63t0z1I.js";
1
+ import { t as SbbTeaserElement } from "./teaser.component-Cky6kKU0.js";
2
2
  export { SbbTeaserElement };
@@ -1838,6 +1838,15 @@ slot[name=error]::slotted(*) {
1838
1838
  --sbb-tag-amount-color: var(--sbb-color-metal);
1839
1839
  --sbb-tag-amount-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));
1840
1840
  --sbb-tag-height: var(--sbb-size-element-xs);
1841
+ --sbb-teaser-scale-hover: 1.02;
1842
+ --sbb-teaser-description-color: var(--sbb-color-granite);
1843
+ --sbb-teaser-description-color: light-dark(var(--sbb-color-granite), var(--sbb-color-silver));
1844
+ --sbb-teaser-flex-direction: row;
1845
+ --sbb-teaser-align-items: center;
1846
+ --sbb-teaser-font-size: var(--sbb-text-font-size-s);
1847
+ --sbb-teaser-gap: var(--sbb-spacing-fixed-4x);
1848
+ --sbb-teaser-border-radius: var(--sbb-border-radius-4x);
1849
+ --sbb-teaser-image-width: 18.75rem;
1841
1850
  --sbb-visual-checkbox-dimension: var(--sbb-checkbox-dimension-m);
1842
1851
  --sbb-visual-checkbox-selection-color: var(--sbb-color-primary);
1843
1852
  --sbb-visual-checkbox-selection-color-negative: var(--sbb-color-primary85);
package/package.json CHANGED
@@ -1,12 +1,12 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements-dev",
3
- "version": "4.9.0-dev.1775122363",
3
+ "version": "4.9.0-dev.1775125441",
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/1d7d5b53274606711e17771379a5a25d3c9cc99e"
9
+ "https://github.com/sbb-design-systems/lyne-components/commit/681aeed89344a87388ed8e9e2006a9507fd6600c"
10
10
  ],
11
11
  "type": "module",
12
12
  "exports": {
package/safety-theme.css CHANGED
@@ -1838,6 +1838,15 @@ slot[name=error]::slotted(*) {
1838
1838
  --sbb-tag-amount-color: var(--sbb-color-metal);
1839
1839
  --sbb-tag-amount-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));
1840
1840
  --sbb-tag-height: var(--sbb-size-element-xs);
1841
+ --sbb-teaser-scale-hover: 1.02;
1842
+ --sbb-teaser-description-color: var(--sbb-color-granite);
1843
+ --sbb-teaser-description-color: light-dark(var(--sbb-color-granite), var(--sbb-color-silver));
1844
+ --sbb-teaser-flex-direction: row;
1845
+ --sbb-teaser-align-items: center;
1846
+ --sbb-teaser-font-size: var(--sbb-text-font-size-s);
1847
+ --sbb-teaser-gap: var(--sbb-spacing-fixed-4x);
1848
+ --sbb-teaser-border-radius: var(--sbb-border-radius-4x);
1849
+ --sbb-teaser-image-width: 18.75rem;
1841
1850
  --sbb-visual-checkbox-dimension: var(--sbb-checkbox-dimension-m);
1842
1851
  --sbb-visual-checkbox-selection-color: var(--sbb-color-primary);
1843
1852
  --sbb-visual-checkbox-selection-color-negative: var(--sbb-color-primary85);
@@ -1838,6 +1838,15 @@ slot[name=error]::slotted(*) {
1838
1838
  --sbb-tag-amount-color: var(--sbb-color-metal);
1839
1839
  --sbb-tag-amount-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));
1840
1840
  --sbb-tag-height: var(--sbb-size-element-xs);
1841
+ --sbb-teaser-scale-hover: 1.02;
1842
+ --sbb-teaser-description-color: var(--sbb-color-granite);
1843
+ --sbb-teaser-description-color: light-dark(var(--sbb-color-granite), var(--sbb-color-silver));
1844
+ --sbb-teaser-flex-direction: row;
1845
+ --sbb-teaser-align-items: center;
1846
+ --sbb-teaser-font-size: var(--sbb-text-font-size-s);
1847
+ --sbb-teaser-gap: var(--sbb-spacing-fixed-4x);
1848
+ --sbb-teaser-border-radius: var(--sbb-border-radius-4x);
1849
+ --sbb-teaser-image-width: 18.75rem;
1841
1850
  --sbb-visual-checkbox-dimension: var(--sbb-checkbox-dimension-m);
1842
1851
  --sbb-visual-checkbox-selection-color: var(--sbb-color-primary);
1843
1852
  --sbb-visual-checkbox-selection-color-negative: var(--sbb-color-primary85);
@@ -1,2 +1,2 @@
1
- import { t as e } from "../teaser.component-u1uLVhwo.js";
1
+ import { t as e } from "../teaser.component-WZL0vAo9.js";
2
2
  export { e as SbbTeaserElement };
@@ -0,0 +1,91 @@
1
+ import { __esDecorate as e, __runInitializers as t } from "tslib";
2
+ import { unsafeCSS as n } from "lit";
3
+ import { property as r } from "lit/decorators.js";
4
+ import { SbbLinkBaseElement as i } from "./core/base-elements.js";
5
+ import { boxSizingStyles as a } from "./core/styles.js";
6
+ import { html as o } from "lit/static-html.js";
7
+ import "./screen-reader-only.js";
8
+ //#region src/elements/teaser/teaser.scss?inline
9
+ var s = "@charset \"UTF-8\";:host{--_sbb-teaser-forced-colors-inset: calc(-1 * var(--sbb-focus-outline-offset));--_sbb-teaser-forced-colors-outline-offset: calc(2 * var(--sbb-focus-outline-offset));--_sbb-teaser-forced-colors-border-radius: calc( var(--sbb-teaser-border-radius) + var(--sbb-focus-outline-offset) );display:inline-block;outline:none!important}@media(forced-colors:active){:host{--sbb-teaser-description-color: LinkText;--sbb-title-text-color-normal-override: LinkText !important}}:host([alignment=after]){--sbb-teaser-align-items: start}:host([alignment=below]){--sbb-teaser-flex-direction: column;--sbb-teaser-align-items: baseline;--sbb-teaser-gap: var(--sbb-spacing-fixed-3x)}@media(any-hover:hover){:host(:hover){--sbb-teaser-scale: var(--sbb-teaser-scale-hover)}}.sbb-teaser__wrapper{display:flex;position:relative;cursor:var(--sbb-cursor-pointer)}.sbb-teaser__wrapper:before{content:\"​\";-webkit-user-select:none;user-select:none;width:0;height:0}.sbb-teaser{text-decoration:none;position:absolute;inset:0}.sbb-teaser:focus-visible{outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);border-radius:var(--sbb-teaser-border-radius)}@media(forced-colors:active){.sbb-teaser:focus-visible{outline-offset:var(--_sbb-teaser-forced-colors-outline-offset)}}@media(forced-colors:active){.sbb-teaser:before{content:\"\";position:absolute;inset:var(--_sbb-teaser-forced-colors-inset);pointer-events:none;border-radius:var(--_sbb-teaser-forced-colors-border-radius);border:var(--sbb-border-width-1x) solid CanvasText}}.sbb-teaser__container{display:flex;flex-flow:var(--sbb-teaser-flex-direction) nowrap;align-items:var(--sbb-teaser-align-items);gap:var(--sbb-teaser-gap);max-width:100%;width:100%;pointer-events:none}.sbb-teaser__text{color:var(--sbb-teaser-description-color);font-size:var(--sbb-teaser-font-size);letter-spacing:var(--sbb-typo-letter-spacing-text);overflow:hidden;max-width:100%}::slotted([slot=image]){display:block;width:var(--sbb-teaser-image-width)}.sbb-teaser__image-wrapper{flex-shrink:0;overflow:hidden;border-radius:var(--sbb-teaser-border-radius);transition:box-shadow var(--sbb-teaser-image-animation-duration) var(--sbb-animation-easing)}:host(:not(:is(:state(slotted-image),[state--slotted-image]))) .sbb-teaser__image-wrapper{display:none}@media(any-hover:hover){:host(:hover) .sbb-teaser__image-wrapper{box-shadow:var(--sbb-box-shadow-level-9-hard)}}.sbb-teaser__description{display:inline-block;margin:0;padding:0}::slotted(sbb-chip-label){display:block;max-width:fit-content;margin-block-end:var(--sbb-spacing-fixed-1x)}::slotted(sbb-title){margin-block:0}", c = (() => {
10
+ let c = i, l, u = [], d = [];
11
+ return class extends c {
12
+ static {
13
+ let t = typeof Symbol == "function" && Symbol.metadata ? Object.create(c[Symbol.metadata] ?? null) : void 0;
14
+ l = [r({ reflect: !0 })], e(this, null, l, {
15
+ kind: "accessor",
16
+ name: "alignment",
17
+ static: !1,
18
+ private: !1,
19
+ access: {
20
+ has: (e) => "alignment" in e,
21
+ get: (e) => e.alignment,
22
+ set: (e, t) => {
23
+ e.alignment = t;
24
+ }
25
+ },
26
+ metadata: t
27
+ }, u, d), t && Object.defineProperty(this, Symbol.metadata, {
28
+ enumerable: !0,
29
+ configurable: !0,
30
+ writable: !0,
31
+ value: t
32
+ });
33
+ }
34
+ static {
35
+ this.elementName = "sbb-teaser";
36
+ }
37
+ static {
38
+ this.styles = [a, n(s)];
39
+ }
40
+ #e = t(this, u, "after-centered");
41
+ get alignment() {
42
+ return this.#e;
43
+ }
44
+ set alignment(e) {
45
+ this.#e = e;
46
+ }
47
+ _handleSlotchange() {
48
+ let e = Array.from(this.children).find((e) => e.localName === "sbb-chip-label");
49
+ e && (e.slot = "chip");
50
+ let t = Array.from(this.children).find((e) => e.localName === "sbb-title");
51
+ t && (t.slot = "title");
52
+ }
53
+ _configureChip(e) {
54
+ let t = e.target.assignedElements().find((e) => e.localName === "sbb-chip-label");
55
+ t && (customElements.upgrade(t), t.color = "charcoal", t.size = "xxs");
56
+ }
57
+ _configureTitle(e) {
58
+ let t = e.target.assignedElements().find((e) => e.localName === "sbb-title");
59
+ t && (customElements.upgrade(t), t.visualLevel = "5");
60
+ }
61
+ render() {
62
+ return o`
63
+ <div class="sbb-teaser__wrapper">
64
+ ${this.renderLink(o`<sbb-screen-reader-only>${this.accessibilityLabel}</sbb-screen-reader-only>`)}
65
+ ${this.renderContent()}
66
+ </div>
67
+ `;
68
+ }
69
+ renderContent() {
70
+ return o`
71
+ <span class="sbb-teaser__container">
72
+ <span class="sbb-teaser__image-wrapper">
73
+ <slot name="image"></slot>
74
+ </span>
75
+ <span class="sbb-teaser__text">
76
+ <slot name="chip" @slotchange=${this._configureChip}></slot>
77
+ <slot name="title" @slotchange=${this._configureTitle}></slot>
78
+ <p class="sbb-teaser__description">
79
+ <slot @slotchange=${this._handleSlotchange}></slot>
80
+ </p>
81
+ </span>
82
+ </span>
83
+ `;
84
+ }
85
+ constructor() {
86
+ super(...arguments), t(this, d);
87
+ }
88
+ };
89
+ })();
90
+ //#endregion
91
+ export { c as t };
package/teaser.js CHANGED
@@ -1,4 +1,4 @@
1
- import { t as e } from "./teaser.component-u1uLVhwo.js";
1
+ import { t as e } from "./teaser.component-WZL0vAo9.js";
2
2
  import "./teaser.pure.js";
3
3
  //#region src/elements/teaser.ts
4
4
  e.define();
package/teaser.pure.js CHANGED
@@ -1,2 +1,2 @@
1
- import { t as e } from "./teaser.component-u1uLVhwo.js";
1
+ import { t as e } from "./teaser.component-WZL0vAo9.js";
2
2
  export { e as SbbTeaserElement };
@@ -1,118 +0,0 @@
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 display: inline-block;\n outline: none !important;\n --sbb-teaser-scale-hover: 1.02;\n --sbb-teaser-description-color: var(--sbb-color-granite);\n --sbb-teaser-description-color: light-dark(var(--sbb-color-granite), var(--sbb-color-silver));\n --sbb-teaser-flex-direction: row;\n --sbb-teaser-align-items: center;\n --sbb-teaser-gap: var(--sbb-spacing-fixed-4x);\n --sbb-teaser-border-radius: var(--sbb-border-radius-4x);\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: calc(2 * var(--sbb-focus-outline-offset));\n }\n}\n@media (forced-colors: active) {\n .sbb-teaser::before {\n content: \"\";\n position: absolute;\n inset: calc(-1 * var(--sbb-focus-outline-offset));\n pointer-events: none;\n border-radius: calc(var(--sbb-teaser-border-radius) + var(--sbb-focus-outline-offset));\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 --sbb-text-font-size: var(--sbb-text-font-size-s);\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-teaser-description-color);\n overflow: hidden;\n max-width: 100%;\n}\n\n::slotted([slot=image]) {\n width: 18.75rem;\n display: block;\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-C63t0z1I.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  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  --sbb-teaser-scale-hover: 1.02;\n  --sbb-teaser-description-color: light-dark(var(--sbb-color-granite), var(--sbb-color-silver));\n  --sbb-teaser-flex-direction: row;\n  --sbb-teaser-align-items: center;\n  --sbb-teaser-gap: var(--sbb-spacing-fixed-4x);\n  --sbb-teaser-border-radius: var(--sbb-border-radius-4x);\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: calc(2 * var(--sbb-focus-outline-offset));\n    }\n  }\n\n  @include sbb.if-forced-colors {\n    &::before {\n      content: '';\n      position: absolute;\n      inset: calc(-1 * var(--sbb-focus-outline-offset));\n      pointer-events: none;\n      border-radius: calc(var(--sbb-teaser-border-radius) + var(--sbb-focus-outline-offset));\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  @include sbb.text-s--regular;\n\n  color: var(--sbb-teaser-description-color);\n  overflow: hidden;\n  max-width: 100%;\n}\n\n::slotted([slot='image']) {\n  width: #{sbb.px-to-rem-build(300)};\n  display: block;\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"}
@@ -1,91 +0,0 @@
1
- import { __esDecorate as e, __runInitializers as t } from "tslib";
2
- import { unsafeCSS as n } from "lit";
3
- import { property as r } from "lit/decorators.js";
4
- import { SbbLinkBaseElement as i } from "./core/base-elements.js";
5
- import { boxSizingStyles as a } from "./core/styles.js";
6
- import { html as o } from "lit/static-html.js";
7
- import "./screen-reader-only.js";
8
- //#region src/elements/teaser/teaser.scss?inline
9
- var s = "@charset \"UTF-8\";:host{display:inline-block;outline:none!important;--sbb-teaser-scale-hover: 1.02;--sbb-teaser-description-color: var(--sbb-color-granite);--sbb-teaser-description-color: light-dark(var(--sbb-color-granite), var(--sbb-color-silver));--sbb-teaser-flex-direction: row;--sbb-teaser-align-items: center;--sbb-teaser-gap: var(--sbb-spacing-fixed-4x);--sbb-teaser-border-radius: var(--sbb-border-radius-4x)}@media(forced-colors:active){:host{--sbb-teaser-description-color: LinkText;--sbb-title-text-color-normal-override: LinkText !important}}:host([alignment=after]){--sbb-teaser-align-items: start}:host([alignment=below]){--sbb-teaser-flex-direction: column;--sbb-teaser-align-items: baseline;--sbb-teaser-gap: var(--sbb-spacing-fixed-3x)}@media(any-hover:hover){:host(:hover){--sbb-teaser-scale: var(--sbb-teaser-scale-hover)}}.sbb-teaser__wrapper{display:flex;position:relative;cursor:var(--sbb-cursor-pointer)}.sbb-teaser__wrapper:before{content:\"​\";-webkit-user-select:none;user-select:none;width:0;height:0}.sbb-teaser{text-decoration:none;position:absolute;inset:0}.sbb-teaser:focus-visible{outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);border-radius:var(--sbb-teaser-border-radius)}@media(forced-colors:active){.sbb-teaser:focus-visible{outline-offset:calc(2 * var(--sbb-focus-outline-offset))}}@media(forced-colors:active){.sbb-teaser:before{content:\"\";position:absolute;inset:calc(-1 * var(--sbb-focus-outline-offset));pointer-events:none;border-radius:calc(var(--sbb-teaser-border-radius) + var(--sbb-focus-outline-offset));border:var(--sbb-border-width-1x) solid CanvasText}}.sbb-teaser__container{display:flex;flex-flow:var(--sbb-teaser-flex-direction) nowrap;align-items:var(--sbb-teaser-align-items);gap:var(--sbb-teaser-gap);max-width:100%;width:100%;pointer-events:none}.sbb-teaser__text{--sbb-text-font-size: var(--sbb-text-font-size-s);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-teaser-description-color);overflow:hidden;max-width:100%}::slotted([slot=image]){width:18.75rem;display:block}.sbb-teaser__image-wrapper{flex-shrink:0;overflow:hidden;border-radius:var(--sbb-teaser-border-radius);transition:box-shadow var(--sbb-teaser-image-animation-duration) var(--sbb-animation-easing)}:host(:not(:is(:state(slotted-image),[state--slotted-image]))) .sbb-teaser__image-wrapper{display:none}@media(any-hover:hover){:host(:hover) .sbb-teaser__image-wrapper{box-shadow:var(--sbb-box-shadow-level-9-hard)}}.sbb-teaser__description{display:inline-block;margin:0;padding:0}::slotted(sbb-chip-label){display:block;max-width:fit-content;margin-block-end:var(--sbb-spacing-fixed-1x)}::slotted(sbb-title){margin-block:0}", c = (() => {
10
- let c = i, l, u = [], d = [];
11
- return class extends c {
12
- static {
13
- let t = typeof Symbol == "function" && Symbol.metadata ? Object.create(c[Symbol.metadata] ?? null) : void 0;
14
- l = [r({ reflect: !0 })], e(this, null, l, {
15
- kind: "accessor",
16
- name: "alignment",
17
- static: !1,
18
- private: !1,
19
- access: {
20
- has: (e) => "alignment" in e,
21
- get: (e) => e.alignment,
22
- set: (e, t) => {
23
- e.alignment = t;
24
- }
25
- },
26
- metadata: t
27
- }, u, d), t && Object.defineProperty(this, Symbol.metadata, {
28
- enumerable: !0,
29
- configurable: !0,
30
- writable: !0,
31
- value: t
32
- });
33
- }
34
- static {
35
- this.elementName = "sbb-teaser";
36
- }
37
- static {
38
- this.styles = [a, n(s)];
39
- }
40
- #e = t(this, u, "after-centered");
41
- get alignment() {
42
- return this.#e;
43
- }
44
- set alignment(e) {
45
- this.#e = e;
46
- }
47
- _handleSlotchange() {
48
- let e = Array.from(this.children).find((e) => e.localName === "sbb-chip-label");
49
- e && (e.slot = "chip");
50
- let t = Array.from(this.children).find((e) => e.localName === "sbb-title");
51
- t && (t.slot = "title");
52
- }
53
- _configureChip(e) {
54
- let t = e.target.assignedElements().find((e) => e.localName === "sbb-chip-label");
55
- t && (customElements.upgrade(t), t.color = "charcoal", t.size = "xxs");
56
- }
57
- _configureTitle(e) {
58
- let t = e.target.assignedElements().find((e) => e.localName === "sbb-title");
59
- t && (customElements.upgrade(t), t.visualLevel = "5");
60
- }
61
- render() {
62
- return o`
63
- <div class="sbb-teaser__wrapper">
64
- ${this.renderLink(o`<sbb-screen-reader-only>${this.accessibilityLabel}</sbb-screen-reader-only>`)}
65
- ${this.renderContent()}
66
- </div>
67
- `;
68
- }
69
- renderContent() {
70
- return o`
71
- <span class="sbb-teaser__container">
72
- <span class="sbb-teaser__image-wrapper">
73
- <slot name="image"></slot>
74
- </span>
75
- <span class="sbb-teaser__text">
76
- <slot name="chip" @slotchange=${this._configureChip}></slot>
77
- <slot name="title" @slotchange=${this._configureTitle}></slot>
78
- <p class="sbb-teaser__description">
79
- <slot @slotchange=${this._handleSlotchange}></slot>
80
- </p>
81
- </span>
82
- </span>
83
- `;
84
- }
85
- constructor() {
86
- super(...arguments), t(this, d);
87
- }
88
- };
89
- })();
90
- //#endregion
91
- export { c as t };