@sbb-esta/lyne-elements 3.8.0 → 3.9.0

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