@sbb-esta/lyne-elements 2.7.1 → 2.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/core/styles/core.scss +7 -1
- package/core/styles/node_modules_@sbb-esta_lyne-design-tokens_dist_scss_sbb-variables.scss +2 -0
- package/core/styles/node_modules_@sbb-esta_lyne-design-tokens_dist_scss_sbb-variables_css--mixin.scss +5 -1
- package/core.css +12 -2
- package/custom-elements.json +447 -42
- package/development/icon/icon-base.js +5 -1
- package/development/paginator/common/paginator-common.d.ts +11 -1
- package/development/paginator/common/paginator-common.d.ts.map +1 -1
- package/development/paginator/common/paginator-common.js +37 -9
- package/development/paginator/paginator/paginator.js +2 -2
- package/development/sbb-tokens-CVLcOi-S.js +1 -1
- package/development/table/table-wrapper/table-wrapper.d.ts +7 -4
- package/development/table/table-wrapper/table-wrapper.d.ts.map +1 -1
- package/development/table/table-wrapper/table-wrapper.js +80 -69
- package/development/toggle/toggle/toggle.d.ts +0 -1
- package/development/toggle/toggle/toggle.d.ts.map +1 -1
- package/development/toggle/toggle/toggle.js +51 -47
- package/development/toggle/toggle-option/toggle-option.d.ts +2 -1
- package/development/toggle/toggle-option/toggle-option.d.ts.map +1 -1
- package/development/toggle/toggle-option/toggle-option.js +15 -29
- package/icon/icon-base.js +21 -21
- package/package.json +1 -1
- package/paginator/common/paginator-common.d.ts +11 -1
- package/paginator/common/paginator-common.d.ts.map +1 -1
- package/paginator/common/paginator-common.js +61 -31
- package/paginator/paginator/paginator.js +3 -3
- package/standard-theme.css +12 -2
- package/table/table-wrapper/table-wrapper.d.ts +7 -4
- package/table/table-wrapper/table-wrapper.d.ts.map +1 -1
- package/table/table-wrapper/table-wrapper.js +53 -31
- package/toggle/toggle/toggle.d.ts +0 -1
- package/toggle/toggle/toggle.d.ts.map +1 -1
- package/toggle/toggle/toggle.js +43 -48
- package/toggle/toggle-option/toggle-option.d.ts +2 -1
- package/toggle/toggle-option/toggle-option.d.ts.map +1 -1
- package/toggle/toggle-option/toggle-option.js +40 -30
|
@@ -1,7 +1,15 @@
|
|
|
1
|
+
var __typeError = (msg) => {
|
|
2
|
+
throw TypeError(msg);
|
|
3
|
+
};
|
|
4
|
+
var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot " + msg);
|
|
5
|
+
var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read from private field"), getter ? getter.call(obj) : member.get(obj));
|
|
6
|
+
var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot add the same private member more than once") : member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
|
|
7
|
+
var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), setter ? setter.call(obj, value) : member.set(obj, value), value);
|
|
1
8
|
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
9
|
import { ResizeController } from "@lit-labs/observers/resize-controller.js";
|
|
3
|
-
import { css, LitElement, html } from "lit";
|
|
4
|
-
import { customElement } from "lit/decorators.js";
|
|
10
|
+
import { css, LitElement, isServer, html } from "lit";
|
|
11
|
+
import { customElement, property } from "lit/decorators.js";
|
|
12
|
+
import { forceType } from "../../core/decorators.js";
|
|
5
13
|
import { SbbNegativeMixin } from "../../core/mixins.js";
|
|
6
14
|
const style = css`*,
|
|
7
15
|
::before,
|
|
@@ -10,83 +18,85 @@ const style = css`*,
|
|
|
10
18
|
}
|
|
11
19
|
|
|
12
20
|
:host {
|
|
13
|
-
--sbb-table-wrapper-border-radius: var(--sbb-border-radius-4x);
|
|
14
21
|
display: block;
|
|
22
|
+
overflow: auto;
|
|
15
23
|
}
|
|
16
24
|
|
|
17
|
-
|
|
18
|
-
|
|
25
|
+
:host(:not(.sbb-table-wrapper-offset-none)) {
|
|
26
|
+
padding-bottom: var(--sbb-spacing-fixed-1x);
|
|
19
27
|
}
|
|
20
28
|
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
--sbb-scrollbar-thumb-width: 0.5rem;
|
|
25
|
-
--sbb-scrollbar-thumb-width-hover: var(--sbb-scrollbar-thumb-width);
|
|
26
|
-
--sbb-scrollbar-width-firefox: auto;
|
|
27
|
-
--sbb-scrollbar-color: var(--sbb-color-black-alpha-30);
|
|
28
|
-
--sbb-scrollbar-color-hover: var(--sbb-color-black-alpha-60);
|
|
29
|
-
--sbb-scrollbar-track-color: var(--sbb-color-cloud);
|
|
30
|
-
--sbb-scrollbar-width: var(--sbb-spacing-fixed-3x);
|
|
31
|
-
}
|
|
32
|
-
.sbb-table-wrapper::-webkit-scrollbar {
|
|
33
|
-
width: var(--sbb-scrollbar-width);
|
|
34
|
-
height: var(--sbb-scrollbar-width);
|
|
35
|
-
background-color: var(--sbb-scrollbar-track-color, transparent);
|
|
29
|
+
:host(:focus-visible) {
|
|
30
|
+
outline-offset: var(--sbb-focus-outline-offset);
|
|
31
|
+
outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);
|
|
36
32
|
}
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
.sbb-table-wrapper::-webkit-scrollbar-thumb {
|
|
41
|
-
background-color: var(--sbb-scrollbar-color, currentcolor);
|
|
42
|
-
border: calc(0.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width))) solid transparent;
|
|
43
|
-
border-radius: var(--sbb-border-radius-4x);
|
|
44
|
-
background-clip: padding-box;
|
|
45
|
-
}
|
|
46
|
-
.sbb-table-wrapper::-webkit-scrollbar-thumb:hover {
|
|
47
|
-
background-color: var(--sbb-scrollbar-color-hover, currentcolor);
|
|
48
|
-
border-width: calc(0.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width-hover)));
|
|
49
|
-
}
|
|
50
|
-
.sbb-table-wrapper::-webkit-scrollbar-button, .sbb-table-wrapper::-webkit-scrollbar-corner {
|
|
51
|
-
display: none;
|
|
52
|
-
}
|
|
53
|
-
@supports not selector(::-webkit-scrollbar) {
|
|
54
|
-
.sbb-table-wrapper {
|
|
55
|
-
scrollbar-width: var(--sbb-scrollbar-width-firefox);
|
|
56
|
-
scrollbar-color: var(--sbb-scrollbar-color, currentcolor) var(--sbb-scrollbar-track-color, transparent);
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
:host([negative]) .sbb-table-wrapper {
|
|
60
|
-
--sbb-scrollbar-color: var(--sbb-color-white-alpha-30);
|
|
61
|
-
--sbb-scrollbar-color-hover: var(--sbb-color-white-alpha-60);
|
|
62
|
-
--sbb-scrollbar-track-color: var(--sbb-color-iron);
|
|
63
|
-
}
|
|
64
|
-
:host(:not(.sbb-table-wrapper-offset-none)) .sbb-table-wrapper {
|
|
65
|
-
padding-bottom: var(--sbb-spacing-fixed-1x);
|
|
33
|
+
|
|
34
|
+
::slotted(.sbb-table) {
|
|
35
|
+
width: 100%;
|
|
66
36
|
}`;
|
|
67
37
|
let SbbTableWrapperElement = (() => {
|
|
68
|
-
var _a;
|
|
38
|
+
var _focusable_accessor_storage, _a;
|
|
69
39
|
let _classDecorators = [customElement("sbb-table-wrapper")];
|
|
70
40
|
let _classDescriptor;
|
|
71
41
|
let _classExtraInitializers = [];
|
|
72
42
|
let _classThis;
|
|
73
43
|
let _classSuper = SbbNegativeMixin(LitElement);
|
|
44
|
+
let _focusable_decorators;
|
|
45
|
+
let _focusable_initializers = [];
|
|
46
|
+
let _focusable_extraInitializers = [];
|
|
74
47
|
_a = class extends _classSuper {
|
|
75
48
|
constructor() {
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
49
|
+
var _a2;
|
|
50
|
+
super();
|
|
51
|
+
__privateAdd(this, _focusable_accessor_storage, __runInitializers(this, _focusable_initializers, false));
|
|
52
|
+
__runInitializers(this, _focusable_extraInitializers);
|
|
53
|
+
const internals = this.attachInternals();
|
|
54
|
+
internals.role = "section";
|
|
55
|
+
this.addController(new ResizeController(this, {
|
|
79
56
|
skipInitial: true,
|
|
80
57
|
callback: () => this._checkHorizontalScrollbarOffset()
|
|
81
|
-
});
|
|
82
|
-
|
|
83
|
-
firstUpdated(changedProperties) {
|
|
84
|
-
super.firstUpdated(changedProperties);
|
|
85
|
-
this._tableWrapper = this.shadowRoot.querySelector(".sbb-table-wrapper");
|
|
86
|
-
this._tableWrapper.addEventListener("scroll", () => this._checkHorizontalScrollbarOffset(), {
|
|
58
|
+
}));
|
|
59
|
+
(_a2 = this.addEventListener) == null ? void 0 : _a2.call(this, "scroll", () => this._checkHorizontalScrollbarOffset(), {
|
|
87
60
|
passive: true
|
|
88
61
|
});
|
|
89
|
-
|
|
62
|
+
}
|
|
63
|
+
/** Whether the table wrapper is focusable. */
|
|
64
|
+
get focusable() {
|
|
65
|
+
return __privateGet(this, _focusable_accessor_storage);
|
|
66
|
+
}
|
|
67
|
+
set focusable(value) {
|
|
68
|
+
__privateSet(this, _focusable_accessor_storage, value);
|
|
69
|
+
}
|
|
70
|
+
connectedCallback() {
|
|
71
|
+
super.connectedCallback();
|
|
72
|
+
this._updateScrollbarClass();
|
|
73
|
+
}
|
|
74
|
+
willUpdate(changedProperties) {
|
|
75
|
+
super.willUpdate(changedProperties);
|
|
76
|
+
if (changedProperties.has("focusable")) {
|
|
77
|
+
if (this.focusable) {
|
|
78
|
+
if (!this.hasAttribute("tabindex")) {
|
|
79
|
+
this.setAttribute("tabindex", "0");
|
|
80
|
+
}
|
|
81
|
+
} else {
|
|
82
|
+
this.removeAttribute("tabindex");
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
if (changedProperties.has("negative")) {
|
|
86
|
+
this._updateScrollbarClass();
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
_updateScrollbarClass() {
|
|
90
|
+
if (isServer) {
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
if (this.negative) {
|
|
94
|
+
this.classList.remove("sbb-scrollbar-thick-track-visible");
|
|
95
|
+
this.classList.add("sbb-scrollbar-thick-negative-track-visible");
|
|
96
|
+
} else {
|
|
97
|
+
this.classList.remove("sbb-scrollbar-thick-negative-track-visible");
|
|
98
|
+
this.classList.add("sbb-scrollbar-thick-track-visible");
|
|
99
|
+
}
|
|
90
100
|
}
|
|
91
101
|
/**
|
|
92
102
|
* Calculates whether the table is horizontally scrolled and adds the
|
|
@@ -98,24 +108,25 @@ let SbbTableWrapperElement = (() => {
|
|
|
98
108
|
this.classList.add(`sbb-table-wrapper-offset-${state}`);
|
|
99
109
|
}
|
|
100
110
|
_calculateScrollOffset() {
|
|
101
|
-
|
|
102
|
-
if (wrapper.scrollWidth === wrapper.offsetWidth) {
|
|
111
|
+
if (this.scrollWidth === this.offsetWidth) {
|
|
103
112
|
return "none";
|
|
104
113
|
}
|
|
105
|
-
const isAtStart =
|
|
106
|
-
const isAtEnd =
|
|
114
|
+
const isAtStart = this.scrollLeft === 0;
|
|
115
|
+
const isAtEnd = this.scrollWidth - this.scrollLeft - this.offsetWidth <= 1;
|
|
107
116
|
if (isAtStart) {
|
|
108
117
|
return isAtEnd ? "none" : "right";
|
|
109
118
|
}
|
|
110
119
|
return isAtEnd ? "left" : "both";
|
|
111
120
|
}
|
|
112
121
|
render() {
|
|
113
|
-
return html`<
|
|
114
|
-
<slot></slot>
|
|
115
|
-
</div>`;
|
|
122
|
+
return html`<slot></slot>`;
|
|
116
123
|
}
|
|
117
|
-
}, _classThis = _a, (() => {
|
|
124
|
+
}, _focusable_accessor_storage = new WeakMap(), _classThis = _a, (() => {
|
|
118
125
|
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
126
|
+
_focusable_decorators = [forceType(), property({ reflect: true, type: Boolean })];
|
|
127
|
+
__esDecorate(_a, null, _focusable_decorators, { kind: "accessor", name: "focusable", static: false, private: false, access: { has: (obj) => "focusable" in obj, get: (obj) => obj.focusable, set: (obj, value) => {
|
|
128
|
+
obj.focusable = value;
|
|
129
|
+
} }, metadata: _metadata }, _focusable_initializers, _focusable_extraInitializers);
|
|
119
130
|
__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
|
|
120
131
|
_classThis = _classDescriptor.value;
|
|
121
132
|
if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
@@ -125,4 +136,4 @@ let SbbTableWrapperElement = (() => {
|
|
|
125
136
|
export {
|
|
126
137
|
SbbTableWrapperElement
|
|
127
138
|
};
|
|
128
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
139
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"table-wrapper.js","sources":["../../../../../src/elements/table/table-wrapper/table-wrapper.ts"],"sourcesContent":["import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport {\n  type CSSResultGroup,\n  html,\n  isServer,\n  LitElement,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { forceType } from '../../core/decorators.js';\nimport { SbbNegativeMixin } from '../../core/mixins.js';\n\nimport style from './table-wrapper.scss?lit&inline';\n\n/**\n * Wraps a table to enhance its functionality.\n *\n * @slot - Use the unnamed slot to add the table.\n */\nexport\n@customElement('sbb-table-wrapper')\nclass SbbTableWrapperElement extends SbbNegativeMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n\n  /** Whether the table wrapper is focusable. */\n  @forceType()\n  @property({ reflect: true, type: Boolean })\n  public accessor focusable: boolean = false;\n\n  public constructor() {\n    super();\n\n    const internals: ElementInternals = this.attachInternals();\n    /** @internal */\n    internals.role = 'section';\n\n    this.addController(\n      new ResizeController(this, {\n        skipInitial: true,\n        callback: () => this._checkHorizontalScrollbarOffset(),\n      }),\n    );\n\n    this.addEventListener?.('scroll', () => this._checkHorizontalScrollbarOffset(), {\n      passive: true,\n    });\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n\n    // As we can't include the scrollbar mixin on the host and to minimize\n    // payload, we decided to add the scrollbar class here.\n    // This is an exception as we normally don't alter the classList of the host.\n    this._updateScrollbarClass();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('focusable')) {\n      if (this.focusable) {\n        if (!this.hasAttribute('tabindex')) {\n          this.setAttribute('tabindex', '0');\n        }\n      } else {\n        this.removeAttribute('tabindex');\n      }\n    }\n\n    if (changedProperties.has('negative')) {\n      this._updateScrollbarClass();\n    }\n  }\n\n  private _updateScrollbarClass(): void {\n    if (isServer) {\n      return;\n    }\n    if (this.negative) {\n      this.classList.remove('sbb-scrollbar-thick-track-visible');\n      this.classList.add('sbb-scrollbar-thick-negative-track-visible');\n    } else {\n      this.classList.remove('sbb-scrollbar-thick-negative-track-visible');\n      this.classList.add('sbb-scrollbar-thick-track-visible');\n    }\n  }\n\n  /**\n   *  Calculates whether the table is horizontally scrolled and adds the\n   *  corresponding class `sbb-table-wrapper-offset-${none | left | right | both}`\n   */\n  private _checkHorizontalScrollbarOffset(): void {\n    const state = this._calculateScrollOffset();\n    this.classList.remove(\n      `sbb-table-wrapper-offset-none`,\n      `sbb-table-wrapper-offset-left`,\n      `sbb-table-wrapper-offset-right`,\n      `sbb-table-wrapper-offset-both`,\n    );\n    this.classList.add(`sbb-table-wrapper-offset-${state}`);\n  }\n\n  private _calculateScrollOffset(): 'none' | 'left' | 'right' | 'both' {\n    if (this.scrollWidth === this.offsetWidth) {\n      return 'none';\n    }\n    const isAtStart = this.scrollLeft === 0;\n    // In some cases the combined value of scrollLeft and offsetWidth is off by\n    // 1 pixel from the scrollWidth.\n    const isAtEnd = this.scrollWidth - this.scrollLeft - this.offsetWidth <= 1;\n\n    if (isAtStart) {\n      return isAtEnd ? 'none' : 'right';\n    }\n    return isAtEnd ? 'left' : 'both';\n  }\n\n  protected override render(): TemplateResult {\n    return html`<slot></slot>`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-table-wrapper': SbbTableWrapperElement;\n  }\n}\n"],"names":["_a"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;IAuBM,0BAAsB,MAAA;;0BAD3B,cAAc,mBAAmB,CAAC;;;;oBACE,iBAAiB,UAAU;;;;AAAnC,EAAA,mBAAQ,YAA4B;AAAA,IAQ/D,cAAA;;;AAFA,sDAAA,kBAAA,MAAA,yBAAqC,KAAK;;AAKlC,YAAA,YAA8B,KAAK;AAEzC,gBAAU,OAAO;AAEZ,WAAA,cACH,IAAI,iBAAiB,MAAM;AAAA,QACzB,aAAa;AAAA,QACb,UAAU,MAAM,KAAK,gCAAiC;AAAA,MAAA,CACvD,CAAC;AAGJ,OAAAA,MAAA,KAAK,qBAAL,gBAAAA,IAAA,WAAwB,UAAU,MAAM,KAAK,mCAAmC;AAAA,QAC9E,SAAS;AAAA,MAAA;AAAA,IACV;AAAA;AAAA,IAlBH,IAAgB,YAA2B;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA3C,IAAgB,UAA2B,OAAA;AAAA,yBAAA,6BAAA;AAAA,IAAA;AAAA,IAqB3B,oBAAiB;AAC/B,YAAM,kBAAiB;AAKvB,WAAK,sBAAqB;AAAA,IAAA;AAAA,IAGT,WAAW,mBAAuC;AACnE,YAAM,WAAW,iBAAiB;AAE9B,UAAA,kBAAkB,IAAI,WAAW,GAAG;AACtC,YAAI,KAAK,WAAW;AAClB,cAAI,CAAC,KAAK,aAAa,UAAU,GAAG;AAC7B,iBAAA,aAAa,YAAY,GAAG;AAAA,UAAA;AAAA,QACnC,OACK;AACL,eAAK,gBAAgB,UAAU;AAAA,QAAA;AAAA,MACjC;AAGE,UAAA,kBAAkB,IAAI,UAAU,GAAG;AACrC,aAAK,sBAAqB;AAAA,MAAA;AAAA,IAC5B;AAAA,IAGM,wBAAqB;AAC3B,UAAI,UAAU;AACZ;AAAA,MAAA;AAEF,UAAI,KAAK,UAAU;AACZ,aAAA,UAAU,OAAO,mCAAmC;AACpD,aAAA,UAAU,IAAI,4CAA4C;AAAA,MAAA,OAC1D;AACA,aAAA,UAAU,OAAO,4CAA4C;AAC7D,aAAA,UAAU,IAAI,mCAAmC;AAAA,MAAA;AAAA,IACxD;AAAA;AAAA;AAAA;AAAA;AAAA,IAOM,kCAA+B;AAC/B,YAAA,QAAQ,KAAK;AACnB,WAAK,UAAU,OACb,iCACA,iCACA,kCACA,+BAA+B;AAEjC,WAAK,UAAU,IAAI,4BAA4B,KAAK,EAAE;AAAA,IAAA;AAAA,IAGhD,yBAAsB;AACxB,UAAA,KAAK,gBAAgB,KAAK,aAAa;AAClC,eAAA;AAAA,MAAA;AAEH,YAAA,YAAY,KAAK,eAAe;AAGtC,YAAM,UAAU,KAAK,cAAc,KAAK,aAAa,KAAK,eAAe;AAEzE,UAAI,WAAW;AACb,eAAO,UAAU,SAAS;AAAA,MAAA;AAE5B,aAAO,UAAU,SAAS;AAAA,IAAA;AAAA,IAGT,SAAM;AAChB,aAAA;AAAA,IAAA;AAAA,KA5FT;;AAFC,4BAAA,CAAA,UAAW,GACX,SAAS,EAAE,SAAS,MAAM,MAAM,SAAS,CAAC;AAC3B,iBAAA,IAAA,MAAA,uBAAA,EAAA,MAAA,YAAA,MAAA,aAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,eAAA,KAAA,KAAA,CAAA,QAAA,IAAA,WAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAA,YAA2B;AAAA,SAAA,UAAA,aAAA,yBAAA,4BAAA;AAN7C,iBAoGC,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;QAnGwB,GAAM,SAAmB,OAD5C,kBAAsB,YAAA,uBAAA,GAAC;;;"}
|
|
@@ -33,7 +33,6 @@ export declare class SbbToggleElement extends SbbToggleElement_base {
|
|
|
33
33
|
/** The child instances of sbb-toggle-option as an array. */
|
|
34
34
|
get options(): SbbToggleOptionElement[];
|
|
35
35
|
private _loaded;
|
|
36
|
-
private _toggleResizeObserver;
|
|
37
36
|
/** Emits whenever the toggle value changes. */
|
|
38
37
|
private _change;
|
|
39
38
|
constructor();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"toggle.d.ts","sourceRoot":"","sources":["../../../../../src/elements/toggle/toggle/toggle.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"toggle.d.ts","sourceRoot":"","sources":["../../../../../src/elements/toggle/toggle/toggle.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAGnB,UAAU,EACV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAOb,OAAO,EACL,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,EAGtB,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,KAAK,sBAAsB,EAAE,MAAM,qBAAqB,CAAC;;AAIlE;;;;;GAKG;AACH,qBAEM,gBAAiB,SAAQ,qBAAoD;IACjF,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;MAElB;IAEX;;;OAGG;IACH,SAEgB,IAAI,EAAE,OAAO,CAAS;IAEtC;;;OAGG;IACH,SAA6C,IAAI,EAAE,GAAG,GAAG,GAAG,CAAwB;IAEpF;;;OAGG;IACH,IACoB,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,EAM7C;IACD,IAAoB,KAAK,IAAI,MAAM,CAIlC;IACD,OAAO,CAAC,MAAM,CAAuB;IAErC,4DAA4D;IAC5D,IAAW,OAAO,IAAI,sBAAsB,EAAE,CAE7C;IAED,OAAO,CAAC,OAAO,CAAkB;IAEjC,+CAA+C;IAC/C,OAAO,CAAC,OAAO,CAGZ;;IAWa,iBAAiB,IAAI,IAAI;cAKtB,UAAU,CAAC,iBAAiB,EAAE,cAAc,GAAG,IAAI;cAO7C,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ7F;;;OAGG;IACI,aAAa,IAAI,IAAI;IAK5B;;OAEG;IACI,iBAAiB,IAAI,IAAI;IAIzB,wBAAwB,CAC7B,KAAK,EAAE,gBAAgB,GAAG,IAAI,EAC9B,OAAO,EAAE,iBAAiB,GACzB,IAAI;IAIP;;;OAGG;IACI,kBAAkB,CAAC,QAAQ,UAAQ,GAAG,IAAI;IAmCjD,SAAS,CAAC,eAAe,IAAI,IAAI;IAIjC,OAAO,CAAC,aAAa;IAKrB,OAAO,CAAC,aAAa;IAuBrB,OAAO,CAAC,eAAe;IAMvB;;OAEG;IACH,OAAO,CAAC,YAAY;IAKpB,OAAO,CAAC,cAAc;cA6BH,MAAM,IAAI,cAAc;CAO5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,YAAY,EAAE,gBAAgB,CAAC;KAChC;CACF"}
|
|
@@ -6,7 +6,6 @@ var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read fr
|
|
|
6
6
|
var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot add the same private member more than once") : member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
|
|
7
7
|
var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), setter ? setter.call(obj, value) : member.set(obj, value), value);
|
|
8
8
|
import { __esDecorate, __runInitializers } from "tslib";
|
|
9
|
-
import { ResizeController } from "@lit-labs/observers/resize-controller.js";
|
|
10
9
|
import { css, LitElement, isServer, html } from "lit";
|
|
11
10
|
import { customElement, property } from "lit/decorators.js";
|
|
12
11
|
import { interactivityChecker, isArrowKeyPressed, getNextElementIndex } from "../../core/a11y.js";
|
|
@@ -23,62 +22,59 @@ const style = css`*,
|
|
|
23
22
|
|
|
24
23
|
:host {
|
|
25
24
|
display: block;
|
|
25
|
+
width: fit-content;
|
|
26
|
+
border-radius: var(--sbb-toggle-border-radius);
|
|
26
27
|
--sbb-toggle-width: fit-content;
|
|
27
28
|
--sbb-toggle-min-width: calc(
|
|
28
|
-
var(--sbb-toggle-padding-inline) *
|
|
29
|
+
var(--sbb-toggle-padding-inline) * 4 + var(--sbb-size-icon-ui-small)
|
|
29
30
|
);
|
|
31
|
+
--sbb-toggle-selected-option-border-width: var(--sbb-border-width-1x);
|
|
32
|
+
--sbb-toggle-selected-option-border-style: solid;
|
|
30
33
|
--sbb-toggle-selected-option-border-color: var(--sbb-color-smoke);
|
|
34
|
+
--sbb-toggle-selected-option-background-color: var(--sbb-color-white);
|
|
35
|
+
--sbb-toggle-selected-option-border-offset: 0.125rem;
|
|
31
36
|
--sbb-toggle-padding-inline: var(--sbb-spacing-responsive-xxxs);
|
|
32
37
|
--sbb-toggle-animation-duration: var(
|
|
33
38
|
--sbb-disable-animation-duration,
|
|
34
39
|
var(--sbb-animation-duration-6x)
|
|
35
40
|
);
|
|
36
|
-
--sbb-toggle-height:
|
|
37
|
-
--sbb-toggle-border-width: var(--sbb-border-width-1x);
|
|
38
|
-
--sbb-toggle-border-style: solid;
|
|
41
|
+
--sbb-toggle-height: var(--sbb-size-element-xxs);
|
|
39
42
|
--sbb-toggle-border-radius: var(--sbb-border-radius-infinity);
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
}
|
|
43
|
+
--sbb-toggle-grid-template-columns: auto auto;
|
|
44
|
+
--_sbb-toggle-height: calc(
|
|
45
|
+
var(--sbb-toggle-height) - 2 * var(--sbb-toggle-selected-option-border-offset)
|
|
46
|
+
);
|
|
45
47
|
}
|
|
46
48
|
@media (forced-colors: active) {
|
|
47
49
|
:host {
|
|
48
50
|
--sbb-toggle-selected-option-border-color: Highlight;
|
|
49
|
-
--sbb-toggle-border-width: var(--sbb-border-width-2x);
|
|
51
|
+
--sbb-toggle-selected-option-border-width: var(--sbb-border-width-2x);
|
|
50
52
|
}
|
|
51
53
|
}
|
|
52
54
|
|
|
53
55
|
:host([even]) {
|
|
56
|
+
width: 100%;
|
|
54
57
|
--sbb-toggle-width: 100%;
|
|
55
|
-
|
|
56
|
-
:host([even]) ::slotted(sbb-toggle-option) {
|
|
57
|
-
width: 50%;
|
|
58
|
+
--sbb-toggle-grid-template-columns: 50% 50%;
|
|
58
59
|
}
|
|
59
60
|
|
|
60
61
|
:host(:disabled) {
|
|
61
62
|
--sbb-toggle-selected-option-border-color: var(--sbb-color-graphite);
|
|
62
|
-
--sbb-toggle-border-style: dashed;
|
|
63
|
+
--sbb-toggle-selected-option-border-style: dashed;
|
|
63
64
|
}
|
|
64
65
|
@media (forced-colors: active) {
|
|
65
66
|
:host(:disabled) {
|
|
66
|
-
--sbb-toggle-border-style: solid;
|
|
67
|
+
--sbb-toggle-selected-option-border-style: solid;
|
|
67
68
|
--sbb-toggle-selected-option-border-color: GrayText;
|
|
68
69
|
}
|
|
69
70
|
}
|
|
70
71
|
|
|
71
72
|
:host([size=m]) {
|
|
72
73
|
--sbb-toggle-padding-inline: var(--sbb-spacing-responsive-xs);
|
|
73
|
-
--sbb-toggle-height:
|
|
74
|
-
}
|
|
75
|
-
@media (min-width: calc(52.5rem)) {
|
|
76
|
-
:host([size=m]) {
|
|
77
|
-
--sbb-toggle-height: 3.25rem;
|
|
78
|
-
}
|
|
74
|
+
--sbb-toggle-height: var(--sbb-size-element-m);
|
|
79
75
|
}
|
|
80
76
|
|
|
81
|
-
:host([data-disable-animation-on-resizing]) {
|
|
77
|
+
:host(:is(:not([data-initialized]), [data-disable-animation-on-resizing])) {
|
|
82
78
|
--sbb-disable-animation-duration: 0s;
|
|
83
79
|
}
|
|
84
80
|
|
|
@@ -89,39 +85,50 @@ const style = css`*,
|
|
|
89
85
|
line-height: var(--sbb-typo-line-height-body-text);
|
|
90
86
|
letter-spacing: var(--sbb-typo-letter-spacing-body-text);
|
|
91
87
|
font-size: var(--sbb-text-font-size);
|
|
92
|
-
|
|
93
|
-
|
|
88
|
+
display: grid;
|
|
89
|
+
grid-template-columns: var(--sbb-toggle-grid-template-columns);
|
|
90
|
+
grid-template-areas: "start end";
|
|
94
91
|
align-items: center;
|
|
92
|
+
min-width: var(--sbb-toggle-min-width);
|
|
95
93
|
width: var(--sbb-toggle-width);
|
|
96
94
|
max-width: 100%;
|
|
97
|
-
|
|
98
|
-
height: var(--sbb-toggle-height);
|
|
95
|
+
height: var(--_sbb-toggle-height);
|
|
99
96
|
user-select: none;
|
|
100
97
|
-webkit-tap-highlight-color: transparent;
|
|
101
98
|
background: var(--sbb-color-cloud);
|
|
102
99
|
border-radius: var(--sbb-toggle-border-radius);
|
|
103
100
|
}
|
|
104
|
-
.sbb-toggle::
|
|
105
|
-
|
|
101
|
+
.sbb-toggle::before {
|
|
102
|
+
grid-area: start/start/end/end;
|
|
106
103
|
padding-inline: var(--sbb-toggle-padding-inline);
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
background-color: var(--sbb-color
|
|
110
|
-
border: var(--sbb-toggle-border-width) var(--sbb-toggle-border-style) var(--sbb-toggle-selected-option-border-color);
|
|
104
|
+
margin-inline: var(--sbb-toggle-option-left, 0) var(--sbb-toggle-option-right, 0);
|
|
105
|
+
display: block;
|
|
106
|
+
background-color: var(--sbb-toggle-selected-option-background-color);
|
|
111
107
|
border-radius: var(--sbb-toggle-border-radius);
|
|
112
|
-
position: absolute;
|
|
113
108
|
max-width: 100%;
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
109
|
+
height: 100%;
|
|
110
|
+
box-shadow: 0 0 0 var(--sbb-toggle-selected-option-border-offset) var(--sbb-toggle-selected-option-background-color);
|
|
111
|
+
outline: var(--sbb-toggle-selected-option-border-width) var(--sbb-toggle-selected-option-border-style) var(--sbb-toggle-selected-option-border-color);
|
|
112
|
+
outline-offset: calc(var(--sbb-toggle-selected-option-border-offset) - var(--sbb-toggle-selected-option-border-width));
|
|
117
113
|
transition-duration: var(--sbb-toggle-animation-duration);
|
|
118
114
|
transition-timing-function: ease;
|
|
119
|
-
transition-property:
|
|
115
|
+
transition-property: margin-inline-start, margin-inline-end;
|
|
116
|
+
}
|
|
117
|
+
:host([data-initialized]) .sbb-toggle::before {
|
|
118
|
+
content: "";
|
|
120
119
|
}
|
|
121
120
|
@media (forced-colors: active) {
|
|
122
121
|
.sbb-toggle {
|
|
123
|
-
outline: var(--sbb-
|
|
122
|
+
outline: var(--sbb-border-width-1x) solid CanvasText;
|
|
124
123
|
}
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
::slotted(sbb-toggle-option:first-of-type) {
|
|
127
|
+
grid-area: start;
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
::slotted(sbb-toggle-option:last-of-type) {
|
|
131
|
+
grid-area: end;
|
|
125
132
|
}`;
|
|
126
133
|
let SbbToggleElement = (() => {
|
|
127
134
|
var _even_accessor_storage, _size_accessor_storage, _a;
|
|
@@ -148,11 +155,6 @@ let SbbToggleElement = (() => {
|
|
|
148
155
|
__privateSet(this, _size_accessor_storage, (__runInitializers(this, _even_extraInitializers), __runInitializers(this, _size_initializers, isLean() ? "s" : "m")));
|
|
149
156
|
this._value = (__runInitializers(this, _size_extraInitializers), null);
|
|
150
157
|
this._loaded = false;
|
|
151
|
-
this._toggleResizeObserver = new ResizeController(this, {
|
|
152
|
-
target: null,
|
|
153
|
-
skipInitial: true,
|
|
154
|
-
callback: () => this.updatePillPosition(true)
|
|
155
|
-
});
|
|
156
158
|
this._change = new EventEmitter(this, SbbToggleElement2.events.change, {
|
|
157
159
|
bubbles: true,
|
|
158
160
|
composed: true
|
|
@@ -203,7 +205,6 @@ let SbbToggleElement = (() => {
|
|
|
203
205
|
}
|
|
204
206
|
connectedCallback() {
|
|
205
207
|
super.connectedCallback();
|
|
206
|
-
this.options.forEach((option) => this._toggleResizeObserver.observe(option));
|
|
207
208
|
this._updateToggle();
|
|
208
209
|
}
|
|
209
210
|
willUpdate(changedProperties) {
|
|
@@ -252,10 +253,13 @@ let SbbToggleElement = (() => {
|
|
|
252
253
|
this.toggleAttribute("data-disable-animation-on-resizing", resizing);
|
|
253
254
|
const firstOption = options[0];
|
|
254
255
|
const isFirstChecked = firstOption.checked;
|
|
255
|
-
const pillLeft =
|
|
256
|
+
const pillLeft = isFirstChecked ? "0px" : `${firstOption.clientWidth}px`;
|
|
256
257
|
const pillRight = isFirstChecked ? `${toggleElement.clientWidth - firstOption.clientWidth}px` : "0px";
|
|
257
258
|
(_a2 = this.style) == null ? void 0 : _a2.setProperty("--sbb-toggle-option-left", pillLeft);
|
|
258
259
|
(_b = this.style) == null ? void 0 : _b.setProperty("--sbb-toggle-option-right", pillRight);
|
|
260
|
+
if (!this.hasAttribute("data-initialized")) {
|
|
261
|
+
setTimeout(() => this.toggleAttribute("data-initialized", true), 0);
|
|
262
|
+
}
|
|
259
263
|
}
|
|
260
264
|
updateFormValue() {
|
|
261
265
|
this.internals.setFormValue(this.value);
|
|
@@ -339,4 +343,4 @@ let SbbToggleElement = (() => {
|
|
|
339
343
|
export {
|
|
340
344
|
SbbToggleElement
|
|
341
345
|
};
|
|
342
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"toggle.js","sources":["../../../../../src/elements/toggle/toggle/toggle.ts"],"sourcesContent":["import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport {\n  type CSSResultGroup,\n  html,\n  isServer,\n  LitElement,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { getNextElementIndex, interactivityChecker, isArrowKeyPressed } from '../../core/a11y.js';\nimport { forceType } from '../../core/decorators.js';\nimport { isLean } from '../../core/dom.js';\nimport { EventEmitter } from '../../core/eventing.js';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbDisabledMixin,\n  SbbFormAssociatedMixin,\n} from '../../core/mixins.js';\nimport { type SbbToggleOptionElement } from '../toggle-option.js';\n\nimport style from './toggle.scss?lit&inline';\n\n/**\n * It can be used as a container for two `sbb-toggle-option`, acting as a toggle button.\n *\n * @slot - Use the unnamed slot to add `<sbb-toggle-option>` elements to the toggle.\n * @event {CustomEvent<void>} change - Emits whenever the toggle value changes.\n */\nexport\n@customElement('sbb-toggle')\nclass SbbToggleElement extends SbbDisabledMixin(SbbFormAssociatedMixin(LitElement)) {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    change: 'change',\n  } as const;\n\n  /**\n   * If true, set the width of the component fixed; if false,\n   * the width is dynamic based on the label of the sbb-toggle-option.\n   */\n  @forceType()\n  @property({ reflect: true, type: Boolean })\n  public accessor even: boolean = false;\n\n  /**\n   * Size variant, either m or s.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true }) public accessor size: 's' | 'm' = isLean() ? 's' : 'm';\n\n  /**\n   * The value of the toggle. It needs to be mutable since it is updated whenever\n   * a new option is selected (see the `onToggleOptionSelect()` method).\n   */\n  @property()\n  public override set value(value: string | null) {\n    if (isServer) {\n      this._value = value;\n    } else {\n      this._valueChanged(value);\n    }\n  }\n  public override get value(): string {\n    return isServer\n      ? (this._value ?? '')\n      : (this.options.find((o) => o.checked)?.value ?? this.options[0]?.value ?? '');\n  }\n  private _value: string | null = null;\n\n  /** The child instances of sbb-toggle-option as an array. */\n  public get options(): SbbToggleOptionElement[] {\n    return Array.from(this.querySelectorAll?.('sbb-toggle-option') ?? []);\n  }\n\n  private _loaded: boolean = false;\n  private _toggleResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: () => this.updatePillPosition(true),\n  });\n\n  /** Emits whenever the toggle value changes. */\n  private _change: EventEmitter = new EventEmitter(this, SbbToggleElement.events.change, {\n    bubbles: true,\n    composed: true,\n  });\n\n  public constructor() {\n    super();\n    /** @internal */\n    this.internals.role = 'radiogroup';\n\n    this.addEventListener?.('input', () => this._handleInput(), { passive: true });\n    this.addEventListener?.('keydown', (e) => this._handleKeyDown(e));\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.options.forEach((option) => this._toggleResizeObserver.observe(option));\n    this._updateToggle();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues): void {\n    super.willUpdate(changedProperties);\n    if (changedProperties.has('disabled') || changedProperties.has('formDisabled')) {\n      this._updateDisabled();\n    }\n  }\n\n  protected override async firstUpdated(changedProperties: PropertyValues<this>): Promise<void> {\n    super.firstUpdated(changedProperties);\n\n    await this.updateComplete;\n    this._loaded = true;\n    this.statusChanged();\n  }\n\n  /**\n   * Called whenever the value changes, both programmatically or by user interaction.\n   * @internal\n   */\n  public statusChanged(): void {\n    this.updateFormValue();\n    this.updatePillPosition();\n  }\n\n  /**\n   * Reset to the init value if present. Select the first option, otherwise.\n   */\n  public formResetCallback(): void {\n    this.value = this.getAttribute('value');\n  }\n\n  public formStateRestoreCallback(\n    state: FormRestoreState | null,\n    _reason: FormRestoreReason,\n  ): void {\n    this.value = state as string;\n  }\n\n  /**\n   * @deprecated Will be made 'private' in the next major version\n   * @internal\n   */\n  public updatePillPosition(resizing = false): void {\n    if (!this._loaded) {\n      return;\n    }\n\n    const options = this.options;\n    const toggleElement = this.shadowRoot!.querySelector<HTMLDivElement>('.sbb-toggle');\n\n    if (\n      options.every((o) => !o.checked) ||\n      options.every((o) => !o.clientWidth) ||\n      !toggleElement\n    ) {\n      return;\n    }\n\n    this.toggleAttribute('data-disable-animation-on-resizing', resizing);\n\n    const firstOption = options[0];\n    const isFirstChecked = firstOption.checked;\n    const pillLeft = firstOption.checked ? '0px' : `${firstOption.clientWidth}px`;\n    const pillRight = isFirstChecked\n      ? `${toggleElement.clientWidth - firstOption.clientWidth}px`\n      : '0px';\n\n    this.style?.setProperty('--sbb-toggle-option-left', pillLeft);\n    this.style?.setProperty('--sbb-toggle-option-right', pillRight);\n  }\n\n  protected updateFormValue(): void {\n    this.internals.setFormValue(this.value);\n  }\n\n  private _updateToggle(): void {\n    this._valueChanged(this.value);\n    this._updateDisabled();\n  }\n\n  private _valueChanged(value: string | null): void {\n    const options = this.options;\n    // If options are not yet defined web components, we can check if attribute is already set as a fallback.\n    // We do this by checking whether value property is available (defined component).\n    const selectedOption =\n      options.find(\n        (o) => value === ('value' in o ? o.value : (o as HTMLElement).getAttribute('value')),\n      ) ??\n      options.find((o) => o.checked) ??\n      options[0];\n\n    if (!selectedOption) {\n      if (import.meta.env.DEV && !isServer) {\n        console.warn(`sbb-toggle: No available options! (${this.id || 'No id'})`);\n      }\n      return;\n    }\n    if (!selectedOption.checked) {\n      selectedOption.checked = true;\n    }\n    this.statusChanged();\n  }\n\n  private _updateDisabled(): void {\n    for (const toggleOption of this.options) {\n      toggleOption.disabled = this.disabled || this.formDisabled;\n    }\n  }\n\n  /**\n   * Called on user interaction (click or keyboard)\n   */\n  private _handleInput(): void {\n    this.statusChanged();\n    this._change.emit();\n  }\n\n  private _handleKeyDown(evt: KeyboardEvent): void {\n    const enabledToggleOptions = this.options.filter(\n      (t) => !t.disabled && interactivityChecker.isVisible(t),\n    );\n\n    if (\n      !enabledToggleOptions ||\n      // don't trap nested handling\n      ((evt.target as HTMLElement) !== this && (evt.target as HTMLElement).parentElement !== this)\n    ) {\n      return;\n    }\n\n    if (isArrowKeyPressed(evt)) {\n      const checked: number = enabledToggleOptions.findIndex(\n        (toggleOption: SbbToggleOptionElement) => toggleOption.checked,\n      );\n      const nextIndex: number = getNextElementIndex(evt, checked, enabledToggleOptions.length);\n      if (!enabledToggleOptions[nextIndex].checked) {\n        enabledToggleOptions[nextIndex].checked = true;\n        enabledToggleOptions[nextIndex].focus();\n        enabledToggleOptions[nextIndex].dispatchEvent(\n          new InputEvent('input', { bubbles: true, composed: true }),\n        );\n      }\n      evt.preventDefault();\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-toggle\">\n        <slot @slotchange=${this._updateToggle}></slot>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-toggle': SbbToggleElement;\n  }\n}\n"],"names":["SbbToggleElement","_a"],"mappings":"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"}
|
|
346
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"toggle.js","sources":["../../../../../src/elements/toggle/toggle/toggle.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  LitElement,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { getNextElementIndex, interactivityChecker, isArrowKeyPressed } from '../../core/a11y.js';\nimport { forceType } from '../../core/decorators.js';\nimport { isLean } from '../../core/dom.js';\nimport { EventEmitter } from '../../core/eventing.js';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbDisabledMixin,\n  SbbFormAssociatedMixin,\n} from '../../core/mixins.js';\nimport { type SbbToggleOptionElement } from '../toggle-option.js';\n\nimport style from './toggle.scss?lit&inline';\n\n/**\n * It can be used as a container for two `sbb-toggle-option`, acting as a toggle button.\n *\n * @slot - Use the unnamed slot to add `<sbb-toggle-option>` elements to the toggle.\n * @event {CustomEvent<void>} change - Emits whenever the toggle value changes.\n */\nexport\n@customElement('sbb-toggle')\nclass SbbToggleElement extends SbbDisabledMixin(SbbFormAssociatedMixin(LitElement)) {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    change: 'change',\n  } as const;\n\n  /**\n   * If true, set the width of the component fixed; if false,\n   * the width is dynamic based on the label of the sbb-toggle-option.\n   */\n  @forceType()\n  @property({ reflect: true, type: Boolean })\n  public accessor even: boolean = false;\n\n  /**\n   * Size variant, either m or s.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true }) public accessor size: 's' | 'm' = isLean() ? 's' : 'm';\n\n  /**\n   * The value of the toggle. It needs to be mutable since it is updated whenever\n   * a new option is selected (see the `onToggleOptionSelect()` method).\n   */\n  @property()\n  public override set value(value: string | null) {\n    if (isServer) {\n      this._value = value;\n    } else {\n      this._valueChanged(value);\n    }\n  }\n  public override get value(): string {\n    return isServer\n      ? (this._value ?? '')\n      : (this.options.find((o) => o.checked)?.value ?? this.options[0]?.value ?? '');\n  }\n  private _value: string | null = null;\n\n  /** The child instances of sbb-toggle-option as an array. */\n  public get options(): SbbToggleOptionElement[] {\n    return Array.from(this.querySelectorAll?.('sbb-toggle-option') ?? []);\n  }\n\n  private _loaded: boolean = false;\n\n  /** Emits whenever the toggle value changes. */\n  private _change: EventEmitter = new EventEmitter(this, SbbToggleElement.events.change, {\n    bubbles: true,\n    composed: true,\n  });\n\n  public constructor() {\n    super();\n    /** @internal */\n    this.internals.role = 'radiogroup';\n\n    this.addEventListener?.('input', () => this._handleInput(), { passive: true });\n    this.addEventListener?.('keydown', (e) => this._handleKeyDown(e));\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this._updateToggle();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues): void {\n    super.willUpdate(changedProperties);\n    if (changedProperties.has('disabled') || changedProperties.has('formDisabled')) {\n      this._updateDisabled();\n    }\n  }\n\n  protected override async firstUpdated(changedProperties: PropertyValues<this>): Promise<void> {\n    super.firstUpdated(changedProperties);\n\n    await this.updateComplete;\n    this._loaded = true;\n    this.statusChanged();\n  }\n\n  /**\n   * Called whenever the value changes, both programmatically or by user interaction.\n   * @internal\n   */\n  public statusChanged(): void {\n    this.updateFormValue();\n    this.updatePillPosition();\n  }\n\n  /**\n   * Reset to the init value if present. Select the first option, otherwise.\n   */\n  public formResetCallback(): void {\n    this.value = this.getAttribute('value');\n  }\n\n  public formStateRestoreCallback(\n    state: FormRestoreState | null,\n    _reason: FormRestoreReason,\n  ): void {\n    this.value = state as string;\n  }\n\n  /**\n   * @deprecated Will be made 'private' in the next major version\n   * @internal\n   */\n  public updatePillPosition(resizing = false): void {\n    if (!this._loaded) {\n      return;\n    }\n\n    const options = this.options;\n    const toggleElement = this.shadowRoot!.querySelector<HTMLDivElement>('.sbb-toggle');\n\n    if (\n      options.every((o) => !o.checked) ||\n      options.every((o) => !o.clientWidth) ||\n      !toggleElement\n    ) {\n      return;\n    }\n\n    this.toggleAttribute('data-disable-animation-on-resizing', resizing);\n\n    const firstOption = options[0];\n    const isFirstChecked = firstOption.checked;\n    const pillLeft = isFirstChecked ? '0px' : `${firstOption.clientWidth}px`;\n    const pillRight = isFirstChecked\n      ? `${toggleElement.clientWidth - firstOption.clientWidth}px`\n      : '0px';\n\n    this.style?.setProperty('--sbb-toggle-option-left', pillLeft);\n    this.style?.setProperty('--sbb-toggle-option-right', pillRight);\n\n    // In order to avoid a transition glitch, we have to know when the first values were set.\n    // Because Safari handles timing differently, we need to set it a tick later.\n    if (!this.hasAttribute('data-initialized')) {\n      setTimeout(() => this.toggleAttribute('data-initialized', true), 0);\n    }\n  }\n\n  protected updateFormValue(): void {\n    this.internals.setFormValue(this.value);\n  }\n\n  private _updateToggle(): void {\n    this._valueChanged(this.value);\n    this._updateDisabled();\n  }\n\n  private _valueChanged(value: string | null): void {\n    const options = this.options;\n    // If options are not yet defined web components, we can check if attribute is already set as a fallback.\n    // We do this by checking whether value property is available (defined component).\n    const selectedOption =\n      options.find(\n        (o) => value === ('value' in o ? o.value : (o as HTMLElement).getAttribute('value')),\n      ) ??\n      options.find((o) => o.checked) ??\n      options[0];\n\n    if (!selectedOption) {\n      if (import.meta.env.DEV && !isServer) {\n        console.warn(`sbb-toggle: No available options! (${this.id || 'No id'})`);\n      }\n      return;\n    }\n    if (!selectedOption.checked) {\n      selectedOption.checked = true;\n    }\n    this.statusChanged();\n  }\n\n  private _updateDisabled(): void {\n    for (const toggleOption of this.options) {\n      toggleOption.disabled = this.disabled || this.formDisabled;\n    }\n  }\n\n  /**\n   * Called on user interaction (click or keyboard)\n   */\n  private _handleInput(): void {\n    this.statusChanged();\n    this._change.emit();\n  }\n\n  private _handleKeyDown(evt: KeyboardEvent): void {\n    const enabledToggleOptions = this.options.filter(\n      (t) => !t.disabled && interactivityChecker.isVisible(t),\n    );\n\n    if (\n      !enabledToggleOptions ||\n      // don't trap nested handling\n      ((evt.target as HTMLElement) !== this && (evt.target as HTMLElement).parentElement !== this)\n    ) {\n      return;\n    }\n\n    if (isArrowKeyPressed(evt)) {\n      const checked: number = enabledToggleOptions.findIndex(\n        (toggleOption: SbbToggleOptionElement) => toggleOption.checked,\n      );\n      const nextIndex: number = getNextElementIndex(evt, checked, enabledToggleOptions.length);\n      if (!enabledToggleOptions[nextIndex].checked) {\n        enabledToggleOptions[nextIndex].checked = true;\n        enabledToggleOptions[nextIndex].focus();\n        enabledToggleOptions[nextIndex].dispatchEvent(\n          new InputEvent('input', { bubbles: true, composed: true }),\n        );\n      }\n      evt.preventDefault();\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-toggle\">\n        <slot @slotchange=${this._updateToggle}></slot>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-toggle': SbbToggleElement;\n  }\n}\n"],"names":["SbbToggleElement","_a"],"mappings":"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"}
|
|
@@ -12,9 +12,10 @@ export declare class SbbToggleOptionElement extends SbbToggleOptionElement_base
|
|
|
12
12
|
accessor checked: boolean;
|
|
13
13
|
/** Value of toggle-option. */
|
|
14
14
|
accessor value: string;
|
|
15
|
-
private _toggle
|
|
15
|
+
private _toggle;
|
|
16
16
|
constructor();
|
|
17
17
|
connectedCallback(): void;
|
|
18
|
+
disconnectedCallback(): void;
|
|
18
19
|
protected willUpdate(changedProperties: PropertyValues<this>): void;
|
|
19
20
|
private _uncheckOtherOptions;
|
|
20
21
|
private _handleDisabledChange;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"toggle-option.d.ts","sourceRoot":"","sources":["../../../../../src/elements/toggle/toggle-option/toggle-option.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"toggle-option.d.ts","sourceRoot":"","sources":["../../../../../src/elements/toggle/toggle-option/toggle-option.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;;AAWvC;;;;;GAKG;AACH,qBAGM,sBAAuB,SAAQ,2BAA8C;IACjF,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,4CAA4C;IAC5C,SAEgB,OAAO,EAAE,OAAO,CAAS;IAEzC,8BAA8B;IAC9B,SAEgB,KAAK,EAAE,MAAM,CAAM;IAEnC,OAAO,CAAC,OAAO,CAAiC;;IAyBhC,iBAAiB,IAAI,IAAI;IAQzB,oBAAoB,IAAI,IAAI;cAKzB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAe5E,OAAO,CAAC,oBAAoB;IAK5B,OAAO,CAAC,qBAAqB;IAK7B,OAAO,CAAC,YAAY;IAQpB,OAAO,CAAC,eAAe;cAIJ,MAAM,IAAI,cAAc;CAU5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,mBAAmB,EAAE,sBAAsB,CAAC;KAC7C;CACF"}
|