@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.
- package/custom-elements.json +24 -5
- package/development/core/eventing/throttle.d.ts +1 -0
- package/development/core/eventing/throttle.d.ts.map +1 -1
- package/development/core/eventing/throttle.js +2 -1
- package/development/tab-group.component-DldBA45K.js +275 -0
- package/development/tabs/tab-group/tab-group.component.d.ts +1 -0
- package/development/tabs/tab-group/tab-group.component.d.ts.map +1 -1
- package/development/tabs/tab-group/tab-group.component.js +1 -1
- package/development/tabs/tab-group.js +1 -1
- package/development/tabs.js +1 -1
- package/development/tabs.pure.js +1 -1
- package/package.json +2 -2
- package/{tab-group.component-Doy39cEh.js → tab-group.component-CHQlrhUy.js} +36 -33
- package/tabs/tab-group/tab-group.component.js +1 -1
- package/tabs/tab-group.js +1 -1
- package/tabs.js +1 -1
- package/tabs.pure.js +1 -1
- package/development/tab-group.component-DRipdAyc.js +0 -272
package/custom-elements.json
CHANGED
|
@@ -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": "
|
|
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": "
|
|
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 +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,
|
|
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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"}
|
|
@@ -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;
|
|
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-
|
|
1
|
+
import { t as SbbTabGroupElement } from "../../tab-group.component-DldBA45K.js";
|
|
2
2
|
export { SbbTabGroupElement };
|
package/development/tabs.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { t as SbbTabGroupElement } from "./tab-group.component-
|
|
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/development/tabs.pure.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { t as SbbTabGroupElement } from "./tab-group.component-
|
|
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.
|
|
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/
|
|
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 {
|
|
8
|
-
import {
|
|
9
|
-
import {
|
|
10
|
-
import {
|
|
11
|
-
import {
|
|
12
|
-
import {
|
|
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
|
|
16
|
-
let
|
|
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(
|
|
20
|
-
|
|
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
|
-
})],
|
|
22
|
+
})], C = [o(), i({
|
|
24
23
|
attribute: "fixed-height",
|
|
25
24
|
type: Boolean,
|
|
26
25
|
reflect: !0
|
|
27
|
-
})], e(this, null,
|
|
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
|
-
},
|
|
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
|
-
},
|
|
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
|
-
},
|
|
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
|
-
|
|
79
|
-
|
|
80
|
-
r(
|
|
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
|
|
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,
|
|
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
|
-
|
|
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) &&
|
|
159
|
-
let n =
|
|
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
|
-
${
|
|
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=${
|
|
178
|
+
${this.fixedHeight ? n`<slot @slotchange=${this._onContentSlotChange}></slot>` : n`
|
|
176
179
|
<div class="sbb-tab-group-content">
|
|
177
|
-
<slot @slotchange=${
|
|
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 {
|
|
188
|
+
export { g as t };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as e } from "../../tab-group.component-
|
|
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-
|
|
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-
|
|
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-
|
|
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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"}
|