@sbb-esta/lyne-elements 2.7.1 → 2.8.0

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