@sbb-esta/lyne-elements 3.8.0 → 3.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/core/base-elements/open-close-base-element.d.ts +2 -0
- package/core/base-elements/open-close-base-element.d.ts.map +1 -1
- package/core/base-elements/open-close-base-element.js +4 -0
- package/core/controllers/escapable-overlay-controller.js +3 -3
- package/core/controllers/inert-controller.d.ts +8 -1
- package/core/controllers/inert-controller.d.ts.map +1 -1
- package/core/controllers/inert-controller.js +25 -13
- package/core/overlay/position.d.ts +20 -0
- package/core/overlay/position.d.ts.map +1 -1
- package/core/overlay/position.js +34 -23
- package/core/overlay.js +11 -10
- package/core/styles/core.scss +7 -0
- package/core.css +6 -0
- package/custom-elements.json +612 -138
- package/development/core/base-elements/open-close-base-element.d.ts +2 -0
- package/development/core/base-elements/open-close-base-element.d.ts.map +1 -1
- package/development/core/base-elements/open-close-base-element.js +5 -1
- package/development/core/controllers/escapable-overlay-controller.js +2 -2
- package/development/core/controllers/inert-controller.d.ts +8 -1
- package/development/core/controllers/inert-controller.d.ts.map +1 -1
- package/development/core/controllers/inert-controller.js +49 -30
- package/development/core/overlay/position.d.ts +20 -0
- package/development/core/overlay/position.d.ts.map +1 -1
- package/development/core/overlay/position.js +41 -1
- package/development/core/overlay.js +2 -1
- package/development/menu/common/menu-action-common.d.ts.map +1 -1
- package/development/menu/common/menu-action-common.js +20 -3
- package/development/menu/menu/menu.component.d.ts +21 -10
- package/development/menu/menu/menu.component.d.ts.map +1 -1
- package/development/menu/menu/menu.component.js +203 -61
- package/development/option/option/option.component.js +4 -2
- package/development/tabs/tab/tab.component.d.ts +10 -4
- package/development/tabs/tab/tab.component.d.ts.map +1 -1
- package/development/tabs/tab/tab.component.js +15 -16
- package/development/tabs/tab-group/tab-group.component.d.ts +15 -14
- package/development/tabs/tab-group/tab-group.component.d.ts.map +1 -1
- package/development/tabs/tab-group/tab-group.component.js +46 -175
- package/development/tabs/tab-label/tab-label.component.d.ts +21 -2
- package/development/tabs/tab-label/tab-label.component.d.ts.map +1 -1
- package/development/tabs/tab-label/tab-label.component.js +91 -6
- package/development/tooltip/tooltip.component.d.ts +6 -6
- package/development/tooltip/tooltip.component.d.ts.map +1 -1
- package/development/tooltip/tooltip.component.js +14 -7
- package/menu/common/menu-action-common.d.ts.map +1 -1
- package/menu/common/menu-action-common.js +15 -12
- package/menu/menu/menu.component.d.ts +21 -10
- package/menu/menu/menu.component.d.ts.map +1 -1
- package/menu/menu/menu.component.js +144 -80
- package/off-brand-theme.css +6 -0
- package/option/option/option.component.js +1 -1
- package/package.json +1 -1
- package/safety-theme.css +6 -0
- package/standard-theme.css +6 -0
- package/tabs/tab/tab.component.d.ts +10 -4
- package/tabs/tab/tab.component.d.ts.map +1 -1
- package/tabs/tab/tab.component.js +22 -24
- package/tabs/tab-group/tab-group.component.d.ts +15 -14
- package/tabs/tab-group/tab-group.component.d.ts.map +1 -1
- package/tabs/tab-group/tab-group.component.js +68 -122
- package/tabs/tab-label/tab-label.component.d.ts +21 -2
- package/tabs/tab-label/tab-label.component.d.ts.map +1 -1
- package/tabs/tab-label/tab-label.component.js +88 -46
- package/tooltip/tooltip.component.d.ts +6 -6
- package/tooltip/tooltip.component.d.ts.map +1 -1
- package/tooltip/tooltip.component.js +59 -54
|
@@ -6,7 +6,6 @@ var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read fr
|
|
|
6
6
|
var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot add the same private member more than once") : member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
|
|
7
7
|
var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), setter ? setter.call(obj, value) : member.set(obj, value), value);
|
|
8
8
|
import { __esDecorate, __runInitializers } from "tslib";
|
|
9
|
-
import { MutationController } from "@lit-labs/observers/mutation-controller.js";
|
|
10
9
|
import { ResizeController } from "@lit-labs/observers/resize-controller.js";
|
|
11
10
|
import { css, LitElement, html } from "lit";
|
|
12
11
|
import { customElement, property } from "lit/decorators.js";
|
|
@@ -16,7 +15,6 @@ import { forceType } from "../../core/decorators.js";
|
|
|
16
15
|
import { isLean } from "../../core/dom.js";
|
|
17
16
|
import { throttle } from "../../core/eventing.js";
|
|
18
17
|
import { SbbHydrationMixin } from "../../core/mixins.js";
|
|
19
|
-
import { SbbTabElement } from "../tab.js";
|
|
20
18
|
const style = css`*,
|
|
21
19
|
::before,
|
|
22
20
|
::after {
|
|
@@ -31,22 +29,22 @@ const style = css`*,
|
|
|
31
29
|
display: block;
|
|
32
30
|
}
|
|
33
31
|
|
|
34
|
-
.tab-group {
|
|
32
|
+
.sbb-tab-group {
|
|
35
33
|
display: flex;
|
|
36
34
|
flex-wrap: wrap;
|
|
37
35
|
}
|
|
38
36
|
|
|
39
|
-
.tab-content {
|
|
37
|
+
.sbb-tab-group-content {
|
|
40
38
|
margin-block-start: var(--sbb-spacing-responsive-m);
|
|
41
39
|
transition: height var(--sbb-tab-group-animation-duration) var(--sbb-animation-easing);
|
|
42
40
|
}
|
|
43
|
-
.tab-content ::slotted(sbb-tab) {
|
|
41
|
+
.sbb-tab-group-content ::slotted(sbb-tab) {
|
|
44
42
|
visibility: hidden;
|
|
45
43
|
opacity: 0;
|
|
46
44
|
height: 0;
|
|
47
45
|
overflow: hidden;
|
|
48
46
|
}
|
|
49
|
-
.tab-content ::slotted(sbb-tab[active]) {
|
|
47
|
+
.sbb-tab-group-content ::slotted(sbb-tab[data-active]) {
|
|
50
48
|
visibility: visible;
|
|
51
49
|
opacity: 1;
|
|
52
50
|
height: fit-content;
|
|
@@ -56,14 +54,10 @@ const style = css`*,
|
|
|
56
54
|
transition-timing-function: var(--sbb-animation-easing);
|
|
57
55
|
transition-property: opacity, visibility;
|
|
58
56
|
}
|
|
59
|
-
.tab-content ::slotted(sbb-tab:focus-visible) {
|
|
57
|
+
.sbb-tab-group-content ::slotted(sbb-tab:focus-visible) {
|
|
60
58
|
outline-offset: var(--sbb-focus-outline-offset);
|
|
61
59
|
outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);
|
|
62
60
|
}`;
|
|
63
|
-
const tabObserverConfig = {
|
|
64
|
-
attributeFilter: ["active", "disabled"]
|
|
65
|
-
};
|
|
66
|
-
let nextId = 0;
|
|
67
61
|
let SbbTabGroupElement = (() => {
|
|
68
62
|
var _initialSelectedIndex_accessor_storage, _a;
|
|
69
63
|
let _classDecorators = [customElement("sbb-tab-group")];
|
|
@@ -80,12 +74,7 @@ let SbbTabGroupElement = (() => {
|
|
|
80
74
|
constructor() {
|
|
81
75
|
super();
|
|
82
76
|
__privateAdd(this, _initialSelectedIndex_accessor_storage);
|
|
83
|
-
this.
|
|
84
|
-
this._tabAttributeObserver = new MutationController(this, {
|
|
85
|
-
target: null,
|
|
86
|
-
config: tabObserverConfig,
|
|
87
|
-
callback: (mutationsList) => this._onTabAttributesChange(mutationsList)
|
|
88
|
-
});
|
|
77
|
+
this._tabGroupElement = __runInitializers(this, _instanceExtraInitializers);
|
|
89
78
|
this._tabGroupResizeObserver = new ResizeController(this, {
|
|
90
79
|
target: null,
|
|
91
80
|
skipInitial: true,
|
|
@@ -99,24 +88,12 @@ let SbbTabGroupElement = (() => {
|
|
|
99
88
|
this._size = isLean() ? "s" : "l";
|
|
100
89
|
__privateSet(this, _initialSelectedIndex_accessor_storage, __runInitializers(this, _initialSelectedIndex_initializers, 0));
|
|
101
90
|
this._onContentSlotChange = (__runInitializers(this, _initialSelectedIndex_extraInitializers), () => {
|
|
102
|
-
this.
|
|
103
|
-
|
|
104
|
-
if (loadedTabs.length) {
|
|
105
|
-
loadedTabs.forEach((tab) => this._configure(tab));
|
|
106
|
-
this._tabs = this._tabs.concat(loadedTabs);
|
|
107
|
-
loadedTabs.find((tab) => tab.active)?.tabGroupActions?.select();
|
|
108
|
-
}
|
|
91
|
+
this.labels.forEach((tabLabel) => tabLabel["linkToTab"]());
|
|
92
|
+
this.labels.find((tabLabel) => tabLabel.active)?.activate();
|
|
109
93
|
});
|
|
110
|
-
this.
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
const removedTabs = this._tabs.filter((tab) => !tabs.includes(tab));
|
|
114
|
-
removedTabs.forEach((removedTab) => {
|
|
115
|
-
removedTab.tab?.remove();
|
|
116
|
-
});
|
|
117
|
-
this._tabs = tabs;
|
|
118
|
-
}
|
|
119
|
-
this._tabs.forEach((tab) => tab.setAttribute("data-size", this.size));
|
|
94
|
+
this._onLabelSlotChange = () => {
|
|
95
|
+
this._updateSize();
|
|
96
|
+
this.labels.forEach((tabLabel) => tabLabel["linkToTab"]());
|
|
120
97
|
};
|
|
121
98
|
this.addEventListener?.("keydown", (e) => this._handleKeyDown(e));
|
|
122
99
|
}
|
|
@@ -141,82 +118,67 @@ let SbbTabGroupElement = (() => {
|
|
|
141
118
|
set initialSelectedIndex(value) {
|
|
142
119
|
__privateSet(this, _initialSelectedIndex_accessor_storage, value);
|
|
143
120
|
}
|
|
121
|
+
/** Gets the slotted `sbb-tab-label`s. */
|
|
122
|
+
get labels() {
|
|
123
|
+
return Array.from(this.children ?? []).filter((child) => /^sbb-tab-label$/u.test(child.localName));
|
|
124
|
+
}
|
|
144
125
|
firstUpdated(changedProperties) {
|
|
145
126
|
super.firstUpdated(changedProperties);
|
|
146
|
-
this.
|
|
147
|
-
this._tabs.forEach((tab) => this._configure(tab));
|
|
127
|
+
this.labels.forEach((tabLabel) => tabLabel["linkToTab"]());
|
|
148
128
|
this._initSelection();
|
|
149
129
|
this._tabGroupResizeObserver.observe(this._tabGroupElement);
|
|
130
|
+
this._tabContentResizeObserver.observe(this._tabContentElement);
|
|
150
131
|
}
|
|
151
132
|
/**
|
|
152
133
|
* Disables a tab by index.
|
|
153
134
|
* @param tabIndex The index of the tab you want to disable.
|
|
154
135
|
*/
|
|
155
136
|
disableTab(tabIndex) {
|
|
156
|
-
this.
|
|
137
|
+
if (this.labels[tabIndex]) {
|
|
138
|
+
this.labels[tabIndex].disabled = true;
|
|
139
|
+
}
|
|
157
140
|
}
|
|
158
141
|
/**
|
|
159
142
|
* Enables a tab by index.
|
|
160
143
|
* @param tabIndex The index of the tab you want to enable.
|
|
161
144
|
*/
|
|
162
145
|
enableTab(tabIndex) {
|
|
163
|
-
this.
|
|
146
|
+
if (this.labels[tabIndex]) {
|
|
147
|
+
this.labels[tabIndex].disabled = false;
|
|
148
|
+
}
|
|
164
149
|
}
|
|
165
150
|
/**
|
|
166
151
|
* Activates a tab by index.
|
|
167
152
|
* @param tabIndex The index of the tab you want to activate.
|
|
168
153
|
*/
|
|
169
154
|
activateTab(tabIndex) {
|
|
170
|
-
this.
|
|
171
|
-
}
|
|
172
|
-
_getTabs() {
|
|
173
|
-
return Array.from(this.children ?? []).filter((child) => /^sbb-tab-label$/u.test(child.localName));
|
|
155
|
+
this.labels[tabIndex]?.activate();
|
|
174
156
|
}
|
|
175
157
|
_enabledTabs() {
|
|
176
|
-
return this.
|
|
158
|
+
return this.labels.filter((t) => {
|
|
159
|
+
customElements.upgrade(t);
|
|
160
|
+
return !t.disabled;
|
|
161
|
+
});
|
|
177
162
|
}
|
|
178
163
|
_updateSize() {
|
|
179
|
-
|
|
180
|
-
tab.setAttribute("data-size", this.size);
|
|
181
|
-
}
|
|
182
|
-
}
|
|
183
|
-
_assignId() {
|
|
184
|
-
return `sbb-tab-panel-${++nextId}`;
|
|
164
|
+
this.labels.forEach((tabLabel) => tabLabel.setAttribute("data-size", this.size));
|
|
185
165
|
}
|
|
186
166
|
_initSelection() {
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
this.
|
|
191
|
-
|
|
192
|
-
}
|
|
193
|
-
_onTabAttributesChange(mutationsList) {
|
|
194
|
-
for (const mutation of mutationsList) {
|
|
195
|
-
if (mutation.type !== "attributes") {
|
|
167
|
+
const selectedTabLabel = this.labels[this.initialSelectedIndex];
|
|
168
|
+
if (selectedTabLabel) {
|
|
169
|
+
customElements.upgrade(selectedTabLabel);
|
|
170
|
+
if (this.initialSelectedIndex >= 0 && this.initialSelectedIndex < this.labels.length && !selectedTabLabel.disabled) {
|
|
171
|
+
selectedTabLabel.activate();
|
|
196
172
|
return;
|
|
197
173
|
}
|
|
198
|
-
const tab = mutation.target;
|
|
199
|
-
if (mutation.attributeName === "disabled") {
|
|
200
|
-
if (tab.hasAttribute("disabled") && tab !== this._selectedTab) {
|
|
201
|
-
tab.tabGroupActions?.disable();
|
|
202
|
-
} else if (tab.disabled) {
|
|
203
|
-
tab.tabGroupActions?.enable();
|
|
204
|
-
}
|
|
205
|
-
}
|
|
206
|
-
if (mutation.attributeName === "active") {
|
|
207
|
-
if (tab.hasAttribute("active") && !tab.disabled) {
|
|
208
|
-
tab.tabGroupActions?.select();
|
|
209
|
-
} else if (tab === this._selectedTab) {
|
|
210
|
-
tab.toggleAttribute("active", true);
|
|
211
|
-
}
|
|
212
|
-
}
|
|
213
174
|
}
|
|
175
|
+
this._enabledTabs()[0]?.activate();
|
|
214
176
|
}
|
|
215
177
|
_onTabGroupElementResize(entries) {
|
|
216
178
|
for (const entry of entries) {
|
|
217
|
-
const
|
|
218
|
-
for (const
|
|
219
|
-
|
|
179
|
+
const labelElements = entry.target.firstElementChild.assignedElements();
|
|
180
|
+
for (const tabLabel of labelElements) {
|
|
181
|
+
tabLabel.toggleAttribute("data-has-divider", tabLabel === labelElements[0] || tabLabel.offsetLeft === labelElements[0].offsetLeft);
|
|
220
182
|
this.style.setProperty("--sbb-tab-group-width", `${this._tabGroupElement.clientWidth}px`);
|
|
221
183
|
}
|
|
222
184
|
}
|
|
@@ -230,99 +192,6 @@ let SbbTabGroupElement = (() => {
|
|
|
230
192
|
this._tabContentElement.style.height = `${contentHeight}px`;
|
|
231
193
|
}
|
|
232
194
|
}
|
|
233
|
-
_configure(tabLabel) {
|
|
234
|
-
tabLabel.tabGroupActions = {
|
|
235
|
-
activate: () => {
|
|
236
|
-
tabLabel.toggleAttribute("active", true);
|
|
237
|
-
tabLabel.active = true;
|
|
238
|
-
tabLabel.tabIndex = 0;
|
|
239
|
-
tabLabel.setAttribute("aria-selected", "true");
|
|
240
|
-
tabLabel.tab?.toggleAttribute("active", true);
|
|
241
|
-
},
|
|
242
|
-
deactivate: () => {
|
|
243
|
-
tabLabel.removeAttribute("active");
|
|
244
|
-
tabLabel.active = false;
|
|
245
|
-
tabLabel.tabIndex = -1;
|
|
246
|
-
tabLabel.setAttribute("aria-selected", "false");
|
|
247
|
-
tabLabel.tab?.removeAttribute("active");
|
|
248
|
-
},
|
|
249
|
-
disable: () => {
|
|
250
|
-
if (tabLabel.disabled) {
|
|
251
|
-
return;
|
|
252
|
-
}
|
|
253
|
-
if (!tabLabel.hasAttribute("disabled")) {
|
|
254
|
-
tabLabel.toggleAttribute("disabled", true);
|
|
255
|
-
}
|
|
256
|
-
tabLabel.disabled = true;
|
|
257
|
-
tabLabel.tabIndex = -1;
|
|
258
|
-
tabLabel.setAttribute("aria-selected", "false");
|
|
259
|
-
tabLabel.tab?.removeAttribute("active");
|
|
260
|
-
if (tabLabel.active) {
|
|
261
|
-
tabLabel.removeAttribute("active");
|
|
262
|
-
tabLabel.active = false;
|
|
263
|
-
this._enabledTabs()[0]?.tabGroupActions?.select();
|
|
264
|
-
}
|
|
265
|
-
},
|
|
266
|
-
enable: () => {
|
|
267
|
-
if (tabLabel.disabled) {
|
|
268
|
-
tabLabel.removeAttribute("disabled");
|
|
269
|
-
tabLabel.disabled = false;
|
|
270
|
-
}
|
|
271
|
-
},
|
|
272
|
-
select: () => {
|
|
273
|
-
if (tabLabel !== this._selectedTab && !tabLabel.disabled) {
|
|
274
|
-
const prevTab = this._selectedTab;
|
|
275
|
-
if (prevTab) {
|
|
276
|
-
prevTab.tabGroupActions?.deactivate();
|
|
277
|
-
this._tabContentResizeObserver.unobserve(prevTab.tab);
|
|
278
|
-
}
|
|
279
|
-
tabLabel.tabGroupActions?.activate();
|
|
280
|
-
this._selectedTab = tabLabel;
|
|
281
|
-
this._tabContentResizeObserver.observe(tabLabel.tab);
|
|
282
|
-
const tabs = this._tabs;
|
|
283
|
-
this.dispatchEvent(new CustomEvent("tabchange", {
|
|
284
|
-
bubbles: true,
|
|
285
|
-
composed: true,
|
|
286
|
-
detail: {
|
|
287
|
-
activeIndex: tabs.findIndex((e) => e === tabLabel),
|
|
288
|
-
activeTabLabel: tabLabel,
|
|
289
|
-
activeTab: tabLabel.tab,
|
|
290
|
-
previousIndex: tabs.findIndex((e) => e === prevTab),
|
|
291
|
-
previousTabLabel: prevTab,
|
|
292
|
-
previousTab: prevTab?.tab
|
|
293
|
-
}
|
|
294
|
-
}));
|
|
295
|
-
} else if (tabLabel.disabled) {
|
|
296
|
-
console.warn("You cannot activate a disabled tab");
|
|
297
|
-
}
|
|
298
|
-
}
|
|
299
|
-
};
|
|
300
|
-
if (tabLabel.nextElementSibling?.localName === "sbb-tab") {
|
|
301
|
-
tabLabel.tab = tabLabel.nextElementSibling;
|
|
302
|
-
tabLabel.tab.id = this._assignId();
|
|
303
|
-
if (tabLabel.tab instanceof SbbTabElement) {
|
|
304
|
-
tabLabel.tab.tabIndex = 0;
|
|
305
|
-
tabLabel.tab.configure();
|
|
306
|
-
}
|
|
307
|
-
} else {
|
|
308
|
-
tabLabel.insertAdjacentHTML("afterend", "<sbb-tab>No content.</sbb-tab>");
|
|
309
|
-
tabLabel.tab = tabLabel.nextElementSibling;
|
|
310
|
-
console.warn(`Missing content: you should provide a related content for the tab ${tabLabel.outerHTML}.`);
|
|
311
|
-
}
|
|
312
|
-
tabLabel.tabIndex = -1;
|
|
313
|
-
tabLabel.disabled = tabLabel.hasAttribute("disabled");
|
|
314
|
-
tabLabel.active = tabLabel.hasAttribute("active") && !tabLabel.disabled;
|
|
315
|
-
tabLabel.setAttribute("aria-selected", String(tabLabel.active));
|
|
316
|
-
tabLabel.addEventListener("click", () => {
|
|
317
|
-
tabLabel.tabGroupActions?.select();
|
|
318
|
-
});
|
|
319
|
-
if (tabLabel.tab) {
|
|
320
|
-
tabLabel.setAttribute("aria-controls", tabLabel.tab.id);
|
|
321
|
-
tabLabel.tab.toggleAttribute("active", tabLabel.active);
|
|
322
|
-
}
|
|
323
|
-
this._tabAttributeObserver.observe(tabLabel);
|
|
324
|
-
tabLabel.slot = "tab-bar";
|
|
325
|
-
}
|
|
326
195
|
_handleKeyDown(evt) {
|
|
327
196
|
const enabledTabs = this._enabledTabs();
|
|
328
197
|
if (!enabledTabs || // don't trap nested handling
|
|
@@ -332,7 +201,7 @@ let SbbTabGroupElement = (() => {
|
|
|
332
201
|
if (isArrowKeyPressed(evt)) {
|
|
333
202
|
const current = enabledTabs.findIndex((t) => t.active);
|
|
334
203
|
const nextIndex = getNextElementIndex(evt, current, enabledTabs.length);
|
|
335
|
-
enabledTabs[nextIndex]?.
|
|
204
|
+
enabledTabs[nextIndex]?.activate();
|
|
336
205
|
enabledTabs[nextIndex]?.focus();
|
|
337
206
|
evt.preventDefault();
|
|
338
207
|
}
|
|
@@ -340,14 +209,16 @@ let SbbTabGroupElement = (() => {
|
|
|
340
209
|
render() {
|
|
341
210
|
return html`
|
|
342
211
|
<div
|
|
343
|
-
class="tab-group"
|
|
212
|
+
class="sbb-tab-group"
|
|
344
213
|
role="tablist"
|
|
345
214
|
${ref((el) => this._tabGroupElement = el)}
|
|
346
215
|
>
|
|
347
|
-
<slot name="tab-bar" @slotchange=${this.
|
|
216
|
+
<slot name="tab-bar" @slotchange=${this._onLabelSlotChange}></slot>
|
|
348
217
|
</div>
|
|
349
|
-
|
|
350
|
-
|
|
218
|
+
<div
|
|
219
|
+
class="sbb-tab-group-content"
|
|
220
|
+
${ref((el) => this._tabContentElement = el)}
|
|
221
|
+
>
|
|
351
222
|
<slot @slotchange=${throttle(this._onContentSlotChange, 150)}></slot>
|
|
352
223
|
</div>
|
|
353
224
|
`;
|
|
@@ -373,4 +244,4 @@ let SbbTabGroupElement = (() => {
|
|
|
373
244
|
export {
|
|
374
245
|
SbbTabGroupElement
|
|
375
246
|
};
|
|
376
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"tab-group.component.js","sources":["../../../../../src/elements/tabs/tab-group/tab-group.component.ts"],"sourcesContent":["import { MutationController } from '@lit-labs/observers/mutation-controller.js';\nimport { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport { getNextElementIndex, isArrowKeyPressed } from '../../core/a11y.js';\nimport { forceType } from '../../core/decorators.js';\nimport { isLean } from '../../core/dom.js';\nimport { throttle } from '../../core/eventing.js';\nimport { SbbHydrationMixin } from '../../core/mixins.js';\nimport type { SbbTabLabelElement } from '../tab-label.js';\nimport { SbbTabElement } from '../tab.js';\n\nimport style from './tab-group.scss?lit&inline';\n\nexport type SbbTabChangedEventDetails = {\n  activeIndex: number;\n  activeTabLabel: SbbTabLabelElement;\n  activeTab: SbbTabElement;\n  previousIndex: number;\n  previousTabLabel: SbbTabLabelElement | undefined;\n  previousTab: SbbTabElement | undefined;\n};\n\nexport interface InterfaceSbbTabGroupActions {\n  activate(): void;\n  deactivate(): void;\n  enable(): void;\n  disable(): void;\n  select(): void;\n}\n\nexport interface InterfaceSbbTabGroupTab extends SbbTabLabelElement {\n  active: boolean;\n  disabled: boolean;\n  tab?: SbbTabElement;\n  index?: number;\n  tabGroupActions?: InterfaceSbbTabGroupActions;\n  size: 's' | 'l' | 'xl';\n}\n\nconst tabObserverConfig: MutationObserverInit = {\n  attributeFilter: ['active', 'disabled'],\n};\n\nlet nextId = 0;\n\n/**\n * It displays one or more tabs, each one with a label and a content.\n *\n * @slot - Use the unnamed slot to add content to the `sbb-tab-group` via\n * `sbb-tab-label` and `sbb-tab` instances.\n */\nexport\n@customElement('sbb-tab-group')\nclass SbbTabGroupElement extends SbbHydrationMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    tabchange: 'tabchange',\n  } as const;\n\n  private _tabs: InterfaceSbbTabGroupTab[] = [];\n  private _selectedTab?: InterfaceSbbTabGroupTab;\n  private _tabGroupElement!: HTMLElement;\n  private _tabContentElement!: HTMLElement;\n  private _tabAttributeObserver = new MutationController(this, {\n    target: null,\n    config: tabObserverConfig,\n    callback: (mutationsList) => this._onTabAttributesChange(mutationsList),\n  });\n  private _tabGroupResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: (entries) => this._onTabGroupElementResize(entries),\n  });\n  private _tabContentResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: (entries) => this._onTabContentElementResize(entries),\n  });\n\n  /**\n   * Size variant, either s, l or xl.\n   * @default 'l' / 's' (lean)\n   */\n  @property()\n  public set size(value: InterfaceSbbTabGroupTab['size']) {\n    this._size = value;\n    this._updateSize();\n  }\n  public get size(): InterfaceSbbTabGroupTab['size'] {\n    return this._size;\n  }\n  private _size: InterfaceSbbTabGroupTab['size'] = 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  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._tabs = this._getTabs();\n    this._tabs.forEach((tab) => this._configure(tab));\n    this._initSelection();\n    this._tabGroupResizeObserver.observe(this._tabGroupElement);\n  }\n\n  /**\n   * Disables a tab by index.\n   * @param tabIndex The index of the tab you want to disable.\n   */\n  public disableTab(tabIndex: number): void {\n    this._tabs[tabIndex]?.tabGroupActions?.disable();\n  }\n\n  /**\n   * Enables a tab by index.\n   * @param tabIndex The index of the tab you want to enable.\n   */\n  public enableTab(tabIndex: number): void {\n    this._tabs[tabIndex]?.tabGroupActions?.enable();\n  }\n\n  /**\n   * Activates a tab by index.\n   * @param tabIndex The index of the tab you want to activate.\n   */\n  public activateTab(tabIndex: number): void {\n    this._tabs[tabIndex]?.tabGroupActions?.select();\n  }\n\n  private _getTabs(): InterfaceSbbTabGroupTab[] {\n    return Array.from(this.children ?? []).filter((child) =>\n      /^sbb-tab-label$/u.test(child.localName),\n    ) as InterfaceSbbTabGroupTab[];\n  }\n\n  private _enabledTabs(): InterfaceSbbTabGroupTab[] {\n    return this._tabs.filter((t) => !t.hasAttribute('disabled'));\n  }\n\n  private _updateSize(): void {\n    for (const tab of this._tabs) {\n      tab.setAttribute('data-size', this.size);\n    }\n  }\n\n  private _onContentSlotChange = (): void => {\n    this._tabContentElement = this.shadowRoot!.querySelector('div.tab-content')!;\n    const loadedTabs = this._getTabs().filter((tab) => !this._tabs.includes(tab));\n\n    // if a new tab/content is added to the tab group\n    if (loadedTabs.length) {\n      loadedTabs.forEach((tab) => this._configure(tab));\n      this._tabs = this._tabs.concat(loadedTabs);\n\n      // If there is an active tab in the new batch, it becomes the new selected\n      loadedTabs.find((tab) => tab.active)?.tabGroupActions?.select();\n    }\n  };\n\n  private _onTabsSlotChange = (): void => {\n    const tabs = this._getTabs();\n\n    // if a tab is removed from the tab group\n    if (tabs.length < this._tabs.length) {\n      const removedTabs = this._tabs.filter((tab) => !tabs.includes(tab));\n\n      removedTabs.forEach((removedTab) => {\n        removedTab.tab?.remove();\n      });\n      this._tabs = tabs;\n    }\n    this._tabs.forEach((tab: InterfaceSbbTabGroupTab) => tab.setAttribute('data-size', this.size));\n  };\n\n  private _assignId(): string {\n    return `sbb-tab-panel-${++nextId}`;\n  }\n\n  private _initSelection(): void {\n    if (\n      this.initialSelectedIndex >= 0 &&\n      this.initialSelectedIndex < this._tabs.length &&\n      !this._tabs[this.initialSelectedIndex].disabled\n    ) {\n      this._tabs[this.initialSelectedIndex].tabGroupActions?.select();\n    } else {\n      this._enabledTabs()[0]?.tabGroupActions?.select();\n    }\n  }\n\n  private _onTabAttributesChange(mutationsList: MutationRecord[]): void {\n    for (const mutation of mutationsList) {\n      if (mutation.type !== 'attributes') {\n        return;\n      }\n      const tab = mutation.target as InterfaceSbbTabGroupTab;\n\n      if (mutation.attributeName === 'disabled') {\n        if (tab.hasAttribute('disabled') && tab !== this._selectedTab) {\n          tab.tabGroupActions?.disable();\n        } else if (tab.disabled) {\n          tab.tabGroupActions?.enable();\n        }\n      }\n      if (mutation.attributeName === 'active') {\n        if (tab.hasAttribute('active') && !tab.disabled) {\n          tab.tabGroupActions?.select();\n        } else if (tab === this._selectedTab) {\n          tab.toggleAttribute('active', true);\n        }\n      }\n    }\n  }\n\n  private _onTabGroupElementResize(entries: ResizeObserverEntry[]): void {\n    for (const entry of entries) {\n      const tabTitles = (\n        entry.target.firstElementChild as HTMLSlotElement\n      ).assignedElements() as SbbTabLabelElement[];\n\n      for (const tab of tabTitles) {\n        tab.toggleAttribute(\n          'data-has-divider',\n          tab === tabTitles[0] || tab.offsetLeft === tabTitles[0].offsetLeft,\n        );\n        this.style.setProperty('--sbb-tab-group-width', `${this._tabGroupElement.clientWidth}px`);\n      }\n    }\n  }\n\n  private _onTabContentElementResize(entries: ResizeObserverEntry[]): void {\n    if (!this._tabContentElement) {\n      return;\n    }\n    for (const entry of entries) {\n      const contentHeight = Math.floor(entry.contentRect.height);\n\n      this._tabContentElement.style.height = `${contentHeight}px`;\n    }\n  }\n\n  private _configure(tabLabel: InterfaceSbbTabGroupTab): void {\n    tabLabel.tabGroupActions = {\n      activate: (): void => {\n        tabLabel.toggleAttribute('active', true);\n        tabLabel.active = true;\n        tabLabel.tabIndex = 0;\n        tabLabel.setAttribute('aria-selected', 'true');\n        tabLabel.tab?.toggleAttribute('active', true);\n      },\n      deactivate: (): void => {\n        tabLabel.removeAttribute('active');\n        tabLabel.active = false;\n        tabLabel.tabIndex = -1;\n        tabLabel.setAttribute('aria-selected', 'false');\n        tabLabel.tab?.removeAttribute('active');\n      },\n      disable: (): void => {\n        if (tabLabel.disabled) {\n          return;\n        }\n        if (!tabLabel.hasAttribute('disabled')) {\n          tabLabel.toggleAttribute('disabled', true);\n        }\n        tabLabel.disabled = true;\n        tabLabel.tabIndex = -1;\n        tabLabel.setAttribute('aria-selected', 'false');\n        tabLabel.tab?.removeAttribute('active');\n        if (tabLabel.active) {\n          tabLabel.removeAttribute('active');\n          tabLabel.active = false;\n          this._enabledTabs()[0]?.tabGroupActions?.select();\n        }\n      },\n      enable: (): void => {\n        if (tabLabel.disabled) {\n          tabLabel.removeAttribute('disabled');\n          tabLabel.disabled = false;\n        }\n      },\n      select: (): void => {\n        if (tabLabel !== this._selectedTab && !tabLabel.disabled) {\n          const prevTab = this._selectedTab;\n\n          if (prevTab) {\n            prevTab.tabGroupActions?.deactivate();\n            this._tabContentResizeObserver.unobserve(prevTab.tab!);\n          }\n\n          tabLabel.tabGroupActions?.activate();\n          this._selectedTab = tabLabel;\n\n          this._tabContentResizeObserver.observe(tabLabel.tab!);\n          const tabs = this._tabs;\n\n          /**\n           * @type {CustomEvent<SbbTabChangedEventDetails>}\n           * The tabchange event is dispatched when a tab is selected.\n           */\n          this.dispatchEvent(\n            new CustomEvent<SbbTabChangedEventDetails>('tabchange', {\n              bubbles: true,\n              composed: true,\n              detail: {\n                activeIndex: tabs.findIndex((e) => e === tabLabel),\n                activeTabLabel: tabLabel,\n                activeTab: tabLabel.tab as SbbTabElement,\n                previousIndex: tabs.findIndex((e) => e === prevTab),\n                previousTabLabel: prevTab,\n                previousTab: prevTab?.tab as SbbTabElement,\n              },\n            }),\n          );\n        } else if (import.meta.env.DEV && tabLabel.disabled) {\n          console.warn('You cannot activate a disabled tab');\n        }\n      },\n    };\n\n    if (tabLabel.nextElementSibling?.localName === 'sbb-tab') {\n      tabLabel.tab = tabLabel.nextElementSibling as SbbTabElement;\n      tabLabel.tab.id = this._assignId();\n      if (tabLabel.tab instanceof SbbTabElement) {\n        tabLabel.tab.tabIndex = 0;\n        tabLabel.tab.configure();\n      }\n    } else if (import.meta.env.DEV) {\n      tabLabel.insertAdjacentHTML('afterend', '<sbb-tab>No content.</sbb-tab>');\n      tabLabel.tab = tabLabel.nextElementSibling as SbbTabElement;\n      console.warn(\n        `Missing content: you should provide a related content for the tab ${tabLabel.outerHTML}.`,\n      );\n    }\n    tabLabel.tabIndex = -1;\n    tabLabel.disabled = tabLabel.hasAttribute('disabled');\n    tabLabel.active = tabLabel.hasAttribute('active') && !tabLabel.disabled;\n    tabLabel.setAttribute('aria-selected', String(tabLabel.active));\n    tabLabel.addEventListener('click', () => {\n      tabLabel.tabGroupActions?.select();\n    });\n    if (tabLabel.tab) {\n      tabLabel.setAttribute('aria-controls', tabLabel.tab.id);\n      tabLabel.tab.toggleAttribute('active', tabLabel.active);\n    }\n\n    this._tabAttributeObserver.observe(tabLabel);\n    tabLabel.slot = 'tab-bar';\n  }\n\n  private _handleKeyDown(evt: KeyboardEvent): void {\n    const enabledTabs: InterfaceSbbTabGroupTab[] = 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: InterfaceSbbTabGroupTab) => t.active);\n      const nextIndex: number = getNextElementIndex(evt, current, enabledTabs.length);\n      enabledTabs[nextIndex]?.tabGroupActions?.select();\n      enabledTabs[nextIndex]?.focus();\n      evt.preventDefault();\n    }\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div\n        class=\"tab-group\"\n        role=\"tablist\"\n        ${ref((el?: Element) => (this._tabGroupElement = el as HTMLElement))}\n      >\n        <slot name=\"tab-bar\" @slotchange=${this._onTabsSlotChange}></slot>\n      </div>\n\n      <div class=\"tab-content\">\n        <slot @slotchange=${throttle(this._onContentSlotChange, 150)}></slot>\n      </div>\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"],"names":[],"mappings":"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"}
|
|
247
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"tab-group.component.js","sources":["../../../../../src/elements/tabs/tab-group/tab-group.component.ts"],"sourcesContent":["import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport { getNextElementIndex, isArrowKeyPressed } from '../../core/a11y.js';\nimport { forceType } from '../../core/decorators.js';\nimport { isLean } from '../../core/dom.js';\nimport { throttle } from '../../core/eventing.js';\nimport { SbbHydrationMixin } from '../../core/mixins.js';\nimport type { SbbTabLabelElement } from '../tab-label.js';\nimport type { SbbTabElement } from '../tab.js';\n\nimport style from './tab-group.scss?lit&inline';\n\nexport type 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 * @deprecated\n */\nexport interface InterfaceSbbTabGroupActions {\n  activate(): void;\n  deactivate(): void;\n  enable(): void;\n  disable(): void;\n  select(): void;\n}\n\n/**\n * @deprecated\n */\nexport interface InterfaceSbbTabGroupTab extends SbbTabLabelElement {\n  active: boolean;\n  disabled: boolean;\n  tab: SbbTabElement | null;\n  index?: number;\n  tabGroupActions?: InterfaceSbbTabGroupActions;\n  size: 's' | 'l' | 'xl';\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\n@customElement('sbb-tab-group')\nclass SbbTabGroupElement extends SbbHydrationMixin(LitElement) {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    tabchange: 'tabchange',\n  } as const;\n\n  private _tabGroupElement!: HTMLElement;\n  private _tabContentElement!: HTMLElement;\n  private _tabGroupResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: (entries) => this._onTabGroupElementResize(entries),\n  });\n  private _tabContentResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: (entries) => this._onTabContentElementResize(entries),\n  });\n\n  /**\n   * Size variant, either s, l or xl.\n   * @default 'l' / 's' (lean)\n   */\n  @property()\n  public set size(value: 's' | 'l' | 'xl') {\n    this._size = value;\n    this._updateSize();\n  }\n  public get size(): 's' | 'l' | 'xl' {\n    return this._size;\n  }\n  private _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  /** 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  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    this._tabGroupResizeObserver.observe(this._tabGroupElement);\n    this._tabContentResizeObserver.observe(this._tabContentElement);\n  }\n\n  /**\n   * Disables a tab by index.\n   * @param tabIndex The index of the tab you want to disable.\n   */\n  public disableTab(tabIndex: number): void {\n    if (this.labels[tabIndex]) {\n      this.labels[tabIndex].disabled = true;\n    }\n  }\n\n  /**\n   * Enables a tab by index.\n   * @param tabIndex The index of the tab you want to enable.\n   */\n  public enableTab(tabIndex: number): void {\n    if (this.labels[tabIndex]) {\n      this.labels[tabIndex].disabled = false;\n    }\n  }\n\n  /**\n   * Activates a tab by index.\n   * @param tabIndex The index of the tab you want to activate.\n   */\n  public activateTab(tabIndex: number): void {\n    this.labels[tabIndex]?.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 _updateSize(): void {\n    this.labels.forEach((tabLabel: SbbTabLabelElement) =>\n      tabLabel.setAttribute('data-size', this.size),\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._updateSize();\n    this.labels.forEach((tabLabel) => tabLabel['linkToTab']());\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(entries: ResizeObserverEntry[]): void {\n    for (const entry of entries) {\n      const labelElements = (\n        entry.target.firstElementChild as HTMLSlotElement\n      ).assignedElements() as SbbTabLabelElement[];\n\n      for (const tabLabel of labelElements) {\n        tabLabel.toggleAttribute(\n          'data-has-divider',\n          tabLabel === labelElements[0] || tabLabel.offsetLeft === labelElements[0].offsetLeft,\n        );\n        this.style.setProperty('--sbb-tab-group-width', `${this._tabGroupElement.clientWidth}px`);\n      }\n    }\n  }\n\n  private _onTabContentElementResize(entries: ResizeObserverEntry[]): void {\n    if (!this._tabContentElement) {\n      return;\n    }\n    for (const entry of entries) {\n      const contentHeight = Math.floor(entry.contentRect.height);\n\n      this._tabContentElement.style.height = `${contentHeight}px`;\n    }\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  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      <div\n        class=\"sbb-tab-group-content\"\n        ${ref((el?: Element) => (this._tabContentElement = el as HTMLElement))}\n      >\n        <slot @slotchange=${throttle(this._onContentSlotChange, 150)}></slot>\n      </div>\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"],"names":[],"mappings":"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"}
|
|
@@ -1,5 +1,7 @@
|
|
|
1
|
-
import { CSSResultGroup, TemplateResult, LitElement } from 'lit';
|
|
1
|
+
import { CSSResultGroup, PropertyValues, TemplateResult, LitElement } from 'lit';
|
|
2
2
|
import { SbbTitleLevel } from '../../title.js';
|
|
3
|
+
import { SbbTabElement } from '../tab/tab.component.js';
|
|
4
|
+
import { SbbTabGroupElement } from '../tab-group.js';
|
|
3
5
|
declare const SbbTabLabelElement_base: import('../../core/mixins.js').AbstractConstructor<import('../../core/mixins.js').SbbDisabledMixinType> & import('../../core/mixins.js').AbstractConstructor<import('../../icon.js').SbbIconNameMixinType> & import('../../core/mixins.js').AbstractConstructor<import('../../core/mixins.js').SbbElementInternalsMixinType> & typeof LitElement & import('../../core/mixins.js').SbbElementInternalsConstructor;
|
|
4
6
|
/**
|
|
5
7
|
* Combined with a `sbb-tab-group`, it displays a tab's title.
|
|
@@ -11,15 +13,32 @@ declare const SbbTabLabelElement_base: import('../../core/mixins.js').AbstractCo
|
|
|
11
13
|
export declare class SbbTabLabelElement extends SbbTabLabelElement_base {
|
|
12
14
|
static role: string;
|
|
13
15
|
static styles: CSSResultGroup;
|
|
16
|
+
/** Whether the tab is selected. */
|
|
17
|
+
private _selected;
|
|
14
18
|
/**
|
|
15
19
|
* The level will correspond to the heading tag generated in the title.
|
|
16
20
|
* Use this property to generate the appropriate header tag, taking SEO into consideration.
|
|
17
21
|
*/
|
|
18
22
|
accessor level: SbbTitleLevel;
|
|
19
|
-
/** Active tab state */
|
|
23
|
+
/** Active tab state. */
|
|
20
24
|
accessor active: boolean;
|
|
21
25
|
/** Amount displayed inside the tab. */
|
|
22
26
|
accessor amount: string;
|
|
27
|
+
/** Get the `sbb-tab` related to the `sbb-tab-label`. */
|
|
28
|
+
get tab(): SbbTabElement | null;
|
|
29
|
+
/** Get the parent `sbb-tab-group`. */
|
|
30
|
+
get group(): SbbTabGroupElement | null;
|
|
31
|
+
constructor();
|
|
32
|
+
connectedCallback(): void;
|
|
33
|
+
protected willUpdate(changedProperties: PropertyValues<this>): void;
|
|
34
|
+
/** Deactivate the tab. */
|
|
35
|
+
deactivate(): void;
|
|
36
|
+
/** Select the tab, deactivating the current selected one, and dispatch the tabchange event. */
|
|
37
|
+
activate(): void;
|
|
38
|
+
/**
|
|
39
|
+
* @internal
|
|
40
|
+
*/
|
|
41
|
+
protected linkToTab(): void;
|
|
23
42
|
protected render(): TemplateResult;
|
|
24
43
|
}
|
|
25
44
|
declare global {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tab-label.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/tabs/tab-label/tab-label.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;
|
|
1
|
+
{"version":3,"file":"tab-label.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/tabs/tab-label/tab-label.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAE,UAAU,EAAE,MAAM,KAAK,CAAC;AAOjC,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AACpD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,KAAK,EAA6B,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;;AAIrF;;;;;;GAMG;AACH,qBAGM,kBAAmB,SAAQ,uBAEhC;IACC,OAAuB,IAAI,SAAS;IACpC,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,mCAAmC;IACnC,OAAO,CAAC,SAAS,CAAkB;IAEnC;;;OAGG;IACH,SAA4B,KAAK,EAAE,aAAa,CAAO;IAEvD,wBAAwB;IACxB,SAEgB,MAAM,EAAE,OAAO,CAAS;IAExC,uCAAuC;IACvC,SAEgB,MAAM,EAAE,MAAM,CAAM;IAEpC,wDAAwD;IACxD,IAAW,GAAG,IAAI,aAAa,GAAG,IAAI,CAIrC;IAED,sCAAsC;IACtC,IAAW,KAAK,IAAI,kBAAkB,GAAG,IAAI,CAE5C;;IAQe,iBAAiB,IAAI,IAAI;cAMtB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAuB5E,0BAA0B;IACnB,UAAU,IAAI,IAAI;IAMzB,+FAA+F;IACxF,QAAQ,IAAI,IAAI;IAiCvB;;OAEG;IACH,SAAS,CAAC,SAAS,IAAI,IAAI;cAYR,MAAM,IAAI,cAAc;CAoB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,eAAe,EAAE,kBAAkB,CAAC;KACrC;CACF"}
|