@sbb-esta/lyne-elements-dev 5.0.0-next-dev.1776267015 → 5.0.0-next-dev.1776331625

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.
@@ -81225,7 +81225,8 @@
81225
81225
  "text": "number"
81226
81226
  }
81227
81227
  }
81228
- ]
81228
+ ],
81229
+ "deprecated": "true"
81229
81230
  }
81230
81231
  ],
81231
81232
  "exports": [
@@ -149598,6 +149599,14 @@
149598
149599
  "privacy": "private",
149599
149600
  "default": "new ResizeController(this, { target: null, skipInitial: true, callback: () => this._onTabGroupElementResize(), })"
149600
149601
  },
149602
+ {
149603
+ "kind": "field",
149604
+ "name": "_contentSlotChangeDebounceId",
149605
+ "type": {
149606
+ "text": "ReturnType<typeof setTimeout> | undefined"
149607
+ },
149608
+ "privacy": "private"
149609
+ },
149601
149610
  {
149602
149611
  "kind": "field",
149603
149612
  "name": "size",
@@ -149723,14 +149732,24 @@
149723
149732
  }
149724
149733
  },
149725
149734
  {
149726
- "kind": "field",
149735
+ "kind": "method",
149727
149736
  "name": "_onContentSlotChange",
149728
- "privacy": "private"
149737
+ "privacy": "private",
149738
+ "return": {
149739
+ "type": {
149740
+ "text": "void"
149741
+ }
149742
+ }
149729
149743
  },
149730
149744
  {
149731
- "kind": "field",
149745
+ "kind": "method",
149732
149746
  "name": "_onLabelSlotChange",
149733
- "privacy": "private"
149747
+ "privacy": "private",
149748
+ "return": {
149749
+ "type": {
149750
+ "text": "void"
149751
+ }
149752
+ }
149734
149753
  },
149735
149754
  {
149736
149755
  "kind": "method",
@@ -1,2 +1,3 @@
1
+ /** @deprecated */
1
2
  export declare const throttle: <F extends (...args: any[]) => any>(func: F, delay: number) => ((...args: Parameters<F>) => Promise<ReturnType<F>>);
2
3
  //# sourceMappingURL=throttle.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"throttle.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/eventing/throttle.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,QAAQ,GAAI,CAAC,SAAS,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,GAAG,EACxD,MAAM,CAAC,EACP,OAAO,MAAM,KACZ,CAAC,CAAC,GAAG,IAAI,EAAE,UAAU,CAAC,CAAC,CAAC,KAAK,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAerD,CAAC"}
1
+ {"version":3,"file":"throttle.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/eventing/throttle.ts"],"names":[],"mappings":"AAAA,kBAAkB;AAClB,eAAO,MAAM,QAAQ,GAAI,CAAC,SAAS,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,GAAG,EACxD,MAAM,CAAC,EACP,OAAO,MAAM,KACZ,CAAC,CAAC,GAAG,IAAI,EAAE,UAAU,CAAC,CAAC,CAAC,KAAK,OAAO,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAerD,CAAC"}
@@ -1,4 +1,5 @@
1
1
  //#region src/elements/core/eventing/throttle.ts
