@sbb-esta/lyne-elements-dev 5.0.0-next.3-dev.1779188320 → 5.0.0-next.3-dev.1779200097
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/autocomplete/autocomplete-base-element.js +2 -2
- package/autocomplete/autocomplete.component.js +1 -1
- package/{autocomplete-base-element-DRGjFF9_.js → autocomplete-base-element-6leI6UF4.js} +24 -14
- package/autocomplete.js +4 -4
- package/autocomplete.pure.js +3 -3
- package/calendar/calendar/calendar.component.js +2 -2
- package/{calendar.component-oS_T4s4k.js → calendar.component-BK4w5GWV.js} +35 -29
- package/calendar.js +4 -4
- package/calendar.pure.js +3 -3
- package/carousel/carousel/carousel.component.js +1 -1
- package/carousel/carousel-item/carousel-item.component.js +2 -2
- package/carousel/carousel-list/carousel-list.component.js +1 -1
- package/{carousel-item.component-DyZAdXL_.js → carousel-item.component-B6WmZPkW.js} +12 -2
- package/{carousel-list.component-Ai0uJWB7.js → carousel-list.component-CnZehdy6.js} +6 -13
- package/{carousel.component-9oMMOyWo.js → carousel.component-ZrkGeJgZ.js} +1 -1
- package/carousel.js +5 -5
- package/carousel.pure.js +4 -4
- package/chip/chip-group/chip-group.component.js +1 -1
- package/{chip-group.component-DJORKUef.js → chip-group.component-BIP7c2G0.js} +2 -7
- package/chip.js +1 -1
- package/chip.pure.js +1 -1
- package/core/overlay/overlay-outside-pointer-event-listener.js +1 -1
- package/custom-elements.json +3886 -3393
- package/datepicker/datepicker/datepicker.component.js +1 -1
- package/development/autocomplete/autocomplete-base-element.d.ts +6 -3
- package/development/autocomplete/autocomplete-base-element.d.ts.map +1 -1
- package/development/autocomplete/autocomplete-base-element.js +2 -2
- package/development/autocomplete/autocomplete.component.js +1 -1
- package/development/autocomplete-base-element-qnPoRLvM.js +695 -0
- package/development/autocomplete.js +2 -2
- package/development/autocomplete.pure.js +2 -2
- package/development/calendar/calendar/calendar.component.d.ts +8 -0
- package/development/calendar/calendar/calendar.component.d.ts.map +1 -1
- package/development/calendar/calendar/calendar.component.js +2 -2
- package/development/calendar.component-BKWvdgzO.js +1461 -0
- package/development/calendar.js +2 -2
- package/development/calendar.pure.js +2 -2
- package/development/carousel/carousel/carousel.component.js +1 -1
- package/development/carousel/carousel-item/carousel-item.component.d.ts +8 -6
- package/development/carousel/carousel-item/carousel-item.component.d.ts.map +1 -1
- package/development/carousel/carousel-item/carousel-item.component.js +2 -2
- package/development/carousel/carousel-list/carousel-list.component.d.ts.map +1 -1
- package/development/carousel/carousel-list/carousel-list.component.js +1 -1
- package/development/{carousel-item.component-B_0wdIAu.js → carousel-item.component-nuo7jAt3.js} +16 -4
- package/development/carousel-list.component-B8PUREwS.js +126 -0
- package/development/carousel.component-D_KIJ9Bb.js +139 -0
- package/development/carousel.js +4 -4
- package/development/carousel.pure.js +4 -4
- package/development/chip/chip-group/chip-group.component.d.ts +1 -23
- package/development/chip/chip-group/chip-group.component.d.ts.map +1 -1
- package/development/chip/chip-group/chip-group.component.js +1 -1
- package/development/chip-group.component-CVizDsAz.js +395 -0
- package/development/chip.js +1 -1
- package/development/chip.pure.js +1 -1
- package/development/core/overlay/overlay-outside-pointer-event-listener.d.ts +1 -1
- package/development/core/overlay/overlay-outside-pointer-event-listener.d.ts.map +1 -1
- package/development/core/overlay/overlay-outside-pointer-event-listener.js +2 -2
- package/development/core.d.ts +0 -1
- package/development/core.d.ts.map +1 -1
- package/development/datepicker/datepicker/datepicker.component.d.ts +1 -1
- package/development/datepicker/datepicker/datepicker.component.d.ts.map +1 -1
- package/development/datepicker/datepicker/datepicker.component.js +3 -3
- package/development/dialog/dialog/dialog.component.d.ts +2 -3
- package/development/dialog/dialog/dialog.component.d.ts.map +1 -1
- package/development/dialog/dialog/dialog.component.js +1 -1
- package/development/{dialog.component-AItB8ixG.js → dialog.component-D8B2dVck.js} +4 -7
- package/development/dialog.js +1 -1
- package/development/dialog.pure.js +1 -1
- package/development/file-selector/common/file-selector-common.d.ts +5 -0
- package/development/file-selector/common/file-selector-common.d.ts.map +1 -1
- package/development/file-selector/common/file-selector-common.js +2 -2
- package/development/{file-selector-common-CGL95Rnw.js → file-selector-common-mZ5UYxOF.js} +17 -8
- package/development/file-selector.js +2 -2
- package/development/file-selector.pure.js +2 -2
- package/development/form-field/form-field/form-field.component.d.ts +1 -1
- package/development/form-field/form-field/form-field.component.d.ts.map +1 -1
- package/development/form-field.component-CPWBCHer.js +1 -1
- package/development/overlay/overlay-base-element.d.ts +4 -4
- package/development/overlay/overlay-base-element.d.ts.map +1 -1
- package/development/overlay/overlay-base-element.js +3 -9
- package/development/overlay/overlay.component.d.ts +3 -3
- package/development/overlay/overlay.component.d.ts.map +1 -1
- package/development/overlay/overlay.component.js +1 -1
- package/development/{overlay.component-rFmitc_r.js → overlay.component-YSCuGeme.js} +4 -7
- package/development/overlay.js +1 -1
- package/development/overlay.pure.js +1 -1
- package/development/paginator/common/paginator-common.d.ts +11 -6
- package/development/paginator/common/paginator-common.d.ts.map +1 -1
- package/development/paginator/common/paginator-common.js +2 -2
- package/development/paginator-common-B7iba0wQ.js +432 -0
- package/development/paginator.js +2 -2
- package/development/paginator.pure.js +2 -2
- package/development/popover/popover.component.d.ts +7 -0
- package/development/popover/popover.component.d.ts.map +1 -1
- package/development/popover/popover.component.js +2 -2
- package/development/popover.component-CKUZbWbV.js +578 -0
- package/development/popover.js +2 -2
- package/development/popover.pure.js +2 -2
- package/development/{step.component-CcjtUFyR.js → step.component-B_YHm1tz.js} +32 -10
- package/development/stepper/step/step.component.d.ts +14 -1
- package/development/stepper/step/step.component.d.ts.map +1 -1
- package/development/stepper/step/step.component.js +2 -2
- package/development/stepper/stepper/stepper.component.d.ts +9 -5
- package/development/stepper/stepper/stepper.component.d.ts.map +1 -1
- package/development/stepper/stepper/stepper.component.js +1 -1
- package/development/stepper.component-BeqeUIRN.js +443 -0
- package/development/stepper.js +3 -3
- package/development/stepper.pure.js +3 -3
- package/development/tab-group.component-CGMBihsQ.js +297 -0
- package/development/{tab-label.component-CNX8bsJL.js → tab-label.component-CQOLO2t7.js} +11 -13
- package/development/tabs/tab-group/tab-group.component.d.ts +15 -8
- package/development/tabs/tab-group/tab-group.component.d.ts.map +1 -1
- package/development/tabs/tab-group/tab-group.component.js +2 -2
- package/development/tabs/tab-label/tab-label.component.d.ts.map +1 -1
- package/development/tabs/tab-label/tab-label.component.js +1 -1
- package/development/tabs.js +3 -3
- package/development/tabs.pure.js +3 -3
- package/dialog/dialog/dialog.component.js +1 -1
- package/{dialog.component-4O3__zyd.js → dialog.component-CsBryhM-.js} +3 -6
- package/dialog.js +1 -1
- package/dialog.pure.js +1 -1
- package/file-selector/common/file-selector-common.js +2 -2
- package/{file-selector-common-BE780nIa.js → file-selector-common-VNwWFEmM.js} +26 -19
- package/file-selector.js +5 -5
- package/file-selector.pure.js +4 -4
- package/overlay/overlay-base-element.js +2 -8
- package/overlay/overlay.component.js +1 -1
- package/{overlay.component-C80XN61v.js → overlay.component-myJflfLY.js} +3 -6
- package/overlay.js +1 -1
- package/overlay.pure.js +1 -1
- package/package.json +2 -2
- package/paginator/common/paginator-common.js +2 -2
- package/{paginator-common-uoCIcl4X.js → paginator-common-BWewgXga.js} +42 -24
- package/paginator.js +5 -5
- package/paginator.pure.js +4 -4
- package/popover/popover.component.js +2 -2
- package/{popover.component-DJruKzY-.js → popover.component-Dm_86bPY.js} +19 -7
- package/popover.js +3 -3
- package/popover.pure.js +2 -2
- package/{step.component-BY6_2Wh2.js → step.component-tJh-Pb_E.js} +23 -8
- package/stepper/step/step.component.js +2 -2
- package/stepper/stepper/stepper.component.js +1 -1
- package/{stepper.component-lh0YSbT1.js → stepper.component-BCl77LVa.js} +20 -3
- package/stepper.js +4 -4
- package/stepper.pure.js +3 -3
- package/{tab-group.component-t4eeCNf-.js → tab-group.component-CDhggNpe.js} +27 -2
- package/{tab-label.component-DvvSohaG.js → tab-label.component-BuF2qt1T.js} +23 -22
- package/tabs/tab-group/tab-group.component.js +2 -2
- package/tabs/tab-label/tab-label.component.js +1 -1
- package/tabs.js +7 -7
- package/tabs.pure.js +6 -6
- package/development/autocomplete-base-element-DQiZ6hhk.js +0 -683
- package/development/calendar.component-CjlcDyS5.js +0 -1450
- package/development/carousel-list.component-DpDh5tqB.js +0 -133
- package/development/carousel.component-ClWvnZ8s.js +0 -139
- package/development/chip-group.component-Sgmi-kSy.js +0 -403
- package/development/core/interfaces/overlay-close-details.d.ts +0 -6
- package/development/core/interfaces/overlay-close-details.d.ts.map +0 -1
- package/development/paginator-common-BCeNUko_.js +0 -410
- package/development/popover.component-BmTfHMFw.js +0 -564
- package/development/stepper.component-80S-oXrH.js +0 -422
- package/development/tab-group.component-D4fvd6Uu.js +0 -265
|
@@ -1,265 +0,0 @@
|
|
|
1
|
-
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
-
import { html, unsafeCSS } from "lit";
|
|
3
|
-
import { property } from "lit/decorators.js";
|
|
4
|
-
import { SbbElement, forceType, getNextElementIndex, isArrowKeyPressed, ɵ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({ reflect: true })];
|
|
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 = [tabGroupCommonStyles, unsafeCSS(tab_group_default)];
|
|
96
|
-
}
|
|
97
|
-
static {
|
|
98
|
-
this.events = { tabchange: "tabchange" };
|
|
99
|
-
}
|
|
100
|
-
#size_accessor_storage;
|
|
101
|
-
/**
|
|
102
|
-
* Size variant, either s (lean theme default), l (standard theme default) or xl.
|
|
103
|
-
*/
|
|
104
|
-
get size() {
|
|
105
|
-
return this.#size_accessor_storage;
|
|
106
|
-
}
|
|
107
|
-
set size(value) {
|
|
108
|
-
this.#size_accessor_storage = value;
|
|
109
|
-
}
|
|
110
|
-
#initialSelectedIndex_accessor_storage;
|
|
111
|
-
/**
|
|
112
|
-
* Sets the initial tab. If it matches a disabled tab or exceeds the length of
|
|
113
|
-
* the tab group, the first enabled tab will be selected.
|
|
114
|
-
*/
|
|
115
|
-
get initialSelectedIndex() {
|
|
116
|
-
return this.#initialSelectedIndex_accessor_storage;
|
|
117
|
-
}
|
|
118
|
-
set initialSelectedIndex(value) {
|
|
119
|
-
this.#initialSelectedIndex_accessor_storage = value;
|
|
120
|
-
}
|
|
121
|
-
#fixedHeight_accessor_storage;
|
|
122
|
-
/**
|
|
123
|
-
* If set to true, the `sbb-tab` elements take 100% height of the `sbb-tab-group`.
|
|
124
|
-
* It enables controlling the height on the `sbb-tab-group` element.
|
|
125
|
-
* The content becomes scrollable on overflow.
|
|
126
|
-
*/
|
|
127
|
-
get fixedHeight() {
|
|
128
|
-
return this.#fixedHeight_accessor_storage;
|
|
129
|
-
}
|
|
130
|
-
set fixedHeight(value) {
|
|
131
|
-
this.#fixedHeight_accessor_storage = value;
|
|
132
|
-
}
|
|
133
|
-
/** Gets the slotted `sbb-tab-label`s. */
|
|
134
|
-
get labels() {
|
|
135
|
-
/**
|
|
136
|
-
* The querySelector API is not used because when nested tabs are used,
|
|
137
|
-
* the returned array contains the inner tabs too, and this breaks the keyboard navigation.
|
|
138
|
-
*/
|
|
139
|
-
return Array.from(this.children ?? []).filter((child) => /^sbb-tab-label$/u.test(child.localName));
|
|
140
|
-
}
|
|
141
|
-
/** Gets the slotted `sbb-tab`s. */
|
|
142
|
-
get tabs() {
|
|
143
|
-
/**
|
|
144
|
-
* The querySelector API is not used because when nested tabs are used,
|
|
145
|
-
* the returned array contains the inner tabs too, and this breaks the keyboard navigation.
|
|
146
|
-
*/
|
|
147
|
-
return Array.from(this.children ?? []).filter((child) => /^sbb-tab$/u.test(child.localName));
|
|
148
|
-
}
|
|
149
|
-
constructor() {
|
|
150
|
-
super();
|
|
151
|
-
this._tabGroupResizeObserver = new ResizeController(this, {
|
|
152
|
-
target: null,
|
|
153
|
-
skipInitial: true,
|
|
154
|
-
callback: () => this._onTabGroupElementResize()
|
|
155
|
-
});
|
|
156
|
-
this.#size_accessor_storage = __runInitializers(this, _size_initializers, null);
|
|
157
|
-
this.#initialSelectedIndex_accessor_storage = (__runInitializers(this, _size_extraInitializers), __runInitializers(this, _initialSelectedIndex_initializers, 0));
|
|
158
|
-
this.#fixedHeight_accessor_storage = (__runInitializers(this, _initialSelectedIndex_extraInitializers), __runInitializers(this, _fixedHeight_initializers, false));
|
|
159
|
-
__runInitializers(this, _fixedHeight_extraInitializers);
|
|
160
|
-
this.addEventListener?.("keydown", (e) => this._handleKeyDown(e));
|
|
161
|
-
}
|
|
162
|
-
firstUpdated(changedProperties) {
|
|
163
|
-
super.firstUpdated(changedProperties);
|
|
164
|
-
this.labels.forEach((tabLabel) => tabLabel["linkToTab"]());
|
|
165
|
-
this._initSelection();
|
|
166
|
-
Promise.resolve().then(() => this.internals.states.add("initialized"));
|
|
167
|
-
this._tabGroupResizeObserver.observe(this._tabGroupElement);
|
|
168
|
-
}
|
|
169
|
-
/**
|
|
170
|
-
* Disables a tab by index.
|
|
171
|
-
* @param index The index of the tab you want to disable.
|
|
172
|
-
*/
|
|
173
|
-
disableTab(index) {
|
|
174
|
-
if (this.labels[index]) this.labels[index].disabled = true;
|
|
175
|
-
}
|
|
176
|
-
/**
|
|
177
|
-
* Enables a tab by index.
|
|
178
|
-
* @param index The index of the tab you want to enable.
|
|
179
|
-
*/
|
|
180
|
-
enableTab(index) {
|
|
181
|
-
if (this.labels[index]) this.labels[index].disabled = false;
|
|
182
|
-
}
|
|
183
|
-
/**
|
|
184
|
-
* Activates a tab by index.
|
|
185
|
-
* @param index The index of the tab you want to activate.
|
|
186
|
-
*/
|
|
187
|
-
activateTab(index) {
|
|
188
|
-
this.labels[index]?.activate();
|
|
189
|
-
}
|
|
190
|
-
_enabledTabs() {
|
|
191
|
-
return this.labels.filter((t) => {
|
|
192
|
-
customElements.upgrade(t);
|
|
193
|
-
return !t.disabled;
|
|
194
|
-
});
|
|
195
|
-
}
|
|
196
|
-
_onContentSlotChange() {
|
|
197
|
-
if (this._contentSlotChangeDebounceId) clearTimeout(this._contentSlotChangeDebounceId);
|
|
198
|
-
this._contentSlotChangeDebounceId = setTimeout(() => {
|
|
199
|
-
this.labels.forEach((tabLabel) => tabLabel["linkToTab"]());
|
|
200
|
-
this.labels.find((tabLabel) => tabLabel.active)?.activate();
|
|
201
|
-
}, 150);
|
|
202
|
-
}
|
|
203
|
-
_onLabelSlotChange() {
|
|
204
|
-
this.labels.forEach((tabLabel) => tabLabel["linkToTab"]());
|
|
205
|
-
this._ensureActiveTab();
|
|
206
|
-
}
|
|
207
|
-
_ensureActiveTab() {
|
|
208
|
-
if (this.matches?.(":is(:state(initialized),[state--initialized])") && !this.labels.some((tabLabel) => tabLabel.active)) this._initSelection();
|
|
209
|
-
}
|
|
210
|
-
_initSelection() {
|
|
211
|
-
const selectedTabLabel = this.labels[this.initialSelectedIndex];
|
|
212
|
-
if (selectedTabLabel) {
|
|
213
|
-
customElements.upgrade(selectedTabLabel);
|
|
214
|
-
if (this.initialSelectedIndex >= 0 && this.initialSelectedIndex < this.labels.length && !selectedTabLabel.disabled) {
|
|
215
|
-
selectedTabLabel.activate();
|
|
216
|
-
return;
|
|
217
|
-
}
|
|
218
|
-
}
|
|
219
|
-
this._enabledTabs()[0]?.activate();
|
|
220
|
-
}
|
|
221
|
-
_onTabGroupElementResize() {
|
|
222
|
-
const tabLabels = this.labels;
|
|
223
|
-
tabLabels.forEach((tabLabel) => {
|
|
224
|
-
ɵstateController(tabLabel)?.toggle("has-divider", tabLabel === tabLabels[0] || tabLabel.offsetLeft === tabLabels[0].offsetLeft);
|
|
225
|
-
});
|
|
226
|
-
this.style.setProperty("--sbb-tab-group-width", `${this._tabGroupElement.clientWidth}px`);
|
|
227
|
-
}
|
|
228
|
-
_handleKeyDown(evt) {
|
|
229
|
-
const enabledTabs = this._enabledTabs();
|
|
230
|
-
if (!enabledTabs || evt.target !== this && evt.target.parentElement !== this) return;
|
|
231
|
-
if (isArrowKeyPressed(evt)) {
|
|
232
|
-
const nextIndex = getNextElementIndex(evt, enabledTabs.findIndex((t) => t.active), enabledTabs.length);
|
|
233
|
-
enabledTabs[nextIndex]?.activate();
|
|
234
|
-
enabledTabs[nextIndex]?.focus();
|
|
235
|
-
evt.preventDefault();
|
|
236
|
-
}
|
|
237
|
-
}
|
|
238
|
-
/**
|
|
239
|
-
* @internal
|
|
240
|
-
*/
|
|
241
|
-
setTabContentHeight(contentHeight) {
|
|
242
|
-
this.style.setProperty("--sbb-tab-content-height", `${contentHeight}px`);
|
|
243
|
-
}
|
|
244
|
-
render() {
|
|
245
|
-
return html`
|
|
246
|
-
<div
|
|
247
|
-
class="sbb-tab-group"
|
|
248
|
-
role="tablist"
|
|
249
|
-
${ref((el) => this._tabGroupElement = el)}
|
|
250
|
-
>
|
|
251
|
-
<slot name="tab-bar" @slotchange=${this._onLabelSlotChange}></slot>
|
|
252
|
-
</div>
|
|
253
|
-
${!this.fixedHeight ? html`
|
|
254
|
-
<div class="sbb-tab-group-content">
|
|
255
|
-
<slot @slotchange=${this._onContentSlotChange}></slot>
|
|
256
|
-
</div>
|
|
257
|
-
` : html`<slot @slotchange=${this._onContentSlotChange}></slot>`}
|
|
258
|
-
`;
|
|
259
|
-
}
|
|
260
|
-
};
|
|
261
|
-
})();
|
|
262
|
-
//#endregion
|
|
263
|
-
export { SbbTabGroupElement as t };
|
|
264
|
-
|
|
265
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLWdyb3VwLmNvbXBvbmVudC1ENGZ2ZDZVdS5qcyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZWxlbWVudHMvdGFicy90YWItZ3JvdXAvdGFiLWdyb3VwLnNjc3M/aW5saW5lIiwiLi4vLi4vLi4vc3JjL2VsZW1lbnRzL3RhYnMvdGFiLWdyb3VwL3RhYi1ncm91cC5jb21wb25lbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiQHVzZSAnLi4vLi4vY29yZS9zdHlsZXMnIGFzIHNiYjtcblxuOmhvc3Qge1xuICAtLXNiYi10YWItZ3JvdXAtYW5pbWF0aW9uLWR1cmF0aW9uOiAwcztcblxuICBnYXA6IHZhcigtLXNiYi10YWItZ3JvdXAtY29udGVudC1nYXApO1xufVxuXG46aG9zdCg6c3RhdGUoaW5pdGlhbGl6ZWQpKSB7XG4gIC0tc2JiLXRhYi1ncm91cC1hbmltYXRpb24tZHVyYXRpb246IHZhcihcbiAgICAtLXNiYi1kaXNhYmxlLWFuaW1hdGlvbi1kdXJhdGlvbixcbiAgICB2YXIoLS1zYmItYW5pbWF0aW9uLWR1cmF0aW9uLTR4KVxuICApO1xufVxuXG4uc2JiLXRhYi1ncm91cC1jb250ZW50IHtcbiAgaGVpZ2h0OiB2YXIoLS1zYmItdGFiLWNvbnRlbnQtaGVpZ2h0KTtcbiAgdHJhbnNpdGlvbjogaGVpZ2h0IHZhcigtLXNiYi10YWItZ3JvdXAtYW5pbWF0aW9uLWR1cmF0aW9uKSB2YXIoLS1zYmItYW5pbWF0aW9uLWVhc2luZyk7XG59XG5cbjo6c2xvdHRlZChzYmItdGFiKSB7XG4gIDpob3N0KFtmaXhlZC1oZWlnaHRdKSAmIHtcbiAgICBoZWlnaHQ6IDEwMCU7XG4gICAgb3ZlcmZsb3c6IGF1dG87XG4gIH1cbn1cbiIsImltcG9ydCB7IFJlc2l6ZUNvbnRyb2xsZXIgfSBmcm9tICdAbGl0LWxhYnMvb2JzZXJ2ZXJzL3Jlc2l6ZS1jb250cm9sbGVyLmpzJztcbmltcG9ydCB7XG4gIHR5cGUgQ1NTUmVzdWx0R3JvdXAsXG4gIGh0bWwsXG4gIHR5cGUgUHJvcGVydHlWYWx1ZXMsXG4gIHR5cGUgVGVtcGxhdGVSZXN1bHQsXG4gIHVuc2FmZUNTUyxcbn0gZnJvbSAnbGl0JztcbmltcG9ydCB7IHByb3BlcnR5IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuaW1wb3J0IHsgcmVmIH0gZnJvbSAnbGl0L2RpcmVjdGl2ZXMvcmVmLmpzJztcblxuaW1wb3J0IHtcbiAgZm9yY2VUeXBlLFxuICBnZXROZXh0RWxlbWVudEluZGV4LFxuICBpc0Fycm93S2V5UHJlc3NlZCxcbiAgU2JiRWxlbWVudCxcbiAgybVzdGF0ZUNvbnRyb2xsZXIsXG59IGZyb20gJy4uLy4uL2NvcmUudHMnO1xuaW1wb3J0IHsgdGFiR3JvdXBDb21tb25TdHlsZXMgfSBmcm9tICcuLi9jb21tb24vc3R5bGVzLnRzJztcbmltcG9ydCB0eXBlIHsgU2JiVGFiRWxlbWVudCB9IGZyb20gJy4uL3RhYi90YWIuY29tcG9uZW50LnRzJztcbmltcG9ydCB0eXBlIHsgU2JiVGFiTGFiZWxFbGVtZW50IH0gZnJvbSAnLi4vdGFiLWxhYmVsL3RhYi1sYWJlbC5jb21wb25lbnQudHMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi90YWItZ3JvdXAuc2Nzcz9pbmxpbmUnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFNiYlRhYkNoYW5nZWRFdmVudERldGFpbHMge1xuICBhY3RpdmVJbmRleDogbnVtYmVyO1xuICBhY3RpdmVUYWJMYWJlbDogU2JiVGFiTGFiZWxFbGVtZW50O1xuICBhY3RpdmVUYWI6IFNiYlRhYkVsZW1lbnQ7XG4gIHByZXZpb3VzSW5kZXg6IG51bWJlcjtcbiAgcHJldmlvdXNUYWJMYWJlbDogU2JiVGFiTGFiZWxFbGVtZW50IHwgdW5kZWZpbmVkO1xuICBwcmV2aW91c1RhYjogU2JiVGFiRWxlbWVudCB8IHVuZGVmaW5lZDtcbn1cblxuLyoqXG4gKiBJdCBkaXNwbGF5cyBvbmUgb3IgbW9yZSB0YWJzLCBlYWNoIG9uZSB3aXRoIGEgbGFiZWwgYW5kIHNvbWUgY29udGVudC5cbiAqXG4gKiBAc2xvdCAtIFVzZSB0aGUgdW5uYW1lZCBzbG90IHRvIGFkZCBjb250ZW50IHRvIHRoZSBgc2JiLXRhYi1ncm91cGAgdmlhIGBzYmItdGFiLWxhYmVsYCBhbmQgYHNiYi10YWJgIGluc3RhbmNlcy5cbiAqIEBldmVudCB7Q3VzdG9tRXZlbnQ8U2JiVGFiQ2hhbmdlZEV2ZW50RGV0YWlscz59IHRhYmNoYW5nZSAtIFRoZSB0YWJjaGFuZ2UgZXZlbnQgaXMgZGlzcGF0Y2hlZCB3aGVuIGEgdGFiIGlzIHNlbGVjdGVkLlxuICovXG5leHBvcnQgY2xhc3MgU2JiVGFiR3JvdXBFbGVtZW50IGV4dGVuZHMgU2JiRWxlbWVudCB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgcmVhZG9ubHkgZWxlbWVudE5hbWU6IHN0cmluZyA9ICdzYmItdGFiLWdyb3VwJztcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gW3RhYkdyb3VwQ29tbW9uU3R5bGVzLCB1bnNhZmVDU1Moc3R5bGUpXTtcbiAgcHVibGljIHN0YXRpYyByZWFkb25seSBldmVudHMgPSB7XG4gICAgdGFiY2hhbmdlOiAndGFiY2hhbmdlJyxcbiAgfSBhcyBjb25zdDtcblxuICBwcml2YXRlIF90YWJHcm91cEVsZW1lbnQhOiBIVE1MRWxlbWVudDtcbiAgcHJpdmF0ZSBfdGFiR3JvdXBSZXNpemVPYnNlcnZlciA9IG5ldyBSZXNpemVDb250cm9sbGVyKHRoaXMsIHtcbiAgICB0YXJnZXQ6IG51bGwsXG4gICAgc2tpcEluaXRpYWw6IHRydWUsXG4gICAgY2FsbGJhY2s6ICgpID0+IHRoaXMuX29uVGFiR3JvdXBFbGVtZW50UmVzaXplKCksXG4gIH0pO1xuICBwcml2YXRlIF9jb250ZW50U2xvdENoYW5nZURlYm91bmNlSWQ/OiBSZXR1cm5UeXBlPHR5cGVvZiBzZXRUaW1lb3V0PjtcblxuICAvKipcbiAgICogU2l6ZSB2YXJpYW50LCBlaXRoZXIgcyAobGVhbiB0aGVtZSBkZWZhdWx0KSwgbCAoc3RhbmRhcmQgdGhlbWUgZGVmYXVsdCkgb3IgeGwuXG4gICAqL1xuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pXG4gIHB1YmxpYyBhY2Nlc3NvciBzaXplOiAncycgfCAnbCcgfCAneGwnIHwgbnVsbCA9IG51bGw7XG5cbiAgLyoqXG4gICAqIFNldHMgdGhlIGluaXRpYWwgdGFiLiBJZiBpdCBtYXRjaGVzIGEgZGlzYWJsZWQgdGFiIG9yIGV4Y2VlZHMgdGhlIGxlbmd0aCBvZlxuICAgKiB0aGUgdGFiIGdyb3VwLCB0aGUgZmlyc3QgZW5hYmxlZCB0YWIgd2lsbCBiZSBzZWxlY3RlZC5cbiAgICovXG4gIEBmb3JjZVR5cGUoKVxuICBAcHJvcGVydHkoeyBhdHRyaWJ1dGU6ICdpbml0aWFsLXNlbGVjdGVkLWluZGV4JywgdHlwZTogTnVtYmVyIH0pXG4gIHB1YmxpYyBhY2Nlc3NvciBpbml0aWFsU2VsZWN0ZWRJbmRleDogbnVtYmVyID0gMDtcblxuICAvKipcbiAgICogSWYgc2V0IHRvIHRydWUsIHRoZSBgc2JiLXRhYmAgZWxlbWVudHMgdGFrZSAxMDAlIGhlaWdodCBvZiB0aGUgYHNiYi10YWItZ3JvdXBgLlxuICAgKiBJdCBlbmFibGVzIGNvbnRyb2xsaW5nIHRoZSBoZWlnaHQgb24gdGhlIGBzYmItdGFiLWdyb3VwYCBlbGVtZW50LlxuICAgKiBUaGUgY29udGVudCBiZWNvbWVzIHNjcm9sbGFibGUgb24gb3ZlcmZsb3cuXG4gICAqL1xuICBAZm9yY2VUeXBlKClcbiAgQHByb3BlcnR5KHsgYXR0cmlidXRlOiAnZml4ZWQtaGVpZ2h0JywgdHlwZTogQm9vbGVhbiwgcmVmbGVjdDogdHJ1ZSB9KVxuICBwdWJsaWMgYWNjZXNzb3IgZml4ZWRIZWlnaHQ6IGJvb2xlYW4gPSBmYWxzZTtcblxuICAvKiogR2V0cyB0aGUgc2xvdHRlZCBgc2JiLXRhYi1sYWJlbGBzLiAqL1xuICBwdWJsaWMgZ2V0IGxhYmVscygpOiBTYmJUYWJMYWJlbEVsZW1lbnRbXSB7XG4gICAgLyoqXG4gICAgICogVGhlIHF1ZXJ5U2VsZWN0b3IgQVBJIGlzIG5vdCB1c2VkIGJlY2F1c2Ugd2hlbiBuZXN0ZWQgdGFicyBhcmUgdXNlZCxcbiAgICAgKiB0aGUgcmV0dXJuZWQgYXJyYXkgY29udGFpbnMgdGhlIGlubmVyIHRhYnMgdG9vLCBhbmQgdGhpcyBicmVha3MgdGhlIGtleWJvYXJkIG5hdmlnYXRpb24uXG4gICAgICovXG4gICAgcmV0dXJuIEFycmF5LmZyb20odGhpcy5jaGlsZHJlbiA/PyBbXSkuZmlsdGVyKChjaGlsZCkgPT5cbiAgICAgIC9ec2JiLXRhYi1sYWJlbCQvdS50ZXN0KGNoaWxkLmxvY2FsTmFtZSksXG4gICAgKSBhcyBTYmJUYWJMYWJlbEVsZW1lbnRbXTtcbiAgfVxuXG4gIC8qKiBHZXRzIHRoZSBzbG90dGVkIGBzYmItdGFiYHMuICovXG4gIHB1YmxpYyBnZXQgdGFicygpOiBTYmJUYWJFbGVtZW50W10ge1xuICAgIC8qKlxuICAgICAqIFRoZSBxdWVyeVNlbGVjdG9yIEFQSSBpcyBub3QgdXNlZCBiZWNhdXNlIHdoZW4gbmVzdGVkIHRhYnMgYXJlIHVzZWQsXG4gICAgICogdGhlIHJldHVybmVkIGFycmF5IGNvbnRhaW5zIHRoZSBpbm5lciB0YWJzIHRvbywgYW5kIHRoaXMgYnJlYWtzIHRoZSBrZXlib2FyZCBuYXZpZ2F0aW9uLlxuICAgICAqL1xuICAgIHJldHVybiBBcnJheS5mcm9tKHRoaXMuY2hpbGRyZW4gPz8gW10pLmZpbHRlcigoY2hpbGQpID0+XG4gICAgICAvXnNiYi10YWIkL3UudGVzdChjaGlsZC5sb2NhbE5hbWUpLFxuICAgICkgYXMgU2JiVGFiRWxlbWVudFtdO1xuICB9XG5cbiAgcHVibGljIGNvbnN0cnVjdG9yKCkge1xuICAgIHN1cGVyKCk7XG4gICAgdGhpcy5hZGRFdmVudExpc3RlbmVyPy4oJ2tleWRvd24nLCAoZSkgPT4gdGhpcy5faGFuZGxlS2V5RG93bihlKSk7XG4gIH1cblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgZmlyc3RVcGRhdGVkKGNoYW5nZWRQcm9wZXJ0aWVzOiBQcm9wZXJ0eVZhbHVlczx0aGlzPik6IHZvaWQge1xuICAgIHN1cGVyLmZpcnN0VXBkYXRlZChjaGFuZ2VkUHJvcGVydGllcyk7XG5cbiAgICB0aGlzLmxhYmVscy5mb3JFYWNoKCh0YWJMYWJlbCkgPT4gdGFiTGFiZWxbJ2xpbmtUb1RhYiddKCkpO1xuICAgIHRoaXMuX2luaXRTZWxlY3Rpb24oKTtcblxuICAgIC8vIFRvIGF2b2lkIGFuaW1hdGlvbnMgb24gaW5pdGlhbGl6YXRpb24sIHdlIGhhdmUgdG8gbWFyayB0aGUgY29tcG9uZW50IGFzIGluaXRpYWxpemVkIGFuZCB3YWl0IGEgdGljay5cbiAgICBQcm9taXNlLnJlc29sdmUoKS50aGVuKCgpID0+IHRoaXMuaW50ZXJuYWxzLnN0YXRlcy5hZGQoJ2luaXRpYWxpemVkJykpO1xuICAgIHRoaXMuX3RhYkdyb3VwUmVzaXplT2JzZXJ2ZXIub2JzZXJ2ZSh0aGlzLl90YWJHcm91cEVsZW1lbnQpO1xuICB9XG5cbiAgLyoqXG4gICAqIERpc2FibGVzIGEgdGFiIGJ5IGluZGV4LlxuICAgKiBAcGFyYW0gaW5kZXggVGhlIGluZGV4IG9mIHRoZSB0YWIgeW91IHdhbnQgdG8gZGlzYWJsZS5cbiAgICovXG4gIHB1YmxpYyBkaXNhYmxlVGFiKGluZGV4OiBudW1iZXIpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5sYWJlbHNbaW5kZXhdKSB7XG4gICAgICB0aGlzLmxhYmVsc1tpbmRleF0uZGlzYWJsZWQgPSB0cnVlO1xuICAgIH1cbiAgfVxuXG4gIC8qKlxuICAgKiBFbmFibGVzIGEgdGFiIGJ5IGluZGV4LlxuICAgKiBAcGFyYW0gaW5kZXggVGhlIGluZGV4IG9mIHRoZSB0YWIgeW91IHdhbnQgdG8gZW5hYmxlLlxuICAgKi9cbiAgcHVibGljIGVuYWJsZVRhYihpbmRleDogbnVtYmVyKTogdm9pZCB7XG4gICAgaWYgKHRoaXMubGFiZWxzW2luZGV4XSkge1xuICAgICAgdGhpcy5sYWJlbHNbaW5kZXhdLmRpc2FibGVkID0gZmFsc2U7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIEFjdGl2YXRlcyBhIHRhYiBieSBpbmRleC5cbiAgICogQHBhcmFtIGluZGV4IFRoZSBpbmRleCBvZiB0aGUgdGFiIHlvdSB3YW50IHRvIGFjdGl2YXRlLlxuICAgKi9cbiAgcHVibGljIGFjdGl2YXRlVGFiKGluZGV4OiBudW1iZXIpOiB2b2lkIHtcbiAgICB0aGlzLmxhYmVsc1tpbmRleF0/LmFjdGl2YXRlKCk7XG4gIH1cblxuICBwcml2YXRlIF9lbmFibGVkVGFicygpOiBTYmJUYWJMYWJlbEVsZW1lbnRbXSB7XG4gICAgcmV0dXJuIHRoaXMubGFiZWxzLmZpbHRlcigodCkgPT4ge1xuICAgICAgY3VzdG9tRWxlbWVudHMudXBncmFkZSh0KTtcbiAgICAgIHJldHVybiAhdC5kaXNhYmxlZDtcbiAgICB9KTtcbiAgfVxuXG4gIHByaXZhdGUgX29uQ29udGVudFNsb3RDaGFuZ2UoKTogdm9pZCB7XG4gICAgaWYgKHRoaXMuX2NvbnRlbnRTbG90Q2hhbmdlRGVib3VuY2VJZCkge1xuICAgICAgY2xlYXJUaW1lb3V0KHRoaXMuX2NvbnRlbnRTbG90Q2hhbmdlRGVib3VuY2VJZCk7XG4gICAgfVxuICAgIHRoaXMuX2NvbnRlbnRTbG90Q2hhbmdlRGVib3VuY2VJZCA9IHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgdGhpcy5sYWJlbHMuZm9yRWFjaCgodGFiTGFiZWwpID0+IHRhYkxhYmVsWydsaW5rVG9UYWInXSgpKTtcbiAgICAgIHRoaXMubGFiZWxzLmZpbmQoKHRhYkxhYmVsKSA9PiB0YWJMYWJlbC5hY3RpdmUpPy5hY3RpdmF0ZSgpO1xuICAgIH0sIDE1MCk7XG4gIH1cblxuICBwcml2YXRlIF9vbkxhYmVsU2xvdENoYW5nZSgpOiB2b2lkIHtcbiAgICB0aGlzLmxhYmVscy5mb3JFYWNoKCh0YWJMYWJlbCkgPT4gdGFiTGFiZWxbJ2xpbmtUb1RhYiddKCkpO1xuICAgIHRoaXMuX2Vuc3VyZUFjdGl2ZVRhYigpO1xuICB9XG5cbiAgcHJpdmF0ZSBfZW5zdXJlQWN0aXZlVGFiKCk6IHZvaWQge1xuICAgIGlmICh0aGlzLm1hdGNoZXM/LignOnN0YXRlKGluaXRpYWxpemVkKScpICYmICF0aGlzLmxhYmVscy5zb21lKCh0YWJMYWJlbCkgPT4gdGFiTGFiZWwuYWN0aXZlKSkge1xuICAgICAgdGhpcy5faW5pdFNlbGVjdGlvbigpO1xuICAgIH1cbiAgfVxuXG4gIHByaXZhdGUgX2luaXRTZWxlY3Rpb24oKTogdm9pZCB7XG4gICAgY29uc3Qgc2VsZWN0ZWRUYWJMYWJlbCA9IHRoaXMubGFiZWxzW3RoaXMuaW5pdGlhbFNlbGVjdGVkSW5kZXhdO1xuICAgIGlmIChzZWxlY3RlZFRhYkxhYmVsKSB7XG4gICAgICBjdXN0b21FbGVtZW50cy51cGdyYWRlKHNlbGVjdGVkVGFiTGFiZWwpO1xuICAgICAgaWYgKFxuICAgICAgICB0aGlzLmluaXRpYWxTZWxlY3RlZEluZGV4ID49IDAgJiZcbiAgICAgICAgdGhpcy5pbml0aWFsU2VsZWN0ZWRJbmRleCA8IHRoaXMubGFiZWxzLmxlbmd0aCAmJlxuICAgICAgICAhc2VsZWN0ZWRUYWJMYWJlbC5kaXNhYmxlZFxuICAgICAgKSB7XG4gICAgICAgIHNlbGVjdGVkVGFiTGFiZWwuYWN0aXZhdGUoKTtcbiAgICAgICAgcmV0dXJuO1xuICAgICAgfVxuICAgIH1cbiAgICB0aGlzLl9lbmFibGVkVGFicygpWzBdPy5hY3RpdmF0ZSgpO1xuICB9XG5cbiAgcHJpdmF0ZSBfb25UYWJHcm91cEVsZW1lbnRSZXNpemUoKTogdm9pZCB7XG4gICAgY29uc3QgdGFiTGFiZWxzID0gdGhpcy5sYWJlbHM7XG4gICAgdGFiTGFiZWxzLmZvckVhY2goKHRhYkxhYmVsKSA9PiB7XG4gICAgICDJtXN0YXRlQ29udHJvbGxlcih0YWJMYWJlbCk/LnRvZ2dsZShcbiAgICAgICAgJ2hhcy1kaXZpZGVyJyxcbiAgICAgICAgdGFiTGFiZWwgPT09IHRhYkxhYmVsc1swXSB8fCB0YWJMYWJlbC5vZmZzZXRMZWZ0ID09PSB0YWJMYWJlbHNbMF0ub2Zmc2V0TGVmdCxcbiAgICAgICk7XG4gICAgfSk7XG5cbiAgICB0aGlzLnN0eWxlLnNldFByb3BlcnR5KCctLXNiYi10YWItZ3JvdXAtd2lkdGgnLCBgJHt0aGlzLl90YWJHcm91cEVsZW1lbnQuY2xpZW50V2lkdGh9cHhgKTtcbiAgfVxuXG4gIHByaXZhdGUgX2hhbmRsZUtleURvd24oZXZ0OiBLZXlib2FyZEV2ZW50KTogdm9pZCB7XG4gICAgY29uc3QgZW5hYmxlZFRhYnM6IFNiYlRhYkxhYmVsRWxlbWVudFtdID0gdGhpcy5fZW5hYmxlZFRhYnMoKTtcblxuICAgIGlmIChcbiAgICAgICFlbmFibGVkVGFicyB8fFxuICAgICAgLy8gZG9uJ3QgdHJhcCBuZXN0ZWQgaGFuZGxpbmdcbiAgICAgICgoZXZ0LnRhcmdldCBhcyBIVE1MRWxlbWVudCkgIT09IHRoaXMgJiYgKGV2dC50YXJnZXQgYXMgSFRNTEVsZW1lbnQpLnBhcmVudEVsZW1lbnQgIT09IHRoaXMpXG4gICAgKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgaWYgKGlzQXJyb3dLZXlQcmVzc2VkKGV2dCkpIHtcbiAgICAgIGNvbnN0IGN1cnJlbnQ6IG51bWJlciA9IGVuYWJsZWRUYWJzLmZpbmRJbmRleCgodCkgPT4gdC5hY3RpdmUpO1xuICAgICAgY29uc3QgbmV4dEluZGV4OiBudW1iZXIgPSBnZXROZXh0RWxlbWVudEluZGV4KGV2dCwgY3VycmVudCwgZW5hYmxlZFRhYnMubGVuZ3RoKTtcbiAgICAgIGVuYWJsZWRUYWJzW25leHRJbmRleF0/LmFjdGl2YXRlKCk7XG4gICAgICBlbmFibGVkVGFic1tuZXh0SW5kZXhdPy5mb2N1cygpO1xuICAgICAgZXZ0LnByZXZlbnREZWZhdWx0KCk7XG4gICAgfVxuICB9XG5cbiAgLyoqXG4gICAqIEBpbnRlcm5hbFxuICAgKi9cbiAgcHJvdGVjdGVkIHNldFRhYkNvbnRlbnRIZWlnaHQoY29udGVudEhlaWdodDogbnVtYmVyKTogdm9pZCB7XG4gICAgdGhpcy5zdHlsZS5zZXRQcm9wZXJ0eSgnLS1zYmItdGFiLWNvbnRlbnQtaGVpZ2h0JywgYCR7Y29udGVudEhlaWdodH1weGApO1xuICB9XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlcigpOiBUZW1wbGF0ZVJlc3VsdCB7XG4gICAgcmV0dXJuIGh0bWxgXG4gICAgICA8ZGl2XG4gICAgICAgIGNsYXNzPVwic2JiLXRhYi1ncm91cFwiXG4gICAgICAgIHJvbGU9XCJ0YWJsaXN0XCJcbiAgICAgICAgJHtyZWYoKGVsPzogRWxlbWVudCkgPT4gKHRoaXMuX3RhYkdyb3VwRWxlbWVudCA9IGVsIGFzIEhUTUxFbGVtZW50KSl9XG4gICAgICA+XG4gICAgICAgIDxzbG90IG5hbWU9XCJ0YWItYmFyXCIgQHNsb3RjaGFuZ2U9JHt0aGlzLl9vbkxhYmVsU2xvdENoYW5nZX0+PC9zbG90PlxuICAgICAgPC9kaXY+XG4gICAgICAkeyF0aGlzLmZpeGVkSGVpZ2h0XG4gICAgICAgID8gaHRtbGBcbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJzYmItdGFiLWdyb3VwLWNvbnRlbnRcIj5cbiAgICAgICAgICAgICAgPHNsb3QgQHNsb3RjaGFuZ2U9JHt0aGlzLl9vbkNvbnRlbnRTbG90Q2hhbmdlfT48L3Nsb3Q+XG4gICAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgICBgXG4gICAgICAgIDogaHRtbGA8c2xvdCBAc2xvdGNoYW5nZT0ke3RoaXMuX29uQ29udGVudFNsb3RDaGFuZ2V9Pjwvc2xvdD5gfVxuICAgIGA7XG4gIH1cbn1cblxuZGVjbGFyZSBnbG9iYWwge1xuICBpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25hbWluZy1jb252ZW50aW9uXG4gICAgJ3NiYi10YWItZ3JvdXAnOiBTYmJUYWJHcm91cEVsZW1lbnQ7XG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7SUN1Q2EsNEJBQWtCO21CQUFTOzs7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
|