@sbb-esta/lyne-elements-dev 4.11.0-dev.1776266967 → 4.11.0-dev.1776332009

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.
@@ -69472,7 +69472,8 @@
69472
69472
  "text": "number"
69473
69473
  }
69474
69474
  }
69475
- ]
69475
+ ],
69476
+ "deprecated": "true"
69476
69477
  }
69477
69478
  ],
69478
69479
  "exports": [
@@ -125241,6 +125242,14 @@
125241
125242
  "privacy": "private",
125242
125243
  "default": "new ResizeController(this, { target: null, skipInitial: true, callback: () => this._onTabGroupElementResize(), })"
125243
125244
  },
125245
+ {
125246
+ "kind": "field",
125247
+ "name": "_contentSlotChangeDebounceId",
125248
+ "type": {
125249
+ "text": "ReturnType<typeof setTimeout> | undefined"
125250
+ },
125251
+ "privacy": "private"
125252
+ },
125244
125253
  {
125245
125254
  "kind": "field",
125246
125255
  "name": "size",
@@ -125366,14 +125375,24 @@
125366
125375
  }
125367
125376
  },
125368
125377
  {
125369
- "kind": "field",
125378
+ "kind": "method",
125370
125379
  "name": "_onContentSlotChange",
125371
- "privacy": "private"
125380
+ "privacy": "private",
125381
+ "return": {
125382
+ "type": {
125383
+ "text": "void"
125384
+ }
125385
+ }
125372
125386
  },
125373
125387
  {
125374
- "kind": "field",
125388
+ "kind": "method",
125375
125389
  "name": "_onLabelSlotChange",
125376
- "privacy": "private"
125390
+ "privacy": "private",
125391
+ "return": {
125392
+ "type": {
125393
+ "text": "void"
125394
+ }
125395
+ }
125377
125396
  },
125378
125397
  {
125379
125398
  "kind": "method",
@@ -1,2 +1,3 @@
1
+ /** @deprecated */
1
2
  export declare const throttle: <F extends (...args: any[]) => any>(func: F, delay: number) => ((...args: Parameters<F>) => Promise<ReturnType<F>>);
2
3
  //# sourceMappingURL=throttle.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"throttle.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/eventing/throttle.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,QAAQ,GAAI,CAAC,SAAS,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,GAAG,EACxD,MAAM,CAAC,EACP,OAAO,MAAM,KACZ,CAAC,CAAC,GAAG,IAAI,EAAE,UAAU,CAAC,CAAC,CAAC,KAAK,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAerD,CAAC"}
1
+ {"version":3,"file":"throttle.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/eventing/throttle.ts"],"names":[],"mappings":"AAAA,kBAAkB;AAClB,eAAO,MAAM,QAAQ,GAAI,CAAC,SAAS,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,GAAG,EACxD,MAAM,CAAC,EACP,OAAO,MAAM,KACZ,CAAC,CAAC,GAAG,IAAI,EAAE,UAAU,CAAC,CAAC,CAAC,KAAK,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAerD,CAAC"}
@@ -1,4 +1,5 @@
1
1
  //#region src/elements/core/eventing/throttle.ts
