@sbb-esta/lyne-elements-dev 5.0.0-next-dev.1776118170 → 5.0.0-next-dev.1776240735
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 +10 -4
- package/core.css +23 -5
- package/custom-elements.json +2331 -2331
- package/development/toggle/toggle/toggle.component.d.ts.map +1 -1
- package/development/toggle/toggle/toggle.component.js +1 -1
- package/development/toggle/toggle-option/toggle-option.component.d.ts.map +1 -1
- package/development/toggle/toggle-option/toggle-option.component.js +1 -1
- package/development/toggle-option.component-D8YWH_D5.js +163 -0
- package/development/toggle.component-Dap1d4rK.js +244 -0
- package/development/toggle.js +2 -2
- package/development/toggle.pure.js +2 -2
- package/off-brand-theme.css +23 -5
- package/package.json +2 -2
- package/safety-theme.css +23 -5
- package/standard-theme.css +23 -5
- package/toggle/toggle/toggle.component.js +1 -1
- package/toggle/toggle-option/toggle-option.component.js +1 -1
- package/{toggle-option.component-BF95HWOF.js → toggle-option.component-BiyjKQB1.js} +5 -7
- package/{toggle.component-2e_7FeR4.js → toggle.component-CVbRdQDM.js} +6 -10
- package/toggle.js +2 -2
- package/toggle.pure.js +2 -2
- package/development/toggle-option.component-BWT4kEZo.js +0 -165
- package/development/toggle.component-DjLnSv3R.js +0 -249
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"toggle.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/toggle/toggle/toggle.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAGnB,KAAK,cAAc,EACnB,KAAK,cAAc,EAEpB,MAAM,KAAK,CAAC;AAGb,OAAO,EAEL,UAAU,EAIX,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,EAGtB,MAAM,eAAe,CAAC;AACvB,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,6CAA6C,CAAC;;AAI1F;;;;;GAKG;AACH,qBAAa,gBAAgB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,qBAEjD;IACC,gBAAgC,WAAW,EAAE,MAAM,CAAgB;IACnE,gBAAgC,IAAI,gBAAgB;IACpD,OAAuB,MAAM,EAAE,cAAc,CAAuC;IACpF,gBAAuB,MAAM;;MAElB;IAEX;;;OAGG;IACH,SAEgB,IAAI,EAAE,OAAO,CAAS;IAEtC;;;OAGG;IACH,SAA6C,IAAI,EAAE,GAAG,GAAG,GAAG,CAAwB;IAEpF;;;OAGG;IACH,IACW,KAAK,CAAC,KAAK,EAAE,CAAC,GAAG,IAAI,EAM/B;IACD,IAAW,KAAK,IAAI,CAAC,GAAG,IAAI,CAI3B;IACD,OAAO,CAAC,cAAc,CAAkB;IAExC,4DAA4D;IAC5D,IAAW,OAAO,IAAI,sBAAsB,CAAC,CAAC,CAAC,EAAE,CAIhD;;cAQkB,UAAU,CAAC,iBAAiB,EAAE,cAAc,GAAG,IAAI;IAatE;;;OAGG;IACI,aAAa,IAAI,IAAI;IAK5B;;;OAGG;IACI,iBAAiB,IAAI,IAAI;IAIhC;;OAEG;IACI,wBAAwB,CAC7B,KAAK,EAAE,gBAAgB,GAAG,IAAI,EAC9B,OAAO,EAAE,iBAAiB,GACzB,IAAI;YAUO,aAAa;IAK3B,gBAAgB;IACT,kBAAkB,CAAC,QAAQ,UAAQ,GAAG,IAAI;
|
|
1
|
+
{"version":3,"file":"toggle.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/toggle/toggle/toggle.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAGnB,KAAK,cAAc,EACnB,KAAK,cAAc,EAEpB,MAAM,KAAK,CAAC;AAGb,OAAO,EAEL,UAAU,EAIX,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,EAGtB,MAAM,eAAe,CAAC;AACvB,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,6CAA6C,CAAC;;AAI1F;;;;;GAKG;AACH,qBAAa,gBAAgB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,qBAEjD;IACC,gBAAgC,WAAW,EAAE,MAAM,CAAgB;IACnE,gBAAgC,IAAI,gBAAgB;IACpD,OAAuB,MAAM,EAAE,cAAc,CAAuC;IACpF,gBAAuB,MAAM;;MAElB;IAEX;;;OAGG;IACH,SAEgB,IAAI,EAAE,OAAO,CAAS;IAEtC;;;OAGG;IACH,SAA6C,IAAI,EAAE,GAAG,GAAG,GAAG,CAAwB;IAEpF;;;OAGG;IACH,IACW,KAAK,CAAC,KAAK,EAAE,CAAC,GAAG,IAAI,EAM/B;IACD,IAAW,KAAK,IAAI,CAAC,GAAG,IAAI,CAI3B;IACD,OAAO,CAAC,cAAc,CAAkB;IAExC,4DAA4D;IAC5D,IAAW,OAAO,IAAI,sBAAsB,CAAC,CAAC,CAAC,EAAE,CAIhD;;cAQkB,UAAU,CAAC,iBAAiB,EAAE,cAAc,GAAG,IAAI;IAatE;;;OAGG;IACI,aAAa,IAAI,IAAI;IAK5B;;;OAGG;IACI,iBAAiB,IAAI,IAAI;IAIhC;;OAEG;IACI,wBAAwB,CAC7B,KAAK,EAAE,gBAAgB,GAAG,IAAI,EAC9B,OAAO,EAAE,iBAAiB,GACzB,IAAI;YAUO,aAAa;IAK3B,gBAAgB;IACT,kBAAkB,CAAC,QAAQ,UAAQ,GAAG,IAAI;IAiCjD,OAAO,CAAC,aAAa;IAKrB,OAAO,CAAC,aAAa;IAgBrB,OAAO,CAAC,eAAe;IAMvB;;OAEG;IACH,OAAO,CAAC,YAAY;IAUpB,OAAO,CAAC,cAAc;IA6BtB,OAAO,CAAC,qBAAqB;cASV,MAAM,IAAI,cAAc;CAG5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,YAAY,EAAE,gBAAgB,CAAC;KAChC;CACF"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as SbbToggleElement } from "../../toggle.component-
|
|
1
|
+
import { t as SbbToggleElement } from "../../toggle.component-Dap1d4rK.js";
|
|
2
2
|
export { SbbToggleElement };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"toggle-option.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/toggle/toggle-option/toggle-option.component.ts"],"names":[],"mappings":"AACA,OAAO,EAGL,KAAK,cAAc,EACnB,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAGb,OAAO,EAAE,UAAU,EAAgD,MAAM,eAAe,CAAC;;AAMzF;;;;;;GAMG;AACH,qBAAa,sBAAsB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,2BAEvD;IACC,gBAAgC,WAAW,EAAE,MAAM,CAAuB;IAC1E,gBAAgC,IAAI,WAAW;IAC/C,OAAuB,MAAM,EAAE,cAAc,CAAuC;IAEpF,4CAA4C;IAC5C,SAEgB,OAAO,EAAE,OAAO,CAAS;IAEzC,8BAA8B;IAC9B,SACgB,KAAK,EAAE,CAAC,GAAG,IAAI,CAAQ;IAEvC,OAAO,CAAC,OAAO,CAAiC;;IAqBhC,iBAAiB,IAAI,IAAI;IASzB,oBAAoB,IAAI,IAAI;cAKzB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAM3D,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;
|
|
1
|
+
{"version":3,"file":"toggle-option.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/toggle/toggle-option/toggle-option.component.ts"],"names":[],"mappings":"AACA,OAAO,EAGL,KAAK,cAAc,EACnB,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAGb,OAAO,EAAE,UAAU,EAAgD,MAAM,eAAe,CAAC;;AAMzF;;;;;;GAMG;AACH,qBAAa,sBAAsB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,2BAEvD;IACC,gBAAgC,WAAW,EAAE,MAAM,CAAuB;IAC1E,gBAAgC,IAAI,WAAW;IAC/C,OAAuB,MAAM,EAAE,cAAc,CAAuC;IAEpF,4CAA4C;IAC5C,SAEgB,OAAO,EAAE,OAAO,CAAS;IAEzC,8BAA8B;IAC9B,SACgB,KAAK,EAAE,CAAC,GAAG,IAAI,CAAQ;IAEvC,OAAO,CAAC,OAAO,CAAiC;;IAqBhC,iBAAiB,IAAI,IAAI;IASzB,oBAAoB,IAAI,IAAI;cAKzB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAM3D,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;CAQ5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,mBAAmB,EAAE,sBAAsB,CAAC;KAC7C;CACF"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as SbbToggleOptionElement } from "../../toggle-option.component-
|
|
1
|
+
import { t as SbbToggleOptionElement } from "../../toggle-option.component-D8YWH_D5.js";
|
|
2
2
|
export { SbbToggleOptionElement };
|
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
import { html, unsafeCSS } from "lit";
|
|
3
|
+
import { property } from "lit/decorators.js";
|
|
4
|
+
import { SbbDisabledMixin, SbbElement, boxSizingStyles, forceType } from "./core.js";
|
|
5
|
+
import { SbbIconNameMixin } from "./icon.pure.js";
|
|
6
|
+
import { ResizeController } from "@lit-labs/observers/resize-controller.js";
|
|
7
|
+
//#region src/elements/toggle/toggle-option/toggle-option.scss?inline
|
|
8
|
+
var toggle_option_default = ":host {\n display: flex;\n justify-content: center;\n align-items: center;\n gap: var(--sbb-toggle-option-gap);\n height: var(--sbb-toggle-height);\n padding-inline: var(--sbb-toggle-padding-inline);\n color: var(--sbb-toggle-option-color);\n cursor: var(--sbb-toggle-option-cursor, var(--sbb-cursor-pointer));\n overflow: hidden;\n font-size: var(--sbb-toggle-option-font-size);\n letter-spacing: var(--sbb-typo-letter-spacing-text);\n font-weight: bold;\n outline: none !important;\n}\n\n:host([checked]) {\n --sbb-toggle-option-color: var(--sbb-color-2);\n}\n\n:host([disabled]) {\n --sbb-toggle-option-cursor: unset;\n --sbb-toggle-option-color: var(--sbb-color-anthracite);\n --sbb-toggle-option-color: light-dark(var(--sbb-color-anthracite), var(--sbb-color-cloud));\n}\n\n.sbb-toggle-option__label {\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n}\n\nsbb-icon,\n::slotted(sbb-icon) {\n min-width: var(--sbb-toggle-option-icon-min-size);\n min-height: var(--sbb-toggle-option-icon-min-size);\n}";
|
|
9
|
+
//#endregion
|
|
10
|
+
//#region src/elements/toggle/toggle-option/toggle-option.component.ts
|
|
11
|
+
/**
|
|
12
|
+
* It displays a toggle option within a `sbb-toggle`.
|
|
13
|
+
*
|
|
14
|
+
* @slot - Use the unnamed slot to add content to the label of the toggle option.
|
|
15
|
+
* @slot icon - Slot used to render the `sbb-icon`.
|
|
16
|
+
* @overrideType value - (T = string) | null
|
|
17
|
+
*/
|
|
18
|
+
var SbbToggleOptionElement = (() => {
|
|
19
|
+
let _classSuper = SbbDisabledMixin(SbbIconNameMixin(SbbElement));
|
|
20
|
+
let _checked_decorators;
|
|
21
|
+
let _checked_initializers = [];
|
|
22
|
+
let _checked_extraInitializers = [];
|
|
23
|
+
let _value_decorators;
|
|
24
|
+
let _value_initializers = [];
|
|
25
|
+
let _value_extraInitializers = [];
|
|
26
|
+
return class SbbToggleOptionElement extends _classSuper {
|
|
27
|
+
static {
|
|
28
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
29
|
+
_checked_decorators = [forceType(), property({
|
|
30
|
+
reflect: true,
|
|
31
|
+
type: Boolean
|
|
32
|
+
})];
|
|
33
|
+
_value_decorators = [property()];
|
|
34
|
+
__esDecorate(this, null, _checked_decorators, {
|
|
35
|
+
kind: "accessor",
|
|
36
|
+
name: "checked",
|
|
37
|
+
static: false,
|
|
38
|
+
private: false,
|
|
39
|
+
access: {
|
|
40
|
+
has: (obj) => "checked" in obj,
|
|
41
|
+
get: (obj) => obj.checked,
|
|
42
|
+
set: (obj, value) => {
|
|
43
|
+
obj.checked = value;
|
|
44
|
+
}
|
|
45
|
+
},
|
|
46
|
+
metadata: _metadata
|
|
47
|
+
}, _checked_initializers, _checked_extraInitializers);
|
|
48
|
+
__esDecorate(this, null, _value_decorators, {
|
|
49
|
+
kind: "accessor",
|
|
50
|
+
name: "value",
|
|
51
|
+
static: false,
|
|
52
|
+
private: false,
|
|
53
|
+
access: {
|
|
54
|
+
has: (obj) => "value" in obj,
|
|
55
|
+
get: (obj) => obj.value,
|
|
56
|
+
set: (obj, value) => {
|
|
57
|
+
obj.value = value;
|
|
58
|
+
}
|
|
59
|
+
},
|
|
60
|
+
metadata: _metadata
|
|
61
|
+
}, _value_initializers, _value_extraInitializers);
|
|
62
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, {
|
|
63
|
+
enumerable: true,
|
|
64
|
+
configurable: true,
|
|
65
|
+
writable: true,
|
|
66
|
+
value: _metadata
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
static {
|
|
70
|
+
this.elementName = "sbb-toggle-option";
|
|
71
|
+
}
|
|
72
|
+
static {
|
|
73
|
+
this.role = "radio";
|
|
74
|
+
}
|
|
75
|
+
static {
|
|
76
|
+
this.styles = [boxSizingStyles, unsafeCSS(toggle_option_default)];
|
|
77
|
+
}
|
|
78
|
+
#checked_accessor_storage;
|
|
79
|
+
/** Whether the toggle-option is checked. */
|
|
80
|
+
get checked() {
|
|
81
|
+
return this.#checked_accessor_storage;
|
|
82
|
+
}
|
|
83
|
+
set checked(value) {
|
|
84
|
+
this.#checked_accessor_storage = value;
|
|
85
|
+
}
|
|
86
|
+
#value_accessor_storage;
|
|
87
|
+
/** Value of toggle-option. */
|
|
88
|
+
get value() {
|
|
89
|
+
return this.#value_accessor_storage;
|
|
90
|
+
}
|
|
91
|
+
set value(value) {
|
|
92
|
+
this.#value_accessor_storage = value;
|
|
93
|
+
}
|
|
94
|
+
constructor() {
|
|
95
|
+
super();
|
|
96
|
+
this.#checked_accessor_storage = __runInitializers(this, _checked_initializers, false);
|
|
97
|
+
this.#value_accessor_storage = (__runInitializers(this, _checked_extraInitializers), __runInitializers(this, _value_initializers, null));
|
|
98
|
+
this._toggle = (__runInitializers(this, _value_extraInitializers), null);
|
|
99
|
+
this.addEventListener?.("input", () => this._handleInput());
|
|
100
|
+
this.addEventListener?.("click", () => {
|
|
101
|
+
if (!this.disabled && !this.checked) this.dispatchEvent(new InputEvent("input", {
|
|
102
|
+
bubbles: true,
|
|
103
|
+
composed: true
|
|
104
|
+
}));
|
|
105
|
+
});
|
|
106
|
+
this.addController(new ResizeController(this, {
|
|
107
|
+
skipInitial: true,
|
|
108
|
+
callback: () => this._toggle?.updatePillPosition?.(true)
|
|
109
|
+
}));
|
|
110
|
+
}
|
|
111
|
+
connectedCallback() {
|
|
112
|
+
super.connectedCallback();
|
|
113
|
+
this._toggle = this.closest?.("sbb-toggle") ?? null;
|
|
114
|
+
this._verifyTabindex();
|
|
115
|
+
this._toggle?.updatePillPosition?.(true);
|
|
116
|
+
}
|
|
117
|
+
disconnectedCallback() {
|
|
118
|
+
super.disconnectedCallback();
|
|
119
|
+
this._toggle = null;
|
|
120
|
+
}
|
|
121
|
+
firstUpdated(changedProperties) {
|
|
122
|
+
super.firstUpdated(changedProperties);
|
|
123
|
+
this._toggle?.updatePillPosition?.(true);
|
|
124
|
+
}
|
|
125
|
+
willUpdate(changedProperties) {
|
|
126
|
+
super.willUpdate(changedProperties);
|
|
127
|
+
if (changedProperties.has("checked")) {
|
|
128
|
+
this.internals.ariaChecked = `${this.checked}`;
|
|
129
|
+
this._verifyTabindex();
|
|
130
|
+
if (this.checked) this._uncheckOtherOptions();
|
|
131
|
+
}
|
|
132
|
+
if (changedProperties.has("disabled")) this._handleDisabledChange();
|
|
133
|
+
}
|
|
134
|
+
_uncheckOtherOptions() {
|
|
135
|
+
this._toggle?.options.filter((o) => o !== this).forEach((o) => o.checked = false);
|
|
136
|
+
this._toggle?.statusChanged();
|
|
137
|
+
}
|
|
138
|
+
_handleDisabledChange() {
|
|
139
|
+
this.internals.ariaDisabled = this.disabled ? "true" : null;
|
|
140
|
+
this._verifyTabindex();
|
|
141
|
+
}
|
|
142
|
+
_handleInput() {
|
|
143
|
+
if (this.disabled) return;
|
|
144
|
+
this.checked = true;
|
|
145
|
+
this._uncheckOtherOptions();
|
|
146
|
+
}
|
|
147
|
+
_verifyTabindex() {
|
|
148
|
+
this.tabIndex = this.checked && !this.disabled ? 0 : -1;
|
|
149
|
+
}
|
|
150
|
+
render() {
|
|
151
|
+
return html`
|
|
152
|
+
${this.renderIconSlot()}
|
|
153
|
+
<span class="sbb-toggle-option__label">
|
|
154
|
+
<slot></slot>
|
|
155
|
+
</span>
|
|
156
|
+
`;
|
|
157
|
+
}
|
|
158
|
+
};
|
|
159
|
+
})();
|
|
160
|
+
//#endregion
|
|
161
|
+
export { SbbToggleOptionElement as t };
|
|
162
|
+
|
|
163
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"toggle-option.component-D8YWH_D5.js","names":[],"sources":["../../../src/elements/toggle/toggle-option/toggle-option.scss?inline","../../../src/elements/toggle/toggle-option/toggle-option.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  display: flex;\n  justify-content: center;\n  align-items: center;\n  gap: var(--sbb-toggle-option-gap);\n  height: var(--sbb-toggle-height);\n  padding-inline: var(--sbb-toggle-padding-inline);\n  color: var(--sbb-toggle-option-color);\n  cursor: var(--sbb-toggle-option-cursor, var(--sbb-cursor-pointer));\n  overflow: hidden;\n  font-size: var(--sbb-toggle-option-font-size);\n  letter-spacing: var(--sbb-typo-letter-spacing-text);\n  font-weight: bold;\n\n  // Use !important here to not interfere with Firefox focus ring definition\n  // which appears in normalize CSS of several frameworks.\n  outline: none !important;\n}\n\n:host([checked]) {\n  --sbb-toggle-option-color: var(--sbb-color-2);\n}\n\n:host([disabled]) {\n  --sbb-toggle-option-cursor: unset;\n  --sbb-toggle-option-color: light-dark(var(--sbb-color-anthracite), var(--sbb-color-cloud));\n}\n\n.sbb-toggle-option__label {\n  @include sbb.ellipsis;\n}\n\nsbb-icon,\n::slotted(sbb-icon) {\n  min-width: var(--sbb-toggle-option-icon-min-size);\n  min-height: var(--sbb-toggle-option-icon-min-size);\n}\n","import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport {\n  html,\n  unsafeCSS,\n  type CSSResultGroup,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbElement, forceType, SbbDisabledMixin, boxSizingStyles } from '../../core.ts';\nimport { SbbIconNameMixin } from '../../icon.pure.ts';\nimport type { SbbToggleElement } from '../toggle/toggle.component.ts';\n\nimport style from './toggle-option.scss?inline';\n\n/**\n * It displays a toggle option within a `sbb-toggle`.\n *\n * @slot - Use the unnamed slot to add content to the label of the toggle option.\n * @slot icon - Slot used to render the `sbb-icon`.\n * @overrideType value - (T = string) | null\n */\nexport class SbbToggleOptionElement<T = string> extends SbbDisabledMixin(\n  SbbIconNameMixin(SbbElement),\n) {\n  public static override readonly elementName: string = 'sbb-toggle-option';\n  public static override readonly role = 'radio';\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(style)];\n\n  /** Whether the toggle-option is checked. */\n  @forceType()\n  @property({ reflect: true, type: Boolean })\n  public accessor checked: boolean = false;\n\n  /** Value of toggle-option. */\n  @property()\n  public accessor value: T | null = null;\n\n  private _toggle: SbbToggleElement | null = null;\n\n  public constructor() {\n    super();\n    // We need to listen input event on host as with keyboard navigation\n    // the Input Event is triggered from sbb-toggle.\n    this.addEventListener?.('input', () => this._handleInput());\n    this.addEventListener?.('click', () => {\n      if (!this.disabled && !this.checked) {\n        this.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n      }\n    });\n\n    this.addController(\n      new ResizeController(this, {\n        skipInitial: true,\n        callback: () => this._toggle?.updatePillPosition?.(true),\n      }),\n    );\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n\n    // We can use closest here, as we expect the parent sbb-toggle to be in light DOM.\n    this._toggle = this.closest?.('sbb-toggle') ?? null;\n    this._verifyTabindex();\n    this._toggle?.updatePillPosition?.(true);\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._toggle = null;\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._toggle?.updatePillPosition?.(true);\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('checked')) {\n      this.internals.ariaChecked = `${this.checked}`;\n      this._verifyTabindex();\n      if (this.checked) {\n        this._uncheckOtherOptions();\n      }\n    }\n    if (changedProperties.has('disabled')) {\n      this._handleDisabledChange();\n    }\n  }\n\n  private _uncheckOtherOptions(): void {\n    this._toggle?.options.filter((o) => o !== this).forEach((o) => (o.checked = false));\n    this._toggle?.statusChanged();\n  }\n\n  private _handleDisabledChange(): void {\n    this.internals.ariaDisabled = this.disabled ? 'true' : null;\n    this._verifyTabindex();\n  }\n\n  private _handleInput(): void {\n    if (this.disabled) {\n      return;\n    }\n    this.checked = true;\n    this._uncheckOtherOptions();\n  }\n\n  private _verifyTabindex(): void {\n    this.tabIndex = this.checked && !this.disabled ? 0 : -1;\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      ${this.renderIconSlot()}\n      <span class=\"sbb-toggle-option__label\">\n        <slot></slot>\n      </span>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-toggle-option': SbbToggleOptionElement;\n  }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;ICuBa,gCAAsB;mBAAqB,iBACtD,iBAAiB,WAAW,CAC7B;;;;;;;cAFY,+BAA2C,YAEvD;;;0BAME,WAAW,EACX,SAAS;IAAE,SAAS;IAAM,MAAM;IAAS,CAAC,CAAA;wBAI1C,UAAU,CAAA;AAHX,gBAAA,MAAA,MAAA,qBAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,aAAA;KAAA,MAAA,QAAA,IAAgB;KAAO,MAAA,KAAA,UAAA;AAAA,UAAP,UAAO;;KAAA;IAAA,UAAA;IAAA,EAAA,uBAAA,2BAAA;AAIvB,gBAAA,MAAA,MAAA,mBAAA;IAAA,MAAA;IAAA,MAAA;IAAA,QAAA;IAAA,SAAA;IAAA,QAAA;KAAA,MAAA,QAAA,WAAA;KAAA,MAAA,QAAA,IAAgB;KAAK,MAAA,KAAA,UAAA;AAAA,UAAL,QAAK;;KAAA;IAAA,UAAA;IAAA,EAAA,qBAAA,yBAAA;;;;;;;;;AAXW,QAAA,cAAsB;;;AACtB,QAAA,OAAO;;;AAChB,QAAA,SAAyB,CAAC,iBAAiB,UAAU,sBAAM,CAAC;;EAKnF;;EAAA,IAAgB,UAAO;AAAA,UAAA,MAAA;;EAAvB,IAAgB,QAAO,OAAA;AAAA,SAAA,2BAAA;;EAIvB;;EAAA,IAAgB,QAAK;AAAA,UAAA,MAAA;;EAArB,IAAgB,MAAK,OAAA;AAAA,SAAA,yBAAA;;EAIrB,cAAA;AACE,UAAO;AATO,SAAA,2BAAA,kBAAA,MAAA,uBAAmB,MAAK;AAIxB,SAAA,0BAAA,kBAAA,MAAA,2BAAA,EAAA,kBAAA,MAAA,qBAAkB,KAAI;AAE9B,QAAA,WAAO,kBAAA,MAAA,yBAAA,EAA4B;AAMzC,QAAK,mBAAmB,eAAe,KAAK,cAAc,CAAC;AAC3D,QAAK,mBAAmB,eAAc;AACpC,QAAI,CAAC,KAAK,YAAY,CAAC,KAAK,QAC1B,MAAK,cAAc,IAAI,WAAW,SAAS;KAAE,SAAS;KAAM,UAAU;KAAM,CAAC,CAAC;KAEhF;AAEF,QAAK,cACH,IAAI,iBAAiB,MAAM;IACzB,aAAa;IACb,gBAAgB,KAAK,SAAS,qBAAqB,KAAA;IACpD,CAAC,CACH;;EAGa,oBAAiB;AAC/B,SAAM,mBAAmB;AAGzB,QAAK,UAAU,KAAK,UAAU,aAAa,IAAI;AAC/C,QAAK,iBAAiB;AACtB,QAAK,SAAS,qBAAqB,KAAK;;EAG1B,uBAAoB;AAClC,SAAM,sBAAsB;AAC5B,QAAK,UAAU;;EAGE,aAAa,mBAAuC;AACrE,SAAM,aAAa,kBAAkB;AAErC,QAAK,SAAS,qBAAqB,KAAK;;EAGvB,WAAW,mBAAuC;AACnE,SAAM,WAAW,kBAAkB;AAEnC,OAAI,kBAAkB,IAAI,UAAU,EAAE;AACpC,SAAK,UAAU,cAAc,GAAG,KAAK;AACrC,SAAK,iBAAiB;AACtB,QAAI,KAAK,QACP,MAAK,sBAAsB;;AAG/B,OAAI,kBAAkB,IAAI,WAAW,CACnC,MAAK,uBAAuB;;EAIxB,uBAAoB;AAC1B,QAAK,SAAS,QAAQ,QAAQ,MAAM,MAAM,KAAK,CAAC,SAAS,MAAO,EAAE,UAAU,MAAO;AACnF,QAAK,SAAS,eAAe;;EAGvB,wBAAqB;AAC3B,QAAK,UAAU,eAAe,KAAK,WAAW,SAAS;AACvD,QAAK,iBAAiB;;EAGhB,eAAY;AAClB,OAAI,KAAK,SACP;AAEF,QAAK,UAAU;AACf,QAAK,sBAAsB;;EAGrB,kBAAe;AACrB,QAAK,WAAW,KAAK,WAAW,CAAC,KAAK,WAAW,IAAI;;EAGpC,SAAM;AACvB,UAAO,IAAI;QACP,KAAK,gBAAgB,CAAA"}
|
|
@@ -0,0 +1,244 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
import { html, isServer, unsafeCSS } from "lit";
|
|
3
|
+
import { property } from "lit/decorators.js";
|
|
4
|
+
import { SbbDisabledMixin, SbbElement, SbbFormAssociatedMixin, boxSizingStyles, forceType, interactivityChecker, isLean } from "./core.js";
|
|
5
|
+
//#region src/elements/toggle/toggle/toggle.scss?inline
|
|
6
|
+
var toggle_default = ":host {\n --_sbb-toggle-min-width: calc(\n var(--sbb-toggle-padding-inline) * 4 + var(--sbb-size-icon-ui-small)\n );\n --sbb-toggle-animation-duration: var(\n --sbb-disable-animation-duration,\n var(--sbb-animation-duration-6x)\n );\n display: grid;\n grid-template-columns: var(--sbb-toggle-grid-template-columns);\n grid-template-areas: \"start end\";\n align-items: center;\n height: var(--sbb-toggle-height);\n width: var(--sbb-toggle-width, fit-content);\n min-width: var(--_sbb-toggle-min-width);\n max-width: 100%;\n border-radius: var(--sbb-toggle-border-radius);\n font-size: var(--sbb-toggle-font-size);\n letter-spacing: var(--sbb-typo-letter-spacing-text);\n user-select: none;\n -webkit-tap-highlight-color: transparent;\n}\n:host::before {\n content: \"\";\n display: block;\n grid-area: start/start/end/end;\n margin-inline: var(--sbb-toggle-option-left, 0) var(--sbb-toggle-option-right, 0);\n background-color: var(--sbb-toggle-selected-option-background-color);\n border-radius: var(--sbb-toggle-border-radius);\n max-width: 100%;\n height: 100%;\n border: var(--sbb-toggle-selected-option-border-width) var(--sbb-toggle-selected-option-border-style) var(--sbb-toggle-selected-option-border-color);\n transition-duration: var(--sbb-toggle-animation-duration);\n transition-timing-function: ease;\n transition-property: margin-inline-start, margin-inline-end;\n}\n:host::after {\n content: \"\";\n grid-area: start/start/end/end;\n order: -1;\n background: var(--sbb-toggle-background-color);\n margin-inline: var(--sbb-toggle-background-inset);\n height: calc(100% - 2 * var(--sbb-toggle-background-inset));\n border-radius: var(--sbb-toggle-border-radius);\n}\n@media (forced-colors: active) {\n :host::after {\n border: var(--sbb-border-width-1x) solid CanvasText;\n }\n}\n\n:host([even]) {\n --sbb-toggle-width: 100%;\n --sbb-toggle-grid-template-columns: 50% 50%;\n}\n\n:host(:disabled) {\n --sbb-toggle-selected-option-border-color: var(--sbb-color-graphite);\n --sbb-toggle-selected-option-border-color: light-dark(\n var(--sbb-color-graphite),\n var(--sbb-color-smoke)\n );\n --sbb-toggle-selected-option-border-style: dashed;\n}\n@media (forced-colors: active) {\n :host(:disabled) {\n --sbb-toggle-selected-option-border-style: solid;\n --sbb-toggle-selected-option-border-color: GrayText;\n }\n}\n\n:host([size=m]) {\n --sbb-toggle-padding-inline: var(--sbb-spacing-responsive-xs);\n --sbb-toggle-height: var(--sbb-size-element-m);\n}\n\n:host([size=s]) {\n --sbb-toggle-padding-inline: var(--sbb-spacing-responsive-xxxs);\n --sbb-toggle-height: var(--sbb-size-element-xxs);\n}\n\n:host(:is(:not(:is(:state(initialized),[state--initialized])), :is(:state(disable-animation-on-resizing),[state--disable-animation-on-resizing]))) {\n --sbb-disable-animation-duration: 0s;\n}\n\n::slotted(sbb-toggle-option:first-of-type) {\n grid-area: start;\n}\n\n::slotted(sbb-toggle-option:last-of-type) {\n grid-area: end;\n}";
|
|
7
|
+
//#endregion
|
|
8
|
+
//#region src/elements/toggle/toggle/toggle.component.ts
|
|
9
|
+
/**
|
|
10
|
+
* It can be used as a container for two `sbb-toggle-option`, acting as a toggle button.
|
|
11
|
+
*
|
|
12
|
+
* @slot - Use the unnamed slot to add `<sbb-toggle-option>` elements to the toggle.
|
|
13
|
+
* @overrideType value - (T = string) | null
|
|
14
|
+
*/
|
|
15
|
+
var SbbToggleElement = (() => {
|
|
16
|
+
let _classSuper = SbbDisabledMixin(SbbFormAssociatedMixin(SbbElement));
|
|
17
|
+
let _instanceExtraInitializers = [];
|
|
18
|
+
let _even_decorators;
|
|
19
|
+
let _even_initializers = [];
|
|
20
|
+
let _even_extraInitializers = [];
|
|
21
|
+
let _size_decorators;
|
|
22
|
+
let _size_initializers = [];
|
|
23
|
+
let _size_extraInitializers = [];
|
|
24
|
+
let _set_value_decorators;
|
|
25
|
+
return class SbbToggleElement extends _classSuper {
|
|
26
|
+
static {
|
|
27
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
28
|
+
_even_decorators = [forceType(), property({
|
|
29
|
+
reflect: true,
|
|
30
|
+
type: Boolean
|
|
31
|
+
})];
|
|
32
|
+
_size_decorators = [property({ reflect: true })];
|
|
33
|
+
_set_value_decorators = [property()];
|
|
34
|
+
__esDecorate(this, null, _even_decorators, {
|
|
35
|
+
kind: "accessor",
|
|
36
|
+
name: "even",
|
|
37
|
+
static: false,
|
|
38
|
+
private: false,
|
|
39
|
+
access: {
|
|
40
|
+
has: (obj) => "even" in obj,
|
|
41
|
+
get: (obj) => obj.even,
|
|
42
|
+
set: (obj, value) => {
|
|
43
|
+
obj.even = value;
|
|
44
|
+
}
|
|
45
|
+
},
|
|
46
|
+
metadata: _metadata
|
|
47
|
+
}, _even_initializers, _even_extraInitializers);
|
|
48
|
+
__esDecorate(this, null, _size_decorators, {
|
|
49
|
+
kind: "accessor",
|
|
50
|
+
name: "size",
|
|
51
|
+
static: false,
|
|
52
|
+
private: false,
|
|
53
|
+
access: {
|
|
54
|
+
has: (obj) => "size" in obj,
|
|
55
|
+
get: (obj) => obj.size,
|
|
56
|
+
set: (obj, value) => {
|
|
57
|
+
obj.size = value;
|
|
58
|
+
}
|
|
59
|
+
},
|
|
60
|
+
metadata: _metadata
|
|
61
|
+
}, _size_initializers, _size_extraInitializers);
|
|
62
|
+
__esDecorate(this, null, _set_value_decorators, {
|
|
63
|
+
kind: "setter",
|
|
64
|
+
name: "value",
|
|
65
|
+
static: false,
|
|
66
|
+
private: false,
|
|
67
|
+
access: {
|
|
68
|
+
has: (obj) => "value" in obj,
|
|
69
|
+
set: (obj, value) => {
|
|
70
|
+
obj.value = value;
|
|
71
|
+
}
|
|
72
|
+
},
|
|
73
|
+
metadata: _metadata
|
|
74
|
+
}, null, _instanceExtraInitializers);
|
|
75
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, {
|
|
76
|
+
enumerable: true,
|
|
77
|
+
configurable: true,
|
|
78
|
+
writable: true,
|
|
79
|
+
value: _metadata
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
static {
|
|
83
|
+
this.elementName = "sbb-toggle";
|
|
84
|
+
}
|
|
85
|
+
static {
|
|
86
|
+
this.role = "radiogroup";
|
|
87
|
+
}
|
|
88
|
+
static {
|
|
89
|
+
this.styles = [boxSizingStyles, unsafeCSS(toggle_default)];
|
|
90
|
+
}
|
|
91
|
+
static {
|
|
92
|
+
this.events = { change: "change" };
|
|
93
|
+
}
|
|
94
|
+
#even_accessor_storage;
|
|
95
|
+
/**
|
|
96
|
+
* If true, set the width of the component fixed; if false,
|
|
97
|
+
* the width is dynamic based on the label of the sbb-toggle-option.
|
|
98
|
+
*/
|
|
99
|
+
get even() {
|
|
100
|
+
return this.#even_accessor_storage;
|
|
101
|
+
}
|
|
102
|
+
set even(value) {
|
|
103
|
+
this.#even_accessor_storage = value;
|
|
104
|
+
}
|
|
105
|
+
#size_accessor_storage;
|
|
106
|
+
/**
|
|
107
|
+
* Size variant, either m or s.
|
|
108
|
+
* @default 'm' / 's' (lean)
|
|
109
|
+
*/
|
|
110
|
+
get size() {
|
|
111
|
+
return this.#size_accessor_storage;
|
|
112
|
+
}
|
|
113
|
+
set size(value) {
|
|
114
|
+
this.#size_accessor_storage = value;
|
|
115
|
+
}
|
|
116
|
+
/**
|
|
117
|
+
* The value of the toggle. It needs to be mutable since it is updated whenever
|
|
118
|
+
* a new option is selected (see the `onToggleOptionSelect()` method).
|
|
119
|
+
*/
|
|
120
|
+
set value(value) {
|
|
121
|
+
if (isServer || !this.hasUpdated) this._fallbackValue = value;
|
|
122
|
+
else this._valueChanged(value);
|
|
123
|
+
}
|
|
124
|
+
get value() {
|
|
125
|
+
return isServer ? this._fallbackValue ?? null : this.options.find((o) => o.checked)?.value ?? this.options[0]?.value ?? null;
|
|
126
|
+
}
|
|
127
|
+
/** The child instances of sbb-toggle-option as an array. */
|
|
128
|
+
get options() {
|
|
129
|
+
return Array.from(this.querySelectorAll?.("sbb-toggle-option") ?? []);
|
|
130
|
+
}
|
|
131
|
+
constructor() {
|
|
132
|
+
super();
|
|
133
|
+
this.#even_accessor_storage = (__runInitializers(this, _instanceExtraInitializers), __runInitializers(this, _even_initializers, false));
|
|
134
|
+
this.#size_accessor_storage = (__runInitializers(this, _even_extraInitializers), __runInitializers(this, _size_initializers, isLean() ? "s" : "m"));
|
|
135
|
+
this._fallbackValue = (__runInitializers(this, _size_extraInitializers), null);
|
|
136
|
+
this.addEventListener?.("input", () => this._handleInput(), { passive: true });
|
|
137
|
+
this.addEventListener?.("keydown", (e) => this._handleKeyDown(e));
|
|
138
|
+
}
|
|
139
|
+
willUpdate(changedProperties) {
|
|
140
|
+
super.willUpdate(changedProperties);
|
|
141
|
+
if (changedProperties.has("disabled") || changedProperties.has("formDisabled")) this._updateDisabled();
|
|
142
|
+
if (!this.hasUpdated) this._valueChanged(this._fallbackValue);
|
|
143
|
+
}
|
|
144
|
+
/**
|
|
145
|
+
* Called whenever the value changes, both programmatically or by user interaction.
|
|
146
|
+
* @internal
|
|
147
|
+
*/
|
|
148
|
+
statusChanged() {
|
|
149
|
+
this.updateFormValue();
|
|
150
|
+
this.updatePillPosition();
|
|
151
|
+
}
|
|
152
|
+
/**
|
|
153
|
+
* Reset to the init value if present. Select the first option, otherwise.
|
|
154
|
+
* @internal
|
|
155
|
+
*/
|
|
156
|
+
formResetCallback() {
|
|
157
|
+
this.value = this.hasAttribute("value") ? this.getAttribute("value") : null;
|
|
158
|
+
}
|
|
159
|
+
/**
|
|
160
|
+
* @internal
|
|
161
|
+
*/
|
|
162
|
+
formStateRestoreCallback(state, _reason) {
|
|
163
|
+
if (typeof state === "string" || state == null) this.value = state ?? null;
|
|
164
|
+
else if (state instanceof FormData) this._readFormData(state).then((data) => {
|
|
165
|
+
this.value = data;
|
|
166
|
+
});
|
|
167
|
+
}
|
|
168
|
+
async _readFormData(formData) {
|
|
169
|
+
const data = formData.get(this.name);
|
|
170
|
+
return data instanceof Blob ? JSON.parse(await data.text()) : data;
|
|
171
|
+
}
|
|
172
|
+
/** @internal */
|
|
173
|
+
updatePillPosition(resizing = false) {
|
|
174
|
+
const options = this.options;
|
|
175
|
+
if (options.length < 2 || options.every((o) => !o.checked) || options.every((o) => !o.clientWidth)) return;
|
|
176
|
+
this.toggleState("disable-animation-on-resizing", resizing);
|
|
177
|
+
const firstOption = options[0];
|
|
178
|
+
const isFirstChecked = firstOption.checked;
|
|
179
|
+
const pillLeft = isFirstChecked ? "0px" : `${firstOption.clientWidth}px`;
|
|
180
|
+
const pillRight = isFirstChecked ? `${this.clientWidth - firstOption.clientWidth}px` : "0px";
|
|
181
|
+
if (pillRight === "0px" && pillLeft === "0px") return;
|
|
182
|
+
this.style?.setProperty("--sbb-toggle-option-left", pillLeft);
|
|
183
|
+
this.style?.setProperty("--sbb-toggle-option-right", pillRight);
|
|
184
|
+
this.offsetWidth;
|
|
185
|
+
this.internals.states.add("initialized");
|
|
186
|
+
}
|
|
187
|
+
_updateToggle() {
|
|
188
|
+
this._valueChanged(this.value);
|
|
189
|
+
this._updateDisabled();
|
|
190
|
+
}
|
|
191
|
+
_valueChanged(value) {
|
|
192
|
+
const options = this.options;
|
|
193
|
+
const selectedOption = options.find((o) => value === o.value) ?? options.find((o) => o.checked) ?? options[0];
|
|
194
|
+
if (!selectedOption) return;
|
|
195
|
+
selectedOption.checked = true;
|
|
196
|
+
this.statusChanged();
|
|
197
|
+
}
|
|
198
|
+
_updateDisabled() {
|
|
199
|
+
for (const toggleOption of this.options) toggleOption.disabled = this.disabled || this.formDisabled;
|
|
200
|
+
}
|
|
201
|
+
/**
|
|
202
|
+
* Called on user interaction (click or keyboard)
|
|
203
|
+
*/
|
|
204
|
+
_handleInput() {
|
|
205
|
+
this.statusChanged();
|
|
206
|
+
/**
|
|
207
|
+
* The change event is fired when the user modifies the element's value.
|
|
208
|
+
* Unlike the input event, the change event is not necessarily fired
|
|
209
|
+
* for each alteration to an element's value.
|
|
210
|
+
*/
|
|
211
|
+
this.dispatchEvent(new Event("change", { bubbles: true }));
|
|
212
|
+
}
|
|
213
|
+
_handleKeyDown(evt) {
|
|
214
|
+
if (!this.options.filter((t) => !t.disabled && interactivityChecker.isVisible(t)) || evt.target !== this && evt.target.parentElement !== this) return;
|
|
215
|
+
const options = this.options;
|
|
216
|
+
const isRtl = this.matches(":dir(rtl)");
|
|
217
|
+
const currentIndex = options.findIndex((option) => option.checked) ?? options[0];
|
|
218
|
+
const availableOptions = options.slice(currentIndex + 1).concat(options.slice(0, currentIndex)).filter((o) => !o.disabled && interactivityChecker.isVisible(o));
|
|
219
|
+
if (!isRtl ? evt.key === " " || evt.key === "ArrowRight" : evt.key === "ArrowLeft") {
|
|
220
|
+
this._selectAndFocusOption(availableOptions[0]);
|
|
221
|
+
evt.preventDefault();
|
|
222
|
+
} else if (isRtl ? evt.key === " " || evt.key === "ArrowRight" : evt.key === "ArrowLeft") {
|
|
223
|
+
this._selectAndFocusOption(availableOptions.at(-1));
|
|
224
|
+
evt.preventDefault();
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
_selectAndFocusOption(option) {
|
|
228
|
+
if (!option || option.disabled || option.checked) return;
|
|
229
|
+
option.checked = true;
|
|
230
|
+
option.focus();
|
|
231
|
+
option.dispatchEvent(new InputEvent("input", {
|
|
232
|
+
bubbles: true,
|
|
233
|
+
composed: true
|
|
234
|
+
}));
|
|
235
|
+
}
|
|
236
|
+
render() {
|
|
237
|
+
return html` <slot @slotchange=${this._updateToggle}></slot> `;
|
|
238
|
+
}
|
|
239
|
+
};
|
|
240
|
+
})();
|
|
241
|
+
//#endregion
|
|
242
|
+
export { SbbToggleElement as t };
|
|
243
|
+
|
|
244
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"toggle.component-Dap1d4rK.js","names":[],"sources":["../../../src/elements/toggle/toggle/toggle.scss?inline","../../../src/elements/toggle/toggle/toggle.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --_sbb-toggle-min-width: calc(\n    var(--sbb-toggle-padding-inline) * 4 + var(--sbb-size-icon-ui-small)\n  );\n  --sbb-toggle-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-6x)\n  );\n\n  display: grid;\n  grid-template-columns: var(--sbb-toggle-grid-template-columns);\n  grid-template-areas: 'start end';\n  align-items: center;\n  height: var(--sbb-toggle-height);\n  width: var(--sbb-toggle-width, fit-content);\n  min-width: var(--_sbb-toggle-min-width);\n  max-width: 100%;\n  border-radius: var(--sbb-toggle-border-radius);\n  font-size: var(--sbb-toggle-font-size);\n  letter-spacing: var(--sbb-typo-letter-spacing-text);\n  user-select: none;\n  -webkit-tap-highlight-color: transparent;\n\n  // White pill of selected toggle option\n  &::before {\n    content: '';\n    display: block;\n    grid-area: start / start / end / end;\n    margin-inline: var(--sbb-toggle-option-left, 0) var(--sbb-toggle-option-right, 0);\n    background-color: var(--sbb-toggle-selected-option-background-color);\n    border-radius: var(--sbb-toggle-border-radius);\n    max-width: 100%;\n    height: 100%;\n    border: var(--sbb-toggle-selected-option-border-width)\n      var(--sbb-toggle-selected-option-border-style) var(--sbb-toggle-selected-option-border-color);\n\n    transition: {\n      duration: var(--sbb-toggle-animation-duration);\n      timing-function: ease;\n      property: margin-inline-start, margin-inline-end;\n    }\n  }\n\n  // Background\n  &::after {\n    content: '';\n    grid-area: start / start / end / end;\n    order: -1;\n    background: var(--sbb-toggle-background-color);\n    margin-inline: var(--sbb-toggle-background-inset);\n    height: calc(100% - 2 * var(--sbb-toggle-background-inset));\n    border-radius: var(--sbb-toggle-border-radius);\n\n    @include sbb.if-forced-colors {\n      border: var(--sbb-border-width-1x) solid CanvasText;\n    }\n  }\n}\n\n:host([even]) {\n  --sbb-toggle-width: 100%;\n  --sbb-toggle-grid-template-columns: 50% 50%;\n}\n\n:host(:disabled) {\n  --sbb-toggle-selected-option-border-color: light-dark(\n    var(--sbb-color-graphite),\n    var(--sbb-color-smoke)\n  );\n  --sbb-toggle-selected-option-border-style: dashed;\n\n  @include sbb.if-forced-colors {\n    --sbb-toggle-selected-option-border-style: solid;\n    --sbb-toggle-selected-option-border-color: GrayText;\n  }\n}\n\n:host([size='m']) {\n  --sbb-toggle-padding-inline: var(--sbb-spacing-responsive-xs);\n  --sbb-toggle-height: var(--sbb-size-element-m);\n}\n\n:host([size='s']) {\n  --sbb-toggle-padding-inline: var(--sbb-spacing-responsive-xxxs);\n  --sbb-toggle-height: var(--sbb-size-element-xxs);\n}\n\n:host(:is(:not(:state(initialized)), :state(disable-animation-on-resizing))) {\n  @include sbb.disable-animation;\n}\n\n::slotted(sbb-toggle-option:first-of-type) {\n  grid-area: start;\n}\n\n::slotted(sbb-toggle-option:last-of-type) {\n  grid-area: end;\n}\n","import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  type PropertyValues,\n  type TemplateResult,\n  unsafeCSS,\n} from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport {\n  interactivityChecker,\n  SbbElement,\n  forceType,\n  isLean,\n  boxSizingStyles,\n} from '../../core.ts';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbDisabledMixin,\n  SbbFormAssociatedMixin,\n} from '../../core.ts';\nimport type { SbbToggleOptionElement } from '../toggle-option/toggle-option.component.ts';\n\nimport style from './toggle.scss?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 * @overrideType value - (T = string) | null\n */\nexport class SbbToggleElement<T = string> extends SbbDisabledMixin(\n  SbbFormAssociatedMixin(SbbElement),\n) {\n  public static override readonly elementName: string = 'sbb-toggle';\n  public static override readonly role = 'radiogroup';\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(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 set value(value: T | null) {\n    if (isServer || !this.hasUpdated) {\n      this._fallbackValue = value;\n    } else {\n      this._valueChanged(value);\n    }\n  }\n  public get value(): T | null {\n    return isServer\n      ? (this._fallbackValue ?? null)\n      : (this.options.find((o) => o.checked)?.value ?? this.options[0]?.value ?? null);\n  }\n  private _fallbackValue: T | null = null;\n\n  /** The child instances of sbb-toggle-option as an array. */\n  public get options(): SbbToggleOptionElement<T>[] {\n    return Array.from(\n      this.querySelectorAll?.<SbbToggleOptionElement<T>>('sbb-toggle-option') ?? [],\n    );\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('input', () => this._handleInput(), { passive: true });\n    this.addEventListener?.('keydown', (e) => this._handleKeyDown(e));\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    // Before the first update, init with the fallback value.\n    // The willUpdate hook is safer than the 'value' setter.\n    if (!this.hasUpdated) {\n      this._valueChanged(this._fallbackValue);\n    }\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   * @internal\n   */\n  public formResetCallback(): void {\n    this.value = (this.hasAttribute('value') ? this.getAttribute('value') : null) as T;\n  }\n\n  /**\n   * @internal\n   */\n  public formStateRestoreCallback(\n    state: FormRestoreState | null,\n    _reason: FormRestoreReason,\n  ): void {\n    if (typeof state === 'string' || state == null) {\n      this.value = (state as T) ?? null;\n    } else if (state instanceof FormData) {\n      this._readFormData(state).then((data) => {\n        this.value = data;\n      });\n    }\n  }\n\n  private async _readFormData(formData: FormData): Promise<T> {\n    const data = formData.get(this.name);\n    return data instanceof Blob ? JSON.parse(await data.text()) : (data as T);\n  }\n\n  /** @internal */\n  public updatePillPosition(resizing = false): void {\n    const options = this.options;\n\n    if (\n      options.length < 2 ||\n      options.every((o) => !o.checked) ||\n      options.every((o) => !o.clientWidth)\n    ) {\n      return;\n    }\n\n    this.toggleState('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 ? `${this.clientWidth - firstOption.clientWidth}px` : '0px';\n\n    if (pillRight === '0px' && pillLeft === '0px') {\n      return;\n    }\n\n    this.style?.setProperty('--sbb-toggle-option-left', pillLeft);\n    this.style?.setProperty('--sbb-toggle-option-right', pillRight);\n\n    // Triggers a layout reflow which is needed to avoid animation glitches.\n    // eslint-disable-next-line @typescript-eslint/no-unused-expressions\n    this.offsetWidth;\n\n    // In order to avoid a transition glitch, we have to know when the first values were set.\n    this.internals.states.add('initialized');\n  }\n\n  private _updateToggle(): void {\n    this._valueChanged(this.value);\n    this._updateDisabled();\n  }\n\n  private _valueChanged(value: T | null): void {\n    const options = this.options;\n\n    const selectedOption =\n      options.find((o) => value === o.value) ?? options.find((o) => o.checked) ?? 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    selectedOption.checked = true;\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    /**\n     * The change event is fired when the user modifies the element's value.\n     * Unlike the input event, the change event is not necessarily fired\n     * for each alteration to an element's value.\n     */\n    this.dispatchEvent(new Event('change', { bubbles: true }));\n  }\n\n  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    const options = this.options;\n    const isRtl = this.matches(':dir(rtl)');\n    const currentIndex = options.findIndex((option) => option.checked) ?? options[0];\n    const availableOptions = options\n      .slice(currentIndex + 1)\n      .concat(options.slice(0, currentIndex))\n      .filter((o) => !o.disabled && interactivityChecker.isVisible(o));\n    if (!isRtl ? evt.key === ' ' || evt.key === 'ArrowRight' : evt.key === 'ArrowLeft') {\n      this._selectAndFocusOption(availableOptions[0]);\n      evt.preventDefault();\n    } else if (isRtl ? evt.key === ' ' || evt.key === 'ArrowRight' : evt.key === 'ArrowLeft') {\n      this._selectAndFocusOption(availableOptions.at(-1));\n      evt.preventDefault();\n    }\n  }\n\n  private _selectAndFocusOption(option: SbbToggleOptionElement<T> | undefined): void {\n    if (!option || option.disabled || option.checked) {\n      return;\n    }\n    option.checked = true;\n    option.focus();\n    option.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n  }\n\n  protected override render(): TemplateResult {\n    return html` <slot @slotchange=${this._updateToggle}></slot> `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-toggle': SbbToggleElement;\n  }\n}\n"],"mappings":"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"}
|
package/development/toggle.js
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { t as SbbToggleOptionElement } from "./toggle-option.component-
|
|
2
|
-
import { t as SbbToggleElement } from "./toggle.component-
|
|
1
|
+
import { t as SbbToggleOptionElement } from "./toggle-option.component-D8YWH_D5.js";
|
|
2
|
+
import { t as SbbToggleElement } from "./toggle.component-Dap1d4rK.js";
|
|
3
3
|
import "./toggle.pure.js";
|
|
4
4
|
//#region src/elements/toggle.ts
|
|
5
5
|
/** @entrypoint */
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import { t as SbbToggleOptionElement } from "./toggle-option.component-
|
|
2
|
-
import { t as SbbToggleElement } from "./toggle.component-
|
|
1
|
+
import { t as SbbToggleOptionElement } from "./toggle-option.component-D8YWH_D5.js";
|
|
2
|
+
import { t as SbbToggleElement } from "./toggle.component-Dap1d4rK.js";
|
|
3
3
|
export { SbbToggleElement, SbbToggleOptionElement };
|
package/off-brand-theme.css
CHANGED
|
@@ -1885,6 +1885,22 @@ slot[name=error]::slotted(*) {
|
|
|
1885
1885
|
--sbb-timetable-occupancy-font-size: var(--sbb-text-font-size-s);
|
|
1886
1886
|
--sbb-timetable-occupancy-list-gap: var(--sbb-spacing-fixed-2x);
|
|
1887
1887
|
--sbb-timetable-occupancy-item-gap: var(--sbb-spacing-fixed-1x);
|
|
1888
|
+
--sbb-toggle-padding-inline: var(--sbb-spacing-responsive-xs);
|
|
1889
|
+
--sbb-toggle-height: var(--sbb-size-element-m);
|
|
1890
|
+
--sbb-toggle-background-color: var(--sbb-background-color-4);
|
|
1891
|
+
--sbb-toggle-background-inset: 0.125rem;
|
|
1892
|
+
--sbb-toggle-border-radius: var(--sbb-border-radius-infinity);
|
|
1893
|
+
--sbb-toggle-font-size: var(--sbb-text-font-size-m);
|
|
1894
|
+
--sbb-toggle-grid-template-columns: auto auto;
|
|
1895
|
+
--sbb-toggle-selected-option-border-width: var(--sbb-border-width-1x);
|
|
1896
|
+
--sbb-toggle-selected-option-border-style: solid;
|
|
1897
|
+
--sbb-toggle-selected-option-border-color: var(--sbb-border-color-5);
|
|
1898
|
+
--sbb-toggle-selected-option-background-color: var(--sbb-background-color-1);
|
|
1899
|
+
--sbb-toggle-option-color: var(--sbb-color-anthracite);
|
|
1900
|
+
--sbb-toggle-option-color: light-dark(var(--sbb-color-anthracite), var(--sbb-color-cloud));
|
|
1901
|
+
--sbb-toggle-option-gap: var(--sbb-spacing-fixed-1x);
|
|
1902
|
+
--sbb-toggle-option-font-size: var(--sbb-text-font-size-xs);
|
|
1903
|
+
--sbb-toggle-option-icon-min-size: var(--sbb-size-icon-ui-small);
|
|
1888
1904
|
--sbb-tooltip-animation-easing: ease-out;
|
|
1889
1905
|
--sbb-tooltip-animation-translate: 0 var(--sbb-spacing-fixed-2x);
|
|
1890
1906
|
--sbb-tooltip-background-color: var(--sbb-background-color-1-inverted);
|
|
@@ -1961,6 +1977,8 @@ slot[name=error]::slotted(*) {
|
|
|
1961
1977
|
--sbb-tag-text-color: ButtonText;
|
|
1962
1978
|
--sbb-tag-border-color: CanvasText;
|
|
1963
1979
|
--sbb-tag-border-width: var(--sbb-border-width-2x);
|
|
1980
|
+
--sbb-toggle-selected-option-border-width: var(--sbb-border-width-2x);
|
|
1981
|
+
--sbb-toggle-selected-option-border-color: Highlight;
|
|
1964
1982
|
}
|
|
1965
1983
|
}
|
|
1966
1984
|
:root {
|
|
@@ -2456,6 +2474,11 @@ sbb-tab-nav-bar .sbb-tab-amount {
|
|
|
2456
2474
|
place-self: stretch;
|
|
2457
2475
|
}
|
|
2458
2476
|
|
|
2477
|
+
sbb-toggle:has(:focus-visible) {
|
|
2478
|
+
outline-offset: var(--sbb-focus-outline-offset);
|
|
2479
|
+
outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);
|
|
2480
|
+
}
|
|
2481
|
+
|
|
2459
2482
|
.sbb-dark {
|
|
2460
2483
|
color-scheme: dark;
|
|
2461
2484
|
}
|
|
@@ -2631,11 +2654,6 @@ sbb-form-field .sbb-select-trigger {
|
|
|
2631
2654
|
top: 0;
|
|
2632
2655
|
}
|
|
2633
2656
|
|
|
2634
|
-
sbb-toggle:has(:focus-visible) {
|
|
2635
|
-
outline-offset: var(--sbb-focus-outline-offset);
|
|
2636
|
-
outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);
|
|
2637
|
-
}
|
|
2638
|
-
|
|
2639
2657
|
.sbb-overlay-outlet {
|
|
2640
2658
|
position: fixed;
|
|
2641
2659
|
inset: 0;
|
package/package.json
CHANGED
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@sbb-esta/lyne-elements-dev",
|
|
3
|
-
"version": "5.0.0-next-dev.
|
|
3
|
+
"version": "5.0.0-next-dev.1776240735",
|
|
4
4
|
"description": "Lyne Design System",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"design system",
|
|
7
7
|
"web components",
|
|
8
8
|
"lit",
|
|
9
|
-
"https://github.com/sbb-design-systems/lyne-components/commit/
|
|
9
|
+
"https://github.com/sbb-design-systems/lyne-components/commit/1a58a6c9fcde044d2f6a7afb8d55a6768b2f4a12"
|
|
10
10
|
],
|
|
11
11
|
"type": "module",
|
|
12
12
|
"exports": {
|
package/safety-theme.css
CHANGED
|
@@ -1885,6 +1885,22 @@ slot[name=error]::slotted(*) {
|
|
|
1885
1885
|
--sbb-timetable-occupancy-font-size: var(--sbb-text-font-size-s);
|
|
1886
1886
|
--sbb-timetable-occupancy-list-gap: var(--sbb-spacing-fixed-2x);
|
|
1887
1887
|
--sbb-timetable-occupancy-item-gap: var(--sbb-spacing-fixed-1x);
|
|
1888
|
+
--sbb-toggle-padding-inline: var(--sbb-spacing-responsive-xs);
|
|
1889
|
+
--sbb-toggle-height: var(--sbb-size-element-m);
|
|
1890
|
+
--sbb-toggle-background-color: var(--sbb-background-color-4);
|
|
1891
|
+
--sbb-toggle-background-inset: 0.125rem;
|
|
1892
|
+
--sbb-toggle-border-radius: var(--sbb-border-radius-infinity);
|
|
1893
|
+
--sbb-toggle-font-size: var(--sbb-text-font-size-m);
|
|
1894
|
+
--sbb-toggle-grid-template-columns: auto auto;
|
|
1895
|
+
--sbb-toggle-selected-option-border-width: var(--sbb-border-width-1x);
|
|
1896
|
+
--sbb-toggle-selected-option-border-style: solid;
|
|
1897
|
+
--sbb-toggle-selected-option-border-color: var(--sbb-border-color-5);
|
|
1898
|
+
--sbb-toggle-selected-option-background-color: var(--sbb-background-color-1);
|
|
1899
|
+
--sbb-toggle-option-color: var(--sbb-color-anthracite);
|
|
1900
|
+
--sbb-toggle-option-color: light-dark(var(--sbb-color-anthracite), var(--sbb-color-cloud));
|
|
1901
|
+
--sbb-toggle-option-gap: var(--sbb-spacing-fixed-1x);
|
|
1902
|
+
--sbb-toggle-option-font-size: var(--sbb-text-font-size-xs);
|
|
1903
|
+
--sbb-toggle-option-icon-min-size: var(--sbb-size-icon-ui-small);
|
|
1888
1904
|
--sbb-tooltip-animation-easing: ease-out;
|
|
1889
1905
|
--sbb-tooltip-animation-translate: 0 var(--sbb-spacing-fixed-2x);
|
|
1890
1906
|
--sbb-tooltip-background-color: var(--sbb-background-color-1-inverted);
|
|
@@ -1961,6 +1977,8 @@ slot[name=error]::slotted(*) {
|
|
|
1961
1977
|
--sbb-tag-text-color: ButtonText;
|
|
1962
1978
|
--sbb-tag-border-color: CanvasText;
|
|
1963
1979
|
--sbb-tag-border-width: var(--sbb-border-width-2x);
|
|
1980
|
+
--sbb-toggle-selected-option-border-width: var(--sbb-border-width-2x);
|
|
1981
|
+
--sbb-toggle-selected-option-border-color: Highlight;
|
|
1964
1982
|
}
|
|
1965
1983
|
}
|
|
1966
1984
|
:root {
|
|
@@ -2456,6 +2474,11 @@ sbb-tab-nav-bar .sbb-tab-amount {
|
|
|
2456
2474
|
place-self: stretch;
|
|
2457
2475
|
}
|
|
2458
2476
|
|
|
2477
|
+
sbb-toggle:has(:focus-visible) {
|
|
2478
|
+
outline-offset: var(--sbb-focus-outline-offset);
|
|
2479
|
+
outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);
|
|
2480
|
+
}
|
|
2481
|
+
|
|
2459
2482
|
.sbb-dark {
|
|
2460
2483
|
color-scheme: dark;
|
|
2461
2484
|
}
|
|
@@ -2631,11 +2654,6 @@ sbb-form-field .sbb-select-trigger {
|
|
|
2631
2654
|
top: 0;
|
|
2632
2655
|
}
|
|
2633
2656
|
|
|
2634
|
-
sbb-toggle:has(:focus-visible) {
|
|
2635
|
-
outline-offset: var(--sbb-focus-outline-offset);
|
|
2636
|
-
outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);
|
|
2637
|
-
}
|
|
2638
|
-
|
|
2639
2657
|
.sbb-overlay-outlet {
|
|
2640
2658
|
position: fixed;
|
|
2641
2659
|
inset: 0;
|