@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.
- package/carousel/carousel/carousel.component.d.ts +2 -1
- package/carousel/carousel/carousel.component.d.ts.map +1 -1
- package/carousel/carousel/carousel.component.js +32 -27
- package/carousel/carousel-list/carousel-list.component.d.ts +1 -1
- package/carousel/carousel-list/carousel-list.component.d.ts.map +1 -1
- package/carousel/carousel-list/carousel-list.component.js +26 -31
- package/custom-elements.json +13 -11
- package/development/carousel/carousel/carousel.component.d.ts +2 -1
- package/development/carousel/carousel/carousel.component.d.ts.map +1 -1
- package/development/carousel/carousel/carousel.component.js +19 -8
- package/development/carousel/carousel-list/carousel-list.component.d.ts +1 -1
- package/development/carousel/carousel-list/carousel-list.component.d.ts.map +1 -1
- package/development/carousel/carousel-list/carousel-list.component.js +7 -14
- package/development/option/option/option-base-element.d.ts.map +1 -1
- package/development/option/option/option-base-element.js +14 -4
- package/development/option/option/option.component.d.ts.map +1 -1
- package/development/option/option/option.component.js +5 -2
- package/option/option/option-base-element.d.ts.map +1 -1
- package/option/option/option-base-element.js +31 -21
- package/option/option/option.component.d.ts.map +1 -1
- package/option/option/option.component.js +6 -6
- package/package.json +1 -1
|
@@ -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
|
|
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;
|
|
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
|
|
1
|
+
var p = (a) => {
|
|
2
2
|
throw TypeError(a);
|
|
3
3
|
};
|
|
4
|
-
var
|
|
5
|
-
var
|
|
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
|
|
11
|
-
import { i18nNextSlide as
|
|
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,
|
|
17
|
-
let a = [S("sbb-carousel")],
|
|
18
|
-
return
|
|
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
|
-
|
|
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
|
|
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((
|
|
48
|
-
if (!e || !
|
|
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
|
|
51
|
-
|
|
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
|
-
})
|
|
56
|
+
}));
|
|
54
57
|
}
|
|
55
|
-
|
|
56
|
-
this.
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
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(),
|
|
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 = [
|
|
76
|
-
|
|
77
|
-
} }, metadata: e }, g, f), w(null,
|
|
78
|
-
})(),
|
|
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
|
|
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":"
|
|
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
|
|
3
|
-
import {
|
|
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
|
|
7
|
-
import { i18nCarouselItemAriaLabel as
|
|
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 =
|
|
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
|
|
12
|
-
let u = [g("sbb-carousel-list")],
|
|
13
|
-
return
|
|
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
|
|
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
|
|
20
|
-
|
|
21
|
-
detail: { index: this._carouselItems().findIndex((h) => h ===
|
|
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
|
|
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((
|
|
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.
|
|
44
|
-
|
|
45
|
-
|
|
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 ||=
|
|
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",
|
|
86
|
-
r ? t = Math.max(0, this._currentIndex - 1) :
|
|
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 =
|
|
97
|
-
const e = typeof Symbol == "function" && Symbol.metadata ? Object.create(
|
|
98
|
-
b(null,
|
|
99
|
-
})(),
|
|
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
|
package/custom-elements.json
CHANGED
|
@@ -39229,21 +39229,23 @@
|
|
|
39229
39229
|
},
|
|
39230
39230
|
{
|
|
39231
39231
|
"kind": "method",
|
|
39232
|
-
"name": "
|
|
39232
|
+
"name": "_setupPaginator",
|
|
39233
39233
|
"privacy": "private",
|
|
39234
39234
|
"return": {
|
|
39235
39235
|
"type": {
|
|
39236
39236
|
"text": "void"
|
|
39237
39237
|
}
|
|
39238
|
-
}
|
|
39239
|
-
|
|
39240
|
-
|
|
39241
|
-
|
|
39242
|
-
|
|
39243
|
-
|
|
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": "
|
|
39482
|
+
"name": "_resizeObserverController",
|
|
39481
39483
|
"privacy": "private",
|
|
39482
|
-
"default": "new
|
|
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
|
|
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;
|
|
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
|
-
|
|
128
|
-
this.
|
|
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[
|
|
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
|
|
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":"
|
|
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 {
|
|
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.
|
|
92
|
-
|
|
93
|
-
|
|
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;
|
|
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
|
|
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
|
-
|
|
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;
|
|
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
|
-
|
|
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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3B0aW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzL29wdGlvbi9vcHRpb24vb3B0aW9uLmNvbXBvbmVudC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENTU1Jlc3VsdEdyb3VwLCBUZW1wbGF0ZVJlc3VsdCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBodG1sLCBub3RoaW5nIH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQgfSBmcm9tICdsaXQvZGVjb3JhdG9ycy5qcyc7XG5cbmltcG9ydCB7IFNiYk9wdGlvbkJhc2VFbGVtZW50IH0gZnJvbSAnLi9vcHRpb24tYmFzZS1lbGVtZW50LmpzJztcbmltcG9ydCBzdHlsZSBmcm9tICcuL29wdGlvbi5zY3NzP2xpdCZpbmxpbmUnO1xuaW1wb3J0ICcuLi8uLi92aXN1YWwtY2hlY2tib3guanMnO1xuXG5leHBvcnQgdHlwZSBTYmJPcHRpb25WYXJpYW50ID0gJ2F1dG9jb21wbGV0ZScgfCAnc2VsZWN0JyB8IG51bGw7XG5cbi8qKlxuICogSXQgZGlzcGxheXMgb24gb3B0aW9uIGl0ZW0gd2hpY2ggY2FuIGJlIHVzZWQgaW4gYHNiYi1zZWxlY3RgIG9yIGBzYmItYXV0b2NvbXBsZXRlYC5cbiAqXG4gKiBAc2xvdCAtIFVzZSB0aGUgdW5uYW1lZCBzbG90IHRvIGFkZCBjb250ZW50IHRvIHRoZSBvcHRpb24gbGFiZWwuXG4gKiBAc2xvdCBpY29uIC0gVXNlIHRoaXMgc2xvdCB0byBwcm92aWRlIGFuIGljb24uIElmIGBpY29uLW5hbWVgIGlzIHNldCwgYSBzYmItaWNvbiB3aWxsIGJlIHVzZWQuXG4gKiBAY3NzcHJvcCBbLS1zYmItb3B0aW9uLWljb24tY29udGFpbmVyLWRpc3BsYXk9bm9uZV0gLSBDYW4gYmUgdXNlZCB0byByZXNlcnZlIHNwYWNlIGV2ZW5cbiAqIHdoZW4gcHJlc2VydmUtaWNvbi1zcGFjZSBvbiBhdXRvY29tcGxldGUgaXMgbm90IHNldCBvciBpY29uTmFtZSBpcyBub3Qgc2V0LlxuICogQG92ZXJyaWRlVHlwZSB2YWx1ZSAtIChUID0gc3RyaW5nKSB8IG51bGxcbiAqL1xuZXhwb3J0XG5AY3VzdG9tRWxlbWVudCgnc2JiLW9wdGlvbicpXG5jbGFzcyBTYmJPcHRpb25FbGVtZW50PFQgPSBzdHJpbmc+IGV4dGVuZHMgU2JiT3B0aW9uQmFzZUVsZW1lbnQ8VD4ge1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHJlYWRvbmx5IHJvbGUgPSAnb3B0aW9uJztcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gc3R5bGU7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgcmVhZG9ubHkgZXZlbnRzID0ge1xuICAgIG9wdGlvbnNlbGVjdGlvbmNoYW5nZTogJ29wdGlvbnNlbGVjdGlvbmNoYW5nZScsXG4gICAgb3B0aW9uc2VsZWN0ZWQ6ICdvcHRpb25zZWxlY3RlZCcsXG4gIH0gYXMgY29uc3Q7XG5cbiAgcHJvdGVjdGVkIG9wdGlvbklkID0gYHNiYi1vcHRpb25gO1xuXG4gIHByaXZhdGUgc2V0IF92YXJpYW50KHN0YXRlOiBTYmJPcHRpb25WYXJpYW50KSB7XG4gICAgaWYgKHN0YXRlKSB7XG4gICAgICB0aGlzLnNldEF0dHJpYnV0ZSgnZGF0YS12YXJpYW50Jywgc3RhdGUpO1xuICAgIH1cbiAgfVxuICBwcml2YXRlIGdldCBfdmFyaWFudCgpOiBTYmJPcHRpb25WYXJpYW50IHtcbiAgICByZXR1cm4gdGhpcy5nZXRBdHRyaWJ1dGUoJ2RhdGEtdmFyaWFudCcpIGFzIFNiYk9wdGlvblZhcmlhbnQ7XG4gIH1cblxuICBwcml2YXRlIHNldCBfaXNNdWx0aXBsZShpc011bHRpcGxlOiBib29sZWFuKSB7XG4gICAgdGhpcy50b2dnbGVBdHRyaWJ1dGUoJ2RhdGEtbXVsdGlwbGUnLCBpc011bHRpcGxlKTtcbiAgfVxuICBwcml2YXRlIGdldCBfaXNNdWx0aXBsZSgpOiBib29sZWFuIHtcbiAgICByZXR1cm4gIXRoaXMuaHlkcmF0aW9uUmVxdWlyZWQgJiYgdGhpcy5oYXNBdHRyaWJ1dGUoJ2RhdGEtbXVsdGlwbGUnKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBzZXRBdHRyaWJ1dGVGcm9tUGFyZW50KCk6IHZvaWQge1xuICAgIGNvbnN0IHBhcmVudEdyb3VwID0gdGhpcy5jbG9zZXN0Py4oJ3NiYi1vcHRncm91cCcpO1xuICAgIGlmIChwYXJlbnRHcm91cCkge1xuICAgICAgdGhpcy5kaXNhYmxlZEZyb21Hcm91cCA9IHBhcmVudEdyb3VwLmRpc2FibGVkO1xuICAgICAgdGhpcy51cGRhdGVBcmlhRGlzYWJsZWQoKTtcbiAgICB9XG5cbiAgICB0aGlzLm5lZ2F0aXZlID0gISF0aGlzLmNsb3Nlc3Q/LihcbiAgICAgIC8vIDppcygpIHNlbGVjdG9yIG5vdCBwb3NzaWJsZSBkdWUgdG8gdGVzdCBlbnZpcm9ubWVudFxuICAgICAgYHNiYi1hdXRvY29tcGxldGVbbmVnYXRpdmVdLHNiYi1mb3JtLWZpZWxkW25lZ2F0aXZlXWAsXG4gICAgKTtcbiAgICB0aGlzLnRvZ2dsZUF0dHJpYnV0ZSgnZGF0YS1uZWdhdGl2ZScsIHRoaXMubmVnYXRpdmUpO1xuXG4gICAgdGhpcy50b2dnbGVBdHRyaWJ1dGUoJ2RhdGEtbXVsdGlwbGUnLCB0aGlzLl9pc011bHRpcGxlKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBzZWxlY3RCeUNsaWNrKGV2ZW50OiBNb3VzZUV2ZW50KTogdm9pZCB7XG4gICAgaWYgKHRoaXMuZGlzYWJsZWQgfHwgdGhpcy5kaXNhYmxlZEZyb21Hcm91cCkge1xuICAgICAgZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCk7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgaWYgKHRoaXMuX2lzTXVsdGlwbGUpIHtcbiAgICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xuICAgICAgdGhpcy5zZWxlY3RWaWFVc2VySW50ZXJhY3Rpb24oIXRoaXMuc2VsZWN0ZWQpO1xuICAgIH0gZWxzZSB7XG4gICAgICB0aGlzLnNlbGVjdFZpYVVzZXJJbnRlcmFjdGlvbih0cnVlKTtcbiAgICB9XG4gIH1cblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgc2VsZWN0VmlhVXNlckludGVyYWN0aW9uKHNlbGVjdGVkOiBib29sZWFuKTogdm9pZCB7XG4gICAgc3VwZXIuc2VsZWN0VmlhVXNlckludGVyYWN0aW9uKHNlbGVjdGVkKTtcbiAgICAvKiogVGhlIG9wdGlvbnNlbGVjdGlvbmNoYW5nZSBldmVudCBpcyBkaXNwYXRjaGVkIHdoZW4gdGhlIG9wdGlvbiBzZWxlY3Rpb24gc3RhdHVzIGNoYW5nZXMuICovXG4gICAgdGhpcy5kaXNwYXRjaEV2ZW50KG5ldyBFdmVudCgnb3B0aW9uc2VsZWN0aW9uY2hhbmdlJywgeyBidWJibGVzOiB0cnVlLCBjb21wb3NlZDogdHJ1ZSB9KSk7XG4gIH1cblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgaW5pdCgpOiB2b2lkIHtcbiAgICBzdXBlci5pbml0KCk7XG4gICAgdGhpcy5fc2V0VmFyaWFudEJ5Q29udGV4dCgpO1xuICAgIC8vIFdlIG5lZWQgdG8gY2hlY2sgaGlnaGxpZ2h0IHN0YXRlIGJvdGggb24gc2xvdCBjaGFuZ2UsIGJ1dCBhbHNvIHdoZW4gY29ubmVjdGluZ1xuICAgIC8vIHRoZSBlbGVtZW50IHRvIHRoZSBET00uIFRoZSBzbG90IGNoYW5nZSBldmVudHMgbWlnaHQgYmUgc3dhbGxvd2VkIHdoZW4gdXNpbmcgZGVjbGFyYXRpdmVcbiAgICAvLyBzaGFkb3cgRE9NIHdpdGggU1NSIG9yIGlmIHRoZSBET00gaXMgY2hhbmdlZCB3aGVuIGRpc2Nvbm5lY3RlZC5cbiAgICB0aGlzLmhhbmRsZUhpZ2hsaWdodFN0YXRlKCk7XG4gIH1cblxuICBwcml2YXRlIF9zZXRWYXJpYW50QnlDb250ZXh0KCk6IHZvaWQge1xuICAgIGlmICh0aGlzLmNsb3Nlc3Q/Lignc2JiLWF1dG9jb21wbGV0ZScpKSB7XG4gICAgICB0aGlzLl92YXJpYW50ID0gJ2F1dG9jb21wbGV0ZSc7XG4gICAgfSBlbHNlIGlmICh0aGlzLmNsb3Nlc3Q/Lignc2JiLXNlbGVjdCcpKSB7XG4gICAgICB0aGlzLl92YXJpYW50ID0gJ3NlbGVjdCc7XG4gICAgfVxuICAgIHRoaXMuX2lzTXVsdGlwbGUgPSAhIXRoaXMuY2xvc2VzdD8uKCdzYmItc2VsZWN0W211bHRpcGxlXScpO1xuICB9XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIGhhbmRsZUhpZ2hsaWdodFN0YXRlKCk6IHZvaWQge1xuICAgIGlmICh0aGlzLl92YXJpYW50ICE9PSAnYXV0b2NvbXBsZXRlJykge1xuICAgICAgdGhpcy51cGRhdGVEaXNhYmxlSGlnaGxpZ2h0KHRydWUpO1xuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIHN1cGVyLmhhbmRsZUhpZ2hsaWdodFN0YXRlKCk7XG4gIH1cblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVySWNvbigpOiBUZW1wbGF0ZVJlc3VsdCB7XG4gICAgcmV0dXJuIGh0bWxgXG4gICAgICA8IS0tIEljb24gLS0+XG4gICAgICAkeyF0aGlzLl9pc011bHRpcGxlXG4gICAgICAgID8gaHRtbGAgPHNwYW4gY2xhc3M9XCJzYmItb3B0aW9uX19pY29uXCI+ICR7dGhpcy5yZW5kZXJJY29uU2xvdCgpfSA8L3NwYW4+YFxuICAgICAgICA6IG5vdGhpbmd9XG5cbiAgICAgIDwhLS0gQ2hlY2tib3ggLS0+XG4gICAgICAke3RoaXMuX2lzTXVsdGlwbGVcbiAgICAgICAgPyBodG1sYFxuICAgICAgICAgICAgPHNiYi12aXN1YWwtY2hlY2tib3hcbiAgICAgICAgICAgICAgP2NoZWNrZWQ9JHt0aGlzLnNlbGVjdGVkfVxuICAgICAgICAgICAgICA/ZGlzYWJsZWQ9JHt0aGlzLmRpc2FibGVkIHx8IHRoaXMuZGlzYWJsZWRGcm9tR3JvdXB9XG4gICAgICAgICAgICAgID9uZWdhdGl2ZT0ke3RoaXMubmVnYXRpdmV9XG4gICAgICAgICAgICA+
|
|
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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAqBM,oBAAgB,MAAA;;0BADrB,cAAc,YAAY,CAAC;;;;oBACe;AAAR,EAAA,mBAAQ,YAAuB;AAAA;;AAQtD,WAAA,WAAW;AAAA,IAiHvB;AAAA,IA/GE,IAAY,SAAS,OAAuB;AAC1C,UAAI,OAAO;AACT,aAAK,aAAa,gBAAgB,KAAK;AAAA,MACzC;AAAA,IACF;AAAA,IACA,IAAY,WAAQ;AAClB,aAAO,KAAK,aAAa,cAAc;AAAA,IACzC;AAAA,IAEA,IAAY,YAAY,YAAmB;AACzC,WAAK,gBAAgB,iBAAiB,UAAU;AAAA,IAClD;AAAA,IACA,IAAY,cAAW;AACrB,aAAO,CAAC,KAAK,qBAAqB,KAAK,aAAa,eAAe;AAAA,IACrE;AAAA,IAEU,yBAAsB;AAC9B,YAAM,cAAc,KAAK,UAAU,cAAc;AACjD,UAAI,aAAa;AACf,aAAK,oBAAoB,YAAY;AACrC,aAAK,mBAAA;AAAA,MACP;AAEA,WAAK,WAAW,CAAC,CAAC,KAAK;AAAA;AAAA,QAErB;AAAA,MAAA;AAEF,WAAK,gBAAgB,iBAAiB,KAAK,QAAQ;AAEnD,WAAK,gBAAgB,iBAAiB,KAAK,WAAW;AAAA,IACxD;AAAA,IAEU,cAAc,OAAiB;AACvC,UAAI,KAAK,YAAY,KAAK,mBAAmB;AAC3C,cAAM,gBAAA;AACN;AAAA,MACF;AAEA,UAAI,KAAK,aAAa;AACpB,cAAM,gBAAA;AACN,aAAK,yBAAyB,CAAC,KAAK,QAAQ;AAAA,MAC9C,OAAO;AACL,aAAK,yBAAyB,IAAI;AAAA,MACpC;AAAA,IACF;AAAA,IAEmB,yBAAyB,UAAiB;AAC3D,YAAM,yBAAyB,QAAQ;AAEvC,WAAK,cAAc,IAAI,MAAM,yBAAyB,EAAE,SAAS,MAAM,UAAU,KAAA,CAAM,CAAC;AAAA,IAC1F;AAAA,IAEmB,OAAI;AACrB,YAAM,KAAA;AACN,WAAK,qBAAA;AAIL,WAAK,qBAAA;AAAA,IACP;AAAA,IAEQ,uBAAoB;AAC1B,UAAI,KAAK,UAAU,kBAAkB,GAAG;AACtC,aAAK,WAAW;AAAA,MAClB,WAAW,KAAK,UAAU,YAAY,GAAG;AACvC,aAAK,WAAW;AAAA,MAClB;AACA,WAAK,cAAc,CAAC,CAAC,KAAK,UAAU,sBAAsB;AAAA,IAC5D;AAAA,IAEmB,uBAAoB;AACrC,UAAI,KAAK,aAAa,gBAAgB;AACpC,aAAK,uBAAuB,IAAI;AAChC;AAAA,MACF;AAEA,YAAM,qBAAA;AAAA,IACR;AAAA,IAEmB,aAAU;AAC3B,aAAO;AAAA;AAAA,QAEH,CAAC,KAAK,cACJ,wCAAwC,KAAK,eAAA,CAAgB,aAC7D,OAAO;AAAA;AAAA;AAAA,QAGT,KAAK,cACH;AAAA;AAAA,yBAEe,KAAK,QAAQ;AAAA,0BACZ,KAAK,YAAY,KAAK,iBAAiB;AAAA,0BACvC,KAAK,QAAQ;AAAA;AAAA,cAG7B,OAAO;AAAA;AAAA,IAEf;AAAA,IAEmB,cAAW;AAC5B,UAAI,KAAK,aAAa,gBAAgB;AACpC,eAAO;AAAA,MACT;AACA,aAAO,MAAM,YAAA;AAAA,IACf;AAAA,IAEmB,aAAU;AAC3B,aAAO,KAAK,aAAa,YAAY,CAAC,KAAK,eAAe,KAAK,WAC3D,gDACA;AAAA,IACN;AAAA;;AAxHF,iBAAA,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;QACkC,GAAA,OAAO,UAChB,GAAA,SAAyB,OAChB,GAAA,SAAS;AAAA,IACvC,uBAAuB;AAAA,IACvB,gBAAgB;AAAA,EAAA,GALd,kBAAA,YAAA,uBAAA,GAA6B;;;"}
|
|
@@ -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;
|
|
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
|
|
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
|
|
13
|
-
import { SbbIconNameMixin as
|
|
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
|
|
16
|
-
const x = Y,
|
|
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
|
|
23
|
+
let vt = (() => {
|
|
24
24
|
var c, u, _, p, m, f, l;
|
|
25
|
-
let s = [W()], a, n = [], o, L =
|
|
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,
|
|
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:
|
|
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}-${
|
|
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
|
|
171
|
+
return v`<span class="sbb-option__icon"> ${this.renderIconSlot()} </span>`;
|
|
172
172
|
}
|
|
173
173
|
renderLabel() {
|
|
174
|
-
return this.label && !this.disableLabelHighlight ? this.getHighlightedLabel() :
|
|
174
|
+
return this.label && !this.disableLabelHighlight ? this.getHighlightedLabel() : S;
|
|
175
175
|
}
|
|
176
176
|
renderTick() {
|
|
177
|
-
return
|
|
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
|
-
|
|
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
|
-
>` :
|
|
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()],
|
|
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,
|
|
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,
|
|
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,
|
|
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
|
-
|
|
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;
|
|
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,
|
|
10
|
-
return t = class extends
|
|
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
|
|
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(
|
|
79
|
-
l(null, a = { value: i }, n, { kind: "class", name: i.name, metadata: o }, null,
|
|
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,
|
|
83
|
+
}, c(i, r), i;
|
|
84
84
|
})();
|
|
85
85
|
export {
|
|
86
86
|
k as SbbOptionElement
|