2
+ /** @deprecated */
2
3
  var throttle = (func, delay) => {
3
4
  let shouldWait = false;
4
5
  const throttled = (...args) => {
@@ -14,4 +15,4 @@ var throttle = (func, delay) => {
14
15
  //#endregion
15
16
  export { throttle };
16
17
 
17
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhyb3R0bGUuanMiLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzL2NvcmUvZXZlbnRpbmcvdGhyb3R0bGUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IHRocm90dGxlID0gPEYgZXh0ZW5kcyAoLi4uYXJnczogYW55W10pID0+IGFueT4oXG4gIGZ1bmM6IEYsXG4gIGRlbGF5OiBudW1iZXIsXG4pOiAoKC4uLmFyZ3M6IFBhcmFtZXRlcnM8Rj4pID0+IFByb21pc2U8UmV0dXJuVHlwZTxGPj4pID0+IHtcbiAgbGV0IHNob3VsZFdhaXQgPSBmYWxzZTtcblxuICBjb25zdCB0aHJvdHRsZWQgPSAoLi4uYXJnczogUGFyYW1ldGVyczxGPik6IGFueSA9PiB7XG4gICAgaWYgKHNob3VsZFdhaXQpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgZnVuYyguLi5hcmdzKTtcbiAgICBzaG91bGRXYWl0ID0gdHJ1ZTtcbiAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIHNob3VsZFdhaXQgPSBmYWxzZTtcbiAgICB9LCBkZWxheSk7XG4gIH07XG5cbiAgcmV0dXJuIHRocm90dGxlZCBhcyAoLi4uYXJnczogUGFyYW1ldGVyczxGPikgPT4gUmV0dXJuVHlwZTxGPjtcbn07XG4iXSwibWFwcGluZ3MiOiI7QUFBQSxJQUFhLFlBQ1gsTUFDQSxVQUN3RDtDQUN4RCxJQUFJLGFBQWE7Q0FFakIsTUFBTSxhQUFhLEdBQUcsU0FBNEI7QUFDaEQsTUFBSSxXQUNGO0FBRUYsT0FBSyxHQUFHLEtBQUs7QUFDYixlQUFhO0FBQ2IsbUJBQWdCO0FBQ2QsZ0JBQWE7S0FDWixNQUFNOztBQUdYLFFBQU8ifQ==
18
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhyb3R0bGUuanMiLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzL2NvcmUvZXZlbnRpbmcvdGhyb3R0bGUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBkZXByZWNhdGVkICovXG5leHBvcnQgY29uc3QgdGhyb3R0bGUgPSA8RiBleHRlbmRzICguLi5hcmdzOiBhbnlbXSkgPT4gYW55PihcbiAgZnVuYzogRixcbiAgZGVsYXk6IG51bWJlcixcbik6ICgoLi4uYXJnczogUGFyYW1ldGVyczxGPikgPT4gUHJvbWlzZTxSZXR1cm5UeXBlPEY+PikgPT4ge1xuICBsZXQgc2hvdWxkV2FpdCA9IGZhbHNlO1xuXG4gIGNvbnN0IHRocm90dGxlZCA9ICguLi5hcmdzOiBQYXJhbWV0ZXJzPEY+KTogYW55ID0+IHtcbiAgICBpZiAoc2hvdWxkV2FpdCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICBmdW5jKC4uLmFyZ3MpO1xuICAgIHNob3VsZFdhaXQgPSB0cnVlO1xuICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgc2hvdWxkV2FpdCA9IGZhbHNlO1xuICAgIH0sIGRlbGF5KTtcbiAgfTtcblxuICByZXR1cm4gdGhyb3R0bGVkIGFzICguLi5hcmdzOiBQYXJhbWV0ZXJzPEY+KSA9PiBSZXR1cm5UeXBlPEY+O1xufTtcbiJdLCJtYXBwaW5ncyI6Ijs7QUFDQSxJQUFhLFlBQ1gsTUFDQSxVQUN3RDtDQUN4RCxJQUFJLGFBQWE7Q0FFakIsTUFBTSxhQUFhLEdBQUcsU0FBNEI7QUFDaEQsTUFBSSxXQUNGO0FBRUYsT0FBSyxHQUFHLEtBQUs7QUFDYixlQUFhO0FBQ2IsbUJBQWdCO0FBQ2QsZ0JBQWE7S0FDWixNQUFNOztBQUdYLFFBQU8ifQ==
@@ -0,0 +1,275 @@
1
+ import { __esDecorate, __runInitializers } from "tslib";
2
+ import { html, unsafeCSS } from "lit";
3
+ import { property } from "lit/decorators.js";
4
+ import { SbbElement } from "./core/base-elements.js";
5
+ import { forceType } from "./core/decorators.js";
6
+ import { isLean } from "./core/dom.js";
7
+ import { ɵstateController } from "./core/mixins.js";
8
+ import { boxSizingStyles } from "./core/styles.js";
9
+ import { ResizeController } from "@lit-labs/observers/resize-controller.js";
10
+ import { ref } from "lit/directives/ref.js";
11
+ import { getNextElementIndex, isArrowKeyPressed } from "./core/a11y.js";
12
+ import { tabGroupCommonStyles } from "./tabs/common/styles.js";
13
+ //#region src/elements/tabs/tab-group/tab-group.scss?inline
14
+ var tab_group_default = ":host {\n --sbb-tab-group-animation-duration: 0s;\n gap: var(--sbb-tab-group-content-gap);\n}\n\n:host(:is(:state(initialized),[state--initialized])) {\n --sbb-tab-group-animation-duration: var(\n --sbb-disable-animation-duration,\n var(--sbb-animation-duration-4x)\n );\n}\n\n.sbb-tab-group-content {\n height: var(--sbb-tab-content-height);\n transition: height var(--sbb-tab-group-animation-duration) var(--sbb-animation-easing);\n}\n\n:host([fixed-height]) ::slotted(sbb-tab) {\n height: 100%;\n overflow: auto;\n}";
15
+ //#endregion
16
+ //#region src/elements/tabs/tab-group/tab-group.component.ts
17
+ /**
18
+ * It displays one or more tabs, each one with a label and some content.
19
+ *
20
+ * @slot - Use the unnamed slot to add content to the `sbb-tab-group` via `sbb-tab-label` and `sbb-tab` instances.
21
+ * @event {CustomEvent<SbbTabChangedEventDetails>} tabchange - The tabchange event is dispatched when a tab is selected.
22
+ */
23
+ var SbbTabGroupElement = (() => {
24
+ let _classSuper = SbbElement;
25
+ let _size_decorators;
26
+ let _size_initializers = [];
27
+ let _size_extraInitializers = [];
28
+ let _initialSelectedIndex_decorators;
29
+ let _initialSelectedIndex_initializers = [];
30
+ let _initialSelectedIndex_extraInitializers = [];
31
+ let _fixedHeight_decorators;
32
+ let _fixedHeight_initializers = [];
33
+ let _fixedHeight_extraInitializers = [];
34
+ return class SbbTabGroupElement extends _classSuper {
35
+ static {
36
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
37
+ _size_decorators = [property()];
38
+ _initialSelectedIndex_decorators = [forceType(), property({
39
+ attribute: "initial-selected-index",
40
+ type: Number
41
+ })];
42
+ _fixedHeight_decorators = [forceType(), property({
43
+ attribute: "fixed-height",
44
+ type: Boolean,
45
+ reflect: true
46
+ })];
47
+ __esDecorate(this, null, _size_decorators, {
48
+ kind: "accessor",
49
+ name: "size",
50
+ static: false,
51
+ private: false,
52
+ access: {
53
+ has: (obj) => "size" in obj,
54
+ get: (obj) => obj.size,
55
+ set: (obj, value) => {
56
+ obj.size = value;
57
+ }
58
+ },
59
+ metadata: _metadata
60
+ }, _size_initializers, _size_extraInitializers);
61
+ __esDecorate(this, null, _initialSelectedIndex_decorators, {
62
+ kind: "accessor",
63
+ name: "initialSelectedIndex",
64
+ static: false,
65
+ private: false,
66
+ access: {
67
+ has: (obj) => "initialSelectedIndex" in obj,
68
+ get: (obj) => obj.initialSelectedIndex,
69
+ set: (obj, value) => {
70
+ obj.initialSelectedIndex = value;
71
+ }
72
+ },
73
+ metadata: _metadata
74
+ }, _initialSelectedIndex_initializers, _initialSelectedIndex_extraInitializers);
75
+ __esDecorate(this, null, _fixedHeight_decorators, {
76
+ kind: "accessor",
77
+ name: "fixedHeight",
78
+ static: false,
79
+ private: false,
80
+ access: {
81
+ has: (obj) => "fixedHeight" in obj,
82
+ get: (obj) => obj.fixedHeight,
83
+ set: (obj, value) => {
84
+ obj.fixedHeight = value;
85
+ }
86
+ },
87
+ metadata: _metadata
88
+ }, _fixedHeight_initializers, _fixedHeight_extraInitializers);
89
+ if (_metadata) Object.defineProperty(this, Symbol.metadata, {
90
+ enumerable: true,
91
+ configurable: true,
92
+ writable: true,
93
+ value: _metadata
94
+ });
95
+ }
96
+ static {
97
+ this.elementName = "sbb-tab-group";
98
+ }
99
+ static {
100
+ this.styles = [
101
+ boxSizingStyles,
102
+ tabGroupCommonStyles,
103
+ unsafeCSS(tab_group_default)
104
+ ];
105
+ }
106
+ static {
107
+ this.events = { tabchange: "tabchange" };
108
+ }
109
+ #size_accessor_storage;
110
+ /**
111
+ * Size variant, either s, l or xl.
112
+ * @default 'l' / 's' (lean)
113
+ */
114
+ get size() {
115
+ return this.#size_accessor_storage;
116
+ }
117
+ set size(value) {
118
+ this.#size_accessor_storage = value;
119
+ }
120
+ #initialSelectedIndex_accessor_storage;
121
+ /**
122
+ * Sets the initial tab. If it matches a disabled tab or exceeds the length of
123
+ * the tab group, the first enabled tab will be selected.
124
+ */
125
+ get initialSelectedIndex() {
126
+ return this.#initialSelectedIndex_accessor_storage;
127
+ }
128
+ set initialSelectedIndex(value) {
129
+ this.#initialSelectedIndex_accessor_storage = value;
130
+ }
131
+ #fixedHeight_accessor_storage;
132
+ /**
133
+ * If set to true, the `sbb-tab` elements take 100% height of the `sbb-tab-group`.
134
+ * It enables controlling the height on the `sbb-tab-group` element.
135
+ * The content becomes scrollable on overflow.
136
+ */
137
+ get fixedHeight() {
138
+ return this.#fixedHeight_accessor_storage;
139
+ }
140
+ set fixedHeight(value) {
141
+ this.#fixedHeight_accessor_storage = value;
142
+ }
143
+ /** Gets the slotted `sbb-tab-label`s. */
144
+ get labels() {
145
+ /**
146
+ * The querySelector API is not used because when nested tabs are used,
147
+ * the returned array contains the inner tabs too, and this breaks the keyboard navigation.
148
+ */
149
+ return Array.from(this.children ?? []).filter((child) => /^sbb-tab-label$/u.test(child.localName));
150
+ }
151
+ /** Gets the slotted `sbb-tab`s. */
152
+ get tabs() {
153
+ /**
154
+ * The querySelector API is not used because when nested tabs are used,
155
+ * the returned array contains the inner tabs too, and this breaks the keyboard navigation.
156
+ */
157
+ return Array.from(this.children ?? []).filter((child) => /^sbb-tab$/u.test(child.localName));
158
+ }
159
+ constructor() {
160
+ super();
161
+ this._tabGroupResizeObserver = new ResizeController(this, {
162
+ target: null,
163
+ skipInitial: true,
164
+ callback: () => this._onTabGroupElementResize()
165
+ });
166
+ this.#size_accessor_storage = __runInitializers(this, _size_initializers, isLean() ? "s" : "l");
167
+ this.#initialSelectedIndex_accessor_storage = (__runInitializers(this, _size_extraInitializers), __runInitializers(this, _initialSelectedIndex_initializers, 0));
168
+ this.#fixedHeight_accessor_storage = (__runInitializers(this, _initialSelectedIndex_extraInitializers), __runInitializers(this, _fixedHeight_initializers, false));
169
+ __runInitializers(this, _fixedHeight_extraInitializers);
170
+ this.addEventListener?.("keydown", (e) => this._handleKeyDown(e));
171
+ }
172
+ firstUpdated(changedProperties) {
173
+ super.firstUpdated(changedProperties);
174
+ this.labels.forEach((tabLabel) => tabLabel["linkToTab"]());
175
+ this._initSelection();
176
+ Promise.resolve().then(() => this.internals.states.add("initialized"));
177
+ this._tabGroupResizeObserver.observe(this._tabGroupElement);
178
+ }
179
+ /**
180
+ * Disables a tab by index.
181
+ * @param index The index of the tab you want to disable.
182
+ */
183
+ disableTab(index) {
184
+ if (this.labels[index]) this.labels[index].disabled = true;
185
+ }
186
+ /**
187
+ * Enables a tab by index.
188
+ * @param index The index of the tab you want to enable.
189
+ */
190
+ enableTab(index) {
191
+ if (this.labels[index]) this.labels[index].disabled = false;
192
+ }
193
+ /**
194
+ * Activates a tab by index.
195
+ * @param index The index of the tab you want to activate.
196
+ */
197
+ activateTab(index) {
198
+ this.labels[index]?.activate();
199
+ }
200
+ _enabledTabs() {
201
+ return this.labels.filter((t) => {
202
+ customElements.upgrade(t);
203
+ return !t.disabled;
204
+ });
205
+ }
206
+ _onContentSlotChange() {
207
+ if (this._contentSlotChangeDebounceId) clearTimeout(this._contentSlotChangeDebounceId);
208
+ this._contentSlotChangeDebounceId = setTimeout(() => {
209
+ this.labels.forEach((tabLabel) => tabLabel["linkToTab"]());
210
+ this.labels.find((tabLabel) => tabLabel.active)?.activate();
211
+ }, 150);
212
+ }
213
+ _onLabelSlotChange() {
214
+ this.labels.forEach((tabLabel) => tabLabel["linkToTab"]());
215
+ this._ensureActiveTab();
216
+ }
217
+ _ensureActiveTab() {
218
+ if (this.internals.states.has("initialized") && !this.labels.some((tabLabel) => tabLabel.active)) this._initSelection();
219
+ }
220
+ _initSelection() {
221
+ const selectedTabLabel = this.labels[this.initialSelectedIndex];
222
+ if (selectedTabLabel) {
223
+ customElements.upgrade(selectedTabLabel);
224
+ if (this.initialSelectedIndex >= 0 && this.initialSelectedIndex < this.labels.length && !selectedTabLabel.disabled) {
225
+ selectedTabLabel.activate();
226
+ return;
227
+ }
228
+ }
229
+ this._enabledTabs()[0]?.activate();
230
+ }
231
+ _onTabGroupElementResize() {
232
+ const tabLabels = this.labels;
233
+ tabLabels.forEach((tabLabel) => {
234
+ ɵstateController(tabLabel)?.toggle("has-divider", tabLabel === tabLabels[0] || tabLabel.offsetLeft === tabLabels[0].offsetLeft);
235
+ });
236
+ this.style.setProperty("--sbb-tab-group-width", `${this._tabGroupElement.clientWidth}px`);
237
+ }
238
+ _handleKeyDown(evt) {
239
+ const enabledTabs = this._enabledTabs();
240
+ if (!enabledTabs || evt.target !== this && evt.target.parentElement !== this) return;
241
+ if (isArrowKeyPressed(evt)) {
242
+ const nextIndex = getNextElementIndex(evt, enabledTabs.findIndex((t) => t.active), enabledTabs.length);
243
+ enabledTabs[nextIndex]?.activate();
244
+ enabledTabs[nextIndex]?.focus();
245
+ evt.preventDefault();
246
+ }
247
+ }
248
+ /**
249
+ * @internal
250
+ */
251
+ setTabContentHeight(contentHeight) {
252
+ this.style.setProperty("--sbb-tab-content-height", `${contentHeight}px`);
253
+ }
254
+ render() {
255
+ return html`
256
+ <div
257
+ class="sbb-tab-group"
258
+ role="tablist"
259
+ ${ref((el) => this._tabGroupElement = el)}
260
+ >
261
+ <slot name="tab-bar" @slotchange=${this._onLabelSlotChange}></slot>
262
+ </div>
263
+ ${!this.fixedHeight ? html`
264
+ <div class="sbb-tab-group-content">
265
+ <slot @slotchange=${this._onContentSlotChange}></slot>
266
+ </div>
267
+ ` : html`<slot @slotchange=${this._onContentSlotChange}></slot>`}
268
+ `;
269
+ }
270
+ };
271
+ })();
272
+ //#endregion
273
+ export { SbbTabGroupElement as t };
274
+
275
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"tab-group.component-DldBA45K.js","names":[],"sources":["../../../src/elements/tabs/tab-group/tab-group.scss?inline","../../../src/elements/tabs/tab-group/tab-group.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-tab-group-animation-duration: 0s;\n\n  gap: var(--sbb-tab-group-content-gap);\n}\n\n:host(:state(initialized)) {\n  --sbb-tab-group-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-4x)\n  );\n}\n\n.sbb-tab-group-content {\n  height: var(--sbb-tab-content-height);\n  transition: height var(--sbb-tab-group-animation-duration) var(--sbb-animation-easing);\n}\n\n::slotted(sbb-tab) {\n  :host([fixed-height]) & {\n    height: 100%;\n    overflow: auto;\n  }\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';\nimport { ref } from 'lit/directives/ref.js';\n\nimport { getNextElementIndex, isArrowKeyPressed } from '../../core/a11y.ts';\nimport { SbbElement } from '../../core/base-elements.ts';\nimport { forceType } from '../../core/decorators.ts';\nimport { isLean } from '../../core/dom.ts';\nimport { ɵstateController } from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport { tabGroupCommonStyles } from '../common/styles.ts';\nimport type { SbbTabElement } from '../tab/tab.component.ts';\nimport type { SbbTabLabelElement } from '../tab-label/tab-label.component.ts';\n\nimport style from './tab-group.scss?inline';\n\nexport interface SbbTabChangedEventDetails {\n  activeIndex: number;\n  activeTabLabel: SbbTabLabelElement;\n  activeTab: SbbTabElement;\n  previousIndex: number;\n  previousTabLabel: SbbTabLabelElement | undefined;\n  previousTab: SbbTabElement | undefined;\n}\n\n/**\n * It displays one or more tabs, each one with a label and some content.\n *\n * @slot - Use the unnamed slot to add content to the `sbb-tab-group` via `sbb-tab-label` and `sbb-tab` instances.\n * @event {CustomEvent<SbbTabChangedEventDetails>} tabchange - The tabchange event is dispatched when a tab is selected.\n */\nexport class SbbTabGroupElement extends SbbElement {\n  public static override readonly elementName: string = 'sbb-tab-group';\n  public static override styles: CSSResultGroup = [\n    boxSizingStyles,\n    tabGroupCommonStyles,\n    unsafeCSS(style),\n  ];\n  public static readonly events = {\n    tabchange: 'tabchange',\n  } as const;\n\n  private _tabGroupElement!: HTMLElement;\n  private _tabGroupResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: () => this._onTabGroupElementResize(),\n  });\n  private _contentSlotChangeDebounceId?: ReturnType<typeof setTimeout>;\n\n  /**\n   * Size variant, either s, l or xl.\n   * @default 'l' / 's' (lean)\n   */\n  @property()\n  public accessor size: 's' | 'l' | 'xl' = isLean() ? 's' : 'l';\n\n  /**\n   * Sets the initial tab. If it matches a disabled tab or exceeds the length of\n   * the tab group, the first enabled tab will be selected.\n   */\n  @forceType()\n  @property({ attribute: 'initial-selected-index', type: Number })\n  public accessor initialSelectedIndex: number = 0;\n\n  /**\n   * If set to true, the `sbb-tab` elements take 100% height of the `sbb-tab-group`.\n   * It enables controlling the height on the `sbb-tab-group` element.\n   * The content becomes scrollable on overflow.\n   */\n  @forceType()\n  @property({ attribute: 'fixed-height', type: Boolean, reflect: true })\n  public accessor fixedHeight: boolean = false;\n\n  /** Gets the slotted `sbb-tab-label`s. */\n  public get labels(): SbbTabLabelElement[] {\n    /**\n     * The querySelector API is not used because when nested tabs are used,\n     * the returned array contains the inner tabs too, and this breaks the keyboard navigation.\n     */\n    return Array.from(this.children ?? []).filter((child) =>\n      /^sbb-tab-label$/u.test(child.localName),\n    ) as SbbTabLabelElement[];\n  }\n\n  /** Gets the slotted `sbb-tab`s. */\n  public get tabs(): SbbTabElement[] {\n    /**\n     * The querySelector API is not used because when nested tabs are used,\n     * the returned array contains the inner tabs too, and this breaks the keyboard navigation.\n     */\n    return Array.from(this.children ?? []).filter((child) =>\n      /^sbb-tab$/u.test(child.localName),\n    ) as SbbTabElement[];\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('keydown', (e) => this._handleKeyDown(e));\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this.labels.forEach((tabLabel) => tabLabel['linkToTab']());\n    this._initSelection();\n\n    // To avoid animations on initialization, we have to mark the component as initialized and wait a tick.\n    Promise.resolve().then(() => this.internals.states.add('initialized'));\n    this._tabGroupResizeObserver.observe(this._tabGroupElement);\n  }\n\n  /**\n   * Disables a tab by index.\n   * @param index The index of the tab you want to disable.\n   */\n  public disableTab(index: number): void {\n    if (this.labels[index]) {\n      this.labels[index].disabled = true;\n    }\n  }\n\n  /**\n   * Enables a tab by index.\n   * @param index The index of the tab you want to enable.\n   */\n  public enableTab(index: number): void {\n    if (this.labels[index]) {\n      this.labels[index].disabled = false;\n    }\n  }\n\n  /**\n   * Activates a tab by index.\n   * @param index The index of the tab you want to activate.\n   */\n  public activateTab(index: number): void {\n    this.labels[index]?.activate();\n  }\n\n  private _enabledTabs(): SbbTabLabelElement[] {\n    return this.labels.filter((t) => {\n      customElements.upgrade(t);\n      return !t.disabled;\n    });\n  }\n\n  private _onContentSlotChange(): void {\n    if (this._contentSlotChangeDebounceId) {\n      clearTimeout(this._contentSlotChangeDebounceId);\n    }\n    this._contentSlotChangeDebounceId = setTimeout(() => {\n      this.labels.forEach((tabLabel) => tabLabel['linkToTab']());\n      this.labels.find((tabLabel) => tabLabel.active)?.activate();\n    }, 150);\n  }\n\n  private _onLabelSlotChange(): void {\n    this.labels.forEach((tabLabel) => tabLabel['linkToTab']());\n    this._ensureActiveTab();\n  }\n\n  private _ensureActiveTab(): void {\n    if (\n      this.internals.states.has('initialized') &&\n      !this.labels.some((tabLabel) => tabLabel.active)\n    ) {\n      this._initSelection();\n    }\n  }\n\n  private _initSelection(): void {\n    const selectedTabLabel = this.labels[this.initialSelectedIndex];\n    if (selectedTabLabel) {\n      customElements.upgrade(selectedTabLabel);\n      if (\n        this.initialSelectedIndex >= 0 &&\n        this.initialSelectedIndex < this.labels.length &&\n        !selectedTabLabel.disabled\n      ) {\n        selectedTabLabel.activate();\n        return;\n      }\n    }\n    this._enabledTabs()[0]?.activate();\n  }\n\n  private _onTabGroupElementResize(): void {\n    const tabLabels = this.labels;\n    tabLabels.forEach((tabLabel) => {\n      ɵstateController(tabLabel)?.toggle(\n        'has-divider',\n        tabLabel === tabLabels[0] || tabLabel.offsetLeft === tabLabels[0].offsetLeft,\n      );\n    });\n\n    this.style.setProperty('--sbb-tab-group-width', `${this._tabGroupElement.clientWidth}px`);\n  }\n\n  private _handleKeyDown(evt: KeyboardEvent): void {\n    const enabledTabs: SbbTabLabelElement[] = this._enabledTabs();\n\n    if (\n      !enabledTabs ||\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 current: number = enabledTabs.findIndex((t) => t.active);\n      const nextIndex: number = getNextElementIndex(evt, current, enabledTabs.length);\n      enabledTabs[nextIndex]?.activate();\n      enabledTabs[nextIndex]?.focus();\n      evt.preventDefault();\n    }\n  }\n\n  /**\n   * @internal\n   */\n  protected setTabContentHeight(contentHeight: number): void {\n    this.style.setProperty('--sbb-tab-content-height', `${contentHeight}px`);\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div\n        class=\"sbb-tab-group\"\n        role=\"tablist\"\n        ${ref((el?: Element) => (this._tabGroupElement = el as HTMLElement))}\n      >\n        <slot name=\"tab-bar\" @slotchange=${this._onLabelSlotChange}></slot>\n      </div>\n      ${!this.fixedHeight\n        ? html`\n            <div class=\"sbb-tab-group-content\">\n              <slot @slotchange=${this._onContentSlotChange}></slot>\n            </div>\n          `\n        : html`<slot @slotchange=${this._onContentSlotChange}></slot>`}\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-tab-group': SbbTabGroupElement;\n  }\n}\n"],"mappings":"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"}
@@ -24,6 +24,7 @@ export declare class SbbTabGroupElement extends SbbElement {
24
24
  };
25
25
  private _tabGroupElement;
26
26
  private _tabGroupResizeObserver;
27
+ private _contentSlotChangeDebounceId?;
27
28
  /**
28
29
  * Size variant, either s, l or xl.
29
30
  * @default 'l' / 's' (lean)
@@ -1 +1 @@
1
- {"version":3,"file":"tab-group.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/tabs/tab-group/tab-group.component.ts"],"names":[],"mappings":"AACA,OAAO,EAGL,KAAK,cAAc,EACnB,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAKb,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AAOzD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AAI9E,MAAM,WAAW,yBAAyB;IACxC,WAAW,EAAE,MAAM,CAAC;IACpB,cAAc,EAAE,kBAAkB,CAAC;IACnC,SAAS,EAAE,aAAa,CAAC;IACzB,aAAa,EAAE,MAAM,CAAC;IACtB,gBAAgB,EAAE,kBAAkB,GAAG,SAAS,CAAC;IACjD,WAAW,EAAE,aAAa,GAAG,SAAS,CAAC;CACxC;AAED;;;;;GAKG;AACH,qBAAa,kBAAmB,SAAQ,UAAU;IAChD,gBAAgC,WAAW,EAAE,MAAM,CAAmB;IACtE,OAAuB,MAAM,EAAE,cAAc,CAI3C;IACF,gBAAuB,MAAM;;MAElB;IAEX,OAAO,CAAC,gBAAgB,CAAe;IACvC,OAAO,CAAC,uBAAuB,CAI5B;IAEH;;;OAGG;IACH,SACgB,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAwB;IAE9D;;;OAGG;IACH,SAEgB,oBAAoB,EAAE,MAAM,CAAK;IAEjD;;;;OAIG;IACH,SAEgB,WAAW,EAAE,OAAO,CAAS;IAE7C,yCAAyC;IACzC,IAAW,MAAM,IAAI,kBAAkB,EAAE,CAQxC;IAED,mCAAmC;IACnC,IAAW,IAAI,IAAI,aAAa,EAAE,CAQjC;;cAOkB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAW9E;;;OAGG;IACI,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAMtC;;;OAGG;IACI,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAMrC;;;OAGG;IACI,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAIvC,OAAO,CAAC,YAAY;IAOpB,OAAO,CAAC,oBAAoB,CAG1B;IAEF,OAAO,CAAC,kBAAkB,CAGxB;IAEF,OAAO,CAAC,gBAAgB;IASxB,OAAO,CAAC,cAAc;IAgBtB,OAAO,CAAC,wBAAwB;IAYhC,OAAO,CAAC,cAAc;IAoBtB;;OAEG;IACH,SAAS,CAAC,mBAAmB,CAAC,aAAa,EAAE,MAAM,GAAG,IAAI;cAIvC,MAAM,IAAI,cAAc;CAkB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,eAAe,EAAE,kBAAkB,CAAC;KACrC;CACF"}
1
+ {"version":3,"file":"tab-group.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/tabs/tab-group/tab-group.component.ts"],"names":[],"mappings":"AACA,OAAO,EAGL,KAAK,cAAc,EACnB,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAKb,OAAO,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AAMzD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AAI9E,MAAM,WAAW,yBAAyB;IACxC,WAAW,EAAE,MAAM,CAAC;IACpB,cAAc,EAAE,kBAAkB,CAAC;IACnC,SAAS,EAAE,aAAa,CAAC;IACzB,aAAa,EAAE,MAAM,CAAC;IACtB,gBAAgB,EAAE,kBAAkB,GAAG,SAAS,CAAC;IACjD,WAAW,EAAE,aAAa,GAAG,SAAS,CAAC;CACxC;AAED;;;;;GAKG;AACH,qBAAa,kBAAmB,SAAQ,UAAU;IAChD,gBAAgC,WAAW,EAAE,MAAM,CAAmB;IACtE,OAAuB,MAAM,EAAE,cAAc,CAI3C;IACF,gBAAuB,MAAM;;MAElB;IAEX,OAAO,CAAC,gBAAgB,CAAe;IACvC,OAAO,CAAC,uBAAuB,CAI5B;IACH,OAAO,CAAC,4BAA4B,CAAC,CAAgC;IAErE;;;OAGG;IACH,SACgB,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAwB;IAE9D;;;OAGG;IACH,SAEgB,oBAAoB,EAAE,MAAM,CAAK;IAEjD;;;;OAIG;IACH,SAEgB,WAAW,EAAE,OAAO,CAAS;IAE7C,yCAAyC;IACzC,IAAW,MAAM,IAAI,kBAAkB,EAAE,CAQxC;IAED,mCAAmC;IACnC,IAAW,IAAI,IAAI,aAAa,EAAE,CAQjC;;cAOkB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAW9E;;;OAGG;IACI,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAMtC;;;OAGG;IACI,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAMrC;;;OAGG;IACI,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAIvC,OAAO,CAAC,YAAY;IAOpB,OAAO,CAAC,oBAAoB;IAU5B,OAAO,CAAC,kBAAkB;IAK1B,OAAO,CAAC,gBAAgB;IASxB,OAAO,CAAC,cAAc;IAgBtB,OAAO,CAAC,wBAAwB;IAYhC,OAAO,CAAC,cAAc;IAoBtB;;OAEG;IACH,SAAS,CAAC,mBAAmB,CAAC,aAAa,EAAE,MAAM,GAAG,IAAI;cAIvC,MAAM,IAAI,cAAc;CAkB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,eAAe,EAAE,kBAAkB,CAAC;KACrC;CACF"}
@@ -1,2 +1,2 @@
1
- import { t as SbbTabGroupElement } from "../../tab-group.component-DRipdAyc.js";
1
+ import { t as SbbTabGroupElement } from "../../tab-group.component-DldBA45K.js";
2
2
  export { SbbTabGroupElement };
@@ -1,4 +1,4 @@
1
- import { t as SbbTabGroupElement } from "../tab-group.component-DRipdAyc.js";
1
+ import { t as SbbTabGroupElement } from "../tab-group.component-DldBA45K.js";
2
2
  //#region src/elements/tabs/tab-group.ts
3
3
  /** @entrypoint */
4
4
  SbbTabGroupElement.define();
@@ -1,4 +1,4 @@
1
- import { t as SbbTabGroupElement } from "./tab-group.component-DRipdAyc.js";
1
+ import { t as SbbTabGroupElement } from "./tab-group.component-DldBA45K.js";
2
2
  import { t as SbbTabLabelElement } from "./tab-label.component-14j2eh4Z.js";
3
3
  import { t as SbbTabNavBarElement } from "./tab-nav-bar.component-CgYwCSVY.js";
4
4
  import { t as SbbTabElement } from "./tab.component-DThKG7-a.js";
@@ -1,4 +1,4 @@
1
- import { t as SbbTabGroupElement } from "./tab-group.component-DRipdAyc.js";
1
+ import { t as SbbTabGroupElement } from "./tab-group.component-DldBA45K.js";
2
2
  import { t as SbbTabLabelElement } from "./tab-label.component-14j2eh4Z.js";
3
3
  import { t as SbbTabNavBarElement } from "./tab-nav-bar.component-CgYwCSVY.js";
4
4
  import { t as SbbTabElement } from "./tab.component-DThKG7-a.js";
package/package.json CHANGED
@@ -1,12 +1,12 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements-dev",
3
- "version": "4.11.0-dev.1776266967",
3
+ "version": "4.11.0-dev.1776332009",
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/17d30200cfc27037d3c696060a70d82be42f57cb"
9
+ "https://github.com/sbb-design-systems/lyne-components/commit/b573cbffa3cab6ddee5eb6555ce548ba81e0d94b"
10
10
  ],
11
11
  "type": "module",
12
12
  "exports": {
@@ -4,27 +4,26 @@ import { property as i } from "lit/decorators.js";
4
4
  import { SbbElement as a } from "./core/base-elements.js";
5
5
  import { forceType as o } from "./core/decorators.js";
6
6
  import { isLean as s } from "./core/dom.js";
7
- import { throttle as c } from "./core/eventing.js";
8
- import { ɵstateController as l } from "./core/mixins.js";
9
- import { boxSizingStyles as u } from "./core/styles.js";
10
- import { ResizeController as d } from "@lit-labs/observers/resize-controller.js";
11
- import { ref as f } from "lit/directives/ref.js";
12
- import { getNextElementIndex as p, isArrowKeyPressed as m } from "./core/a11y.js";
13
- import { tabGroupCommonStyles as h } from "./tabs/common/styles.js";
7
+ import { ɵstateController as c } from "./core/mixins.js";
8
+ import { boxSizingStyles as l } from "./core/styles.js";
9
+ import { ResizeController as u } from "@lit-labs/observers/resize-controller.js";
10
+ import { ref as d } from "lit/directives/ref.js";
11
+ import { getNextElementIndex as f, isArrowKeyPressed as p } from "./core/a11y.js";
12
+ import { tabGroupCommonStyles as m } from "./tabs/common/styles.js";
14
13
  //#region src/elements/tabs/tab-group/tab-group.scss?inline
15
- var g = ":host{--sbb-tab-group-animation-duration: 0s;gap:var(--sbb-tab-group-content-gap)}:host(:is(:state(initialized),[state--initialized])){--sbb-tab-group-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-4x) )}.sbb-tab-group-content{height:var(--sbb-tab-content-height);transition:height var(--sbb-tab-group-animation-duration) var(--sbb-animation-easing)}:host([fixed-height]) ::slotted(sbb-tab){height:100%;overflow:auto}", _ = (() => {
16
- let _ = a, v, y = [], b = [], x, S = [], C = [], w, T = [], E = [];
17
- return class extends _ {
14
+ var h = ":host{--sbb-tab-group-animation-duration: 0s;gap:var(--sbb-tab-group-content-gap)}:host(:is(:state(initialized),[state--initialized])){--sbb-tab-group-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-4x) )}.sbb-tab-group-content{height:var(--sbb-tab-content-height);transition:height var(--sbb-tab-group-animation-duration) var(--sbb-animation-easing)}:host([fixed-height]) ::slotted(sbb-tab){height:100%;overflow:auto}", g = (() => {
15
+ let g = a, _, v = [], y = [], b, x = [], S = [], C, w = [], T = [];
16
+ return class extends g {
18
17
  static {
19
- let t = typeof Symbol == "function" && Symbol.metadata ? Object.create(_[Symbol.metadata] ?? null) : void 0;
20
- v = [i()], x = [o(), i({
18
+ let t = typeof Symbol == "function" && Symbol.metadata ? Object.create(g[Symbol.metadata] ?? null) : void 0;
19
+ _ = [i()], b = [o(), i({
21
20
  attribute: "initial-selected-index",
22
21
  type: Number
23
- })], w = [o(), i({
22
+ })], C = [o(), i({
24
23
  attribute: "fixed-height",
25
24
  type: Boolean,
26
25
  reflect: !0
27
- })], e(this, null, v, {
26
+ })], e(this, null, _, {
28
27
  kind: "accessor",
29
28
  name: "size",
30
29
  static: !1,
@@ -37,7 +36,7 @@ var g = ":host{--sbb-tab-group-animation-duration: 0s;gap:var(--sbb-tab-group-co
37
36
  }
38
37
  },
39
38
  metadata: t
40
- }, y, b), e(this, null, x, {
39
+ }, v, y), e(this, null, b, {
41
40
  kind: "accessor",
42
41
  name: "initialSelectedIndex",
43
42
  static: !1,
@@ -50,7 +49,7 @@ var g = ":host{--sbb-tab-group-animation-duration: 0s;gap:var(--sbb-tab-group-co
50
49
  }
51
50
  },
52
51
  metadata: t
53
- }, S, C), e(this, null, w, {
52
+ }, x, S), e(this, null, C, {
54
53
  kind: "accessor",
55
54
  name: "fixedHeight",
56
55
  static: !1,
@@ -63,7 +62,7 @@ var g = ":host{--sbb-tab-group-animation-duration: 0s;gap:var(--sbb-tab-group-co
63
62
  }
64
63
  },
65
64
  metadata: t
66
- }, T, E), t && Object.defineProperty(this, Symbol.metadata, {
65
+ }, w, T), t && Object.defineProperty(this, Symbol.metadata, {
67
66
  enumerable: !0,
68
67
  configurable: !0,
69
68
  writable: !0,
@@ -75,9 +74,9 @@ var g = ":host{--sbb-tab-group-animation-duration: 0s;gap:var(--sbb-tab-group-co
75
74
  }
76
75
  static {
77
76
  this.styles = [
78
- u,
79
- h,
80
- r(g)
77
+ l,
78
+ m,
79
+ r(h)
81
80
  ];
82
81
  }
83
82
  static {
@@ -111,15 +110,11 @@ var g = ":host{--sbb-tab-group-animation-duration: 0s;gap:var(--sbb-tab-group-co
111
110
  return Array.from(this.children ?? []).filter((e) => /^sbb-tab$/u.test(e.localName));
112
111
  }
113
112
  constructor() {
114
- super(), this._tabGroupResizeObserver = new d(this, {
113
+ super(), this._tabGroupResizeObserver = new u(this, {
115
114
  target: null,
116
115
  skipInitial: !0,
117
116
  callback: () => this._onTabGroupElementResize()
118
- }), this.#e = t(this, y, s() ? "s" : "l"), this.#t = (t(this, b), t(this, S, 0)), this.#n = (t(this, C), t(this, T, !1)), this._onContentSlotChange = (t(this, E), () => {
119
- this.labels.forEach((e) => e.linkToTab()), this.labels.find((e) => e.active)?.activate();
120
- }), this._onLabelSlotChange = () => {
121
- this.labels.forEach((e) => e.linkToTab()), this._ensureActiveTab();
122
- }, this.addEventListener?.("keydown", (e) => this._handleKeyDown(e));
117
+ }), this.#e = t(this, v, s() ? "s" : "l"), this.#t = (t(this, y), t(this, x, 0)), this.#n = (t(this, S), t(this, w, !1)), t(this, T), this.addEventListener?.("keydown", (e) => this._handleKeyDown(e));
123
118
  }
124
119
  firstUpdated(e) {
125
120
  super.firstUpdated(e), this.labels.forEach((e) => e.linkToTab()), this._initSelection(), Promise.resolve().then(() => this.internals.states.add("initialized")), this._tabGroupResizeObserver.observe(this._tabGroupElement);
@@ -136,6 +131,14 @@ var g = ":host{--sbb-tab-group-animation-duration: 0s;gap:var(--sbb-tab-group-co
136
131
  _enabledTabs() {
137
132
  return this.labels.filter((e) => (customElements.upgrade(e), !e.disabled));
138
133
  }
134
+ _onContentSlotChange() {
135
+ this._contentSlotChangeDebounceId && clearTimeout(this._contentSlotChangeDebounceId), this._contentSlotChangeDebounceId = setTimeout(() => {
136
+ this.labels.forEach((e) => e.linkToTab()), this.labels.find((e) => e.active)?.activate();
137
+ }, 150);
138
+ }
139
+ _onLabelSlotChange() {
140
+ this.labels.forEach((e) => e.linkToTab()), this._ensureActiveTab();
141
+ }
139
142
  _ensureActiveTab() {
140
143
  this.internals.states.has("initialized") && !this.labels.some((e) => e.active) && this._initSelection();
141
144
  }
@@ -150,13 +153,13 @@ var g = ":host{--sbb-tab-group-animation-duration: 0s;gap:var(--sbb-tab-group-co
150
153
  _onTabGroupElementResize() {
151
154
  let e = this.labels;
152
155
  e.forEach((t) => {
153
- l(t)?.toggle("has-divider", t === e[0] || t.offsetLeft === e[0].offsetLeft);
156
+ c(t)?.toggle("has-divider", t === e[0] || t.offsetLeft === e[0].offsetLeft);
154
157
  }), this.style.setProperty("--sbb-tab-group-width", `${this._tabGroupElement.clientWidth}px`);
155
158
  }
156
159
  _handleKeyDown(e) {
157
160
  let t = this._enabledTabs();
158
- if (!(!t || e.target !== this && e.target.parentElement !== this) && m(e)) {
159
- let n = p(e, t.findIndex((e) => e.active), t.length);
161
+ if (!(!t || e.target !== this && e.target.parentElement !== this) && p(e)) {
162
+ let n = f(e, t.findIndex((e) => e.active), t.length);
160
163
  t[n]?.activate(), t[n]?.focus(), e.preventDefault();
161
164
  }
162
165
  }
@@ -168,13 +171,13 @@ var g = ":host{--sbb-tab-group-animation-duration: 0s;gap:var(--sbb-tab-group-co
168
171
  <div
169
172
  class="sbb-tab-group"
170
173
  role="tablist"
171
- ${f((e) => this._tabGroupElement = e)}
174
+ ${d((e) => this._tabGroupElement = e)}
172
175
  >
173
176
  <slot name="tab-bar" @slotchange=${this._onLabelSlotChange}></slot>
174
177
  </div>
175
- ${this.fixedHeight ? n`<slot @slotchange=${c(this._onContentSlotChange, 150)}></slot>` : n`
178
+ ${this.fixedHeight ? n`<slot @slotchange=${this._onContentSlotChange}></slot>` : n`
176
179
  <div class="sbb-tab-group-content">
177
- <slot @slotchange=${c(this._onContentSlotChange, 150)}></slot>
180
+ <slot @slotchange=${this._onContentSlotChange}></slot>
178
181
  </div>
179
182
  `}
180
183
  `;
@@ -182,4 +185,4 @@ var g = ":host{--sbb-tab-group-animation-duration: 0s;gap:var(--sbb-tab-group-co
182
185
  };
183
186
  })();
184
187
  //#endregion
185
- export { _ as t };
188
+ export { g as t };
@@ -1,2 +1,2 @@
1
- import { t as e } from "../../tab-group.component-Doy39cEh.js";
1
+ import { t as e } from "../../tab-group.component-CHQlrhUy.js";
2
2
  export { e as SbbTabGroupElement };
package/tabs/tab-group.js CHANGED
@@ -1,4 +1,4 @@
1
- import { t as e } from "../tab-group.component-Doy39cEh.js";
1
+ import { t as e } from "../tab-group.component-CHQlrhUy.js";
2
2
  e.define(), console.warn("The entrypoint '@sbb-esta/elements/tabs/tab-group.js' has been deprecated.\nUse either '@sbb-esta/elements/tabs.js' or '@sbb-esta/elements/tabs.pure.js' instead.");
3
3
  //#endregion
4
4
  export { e as SbbTabGroupElement };
package/tabs.js CHANGED
@@ -1,4 +1,4 @@
1
- import { t as e } from "./tab-group.component-Doy39cEh.js";
1
+ import { t as e } from "./tab-group.component-CHQlrhUy.js";
2
2
  import { t } from "./tab-label.component-CD56RH1Z.js";
3
3
  import { t as n } from "./tab-nav-bar.component-7mG-Dk6g.js";
4
4
  import { t as r } from "./tab.component-rEJAbgtn.js";
package/tabs.pure.js CHANGED
@@ -1,4 +1,4 @@
1
- import { t as e } from "./tab-group.component-Doy39cEh.js";
1
+ import { t as e } from "./tab-group.component-CHQlrhUy.js";
2
2
  import { t } from "./tab-label.component-CD56RH1Z.js";
3
3
  import { t as n } from "./tab-nav-bar.component-7mG-Dk6g.js";
4
4
  import { t as r } from "./tab.component-rEJAbgtn.js";
@@ -1,272 +0,0 @@
1
- import { __esDecorate, __runInitializers } from "tslib";
2
- import { html, unsafeCSS } from "lit";
3
- import { property } from "lit/decorators.js";
4
- import { SbbElement } from "./core/base-elements.js";
5
- import { forceType } from "./core/decorators.js";
6
- import { isLean } from "./core/dom.js";
7
- import { throttle } from "./core/eventing.js";
8
- import { ɵstateController } from "./core/mixins.js";
9
- import { boxSizingStyles } from "./core/styles.js";
10
- import { ResizeController } from "@lit-labs/observers/resize-controller.js";
11
- import { ref } from "lit/directives/ref.js";
12
- import { getNextElementIndex, isArrowKeyPressed } from "./core/a11y.js";
13
- import { tabGroupCommonStyles } from "./tabs/common/styles.js";
14
- //#region src/elements/tabs/tab-group/tab-group.scss?inline
15
- var tab_group_default = ":host {\n --sbb-tab-group-animation-duration: 0s;\n gap: var(--sbb-tab-group-content-gap);\n}\n\n:host(:is(:state(initialized),[state--initialized])) {\n --sbb-tab-group-animation-duration: var(\n --sbb-disable-animation-duration,\n var(--sbb-animation-duration-4x)\n );\n}\n\n.sbb-tab-group-content {\n height: var(--sbb-tab-content-height);\n transition: height var(--sbb-tab-group-animation-duration) var(--sbb-animation-easing);\n}\n\n:host([fixed-height]) ::slotted(sbb-tab) {\n height: 100%;\n overflow: auto;\n}";
16
- //#endregion
17
- //#region src/elements/tabs/tab-group/tab-group.component.ts
18
- /**
19
- * It displays one or more tabs, each one with a label and some content.
20
- *
21
- * @slot - Use the unnamed slot to add content to the `sbb-tab-group` via `sbb-tab-label` and `sbb-tab` instances.
22
- * @event {CustomEvent<SbbTabChangedEventDetails>} tabchange - The tabchange event is dispatched when a tab is selected.
23
- */
24
- var SbbTabGroupElement = (() => {
25
- let _classSuper = SbbElement;
26
- let _size_decorators;
27
- let _size_initializers = [];
28
- let _size_extraInitializers = [];
29
- let _initialSelectedIndex_decorators;
30
- let _initialSelectedIndex_initializers = [];
31
- let _initialSelectedIndex_extraInitializers = [];
32
- let _fixedHeight_decorators;
33
- let _fixedHeight_initializers = [];
34
- let _fixedHeight_extraInitializers = [];
35
- return class SbbTabGroupElement extends _classSuper {
36
- static {
37
- const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
38
- _size_decorators = [property()];
39
- _initialSelectedIndex_decorators = [forceType(), property({
40
- attribute: "initial-selected-index",
41
- type: Number
42
- })];
43
- _fixedHeight_decorators = [forceType(), property({
44
- attribute: "fixed-height",
45
- type: Boolean,
46
- reflect: true
47
- })];
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, _initialSelectedIndex_decorators, {
63
- kind: "accessor",
64
- name: "initialSelectedIndex",
65
- static: false,
66
- private: false,
67
- access: {
68
- has: (obj) => "initialSelectedIndex" in obj,
69
- get: (obj) => obj.initialSelectedIndex,
70
- set: (obj, value) => {
71
- obj.initialSelectedIndex = value;
72
- }
73
- },
74
- metadata: _metadata
75
- }, _initialSelectedIndex_initializers, _initialSelectedIndex_extraInitializers);
76
- __esDecorate(this, null, _fixedHeight_decorators, {
77
- kind: "accessor",
78
- name: "fixedHeight",
79
- static: false,
80
- private: false,
81
- access: {
82
- has: (obj) => "fixedHeight" in obj,
83
- get: (obj) => obj.fixedHeight,
84
- set: (obj, value) => {
85
- obj.fixedHeight = value;
86
- }
87
- },
88
- metadata: _metadata
89
- }, _fixedHeight_initializers, _fixedHeight_extraInitializers);
90
- if (_metadata) Object.defineProperty(this, Symbol.metadata, {
91
- enumerable: true,
92
- configurable: true,
93
- writable: true,
94
- value: _metadata
95
- });
96
- }
97
- static {
98
- this.elementName = "sbb-tab-group";
99
- }
100
- static {
101
- this.styles = [
102
- boxSizingStyles,
103
- tabGroupCommonStyles,
104
- unsafeCSS(tab_group_default)
105
- ];
106
- }
107
- static {
108
- this.events = { tabchange: "tabchange" };
109
- }
110
- #size_accessor_storage;
111
- /**
112
- * Size variant, either s, l or xl.
113
- * @default 'l' / 's' (lean)
114
- */
115
- get size() {
116
- return this.#size_accessor_storage;
117
- }
118
- set size(value) {
119
- this.#size_accessor_storage = value;
120
- }
121
- #initialSelectedIndex_accessor_storage;
122
- /**
123
- * Sets the initial tab. If it matches a disabled tab or exceeds the length of
124
- * the tab group, the first enabled tab will be selected.
125
- */
126
- get initialSelectedIndex() {
127
- return this.#initialSelectedIndex_accessor_storage;
128
- }
129
- set initialSelectedIndex(value) {
130
- this.#initialSelectedIndex_accessor_storage = value;
131
- }
132
- #fixedHeight_accessor_storage;
133
- /**
134
- * If set to true, the `sbb-tab` elements take 100% height of the `sbb-tab-group`.
135
- * It enables controlling the height on the `sbb-tab-group` element.
136
- * The content becomes scrollable on overflow.
137
- */
138
- get fixedHeight() {
139
- return this.#fixedHeight_accessor_storage;
140
- }
141
- set fixedHeight(value) {
142
- this.#fixedHeight_accessor_storage = value;
143
- }
144
- /** Gets the slotted `sbb-tab-label`s. */
145
- get labels() {
146
- /**
147
- * The querySelector API is not used because when nested tabs are used,
148
- * the returned array contains the inner tabs too, and this breaks the keyboard navigation.
149
- */
150
- return Array.from(this.children ?? []).filter((child) => /^sbb-tab-label$/u.test(child.localName));
151
- }
152
- /** Gets the slotted `sbb-tab`s. */
153
- get tabs() {
154
- /**
155
- * The querySelector API is not used because when nested tabs are used,
156
- * the returned array contains the inner tabs too, and this breaks the keyboard navigation.
157
- */
158
- return Array.from(this.children ?? []).filter((child) => /^sbb-tab$/u.test(child.localName));
159
- }
160
- constructor() {
161
- super();
162
- this._tabGroupResizeObserver = new ResizeController(this, {
163
- target: null,
164
- skipInitial: true,
165
- callback: () => this._onTabGroupElementResize()
166
- });
167
- this.#size_accessor_storage = __runInitializers(this, _size_initializers, isLean() ? "s" : "l");
168
- this.#initialSelectedIndex_accessor_storage = (__runInitializers(this, _size_extraInitializers), __runInitializers(this, _initialSelectedIndex_initializers, 0));
169
- this.#fixedHeight_accessor_storage = (__runInitializers(this, _initialSelectedIndex_extraInitializers), __runInitializers(this, _fixedHeight_initializers, false));
170
- this._onContentSlotChange = (__runInitializers(this, _fixedHeight_extraInitializers), () => {
171
- this.labels.forEach((tabLabel) => tabLabel["linkToTab"]());
172
- this.labels.find((tabLabel) => tabLabel.active)?.activate();
173
- });
174
- this._onLabelSlotChange = () => {
175
- this.labels.forEach((tabLabel) => tabLabel["linkToTab"]());
176
- this._ensureActiveTab();
177
- };
178
- this.addEventListener?.("keydown", (e) => this._handleKeyDown(e));
179
- }
180
- firstUpdated(changedProperties) {
181
- super.firstUpdated(changedProperties);
182
- this.labels.forEach((tabLabel) => tabLabel["linkToTab"]());
183
- this._initSelection();
184
- Promise.resolve().then(() => this.internals.states.add("initialized"));
185
- this._tabGroupResizeObserver.observe(this._tabGroupElement);
186
- }
187
- /**
188
- * Disables a tab by index.
189
- * @param index The index of the tab you want to disable.
190
- */
191
- disableTab(index) {
192
- if (this.labels[index]) this.labels[index].disabled = true;
193
- }
194
- /**
195
- * Enables a tab by index.
196
- * @param index The index of the tab you want to enable.
197
- */
198
- enableTab(index) {
199
- if (this.labels[index]) this.labels[index].disabled = false;
200
- }
201
- /**
202
- * Activates a tab by index.
203
- * @param index The index of the tab you want to activate.
204
- */
205
- activateTab(index) {
206
- this.labels[index]?.activate();
207
- }
208
- _enabledTabs() {
209
- return this.labels.filter((t) => {
210
- customElements.upgrade(t);
211
- return !t.disabled;
212
- });
213
- }
214
- _ensureActiveTab() {
215
- if (this.internals.states.has("initialized") && !this.labels.some((tabLabel) => tabLabel.active)) this._initSelection();
216
- }
217
- _initSelection() {
218
- const selectedTabLabel = this.labels[this.initialSelectedIndex];
219
- if (selectedTabLabel) {
220
- customElements.upgrade(selectedTabLabel);
221
- if (this.initialSelectedIndex >= 0 && this.initialSelectedIndex < this.labels.length && !selectedTabLabel.disabled) {
222
- selectedTabLabel.activate();
223
- return;
224
- }
225
- }
226
- this._enabledTabs()[0]?.activate();
227
- }
228
- _onTabGroupElementResize() {
229
- const tabLabels = this.labels;
230
- tabLabels.forEach((tabLabel) => {
231
- ɵstateController(tabLabel)?.toggle("has-divider", tabLabel === tabLabels[0] || tabLabel.offsetLeft === tabLabels[0].offsetLeft);
232
- });
233
- this.style.setProperty("--sbb-tab-group-width", `${this._tabGroupElement.clientWidth}px`);
234
- }
235
- _handleKeyDown(evt) {
236
- const enabledTabs = this._enabledTabs();
237
- if (!enabledTabs || evt.target !== this && evt.target.parentElement !== this) return;
238
- if (isArrowKeyPressed(evt)) {
239
- const nextIndex = getNextElementIndex(evt, enabledTabs.findIndex((t) => t.active), enabledTabs.length);
240
- enabledTabs[nextIndex]?.activate();
241
- enabledTabs[nextIndex]?.focus();
242
- evt.preventDefault();
243
- }
244
- }
245
- /**
246
- * @internal
247
- */
248
- setTabContentHeight(contentHeight) {
249
- this.style.setProperty("--sbb-tab-content-height", `${contentHeight}px`);
250
- }
251
- render() {
252
- return html`
253
- <div
254
- class="sbb-tab-group"
255
- role="tablist"
256
- ${ref((el) => this._tabGroupElement = el)}
257
- >
258
- <slot name="tab-bar" @slotchange=${this._onLabelSlotChange}></slot>
259
- </div>
260
- ${!this.fixedHeight ? html`
261
- <div class="sbb-tab-group-content">
262
- <slot @slotchange=${throttle(this._onContentSlotChange, 150)}></slot>
263
- </div>
264
- ` : html`<slot @slotchange=${throttle(this._onContentSlotChange, 150)}></slot>`}
265
- `;
266
- }
267
- };
268
- })();
269
- //#endregion
270
- export { SbbTabGroupElement as t };
271
-
272
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"tab-group.component-DRipdAyc.js","names":[],"sources":["../../../src/elements/tabs/tab-group/tab-group.scss?inline","../../../src/elements/tabs/tab-group/tab-group.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-tab-group-animation-duration: 0s;\n\n  gap: var(--sbb-tab-group-content-gap);\n}\n\n:host(:state(initialized)) {\n  --sbb-tab-group-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-4x)\n  );\n}\n\n.sbb-tab-group-content {\n  height: var(--sbb-tab-content-height);\n  transition: height var(--sbb-tab-group-animation-duration) var(--sbb-animation-easing);\n}\n\n::slotted(sbb-tab) {\n  :host([fixed-height]) & {\n    height: 100%;\n    overflow: auto;\n  }\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';\nimport { ref } from 'lit/directives/ref.js';\n\nimport { getNextElementIndex, isArrowKeyPressed } from '../../core/a11y.ts';\nimport { SbbElement } from '../../core/base-elements.ts';\nimport { forceType } from '../../core/decorators.ts';\nimport { isLean } from '../../core/dom.ts';\nimport { throttle } from '../../core/eventing.ts';\nimport { ɵstateController } from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport { tabGroupCommonStyles } from '../common/styles.ts';\nimport type { SbbTabElement } from '../tab/tab.component.ts';\nimport type { SbbTabLabelElement } from '../tab-label/tab-label.component.ts';\n\nimport style from './tab-group.scss?inline';\n\nexport interface SbbTabChangedEventDetails {\n  activeIndex: number;\n  activeTabLabel: SbbTabLabelElement;\n  activeTab: SbbTabElement;\n  previousIndex: number;\n  previousTabLabel: SbbTabLabelElement | undefined;\n  previousTab: SbbTabElement | undefined;\n}\n\n/**\n * It displays one or more tabs, each one with a label and some content.\n *\n * @slot - Use the unnamed slot to add content to the `sbb-tab-group` via `sbb-tab-label` and `sbb-tab` instances.\n * @event {CustomEvent<SbbTabChangedEventDetails>} tabchange - The tabchange event is dispatched when a tab is selected.\n */\nexport class SbbTabGroupElement extends SbbElement {\n  public static override readonly elementName: string = 'sbb-tab-group';\n  public static override styles: CSSResultGroup = [\n    boxSizingStyles,\n    tabGroupCommonStyles,\n    unsafeCSS(style),\n  ];\n  public static readonly events = {\n    tabchange: 'tabchange',\n  } as const;\n\n  private _tabGroupElement!: HTMLElement;\n  private _tabGroupResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: () => this._onTabGroupElementResize(),\n  });\n\n  /**\n   * Size variant, either s, l or xl.\n   * @default 'l' / 's' (lean)\n   */\n  @property()\n  public accessor size: 's' | 'l' | 'xl' = isLean() ? 's' : 'l';\n\n  /**\n   * Sets the initial tab. If it matches a disabled tab or exceeds the length of\n   * the tab group, the first enabled tab will be selected.\n   */\n  @forceType()\n  @property({ attribute: 'initial-selected-index', type: Number })\n  public accessor initialSelectedIndex: number = 0;\n\n  /**\n   * If set to true, the `sbb-tab` elements take 100% height of the `sbb-tab-group`.\n   * It enables controlling the height on the `sbb-tab-group` element.\n   * The content becomes scrollable on overflow.\n   */\n  @forceType()\n  @property({ attribute: 'fixed-height', type: Boolean, reflect: true })\n  public accessor fixedHeight: boolean = false;\n\n  /** Gets the slotted `sbb-tab-label`s. */\n  public get labels(): SbbTabLabelElement[] {\n    /**\n     * The querySelector API is not used because when nested tabs are used,\n     * the returned array contains the inner tabs too, and this breaks the keyboard navigation.\n     */\n    return Array.from(this.children ?? []).filter((child) =>\n      /^sbb-tab-label$/u.test(child.localName),\n    ) as SbbTabLabelElement[];\n  }\n\n  /** Gets the slotted `sbb-tab`s. */\n  public get tabs(): SbbTabElement[] {\n    /**\n     * The querySelector API is not used because when nested tabs are used,\n     * the returned array contains the inner tabs too, and this breaks the keyboard navigation.\n     */\n    return Array.from(this.children ?? []).filter((child) =>\n      /^sbb-tab$/u.test(child.localName),\n    ) as SbbTabElement[];\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('keydown', (e) => this._handleKeyDown(e));\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this.labels.forEach((tabLabel) => tabLabel['linkToTab']());\n    this._initSelection();\n\n    // To avoid animations on initialization, we have to mark the component as initialized and wait a tick.\n    Promise.resolve().then(() => this.internals.states.add('initialized'));\n    this._tabGroupResizeObserver.observe(this._tabGroupElement);\n  }\n\n  /**\n   * Disables a tab by index.\n   * @param index The index of the tab you want to disable.\n   */\n  public disableTab(index: number): void {\n    if (this.labels[index]) {\n      this.labels[index].disabled = true;\n    }\n  }\n\n  /**\n   * Enables a tab by index.\n   * @param index The index of the tab you want to enable.\n   */\n  public enableTab(index: number): void {\n    if (this.labels[index]) {\n      this.labels[index].disabled = false;\n    }\n  }\n\n  /**\n   * Activates a tab by index.\n   * @param index The index of the tab you want to activate.\n   */\n  public activateTab(index: number): void {\n    this.labels[index]?.activate();\n  }\n\n  private _enabledTabs(): SbbTabLabelElement[] {\n    return this.labels.filter((t) => {\n      customElements.upgrade(t);\n      return !t.disabled;\n    });\n  }\n\n  private _onContentSlotChange = (): void => {\n    this.labels.forEach((tabLabel) => tabLabel['linkToTab']());\n    this.labels.find((tabLabel) => tabLabel.active)?.activate();\n  };\n\n  private _onLabelSlotChange = (): void => {\n    this.labels.forEach((tabLabel) => tabLabel['linkToTab']());\n    this._ensureActiveTab();\n  };\n\n  private _ensureActiveTab(): void {\n    if (\n      this.internals.states.has('initialized') &&\n      !this.labels.some((tabLabel) => tabLabel.active)\n    ) {\n      this._initSelection();\n    }\n  }\n\n  private _initSelection(): void {\n    const selectedTabLabel = this.labels[this.initialSelectedIndex];\n    if (selectedTabLabel) {\n      customElements.upgrade(selectedTabLabel);\n      if (\n        this.initialSelectedIndex >= 0 &&\n        this.initialSelectedIndex < this.labels.length &&\n        !selectedTabLabel.disabled\n      ) {\n        selectedTabLabel.activate();\n        return;\n      }\n    }\n    this._enabledTabs()[0]?.activate();\n  }\n\n  private _onTabGroupElementResize(): void {\n    const tabLabels = this.labels;\n    tabLabels.forEach((tabLabel) => {\n      ɵstateController(tabLabel)?.toggle(\n        'has-divider',\n        tabLabel === tabLabels[0] || tabLabel.offsetLeft === tabLabels[0].offsetLeft,\n      );\n    });\n\n    this.style.setProperty('--sbb-tab-group-width', `${this._tabGroupElement.clientWidth}px`);\n  }\n\n  private _handleKeyDown(evt: KeyboardEvent): void {\n    const enabledTabs: SbbTabLabelElement[] = this._enabledTabs();\n\n    if (\n      !enabledTabs ||\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 current: number = enabledTabs.findIndex((t) => t.active);\n      const nextIndex: number = getNextElementIndex(evt, current, enabledTabs.length);\n      enabledTabs[nextIndex]?.activate();\n      enabledTabs[nextIndex]?.focus();\n      evt.preventDefault();\n    }\n  }\n\n  /**\n   * @internal\n   */\n  protected setTabContentHeight(contentHeight: number): void {\n    this.style.setProperty('--sbb-tab-content-height', `${contentHeight}px`);\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div\n        class=\"sbb-tab-group\"\n        role=\"tablist\"\n        ${ref((el?: Element) => (this._tabGroupElement = el as HTMLElement))}\n      >\n        <slot name=\"tab-bar\" @slotchange=${this._onLabelSlotChange}></slot>\n      </div>\n      ${!this.fixedHeight\n        ? html`\n            <div class=\"sbb-tab-group-content\">\n              <slot @slotchange=${throttle(this._onContentSlotChange, 150)}></slot>\n            </div>\n          `\n        : html`<slot @slotchange=${throttle(this._onContentSlotChange, 150)}></slot>`}\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-tab-group': SbbTabGroupElement;\n  }\n}\n"],"mappings":"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"}