@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.
@@ -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;IAqCjD,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;CAO5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,YAAY,EAAE,gBAAgB,CAAC;KAChC;CACF"}
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-DjLnSv3R.js";
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;CAU5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,mBAAmB,EAAE,sBAAsB,CAAC;KAC7C;CACF"}
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-BWT4kEZo.js";
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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"}
@@ -1,5 +1,5 @@
1
- import { t as SbbToggleOptionElement } from "./toggle-option.component-BWT4kEZo.js";
2
- import { t as SbbToggleElement } from "./toggle.component-DjLnSv3R.js";
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-BWT4kEZo.js";
2
- import { t as SbbToggleElement } from "./toggle.component-DjLnSv3R.js";
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 };
@@ -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.1776118170",
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/1744a8b10de90f014a85a93213d5b51e013c0374"
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;