@sbb-esta/lyne-elements 3.13.0 → 3.13.2

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.
@@ -21,7 +21,8 @@ export declare class SbbCarouselElement extends SbbCarouselElement_base {
21
21
  firstUpdated(_changedProperties: PropertyValues): void;
22
22
  disconnectedCallback(): void;
23
23
  private _handleSlotchange;
24
- private _scrollAtPageChange;
24
+ private _setupPaginator;
25
+ private _scrollAtPaginatorChange;
25
26
  protected render(): TemplateResult;
26
27
  }
27
28
  declare global {
@@ -1 +1 @@
1
- {"version":3,"file":"carousel.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/carousel/carousel/carousel.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AAmBvC,OAAO,6BAA6B,CAAC;;AAIrC;;;;GAIG;AACH,qBAEM,kBAAmB,SAAQ,uBAAoC;IACnE,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD;;OAEG;IACH,SAEgB,MAAM,EAAE,OAAO,CAAS;IAExC,OAAO,CAAC,UAAU,CAA2C;IAC7D,OAAO,CAAC,gBAAgB,CAAgC;IACxD,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,8BAA8B,CAAM;;IAwB5B,iBAAiB,IAAI,IAAI;IAOzB,YAAY,CAAC,kBAAkB,EAAE,cAAc,GAAG,IAAI;IAQtD,oBAAoB,IAAI,IAAI;IAK5C,OAAO,CAAC,iBAAiB;IA4BzB,OAAO,CAAC,mBAAmB;cAoBR,MAAM,IAAI,cAAc;CAU5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,cAAc,EAAE,kBAAkB,CAAC;KACpC;CACF"}
1
+ {"version":3,"file":"carousel.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/carousel/carousel/carousel.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AAmBvC,OAAO,6BAA6B,CAAC;;AAIrC;;;;GAIG;AACH,qBAEM,kBAAmB,SAAQ,uBAAoC;IACnE,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD;;OAEG;IACH,SAEgB,MAAM,EAAE,OAAO,CAAS;IAExC,OAAO,CAAC,UAAU,CAA2C;IAC7D,OAAO,CAAC,gBAAgB,CAAgC;IACxD,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,8BAA8B,CAAM;;IAwB5B,iBAAiB,IAAI,IAAI;IASzB,YAAY,CAAC,kBAAkB,EAAE,cAAc,GAAG,IAAI;IAQtD,oBAAoB,IAAI,IAAI;IAK5C,OAAO,CAAC,iBAAiB;IAyBzB,OAAO,CAAC,eAAe;IAgBvB,OAAO,CAAC,wBAAwB;cAwBb,MAAM,IAAI,cAAc;CAU5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,cAAc,EAAE,kBAAkB,CAAC;KACpC;CACF"}
@@ -1,24 +1,24 @@
1
- var v = (a) => {
1
+ var p = (a) => {
2
2
  throw TypeError(a);
3
3
  };
4
- var m = (a, s, r) => s.has(a) || v("Cannot " + r);
5
- var p = (a, s, r) => (m(a, s, "read from private field"), r ? r.call(a) : s.get(a)), _ = (a, s, r) => s.has(a) ? v("Cannot add the same private member more than once") : s instanceof WeakSet ? s.add(a) : s.set(a, r), b = (a, s, r, o) => (m(a, s, "write to private field"), o ? o.call(a, r) : s.set(a, r), r);
4
+ var _ = (a, t, s) => t.has(a) || p("Cannot " + s);
5
+ var v = (a, t, s) => (_(a, t, "read from private field"), s ? s.call(a) : t.get(a)), m = (a, t, s) => t.has(a) ? p("Cannot add the same private member more than once") : t instanceof WeakSet ? t.add(a) : t.set(a, s), b = (a, t, s, r) => (_(a, t, "write to private field"), r ? r.call(a, s) : t.set(a, s), s);
6
6
  import { __esDecorate as w, __runInitializers as c } from "tslib";
7
7
  import { css as y, LitElement as x, html as P } from "lit";
8
8
  import { customElement as S, property as C } from "lit/decorators.js";
9
9
  import { SbbLanguageController as I } from "../../core/controllers/language-controller.js";
10
- import { forceType as L } from "../../core/decorators.js";
11
- import { i18nNextSlide as k, i18nPreviousSlide as q, i18nSlide as A, i18nCarouselArrowsNavigationHint as E } from "../../core/i18n/i18n.js";
10
+ import { forceType as k } from "../../core/decorators.js";
11
+ import { i18nNextSlide as L, i18nPreviousSlide as q, i18nSlide as A, i18nCarouselArrowsNavigationHint as E } from "../../core/i18n/i18n.js";
12
12
  import { SbbElementInternalsMixin as B } from "../../core/mixins.js";
13
13
  import "../../screen-reader-only.js";
14
14
  const z = y`*,:before,:after{box-sizing:border-box}:host{--sbb-carousel-border-radius: var(--sbb-border-radius-4x);--sbb-carousel-background-color: var(--sbb-background-color-1);display:inline-block;overflow:hidden;border-radius:var(--sbb-carousel-border-radius) var(--sbb-carousel-border-radius) 0 0}:host([shadow]){box-shadow:var(--sbb-shadow-elevation-level-9-shadow-2-offset-x) var(--sbb-shadow-elevation-level-9-shadow-2-offset-y) var(--sbb-shadow-elevation-level-9-shadow-2-blur) var(--sbb-shadow-elevation-level-9-shadow-2-spread) var(--sbb-shadow-color-hard-2),var(--sbb-shadow-elevation-level-9-shadow-1-offset-x) var(--sbb-shadow-elevation-level-9-shadow-1-offset-y) var(--sbb-shadow-elevation-level-9-shadow-1-blur) var(--sbb-shadow-elevation-level-9-shadow-1-spread) var(--sbb-shadow-color-hard-1);border-radius:var(--sbb-carousel-border-radius)}:host(:not([shadow])) ::slotted(sbb-carousel-list){--sbb-carousel-inherit-border-radius: var(--sbb-carousel-border-radius)}.sbb-carousel{display:flex;flex-direction:column;justify-content:center;align-items:center;background-color:var(--sbb-carousel-background-color)}::slotted(sbb-compact-paginator){padding:var(--sbb-spacing-responsive-xs)}`;
15
15
  let W = (() => {
16
- var n, l;
17
- let a = [S("sbb-carousel")], s, r = [], o, h = B(x), u, g = [], f = [];
18
- return l = class extends h {
16
+ var n, i;
17
+ let a = [S("sbb-carousel")], t, s = [], r, h = B(x), u, g = [], f = [];
18
+ return i = class extends h {
19
19
  constructor() {
20
20
  super();
21
- _(this, n);
21
+ m(this, n);
22
22
  b(this, n, c(this, g, !1)), this._paginator = (c(this, f), null), this._abortController = null, this._language = new I(this), this._requestedPageIndexByPaginator = -1, this.addEventListener?.("show", (e) => {
23
23
  this._requestedPageIndexByPaginator !== -1 && this._requestedPageIndexByPaginator !== e.detail.index || (this._paginator && e.detail.index !== this._paginator.pageIndex && (this._paginator.pageIndex = e.detail.index), this._requestedPageIndexByPaginator = -1);
24
24
  });
@@ -27,13 +27,13 @@ let W = (() => {
27
27
  * Used to display a box-shadow around the component.
28
28
  */
29
29
  get shadow() {
30
- return p(this, n);
30
+ return v(this, n);
31
31
  }
32
32
  set shadow(e) {
33
33
  b(this, n, e);
34
34
  }
35
35
  connectedCallback() {
36
- super.connectedCallback(), this.internals.role = "region", this.internals.ariaLabel = "carousel";
36
+ super.connectedCallback(), this.internals.role = "region", this.internals.ariaLabel = "carousel", this._setupPaginator();
37
37
  }
38
38
  firstUpdated(e) {
39
39
  super.firstUpdated(e), this.internals.ariaDescribedByElements = [
@@ -44,20 +44,25 @@ let W = (() => {
44
44
  super.disconnectedCallback(), this._abortController?.abort();
45
45
  }
46
46
  _handleSlotchange() {
47
- const e = Array.from(this.children).find((i) => i.localName === "sbb-compact-paginator"), t = Array.from(this.children).find((i) => i.localName === "sbb-carousel-list");
48
- if (!e || !t)
47
+ const e = Array.from(this.children).find((d) => d.localName === "sbb-compact-paginator"), o = Array.from(this.children).find((d) => d.localName === "sbb-carousel-list");
48
+ if (!e || !o)
49
49
  return;
50
- const d = t.querySelectorAll("sbb-carousel-item");
51
- d && d.length > 0 && (e.length = d.length, e.pageSize = 1), e.accessibilityNextPageLabel ||= k[this._language.current], e.accessibilityPreviousPageLabel ||= q[this._language.current], e.accessibilityPageLabel ||= A[this._language.current], e !== this._paginator && (this._abortController = new AbortController(), e.addEventListener("page", (i) => this._scrollAtPageChange(i), {
50
+ const l = o.querySelectorAll("sbb-carousel-item");
51
+ l && l.length > 0 && (e.length = l.length, e.pageSize = 1), e.accessibilityNextPageLabel ||= L[this._language.current], e.accessibilityPreviousPageLabel ||= q[this._language.current], e.accessibilityPageLabel ||= A[this._language.current], e !== this._paginator && (this._paginator = e, this._setupPaginator());
52
+ }
53
+ _setupPaginator() {
54
+ this._abortController?.abort(), this._paginator && (this._abortController = new AbortController(), this._paginator.addEventListener("click", () => this._scrollAtPaginatorChange(), {
52
55
  signal: this._abortController.signal
53
- }), this._paginator = e);
56
+ }));
54
57
  }
55
- _scrollAtPageChange(e) {
56
- this._requestedPageIndexByPaginator = e.detail.pageIndex;
57
- const t = this.querySelector("sbb-carousel-list");
58
- if (t) {
59
- const i = t.querySelectorAll("sbb-carousel-item")[e.detail.pageIndex].offsetLeft - this.offsetLeft;
60
- (t.clientWidth <= 100 || Math.abs(t.scrollLeft - i) > 50) && t.scrollTo({ left: i });
58
+ _scrollAtPaginatorChange() {
59
+ if (!this._paginator)
60
+ return;
61
+ this._requestedPageIndexByPaginator = this._paginator.pageIndex;
62
+ const e = this.querySelector("sbb-carousel-list");
63
+ if (e) {
64
+ const l = e.querySelectorAll("sbb-carousel-item")[this._paginator.pageIndex].offsetLeft - this.offsetLeft;
65
+ (e.clientWidth <= 100 || Math.abs(e.scrollLeft - l) > 50) && e.scrollTo({ left: l });
61
66
  }
62
67
  }
63
68
  render() {
@@ -70,12 +75,12 @@ let W = (() => {
70
75
  </div>
71
76
  `;
72
77
  }
73
- }, n = new WeakMap(), o = l, (() => {
78
+ }, n = new WeakMap(), r = i, (() => {
74
79
  const e = typeof Symbol == "function" && Symbol.metadata ? Object.create(h[Symbol.metadata] ?? null) : void 0;
75
- u = [L(), C({ reflect: !0, type: Boolean })], w(l, null, u, { kind: "accessor", name: "shadow", static: !1, private: !1, access: { has: (t) => "shadow" in t, get: (t) => t.shadow, set: (t, d) => {
76
- t.shadow = d;
77
- } }, metadata: e }, g, f), w(null, s = { value: o }, a, { kind: "class", name: o.name, metadata: e }, null, r), o = s.value, e && Object.defineProperty(o, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: e });
78
- })(), l.styles = z, c(o, r), o;
80
+ u = [k(), C({ reflect: !0, type: Boolean })], w(i, null, u, { kind: "accessor", name: "shadow", static: !1, private: !1, access: { has: (o) => "shadow" in o, get: (o) => o.shadow, set: (o, l) => {
81
+ o.shadow = l;
82
+ } }, metadata: e }, g, f), w(null, t = { value: r }, a, { kind: "class", name: r.name, metadata: e }, null, s), r = t.value, e && Object.defineProperty(r, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: e });
83
+ })(), i.styles = z, c(r, s), r;
79
84
  })();
80
85
  export {
81
86
  W as SbbCarouselElement
@@ -12,7 +12,7 @@ export declare class SbbCarouselListElement extends SbbCarouselListElement_base
12
12
  private _observedCarouselItems;
13
13
  private _beforeShowObserver;
14
14
  private _showObserver;
15
- private _firstVisibleIntersectionController;
15
+ private _resizeObserverController;
16
16
  constructor();
17
17
  /** Gets the slotted items. */
18
18
  private _carouselItems;
@@ -1 +1 @@
1
- {"version":3,"file":"carousel-list.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/carousel/carousel-list/carousel-list.component.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,cAAc,EAAkB,UAAU,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;;AAc3F;;;;GAIG;AACH,qBAEM,sBAAuB,SAAQ,2BAAoC;IACvE,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,OAAO,CAAC,aAAa,CAAK;IAC1B,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,sBAAsB,CAAgC;IAE9D,OAAO,CAAC,mBAAmB,CAgBxB;IAEH,OAAO,CAAC,aAAa,CAwBlB;IAGH,OAAO,CAAC,mCAAmC,CAYxC;;IAQH,8BAA8B;IAC9B,OAAO,CAAC,cAAc;IAItB,OAAO,CAAC,iBAAiB;IAoBzB;;;OAGG;IACH,OAAO,CAAC,eAAe;IAwBvB,OAAO,CAAC,UAAU;IAwBF,iBAAiB,IAAI,IAAI;cAOtB,MAAM,IAAI,cAAc;CAG5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,mBAAmB,EAAE,sBAAsB,CAAC;KAC7C;CACF"}
1
+ {"version":3,"file":"carousel-list.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/carousel/carousel-list/carousel-list.component.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,cAAc,EAAQ,UAAU,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;;AAcjF;;;;GAIG;AACH,qBAEM,sBAAuB,SAAQ,2BAAoC;IACvE,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,OAAO,CAAC,aAAa,CAAK;IAC1B,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,sBAAsB,CAAgC;IAE9D,OAAO,CAAC,mBAAmB,CAgBxB;IAEH,OAAO,CAAC,aAAa,CAwBlB;IAEH,OAAO,CAAC,yBAAyB,CAG9B;;IAQH,8BAA8B;IAC9B,OAAO,CAAC,cAAc;IAItB,OAAO,CAAC,iBAAiB;IAoBzB;;;OAGG;IACH,OAAO,CAAC,eAAe;IAyBvB,OAAO,CAAC,UAAU;IAwBF,iBAAiB,IAAI,IAAI;cAOtB,MAAM,IAAI,cAAc;CAG5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,mBAAmB,EAAE,sBAAsB,CAAC;KAC7C;CACF"}
@@ -1,38 +1,39 @@
1
1
  import { __esDecorate as b, __runInitializers as d } from "tslib";
2
- import { IntersectionController as n } from "@lit-labs/observers/intersection-controller.js";
3
- import { css as f, LitElement as m, isServer as _, html as v } from "lit";
2
+ import { IntersectionController as c } from "@lit-labs/observers/intersection-controller.js";
3
+ import { ResizeController as f } from "@lit-labs/observers/resize-controller.js";
4
+ import { css as m, LitElement as _, html as v } from "lit";
4
5
  import { customElement as g } from "lit/decorators.js";
5
6
  import { isArrowKeyPressed as I } from "../../core/a11y.js";
6
- import { SbbLanguageController as w } from "../../core/controllers.js";
7
- import { i18nCarouselItemAriaLabel as p } from "../../core/i18n.js";
7
+ import { SbbLanguageController as p } from "../../core/controllers.js";
8
+ import { i18nCarouselItemAriaLabel as w } from "../../core/i18n.js";
8
9
  import { SbbElementInternalsMixin as x } from "../../core/mixins.js";
9
- const y = f`*,:before,:after{box-sizing:border-box}:host{--sbb-carousel-list-border-radius: var(--sbb-border-radius-4x);display:flex;height:var(--sbb-carousel-list-height);width:var(--sbb-carousel-list-width, 0);overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;outline:none;border-radius:var(--sbb-carousel-inherit-border-radius)}:host(:focus-visible):before{outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);content:"";position:absolute;height:inherit;width:inherit;border-start-start-radius:var(--sbb-carousel-list-border-radius);border-start-end-radius:var(--sbb-carousel-list-border-radius);border-end-start-radius:var(--sbb-carousel-inherit-border-radius);border-end-end-radius:var(--sbb-carousel-inherit-border-radius)}`;
10
+ const y = m`*,:before,:after{box-sizing:border-box}:host{--sbb-carousel-list-border-radius: var(--sbb-border-radius-4x);display:flex;height:var(--sbb-carousel-list-height);width:var(--sbb-carousel-list-width, 0);overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;scrollbar-width:none;outline:none;border-radius:var(--sbb-carousel-inherit-border-radius)}:host(:focus-visible):before{outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);content:"";position:absolute;height:inherit;width:inherit;border-start-start-radius:var(--sbb-carousel-list-border-radius);border-start-end-radius:var(--sbb-carousel-list-border-radius);border-end-start-radius:var(--sbb-carousel-inherit-border-radius);border-end-end-radius:var(--sbb-carousel-inherit-border-radius)}`;
10
11
  let H = (() => {
11
- var i;
12
- let u = [g("sbb-carousel-list")], a, l = [], s, c = x(m);
13
- return i = class extends c {
12
+ var o;
13
+ let u = [g("sbb-carousel-list")], n, a = [], s, l = x(_);
14
+ return o = class extends l {
14
15
  constructor() {
15
- super(), this._currentIndex = 0, this._language = new w(this), this._observedCarouselItems = [], this._beforeShowObserver = new n(this, {
16
+ super(), this._currentIndex = 0, this._language = new p(this), this._observedCarouselItems = [], this._beforeShowObserver = new c(this, {
16
17
  target: null,
17
18
  callback: (e) => {
18
19
  e.filter((r) => r.isIntersecting && r.target !== this).forEach((r) => {
19
- const o = r.target;
20
- o.dispatchEvent(new CustomEvent("beforeshow", {
21
- detail: { index: this._carouselItems().findIndex((h) => h === o) },
20
+ const i = r.target;
21
+ i.dispatchEvent(new CustomEvent("beforeshow", {
22
+ detail: { index: this._carouselItems().findIndex((h) => h === i) },
22
23
  bubbles: !0,
23
24
  composed: !0
24
25
  }));
25
26
  });
26
27
  },
27
28
  config: { threshold: 0.01, root: this, rootMargin: "100% 0% 100% 0%" }
28
- }), this._showObserver = new n(this, {
29
+ }), this._showObserver = new c(this, {
29
30
  target: null,
30
31
  callback: (e) => {
31
32
  for (const t of e) {
32
33
  if (t.target === this)
33
34
  continue;
34
35
  const r = t.target;
35
- t.isIntersecting ? (r.ariaHidden = null, this._currentIndex = this._carouselItems().findIndex((o) => o === r), r.dispatchEvent(new CustomEvent("show", {
36
+ t.isIntersecting ? (r.ariaHidden = null, this._currentIndex = this._carouselItems().findIndex((i) => i === r), r.dispatchEvent(new CustomEvent("show", {
36
37
  detail: { index: this._currentIndex },
37
38
  bubbles: !0,
38
39
  composed: !0
@@ -40,15 +41,9 @@ let H = (() => {
40
41
  }
41
42
  },
42
43
  config: { threshold: 0.99, root: this, rootMargin: "100% 0% 100% 0%" }
43
- }), this._firstVisibleIntersectionController = new n(this, {
44
- callback: (e) => {
45
- e.forEach((t) => {
46
- t.intersectionRatio > 0 && (this._readDimensions(), this._firstVisibleIntersectionController.unobserve(this));
47
- });
48
- },
49
- config: {
50
- root: _ ? null : document?.documentElement
51
- }
44
+ }), this._resizeObserverController = new f(this, {
45
+ skipInitial: !0,
46
+ callback: () => this._readDimensions()
52
47
  }), this.addEventListener?.("keydown", (e) => this._onKeyDown(e));
53
48
  }
54
49
  /** Gets the slotted items. */
@@ -61,7 +56,7 @@ let H = (() => {
61
56
  });
62
57
  const e = this._carouselItems();
63
58
  e.forEach((t, r) => {
64
- t.ariaLabel ||= p(r + 1, e.length)[this._language.current], t.ariaHidden = r === this._currentIndex ? null : "true";
59
+ t.ariaLabel ||= w(r + 1, e.length)[this._language.current], t.ariaHidden = r === this._currentIndex ? null : "true";
65
60
  }), this._readDimensions();
66
61
  }
67
62
  /**
@@ -75,15 +70,15 @@ let H = (() => {
75
70
  const t = e[0];
76
71
  t.clientHeight > 0 && this.style.setProperty("--sbb-carousel-list-height", `${t.clientHeight}px`), t.clientWidth > 0 && (this.style.setProperty("--sbb-carousel-list-width", `${t.clientWidth}px`), e.forEach((r) => {
77
72
  this._beforeShowObserver.observe(r), this._showObserver.observe(r);
78
- }), this._observedCarouselItems = e);
73
+ }), this._observedCarouselItems = e, this._resizeObserverController.unobserve(this));
79
74
  }
80
75
  _onKeyDown(e) {
81
76
  if (!I(e))
82
77
  return;
83
78
  e.preventDefault();
84
79
  let t = this._currentIndex;
85
- const r = e.key === "ArrowUp" || e.key === "ArrowLeft", o = e.key === "ArrowDown" || e.key === "ArrowRight";
86
- r ? t = Math.max(0, this._currentIndex - 1) : o && (t = Math.min(this._carouselItems().length - 1, this._currentIndex + 1)), t !== this._currentIndex && (this._currentIndex = t, this.scrollTo({
80
+ const r = e.key === "ArrowUp" || e.key === "ArrowLeft", i = e.key === "ArrowDown" || e.key === "ArrowRight";
81
+ r ? t = Math.max(0, this._currentIndex - 1) : i && (t = Math.min(this._carouselItems().length - 1, this._currentIndex + 1)), t !== this._currentIndex && (this._currentIndex = t, this.scrollTo({
87
82
  left: this._carouselItems()[this._currentIndex].offsetLeft - this.offsetLeft
88
83
  }));
89
84
  }
@@ -93,10 +88,10 @@ let H = (() => {
93
88
  render() {
94
89
  return v`<slot @slotchange=${this._handleSlotchange}></slot>`;
95
90
  }
96
- }, s = i, (() => {
97
- const e = typeof Symbol == "function" && Symbol.metadata ? Object.create(c[Symbol.metadata] ?? null) : void 0;
98
- b(null, a = { value: s }, u, { kind: "class", name: s.name, metadata: e }, null, l), s = a.value, e && Object.defineProperty(s, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: e });
99
- })(), i.styles = y, d(s, l), s;
91
+ }, s = o, (() => {
92
+ const e = typeof Symbol == "function" && Symbol.metadata ? Object.create(l[Symbol.metadata] ?? null) : void 0;
93
+ b(null, n = { value: s }, u, { kind: "class", name: s.name, metadata: e }, null, a), s = n.value, e && Object.defineProperty(s, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: e });
94
+ })(), o.styles = y, d(s, a), s;
100
95
  })();
101
96
  export {
102
97
  H as SbbCarouselListElement
@@ -39229,21 +39229,23 @@
39229
39229
  },
39230
39230
  {
39231
39231
  "kind": "method",
39232
- "name": "_scrollAtPageChange",
39232
+ "name": "_setupPaginator",
39233
39233
  "privacy": "private",
39234
39234
  "return": {
39235
39235
  "type": {
39236
39236
  "text": "void"
39237
39237
  }
39238
- },
39239
- "parameters": [
39240
- {
39241
- "name": "e",
39242
- "type": {
39243
- "text": "CustomEvent<SbbPaginatorPageEventDetails>"
39244
- }
39238
+ }
39239
+ },
39240
+ {
39241
+ "kind": "method",
39242
+ "name": "_scrollAtPaginatorChange",
39243
+ "privacy": "private",
39244
+ "return": {
39245
+ "type": {
39246
+ "text": "void"
39245
39247
  }
39246
- ]
39248
+ }
39247
39249
  },
39248
39250
  {
39249
39251
  "kind": "method",
@@ -39477,9 +39479,9 @@
39477
39479
  },
39478
39480
  {
39479
39481
  "kind": "field",
39480
- "name": "_firstVisibleIntersectionController",
39482
+ "name": "_resizeObserverController",
39481
39483
  "privacy": "private",
39482
- "default": "new IntersectionController(this, { callback: (entries) => { entries.forEach((entry) => { if (entry.intersectionRatio > 0) { this._readDimensions(); this._firstVisibleIntersectionController.unobserve(this); } }); }, config: { root: !isServer ? document?.documentElement : null, }, })"
39484
+ "default": "new ResizeController(this, { skipInitial: true, callback: () => this._readDimensions(), })"
39483
39485
  },
39484
39486
  {
39485
39487
  "kind": "method",
@@ -21,7 +21,8 @@ export declare class SbbCarouselElement extends SbbCarouselElement_base {
21
21
  firstUpdated(_changedProperties: PropertyValues): void;
22
22
  disconnectedCallback(): void;
23
23
  private _handleSlotchange;
24
- private _scrollAtPageChange;
24
+ private _setupPaginator;
25
+ private _scrollAtPaginatorChange;
25
26
  protected render(): TemplateResult;
26
27
  }
27
28
  declare global {
@@ -1 +1 @@
1
- {"version":3,"file":"carousel.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/carousel/carousel/carousel.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AAmBvC,OAAO,6BAA6B,CAAC;;AAIrC;;;;GAIG;AACH,qBAEM,kBAAmB,SAAQ,uBAAoC;IACnE,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD;;OAEG;IACH,SAEgB,MAAM,EAAE,OAAO,CAAS;IAExC,OAAO,CAAC,UAAU,CAA2C;IAC7D,OAAO,CAAC,gBAAgB,CAAgC;IACxD,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,8BAA8B,CAAM;;IAwB5B,iBAAiB,IAAI,IAAI;IAOzB,YAAY,CAAC,kBAAkB,EAAE,cAAc,GAAG,IAAI;IAQtD,oBAAoB,IAAI,IAAI;IAK5C,OAAO,CAAC,iBAAiB;IA4BzB,OAAO,CAAC,mBAAmB;cAoBR,MAAM,IAAI,cAAc;CAU5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,cAAc,EAAE,kBAAkB,CAAC;KACpC;CACF"}
1
+ {"version":3,"file":"carousel.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/carousel/carousel/carousel.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AAmBvC,OAAO,6BAA6B,CAAC;;AAIrC;;;;GAIG;AACH,qBAEM,kBAAmB,SAAQ,uBAAoC;IACnE,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD;;OAEG;IACH,SAEgB,MAAM,EAAE,OAAO,CAAS;IAExC,OAAO,CAAC,UAAU,CAA2C;IAC7D,OAAO,CAAC,gBAAgB,CAAgC;IACxD,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,8BAA8B,CAAM;;IAwB5B,iBAAiB,IAAI,IAAI;IASzB,YAAY,CAAC,kBAAkB,EAAE,cAAc,GAAG,IAAI;IAQtD,oBAAoB,IAAI,IAAI;IAK5C,OAAO,CAAC,iBAAiB;IAyBzB,OAAO,CAAC,eAAe;IAgBvB,OAAO,CAAC,wBAAwB;cAwBb,MAAM,IAAI,cAAc;CAU5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,cAAc,EAAE,kBAAkB,CAAC;KACpC;CACF"}
@@ -91,6 +91,7 @@ let SbbCarouselElement = (() => {
91
91
  super.connectedCallback();
92
92
  this.internals.role = "region";
93
93
  this.internals.ariaLabel = "carousel";
94
+ this._setupPaginator();
94
95
  }
95
96
  firstUpdated(_changedProperties) {
96
97
  super.firstUpdated(_changedProperties);
@@ -117,19 +118,29 @@ let SbbCarouselElement = (() => {
117
118
  paginator.accessibilityPreviousPageLabel ||= i18nPreviousSlide[this._language.current];
118
119
  paginator.accessibilityPageLabel ||= i18nSlide[this._language.current];
119
120
  if (paginator !== this._paginator) {
120
- this._abortController = new AbortController();
121
- paginator.addEventListener("page", (e) => this._scrollAtPageChange(e), {
122
- signal: this._abortController.signal
123
- });
124
121
  this._paginator = paginator;
122
+ this._setupPaginator();
125
123
  }
126
124
  }
127
- _scrollAtPageChange(e) {
128
- this._requestedPageIndexByPaginator = e.detail.pageIndex;
125
+ _setupPaginator() {
126
+ this._abortController?.abort();
127
+ if (!this._paginator) {
128
+ return;
129
+ }
130
+ this._abortController = new AbortController();
131
+ this._paginator.addEventListener("click", () => this._scrollAtPaginatorChange(), {
132
+ signal: this._abortController.signal
133
+ });
134
+ }
135
+ _scrollAtPaginatorChange() {
136
+ if (!this._paginator) {
137
+ return;
138
+ }
139
+ this._requestedPageIndexByPaginator = this._paginator.pageIndex;
129
140
  const list = this.querySelector("sbb-carousel-list");
130
141
  if (list) {
131
142
  const items = list.querySelectorAll("sbb-carousel-item");
132
- const offsetLeft = items[e.detail.pageIndex].offsetLeft - this.offsetLeft;
143
+ const offsetLeft = items[this._paginator.pageIndex].offsetLeft - this.offsetLeft;
133
144
  if (list.clientWidth <= 100 || Math.abs(list.scrollLeft - offsetLeft) > 50) {
134
145
  list.scrollTo({ left: offsetLeft });
135
146
  }
@@ -160,4 +171,4 @@ let SbbCarouselElement = (() => {
160
171
  export {
161
172
  SbbCarouselElement
162
173
  };
163
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"carousel.component.js","sources":["../../../../../src/elements/carousel/carousel/carousel.component.ts"],"sourcesContent":["import type { PropertyValues } from '@lit/reactive-element';\nimport type { CSSResultGroup, TemplateResult } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { SbbLanguageController } from '../../core/controllers/language-controller.js';\nimport { forceType } from '../../core/decorators.js';\nimport {\n  i18nCarouselArrowsNavigationHint,\n  i18nNextSlide,\n  i18nPreviousSlide,\n  i18nSlide,\n} from '../../core/i18n/i18n.js';\nimport type { SbbPaginatorPageEventDetails } from '../../core/interfaces.js';\nimport { SbbElementInternalsMixin } from '../../core/mixins.js';\nimport type { SbbCompactPaginatorElement } from '../../paginator/compact-paginator/compact-paginator.component.js';\nimport type {\n  SbbCarouselItemElement,\n  SbbCarouselItemEventDetail,\n} from '../carousel-item/carousel-item.component.js';\nimport type { SbbCarouselListElement } from '../carousel-list/carousel-list.component.js';\nimport '../../screen-reader-only.js';\n\nimport style from './carousel.scss?lit&inline';\n\n/**\n * It displays a carousel component.\n *\n * @slot - Use the unnamed slot to add the `sbb-carousel-list` for content and a `sbb-paginator` for controls.\n */\nexport\n@customElement('sbb-carousel')\nclass SbbCarouselElement extends SbbElementInternalsMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n\n  /**\n   * Used to display a box-shadow around the component.\n   */\n  @forceType()\n  @property({ reflect: true, type: Boolean })\n  public accessor shadow: boolean = false;\n\n  private _paginator: SbbCompactPaginatorElement | null = null;\n  private _abortController: AbortController | null = null;\n  private _language = new SbbLanguageController(this);\n  private _requestedPageIndexByPaginator = -1;\n\n  public constructor() {\n    super();\n\n    // If the list is scrolled using mouse/keyboard, it keeps the paginator updated.\n    this.addEventListener?.('show', (e: CustomEvent<SbbCarouselItemEventDetail>) => {\n      // We have to give priority to the paginator for the case,\n      // if during an animation the next page is called from the paginator, the paginator is reset.\n      if (\n        this._requestedPageIndexByPaginator !== -1 &&\n        this._requestedPageIndexByPaginator !== e.detail.index\n      ) {\n        return;\n      }\n      if (this._paginator) {\n        if (e.detail.index !== this._paginator.pageIndex) {\n          this._paginator.pageIndex = e.detail.index;\n        }\n      }\n      this._requestedPageIndexByPaginator = -1;\n    });\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n\n    this.internals.role = 'region';\n    this.internals.ariaLabel = 'carousel';\n  }\n\n  public override firstUpdated(_changedProperties: PropertyValues): void {\n    super.firstUpdated(_changedProperties);\n\n    this.internals.ariaDescribedByElements = [\n      this.shadowRoot!.querySelector('#sbb-carousel-arrows-navigation-hint')!,\n    ];\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._abortController?.abort();\n  }\n\n  private _handleSlotchange(): void {\n    const paginator: SbbCompactPaginatorElement = Array.from(this.children).find(\n      (el) => el.localName === 'sbb-compact-paginator',\n    ) as SbbCompactPaginatorElement;\n    const list: SbbCarouselListElement = Array.from(this.children).find(\n      (el) => el.localName === 'sbb-carousel-list',\n    ) as SbbCarouselListElement;\n    if (!paginator || !list) {\n      return;\n    }\n    const items = list.querySelectorAll<SbbCarouselItemElement>('sbb-carousel-item');\n    if (items && items.length > 0) {\n      paginator.length = items.length;\n      paginator.pageSize = 1;\n    }\n    paginator.accessibilityNextPageLabel ||= i18nNextSlide[this._language.current];\n    paginator.accessibilityPreviousPageLabel ||= i18nPreviousSlide[this._language.current];\n    paginator.accessibilityPageLabel ||= i18nSlide[this._language.current];\n\n    if (paginator !== this._paginator) {\n      this._abortController = new AbortController();\n      paginator.addEventListener('page', (e) => this._scrollAtPageChange(e), {\n        signal: this._abortController.signal,\n      });\n      this._paginator = paginator;\n    }\n  }\n\n  private _scrollAtPageChange(e: CustomEvent<SbbPaginatorPageEventDetails>): void {\n    this._requestedPageIndexByPaginator = e.detail.pageIndex;\n    const list = this.querySelector<SbbCarouselListElement>('sbb-carousel-list');\n\n    if (list) {\n      const items = list.querySelectorAll<SbbCarouselItemElement>('sbb-carousel-item');\n\n      // As the offsetLeft is always rendered from the viewport boundaries, we need to subtract the offsetLeft\n      // from the carousel to get the offset inside the scroll area.\n      const offsetLeft = items[e.detail.pageIndex].offsetLeft - this.offsetLeft;\n\n      // Prevents redundant scrolling when the paginator updates after a scroll event\n      // by checking the distance between the current and target scroll positions.\n      // (show event is triggered slightly before fully scrolled).\n      if (list.clientWidth <= 100 || Math.abs(list.scrollLeft - offsetLeft) > 50) {\n        list.scrollTo({ left: offsetLeft });\n      }\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-carousel\">\n        <sbb-screen-reader-only id=\"sbb-carousel-arrows-navigation-hint\"\n          >${i18nCarouselArrowsNavigationHint[this._language.current]}</sbb-screen-reader-only\n        >\n        <slot @slotchange=${this._handleSlotchange}></slot>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-carousel': SbbCarouselElement;\n  }\n}\n"],"names":[],"mappings":"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"}
174
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"carousel.component.js","sources":["../../../../../src/elements/carousel/carousel/carousel.component.ts"],"sourcesContent":["import type { PropertyValues } from '@lit/reactive-element';\nimport type { CSSResultGroup, TemplateResult } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { SbbLanguageController } from '../../core/controllers/language-controller.js';\nimport { forceType } from '../../core/decorators.js';\nimport {\n  i18nCarouselArrowsNavigationHint,\n  i18nNextSlide,\n  i18nPreviousSlide,\n  i18nSlide,\n} from '../../core/i18n/i18n.js';\nimport { SbbElementInternalsMixin } from '../../core/mixins.js';\nimport type { SbbCompactPaginatorElement } from '../../paginator/compact-paginator/compact-paginator.component.js';\nimport type {\n  SbbCarouselItemElement,\n  SbbCarouselItemEventDetail,\n} from '../carousel-item/carousel-item.component.js';\nimport type { SbbCarouselListElement } from '../carousel-list/carousel-list.component.js';\n\nimport '../../screen-reader-only.js';\n\nimport style from './carousel.scss?lit&inline';\n\n/**\n * It displays a carousel component.\n *\n * @slot - Use the unnamed slot to add the `sbb-carousel-list` for content and a `sbb-paginator` for controls.\n */\nexport\n@customElement('sbb-carousel')\nclass SbbCarouselElement extends SbbElementInternalsMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n\n  /**\n   * Used to display a box-shadow around the component.\n   */\n  @forceType()\n  @property({ reflect: true, type: Boolean })\n  public accessor shadow: boolean = false;\n\n  private _paginator: SbbCompactPaginatorElement | null = null;\n  private _abortController: AbortController | null = null;\n  private _language = new SbbLanguageController(this);\n  private _requestedPageIndexByPaginator = -1;\n\n  public constructor() {\n    super();\n\n    // If the list is scrolled using mouse/keyboard, it keeps the paginator updated.\n    this.addEventListener?.('show', (e: CustomEvent<SbbCarouselItemEventDetail>) => {\n      // We have to give priority to the paginator for the case,\n      // if during an animation the next page is called from the paginator, the paginator is reset.\n      if (\n        this._requestedPageIndexByPaginator !== -1 &&\n        this._requestedPageIndexByPaginator !== e.detail.index\n      ) {\n        return;\n      }\n      if (this._paginator) {\n        if (e.detail.index !== this._paginator.pageIndex) {\n          this._paginator.pageIndex = e.detail.index;\n        }\n      }\n      this._requestedPageIndexByPaginator = -1;\n    });\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n\n    this.internals.role = 'region';\n    this.internals.ariaLabel = 'carousel';\n\n    this._setupPaginator();\n  }\n\n  public override firstUpdated(_changedProperties: PropertyValues): void {\n    super.firstUpdated(_changedProperties);\n\n    this.internals.ariaDescribedByElements = [\n      this.shadowRoot!.querySelector('#sbb-carousel-arrows-navigation-hint')!,\n    ];\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._abortController?.abort();\n  }\n\n  private _handleSlotchange(): void {\n    const paginator: SbbCompactPaginatorElement = Array.from(this.children).find(\n      (el) => el.localName === 'sbb-compact-paginator',\n    ) as SbbCompactPaginatorElement;\n    const list: SbbCarouselListElement = Array.from(this.children).find(\n      (el) => el.localName === 'sbb-carousel-list',\n    ) as SbbCarouselListElement;\n    if (!paginator || !list) {\n      return;\n    }\n    const items = list.querySelectorAll<SbbCarouselItemElement>('sbb-carousel-item');\n    if (items && items.length > 0) {\n      paginator.length = items.length;\n      paginator.pageSize = 1;\n    }\n    paginator.accessibilityNextPageLabel ||= i18nNextSlide[this._language.current];\n    paginator.accessibilityPreviousPageLabel ||= i18nPreviousSlide[this._language.current];\n    paginator.accessibilityPageLabel ||= i18nSlide[this._language.current];\n\n    if (paginator !== this._paginator) {\n      this._paginator = paginator;\n      this._setupPaginator();\n    }\n  }\n\n  private _setupPaginator(): void {\n    this._abortController?.abort();\n\n    if (!this._paginator) {\n      return;\n    }\n    this._abortController = new AbortController();\n\n    // By listening to the click event on the paginator, we can ensure that the change was user triggered.\n    // If we instead use the page event, we would also catch programmatic changes to the paginator\n    // which can cause a loop and wrong timing as we also listen to the show event.\n    this._paginator.addEventListener('click', () => this._scrollAtPaginatorChange(), {\n      signal: this._abortController.signal,\n    });\n  }\n\n  private _scrollAtPaginatorChange(): void {\n    if (!this._paginator) {\n      return;\n    }\n    this._requestedPageIndexByPaginator = this._paginator.pageIndex;\n\n    const list = this.querySelector<SbbCarouselListElement>('sbb-carousel-list');\n\n    if (list) {\n      const items = list.querySelectorAll<SbbCarouselItemElement>('sbb-carousel-item');\n\n      // As the offsetLeft is always rendered from the viewport boundaries, we need to subtract the offsetLeft\n      // from the carousel to get the offset inside the scroll area.\n      const offsetLeft = items[this._paginator.pageIndex].offsetLeft - this.offsetLeft;\n\n      // Prevents redundant scrolling when the paginator updates after a scroll event\n      // by checking the distance between the current and target scroll positions.\n      // (show event is triggered slightly before fully scrolled).\n      if (list.clientWidth <= 100 || Math.abs(list.scrollLeft - offsetLeft) > 50) {\n        list.scrollTo({ left: offsetLeft });\n      }\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-carousel\">\n        <sbb-screen-reader-only id=\"sbb-carousel-arrows-navigation-hint\"\n          >${i18nCarouselArrowsNavigationHint[this._language.current]}</sbb-screen-reader-only\n        >\n        <slot @slotchange=${this._handleSlotchange}></slot>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-carousel': SbbCarouselElement;\n  }\n}\n"],"names":[],"mappings":"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"}
@@ -12,7 +12,7 @@ export declare class SbbCarouselListElement extends SbbCarouselListElement_base
12
12
  private _observedCarouselItems;
13
13
  private _beforeShowObserver;
14
14
  private _showObserver;
15
- private _firstVisibleIntersectionController;
15
+ private _resizeObserverController;
16
16
  constructor();
17
17
  /** Gets the slotted items. */
18
18
  private _carouselItems;
@@ -1 +1 @@
1
- {"version":3,"file":"carousel-list.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/carousel/carousel-list/carousel-list.component.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,KAAK,cAAc,EAAkB,UAAU,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;;AAc3F;;;;GAIG;AACH,qBAEM,sBAAuB,SAAQ,2BAAoC;IACvE,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,OAAO,CAAC,aAAa,CAAK;IAC1B,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,sBAAsB,CAAgC;IAE9D,OAAO,CAAC,mBAAmB,CAgBxB;IAEH,OAAO,CAAC,aAAa,CAwBlB;IAGH,OAAO,CAAC,mCAAmC,CAYxC;;IAQH,8BAA8B;IAC9B,OAAO,CAAC,cAAc;IAItB,OAAO,CAAC,iBAAiB;IAoBzB;;;OAGG;IACH,OAAO,CAAC,eAAe;IAwBvB,OAAO,CAAC,UAAU;IAwBF,iBAAiB,IAAI,IAAI;cAOtB,MAAM,IAAI,cAAc;CAG5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,mBAAmB,EAAE,sBAAsB,CAAC;KAC7C;CACF"}
1
+ {"version":3,"file":"carousel-list.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/carousel/carousel-list/carousel-list.component.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,cAAc,EAAQ,UAAU,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;;AAcjF;;;;GAIG;AACH,qBAEM,sBAAuB,SAAQ,2BAAoC;IACvE,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,OAAO,CAAC,aAAa,CAAK;IAC1B,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,sBAAsB,CAAgC;IAE9D,OAAO,CAAC,mBAAmB,CAgBxB;IAEH,OAAO,CAAC,aAAa,CAwBlB;IAEH,OAAO,CAAC,yBAAyB,CAG9B;;IAQH,8BAA8B;IAC9B,OAAO,CAAC,cAAc;IAItB,OAAO,CAAC,iBAAiB;IAoBzB;;;OAGG;IACH,OAAO,CAAC,eAAe;IAyBvB,OAAO,CAAC,UAAU;IAwBF,iBAAiB,IAAI,IAAI;cAOtB,MAAM,IAAI,cAAc;CAG5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,mBAAmB,EAAE,sBAAsB,CAAC;KAC7C;CACF"}
@@ -1,6 +1,7 @@
1
1
  import { __esDecorate, __runInitializers } from "tslib";
2
2
  import { IntersectionController } from "@lit-labs/observers/intersection-controller.js";
3
- import { css, LitElement, isServer, html } from "lit";
3
+ import { ResizeController } from "@lit-labs/observers/resize-controller.js";
4
+ import { css, LitElement, html } from "lit";
4
5
  import { customElement } from "lit/decorators.js";
5
6
  import { isArrowKeyPressed } from "../../core/a11y.js";
6
7
  import { SbbLanguageController } from "../../core/controllers.js";
@@ -88,18 +89,9 @@ let SbbCarouselListElement = (() => {
88
89
  },
89
90
  config: { threshold: 0.99, root: this, rootMargin: "100% 0% 100% 0%" }
90
91
  });
91
- this._firstVisibleIntersectionController = new IntersectionController(this, {
92
- callback: (entries) => {
93
- entries.forEach((entry) => {
94
- if (entry.intersectionRatio > 0) {
95
- this._readDimensions();
96
- this._firstVisibleIntersectionController.unobserve(this);
97
- }
98
- });
99
- },
100
- config: {
101
- root: !isServer ? document?.documentElement : null
102
- }
92
+ this._resizeObserverController = new ResizeController(this, {
93
+ skipInitial: true,
94
+ callback: () => this._readDimensions()
103
95
  });
104
96
  this.addEventListener?.("keydown", (e) => this._onKeyDown(e));
105
97
  }
@@ -139,6 +131,7 @@ let SbbCarouselListElement = (() => {
139
131
  this._showObserver.observe(item);
140
132
  });
141
133
  this._observedCarouselItems = carouselItems;
134
+ this._resizeObserverController.unobserve(this);
142
135
  }
143
136
  }
144
137
  _onKeyDown(evt) {
@@ -180,4 +173,4 @@ let SbbCarouselListElement = (() => {
180
173
  export {
181
174
  SbbCarouselListElement
182
175
  };
183
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"carousel-list.component.js","sources":["../../../../../src/elements/carousel/carousel-list/carousel-list.component.ts"],"sourcesContent":["import { IntersectionController } from '@lit-labs/observers/intersection-controller.js';\nimport { type CSSResultGroup, html, isServer, LitElement, type TemplateResult } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\nimport { isArrowKeyPressed } from '../../core/a11y.js';\nimport { SbbLanguageController } from '../../core/controllers.js';\nimport { i18nCarouselItemAriaLabel } from '../../core/i18n.js';\nimport { SbbElementInternalsMixin } from '../../core/mixins.js';\nimport type {\n  SbbCarouselItemElement,\n  SbbCarouselItemEventDetail,\n} from '../carousel-item/carousel-item.component.js';\n\nimport style from './carousel-list.scss?lit&inline';\n\n/**\n * It displays a list of `sbb-carousel-item` components.\n *\n * @slot - Use the unnamed slot to add `sbb-carousel-item` elements.\n */\nexport\n@customElement('sbb-carousel-list')\nclass SbbCarouselListElement extends SbbElementInternalsMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n\n  private _currentIndex = 0;\n  private _language = new SbbLanguageController(this);\n  private _observedCarouselItems: SbbCarouselItemElement[] = [];\n\n  private _beforeShowObserver = new IntersectionController(this, {\n    target: null,\n    callback: (entry) => {\n      const item = entry.filter((e) => e.isIntersecting && e.target !== this);\n      item.forEach((e) => {\n        const target = e.target as SbbCarouselItemElement;\n        target.dispatchEvent(\n          new CustomEvent<SbbCarouselItemEventDetail>('beforeshow', {\n            detail: { index: this._carouselItems().findIndex((e) => e === target) },\n            bubbles: true,\n            composed: true,\n          }),\n        );\n      });\n    },\n    config: { threshold: 0.01, root: this, rootMargin: '100% 0% 100% 0%' },\n  });\n\n  private _showObserver = new IntersectionController(this, {\n    target: null,\n    callback: (entryArr) => {\n      for (const entry of entryArr) {\n        if (entry.target === this) {\n          continue;\n        }\n        const target = entry.target as SbbCarouselItemElement;\n        if (entry.isIntersecting) {\n          target.ariaHidden = null;\n          this._currentIndex = this._carouselItems().findIndex((el) => el === target);\n          target.dispatchEvent(\n            new CustomEvent<SbbCarouselItemEventDetail>('show', {\n              detail: { index: this._currentIndex },\n              bubbles: true,\n              composed: true,\n            }),\n          );\n        } else {\n          target.ariaHidden = 'true';\n        }\n      }\n    },\n    config: { threshold: 0.99, root: this, rootMargin: '100% 0% 100% 0%' },\n  });\n\n  // Observer to read the dimensions of the first item when it becomes visible.\n  private _firstVisibleIntersectionController = new IntersectionController(this, {\n    callback: (entries) => {\n      entries.forEach((entry) => {\n        if (entry.intersectionRatio > 0) {\n          this._readDimensions();\n          this._firstVisibleIntersectionController.unobserve(this);\n        }\n      });\n    },\n    config: {\n      root: !isServer ? document?.documentElement : null,\n    },\n  });\n\n  public constructor() {\n    super();\n\n    this.addEventListener?.('keydown', (e) => this._onKeyDown(e));\n  }\n\n  /** Gets the slotted items. */\n  private _carouselItems(): SbbCarouselItemElement[] {\n    return Array.from(this.querySelectorAll?.('sbb-carousel-item') ?? []);\n  }\n\n  private _handleSlotchange(): void {\n    // In case of removed carousel items, we need to unobserve the current observers.\n    this._observedCarouselItems.forEach((item) => {\n      this._beforeShowObserver.unobserve(item);\n      this._showObserver.unobserve(item);\n    });\n\n    const carouselItems = this._carouselItems();\n\n    // Set the aria-label if not provided\n    carouselItems.forEach((item, index) => {\n      item.ariaLabel ||= i18nCarouselItemAriaLabel(index + 1, carouselItems.length)[\n        this._language.current\n      ];\n      item.ariaHidden = index === this._currentIndex ? null : 'true';\n    });\n\n    this._readDimensions();\n  }\n\n  /**\n   * Reads the dimensions of the first carousel item and sets the CSS properties accordingly.\n   * Should set the dimensions only once, when the first item becomes visible and if the value is non-zero.\n   */\n  private _readDimensions(): void {\n    const carouselItems = this._carouselItems();\n    if (carouselItems.length === 0) {\n      return;\n    }\n\n    const firstItem = carouselItems[0];\n\n    if (firstItem.clientHeight > 0) {\n      this.style.setProperty('--sbb-carousel-list-height', `${firstItem.clientHeight}px`);\n    }\n\n    if (firstItem.clientWidth > 0) {\n      this.style.setProperty('--sbb-carousel-list-width', `${firstItem.clientWidth}px`);\n\n      // We should only observe the items if they have a non-zero width. Otherwise, an unwanted scrolling can happen.\n      carouselItems.forEach((item) => {\n        this._beforeShowObserver.observe(item);\n        this._showObserver.observe(item);\n      });\n      this._observedCarouselItems = carouselItems;\n    }\n  }\n\n  private _onKeyDown(evt: KeyboardEvent): void {\n    if (!isArrowKeyPressed(evt)) {\n      return;\n    }\n    evt.preventDefault();\n\n    let newIndex = this._currentIndex;\n    const isPrev = evt.key === 'ArrowUp' || evt.key === 'ArrowLeft';\n    const isNext = evt.key === 'ArrowDown' || evt.key === 'ArrowRight';\n\n    if (isPrev) {\n      newIndex = Math.max(0, this._currentIndex - 1);\n    } else if (isNext) {\n      newIndex = Math.min(this._carouselItems().length - 1, this._currentIndex + 1);\n    }\n\n    if (newIndex !== this._currentIndex) {\n      this._currentIndex = newIndex;\n      this.scrollTo({\n        left: this._carouselItems()[this._currentIndex].offsetLeft - this.offsetLeft,\n      });\n    }\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n\n    this.internals.ariaLive = 'polite';\n    this.internals.ariaAtomic = 'true';\n  }\n\n  protected override render(): TemplateResult {\n    return html`<slot @slotchange=${this._handleSlotchange}></slot>`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-carousel-list': SbbCarouselListElement;\n  }\n}\n"],"names":["e"],"mappings":"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"}
176
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"carousel-list.component.js","sources":["../../../../../src/elements/carousel/carousel-list/carousel-list.component.ts"],"sourcesContent":["import { IntersectionController } from '@lit-labs/observers/intersection-controller.js';\nimport { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport { type CSSResultGroup, html, LitElement, type TemplateResult } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\nimport { isArrowKeyPressed } from '../../core/a11y.js';\nimport { SbbLanguageController } from '../../core/controllers.js';\nimport { i18nCarouselItemAriaLabel } from '../../core/i18n.js';\nimport { SbbElementInternalsMixin } from '../../core/mixins.js';\nimport type {\n  SbbCarouselItemElement,\n  SbbCarouselItemEventDetail,\n} from '../carousel-item/carousel-item.component.js';\n\nimport style from './carousel-list.scss?lit&inline';\n\n/**\n * It displays a list of `sbb-carousel-item` components.\n *\n * @slot - Use the unnamed slot to add `sbb-carousel-item` elements.\n */\nexport\n@customElement('sbb-carousel-list')\nclass SbbCarouselListElement extends SbbElementInternalsMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n\n  private _currentIndex = 0;\n  private _language = new SbbLanguageController(this);\n  private _observedCarouselItems: SbbCarouselItemElement[] = [];\n\n  private _beforeShowObserver = new IntersectionController(this, {\n    target: null,\n    callback: (entry) => {\n      const item = entry.filter((e) => e.isIntersecting && e.target !== this);\n      item.forEach((e) => {\n        const target = e.target as SbbCarouselItemElement;\n        target.dispatchEvent(\n          new CustomEvent<SbbCarouselItemEventDetail>('beforeshow', {\n            detail: { index: this._carouselItems().findIndex((e) => e === target) },\n            bubbles: true,\n            composed: true,\n          }),\n        );\n      });\n    },\n    config: { threshold: 0.01, root: this, rootMargin: '100% 0% 100% 0%' },\n  });\n\n  private _showObserver = new IntersectionController(this, {\n    target: null,\n    callback: (entryArr) => {\n      for (const entry of entryArr) {\n        if (entry.target === this) {\n          continue;\n        }\n        const target = entry.target as SbbCarouselItemElement;\n        if (entry.isIntersecting) {\n          target.ariaHidden = null;\n          this._currentIndex = this._carouselItems().findIndex((el) => el === target);\n          target.dispatchEvent(\n            new CustomEvent<SbbCarouselItemEventDetail>('show', {\n              detail: { index: this._currentIndex },\n              bubbles: true,\n              composed: true,\n            }),\n          );\n        } else {\n          target.ariaHidden = 'true';\n        }\n      }\n    },\n    config: { threshold: 0.99, root: this, rootMargin: '100% 0% 100% 0%' },\n  });\n\n  private _resizeObserverController = new ResizeController(this, {\n    skipInitial: true,\n    callback: () => this._readDimensions(),\n  });\n\n  public constructor() {\n    super();\n\n    this.addEventListener?.('keydown', (e) => this._onKeyDown(e));\n  }\n\n  /** Gets the slotted items. */\n  private _carouselItems(): SbbCarouselItemElement[] {\n    return Array.from(this.querySelectorAll?.('sbb-carousel-item') ?? []);\n  }\n\n  private _handleSlotchange(): void {\n    // In case of removed carousel items, we need to unobserve the current observers.\n    this._observedCarouselItems.forEach((item) => {\n      this._beforeShowObserver.unobserve(item);\n      this._showObserver.unobserve(item);\n    });\n\n    const carouselItems = this._carouselItems();\n\n    // Set the aria-label if not provided\n    carouselItems.forEach((item, index) => {\n      item.ariaLabel ||= i18nCarouselItemAriaLabel(index + 1, carouselItems.length)[\n        this._language.current\n      ];\n      item.ariaHidden = index === this._currentIndex ? null : 'true';\n    });\n\n    this._readDimensions();\n  }\n\n  /**\n   * Reads the dimensions of the first carousel item and sets the CSS properties accordingly.\n   * Should set the dimensions only once, when the first item becomes visible and if the value is non-zero.\n   */\n  private _readDimensions(): void {\n    const carouselItems = this._carouselItems();\n    if (carouselItems.length === 0) {\n      return;\n    }\n\n    const firstItem = carouselItems[0];\n\n    if (firstItem.clientHeight > 0) {\n      this.style.setProperty('--sbb-carousel-list-height', `${firstItem.clientHeight}px`);\n    }\n\n    if (firstItem.clientWidth > 0) {\n      this.style.setProperty('--sbb-carousel-list-width', `${firstItem.clientWidth}px`);\n\n      // We should only observe the items if they have a non-zero width. Otherwise, an unwanted scrolling can happen.\n      carouselItems.forEach((item) => {\n        this._beforeShowObserver.observe(item);\n        this._showObserver.observe(item);\n      });\n      this._observedCarouselItems = carouselItems;\n      this._resizeObserverController.unobserve(this);\n    }\n  }\n\n  private _onKeyDown(evt: KeyboardEvent): void {\n    if (!isArrowKeyPressed(evt)) {\n      return;\n    }\n    evt.preventDefault();\n\n    let newIndex = this._currentIndex;\n    const isPrev = evt.key === 'ArrowUp' || evt.key === 'ArrowLeft';\n    const isNext = evt.key === 'ArrowDown' || evt.key === 'ArrowRight';\n\n    if (isPrev) {\n      newIndex = Math.max(0, this._currentIndex - 1);\n    } else if (isNext) {\n      newIndex = Math.min(this._carouselItems().length - 1, this._currentIndex + 1);\n    }\n\n    if (newIndex !== this._currentIndex) {\n      this._currentIndex = newIndex;\n      this.scrollTo({\n        left: this._carouselItems()[this._currentIndex].offsetLeft - this.offsetLeft,\n      });\n    }\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n\n    this.internals.ariaLive = 'polite';\n    this.internals.ariaAtomic = 'true';\n  }\n\n  protected override render(): TemplateResult {\n    return html`<slot @slotchange=${this._handleSlotchange}></slot>`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-carousel-list': SbbCarouselListElement;\n  }\n}\n"],"names":["e"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"option-base-element.d.ts","sourceRoot":"","sources":["../../../../../src/elements/option/option/option-base-element.ts"],"names":[],"mappings":"AACA,OAAO,EAAQ,UAAU,EAAE,OAAO,EAAE,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAY1F,OAAO,6BAA6B,CAAC;;AAoBrC,8BAEe,oBAAoB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,yBAEvD;IACC,gBAAuB,MAAM;;MAElB;IAEX,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAEpC;;;;;OAKG;IACH,IACW,KAAK,CAAC,KAAK,EAAE,CAAC,EAOxB;IACD,IAAW,KAAK,IAAI,CAAC,CAEpB;IACD,OAAO,CAAC,MAAM,CAAkB;IAEhC,sCAAsC;IACtC,IACW,QAAQ,CAAC,KAAK,EAAE,OAAO,EAGjC;IACD,IAAW,QAAQ,IAAI,OAAO,CAE7B;IAED,4CAA4C;IACnC,SAAS,CAAC,QAAQ,CAAC,QAAQ,UAAS;IAE7C,yFAAyF;IAChF,SAAS,CAAC,QAAQ,CAAC,iBAAiB,UAAS;IAE7C,SAAS,CAAC,QAAQ,CAAC,KAAK,EAAG,MAAM,CAAC;IAE3C,0CAA0C;IACjC,SAAS,CAAC,QAAQ,CAAC,qBAAqB,EAAE,OAAO,CAAS;IAEnE,4CAA4C;IACnC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAuB;IAExD,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAS;;IAwBnC,wBAAwB,CACtC,IAAI,EAAE,MAAM,EACZ,GAAG,EAAE,MAAM,GAAG,IAAI,EAClB,KAAK,EAAE,MAAM,GAAG,IAAI,GACnB,IAAI;IAMP;;;;OAIG;IACI,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAIrC,SAAS,CAAC,wBAAwB,CAAC,QAAQ,EAAE,OAAO,GAAG,IAAI;IAQ3C,iBAAiB,IAAI,IAAI;cAUtB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cASzD,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAO9E,SAAS,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;IACzD,SAAS,CAAC,QAAQ,CAAC,sBAAsB,IAAI,IAAI;IAEjD,SAAS,CAAC,sBAAsB,CAAC,QAAQ,EAAE,OAAO,GAAG,IAAI;IAKzD;;;OAGG;IACI,SAAS,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI;IAItC,SAAS,CAAC,IAAI,IAAI,IAAI;IAItB,SAAS,CAAC,kBAAkB,IAAI,IAAI;IAYpC,OAAO,CAAC,mBAAmB;IAI3B,2FAA2F;IAC3F,SAAS,CAAC,kBAAkB,CAAC,aAAa,EAAE,cAAc,EAAE,GAAG,IAAI;IAoBnE,SAAS,CAAC,oBAAoB,IAAI,IAAI;IAuBtC,SAAS,CAAC,mBAAmB,IAAI,cAAc;IAwB/C,SAAS,CAAC,UAAU,IAAI,cAAc;IAItC,SAAS,CAAC,WAAW,IAAI,cAAc,GAAG,OAAO,OAAO;IAIxD,SAAS,CAAC,UAAU,IAAI,cAAc,GAAG,OAAO,OAAO;cAIpC,MAAM,IAAI,cAAc;CAmB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,2BAA2B;QACnC,cAAc,EAAE,KAAK,CAAC;KACvB;CACF"}
1
+ {"version":3,"file":"option-base-element.d.ts","sourceRoot":"","sources":["../../../../../src/elements/option/option/option-base-element.ts"],"names":[],"mappings":"AACA,OAAO,EAAQ,UAAU,EAAE,OAAO,EAAE,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAY1F,OAAO,6BAA6B,CAAC;;AAoBrC,8BAEe,oBAAoB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,yBAEvD;IACC,gBAAuB,MAAM;;MAElB;IAEX,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAEpC;;;;;OAKG;IACH,IACW,KAAK,CAAC,KAAK,EAAE,CAAC,EAOxB;IACD,IAAW,KAAK,IAAI,CAAC,CAEpB;IACD,OAAO,CAAC,MAAM,CAAkB;IAEhC,sCAAsC;IACtC,IACW,QAAQ,CAAC,KAAK,EAAE,OAAO,EAGjC;IACD,IAAW,QAAQ,IAAI,OAAO,CAE7B;IAED,4CAA4C;IACnC,SAAS,CAAC,QAAQ,CAAC,QAAQ,UAAS;IAE7C,yFAAyF;IAChF,SAAS,CAAC,QAAQ,CAAC,iBAAiB,UAAS;IAE7C,SAAS,CAAC,QAAQ,CAAC,KAAK,EAAG,MAAM,CAAC;IAE3C,0CAA0C;IACjC,SAAS,CAAC,QAAQ,CAAC,qBAAqB,EAAE,OAAO,CAAS;IAEnE,4CAA4C;IACnC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAuB;IAExD,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAS;;IAwBnC,wBAAwB,CACtC,IAAI,EAAE,MAAM,EACZ,GAAG,EAAE,MAAM,GAAG,IAAI,EAClB,KAAK,EAAE,MAAM,GAAG,IAAI,GACnB,IAAI;IAMP;;;;OAIG;IACI,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAIrC,SAAS,CAAC,wBAAwB,CAAC,QAAQ,EAAE,OAAO,GAAG,IAAI;IAQ3C,iBAAiB,IAAI,IAAI;cAUtB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cASzD,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAO9E,SAAS,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;IACzD,SAAS,CAAC,QAAQ,CAAC,sBAAsB,IAAI,IAAI;IAEjD,SAAS,CAAC,sBAAsB,CAAC,QAAQ,EAAE,OAAO,GAAG,IAAI;IAKzD;;;OAGG;IACI,SAAS,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI;IAItC,SAAS,CAAC,IAAI,IAAI,IAAI;IAItB,SAAS,CAAC,kBAAkB,IAAI,IAAI;IAYpC,OAAO,CAAC,mBAAmB;IAI3B,2FAA2F;IAC3F,SAAS,CAAC,kBAAkB,CAAC,aAAa,EAAE,cAAc,EAAE,GAAG,IAAI;IAoBnE,SAAS,CAAC,oBAAoB,IAAI,IAAI;IAuBtC,SAAS,CAAC,mBAAmB,IAAI,cAAc;IAwB/C,SAAS,CAAC,UAAU,IAAI,cAAc;IAItC,SAAS,CAAC,WAAW,IAAI,cAAc,GAAG,OAAO,OAAO;IAIxD,SAAS,CAAC,UAAU,IAAI,cAAc,GAAG,OAAO,OAAO;cAIpC,MAAM,IAAI,cAAc;CA+B5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,2BAA2B;QACnC,cAAc,EAAE,KAAK,CAAC;KACvB;CACF"}
@@ -10,7 +10,7 @@ import { MutationController } from "@lit-labs/observers/mutation-controller.js";
10
10
  import { LitElement, html, nothing } from "lit";
11
11
  import { property, state } from "lit/decorators.js";
12
12
  import { slotState } from "../../core/decorators.js";
13
- import { isSafari, setOrRemoveAttribute, isAndroid } from "../../core/dom.js";
13
+ import { isSafari, setOrRemoveAttribute, isAndroid, isBlink } from "../../core/dom.js";
14
14
  import { SbbDisabledMixin, SbbElementInternalsMixin, SbbHydrationMixin } from "../../core/mixins.js";
15
15
  import { SbbIconNameMixin } from "../../icon.js";
16
16
  import "../../screen-reader-only.js";
@@ -256,7 +256,7 @@ let SbbOptionBaseElement = (() => {
256
256
  `;
257
257
  }
258
258
  renderIcon() {
259
- return html` <span class="sbb-option__icon"> ${this.renderIconSlot()} </span>`;
259
+ return html`<span class="sbb-option__icon"> ${this.renderIconSlot()} </span>`;
260
260
  }
261
261
  renderLabel() {
262
262
  return this.label && !this.disableLabelHighlight ? this.getHighlightedLabel() : nothing;
@@ -271,7 +271,17 @@ let SbbOptionBaseElement = (() => {
271
271
  ${this.renderIcon()}
272
272
  <span class="sbb-option__label">
273
273
  <slot @slotchange=${this.handleHighlightState}></slot>
274
- ${this.renderLabel()}
274
+ <span
275
+ aria-hidden=${/**
276
+ * Screen readers with Chromium read the option twice.
277
+ * We therefore have to hide the option for the screen readers.
278
+ * TODO: Recheck periodically if this is still necessary.
279
+ * https://issues.chromium.org/issues/460165741
280
+ */
281
+ isBlink ? "true" : nothing}
282
+ >
283
+ ${this.renderLabel()}
284
+ </span>
275
285
  ${this._inertAriaGroups && this.getAttribute("data-group-label") ? html`<sbb-screen-reader-only>
276
286
  (${this.getAttribute("data-group-label")})</sbb-screen-reader-only
277
287
  >` : nothing}
@@ -326,4 +336,4 @@ let SbbOptionBaseElement = (() => {
326
336
  export {
327
337
  SbbOptionBaseElement
328
338
  };
329
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"option-base-element.js","sources":["../../../../../src/elements/option/option/option-base-element.ts"],"sourcesContent":["import { MutationController } from '@lit-labs/observers/mutation-controller.js';\nimport { html, LitElement, nothing, type PropertyValues, type TemplateResult } from 'lit';\nimport { property, state } from 'lit/decorators.js';\n\nimport { slotState } from '../../core/decorators.js';\nimport { isAndroid, isSafari, setOrRemoveAttribute } from '../../core/dom.js';\nimport {\n  SbbDisabledMixin,\n  SbbElementInternalsMixin,\n  SbbHydrationMixin,\n} from '../../core/mixins.js';\nimport { SbbIconNameMixin } from '../../icon.js';\n\nimport '../../screen-reader-only.js';\n\nlet nextId = 0;\n\n/**\n * On Safari, the groups labels are not read by VoiceOver.\n * To solve the problem, we remove the role=\"group\" and add an hidden span containing the group name\n * TODO: We should periodically check if it has been solved and, if so, remove the property.\n */\nconst inertAriaGroups = isSafari;\n\n/** Configuration for the attribute to look at if component is nested in an option group */\nconst optionObserverConfig: MutationObserverInit = {\n  attributeFilter: ['data-group-disabled', 'data-negative'],\n  attributes: true,\n  childList: true,\n  subtree: true,\n  characterData: true,\n};\n\nexport\n@slotState()\nabstract class SbbOptionBaseElement<T = string> extends SbbDisabledMixin(\n  SbbIconNameMixin(SbbElementInternalsMixin(SbbHydrationMixin(LitElement))),\n) {\n  public static readonly events = {\n    optionselected: 'optionselected',\n  } as const;\n\n  protected abstract optionId: string;\n\n  /**\n   * Value of the option.\n   *\n   * @description Developer note: In this case updating the attribute must be synchronous.\n   * Due to this, it is implemented as a getter/setter and the attributeChangedCallback() handles the diff check.\n   */\n  @property()\n  public set value(value: T) {\n    if (typeof value === 'string') {\n      this.setAttribute('value', `${value}`);\n      this._value = null;\n    } else {\n      this._value = value;\n    }\n  }\n  public get value(): T {\n    return (this._value ?? this.getAttribute('value')) as T;\n  }\n  private _value: T | null = null;\n\n  /** Whether the option is selected. */\n  @property({ type: Boolean })\n  public set selected(value: boolean) {\n    this.toggleAttribute('selected', value);\n    this._updateAriaSelected();\n  }\n  public get selected(): boolean {\n    return this.hasAttribute('selected');\n  }\n\n  /** Whether to apply the negative styling */\n  @state() protected accessor negative = false;\n\n  /** Whether the component must be set disabled due disabled attribute on sbb-optgroup. */\n  @state() protected accessor disabledFromGroup = false;\n\n  @state() protected accessor label!: string;\n\n  /** Disable the highlight of the label. */\n  @state() protected accessor disableLabelHighlight: boolean = false;\n\n  /** The portion of the highlighted label. */\n  @state() private accessor _highlightString: string | null = null;\n\n  @state() private accessor _inertAriaGroups = false;\n\n  public constructor() {\n    super();\n    this.addEventListener?.('click', (e: MouseEvent) => this.selectByClick(e), {\n      passive: true,\n    });\n\n    this.addController(\n      new MutationController(this, {\n        config: optionObserverConfig,\n        callback: (mutationsList) => this.onExternalMutation(mutationsList),\n      }),\n    );\n\n    if (inertAriaGroups) {\n      if (this.hydrationRequired) {\n        this.hydrationComplete.then(() => (this._inertAriaGroups = inertAriaGroups));\n      } else {\n        this._inertAriaGroups = inertAriaGroups;\n      }\n    }\n  }\n\n  public override attributeChangedCallback(\n    name: string,\n    old: string | null,\n    value: string | null,\n  ): void {\n    if (name !== 'value' || old !== value) {\n      super.attributeChangedCallback(name, old, value);\n    }\n  }\n\n  /**\n   * Highlight the label of the option\n   * @param value the highlighted portion of the label\n   * @internal\n   */\n  public highlight(value: string): void {\n    this._highlightString = value;\n  }\n\n  protected selectViaUserInteraction(selected: boolean): void {\n    this.selected = selected;\n    if (this.selected) {\n      /** Emits when an option was selected by user. */\n      this.dispatchEvent(new Event('optionselected', { bubbles: true, composed: true }));\n    }\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.id ||= `${this.optionId}-${nextId++}`;\n    if (this.hydrationRequired) {\n      this.hydrationComplete.then(() => this.init());\n    } else {\n      this.init();\n    }\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('disabled')) {\n      setOrRemoveAttribute(this, 'tabindex', isAndroid && !this.disabled && 0);\n      this.updateAriaDisabled();\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    // Init first select state because false would not call setter of selected property.\n    this._updateAriaSelected();\n  }\n\n  protected abstract selectByClick(event: MouseEvent): void;\n  protected abstract setAttributeFromParent(): void;\n\n  protected updateDisableHighlight(disabled: boolean): void {\n    this.disableLabelHighlight = disabled;\n    this.toggleAttribute('data-disable-highlight', disabled);\n  }\n\n  /**\n   * Whether the option is currently active.\n   * @internal\n   */\n  public setActive(value: boolean): void {\n    this.toggleAttribute('data-active', value);\n  }\n\n  protected init(): void {\n    this.setAttributeFromParent();\n  }\n\n  protected updateAriaDisabled(): void {\n    if (this.disabled || this.disabledFromGroup) {\n      this.setAttribute('aria-disabled', 'true');\n    } else {\n      this.removeAttribute('aria-disabled');\n    }\n\n    // Listened by autocomplete\n    /** @internal */\n    this.dispatchEvent(new Event('ɵdisabledchange', { bubbles: true }));\n  }\n\n  private _updateAriaSelected(): void {\n    this.setAttribute('aria-selected', `${this.selected}`);\n  }\n\n  /** Observe changes on data attributes + slotted content and set the appropriate values. */\n  protected onExternalMutation(mutationsList: MutationRecord[]): void {\n    let contentChanged = false;\n    for (const mutation of mutationsList) {\n      if (mutation.attributeName === 'data-group-disabled') {\n        this.disabledFromGroup = this.hasAttribute('data-group-disabled');\n        this.updateAriaDisabled();\n      } else if (mutation.attributeName === 'data-negative') {\n        this.negative = this.hasAttribute('data-negative');\n      } else {\n        contentChanged = true;\n      }\n    }\n\n    if (contentChanged) {\n      this.handleHighlightState();\n      /** @internal */\n      this.dispatchEvent(new Event('optionLabelChanged', { bubbles: true }));\n    }\n  }\n\n  protected handleHighlightState(): void {\n    const slotNodes = Array.from(this.childNodes ?? []).filter(\n      (n) => n.nodeType !== Node.COMMENT_NODE && (!(n instanceof Element) || n.slot !== 'icon'),\n    );\n    const labelNodes = slotNodes.filter((el) => el.nodeType === Node.TEXT_NODE) as Text[];\n\n    // Disable the highlight if the slot contain more than just text nodes.\n    // We need to ignore template elements, as SSR adds a declarative shadow DOM\n    // in the form of a template element.\n    if (\n      labelNodes.length === 0 ||\n      slotNodes.filter((n) => !(n instanceof Element) || n.localName !== 'template').length !==\n        labelNodes.length\n    ) {\n      this.updateDisableHighlight(true);\n      return;\n    }\n    this.label = labelNodes\n      .map((l) => l.wholeText)\n      .filter((l) => l.trim())\n      .join();\n  }\n\n  protected getHighlightedLabel(): TemplateResult {\n    if (!this._highlightString || !this._highlightString.trim()) {\n      return html`${this.label}`;\n    }\n\n    const matchIndex = this.label!.toLowerCase().indexOf(this._highlightString.toLowerCase());\n\n    if (matchIndex === -1) {\n      return html`${this.label}`;\n    }\n\n    const prefix = this.label!.substring(0, matchIndex);\n    const highlighted = this.label!.substring(\n      matchIndex,\n      matchIndex + this._highlightString.length,\n    );\n    const postfix = this.label!.substring(matchIndex + this._highlightString.length);\n\n    return html`\n      <span class=\"sbb-option__label--highlight\">${prefix}</span><span>${highlighted}</span\n      ><span class=\"sbb-option__label--highlight\">${postfix}</span>\n    `;\n  }\n\n  protected renderIcon(): TemplateResult {\n    return html` <span class=\"sbb-option__icon\"> ${this.renderIconSlot()} </span>`;\n  }\n\n  protected renderLabel(): TemplateResult | typeof nothing {\n    return this.label && !this.disableLabelHighlight ? this.getHighlightedLabel() : nothing;\n  }\n\n  protected renderTick(): TemplateResult | typeof nothing {\n    return nothing;\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-option__container\">\n        <div class=\"sbb-option\">\n          ${this.renderIcon()}\n          <span class=\"sbb-option__label\">\n            <slot @slotchange=${this.handleHighlightState}></slot>\n            ${this.renderLabel()}\n            ${this._inertAriaGroups && this.getAttribute('data-group-label')\n              ? html`<sbb-screen-reader-only>\n                  (${this.getAttribute('data-group-label')})</sbb-screen-reader-only\n                >`\n              : nothing}\n          </span>\n          ${this.renderTick()}\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface GlobalEventHandlersEventMap {\n    optionselected: Event;\n  }\n}\n"],"names":[],"mappings":"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"}
339
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"option-base-element.js","sources":["../../../../../src/elements/option/option/option-base-element.ts"],"sourcesContent":["import { MutationController } from '@lit-labs/observers/mutation-controller.js';\nimport { html, LitElement, nothing, type PropertyValues, type TemplateResult } from 'lit';\nimport { property, state } from 'lit/decorators.js';\n\nimport { slotState } from '../../core/decorators.js';\nimport { isAndroid, isBlink, isSafari, setOrRemoveAttribute } from '../../core/dom.js';\nimport {\n  SbbDisabledMixin,\n  SbbElementInternalsMixin,\n  SbbHydrationMixin,\n} from '../../core/mixins.js';\nimport { SbbIconNameMixin } from '../../icon.js';\n\nimport '../../screen-reader-only.js';\n\nlet nextId = 0;\n\n/**\n * On Safari, the groups labels are not read by VoiceOver.\n * To solve the problem, we remove the role=\"group\" and add an hidden span containing the group name\n * TODO: We should periodically check if it has been solved and, if so, remove the property.\n */\nconst inertAriaGroups = isSafari;\n\n/** Configuration for the attribute to look at if component is nested in an option group */\nconst optionObserverConfig: MutationObserverInit = {\n  attributeFilter: ['data-group-disabled', 'data-negative'],\n  attributes: true,\n  childList: true,\n  subtree: true,\n  characterData: true,\n};\n\nexport\n@slotState()\nabstract class SbbOptionBaseElement<T = string> extends SbbDisabledMixin(\n  SbbIconNameMixin(SbbElementInternalsMixin(SbbHydrationMixin(LitElement))),\n) {\n  public static readonly events = {\n    optionselected: 'optionselected',\n  } as const;\n\n  protected abstract optionId: string;\n\n  /**\n   * Value of the option.\n   *\n   * @description Developer note: In this case updating the attribute must be synchronous.\n   * Due to this, it is implemented as a getter/setter and the attributeChangedCallback() handles the diff check.\n   */\n  @property()\n  public set value(value: T) {\n    if (typeof value === 'string') {\n      this.setAttribute('value', `${value}`);\n      this._value = null;\n    } else {\n      this._value = value;\n    }\n  }\n  public get value(): T {\n    return (this._value ?? this.getAttribute('value')) as T;\n  }\n  private _value: T | null = null;\n\n  /** Whether the option is selected. */\n  @property({ type: Boolean })\n  public set selected(value: boolean) {\n    this.toggleAttribute('selected', value);\n    this._updateAriaSelected();\n  }\n  public get selected(): boolean {\n    return this.hasAttribute('selected');\n  }\n\n  /** Whether to apply the negative styling */\n  @state() protected accessor negative = false;\n\n  /** Whether the component must be set disabled due disabled attribute on sbb-optgroup. */\n  @state() protected accessor disabledFromGroup = false;\n\n  @state() protected accessor label!: string;\n\n  /** Disable the highlight of the label. */\n  @state() protected accessor disableLabelHighlight: boolean = false;\n\n  /** The portion of the highlighted label. */\n  @state() private accessor _highlightString: string | null = null;\n\n  @state() private accessor _inertAriaGroups = false;\n\n  public constructor() {\n    super();\n    this.addEventListener?.('click', (e: MouseEvent) => this.selectByClick(e), {\n      passive: true,\n    });\n\n    this.addController(\n      new MutationController(this, {\n        config: optionObserverConfig,\n        callback: (mutationsList) => this.onExternalMutation(mutationsList),\n      }),\n    );\n\n    if (inertAriaGroups) {\n      if (this.hydrationRequired) {\n        this.hydrationComplete.then(() => (this._inertAriaGroups = inertAriaGroups));\n      } else {\n        this._inertAriaGroups = inertAriaGroups;\n      }\n    }\n  }\n\n  public override attributeChangedCallback(\n    name: string,\n    old: string | null,\n    value: string | null,\n  ): void {\n    if (name !== 'value' || old !== value) {\n      super.attributeChangedCallback(name, old, value);\n    }\n  }\n\n  /**\n   * Highlight the label of the option\n   * @param value the highlighted portion of the label\n   * @internal\n   */\n  public highlight(value: string): void {\n    this._highlightString = value;\n  }\n\n  protected selectViaUserInteraction(selected: boolean): void {\n    this.selected = selected;\n    if (this.selected) {\n      /** Emits when an option was selected by user. */\n      this.dispatchEvent(new Event('optionselected', { bubbles: true, composed: true }));\n    }\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.id ||= `${this.optionId}-${nextId++}`;\n    if (this.hydrationRequired) {\n      this.hydrationComplete.then(() => this.init());\n    } else {\n      this.init();\n    }\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('disabled')) {\n      setOrRemoveAttribute(this, 'tabindex', isAndroid && !this.disabled && 0);\n      this.updateAriaDisabled();\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    // Init first select state because false would not call setter of selected property.\n    this._updateAriaSelected();\n  }\n\n  protected abstract selectByClick(event: MouseEvent): void;\n  protected abstract setAttributeFromParent(): void;\n\n  protected updateDisableHighlight(disabled: boolean): void {\n    this.disableLabelHighlight = disabled;\n    this.toggleAttribute('data-disable-highlight', disabled);\n  }\n\n  /**\n   * Whether the option is currently active.\n   * @internal\n   */\n  public setActive(value: boolean): void {\n    this.toggleAttribute('data-active', value);\n  }\n\n  protected init(): void {\n    this.setAttributeFromParent();\n  }\n\n  protected updateAriaDisabled(): void {\n    if (this.disabled || this.disabledFromGroup) {\n      this.setAttribute('aria-disabled', 'true');\n    } else {\n      this.removeAttribute('aria-disabled');\n    }\n\n    // Listened by autocomplete\n    /** @internal */\n    this.dispatchEvent(new Event('ɵdisabledchange', { bubbles: true }));\n  }\n\n  private _updateAriaSelected(): void {\n    this.setAttribute('aria-selected', `${this.selected}`);\n  }\n\n  /** Observe changes on data attributes + slotted content and set the appropriate values. */\n  protected onExternalMutation(mutationsList: MutationRecord[]): void {\n    let contentChanged = false;\n    for (const mutation of mutationsList) {\n      if (mutation.attributeName === 'data-group-disabled') {\n        this.disabledFromGroup = this.hasAttribute('data-group-disabled');\n        this.updateAriaDisabled();\n      } else if (mutation.attributeName === 'data-negative') {\n        this.negative = this.hasAttribute('data-negative');\n      } else {\n        contentChanged = true;\n      }\n    }\n\n    if (contentChanged) {\n      this.handleHighlightState();\n      /** @internal */\n      this.dispatchEvent(new Event('optionLabelChanged', { bubbles: true }));\n    }\n  }\n\n  protected handleHighlightState(): void {\n    const slotNodes = Array.from(this.childNodes ?? []).filter(\n      (n) => n.nodeType !== Node.COMMENT_NODE && (!(n instanceof Element) || n.slot !== 'icon'),\n    );\n    const labelNodes = slotNodes.filter((el) => el.nodeType === Node.TEXT_NODE) as Text[];\n\n    // Disable the highlight if the slot contain more than just text nodes.\n    // We need to ignore template elements, as SSR adds a declarative shadow DOM\n    // in the form of a template element.\n    if (\n      labelNodes.length === 0 ||\n      slotNodes.filter((n) => !(n instanceof Element) || n.localName !== 'template').length !==\n        labelNodes.length\n    ) {\n      this.updateDisableHighlight(true);\n      return;\n    }\n    this.label = labelNodes\n      .map((l) => l.wholeText)\n      .filter((l) => l.trim())\n      .join();\n  }\n\n  protected getHighlightedLabel(): TemplateResult {\n    if (!this._highlightString || !this._highlightString.trim()) {\n      return html`${this.label}`;\n    }\n\n    const matchIndex = this.label!.toLowerCase().indexOf(this._highlightString.toLowerCase());\n\n    if (matchIndex === -1) {\n      return html`${this.label}`;\n    }\n\n    const prefix = this.label!.substring(0, matchIndex);\n    const highlighted = this.label!.substring(\n      matchIndex,\n      matchIndex + this._highlightString.length,\n    );\n    const postfix = this.label!.substring(matchIndex + this._highlightString.length);\n\n    return html`\n      <span class=\"sbb-option__label--highlight\">${prefix}</span><span>${highlighted}</span\n      ><span class=\"sbb-option__label--highlight\">${postfix}</span>\n    `;\n  }\n\n  protected renderIcon(): TemplateResult {\n    return html`<span class=\"sbb-option__icon\"> ${this.renderIconSlot()} </span>`;\n  }\n\n  protected renderLabel(): TemplateResult | typeof nothing {\n    return this.label && !this.disableLabelHighlight ? this.getHighlightedLabel() : nothing;\n  }\n\n  protected renderTick(): TemplateResult | typeof nothing {\n    return nothing;\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-option__container\">\n        <div class=\"sbb-option\">\n          ${this.renderIcon()}\n          <span class=\"sbb-option__label\">\n            <slot @slotchange=${this.handleHighlightState}></slot>\n            <span\n              aria-hidden=${\n                /**\n                 * Screen readers with Chromium read the option twice.\n                 * We therefore have to hide the option for the screen readers.\n                 * TODO: Recheck periodically if this is still necessary.\n                 * https://issues.chromium.org/issues/460165741\n                 */\n                isBlink ? 'true' : nothing\n              }\n            >\n              ${this.renderLabel()}\n            </span>\n            ${this._inertAriaGroups && this.getAttribute('data-group-label')\n              ? html`<sbb-screen-reader-only>\n                  (${this.getAttribute('data-group-label')})</sbb-screen-reader-only\n                >`\n              : nothing}\n          </span>\n          ${this.renderTick()}\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface GlobalEventHandlersEventMap {\n    optionselected: Event;\n  }\n}\n"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"option.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/option/option/option.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAQ,OAAO,EAAE,MAAM,KAAK,CAAC;AAGpC,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAEhE,OAAO,0BAA0B,CAAC;AAElC,MAAM,MAAM,gBAAgB,GAAG,cAAc,GAAG,QAAQ,GAAG,IAAI,CAAC;AAEhE;;;;;;;;GAQG;AACH,qBAEM,gBAAgB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,oBAAoB,CAAC,CAAC,CAAC;IAChE,gBAAgC,IAAI,YAAY;IAChD,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAgC,MAAM;;;MAG3B;IAEX,SAAS,CAAC,QAAQ,SAAgB;IAElC,OAAO,KAAK,QAAQ,QAInB;IACD,OAAO,KAAK,QAAQ,GAEnB;IAED,OAAO,KAAK,WAAW,QAEtB;IACD,OAAO,KAAK,WAAW,GAEtB;IAED,SAAS,CAAC,sBAAsB,IAAI,IAAI;IAgBxC,SAAS,CAAC,aAAa,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;cAc7B,wBAAwB,CAAC,QAAQ,EAAE,OAAO,GAAG,IAAI;cAMjD,IAAI,IAAI,IAAI;IAS/B,OAAO,CAAC,oBAAoB;cAST,oBAAoB,IAAI,IAAI;cAS5B,UAAU,IAAI,cAAc;cAoB5B,WAAW,IAAI,cAAc,GAAG,OAAO,OAAO;cAM9C,UAAU,IAAI,cAAc,GAAG,OAAO,OAAO;CAKjE;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,YAAY,EAAE,gBAAgB,CAAC;KAChC;IAED,UAAU,2BAA2B;QACnC,qBAAqB,EAAE,KAAK,CAAC;KAC9B;CACF"}
1
+ {"version":3,"file":"option.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/option/option/option.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAQ,OAAO,EAAE,MAAM,KAAK,CAAC;AAGpC,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAEhE,OAAO,0BAA0B,CAAC;AAElC,MAAM,MAAM,gBAAgB,GAAG,cAAc,GAAG,QAAQ,GAAG,IAAI,CAAC;AAEhE;;;;;;;;GAQG;AACH,qBAEM,gBAAgB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,oBAAoB,CAAC,CAAC,CAAC;IAChE,gBAAgC,IAAI,YAAY;IAChD,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAgC,MAAM;;;MAG3B;IAEX,SAAS,CAAC,QAAQ,SAAgB;IAElC,OAAO,KAAK,QAAQ,QAInB;IACD,OAAO,KAAK,QAAQ,GAEnB;IAED,OAAO,KAAK,WAAW,QAEtB;IACD,OAAO,KAAK,WAAW,GAEtB;IAED,SAAS,CAAC,sBAAsB,IAAI,IAAI;IAgBxC,SAAS,CAAC,aAAa,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;cAc7B,wBAAwB,CAAC,QAAQ,EAAE,OAAO,GAAG,IAAI;cAMjD,IAAI,IAAI,IAAI;IAS/B,OAAO,CAAC,oBAAoB;cAST,oBAAoB,IAAI,IAAI;cAS5B,UAAU,IAAI,cAAc;cAoB5B,WAAW,IAAI,cAAc,GAAG,OAAO,OAAO;cAO9C,UAAU,IAAI,cAAc,GAAG,OAAO,OAAO;CAKjE;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,YAAY,EAAE,gBAAgB,CAAC;KAChC;IAED,UAAU,2BAA2B;QACnC,qBAAqB,EAAE,KAAK,CAAC;KAC9B;CACF"}
@@ -243,7 +243,10 @@ let SbbOptionElement = (() => {
243
243
  `;
244
244
  }
245
245
  renderLabel() {
246
- return this._variant === "autocomplete" && this.label && !this.disableLabelHighlight ? this.getHighlightedLabel() : nothing;
246
+ if (this._variant !== "autocomplete") {
247
+ return nothing;
248
+ }
249
+ return super.renderLabel();
247
250
  }
248
251
  renderTick() {
249
252
  return this._variant === "select" && !this._isMultiple && this.selected ? html`<sbb-icon name="tick-small"></sbb-icon>` : nothing;
@@ -262,4 +265,4 @@ let SbbOptionElement = (() => {
262
265
  export {
263
266
  SbbOptionElement
264
267
  };
265
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"option.component.js","sources":["../../../../../src/elements/option/option/option.component.ts"],"sourcesContent":["import type { CSSResultGroup, TemplateResult } from 'lit';\nimport { html, nothing } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\nimport { SbbOptionBaseElement } from './option-base-element.js';\nimport style from './option.scss?lit&inline';\nimport '../../visual-checkbox.js';\n\nexport type SbbOptionVariant = 'autocomplete' | 'select' | null;\n\n/**\n * It displays on option item which can be used in `sbb-select` or `sbb-autocomplete`.\n *\n * @slot - Use the unnamed slot to add content to the option label.\n * @slot icon - Use this slot to provide an icon. If `icon-name` is set, a sbb-icon will be used.\n * @cssprop [--sbb-option-icon-container-display=none] - Can be used to reserve space even\n * when preserve-icon-space on autocomplete is not set or iconName is not set.\n * @overrideType value - (T = string) | null\n */\nexport\n@customElement('sbb-option')\nclass SbbOptionElement<T = string> extends SbbOptionBaseElement<T> {\n  public static override readonly role = 'option';\n  public static override styles: CSSResultGroup = style;\n  public static override readonly events = {\n    optionselectionchange: 'optionselectionchange',\n    optionselected: 'optionselected',\n  } as const;\n\n  protected optionId = `sbb-option`;\n\n  private set _variant(state: SbbOptionVariant) {\n    if (state) {\n      this.setAttribute('data-variant', state);\n    }\n  }\n  private get _variant(): SbbOptionVariant {\n    return this.getAttribute('data-variant') as SbbOptionVariant;\n  }\n\n  private set _isMultiple(isMultiple: boolean) {\n    this.toggleAttribute('data-multiple', isMultiple);\n  }\n  private get _isMultiple(): boolean {\n    return !this.hydrationRequired && this.hasAttribute('data-multiple');\n  }\n\n  protected setAttributeFromParent(): void {\n    const parentGroup = this.closest?.('sbb-optgroup');\n    if (parentGroup) {\n      this.disabledFromGroup = parentGroup.disabled;\n      this.updateAriaDisabled();\n    }\n\n    this.negative = !!this.closest?.(\n      // :is() selector not possible due to test environment\n      `sbb-autocomplete[negative],sbb-form-field[negative]`,\n    );\n    this.toggleAttribute('data-negative', this.negative);\n\n    this.toggleAttribute('data-multiple', this._isMultiple);\n  }\n\n  protected selectByClick(event: MouseEvent): void {\n    if (this.disabled || this.disabledFromGroup) {\n      event.stopPropagation();\n      return;\n    }\n\n    if (this._isMultiple) {\n      event.stopPropagation();\n      this.selectViaUserInteraction(!this.selected);\n    } else {\n      this.selectViaUserInteraction(true);\n    }\n  }\n\n  protected override selectViaUserInteraction(selected: boolean): void {\n    super.selectViaUserInteraction(selected);\n    /** The optionselectionchange event is dispatched when the option selection status changes. */\n    this.dispatchEvent(new Event('optionselectionchange', { bubbles: true, composed: true }));\n  }\n\n  protected override init(): void {\n    super.init();\n    this._setVariantByContext();\n    // We need to check highlight state both on slot change, but also when connecting\n    // the element to the DOM. The slot change events might be swallowed when using declarative\n    // shadow DOM with SSR or if the DOM is changed when disconnected.\n    this.handleHighlightState();\n  }\n\n  private _setVariantByContext(): void {\n    if (this.closest?.('sbb-autocomplete')) {\n      this._variant = 'autocomplete';\n    } else if (this.closest?.('sbb-select')) {\n      this._variant = 'select';\n    }\n    this._isMultiple = !!this.closest?.('sbb-select[multiple]');\n  }\n\n  protected override handleHighlightState(): void {\n    if (this._variant !== 'autocomplete') {\n      this.updateDisableHighlight(true);\n      return;\n    }\n\n    super.handleHighlightState();\n  }\n\n  protected override renderIcon(): TemplateResult {\n    return html`\n      <!-- Icon -->\n      ${!this._isMultiple\n        ? html` <span class=\"sbb-option__icon\"> ${this.renderIconSlot()} </span>`\n        : nothing}\n\n      <!-- Checkbox -->\n      ${this._isMultiple\n        ? html`\n            <sbb-visual-checkbox\n              ?checked=${this.selected}\n              ?disabled=${this.disabled || this.disabledFromGroup}\n              ?negative=${this.negative}\n            ></sbb-visual-checkbox>\n          `\n        : nothing}\n    `;\n  }\n\n  protected override renderLabel(): TemplateResult | typeof nothing {\n    return this._variant === 'autocomplete' && this.label && !this.disableLabelHighlight\n      ? this.getHighlightedLabel()\n      : nothing;\n  }\n\n  protected override renderTick(): TemplateResult | typeof nothing {\n    return this._variant === 'select' && !this._isMultiple && this.selected\n      ? html`<sbb-icon name=\"tick-small\"></sbb-icon>`\n      : nothing;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-option': SbbOptionElement;\n  }\n\n  interface GlobalEventHandlersEventMap {\n    optionselectionchange: Event;\n  }\n}\n"],"names":[],"mappings":"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"}
268
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"option.component.js","sources":["../../../../../src/elements/option/option/option.component.ts"],"sourcesContent":["import type { CSSResultGroup, TemplateResult } from 'lit';\nimport { html, nothing } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\nimport { SbbOptionBaseElement } from './option-base-element.js';\nimport style from './option.scss?lit&inline';\nimport '../../visual-checkbox.js';\n\nexport type SbbOptionVariant = 'autocomplete' | 'select' | null;\n\n/**\n * It displays on option item which can be used in `sbb-select` or `sbb-autocomplete`.\n *\n * @slot - Use the unnamed slot to add content to the option label.\n * @slot icon - Use this slot to provide an icon. If `icon-name` is set, a sbb-icon will be used.\n * @cssprop [--sbb-option-icon-container-display=none] - Can be used to reserve space even\n * when preserve-icon-space on autocomplete is not set or iconName is not set.\n * @overrideType value - (T = string) | null\n */\nexport\n@customElement('sbb-option')\nclass SbbOptionElement<T = string> extends SbbOptionBaseElement<T> {\n  public static override readonly role = 'option';\n  public static override styles: CSSResultGroup = style;\n  public static override readonly events = {\n    optionselectionchange: 'optionselectionchange',\n    optionselected: 'optionselected',\n  } as const;\n\n  protected optionId = `sbb-option`;\n\n  private set _variant(state: SbbOptionVariant) {\n    if (state) {\n      this.setAttribute('data-variant', state);\n    }\n  }\n  private get _variant(): SbbOptionVariant {\n    return this.getAttribute('data-variant') as SbbOptionVariant;\n  }\n\n  private set _isMultiple(isMultiple: boolean) {\n    this.toggleAttribute('data-multiple', isMultiple);\n  }\n  private get _isMultiple(): boolean {\n    return !this.hydrationRequired && this.hasAttribute('data-multiple');\n  }\n\n  protected setAttributeFromParent(): void {\n    const parentGroup = this.closest?.('sbb-optgroup');\n    if (parentGroup) {\n      this.disabledFromGroup = parentGroup.disabled;\n      this.updateAriaDisabled();\n    }\n\n    this.negative = !!this.closest?.(\n      // :is() selector not possible due to test environment\n      `sbb-autocomplete[negative],sbb-form-field[negative]`,\n    );\n    this.toggleAttribute('data-negative', this.negative);\n\n    this.toggleAttribute('data-multiple', this._isMultiple);\n  }\n\n  protected selectByClick(event: MouseEvent): void {\n    if (this.disabled || this.disabledFromGroup) {\n      event.stopPropagation();\n      return;\n    }\n\n    if (this._isMultiple) {\n      event.stopPropagation();\n      this.selectViaUserInteraction(!this.selected);\n    } else {\n      this.selectViaUserInteraction(true);\n    }\n  }\n\n  protected override selectViaUserInteraction(selected: boolean): void {\n    super.selectViaUserInteraction(selected);\n    /** The optionselectionchange event is dispatched when the option selection status changes. */\n    this.dispatchEvent(new Event('optionselectionchange', { bubbles: true, composed: true }));\n  }\n\n  protected override init(): void {\n    super.init();\n    this._setVariantByContext();\n    // We need to check highlight state both on slot change, but also when connecting\n    // the element to the DOM. The slot change events might be swallowed when using declarative\n    // shadow DOM with SSR or if the DOM is changed when disconnected.\n    this.handleHighlightState();\n  }\n\n  private _setVariantByContext(): void {\n    if (this.closest?.('sbb-autocomplete')) {\n      this._variant = 'autocomplete';\n    } else if (this.closest?.('sbb-select')) {\n      this._variant = 'select';\n    }\n    this._isMultiple = !!this.closest?.('sbb-select[multiple]');\n  }\n\n  protected override handleHighlightState(): void {\n    if (this._variant !== 'autocomplete') {\n      this.updateDisableHighlight(true);\n      return;\n    }\n\n    super.handleHighlightState();\n  }\n\n  protected override renderIcon(): TemplateResult {\n    return html`\n      <!-- Icon -->\n      ${!this._isMultiple\n        ? html` <span class=\"sbb-option__icon\"> ${this.renderIconSlot()} </span>`\n        : nothing}\n\n      <!-- Checkbox -->\n      ${this._isMultiple\n        ? html`\n            <sbb-visual-checkbox\n              ?checked=${this.selected}\n              ?disabled=${this.disabled || this.disabledFromGroup}\n              ?negative=${this.negative}\n            ></sbb-visual-checkbox>\n          `\n        : nothing}\n    `;\n  }\n\n  protected override renderLabel(): TemplateResult | typeof nothing {\n    if (this._variant !== 'autocomplete') {\n      return nothing;\n    }\n    return super.renderLabel();\n  }\n\n  protected override renderTick(): TemplateResult | typeof nothing {\n    return this._variant === 'select' && !this._isMultiple && this.selected\n      ? html`<sbb-icon name=\"tick-small\"></sbb-icon>`\n      : nothing;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-option': SbbOptionElement;\n  }\n\n  interface GlobalEventHandlersEventMap {\n    optionselectionchange: Event;\n  }\n}\n"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"option-base-element.d.ts","sourceRoot":"","sources":["../../../../src/elements/option/option/option-base-element.ts"],"names":[],"mappings":"AACA,OAAO,EAAQ,UAAU,EAAE,OAAO,EAAE,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAY1F,OAAO,6BAA6B,CAAC;;AAoBrC,8BAEe,oBAAoB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,yBAEvD;IACC,gBAAuB,MAAM;;MAElB;IAEX,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAEpC;;;;;OAKG;IACH,IACW,KAAK,CAAC,KAAK,EAAE,CAAC,EAOxB;IACD,IAAW,KAAK,IAAI,CAAC,CAEpB;IACD,OAAO,CAAC,MAAM,CAAkB;IAEhC,sCAAsC;IACtC,IACW,QAAQ,CAAC,KAAK,EAAE,OAAO,EAGjC;IACD,IAAW,QAAQ,IAAI,OAAO,CAE7B;IAED,4CAA4C;IACnC,SAAS,CAAC,QAAQ,CAAC,QAAQ,UAAS;IAE7C,yFAAyF;IAChF,SAAS,CAAC,QAAQ,CAAC,iBAAiB,UAAS;IAE7C,SAAS,CAAC,QAAQ,CAAC,KAAK,EAAG,MAAM,CAAC;IAE3C,0CAA0C;IACjC,SAAS,CAAC,QAAQ,CAAC,qBAAqB,EAAE,OAAO,CAAS;IAEnE,4CAA4C;IACnC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAuB;IAExD,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAS;;IAwBnC,wBAAwB,CACtC,IAAI,EAAE,MAAM,EACZ,GAAG,EAAE,MAAM,GAAG,IAAI,EAClB,KAAK,EAAE,MAAM,GAAG,IAAI,GACnB,IAAI;IAMP;;;;OAIG;IACI,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAIrC,SAAS,CAAC,wBAAwB,CAAC,QAAQ,EAAE,OAAO,GAAG,IAAI;IAQ3C,iBAAiB,IAAI,IAAI;cAUtB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cASzD,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAO9E,SAAS,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;IACzD,SAAS,CAAC,QAAQ,CAAC,sBAAsB,IAAI,IAAI;IAEjD,SAAS,CAAC,sBAAsB,CAAC,QAAQ,EAAE,OAAO,GAAG,IAAI;IAKzD;;;OAGG;IACI,SAAS,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI;IAItC,SAAS,CAAC,IAAI,IAAI,IAAI;IAItB,SAAS,CAAC,kBAAkB,IAAI,IAAI;IAYpC,OAAO,CAAC,mBAAmB;IAI3B,2FAA2F;IAC3F,SAAS,CAAC,kBAAkB,CAAC,aAAa,EAAE,cAAc,EAAE,GAAG,IAAI;IAoBnE,SAAS,CAAC,oBAAoB,IAAI,IAAI;IAuBtC,SAAS,CAAC,mBAAmB,IAAI,cAAc;IAwB/C,SAAS,CAAC,UAAU,IAAI,cAAc;IAItC,SAAS,CAAC,WAAW,IAAI,cAAc,GAAG,OAAO,OAAO;IAIxD,SAAS,CAAC,UAAU,IAAI,cAAc,GAAG,OAAO,OAAO;cAIpC,MAAM,IAAI,cAAc;CAmB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,2BAA2B;QACnC,cAAc,EAAE,KAAK,CAAC;KACvB;CACF"}
1
+ {"version":3,"file":"option-base-element.d.ts","sourceRoot":"","sources":["../../../../src/elements/option/option/option-base-element.ts"],"names":[],"mappings":"AACA,OAAO,EAAQ,UAAU,EAAE,OAAO,EAAE,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAY1F,OAAO,6BAA6B,CAAC;;AAoBrC,8BAEe,oBAAoB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,yBAEvD;IACC,gBAAuB,MAAM;;MAElB;IAEX,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAEpC;;;;;OAKG;IACH,IACW,KAAK,CAAC,KAAK,EAAE,CAAC,EAOxB;IACD,IAAW,KAAK,IAAI,CAAC,CAEpB;IACD,OAAO,CAAC,MAAM,CAAkB;IAEhC,sCAAsC;IACtC,IACW,QAAQ,CAAC,KAAK,EAAE,OAAO,EAGjC;IACD,IAAW,QAAQ,IAAI,OAAO,CAE7B;IAED,4CAA4C;IACnC,SAAS,CAAC,QAAQ,CAAC,QAAQ,UAAS;IAE7C,yFAAyF;IAChF,SAAS,CAAC,QAAQ,CAAC,iBAAiB,UAAS;IAE7C,SAAS,CAAC,QAAQ,CAAC,KAAK,EAAG,MAAM,CAAC;IAE3C,0CAA0C;IACjC,SAAS,CAAC,QAAQ,CAAC,qBAAqB,EAAE,OAAO,CAAS;IAEnE,4CAA4C;IACnC,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAuB;IAExD,OAAO,CAAC,QAAQ,CAAC,gBAAgB,CAAS;;IAwBnC,wBAAwB,CACtC,IAAI,EAAE,MAAM,EACZ,GAAG,EAAE,MAAM,GAAG,IAAI,EAClB,KAAK,EAAE,MAAM,GAAG,IAAI,GACnB,IAAI;IAMP;;;;OAIG;IACI,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAIrC,SAAS,CAAC,wBAAwB,CAAC,QAAQ,EAAE,OAAO,GAAG,IAAI;IAQ3C,iBAAiB,IAAI,IAAI;cAUtB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cASzD,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAO9E,SAAS,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;IACzD,SAAS,CAAC,QAAQ,CAAC,sBAAsB,IAAI,IAAI;IAEjD,SAAS,CAAC,sBAAsB,CAAC,QAAQ,EAAE,OAAO,GAAG,IAAI;IAKzD;;;OAGG;IACI,SAAS,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI;IAItC,SAAS,CAAC,IAAI,IAAI,IAAI;IAItB,SAAS,CAAC,kBAAkB,IAAI,IAAI;IAYpC,OAAO,CAAC,mBAAmB;IAI3B,2FAA2F;IAC3F,SAAS,CAAC,kBAAkB,CAAC,aAAa,EAAE,cAAc,EAAE,GAAG,IAAI;IAoBnE,SAAS,CAAC,oBAAoB,IAAI,IAAI;IAuBtC,SAAS,CAAC,mBAAmB,IAAI,cAAc;IAwB/C,SAAS,CAAC,UAAU,IAAI,cAAc;IAItC,SAAS,CAAC,WAAW,IAAI,cAAc,GAAG,OAAO,OAAO;IAIxD,SAAS,CAAC,UAAU,IAAI,cAAc,GAAG,OAAO,OAAO;cAIpC,MAAM,IAAI,cAAc;CA+B5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,2BAA2B;QACnC,cAAc,EAAE,KAAK,CAAC;KACvB;CACF"}
@@ -5,24 +5,24 @@ var V = (s, a, n) => a.has(s) || P("Cannot " + n);
5
5
  var g = (s, a, n) => (V(s, a, "read from private field"), n ? n.call(s) : a.get(s)), b = (s, a, n) => a.has(s) ? P("Cannot add the same private member more than once") : a instanceof WeakSet ? a.add(s) : a.set(s, n), h = (s, a, n, o) => (V(s, a, "write to private field"), o ? o.call(s, n) : a.set(s, n), n);
6
6
  import { __esDecorate as d, __runInitializers as r } from "tslib";
7
7
  import { MutationController as K } from "@lit-labs/observers/mutation-controller.js";
8
- import { LitElement as Q, html as v, nothing as G } from "lit";
8
+ import { LitElement as Q, html as v, nothing as S } from "lit";
9
9
  import { property as X, state as A } from "lit/decorators.js";
10
10
  import { slotState as W } from "../../core/decorators.js";
11
- import { isSafari as Y, setOrRemoveAttribute as Z, isAndroid as tt } from "../../core/dom.js";
12
- import { SbbDisabledMixin as et, SbbElementInternalsMixin as it, SbbHydrationMixin as st } from "../../core/mixins.js";
13
- import { SbbIconNameMixin as at } from "../../icon.js";
11
+ import { isSafari as Y, setOrRemoveAttribute as Z, isAndroid as tt, isBlink as et } from "../../core/dom.js";
12
+ import { SbbDisabledMixin as it, SbbElementInternalsMixin as st, SbbHydrationMixin as at } from "../../core/mixins.js";
13
+ import { SbbIconNameMixin as lt } from "../../icon.js";
14
14
  import "../../screen-reader-only.js";
15
- let lt = 0;
16
- const x = Y, rt = {
15
+ let rt = 0;
16
+ const x = Y, nt = {
17
17
  attributeFilter: ["data-group-disabled", "data-negative"],
18
18
  attributes: !0,
19
19
  childList: !0,
20
20
  subtree: !0,
21
21
  characterData: !0
22
22
  };
23
- let ft = (() => {
23
+ let vt = (() => {
24
24
  var c, u, _, p, m, f, l;
25
- let s = [W()], a, n = [], o, L = et(at(it(st(Q)))), S = [], y, E, H, k = [], I = [], C, $ = [], z = [], F, D = [], N = [], w, M = [], O = [], T, U = [], j = [], B, R = [], q = [];
25
+ let s = [W()], a, n = [], o, L = it(lt(st(at(Q)))), G = [], y, E, H, k = [], I = [], C, $ = [], z = [], F, D = [], N = [], w, M = [], O = [], T, U = [], B = [], j, R = [], q = [];
26
26
  return l = class extends L {
27
27
  constructor() {
28
28
  super();
@@ -32,10 +32,10 @@ let ft = (() => {
32
32
  b(this, p);
33
33
  b(this, m);
34
34
  b(this, f);
35
- this._value = (r(this, S), null), h(this, c, r(this, k, !1)), h(this, u, (r(this, I), r(this, $, !1))), h(this, _, (r(this, z), r(this, D, void 0))), h(this, p, (r(this, N), r(this, M, !1))), h(this, m, (r(this, O), r(this, U, null))), h(this, f, (r(this, j), r(this, R, !1))), r(this, q), this.addEventListener?.("click", (t) => this.selectByClick(t), {
35
+ this._value = (r(this, G), null), h(this, c, r(this, k, !1)), h(this, u, (r(this, I), r(this, $, !1))), h(this, _, (r(this, z), r(this, D, void 0))), h(this, p, (r(this, N), r(this, M, !1))), h(this, m, (r(this, O), r(this, U, null))), h(this, f, (r(this, B), r(this, R, !1))), r(this, q), this.addEventListener?.("click", (t) => this.selectByClick(t), {
36
36
  passive: !0
37
37
  }), this.addController(new K(this, {
38
- config: rt,
38
+ config: nt,
39
39
  callback: (t) => this.onExternalMutation(t)
40
40
  })), x && (this.hydrationRequired ? this.hydrationComplete.then(() => this._inertAriaGroups = x) : this._inertAriaGroups = x);
41
41
  }
@@ -113,7 +113,7 @@ let ft = (() => {
113
113
  this.selected = t, this.selected && this.dispatchEvent(new Event("optionselected", { bubbles: !0, composed: !0 }));
114
114
  }
115
115
  connectedCallback() {
116
- super.connectedCallback(), this.id ||= `${this.optionId}-${lt++}`, this.hydrationRequired ? this.hydrationComplete.then(() => this.init()) : this.init();
116
+ super.connectedCallback(), this.id ||= `${this.optionId}-${rt++}`, this.hydrationRequired ? this.hydrationComplete.then(() => this.init()) : this.init();
117
117
  }
118
118
  willUpdate(t) {
119
119
  super.willUpdate(t), t.has("disabled") && (Z(this, "tabindex", tt && !this.disabled && 0), this.updateAriaDisabled());
@@ -168,13 +168,13 @@ let ft = (() => {
168
168
  `;
169
169
  }
170
170
  renderIcon() {
171
- return v` <span class="sbb-option__icon"> ${this.renderIconSlot()} </span>`;
171
+ return v`<span class="sbb-option__icon"> ${this.renderIconSlot()} </span>`;
172
172
  }
173
173
  renderLabel() {
174
- return this.label && !this.disableLabelHighlight ? this.getHighlightedLabel() : G;
174
+ return this.label && !this.disableLabelHighlight ? this.getHighlightedLabel() : S;
175
175
  }
176
176
  renderTick() {
177
- return G;
177
+ return S;
178
178
  }
179
179
  render() {
180
180
  return v`
@@ -183,10 +183,20 @@ let ft = (() => {
183
183
  ${this.renderIcon()}
184
184
  <span class="sbb-option__label">
185
185
  <slot @slotchange=${this.handleHighlightState}></slot>
186
- ${this.renderLabel()}
186
+ <span
187
+ aria-hidden=${/**
188
+ * Screen readers with Chromium read the option twice.
189
+ * We therefore have to hide the option for the screen readers.
190
+ * TODO: Recheck periodically if this is still necessary.
191
+ * https://issues.chromium.org/issues/460165741
192
+ */
193
+ et ? "true" : S}
194
+ >
195
+ ${this.renderLabel()}
196
+ </span>
187
197
  ${this._inertAriaGroups && this.getAttribute("data-group-label") ? v`<sbb-screen-reader-only>
188
198
  (${this.getAttribute("data-group-label")})</sbb-screen-reader-only
189
- >` : G}
199
+ >` : S}
190
200
  </span>
191
201
  ${this.renderTick()}
192
202
  </div>
@@ -195,11 +205,11 @@ let ft = (() => {
195
205
  }
196
206
  }, c = new WeakMap(), u = new WeakMap(), _ = new WeakMap(), p = new WeakMap(), m = new WeakMap(), f = new WeakMap(), o = l, (() => {
197
207
  const t = typeof Symbol == "function" && Symbol.metadata ? Object.create(L[Symbol.metadata] ?? null) : void 0;
198
- y = [X()], E = [X({ type: Boolean })], H = [A()], C = [A()], F = [A()], w = [A()], T = [A()], B = [A()], d(l, null, y, { kind: "setter", name: "value", static: !1, private: !1, access: { has: (e) => "value" in e, set: (e, i) => {
208
+ y = [X()], E = [X({ type: Boolean })], H = [A()], C = [A()], F = [A()], w = [A()], T = [A()], j = [A()], d(l, null, y, { kind: "setter", name: "value", static: !1, private: !1, access: { has: (e) => "value" in e, set: (e, i) => {
199
209
  e.value = i;
200
- } }, metadata: t }, null, S), d(l, null, E, { kind: "setter", name: "selected", static: !1, private: !1, access: { has: (e) => "selected" in e, set: (e, i) => {
210
+ } }, metadata: t }, null, G), d(l, null, E, { kind: "setter", name: "selected", static: !1, private: !1, access: { has: (e) => "selected" in e, set: (e, i) => {
201
211
  e.selected = i;
202
- } }, metadata: t }, null, S), d(l, null, H, { kind: "accessor", name: "negative", static: !1, private: !1, access: { has: (e) => "negative" in e, get: (e) => e.negative, set: (e, i) => {
212
+ } }, metadata: t }, null, G), d(l, null, H, { kind: "accessor", name: "negative", static: !1, private: !1, access: { has: (e) => "negative" in e, get: (e) => e.negative, set: (e, i) => {
203
213
  e.negative = i;
204
214
  } }, metadata: t }, k, I), d(l, null, C, { kind: "accessor", name: "disabledFromGroup", static: !1, private: !1, access: { has: (e) => "disabledFromGroup" in e, get: (e) => e.disabledFromGroup, set: (e, i) => {
205
215
  e.disabledFromGroup = i;
@@ -209,7 +219,7 @@ let ft = (() => {
209
219
  e.disableLabelHighlight = i;
210
220
  } }, metadata: t }, M, O), d(l, null, T, { kind: "accessor", name: "_highlightString", static: !1, private: !1, access: { has: (e) => "_highlightString" in e, get: (e) => e._highlightString, set: (e, i) => {
211
221
  e._highlightString = i;
212
- } }, metadata: t }, U, j), d(l, null, B, { kind: "accessor", name: "_inertAriaGroups", static: !1, private: !1, access: { has: (e) => "_inertAriaGroups" in e, get: (e) => e._inertAriaGroups, set: (e, i) => {
222
+ } }, metadata: t }, U, B), d(l, null, j, { kind: "accessor", name: "_inertAriaGroups", static: !1, private: !1, access: { has: (e) => "_inertAriaGroups" in e, get: (e) => e._inertAriaGroups, set: (e, i) => {
213
223
  e._inertAriaGroups = i;
214
224
  } }, metadata: t }, R, q), d(null, a = { value: o }, s, { kind: "class", name: o.name, metadata: t }, null, n), o = a.value, t && Object.defineProperty(o, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: t });
215
225
  })(), l.events = {
@@ -217,5 +227,5 @@ let ft = (() => {
217
227
  }, r(o, n), o;
218
228
  })();
219
229
  export {
220
- ft as SbbOptionBaseElement
230
+ vt as SbbOptionBaseElement
221
231
  };
@@ -1 +1 @@
1
- {"version":3,"file":"option.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/option/option/option.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAQ,OAAO,EAAE,MAAM,KAAK,CAAC;AAGpC,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAEhE,OAAO,0BAA0B,CAAC;AAElC,MAAM,MAAM,gBAAgB,GAAG,cAAc,GAAG,QAAQ,GAAG,IAAI,CAAC;AAEhE;;;;;;;;GAQG;AACH,qBAEM,gBAAgB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,oBAAoB,CAAC,CAAC,CAAC;IAChE,gBAAgC,IAAI,YAAY;IAChD,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAgC,MAAM;;;MAG3B;IAEX,SAAS,CAAC,QAAQ,SAAgB;IAElC,OAAO,KAAK,QAAQ,QAInB;IACD,OAAO,KAAK,QAAQ,GAEnB;IAED,OAAO,KAAK,WAAW,QAEtB;IACD,OAAO,KAAK,WAAW,GAEtB;IAED,SAAS,CAAC,sBAAsB,IAAI,IAAI;IAgBxC,SAAS,CAAC,aAAa,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;cAc7B,wBAAwB,CAAC,QAAQ,EAAE,OAAO,GAAG,IAAI;cAMjD,IAAI,IAAI,IAAI;IAS/B,OAAO,CAAC,oBAAoB;cAST,oBAAoB,IAAI,IAAI;cAS5B,UAAU,IAAI,cAAc;cAoB5B,WAAW,IAAI,cAAc,GAAG,OAAO,OAAO;cAM9C,UAAU,IAAI,cAAc,GAAG,OAAO,OAAO;CAKjE;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,YAAY,EAAE,gBAAgB,CAAC;KAChC;IAED,UAAU,2BAA2B;QACnC,qBAAqB,EAAE,KAAK,CAAC;KAC9B;CACF"}
1
+ {"version":3,"file":"option.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/option/option/option.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAQ,OAAO,EAAE,MAAM,KAAK,CAAC;AAGpC,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAC;AAEhE,OAAO,0BAA0B,CAAC;AAElC,MAAM,MAAM,gBAAgB,GAAG,cAAc,GAAG,QAAQ,GAAG,IAAI,CAAC;AAEhE;;;;;;;;GAQG;AACH,qBAEM,gBAAgB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,oBAAoB,CAAC,CAAC,CAAC;IAChE,gBAAgC,IAAI,YAAY;IAChD,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAgC,MAAM;;;MAG3B;IAEX,SAAS,CAAC,QAAQ,SAAgB;IAElC,OAAO,KAAK,QAAQ,QAInB;IACD,OAAO,KAAK,QAAQ,GAEnB;IAED,OAAO,KAAK,WAAW,QAEtB;IACD,OAAO,KAAK,WAAW,GAEtB;IAED,SAAS,CAAC,sBAAsB,IAAI,IAAI;IAgBxC,SAAS,CAAC,aAAa,CAAC,KAAK,EAAE,UAAU,GAAG,IAAI;cAc7B,wBAAwB,CAAC,QAAQ,EAAE,OAAO,GAAG,IAAI;cAMjD,IAAI,IAAI,IAAI;IAS/B,OAAO,CAAC,oBAAoB;cAST,oBAAoB,IAAI,IAAI;cAS5B,UAAU,IAAI,cAAc;cAoB5B,WAAW,IAAI,cAAc,GAAG,OAAO,OAAO;cAO9C,UAAU,IAAI,cAAc,GAAG,OAAO,OAAO;CAKjE;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,YAAY,EAAE,gBAAgB,CAAC;KAChC;IAED,UAAU,2BAA2B;QACnC,qBAAqB,EAAE,KAAK,CAAC;KAC9B;CACF"}
@@ -6,8 +6,8 @@ import "../../visual-checkbox.js";
6
6
  const h = d`*,:before,:after{box-sizing:border-box}:host{--sbb-option-color: var(--sbb-color-3);--sbb-option-background-color: inherit;--sbb-option-background-color-hover: var(--sbb-background-color-3);--sbb-option-background-color-active: var(--sbb-background-color-4);--sbb-option-disabled-border-color: var(--sbb-color-graphite);--sbb-option-disabled-border-color: light-dark(var(--sbb-color-graphite), var(--sbb-color-smoke));--sbb-option-disabled-background-color: var(--sbb-background-color-3);--sbb-option-padding-inline: var(--sbb-spacing-responsive-xxxs);--sbb-option-min-height: var(--sbb-size-element-s);--sbb-option-column-gap: var(--sbb-spacing-responsive-xxxs);--sbb-option-justify-content: start;--sbb-option-cursor: var(--sbb-cursor-pointer);--sbb-option-border-radius: var(--sbb-border-radius-4x);--sbb-option-icon-color: var(--sbb-color-metal);--sbb-option-icon-color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));--sbb-option-focus-outline-color: transparent;--sbb-option-focus-outline-inset: var(--sbb-spacing-fixed-1x);display:block}:host([data-negative]){--sbb-option-color: var(--sbb-color-3-negative);--sbb-option-icon-color: var(--sbb-color-5);--sbb-option-background-color-hover: var(--sbb-background-color-3-negative);--sbb-option-background-color-active: var(--sbb-background-color-4-negative);--sbb-option-disabled-border-color: var(--sbb-border-color-5);--sbb-option-disabled-background-color: var(--sbb-background-color-3-negative);--sbb-focus-outline-color: var(--sbb-focus-outline-color-dark)}@media(any-hover:hover){:host(:hover:not([disabled],[data-group-disabled])){--sbb-option-background-color: var(--sbb-option-background-color-hover)}}:host(:active:not([disabled],[data-group-disabled])){--sbb-option-background-color: var(--sbb-option-background-color-active)}:host(:not([data-disable-highlight])) .sbb-option__label slot{display:none}:host(:is([data-group-disabled],[disabled])){--sbb-option-cursor: var(--sbb-cursor-default)}@media(forced-colors:active){:host(:is([data-group-disabled],[disabled])){--sbb-option-color: GrayText}}:host([data-variant=select]){--sbb-option-column-gap: var(--sbb-spacing-fixed-2x);--sbb-option-justify-content: space-between}:host([data-variant=select][data-multiple]){--sbb-option-justify-content: start}:host([data-active]){--sbb-option-focus-outline-color: var(--sbb-focus-outline-color)}:host(:not(:is([disabled],[data-group-disabled]))) .sbb-option__label--highlight{font-weight:700}@media(forced-colors:active){:host(:not(:is([disabled],[data-group-disabled]))) .sbb-option__label--highlight{color:Highlight}}.sbb-option__container{background-color:var(--sbb-option-background-color)}.sbb-option{--sbb-text-font-size: var(--sbb-font-size-text-s);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-text);font-size:var(--sbb-text-font-size);position:relative;display:flex;min-height:var(--sbb-option-min-height);align-items:center;column-gap:var(--sbb-option-column-gap);padding-inline:var(--sbb-option-padding-inline);justify-content:var(--sbb-option-justify-content);color:var(--sbb-option-color);cursor:var(--sbb-option-cursor);-webkit-tap-highlight-color:transparent;-webkit-text-fill-color:var(--sbb-option-color)}.sbb-option:after{content:"";display:block;position:absolute;inset:var(--sbb-option-focus-outline-inset);pointer-events:none;border:var(--sbb-focus-outline-width) solid var(--sbb-option-focus-outline-color);border-radius:var(--sbb-option-border-radius)}:host(:is([data-group-disabled],[disabled]):not([data-multiple])) .sbb-option{position:relative;z-index:0}:host(:is([data-group-disabled],[disabled]):not([data-multiple])) .sbb-option:before{content:"";display:block;position:absolute;inset:.375rem;border:var(--sbb-border-width-1x) dashed var(--sbb-option-disabled-border-color);border-radius:var(--sbb-border-radius-2x);background-color:var(--sbb-option-disabled-background-color);z-index:-1}@media(forced-colors:active){:host(:is([data-group-disabled],[disabled]):not([data-multiple])) .sbb-option:before{border-color:GrayText}}.sbb-option__icon{display:flex;min-width:var(--sbb-size-icon-ui-small);min-height:var(--sbb-size-icon-ui-small);color:var(--sbb-option-icon-color)}:host(:not([data-slot-names~=icon],[icon-name])) .sbb-option__icon{display:var(--sbb-option-icon-container-display, none)}.sbb-option__label{text-overflow:var(--sbb-option-text-overflow);overflow:var(--sbb-option-overflow);white-space:var(--sbb-option-white-space, initial)}`;
7
7
  let k = (() => {
8
8
  var t;
9
- let n = [p("sbb-option")], a, b = [], i, r = u;
10
- return t = class extends r {
9
+ let n = [p("sbb-option")], a, r = [], i, b = u;
10
+ return t = class extends b {
11
11
  constructor() {
12
12
  super(...arguments), this.optionId = "sbb-option";
13
13
  }
@@ -69,18 +69,18 @@ let k = (() => {
69
69
  `;
70
70
  }
71
71
  renderLabel() {
72
- return this._variant === "autocomplete" && this.label && !this.disableLabelHighlight ? this.getHighlightedLabel() : e;
72
+ return this._variant !== "autocomplete" ? e : super.renderLabel();
73
73
  }
74
74
  renderTick() {
75
75
  return this._variant === "select" && !this._isMultiple && this.selected ? s`<sbb-icon name="tick-small"></sbb-icon>` : e;
76
76
  }
77
77
  }, i = t, (() => {
78
- const o = typeof Symbol == "function" && Symbol.metadata ? Object.create(r[Symbol.metadata] ?? null) : void 0;
79
- l(null, a = { value: i }, n, { kind: "class", name: i.name, metadata: o }, null, b), i = a.value, o && Object.defineProperty(i, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: o });
78
+ const o = typeof Symbol == "function" && Symbol.metadata ? Object.create(b[Symbol.metadata] ?? null) : void 0;
79
+ l(null, a = { value: i }, n, { kind: "class", name: i.name, metadata: o }, null, r), i = a.value, o && Object.defineProperty(i, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: o });
80
80
  })(), t.role = "option", t.styles = h, t.events = {
81
81
  optionselectionchange: "optionselectionchange",
82
82
  optionselected: "optionselected"
83
- }, c(i, b), i;
83
+ }, c(i, r), i;
84
84
  })();
85
85
  export {
86
86
  k as SbbOptionElement
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements",
3
- "version": "3.13.0",
3
+ "version": "3.13.2",
4
4
  "description": "Lyne Design System",
5
5
  "keywords": [
6
6
  "design system",