2
+ /** @deprecated */
2
3
  var throttle = (func, delay) => {
3
4
  let shouldWait = false;
4
5
  const throttled = (...args) => {
@@ -14,4 +15,4 @@ var throttle = (func, delay) => {
14
15
  //#endregion
15
16
  export { throttle };
16
17
 
17
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhyb3R0bGUuanMiLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzL2NvcmUvZXZlbnRpbmcvdGhyb3R0bGUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNvbnN0IHRocm90dGxlID0gPEYgZXh0ZW5kcyAoLi4uYXJnczogYW55W10pID0+IGFueT4oXG4gIGZ1bmM6IEYsXG4gIGRlbGF5OiBudW1iZXIsXG4pOiAoKC4uLmFyZ3M6IFBhcmFtZXRlcnM8Rj4pID0+IFByb21pc2U8UmV0dXJuVHlwZTxGPj4pID0+IHtcbiAgbGV0IHNob3VsZFdhaXQgPSBmYWxzZTtcblxuICBjb25zdCB0aHJvdHRsZWQgPSAoLi4uYXJnczogUGFyYW1ldGVyczxGPik6IGFueSA9PiB7XG4gICAgaWYgKHNob3VsZFdhaXQpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG4gICAgZnVuYyguLi5hcmdzKTtcbiAgICBzaG91bGRXYWl0ID0gdHJ1ZTtcbiAgICBzZXRUaW1lb3V0KCgpID0+IHtcbiAgICAgIHNob3VsZFdhaXQgPSBmYWxzZTtcbiAgICB9LCBkZWxheSk7XG4gIH07XG5cbiAgcmV0dXJuIHRocm90dGxlZCBhcyAoLi4uYXJnczogUGFyYW1ldGVyczxGPikgPT4gUmV0dXJuVHlwZTxGPjtcbn07XG4iXSwibWFwcGluZ3MiOiI7QUFBQSxJQUFhLFlBQ1gsTUFDQSxVQUN3RDtDQUN4RCxJQUFJLGFBQWE7Q0FFakIsTUFBTSxhQUFhLEdBQUcsU0FBNEI7QUFDaEQsTUFBSSxXQUNGO0FBRUYsT0FBSyxHQUFHLEtBQUs7QUFDYixlQUFhO0FBQ2IsbUJBQWdCO0FBQ2QsZ0JBQWE7S0FDWixNQUFNOztBQUdYLFFBQU8ifQ==
18
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhyb3R0bGUuanMiLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzL2NvcmUvZXZlbnRpbmcvdGhyb3R0bGUudHMiXSwic291cmNlc0NvbnRlbnQiOlsiLyoqIEBkZXByZWNhdGVkICovXG5leHBvcnQgY29uc3QgdGhyb3R0bGUgPSA8RiBleHRlbmRzICguLi5hcmdzOiBhbnlbXSkgPT4gYW55PihcbiAgZnVuYzogRixcbiAgZGVsYXk6IG51bWJlcixcbik6ICgoLi4uYXJnczogUGFyYW1ldGVyczxGPikgPT4gUHJvbWlzZTxSZXR1cm5UeXBlPEY+PikgPT4ge1xuICBsZXQgc2hvdWxkV2FpdCA9IGZhbHNlO1xuXG4gIGNvbnN0IHRocm90dGxlZCA9ICguLi5hcmdzOiBQYXJhbWV0ZXJzPEY+KTogYW55ID0+IHtcbiAgICBpZiAoc2hvdWxkV2FpdCkge1xuICAgICAgcmV0dXJuO1xuICAgIH1cbiAgICBmdW5jKC4uLmFyZ3MpO1xuICAgIHNob3VsZFdhaXQgPSB0cnVlO1xuICAgIHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgc2hvdWxkV2FpdCA9IGZhbHNlO1xuICAgIH0sIGRlbGF5KTtcbiAgfTtcblxuICByZXR1cm4gdGhyb3R0bGVkIGFzICguLi5hcmdzOiBQYXJhbWV0ZXJzPEY+KSA9PiBSZXR1cm5UeXBlPEY+O1xufTtcbiJdLCJtYXBwaW5ncyI6Ijs7QUFDQSxJQUFhLFlBQ1gsTUFDQSxVQUN3RDtDQUN4RCxJQUFJLGFBQWE7Q0FFakIsTUFBTSxhQUFhLEdBQUcsU0FBNEI7QUFDaEQsTUFBSSxXQUNGO0FBRUYsT0FBSyxHQUFHLEtBQUs7QUFDYixlQUFhO0FBQ2IsbUJBQWdCO0FBQ2QsZ0JBQWE7S0FDWixNQUFNOztBQUdYLFFBQU8ifQ==
@@ -0,0 +1,270 @@
1
+ import { __esDecorate, __runInitializers } from "tslib";
2
+ import { html, unsafeCSS } from "lit";
3
+ import { property } from "lit/decorators.js";
4
+ import { SbbElement, boxSizingStyles, forceType, getNextElementIndex, isArrowKeyPressed, isLean, ɵstateController } from "./core.js";
5
+ import { ResizeController } from "@lit-labs/observers/resize-controller.js";
6
+ import { ref } from "lit/directives/ref.js";
7
+ import { tabGroupCommonStyles } from "./tabs/common/styles.js";
8
+ //#region src/elements/tabs/tab-group/tab-group.scss?inline
9
+ 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}";
10
+ //#endregion
11
+ //#region src/elements/tabs/tab-group/tab-group.component.ts
12
+ /**
13
+ * It displays one or more tabs, each one with a label and some content.
14
+ *
15
+ * @slot - Use the unnamed slot to add content to the `sbb-tab-group` via `sbb-tab-label` and `sbb-tab` instances.
16
+ * @event {CustomEvent<SbbTabChangedEventDetails>} tabchange - The tabchange event is dispatched when a tab is selected.
17
+ */
18
+ var SbbTabGroupElement = (() => {
19
+ let _classSuper = SbbElement;
20
+ let _size_decorators;
21
+ let _size_initializers = [];
22
+ let _size_extraInitializers = [];
23
+ let _initialSelectedIndex_decorators;
24
+ let _initialSelectedIndex_initializers = [];
25
+ let _initialSelectedIndex_extraInitializers = [];
26
+ let _fixedHeight_decorators;
27
+ let _fixedHeight_initializers = [];
28
+ let _fixedHeight_extraInitializers = [];
29
+ return class SbbTabGroupElement extends _classSuper {
30
+ static {
31
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
32
+ _size_decorators = [property()];
33
+ _initialSelectedIndex_decorators = [forceType(), property({
34
+ attribute: "initial-selected-index",
35
+ type: Number
36
+ })];
37
+ _fixedHeight_decorators = [forceType(), property({
38
+ attribute: "fixed-height",
39
+ type: Boolean,
40
+ reflect: true
41
+ })];
42
+ __esDecorate(this, null, _size_decorators, {
43
+ kind: "accessor",
44
+ name: "size",
45
+ static: false,
46
+ private: false,
47
+ access: {
48
+ has: (obj) => "size" in obj,
49
+ get: (obj) => obj.size,
50
+ set: (obj, value) => {
51
+ obj.size = value;
52
+ }
53
+ },
54
+ metadata: _metadata
55
+ }, _size_initializers, _size_extraInitializers);
56
+ __esDecorate(this, null, _initialSelectedIndex_decorators, {
57
+ kind: "accessor",
58
+ name: "initialSelectedIndex",
59
+ static: false,
60
+ private: false,
61
+ access: {
62
+ has: (obj) => "initialSelectedIndex" in obj,
63
+ get: (obj) => obj.initialSelectedIndex,
64
+ set: (obj, value) => {
65
+ obj.initialSelectedIndex = value;
66
+ }
67
+ },
68
+ metadata: _metadata
69
+ }, _initialSelectedIndex_initializers, _initialSelectedIndex_extraInitializers);
70
+ __esDecorate(this, null, _fixedHeight_decorators, {
71
+ kind: "accessor",
72
+ name: "fixedHeight",
73
+ static: false,
74
+ private: false,
75
+ access: {
76
+ has: (obj) => "fixedHeight" in obj,
77
+ get: (obj) => obj.fixedHeight,
78
+ set: (obj, value) => {
79
+ obj.fixedHeight = value;
80
+ }
81
+ },
82
+ metadata: _metadata
83
+ }, _fixedHeight_initializers, _fixedHeight_extraInitializers);
84
+ if (_metadata) Object.defineProperty(this, Symbol.metadata, {
85
+ enumerable: true,
86
+ configurable: true,
87
+ writable: true,
88
+ value: _metadata
89
+ });
90
+ }
91
+ static {
92
+ this.elementName = "sbb-tab-group";
93
+ }
94
+ static {
95
+ this.styles = [
96
+ boxSizingStyles,
97
+ tabGroupCommonStyles,
98
+ unsafeCSS(tab_group_default)
99
+ ];
100
+ }
101
+ static {
102
+ this.events = { tabchange: "tabchange" };
103
+ }
104
+ #size_accessor_storage;
105
+ /**
106
+ * Size variant, either s, l or xl.
107
+ * @default 'l' / 's' (lean)
108
+ */
109
+ get size() {
110
+ return this.#size_accessor_storage;
111
+ }
112
+ set size(value) {
113
+ this.#size_accessor_storage = value;
114
+ }
115
+ #initialSelectedIndex_accessor_storage;
116
+ /**
117
+ * Sets the initial tab. If it matches a disabled tab or exceeds the length of
118
+ * the tab group, the first enabled tab will be selected.
119
+ */
120
+ get initialSelectedIndex() {
121
+ return this.#initialSelectedIndex_accessor_storage;
122
+ }
123
+ set initialSelectedIndex(value) {
124
+ this.#initialSelectedIndex_accessor_storage = value;
125
+ }
126
+ #fixedHeight_accessor_storage;
127
+ /**
128
+ * If set to true, the `sbb-tab` elements take 100% height of the `sbb-tab-group`.
129
+ * It enables controlling the height on the `sbb-tab-group` element.
130
+ * The content becomes scrollable on overflow.
131
+ */
132
+ get fixedHeight() {
133
+ return this.#fixedHeight_accessor_storage;
134
+ }
135
+ set fixedHeight(value) {
136
+ this.#fixedHeight_accessor_storage = value;
137
+ }
138
+ /** Gets the slotted `sbb-tab-label`s. */
139
+ get labels() {
140
+ /**
141
+ * The querySelector API is not used because when nested tabs are used,
142
+ * the returned array contains the inner tabs too, and this breaks the keyboard navigation.
143
+ */
144
+ return Array.from(this.children ?? []).filter((child) => /^sbb-tab-label$/u.test(child.localName));
145
+ }
146
+ /** Gets the slotted `sbb-tab`s. */
147
+ get tabs() {
148
+ /**
149
+ * The querySelector API is not used because when nested tabs are used,
150
+ * the returned array contains the inner tabs too, and this breaks the keyboard navigation.
151
+ */
152
+ return Array.from(this.children ?? []).filter((child) => /^sbb-tab$/u.test(child.localName));
153
+ }
154
+ constructor() {
155
+ super();
156
+ this._tabGroupResizeObserver = new ResizeController(this, {
157
+ target: null,
158
+ skipInitial: true,
159
+ callback: () => this._onTabGroupElementResize()
160
+ });
161
+ this.#size_accessor_storage = __runInitializers(this, _size_initializers, isLean() ? "s" : "l");
162
+ this.#initialSelectedIndex_accessor_storage = (__runInitializers(this, _size_extraInitializers), __runInitializers(this, _initialSelectedIndex_initializers, 0));
163
+ this.#fixedHeight_accessor_storage = (__runInitializers(this, _initialSelectedIndex_extraInitializers), __runInitializers(this, _fixedHeight_initializers, false));
164
+ __runInitializers(this, _fixedHeight_extraInitializers);
165
+ this.addEventListener?.("keydown", (e) => this._handleKeyDown(e));
166
+ }
167
+ firstUpdated(changedProperties) {
168
+ super.firstUpdated(changedProperties);
169
+ this.labels.forEach((tabLabel) => tabLabel["linkToTab"]());
170
+ this._initSelection();
171
+ Promise.resolve().then(() => this.internals.states.add("initialized"));
172
+ this._tabGroupResizeObserver.observe(this._tabGroupElement);
173
+ }
174
+ /**
175
+ * Disables a tab by index.
176
+ * @param index The index of the tab you want to disable.
177
+ */
178
+ disableTab(index) {
179
+ if (this.labels[index]) this.labels[index].disabled = true;
180
+ }
181
+ /**
182
+ * Enables a tab by index.
183
+ * @param index The index of the tab you want to enable.
184
+ */
185
+ enableTab(index) {
186
+ if (this.labels[index]) this.labels[index].disabled = false;
187
+ }
188
+ /**
189
+ * Activates a tab by index.
190
+ * @param index The index of the tab you want to activate.
191
+ */
192
+ activateTab(index) {
193
+ this.labels[index]?.activate();
194
+ }
195
+ _enabledTabs() {
196
+ return this.labels.filter((t) => {
197
+ customElements.upgrade(t);
198
+ return !t.disabled;
199
+ });
200
+ }
201
+ _onContentSlotChange() {
202
+ if (this._contentSlotChangeDebounceId) clearTimeout(this._contentSlotChangeDebounceId);
203
+ this._contentSlotChangeDebounceId = setTimeout(() => {
204
+ this.labels.forEach((tabLabel) => tabLabel["linkToTab"]());
205
+ this.labels.find((tabLabel) => tabLabel.active)?.activate();
206
+ }, 150);
207
+ }
208
+ _onLabelSlotChange() {
209
+ this.labels.forEach((tabLabel) => tabLabel["linkToTab"]());
210
+ this._ensureActiveTab();
211
+ }
212
+ _ensureActiveTab() {
213
+ if (this.internals.states.has("initialized") && !this.labels.some((tabLabel) => tabLabel.active)) this._initSelection();
214
+ }
215
+ _initSelection() {
216
+ const selectedTabLabel = this.labels[this.initialSelectedIndex];
217
+ if (selectedTabLabel) {
218
+ customElements.upgrade(selectedTabLabel);
219
+ if (this.initialSelectedIndex >= 0 && this.initialSelectedIndex < this.labels.length && !selectedTabLabel.disabled) {
220
+ selectedTabLabel.activate();
221
+ return;
222
+ }
223
+ }
224
+ this._enabledTabs()[0]?.activate();
225
+ }
226
+ _onTabGroupElementResize() {
227
+ const tabLabels = this.labels;
228
+ tabLabels.forEach((tabLabel) => {
229
+ ɵstateController(tabLabel)?.toggle("has-divider", tabLabel === tabLabels[0] || tabLabel.offsetLeft === tabLabels[0].offsetLeft);
230
+ });
231
+ this.style.setProperty("--sbb-tab-group-width", `${this._tabGroupElement.clientWidth}px`);
232
+ }
233
+ _handleKeyDown(evt) {
234
+ const enabledTabs = this._enabledTabs();
235
+ if (!enabledTabs || evt.target !== this && evt.target.parentElement !== this) return;
236
+ if (isArrowKeyPressed(evt)) {
237
+ const nextIndex = getNextElementIndex(evt, enabledTabs.findIndex((t) => t.active), enabledTabs.length);
238
+ enabledTabs[nextIndex]?.activate();
239
+ enabledTabs[nextIndex]?.focus();
240
+ evt.preventDefault();
241
+ }
242
+ }
243
+ /**
244
+ * @internal
245
+ */
246
+ setTabContentHeight(contentHeight) {
247
+ this.style.setProperty("--sbb-tab-content-height", `${contentHeight}px`);
248
+ }
249
+ render() {
250
+ return html`
251
+ <div
252
+ class="sbb-tab-group"
253
+ role="tablist"
254
+ ${ref((el) => this._tabGroupElement = el)}
255
+ >
256
+ <slot name="tab-bar" @slotchange=${this._onLabelSlotChange}></slot>
257
+ </div>
258
+ ${!this.fixedHeight ? html`
259
+ <div class="sbb-tab-group-content">
260
+ <slot @slotchange=${this._onContentSlotChange}></slot>
261
+ </div>
262
+ ` : html`<slot @slotchange=${this._onContentSlotChange}></slot>`}
263
+ `;
264
+ }
265
+ };
266
+ })();
267
+ //#endregion
268
+ export { SbbTabGroupElement as t };
269
+
270
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLWdyb3VwLmNvbXBvbmVudC1EWDdCWTdYeS5qcyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZWxlbWVudHMvdGFicy90YWItZ3JvdXAvdGFiLWdyb3VwLnNjc3M/aW5saW5lIiwiLi4vLi4vLi4vc3JjL2VsZW1lbnRzL3RhYnMvdGFiLWdyb3VwL3RhYi1ncm91cC5jb21wb25lbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiQHVzZSAnLi4vLi4vY29yZS9zdHlsZXMnIGFzIHNiYjtcblxuOmhvc3Qge1xuICAtLXNiYi10YWItZ3JvdXAtYW5pbWF0aW9uLWR1cmF0aW9uOiAwcztcblxuICBnYXA6IHZhcigtLXNiYi10YWItZ3JvdXAtY29udGVudC1nYXApO1xufVxuXG46aG9zdCg6c3RhdGUoaW5pdGlhbGl6ZWQpKSB7XG4gIC0tc2JiLXRhYi1ncm91cC1hbmltYXRpb24tZHVyYXRpb246IHZhcihcbiAgICAtLXNiYi1kaXNhYmxlLWFuaW1hdGlvbi1kdXJhdGlvbixcbiAgICB2YXIoLS1zYmItYW5pbWF0aW9uLWR1cmF0aW9uLTR4KVxuICApO1xufVxuXG4uc2JiLXRhYi1ncm91cC1jb250ZW50IHtcbiAgaGVpZ2h0OiB2YXIoLS1zYmItdGFiLWNvbnRlbnQtaGVpZ2h0KTtcbiAgdHJhbnNpdGlvbjogaGVpZ2h0IHZhcigtLXNiYi10YWItZ3JvdXAtYW5pbWF0aW9uLWR1cmF0aW9uKSB2YXIoLS1zYmItYW5pbWF0aW9uLWVhc2luZyk7XG59XG5cbjo6c2xvdHRlZChzYmItdGFiKSB7XG4gIDpob3N0KFtmaXhlZC1oZWlnaHRdKSAmIHtcbiAgICBoZWlnaHQ6IDEwMCU7XG4gICAgb3ZlcmZsb3c6IGF1dG87XG4gIH1cbn1cbiIsImltcG9ydCB7IFJlc2l6ZUNvbnRyb2xsZXIgfSBmcm9tICdAbGl0LWxhYnMvb2JzZXJ2ZXJzL3Jlc2l6ZS1jb250cm9sbGVyLmpzJztcbmltcG9ydCB7XG4gIGh0bWwsXG4gIHVuc2FmZUNTUyxcbiAgdHlwZSBDU1NSZXN1bHRHcm91cCxcbiAgdHlwZSBQcm9wZXJ0eVZhbHVlcyxcbiAgdHlwZSBUZW1wbGF0ZVJlc3VsdCxcbn0gZnJvbSAnbGl0JztcbmltcG9ydCB7IHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuaW1wb3J0IHsgcmVmIH0gZnJvbSAnbGl0L2RpcmVjdGl2ZXMvcmVmLmpzJztcblxuaW1wb3J0IHtcbiAgZ2V0TmV4dEVsZW1lbnRJbmRleCxcbiAgaXNBcnJvd0tleVByZXNzZWQsXG4gIFNiYkVsZW1lbnQsXG4gIMm1c3RhdGVDb250cm9sbGVyLFxuICBmb3JjZVR5cGUsXG4gIGlzTGVhbixcbiAgYm94U2l6aW5nU3R5bGVzLFxufSBmcm9tICcuLi8uLi9jb3JlLnRzJztcbmltcG9ydCB7IHRhYkdyb3VwQ29tbW9uU3R5bGVzIH0gZnJvbSAnLi4vY29tbW9uL3N0eWxlcy50cyc7XG5pbXBvcnQgdHlwZSB7IFNiYlRhYkVsZW1lbnQgfSBmcm9tICcuLi90YWIvdGFiLmNvbXBvbmVudC50cyc7XG5pbXBvcnQgdHlwZSB7IFNiYlRhYkxhYmVsRWxlbWVudCB9IGZyb20gJy4uL3RhYi1sYWJlbC90YWItbGFiZWwuY29tcG9uZW50LnRzJztcblxuaW1wb3J0IHN0eWxlIGZyb20gJy4vdGFiLWdyb3VwLnNjc3M/aW5saW5lJztcblxuZXhwb3J0IGludGVyZmFjZSBTYmJUYWJDaGFuZ2VkRXZlbnREZXRhaWxzIHtcbiAgYWN0aXZlSW5kZXg6IG51bWJlcjtcbiAgYWN0aXZlVGFiTGFiZWw6IFNiYlRhYkxhYmVsRWxlbWVudDtcbiAgYWN0aXZlVGFiOiBTYmJUYWJFbGVtZW50O1xuICBwcmV2aW91c0luZGV4OiBudW1iZXI7XG4gIHByZXZpb3VzVGFiTGFiZWw6IFNiYlRhYkxhYmVsRWxlbWVudCB8IHVuZGVmaW5lZDtcbiAgcHJldmlvdXNUYWI6IFNiYlRhYkVsZW1lbnQgfCB1bmRlZmluZWQ7XG59XG5cbi8qKlxuICogSXQgZGlzcGxheXMgb25lIG9yIG1vcmUgdGFicywgZWFjaCBvbmUgd2l0aCBhIGxhYmVsIGFuZCBzb21lIGNvbnRlbnQuXG4gKlxuICogQHNsb3QgLSBVc2UgdGhlIHVubmFtZWQgc2xvdCB0byBhZGQgY29udGVudCB0byB0aGUgYHNiYi10YWItZ3JvdXBgIHZpYSBgc2JiLXRhYi1sYWJlbGAgYW5kIGBzYmItdGFiYCBpbnN0YW5jZXMuXG4gKiBAZXZlbnQge0N1c3RvbUV2ZW50PFNiYlRhYkNoYW5nZWRFdmVudERldGFpbHM+fSB0YWJjaGFuZ2UgLSBUaGUgdGFiY2hhbmdlIGV2ZW50IGlzIGRpc3BhdGNoZWQgd2hlbiBhIHRhYiBpcyBzZWxlY3RlZC5cbiAqL1xuZXhwb3J0IGNsYXNzIFNiYlRhYkdyb3VwRWxlbWVudCBleHRlbmRzIFNiYkVsZW1lbnQge1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHJlYWRvbmx5IGVsZW1lbnROYW1lOiBzdHJpbmcgPSAnc2JiLXRhYi1ncm91cCc7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IFtcbiAgICBib3hTaXppbmdTdHlsZXMsXG4gICAgdGFiR3JvdXBDb21tb25TdHlsZXMsXG4gICAgdW5zYWZlQ1NTKHN0eWxlKSxcbiAgXTtcbiAgcHVibGljIHN0YXRpYyByZWFkb25seSBldmVudHMgPSB7XG4gICAgdGFiY2hhbmdlOiAndGFiY2hhbmdlJyxcbiAgfSBhcyBjb25zdDtcblxuICBwcml2YXRlIF90YWJHcm91cEVsZW1lbnQhOiBIVE1MRWxlbWVudDtcbiAgcHJpdmF0ZSBfdGFiR3JvdXBSZXNpemVPYnNlcnZlciA9IG5ldyBSZXNpemVDb250cm9sbGVyKHRoaXMsIHtcbiAgICB0YXJnZXQ6IG51bGwsXG4gICAgc2tpcEluaXRpYWw6IHRydWUsXG4gICAgY2FsbGJhY2s6ICgpID0+IHRoaXMuX29uVGFiR3JvdXBFbGVtZW50UmVzaXplKCksXG4gIH0pO1xuICBwcml2YXRlIF9jb250ZW50U2xvdENoYW5nZURlYm91bmNlSWQ/OiBSZXR1cm5UeXBlPHR5cGVvZiBzZXRUaW1lb3V0PjtcblxuICAvKipcbiAgICogU2l6ZSB2YXJpYW50LCBlaXRoZXIgcywgbCBvciB4bC5cbiAgICogQGRlZmF1bHQgJ2wnIC8gJ3MnIChsZWFuKVxuICAgKi9cbiAgQHByb3BlcnR5KClcbiAgcHVibGljIGFjY2Vzc29yIHNpemU6ICdzJyB8ICdsJyB8ICd4bCcgPSBpc0xlYW4oKSA/ICdzJyA6ICdsJztcblxuICAvKipcbiAgICogU2V0cyB0aGUgaW5pdGlhbCB0YWIuIElmIGl0IG1hdGNoZXMgYSBkaXNhYmxlZCB0YWIgb3IgZXhjZWVkcyB0aGUgbGVuZ3RoIG9mXG4gICAqIHRoZSB0YWIgZ3JvdXAsIHRoZSBmaXJzdCBlbmFibGVkIHRhYiB3aWxsIGJlIHNlbGVjdGVkLlxuICAgKi9cbiAgQGZvcmNlVHlwZSgpXG4gIEBwcm9wZXJ0eSh7IGF0dHJpYnV0ZTogJ2luaXRpYWwtc2VsZWN0ZWQtaW5kZXgnLCB0eXBlOiBOdW1iZXIgfSlcbiAgcHVibGljIGFjY2Vzc29yIGluaXRpYWxTZWxlY3RlZEluZGV4OiBudW1iZXIgPSAwO1xuXG4gIC8qKlxuICAgKiBJZiBzZXQgdG8gdHJ1ZSwgdGhlIGBzYmItdGFiYCBlbGVtZW50cyB0YWtlIDEwMCUgaGVpZ2h0IG9mIHRoZSBgc2JiLXRhYi1ncm91cGAuXG4gICAqIEl0IGVuYWJsZXMgY29udHJvbGxpbmcgdGhlIGhlaWdodCBvbiB0aGUgYHNiYi10YWItZ3JvdXBgIGVsZW1lbnQuXG4gICAqIFRoZSBjb250ZW50IGJlY29tZXMgc2Nyb2xsYWJsZSBvbiBvdmVyZmxvdy5cbiAgICovXG4gIEBmb3JjZVR5cGUoKVxuICBAcHJvcGVydHkoeyBhdHRyaWJ1dGU6ICdmaXhlZC1oZWlnaHQnLCB0eXBlOiBCb29sZWFuLCByZWZsZWN0OiB0cnVlIH0pXG4gIHB1YmxpYyBhY2Nlc3NvciBmaXhlZEhlaWdodDogYm9vbGVhbiA9IGZhbHNlO1xuXG4gIC8qKiBHZXRzIHRoZSBzbG90dGVkIGBzYmItdGFiLWxhYmVsYHMuICovXG4gIHB1YmxpYyBnZXQgbGFiZWxzKCk6IFNiYlRhYkxhYmVsRWxlbWVudFtdIHtcbiAgICAvKipcbiAgICAgKiBUaGUgcXVlcnlTZWxlY3RvciBBUEkgaXMgbm90IHVzZWQgYmVjYXVzZSB3aGVuIG5lc3RlZCB0YWJzIGFyZSB1c2VkLFxuICAgICAqIHRoZSByZXR1cm5lZCBhcnJheSBjb250YWlucyB0aGUgaW5uZXIgdGFicyB0b28sIGFuZCB0aGlzIGJyZWFrcyB0aGUga2V5Ym9hcmQgbmF2aWdhdGlvbi5cbiAgICAgKi9cbiAgICByZXR1cm4gQXJyYXkuZnJvbSh0aGlzLmNoaWxkcmVuID8/IFtdKS5maWx0ZXIoKGNoaWxkKSA9PlxuICAgICAgL15zYmItdGFiLWxhYmVsJC91LnRlc3QoY2hpbGQubG9jYWxOYW1lKSxcbiAgICApIGFzIFNiYlRhYkxhYmVsRWxlbWVudFtdO1xuICB9XG5cbiAgLyoqIEdldHMgdGhlIHNsb3R0ZWQgYHNiYi10YWJgcy4gKi9cbiAgcHVibGljIGdldCB0YWJzKCk6IFNiYlRhYkVsZW1lbnRbXSB7XG4gICAgLyoqXG4gICAgICogVGhlIHF1ZXJ5U2VsZWN0b3IgQVBJIGlzIG5vdCB1c2VkIGJlY2F1c2Ugd2hlbiBuZXN0ZWQgdGFicyBhcmUgdXNlZCxcbiAgICAgKiB0aGUgcmV0dXJuZWQgYXJyYXkgY29udGFpbnMgdGhlIGlubmVyIHRhYnMgdG9vLCBhbmQgdGhpcyBicmVha3MgdGhlIGtleWJvYXJkIG5hdmlnYXRpb24uXG4gICAgICovXG4gICAgcmV0dXJuIEFycmF5LmZyb20odGhpcy5jaGlsZHJlbiA/PyBbXSkuZmlsdGVyKChjaGlsZCkgPT5cbiAgICAgIC9ec2JiLXRhYiQvdS50ZXN0KGNoaWxkLmxvY2FsTmFtZSksXG4gICAgKSBhcyBTYmJUYWJFbGVtZW50W107XG4gIH1cblxuICBwdWJsaWMgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoKTtcbiAgICB0aGlzLmFkZEV2ZW50TGlzdGVuZXI/Ligna2V5ZG93bicsIChlKSA9PiB0aGlzLl9oYW5kbGVLZXlEb3duKGUpKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBvdmVycmlkZSBmaXJzdFVwZGF0ZWQoY2hhbmdlZFByb3BlcnRpZXM6IFByb3BlcnR5VmFsdWVzPHRoaXM+KTogdm9pZCB7XG4gICAgc3VwZXIuZmlyc3RVcGRhdGVkKGNoYW5nZWRQcm9wZXJ0aWVzKTtcblxuICAgIHRoaXMubGFiZWxzLmZvckVhY2goKHRhYkxhYmVsKSA9PiB0YWJMYWJlbFsnbGlua1RvVGFiJ10oKSk7XG4gICAgdGhpcy5faW5pdFNlbGVjdGlvbigpO1xuXG4gICAgLy8gVG8gYXZvaWQgYW5pbWF0aW9ucyBvbiBpbml0aWFsaXphdGlvbiwgd2UgaGF2ZSB0byBtYXJrIHRoZSBjb21wb25lbnQgYXMgaW5pdGlhbGl6ZWQgYW5kIHdhaXQgYSB0aWNrLlxuICAgIFByb21pc2UucmVzb2x2ZSgpLnRoZW4oKCkgPT4gdGhpcy5pbnRlcm5hbHMuc3RhdGVzLmFkZCgnaW5pdGlhbGl6ZWQnKSk7XG4gICAgdGhpcy5fdGFiR3JvdXBSZXNpemVPYnNlcnZlci5vYnNlcnZlKHRoaXMuX3RhYkdyb3VwRWxlbWVudCk7XG4gIH1cblxuICAvKipcbiAgICogRGlzYWJsZXMgYSB0YWIgYnkgaW5kZXguXG4gICAqIEBwYXJhbSBpbmRleCBUaGUgaW5kZXggb2YgdGhlIHRhYiB5b3Ugd2FudCB0byBkaXNhYmxlLlxuICAgKi9cbiAgcHVibGljIGRpc2FibGVUYWIoaW5kZXg6IG51bWJlcik6IHZvaWQge1xuICAgIGlmICh0aGlzLmxhYmVsc1tpbmRleF0pIHtcbiAgICAgIHRoaXMubGFiZWxzW2luZGV4XS5kaXNhYmxlZCA9IHRydWU7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIEVuYWJsZXMgYSB0YWIgYnkgaW5kZXguXG4gICAqIEBwYXJhbSBpbmRleCBUaGUgaW5kZXggb2YgdGhlIHRhYiB5b3Ugd2FudCB0byBlbmFibGUuXG4gICAqL1xuICBwdWJsaWMgZW5hYmxlVGFiKGluZGV4OiBudW1iZXIpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5sYWJlbHNbaW5kZXhdKSB7XG4gICAgICB0aGlzLmxhYmVsc1tpbmRleF0uZGlzYWJsZWQgPSBmYWxzZTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogQWN0aXZhdGVzIGEgdGFiIGJ5IGluZGV4LlxuICAgKiBAcGFyYW0gaW5kZXggVGhlIGluZGV4IG9mIHRoZSB0YWIgeW91IHdhbnQgdG8gYWN0aXZhdGUuXG4gICAqL1xuICBwdWJsaWMgYWN0aXZhdGVUYWIoaW5kZXg6IG51bWJlcik6IHZvaWQge1xuICAgIHRoaXMubGFiZWxzW2luZGV4XT8uYWN0aXZhdGUoKTtcbiAgfVxuXG4gIHByaXZhdGUgX2VuYWJsZWRUYWJzKCk6IFNiYlRhYkxhYmVsRWxlbWVudFtdIHtcbiAgICByZXR1cm4gdGhpcy5sYWJlbHMuZmlsdGVyKCh0KSA9PiB7XG4gICAgICBjdXN0b21FbGVtZW50cy51cGdyYWRlKHQpO1xuICAgICAgcmV0dXJuICF0LmRpc2FibGVkO1xuICAgIH0pO1xuICB9XG5cbiAgcHJpdmF0ZSBfb25Db250ZW50U2xvdENoYW5nZSgpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5fY29udGVudFNsb3RDaGFuZ2VEZWJvdW5jZUlkKSB7XG4gICAgICBjbGVhclRpbWVvdXQodGhpcy5fY29udGVudFNsb3RDaGFuZ2VEZWJvdW5jZUlkKTtcbiAgICB9XG4gICAgdGhpcy5fY29udGVudFNsb3RDaGFuZ2VEZWJvdW5jZUlkID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICB0aGlzLmxhYmVscy5mb3JFYWNoKCh0YWJMYWJlbCkgPT4gdGFiTGFiZWxbJ2xpbmtUb1RhYiddKCkpO1xuICAgICAgdGhpcy5sYWJlbHMuZmluZCgodGFiTGFiZWwpID0+IHRhYkxhYmVsLmFjdGl2ZSk/LmFjdGl2YXRlKCk7XG4gICAgfSwgMTUwKTtcbiAgfVxuXG4gIHByaXZhdGUgX29uTGFiZWxTbG90Q2hhbmdlKCk6IHZvaWQge1xuICAgIHRoaXMubGFiZWxzLmZvckVhY2goKHRhYkxhYmVsKSA9PiB0YWJMYWJlbFsnbGlua1RvVGFiJ10oKSk7XG4gICAgdGhpcy5fZW5zdXJlQWN0aXZlVGFiKCk7XG4gIH1cblxuICBwcml2YXRlIF9lbnN1cmVBY3RpdmVUYWIoKTogdm9pZCB7XG4gICAgaWYgKFxuICAgICAgdGhpcy5pbnRlcm5hbHMuc3RhdGVzLmhhcygnaW5pdGlhbGl6ZWQnKSAmJlxuICAgICAgIXRoaXMubGFiZWxzLnNvbWUoKHRhYkxhYmVsKSA9PiB0YWJMYWJlbC5hY3RpdmUpXG4gICAgKSB7XG4gICAgICB0aGlzLl9pbml0U2VsZWN0aW9uKCk7XG4gICAgfVxuICB9XG5cbiAgcHJpdmF0ZSBfaW5pdFNlbGVjdGlvbigpOiB2b2lkIHtcbiAgICBjb25zdCBzZWxlY3RlZFRhYkxhYmVsID0gdGhpcy5sYWJlbHNbdGhpcy5pbml0aWFsU2VsZWN0ZWRJbmRleF07XG4gICAgaWYgKHNlbGVjdGVkVGFiTGFiZWwpIHtcbiAgICAgIGN1c3RvbUVsZW1lbnRzLnVwZ3JhZGUoc2VsZWN0ZWRUYWJMYWJlbCk7XG4gICAgICBpZiAoXG4gICAgICAgIHRoaXMuaW5pdGlhbFNlbGVjdGVkSW5kZXggPj0gMCAmJlxuICAgICAgICB0aGlzLmluaXRpYWxTZWxlY3RlZEluZGV4IDwgdGhpcy5sYWJlbHMubGVuZ3RoICYmXG4gICAgICAgICFzZWxlY3RlZFRhYkxhYmVsLmRpc2FibGVkXG4gICAgICApIHtcbiAgICAgICAgc2VsZWN0ZWRUYWJMYWJlbC5hY3RpdmF0ZSgpO1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG4gICAgfVxuICAgIHRoaXMuX2VuYWJsZWRUYWJzKClbMF0/LmFjdGl2YXRlKCk7XG4gIH1cblxuICBwcml2YXRlIF9vblRhYkdyb3VwRWxlbWVudFJlc2l6ZSgpOiB2b2lkIHtcbiAgICBjb25zdCB0YWJMYWJlbHMgPSB0aGlzLmxhYmVscztcbiAgICB0YWJMYWJlbHMuZm9yRWFjaCgodGFiTGFiZWwpID0+IHtcbiAgICAgIMm1c3RhdGVDb250cm9sbGVyKHRhYkxhYmVsKT8udG9nZ2xlKFxuICAgICAgICAnaGFzLWRpdmlkZXInLFxuICAgICAgICB0YWJMYWJlbCA9PT0gdGFiTGFiZWxzWzBdIHx8IHRhYkxhYmVsLm9mZnNldExlZnQgPT09IHRhYkxhYmVsc1swXS5vZmZzZXRMZWZ0LFxuICAgICAgKTtcbiAgICB9KTtcblxuICAgIHRoaXMuc3R5bGUuc2V0UHJvcGVydHkoJy0tc2JiLXRhYi1ncm91cC13aWR0aCcsIGAke3RoaXMuX3RhYkdyb3VwRWxlbWVudC5jbGllbnRXaWR0aH1weGApO1xuICB9XG5cbiAgcHJpdmF0ZSBfaGFuZGxlS2V5RG93bihldnQ6IEtleWJvYXJkRXZlbnQpOiB2b2lkIHtcbiAgICBjb25zdCBlbmFibGVkVGFiczogU2JiVGFiTGFiZWxFbGVtZW50W10gPSB0aGlzLl9lbmFibGVkVGFicygpO1xuXG4gICAgaWYgKFxuICAgICAgIWVuYWJsZWRUYWJzIHx8XG4gICAgICAvLyBkb24ndCB0cmFwIG5lc3RlZCBoYW5kbGluZ1xuICAgICAgKChldnQudGFyZ2V0IGFzIEhUTUxFbGVtZW50KSAhPT0gdGhpcyAmJiAoZXZ0LnRhcmdldCBhcyBIVE1MRWxlbWVudCkucGFyZW50RWxlbWVudCAhPT0gdGhpcylcbiAgICApIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBpZiAoaXNBcnJvd0tleVByZXNzZWQoZXZ0KSkge1xuICAgICAgY29uc3QgY3VycmVudDogbnVtYmVyID0gZW5hYmxlZFRhYnMuZmluZEluZGV4KCh0KSA9PiB0LmFjdGl2ZSk7XG4gICAgICBjb25zdCBuZXh0SW5kZXg6IG51bWJlciA9IGdldE5leHRFbGVtZW50SW5kZXgoZXZ0LCBjdXJyZW50LCBlbmFibGVkVGFicy5sZW5ndGgpO1xuICAgICAgZW5hYmxlZFRhYnNbbmV4dEluZGV4XT8uYWN0aXZhdGUoKTtcbiAgICAgIGVuYWJsZWRUYWJzW25leHRJbmRleF0/LmZvY3VzKCk7XG4gICAgICBldnQucHJldmVudERlZmF1bHQoKTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogQGludGVybmFsXG4gICAqL1xuICBwcm90ZWN0ZWQgc2V0VGFiQ29udGVudEhlaWdodChjb250ZW50SGVpZ2h0OiBudW1iZXIpOiB2b2lkIHtcbiAgICB0aGlzLnN0eWxlLnNldFByb3BlcnR5KCctLXNiYi10YWItY29udGVudC1oZWlnaHQnLCBgJHtjb250ZW50SGVpZ2h0fXB4YCk7XG4gIH1cblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGBcbiAgICAgIDxkaXZcbiAgICAgICAgY2xhc3M9XCJzYmItdGFiLWdyb3VwXCJcbiAgICAgICAgcm9sZT1cInRhYmxpc3RcIlxuICAgICAgICAke3JlZigoZWw/OiBFbGVtZW50KSA9PiAodGhpcy5fdGFiR3JvdXBFbGVtZW50ID0gZWwgYXMgSFRNTEVsZW1lbnQpKX1cbiAgICAgID5cbiAgICAgICAgPHNsb3QgbmFtZT1cInRhYi1iYXJcIiBAc2xvdGNoYW5nZT0ke3RoaXMuX29uTGFiZWxTbG90Q2hhbmdlfT48L3Nsb3Q+XG4gICAgICA8L2Rpdj5cbiAgICAgICR7IXRoaXMuZml4ZWRIZWlnaHRcbiAgICAgICAgPyBodG1sYFxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cInNiYi10YWItZ3JvdXAtY29udGVudFwiPlxuICAgICAgICAgICAgICA8c2xvdCBAc2xvdGNoYW5nZT0ke3RoaXMuX29uQ29udGVudFNsb3RDaGFuZ2V9Pjwvc2xvdD5cbiAgICAgICAgICAgIDwvZGl2PlxuICAgICAgICAgIGBcbiAgICAgICAgOiBodG1sYDxzbG90IEBzbG90Y2hhbmdlPSR7dGhpcy5fb25Db250ZW50U2xvdENoYW5nZX0+PC9zbG90PmB9XG4gICAgYDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLXRhYi1ncm91cCc6IFNiYlRhYkdyb3Vw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
@@ -24,6 +24,7 @@ export declare class SbbTabGroupElement extends SbbElement {
24
24
  };
25
25
  private _tabGroupElement;
26
26
  private _tabGroupResizeObserver;
27
+ private _contentSlotChangeDebounceId?;
27
28
  /**
28
29
  * Size variant, either s, l or xl.
29
30
  * @default 'l' / 's' (lean)
@@ -1 +1 @@
1
- {"version":3,"file":"tab-group.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/tabs/tab-group/tab-group.component.ts"],"names":[],"mappings":"AACA,OAAO,EAGL,KAAK,cAAc,EACnB,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAIb,OAAO,EAGL,UAAU,EAMX,MAAM,eAAe,CAAC;AAEvB,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AAI9E,MAAM,WAAW,yBAAyB;IACxC,WAAW,EAAE,MAAM,CAAC;IACpB,cAAc,EAAE,kBAAkB,CAAC;IACnC,SAAS,EAAE,aAAa,CAAC;IACzB,aAAa,EAAE,MAAM,CAAC;IACtB,gBAAgB,EAAE,kBAAkB,GAAG,SAAS,CAAC;IACjD,WAAW,EAAE,aAAa,GAAG,SAAS,CAAC;CACxC;AAED;;;;;GAKG;AACH,qBAAa,kBAAmB,SAAQ,UAAU;IAChD,gBAAgC,WAAW,EAAE,MAAM,CAAmB;IACtE,OAAuB,MAAM,EAAE,cAAc,CAI3C;IACF,gBAAuB,MAAM;;MAElB;IAEX,OAAO,CAAC,gBAAgB,CAAe;IACvC,OAAO,CAAC,uBAAuB,CAI5B;IAEH;;;OAGG;IACH,SACgB,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAwB;IAE9D;;;OAGG;IACH,SAEgB,oBAAoB,EAAE,MAAM,CAAK;IAEjD;;;;OAIG;IACH,SAEgB,WAAW,EAAE,OAAO,CAAS;IAE7C,yCAAyC;IACzC,IAAW,MAAM,IAAI,kBAAkB,EAAE,CAQxC;IAED,mCAAmC;IACnC,IAAW,IAAI,IAAI,aAAa,EAAE,CAQjC;;cAOkB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAW9E;;;OAGG;IACI,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAMtC;;;OAGG;IACI,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAMrC;;;OAGG;IACI,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAIvC,OAAO,CAAC,YAAY;IAOpB,OAAO,CAAC,oBAAoB,CAG1B;IAEF,OAAO,CAAC,kBAAkB,CAGxB;IAEF,OAAO,CAAC,gBAAgB;IASxB,OAAO,CAAC,cAAc;IAgBtB,OAAO,CAAC,wBAAwB;IAYhC,OAAO,CAAC,cAAc;IAoBtB;;OAEG;IACH,SAAS,CAAC,mBAAmB,CAAC,aAAa,EAAE,MAAM,GAAG,IAAI;cAIvC,MAAM,IAAI,cAAc;CAkB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,eAAe,EAAE,kBAAkB,CAAC;KACrC;CACF"}
1
+ {"version":3,"file":"tab-group.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/tabs/tab-group/tab-group.component.ts"],"names":[],"mappings":"AACA,OAAO,EAGL,KAAK,cAAc,EACnB,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAIb,OAAO,EAGL,UAAU,EAKX,MAAM,eAAe,CAAC;AAEvB,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-C3R8ZTbg.js";
1
+ import { t as SbbTabGroupElement } from "../../tab-group.component-DX7BY7Xy.js";
2
2
  export { SbbTabGroupElement };
@@ -1,4 +1,4 @@
1
- import { t as SbbTabGroupElement } from "./tab-group.component-C3R8ZTbg.js";
1
+ import { t as SbbTabGroupElement } from "./tab-group.component-DX7BY7Xy.js";
2
2
  import { t as SbbTabLabelElement } from "./tab-label.component-Du1W0dxN.js";
3
3
  import { t as SbbTabNavBarElement } from "./tab-nav-bar.component-BTPTHy2C.js";
4
4
  import { t as SbbTabElement } from "./tab.component-DteuwiHv.js";
@@ -1,4 +1,4 @@
1
- import { t as SbbTabGroupElement } from "./tab-group.component-C3R8ZTbg.js";
1
+ import { t as SbbTabGroupElement } from "./tab-group.component-DX7BY7Xy.js";
2
2
  import { t as SbbTabLabelElement } from "./tab-label.component-Du1W0dxN.js";
3
3
  import { t as SbbTabNavBarElement } from "./tab-nav-bar.component-BTPTHy2C.js";
4
4
  import { t as SbbTabElement } from "./tab.component-DteuwiHv.js";
package/package.json CHANGED
@@ -1,12 +1,12 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements-dev",
3
- "version": "5.0.0-next-dev.1776267015",
3
+ "version": "5.0.0-next-dev.1776331625",
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/424c8e443067a7991229766ac495c300a6e27e6e"
9
+ "https://github.com/sbb-design-systems/lyne-components/commit/f9d206a39efc5eadc61b7a8ab41ccf40ae5c248d"
10
10
  ],
11
11
  "type": "module",
12
12
  "exports": {
@@ -1,24 +1,24 @@
1
1
  import { __esDecorate as e, __runInitializers as t } from "tslib";
2
2
  import { html as n, unsafeCSS as r } from "lit";
3
3
  import { property as i } from "lit/decorators.js";
4
- import { SbbElement as a, boxSizingStyles as o, forceType as s, getNextElementIndex as c, isArrowKeyPressed as l, isLean as u, throttle as d, ɵstateController as f } from "./core.js";
5
- import { ResizeController as p } from "@lit-labs/observers/resize-controller.js";
6
- import { ref as m } from "lit/directives/ref.js";
7
- import { tabGroupCommonStyles as h } from "./tabs/common/styles.js";
4
+ import { SbbElement as a, boxSizingStyles as o, forceType as s, getNextElementIndex as c, isArrowKeyPressed as l, isLean as u, ɵstateController as d } from "./core.js";
5
+ import { ResizeController as f } from "@lit-labs/observers/resize-controller.js";
6
+ import { ref as p } from "lit/directives/ref.js";
7
+ import { tabGroupCommonStyles as m } from "./tabs/common/styles.js";
8
8
  //#region src/elements/tabs/tab-group/tab-group.scss?inline
9
- var g = ":host{--sbb-tab-group-animation-duration: 0s;gap:var(--sbb-tab-group-content-gap)}:host(:is(:state(initialized),[state--initialized])){--sbb-tab-group-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-4x) )}.sbb-tab-group-content{height:var(--sbb-tab-content-height);transition:height var(--sbb-tab-group-animation-duration) var(--sbb-animation-easing)}:host([fixed-height]) ::slotted(sbb-tab){height:100%;overflow:auto}", _ = (() => {
10
- let _ = a, v, y = [], b = [], x, S = [], C = [], w, T = [], E = [];
11
- return class extends _ {
9
+ 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 = (() => {
10
+ let g = a, _, v = [], y = [], b, x = [], S = [], C, w = [], T = [];
11
+ return class extends g {
12
12
  static {
13
- let t = typeof Symbol == "function" && Symbol.metadata ? Object.create(_[Symbol.metadata] ?? null) : void 0;
14
- v = [i()], x = [s(), i({
13
+ let t = typeof Symbol == "function" && Symbol.metadata ? Object.create(g[Symbol.metadata] ?? null) : void 0;
14
+ _ = [i()], b = [s(), i({
15
15
  attribute: "initial-selected-index",
16
16
  type: Number
17
- })], w = [s(), i({
17
+ })], C = [s(), i({
18
18
  attribute: "fixed-height",
19
19
  type: Boolean,
20
20
  reflect: !0
21
- })], e(this, null, v, {
21
+ })], e(this, null, _, {
22
22
  kind: "accessor",
23
23
  name: "size",
24
24
  static: !1,
@@ -31,7 +31,7 @@ var g = ":host{--sbb-tab-group-animation-duration: 0s;gap:var(--sbb-tab-group-co
31
31
  }
32
32
  },
33
33
  metadata: t
34
- }, y, b), e(this, null, x, {
34
+ }, v, y), e(this, null, b, {
35
35
  kind: "accessor",
36
36
  name: "initialSelectedIndex",
37
37
  static: !1,
@@ -44,7 +44,7 @@ var g = ":host{--sbb-tab-group-animation-duration: 0s;gap:var(--sbb-tab-group-co
44
44
  }
45
45
  },
46
46
  metadata: t
47
- }, S, C), e(this, null, w, {
47
+ }, x, S), e(this, null, C, {
48
48
  kind: "accessor",
49
49
  name: "fixedHeight",
50
50
  static: !1,
@@ -57,7 +57,7 @@ var g = ":host{--sbb-tab-group-animation-duration: 0s;gap:var(--sbb-tab-group-co
57
57
  }
58
58
  },
59
59
  metadata: t
60
- }, T, E), t && Object.defineProperty(this, Symbol.metadata, {
60
+ }, w, T), t && Object.defineProperty(this, Symbol.metadata, {
61
61
  enumerable: !0,
62
62
  configurable: !0,
63
63
  writable: !0,
@@ -70,8 +70,8 @@ var g = ":host{--sbb-tab-group-animation-duration: 0s;gap:var(--sbb-tab-group-co
70
70
  static {
71
71
  this.styles = [
72
72
  o,
73
- h,
74
- r(g)
73
+ m,
74
+ r(h)
75
75
  ];
76
76
  }
77
77
  static {
@@ -105,15 +105,11 @@ var g = ":host{--sbb-tab-group-animation-duration: 0s;gap:var(--sbb-tab-group-co
105
105
  return Array.from(this.children ?? []).filter((e) => /^sbb-tab$/u.test(e.localName));
106
106
  }
107
107
  constructor() {
108
- super(), this._tabGroupResizeObserver = new p(this, {
108
+ super(), this._tabGroupResizeObserver = new f(this, {
109
109
  target: null,
110
110
  skipInitial: !0,
111
111
  callback: () => this._onTabGroupElementResize()
112
- }), this.#e = t(this, y, u() ? "s" : "l"), this.#t = (t(this, b), t(this, S, 0)), this.#n = (t(this, C), t(this, T, !1)), this._onContentSlotChange = (t(this, E), () => {
113
- this.labels.forEach((e) => e.linkToTab()), this.labels.find((e) => e.active)?.activate();
114
- }), this._onLabelSlotChange = () => {
115
- this.labels.forEach((e) => e.linkToTab()), this._ensureActiveTab();
116
- }, this.addEventListener?.("keydown", (e) => this._handleKeyDown(e));
112
+ }), this.#e = t(this, v, u() ? "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));
117
113
  }
118
114
  firstUpdated(e) {
119
115
  super.firstUpdated(e), this.labels.forEach((e) => e.linkToTab()), this._initSelection(), Promise.resolve().then(() => this.internals.states.add("initialized")), this._tabGroupResizeObserver.observe(this._tabGroupElement);
@@ -130,6 +126,14 @@ var g = ":host{--sbb-tab-group-animation-duration: 0s;gap:var(--sbb-tab-group-co
130
126
  _enabledTabs() {
131
127
  return this.labels.filter((e) => (customElements.upgrade(e), !e.disabled));
132
128
  }
129
+ _onContentSlotChange() {
130
+ this._contentSlotChangeDebounceId && clearTimeout(this._contentSlotChangeDebounceId), this._contentSlotChangeDebounceId = setTimeout(() => {
131
+ this.labels.forEach((e) => e.linkToTab()), this.labels.find((e) => e.active)?.activate();
132
+ }, 150);
133
+ }
134
+ _onLabelSlotChange() {
135
+ this.labels.forEach((e) => e.linkToTab()), this._ensureActiveTab();
136
+ }
133
137
  _ensureActiveTab() {
134
138
  this.internals.states.has("initialized") && !this.labels.some((e) => e.active) && this._initSelection();
135
139
  }
@@ -144,7 +148,7 @@ var g = ":host{--sbb-tab-group-animation-duration: 0s;gap:var(--sbb-tab-group-co
144
148
  _onTabGroupElementResize() {
145
149
  let e = this.labels;
146
150
  e.forEach((t) => {
147
- f(t)?.toggle("has-divider", t === e[0] || t.offsetLeft === e[0].offsetLeft);
151
+ d(t)?.toggle("has-divider", t === e[0] || t.offsetLeft === e[0].offsetLeft);
148
152
  }), this.style.setProperty("--sbb-tab-group-width", `${this._tabGroupElement.clientWidth}px`);
149
153
  }
150
154
  _handleKeyDown(e) {
@@ -162,13 +166,13 @@ var g = ":host{--sbb-tab-group-animation-duration: 0s;gap:var(--sbb-tab-group-co
162
166
  <div
163
167
  class="sbb-tab-group"
164
168
  role="tablist"
165
- ${m((e) => this._tabGroupElement = e)}
169
+ ${p((e) => this._tabGroupElement = e)}
166
170
  >
167
171
  <slot name="tab-bar" @slotchange=${this._onLabelSlotChange}></slot>
168
172
  </div>
169
- ${this.fixedHeight ? n`<slot @slotchange=${d(this._onContentSlotChange, 150)}></slot>` : n`
173
+ ${this.fixedHeight ? n`<slot @slotchange=${this._onContentSlotChange}></slot>` : n`
170
174
  <div class="sbb-tab-group-content">
171
- <slot @slotchange=${d(this._onContentSlotChange, 150)}></slot>
175
+ <slot @slotchange=${this._onContentSlotChange}></slot>
172
176
  </div>
173
177
  `}
174
178
  `;
@@ -176,4 +180,4 @@ var g = ":host{--sbb-tab-group-animation-duration: 0s;gap:var(--sbb-tab-group-co
176
180
  };
177
181
  })();
178
182
  //#endregion
179
- export { _ as t };
183
+ export { g as t };
@@ -1,2 +1,2 @@
1
- import { t as e } from "../../tab-group.component-sdbLQtoj.js";
1
+ import { t as e } from "../../tab-group.component-B3uz-8FA.js";
2
2
  export { e as SbbTabGroupElement };
package/tabs.js CHANGED
@@ -1,4 +1,4 @@
1
- import { t as e } from "./tab-group.component-sdbLQtoj.js";
1
+ import { t as e } from "./tab-group.component-B3uz-8FA.js";
2
2
  import { t } from "./tab-label.component-CH24fqmB.js";
3
3
  import { t as n } from "./tab-nav-bar.component-C6ZRnHq_.js";
4
4
  import { t as r } from "./tab.component-DGzqld4u.js";
package/tabs.pure.js CHANGED
@@ -1,4 +1,4 @@
1
- import { t as e } from "./tab-group.component-sdbLQtoj.js";
1
+ import { t as e } from "./tab-group.component-B3uz-8FA.js";
2
2
  import { t } from "./tab-label.component-CH24fqmB.js";
3
3
  import { t as n } from "./tab-nav-bar.component-C6ZRnHq_.js";
4
4
  import { t as r } from "./tab.component-DGzqld4u.js";
@@ -1,266 +0,0 @@
1
- import { __esDecorate, __runInitializers } from "tslib";
2
- import { html, unsafeCSS } from "lit";
3
- import { property } from "lit/decorators.js";
4
- import { SbbElement, boxSizingStyles, forceType, getNextElementIndex, isArrowKeyPressed, isLean, throttle, ɵstateController } from "./core.js";
5
- import { ResizeController } from "@lit-labs/observers/resize-controller.js";
6
- import { ref } from "lit/directives/ref.js";
7
- import { tabGroupCommonStyles } from "./tabs/common/styles.js";
8
- //#region src/elements/tabs/tab-group/tab-group.scss?inline
9
- 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}";
10
- //#endregion
11
- //#region src/elements/tabs/tab-group/tab-group.component.ts
12
- /**
13
- * It displays one or more tabs, each one with a label and some content.
14
- *
15
- * @slot - Use the unnamed slot to add content to the `sbb-tab-group` via `sbb-tab-label` and `sbb-tab` instances.
16
- * @event {CustomEvent<SbbTabChangedEventDetails>} tabchange - The tabchange event is dispatched when a tab is selected.
17
- */
18
- var SbbTabGroupElement = (() => {
19
- let _classSuper = SbbElement;
20
- let _size_decorators;
21
- let _size_initializers = [];
22
- let _size_extraInitializers = [];
23
- let _initialSelectedIndex_decorators;
24
- let _initialSelectedIndex_initializers = [];
25
- let _initialSelectedIndex_extraInitializers = [];
26
- let _fixedHeight_decorators;
27
- let _fixedHeight_initializers = [];
28
- let _fixedHeight_extraInitializers = [];
29
- return class SbbTabGroupElement extends _classSuper {
30
- static {
31
- const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
32
- _size_decorators = [property()];
33
- _initialSelectedIndex_decorators = [forceType(), property({
34
- attribute: "initial-selected-index",
35
- type: Number
36
- })];
37
- _fixedHeight_decorators = [forceType(), property({
38
- attribute: "fixed-height",
39
- type: Boolean,
40
- reflect: true
41
- })];
42
- __esDecorate(this, null, _size_decorators, {
43
- kind: "accessor",
44
- name: "size",
45
- static: false,
46
- private: false,
47
- access: {
48
- has: (obj) => "size" in obj,
49
- get: (obj) => obj.size,
50
- set: (obj, value) => {
51
- obj.size = value;
52
- }
53
- },
54
- metadata: _metadata
55
- }, _size_initializers, _size_extraInitializers);
56
- __esDecorate(this, null, _initialSelectedIndex_decorators, {
57
- kind: "accessor",
58
- name: "initialSelectedIndex",
59
- static: false,
60
- private: false,
61
- access: {
62
- has: (obj) => "initialSelectedIndex" in obj,
63
- get: (obj) => obj.initialSelectedIndex,
64
- set: (obj, value) => {
65
- obj.initialSelectedIndex = value;
66
- }
67
- },
68
- metadata: _metadata
69
- }, _initialSelectedIndex_initializers, _initialSelectedIndex_extraInitializers);
70
- __esDecorate(this, null, _fixedHeight_decorators, {
71
- kind: "accessor",
72
- name: "fixedHeight",
73
- static: false,
74
- private: false,
75
- access: {
76
- has: (obj) => "fixedHeight" in obj,
77
- get: (obj) => obj.fixedHeight,
78
- set: (obj, value) => {
79
- obj.fixedHeight = value;
80
- }
81
- },
82
- metadata: _metadata
83
- }, _fixedHeight_initializers, _fixedHeight_extraInitializers);
84
- if (_metadata) Object.defineProperty(this, Symbol.metadata, {
85
- enumerable: true,
86
- configurable: true,
87
- writable: true,
88
- value: _metadata
89
- });
90
- }
91
- static {
92
- this.elementName = "sbb-tab-group";
93
- }
94
- static {
95
- this.styles = [
96
- boxSizingStyles,
97
- tabGroupCommonStyles,
98
- unsafeCSS(tab_group_default)
99
- ];
100
- }
101
- static {
102
- this.events = { tabchange: "tabchange" };
103
- }
104
- #size_accessor_storage;
105
- /**
106
- * Size variant, either s, l or xl.
107
- * @default 'l' / 's' (lean)
108
- */
109
- get size() {
110
- return this.#size_accessor_storage;
111
- }
112
- set size(value) {
113
- this.#size_accessor_storage = value;
114
- }
115
- #initialSelectedIndex_accessor_storage;
116
- /**
117
- * Sets the initial tab. If it matches a disabled tab or exceeds the length of
118
- * the tab group, the first enabled tab will be selected.
119
- */
120
- get initialSelectedIndex() {
121
- return this.#initialSelectedIndex_accessor_storage;
122
- }
123
- set initialSelectedIndex(value) {
124
- this.#initialSelectedIndex_accessor_storage = value;
125
- }
126
- #fixedHeight_accessor_storage;
127
- /**
128
- * If set to true, the `sbb-tab` elements take 100% height of the `sbb-tab-group`.
129
- * It enables controlling the height on the `sbb-tab-group` element.
130
- * The content becomes scrollable on overflow.
131
- */
132
- get fixedHeight() {
133
- return this.#fixedHeight_accessor_storage;
134
- }
135
- set fixedHeight(value) {
136
- this.#fixedHeight_accessor_storage = value;
137
- }
138
- /** Gets the slotted `sbb-tab-label`s. */
139
- get labels() {
140
- /**
141
- * The querySelector API is not used because when nested tabs are used,
142
- * the returned array contains the inner tabs too, and this breaks the keyboard navigation.
143
- */
144
- return Array.from(this.children ?? []).filter((child) => /^sbb-tab-label$/u.test(child.localName));
145
- }
146
- /** Gets the slotted `sbb-tab`s. */
147
- get tabs() {
148
- /**
149
- * The querySelector API is not used because when nested tabs are used,
150
- * the returned array contains the inner tabs too, and this breaks the keyboard navigation.
151
- */
152
- return Array.from(this.children ?? []).filter((child) => /^sbb-tab$/u.test(child.localName));
153
- }
154
- constructor() {
155
- super();
156
- this._tabGroupResizeObserver = new ResizeController(this, {
157
- target: null,
158
- skipInitial: true,
159
- callback: () => this._onTabGroupElementResize()
160
- });
161
- this.#size_accessor_storage = __runInitializers(this, _size_initializers, isLean() ? "s" : "l");
162
- this.#initialSelectedIndex_accessor_storage = (__runInitializers(this, _size_extraInitializers), __runInitializers(this, _initialSelectedIndex_initializers, 0));
163
- this.#fixedHeight_accessor_storage = (__runInitializers(this, _initialSelectedIndex_extraInitializers), __runInitializers(this, _fixedHeight_initializers, false));
164
- this._onContentSlotChange = (__runInitializers(this, _fixedHeight_extraInitializers), () => {
165
- this.labels.forEach((tabLabel) => tabLabel["linkToTab"]());
166
- this.labels.find((tabLabel) => tabLabel.active)?.activate();
167
- });
168
- this._onLabelSlotChange = () => {
169
- this.labels.forEach((tabLabel) => tabLabel["linkToTab"]());
170
- this._ensureActiveTab();
171
- };
172
- this.addEventListener?.("keydown", (e) => this._handleKeyDown(e));
173
- }
174
- firstUpdated(changedProperties) {
175
- super.firstUpdated(changedProperties);
176
- this.labels.forEach((tabLabel) => tabLabel["linkToTab"]());
177
- this._initSelection();
178
- Promise.resolve().then(() => this.internals.states.add("initialized"));
179
- this._tabGroupResizeObserver.observe(this._tabGroupElement);
180
- }
181
- /**
182
- * Disables a tab by index.
183
- * @param index The index of the tab you want to disable.
184
- */
185
- disableTab(index) {
186
- if (this.labels[index]) this.labels[index].disabled = true;
187
- }
188
- /**
189
- * Enables a tab by index.
190
- * @param index The index of the tab you want to enable.
191
- */
192
- enableTab(index) {
193
- if (this.labels[index]) this.labels[index].disabled = false;
194
- }
195
- /**
196
- * Activates a tab by index.
197
- * @param index The index of the tab you want to activate.
198
- */
199
- activateTab(index) {
200
- this.labels[index]?.activate();
201
- }
202
- _enabledTabs() {
203
- return this.labels.filter((t) => {
204
- customElements.upgrade(t);
205
- return !t.disabled;
206
- });
207
- }
208
- _ensureActiveTab() {
209
- if (this.internals.states.has("initialized") && !this.labels.some((tabLabel) => tabLabel.active)) this._initSelection();
210
- }
211
- _initSelection() {
212
- const selectedTabLabel = this.labels[this.initialSelectedIndex];
213
- if (selectedTabLabel) {
214
- customElements.upgrade(selectedTabLabel);
215
- if (this.initialSelectedIndex >= 0 && this.initialSelectedIndex < this.labels.length && !selectedTabLabel.disabled) {
216
- selectedTabLabel.activate();
217
- return;
218
- }
219
- }
220
- this._enabledTabs()[0]?.activate();
221
- }
222
- _onTabGroupElementResize() {
223
- const tabLabels = this.labels;
224
- tabLabels.forEach((tabLabel) => {
225
- ɵstateController(tabLabel)?.toggle("has-divider", tabLabel === tabLabels[0] || tabLabel.offsetLeft === tabLabels[0].offsetLeft);
226
- });
227
- this.style.setProperty("--sbb-tab-group-width", `${this._tabGroupElement.clientWidth}px`);
228
- }
229
- _handleKeyDown(evt) {
230
- const enabledTabs = this._enabledTabs();
231
- if (!enabledTabs || evt.target !== this && evt.target.parentElement !== this) return;
232
- if (isArrowKeyPressed(evt)) {
233
- const nextIndex = getNextElementIndex(evt, enabledTabs.findIndex((t) => t.active), enabledTabs.length);
234
- enabledTabs[nextIndex]?.activate();
235
- enabledTabs[nextIndex]?.focus();
236
- evt.preventDefault();
237
- }
238
- }
239
- /**
240
- * @internal
241
- */
242
- setTabContentHeight(contentHeight) {
243
- this.style.setProperty("--sbb-tab-content-height", `${contentHeight}px`);
244
- }
245
- render() {
246
- return html`
247
- <div
248
- class="sbb-tab-group"
249
- role="tablist"
250
- ${ref((el) => this._tabGroupElement = el)}
251
- >
252
- <slot name="tab-bar" @slotchange=${this._onLabelSlotChange}></slot>
253
- </div>
254
- ${!this.fixedHeight ? html`
255
- <div class="sbb-tab-group-content">
256
- <slot @slotchange=${throttle(this._onContentSlotChange, 150)}></slot>
257
- </div>
258
- ` : html`<slot @slotchange=${throttle(this._onContentSlotChange, 150)}></slot>`}
259
- `;
260
- }
261
- };
262
- })();
263
- //#endregion
264
- export { SbbTabGroupElement as t };
265
-
266
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLWdyb3VwLmNvbXBvbmVudC1DM1I4WlRiZy5qcyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZWxlbWVudHMvdGFicy90YWItZ3JvdXAvdGFiLWdyb3VwLnNjc3M/aW5saW5lIiwiLi4vLi4vLi4vc3JjL2VsZW1lbnRzL3RhYnMvdGFiLWdyb3VwL3RhYi1ncm91cC5jb21wb25lbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiQHVzZSAnLi4vLi4vY29yZS9zdHlsZXMnIGFzIHNiYjtcblxuOmhvc3Qge1xuICAtLXNiYi10YWItZ3JvdXAtYW5pbWF0aW9uLWR1cmF0aW9uOiAwcztcblxuICBnYXA6IHZhcigtLXNiYi10YWItZ3JvdXAtY29udGVudC1nYXApO1xufVxuXG46aG9zdCg6c3RhdGUoaW5pdGlhbGl6ZWQpKSB7XG4gIC0tc2JiLXRhYi1ncm91cC1hbmltYXRpb24tZHVyYXRpb246IHZhcihcbiAgICAtLXNiYi1kaXNhYmxlLWFuaW1hdGlvbi1kdXJhdGlvbixcbiAgICB2YXIoLS1zYmItYW5pbWF0aW9uLWR1cmF0aW9uLTR4KVxuICApO1xufVxuXG4uc2JiLXRhYi1ncm91cC1jb250ZW50IHtcbiAgaGVpZ2h0OiB2YXIoLS1zYmItdGFiLWNvbnRlbnQtaGVpZ2h0KTtcbiAgdHJhbnNpdGlvbjogaGVpZ2h0IHZhcigtLXNiYi10YWItZ3JvdXAtYW5pbWF0aW9uLWR1cmF0aW9uKSB2YXIoLS1zYmItYW5pbWF0aW9uLWVhc2luZyk7XG59XG5cbjo6c2xvdHRlZChzYmItdGFiKSB7XG4gIDpob3N0KFtmaXhlZC1oZWlnaHRdKSAmIHtcbiAgICBoZWlnaHQ6IDEwMCU7XG4gICAgb3ZlcmZsb3c6IGF1dG87XG4gIH1cbn1cbiIsImltcG9ydCB7IFJlc2l6ZUNvbnRyb2xsZXIgfSBmcm9tICdAbGl0LWxhYnMvb2JzZXJ2ZXJzL3Jlc2l6ZS1jb250cm9sbGVyLmpzJztcbmltcG9ydCB7XG4gIGh0bWwsXG4gIHVuc2FmZUNTUyxcbiAgdHlwZSBDU1NSZXN1bHRHcm91cCxcbiAgdHlwZSBQcm9wZXJ0eVZhbHVlcyxcbiAgdHlwZSBUZW1wbGF0ZVJlc3VsdCxcbn0gZnJvbSAnbGl0JztcbmltcG9ydCB7IHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuaW1wb3J0IHsgcmVmIH0gZnJvbSAnbGl0L2RpcmVjdGl2ZXMvcmVmLmpzJztcblxuaW1wb3J0IHtcbiAgZ2V0TmV4dEVsZW1lbnRJbmRleCxcbiAgaXNBcnJvd0tleVByZXNzZWQsXG4gIFNiYkVsZW1lbnQsXG4gIMm1c3RhdGVDb250cm9sbGVyLFxuICBmb3JjZVR5cGUsXG4gIGlzTGVhbixcbiAgdGhyb3R0bGUsXG4gIGJveFNpemluZ1N0eWxlcyxcbn0gZnJvbSAnLi4vLi4vY29yZS50cyc7XG5pbXBvcnQgeyB0YWJHcm91cENvbW1vblN0eWxlcyB9IGZyb20gJy4uL2NvbW1vbi9zdHlsZXMudHMnO1xuaW1wb3J0IHR5cGUgeyBTYmJUYWJFbGVtZW50IH0gZnJvbSAnLi4vdGFiL3RhYi5jb21wb25lbnQudHMnO1xuaW1wb3J0IHR5cGUgeyBTYmJUYWJMYWJlbEVsZW1lbnQgfSBmcm9tICcuLi90YWItbGFiZWwvdGFiLWxhYmVsLmNvbXBvbmVudC50cyc7XG5cbmltcG9ydCBzdHlsZSBmcm9tICcuL3RhYi1ncm91cC5zY3NzP2lubGluZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2JiVGFiQ2hhbmdlZEV2ZW50RGV0YWlscyB7XG4gIGFjdGl2ZUluZGV4OiBudW1iZXI7XG4gIGFjdGl2ZVRhYkxhYmVsOiBTYmJUYWJMYWJlbEVsZW1lbnQ7XG4gIGFjdGl2ZVRhYjogU2JiVGFiRWxlbWVudDtcbiAgcHJldmlvdXNJbmRleDogbnVtYmVyO1xuICBwcmV2aW91c1RhYkxhYmVsOiBTYmJUYWJMYWJlbEVsZW1lbnQgfCB1bmRlZmluZWQ7XG4gIHByZXZpb3VzVGFiOiBTYmJUYWJFbGVtZW50IHwgdW5kZWZpbmVkO1xufVxuXG4vKipcbiAqIEl0IGRpc3BsYXlzIG9uZSBvciBtb3JlIHRhYnMsIGVhY2ggb25lIHdpdGggYSBsYWJlbCBhbmQgc29tZSBjb250ZW50LlxuICpcbiAqIEBzbG90IC0gVXNlIHRoZSB1bm5hbWVkIHNsb3QgdG8gYWRkIGNvbnRlbnQgdG8gdGhlIGBzYmItdGFiLWdyb3VwYCB2aWEgYHNiYi10YWItbGFiZWxgIGFuZCBgc2JiLXRhYmAgaW5zdGFuY2VzLlxuICogQGV2ZW50IHtDdXN0b21FdmVudDxTYmJUYWJDaGFuZ2VkRXZlbnREZXRhaWxzPn0gdGFiY2hhbmdlIC0gVGhlIHRhYmNoYW5nZSBldmVudCBpcyBkaXNwYXRjaGVkIHdoZW4gYSB0YWIgaXMgc2VsZWN0ZWQuXG4gKi9cbmV4cG9ydCBjbGFzcyBTYmJUYWJHcm91cEVsZW1lbnQgZXh0ZW5kcyBTYmJFbGVtZW50IHtcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSByZWFkb25seSBlbGVtZW50TmFtZTogc3RyaW5nID0gJ3NiYi10YWItZ3JvdXAnO1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHN0eWxlczogQ1NTUmVzdWx0R3JvdXAgPSBbXG4gICAgYm94U2l6aW5nU3R5bGVzLFxuICAgIHRhYkdyb3VwQ29tbW9uU3R5bGVzLFxuICAgIHVuc2FmZUNTUyhzdHlsZSksXG4gIF07XG4gIHB1YmxpYyBzdGF0aWMgcmVhZG9ubHkgZXZlbnRzID0ge1xuICAgIHRhYmNoYW5nZTogJ3RhYmNoYW5nZScsXG4gIH0gYXMgY29uc3Q7XG5cbiAgcHJpdmF0ZSBfdGFiR3JvdXBFbGVtZW50ITogSFRNTEVsZW1lbnQ7XG4gIHByaXZhdGUgX3RhYkdyb3VwUmVzaXplT2JzZXJ2ZXIgPSBuZXcgUmVzaXplQ29udHJvbGxlcih0aGlzLCB7XG4gICAgdGFyZ2V0OiBudWxsLFxuICAgIHNraXBJbml0aWFsOiB0cnVlLFxuICAgIGNhbGxiYWNrOiAoKSA9PiB0aGlzLl9vblRhYkdyb3VwRWxlbWVudFJlc2l6ZSgpLFxuICB9KTtcblxuICAvKipcbiAgICogU2l6ZSB2YXJpYW50LCBlaXRoZXIgcywgbCBvciB4bC5cbiAgICogQGRlZmF1bHQgJ2wnIC8gJ3MnIChsZWFuKVxuICAgKi9cbiAgQHByb3BlcnR5KClcbiAgcHVibGljIGFjY2Vzc29yIHNpemU6ICdzJyB8ICdsJyB8ICd4bCcgPSBpc0xlYW4oKSA/ICdzJyA6ICdsJztcblxuICAvKipcbiAgICogU2V0cyB0aGUgaW5pdGlhbCB0YWIuIElmIGl0IG1hdGNoZXMgYSBkaXNhYmxlZCB0YWIgb3IgZXhjZWVkcyB0aGUgbGVuZ3RoIG9mXG4gICAqIHRoZSB0YWIgZ3JvdXAsIHRoZSBmaXJzdCBlbmFibGVkIHRhYiB3aWxsIGJlIHNlbGVjdGVkLlxuICAgKi9cbiAgQGZvcmNlVHlwZSgpXG4gIEBwcm9wZXJ0eSh7IGF0dHJpYnV0ZTogJ2luaXRpYWwtc2VsZWN0ZWQtaW5kZXgnLCB0eXBlOiBOdW1iZXIgfSlcbiAgcHVibGljIGFjY2Vzc29yIGluaXRpYWxTZWxlY3RlZEluZGV4OiBudW1iZXIgPSAwO1xuXG4gIC8qKlxuICAgKiBJZiBzZXQgdG8gdHJ1ZSwgdGhlIGBzYmItdGFiYCBlbGVtZW50cyB0YWtlIDEwMCUgaGVpZ2h0IG9mIHRoZSBgc2JiLXRhYi1ncm91cGAuXG4gICAqIEl0IGVuYWJsZXMgY29udHJvbGxpbmcgdGhlIGhlaWdodCBvbiB0aGUgYHNiYi10YWItZ3JvdXBgIGVsZW1lbnQuXG4gICAqIFRoZSBjb250ZW50IGJlY29tZXMgc2Nyb2xsYWJsZSBvbiBvdmVyZmxvdy5cbiAgICovXG4gIEBmb3JjZVR5cGUoKVxuICBAcHJvcGVydHkoeyBhdHRyaWJ1dGU6ICdmaXhlZC1oZWlnaHQnLCB0eXBlOiBCb29sZWFuLCByZWZsZWN0OiB0cnVlIH0pXG4gIHB1YmxpYyBhY2Nlc3NvciBmaXhlZEhlaWdodDogYm9vbGVhbiA9IGZhbHNlO1xuXG4gIC8qKiBHZXRzIHRoZSBzbG90dGVkIGBzYmItdGFiLWxhYmVsYHMuICovXG4gIHB1YmxpYyBnZXQgbGFiZWxzKCk6IFNiYlRhYkxhYmVsRWxlbWVudFtdIHtcbiAgICAvKipcbiAgICAgKiBUaGUgcXVlcnlTZWxlY3RvciBBUEkgaXMgbm90IHVzZWQgYmVjYXVzZSB3aGVuIG5lc3RlZCB0YWJzIGFyZSB1c2VkLFxuICAgICAqIHRoZSByZXR1cm5lZCBhcnJheSBjb250YWlucyB0aGUgaW5uZXIgdGFicyB0b28sIGFuZCB0aGlzIGJyZWFrcyB0aGUga2V5Ym9hcmQgbmF2aWdhdGlvbi5cbiAgICAgKi9cbiAgICByZXR1cm4gQXJyYXkuZnJvbSh0aGlzLmNoaWxkcmVuID8/IFtdKS5maWx0ZXIoKGNoaWxkKSA9PlxuICAgICAgL15zYmItdGFiLWxhYmVsJC91LnRlc3QoY2hpbGQubG9jYWxOYW1lKSxcbiAgICApIGFzIFNiYlRhYkxhYmVsRWxlbWVudFtdO1xuICB9XG5cbiAgLyoqIEdldHMgdGhlIHNsb3R0ZWQgYHNiYi10YWJgcy4gKi9cbiAgcHVibGljIGdldCB0YWJzKCk6IFNiYlRhYkVsZW1lbnRbXSB7XG4gICAgLyoqXG4gICAgICogVGhlIHF1ZXJ5U2VsZWN0b3IgQVBJIGlzIG5vdCB1c2VkIGJlY2F1c2Ugd2hlbiBuZXN0ZWQgdGFicyBhcmUgdXNlZCxcbiAgICAgKiB0aGUgcmV0dXJuZWQgYXJyYXkgY29udGFpbnMgdGhlIGlubmVyIHRhYnMgdG9vLCBhbmQgdGhpcyBicmVha3MgdGhlIGtleWJvYXJkIG5hdmlnYXRpb24uXG4gICAgICovXG4gICAgcmV0dXJuIEFycmF5LmZyb20odGhpcy5jaGlsZHJlbiA/PyBbXSkuZmlsdGVyKChjaGlsZCkgPT5cbiAgICAgIC9ec2JiLXRhYiQvdS50ZXN0KGNoaWxkLmxvY2FsTmFtZSksXG4gICAgKSBhcyBTYmJUYWJFbGVtZW50W107XG4gIH1cblxuICBwdWJsaWMgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoKTtcbiAgICB0aGlzLmFkZEV2ZW50TGlzdGVuZXI/Ligna2V5ZG93bicsIChlKSA9PiB0aGlzLl9oYW5kbGVLZXlEb3duKGUpKTtcbiAgfVxuXG4gIHByb3RlY3RlZCBvdmVycmlkZSBmaXJzdFVwZGF0ZWQoY2hhbmdlZFByb3BlcnRpZXM6IFByb3BlcnR5VmFsdWVzPHRoaXM+KTogdm9pZCB7XG4gICAgc3VwZXIuZmlyc3RVcGRhdGVkKGNoYW5nZWRQcm9wZXJ0aWVzKTtcblxuICAgIHRoaXMubGFiZWxzLmZvckVhY2goKHRhYkxhYmVsKSA9PiB0YWJMYWJlbFsnbGlua1RvVGFiJ10oKSk7XG4gICAgdGhpcy5faW5pdFNlbGVjdGlvbigpO1xuXG4gICAgLy8gVG8gYXZvaWQgYW5pbWF0aW9ucyBvbiBpbml0aWFsaXphdGlvbiwgd2UgaGF2ZSB0byBtYXJrIHRoZSBjb21wb25lbnQgYXMgaW5pdGlhbGl6ZWQgYW5kIHdhaXQgYSB0aWNrLlxuICAgIFByb21pc2UucmVzb2x2ZSgpLnRoZW4oKCkgPT4gdGhpcy5pbnRlcm5hbHMuc3RhdGVzLmFkZCgnaW5pdGlhbGl6ZWQnKSk7XG4gICAgdGhpcy5fdGFiR3JvdXBSZXNpemVPYnNlcnZlci5vYnNlcnZlKHRoaXMuX3RhYkdyb3VwRWxlbWVudCk7XG4gIH1cblxuICAvKipcbiAgICogRGlzYWJsZXMgYSB0YWIgYnkgaW5kZXguXG4gICAqIEBwYXJhbSBpbmRleCBUaGUgaW5kZXggb2YgdGhlIHRhYiB5b3Ugd2FudCB0byBkaXNhYmxlLlxuICAgKi9cbiAgcHVibGljIGRpc2FibGVUYWIoaW5kZXg6IG51bWJlcik6IHZvaWQge1xuICAgIGlmICh0aGlzLmxhYmVsc1tpbmRleF0pIHtcbiAgICAgIHRoaXMubGFiZWxzW2luZGV4XS5kaXNhYmxlZCA9IHRydWU7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIEVuYWJsZXMgYSB0YWIgYnkgaW5kZXguXG4gICAqIEBwYXJhbSBpbmRleCBUaGUgaW5kZXggb2YgdGhlIHRhYiB5b3Ugd2FudCB0byBlbmFibGUuXG4gICAqL1xuICBwdWJsaWMgZW5hYmxlVGFiKGluZGV4OiBudW1iZXIpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5sYWJlbHNbaW5kZXhdKSB7XG4gICAgICB0aGlzLmxhYmVsc1tpbmRleF0uZGlzYWJsZWQgPSBmYWxzZTtcbiAgICB9XG4gIH1cblxuICAvKipcbiAgICogQWN0aXZhdGVzIGEgdGFiIGJ5IGluZGV4LlxuICAgKiBAcGFyYW0gaW5kZXggVGhlIGluZGV4IG9mIHRoZSB0YWIgeW91IHdhbnQgdG8gYWN0aXZhdGUuXG4gICAqL1xuICBwdWJsaWMgYWN0aXZhdGVUYWIoaW5kZXg6IG51bWJlcik6IHZvaWQge1xuICAgIHRoaXMubGFiZWxzW2luZGV4XT8uYWN0aXZhdGUoKTtcbiAgfVxuXG4gIHByaXZhdGUgX2VuYWJsZWRUYWJzKCk6IFNiYlRhYkxhYmVsRWxlbWVudFtdIHtcbiAgICByZXR1cm4gdGhpcy5sYWJlbHMuZmlsdGVyKCh0KSA9PiB7XG4gICAgICBjdXN0b21FbGVtZW50cy51cGdyYWRlKHQpO1xuICAgICAgcmV0dXJuICF0LmRpc2FibGVkO1xuICAgIH0pO1xuICB9XG5cbiAgcHJpdmF0ZSBfb25Db250ZW50U2xvdENoYW5nZSA9ICgpOiB2b2lkID0+IHtcbiAgICB0aGlzLmxhYmVscy5mb3JFYWNoKCh0YWJMYWJlbCkgPT4gdGFiTGFiZWxbJ2xpbmtUb1RhYiddKCkpO1xuICAgIHRoaXMubGFiZWxzLmZpbmQoKHRhYkxhYmVsKSA9PiB0YWJMYWJlbC5hY3RpdmUpPy5hY3RpdmF0ZSgpO1xuICB9O1xuXG4gIHByaXZhdGUgX29uTGFiZWxTbG90Q2hhbmdlID0gKCk6IHZvaWQgPT4ge1xuICAgIHRoaXMubGFiZWxzLmZvckVhY2goKHRhYkxhYmVsKSA9PiB0YWJMYWJlbFsnbGlua1RvVGFiJ10oKSk7XG4gICAgdGhpcy5fZW5zdXJlQWN0aXZlVGFiKCk7XG4gIH07XG5cbiAgcHJpdmF0ZSBfZW5zdXJlQWN0aXZlVGFiKCk6IHZvaWQge1xuICAgIGlmIChcbiAgICAgIHRoaXMuaW50ZXJuYWxzLnN0YXRlcy5oYXMoJ2luaXRpYWxpemVkJykgJiZcbiAgICAgICF0aGlzLmxhYmVscy5zb21lKCh0YWJMYWJlbCkgPT4gdGFiTGFiZWwuYWN0aXZlKVxuICAgICkge1xuICAgICAgdGhpcy5faW5pdFNlbGVjdGlvbigpO1xuICAgIH1cbiAgfVxuXG4gIHByaXZhdGUgX2luaXRTZWxlY3Rpb24oKTogdm9pZCB7XG4gICAgY29uc3Qgc2VsZWN0ZWRUYWJMYWJlbCA9IHRoaXMubGFiZWxzW3RoaXMuaW5pdGlhbFNlbGVjdGVkSW5kZXhdO1xuICAgIGlmIChzZWxlY3RlZFRhYkxhYmVsKSB7XG4gICAgICBjdXN0b21FbGVtZW50cy51cGdyYWRlKHNlbGVjdGVkVGFiTGFiZWwpO1xuICAgICAgaWYgKFxuICAgICAgICB0aGlzLmluaXRpYWxTZWxlY3RlZEluZGV4ID49IDAgJiZcbiAgICAgICAgdGhpcy5pbml0aWFsU2VsZWN0ZWRJbmRleCA8IHRoaXMubGFiZWxzLmxlbmd0aCAmJlxuICAgICAgICAhc2VsZWN0ZWRUYWJMYWJlbC5kaXNhYmxlZFxuICAgICAgKSB7XG4gICAgICAgIHNlbGVjdGVkVGFiTGFiZWwuYWN0aXZhdGUoKTtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuICAgIH1cbiAgICB0aGlzLl9lbmFibGVkVGFicygpWzBdPy5hY3RpdmF0ZSgpO1xuICB9XG5cbiAgcHJpdmF0ZSBfb25UYWJHcm91cEVsZW1lbnRSZXNpemUoKTogdm9pZCB7XG4gICAgY29uc3QgdGFiTGFiZWxzID0gdGhpcy5sYWJlbHM7XG4gICAgdGFiTGFiZWxzLmZvckVhY2goKHRhYkxhYmVsKSA9PiB7XG4gICAgICDJtXN0YXRlQ29udHJvbGxlcih0YWJMYWJlbCk/LnRvZ2dsZShcbiAgICAgICAgJ2hhcy1kaXZpZGVyJyxcbiAgICAgICAgdGFiTGFiZWwgPT09IHRhYkxhYmVsc1swXSB8fCB0YWJMYWJlbC5vZmZzZXRMZWZ0ID09PSB0YWJMYWJlbHNbMF0ub2Zmc2V0TGVmdCxcbiAgICAgICk7XG4gICAgfSk7XG5cbiAgICB0aGlzLnN0eWxlLnNldFByb3BlcnR5KCctLXNiYi10YWItZ3JvdXAtd2lkdGgnLCBgJHt0aGlzLl90YWJHcm91cEVsZW1lbnQuY2xpZW50V2lkdGh9cHhgKTtcbiAgfVxuXG4gIHByaXZhdGUgX2hhbmRsZUtleURvd24oZXZ0OiBLZXlib2FyZEV2ZW50KTogdm9pZCB7XG4gICAgY29uc3QgZW5hYmxlZFRhYnM6IFNiYlRhYkxhYmVsRWxlbWVudFtdID0gdGhpcy5fZW5hYmxlZFRhYnMoKTtcblxuICAgIGlmIChcbiAgICAgICFlbmFibGVkVGFicyB8fFxuICAgICAgLy8gZG9uJ3QgdHJhcCBuZXN0ZWQgaGFuZGxpbmdcbiAgICAgICgoZXZ0LnRhcmdldCBhcyBIVE1MRWxlbWVudCkgIT09IHRoaXMgJiYgKGV2dC50YXJnZXQgYXMgSFRNTEVsZW1lbnQpLnBhcmVudEVsZW1lbnQgIT09IHRoaXMpXG4gICAgKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgaWYgKGlzQXJyb3dLZXlQcmVzc2VkKGV2dCkpIHtcbiAgICAgIGNvbnN0IGN1cnJlbnQ6IG51bWJlciA9IGVuYWJsZWRUYWJzLmZpbmRJbmRleCgodCkgPT4gdC5hY3RpdmUpO1xuICAgICAgY29uc3QgbmV4dEluZGV4OiBudW1iZXIgPSBnZXROZXh0RWxlbWVudEluZGV4KGV2dCwgY3VycmVudCwgZW5hYmxlZFRhYnMubGVuZ3RoKTtcbiAgICAgIGVuYWJsZWRUYWJzW25leHRJbmRleF0/LmFjdGl2YXRlKCk7XG4gICAgICBlbmFibGVkVGFic1tuZXh0SW5kZXhdPy5mb2N1cygpO1xuICAgICAgZXZ0LnByZXZlbnREZWZhdWx0KCk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIEBpbnRlcm5hbFxuICAgKi9cbiAgcHJvdGVjdGVkIHNldFRhYkNvbnRlbnRIZWlnaHQoY29udGVudEhlaWdodDogbnVtYmVyKTogdm9pZCB7XG4gICAgdGhpcy5zdHlsZS5zZXRQcm9wZXJ0eSgnLS1zYmItdGFiLWNvbnRlbnQtaGVpZ2h0JywgYCR7Y29udGVudEhlaWdodH1weGApO1xuICB9XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlcigpOiBUZW1wbGF0ZVJlc3VsdCB7XG4gICAgcmV0dXJuIGh0bWxgXG4gICAgICA8ZGl2XG4gICAgICAgIGNsYXNzPVwic2JiLXRhYi1ncm91cFwiXG4gICAgICAgIHJvbGU9XCJ0YWJsaXN0XCJcbiAgICAgICAgJHtyZWYoKGVsPzogRWxlbWVudCkgPT4gKHRoaXMuX3RhYkdyb3VwRWxlbWVudCA9IGVsIGFzIEhUTUxFbGVtZW50KSl9XG4gICAgICA+XG4gICAgICAgIDxzbG90IG5hbWU9XCJ0YWItYmFyXCIgQHNsb3RjaGFuZ2U9JHt0aGlzLl9vbkxhYmVsU2xvdENoYW5nZX0+PC9zbG90PlxuICAgICAgPC9kaXY+XG4gICAgICAkeyF0aGlzLmZpeGVkSGVpZ2h0XG4gICAgICAgID8gaHRtbGBcbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJzYmItdGFiLWdyb3VwLWNvbnRlbnRcIj5cbiAgICAgICAgICAgICAgPHNsb3QgQHNsb3RjaGFuZ2U9JHt0aHJvdHRsZSh0aGlzLl9vbkNvbnRlbnRTbG90Q2hhbmdlLCAxNTApfT48L3Nsb3Q+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICBgXG4gICAgICAgIDogaHRtbGA8c2xvdCBAc2xvdGNoYW5nZT0ke3Rocm90dGxlKHRoaXMuX29uQ29udGVudFNsb3RDaGFuZ2UsIDE1MCl9Pjwvc2xvdD5gfVxuICAgIGA7XG4gIH1cbn1cblxuZGVjbGFyZSBnbG9iYWwge1xuICBpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25hbWluZy1jb252ZW50aW9uXG4gICAgJ3NiYi10YWItZ3JvdXAnOiBTYmJUYWJHcm91cEVsZW1lbnQ7XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7SUMwQ2EsNEJBQWtCO21CQUFTOzs7Ozs7Ozs7O2NBQTNCLDJCQUEyQixZQUFVOzs7dUJBc0IvQyxVQUFVLENBQUE7dUNBT1YsV0FBVyxFQUNYLFNBQVM7SUFBRSxXQUFXO0lBQTBCLE1BQU07SUFBUSxDQUFDLENBQUE7OEJBUS9ELFdBQVcsRUFDWCxTQUFTO0lBQUUsV0FB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