@sbb-esta/lyne-elements-dev 4.11.0-dev.1776257936 → 4.11.0-dev.1776332009

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (30) hide show
  1. package/autocomplete/autocomplete-base-element.js +1 -1
  2. package/autocomplete/autocomplete.component.js +1 -1
  3. package/{autocomplete-base-element-DarHnnYC.js → autocomplete-base-element-BryH362a.js} +12 -7
  4. package/autocomplete.js +1 -1
  5. package/autocomplete.pure.js +1 -1
  6. package/custom-elements.json +8379 -8340
  7. package/development/autocomplete/autocomplete-base-element.d.ts +2 -1
  8. package/development/autocomplete/autocomplete-base-element.d.ts.map +1 -1
  9. package/development/autocomplete/autocomplete-base-element.js +1 -1
  10. package/development/autocomplete/autocomplete.component.js +1 -1
  11. package/development/{autocomplete-base-element-VKU7Lpr7.js → autocomplete-base-element-BNfirRyP.js} +15 -7
  12. package/development/autocomplete.js +1 -1
  13. package/development/autocomplete.pure.js +1 -1
  14. package/development/core/eventing/throttle.d.ts +1 -0
  15. package/development/core/eventing/throttle.d.ts.map +1 -1
  16. package/development/core/eventing/throttle.js +2 -1
  17. package/development/tab-group.component-DldBA45K.js +275 -0
  18. package/development/tabs/tab-group/tab-group.component.d.ts +1 -0
  19. package/development/tabs/tab-group/tab-group.component.d.ts.map +1 -1
  20. package/development/tabs/tab-group/tab-group.component.js +1 -1
  21. package/development/tabs/tab-group.js +1 -1
  22. package/development/tabs.js +1 -1
  23. package/development/tabs.pure.js +1 -1
  24. package/package.json +2 -2
  25. package/{tab-group.component-Doy39cEh.js → tab-group.component-CHQlrhUy.js} +36 -33
  26. package/tabs/tab-group/tab-group.component.js +1 -1
  27. package/tabs/tab-group.js +1 -1
  28. package/tabs.js +1 -1
  29. package/tabs.pure.js +1 -1
  30. package/development/tab-group.component-DRipdAyc.js +0 -272
@@ -1,272 +0,0 @@
1
- import { __esDecorate, __runInitializers } from "tslib";
2
- import { html, unsafeCSS } from "lit";
3
- import { property } from "lit/decorators.js";
4
- import { SbbElement } from "./core/base-elements.js";
5
- import { forceType } from "./core/decorators.js";
6
- import { isLean } from "./core/dom.js";
7
- import { throttle } from "./core/eventing.js";
8
- import { ɵstateController } from "./core/mixins.js";
9
- import { boxSizingStyles } from "./core/styles.js";
10
- import { ResizeController } from "@lit-labs/observers/resize-controller.js";
11
- import { ref } from "lit/directives/ref.js";
12
- import { getNextElementIndex, isArrowKeyPressed } from "./core/a11y.js";
13
- import { tabGroupCommonStyles } from "./tabs/common/styles.js";
14
- //#region src/elements/tabs/tab-group/tab-group.scss?inline
15
- var tab_group_default = ":host {\n --sbb-tab-group-animation-duration: 0s;\n gap: var(--sbb-tab-group-content-gap);\n}\n\n:host(:is(:state(initialized),[state--initialized])) {\n --sbb-tab-group-animation-duration: var(\n --sbb-disable-animation-duration,\n var(--sbb-animation-duration-4x)\n );\n}\n\n.sbb-tab-group-content {\n height: var(--sbb-tab-content-height);\n transition: height var(--sbb-tab-group-animation-duration) var(--sbb-animation-easing);\n}\n\n:host([fixed-height]) ::slotted(sbb-tab) {\n height: 100%;\n overflow: auto;\n}";
16
- //#endregion
17
- //#region src/elements/tabs/tab-group/tab-group.component.ts
18
- /**
19
- * It displays one or more tabs, each one with a label and some content.
20
- *
21
- * @slot - Use the unnamed slot to add content to the `sbb-tab-group` via `sbb-tab-label` and `sbb-tab` instances.
22
- * @event {CustomEvent<SbbTabChangedEventDetails>} tabchange - The tabchange event is dispatched when a tab is selected.
23
- */
24
- var SbbTabGroupElement = (() => {
25
- let _classSuper = SbbElement;
26
- let _size_decorators;
27
- let _size_initializers = [];
28
- let _size_extraInitializers = [];
29
- let _initialSelectedIndex_decorators;
30
- let _initialSelectedIndex_initializers = [];
31
- let _initialSelectedIndex_extraInitializers = [];
32
- let _fixedHeight_decorators;
33
- let _fixedHeight_initializers = [];
34
- let _fixedHeight_extraInitializers = [];
35
- return class SbbTabGroupElement extends _classSuper {
36
- static {
37
- const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
38
- _size_decorators = [property()];
39
- _initialSelectedIndex_decorators = [forceType(), property({
40
- attribute: "initial-selected-index",
41
- type: Number
42
- })];
43
- _fixedHeight_decorators = [forceType(), property({
44
- attribute: "fixed-height",
45
- type: Boolean,
46
- reflect: true
47
- })];
48
- __esDecorate(this, null, _size_decorators, {
49
- kind: "accessor",
50
- name: "size",
51
- static: false,
52
- private: false,
53
- access: {
54
- has: (obj) => "size" in obj,
55
- get: (obj) => obj.size,
56
- set: (obj, value) => {
57
- obj.size = value;
58
- }
59
- },
60
- metadata: _metadata
61
- }, _size_initializers, _size_extraInitializers);
62
- __esDecorate(this, null, _initialSelectedIndex_decorators, {
63
- kind: "accessor",
64
- name: "initialSelectedIndex",
65
- static: false,
66
- private: false,
67
- access: {
68
- has: (obj) => "initialSelectedIndex" in obj,
69
- get: (obj) => obj.initialSelectedIndex,
70
- set: (obj, value) => {
71
- obj.initialSelectedIndex = value;
72
- }
73
- },
74
- metadata: _metadata
75
- }, _initialSelectedIndex_initializers, _initialSelectedIndex_extraInitializers);
76
- __esDecorate(this, null, _fixedHeight_decorators, {
77
- kind: "accessor",
78
- name: "fixedHeight",
79
- static: false,
80
- private: false,
81
- access: {
82
- has: (obj) => "fixedHeight" in obj,
83
- get: (obj) => obj.fixedHeight,
84
- set: (obj, value) => {
85
- obj.fixedHeight = value;
86
- }
87
- },
88
- metadata: _metadata
89
- }, _fixedHeight_initializers, _fixedHeight_extraInitializers);
90
- if (_metadata) Object.defineProperty(this, Symbol.metadata, {
91
- enumerable: true,
92
- configurable: true,
93
- writable: true,
94
- value: _metadata
95
- });
96
- }
97
- static {
98
- this.elementName = "sbb-tab-group";
99
- }
100
- static {
101
- this.styles = [
102
- boxSizingStyles,
103
- tabGroupCommonStyles,
104
- unsafeCSS(tab_group_default)
105
- ];
106
- }
107
- static {
108
- this.events = { tabchange: "tabchange" };
109
- }
110
- #size_accessor_storage;
111
- /**
112
- * Size variant, either s, l or xl.
113
- * @default 'l' / 's' (lean)
114
- */
115
- get size() {
116
- return this.#size_accessor_storage;
117
- }
118
- set size(value) {
119
- this.#size_accessor_storage = value;
120
- }
121
- #initialSelectedIndex_accessor_storage;
122
- /**
123
- * Sets the initial tab. If it matches a disabled tab or exceeds the length of
124
- * the tab group, the first enabled tab will be selected.
125
- */
126
- get initialSelectedIndex() {
127
- return this.#initialSelectedIndex_accessor_storage;
128
- }
129
- set initialSelectedIndex(value) {
130
- this.#initialSelectedIndex_accessor_storage = value;
131
- }
132
- #fixedHeight_accessor_storage;
133
- /**
134
- * If set to true, the `sbb-tab` elements take 100% height of the `sbb-tab-group`.
135
- * It enables controlling the height on the `sbb-tab-group` element.
136
- * The content becomes scrollable on overflow.
137
- */
138
- get fixedHeight() {
139
- return this.#fixedHeight_accessor_storage;
140
- }
141
- set fixedHeight(value) {
142
- this.#fixedHeight_accessor_storage = value;
143
- }
144
- /** Gets the slotted `sbb-tab-label`s. */
145
- get labels() {
146
- /**
147
- * The querySelector API is not used because when nested tabs are used,
148
- * the returned array contains the inner tabs too, and this breaks the keyboard navigation.
149
- */
150
- return Array.from(this.children ?? []).filter((child) => /^sbb-tab-label$/u.test(child.localName));
151
- }
152
- /** Gets the slotted `sbb-tab`s. */
153
- get tabs() {
154
- /**
155
- * The querySelector API is not used because when nested tabs are used,
156
- * the returned array contains the inner tabs too, and this breaks the keyboard navigation.
157
- */
158
- return Array.from(this.children ?? []).filter((child) => /^sbb-tab$/u.test(child.localName));
159
- }
160
- constructor() {
161
- super();
162
- this._tabGroupResizeObserver = new ResizeController(this, {
163
- target: null,
164
- skipInitial: true,
165
- callback: () => this._onTabGroupElementResize()
166
- });
167
- this.#size_accessor_storage = __runInitializers(this, _size_initializers, isLean() ? "s" : "l");
168
- this.#initialSelectedIndex_accessor_storage = (__runInitializers(this, _size_extraInitializers), __runInitializers(this, _initialSelectedIndex_initializers, 0));
169
- this.#fixedHeight_accessor_storage = (__runInitializers(this, _initialSelectedIndex_extraInitializers), __runInitializers(this, _fixedHeight_initializers, false));
170
- this._onContentSlotChange = (__runInitializers(this, _fixedHeight_extraInitializers), () => {
171
- this.labels.forEach((tabLabel) => tabLabel["linkToTab"]());
172
- this.labels.find((tabLabel) => tabLabel.active)?.activate();
173
- });
174
- this._onLabelSlotChange = () => {
175
- this.labels.forEach((tabLabel) => tabLabel["linkToTab"]());
176
- this._ensureActiveTab();
177
- };
178
- this.addEventListener?.("keydown", (e) => this._handleKeyDown(e));
179
- }
180
- firstUpdated(changedProperties) {
181
- super.firstUpdated(changedProperties);
182
- this.labels.forEach((tabLabel) => tabLabel["linkToTab"]());
183
- this._initSelection();
184
- Promise.resolve().then(() => this.internals.states.add("initialized"));
185
- this._tabGroupResizeObserver.observe(this._tabGroupElement);
186
- }
187
- /**
188
- * Disables a tab by index.
189
- * @param index The index of the tab you want to disable.
190
- */
191
- disableTab(index) {
192
- if (this.labels[index]) this.labels[index].disabled = true;
193
- }
194
- /**
195
- * Enables a tab by index.
196
- * @param index The index of the tab you want to enable.
197
- */
198
- enableTab(index) {
199
- if (this.labels[index]) this.labels[index].disabled = false;
200
- }
201
- /**
202
- * Activates a tab by index.
203
- * @param index The index of the tab you want to activate.
204
- */
205
- activateTab(index) {
206
- this.labels[index]?.activate();
207
- }
208
- _enabledTabs() {
209
- return this.labels.filter((t) => {
210
- customElements.upgrade(t);
211
- return !t.disabled;
212
- });
213
- }
214
- _ensureActiveTab() {
215
- if (this.internals.states.has("initialized") && !this.labels.some((tabLabel) => tabLabel.active)) this._initSelection();
216
- }
217
- _initSelection() {
218
- const selectedTabLabel = this.labels[this.initialSelectedIndex];
219
- if (selectedTabLabel) {
220
- customElements.upgrade(selectedTabLabel);
221
- if (this.initialSelectedIndex >= 0 && this.initialSelectedIndex < this.labels.length && !selectedTabLabel.disabled) {
222
- selectedTabLabel.activate();
223
- return;
224
- }
225
- }
226
- this._enabledTabs()[0]?.activate();
227
- }
228
- _onTabGroupElementResize() {
229
- const tabLabels = this.labels;
230
- tabLabels.forEach((tabLabel) => {
231
- ɵstateController(tabLabel)?.toggle("has-divider", tabLabel === tabLabels[0] || tabLabel.offsetLeft === tabLabels[0].offsetLeft);
232
- });
233
- this.style.setProperty("--sbb-tab-group-width", `${this._tabGroupElement.clientWidth}px`);
234
- }
235
- _handleKeyDown(evt) {
236
- const enabledTabs = this._enabledTabs();
237
- if (!enabledTabs || evt.target !== this && evt.target.parentElement !== this) return;
238
- if (isArrowKeyPressed(evt)) {
239
- const nextIndex = getNextElementIndex(evt, enabledTabs.findIndex((t) => t.active), enabledTabs.length);
240
- enabledTabs[nextIndex]?.activate();
241
- enabledTabs[nextIndex]?.focus();
242
- evt.preventDefault();
243
- }
244
- }
245
- /**
246
- * @internal
247
- */
248
- setTabContentHeight(contentHeight) {
249
- this.style.setProperty("--sbb-tab-content-height", `${contentHeight}px`);
250
- }
251
- render() {
252
- return html`
253
- <div
254
- class="sbb-tab-group"
255
- role="tablist"
256
- ${ref((el) => this._tabGroupElement = el)}
257
- >
258
- <slot name="tab-bar" @slotchange=${this._onLabelSlotChange}></slot>
259
- </div>
260
- ${!this.fixedHeight ? html`
261
- <div class="sbb-tab-group-content">
262
- <slot @slotchange=${throttle(this._onContentSlotChange, 150)}></slot>
263
- </div>
264
- ` : html`<slot @slotchange=${throttle(this._onContentSlotChange, 150)}></slot>`}
265
- `;
266
- }
267
- };
268
- })();
269
- //#endregion
270
- export { SbbTabGroupElement as t };
271
-
272
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"tab-group.component-DRipdAyc.js","names":[],"sources":["../../../src/elements/tabs/tab-group/tab-group.scss?inline","../../../src/elements/tabs/tab-group/tab-group.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-tab-group-animation-duration: 0s;\n\n  gap: var(--sbb-tab-group-content-gap);\n}\n\n:host(:state(initialized)) {\n  --sbb-tab-group-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-4x)\n  );\n}\n\n.sbb-tab-group-content {\n  height: var(--sbb-tab-content-height);\n  transition: height var(--sbb-tab-group-animation-duration) var(--sbb-animation-easing);\n}\n\n::slotted(sbb-tab) {\n  :host([fixed-height]) & {\n    height: 100%;\n    overflow: auto;\n  }\n}\n","import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport {\n  html,\n  unsafeCSS,\n  type CSSResultGroup,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport { getNextElementIndex, isArrowKeyPressed } from '../../core/a11y.ts';\nimport { SbbElement } from '../../core/base-elements.ts';\nimport { forceType } from '../../core/decorators.ts';\nimport { isLean } from '../../core/dom.ts';\nimport { throttle } from '../../core/eventing.ts';\nimport { ɵstateController } from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport { tabGroupCommonStyles } from '../common/styles.ts';\nimport type { SbbTabElement } from '../tab/tab.component.ts';\nimport type { SbbTabLabelElement } from '../tab-label/tab-label.component.ts';\n\nimport style from './tab-group.scss?inline';\n\nexport interface SbbTabChangedEventDetails {\n  activeIndex: number;\n  activeTabLabel: SbbTabLabelElement;\n  activeTab: SbbTabElement;\n  previousIndex: number;\n  previousTabLabel: SbbTabLabelElement | undefined;\n  previousTab: SbbTabElement | undefined;\n}\n\n/**\n * It displays one or more tabs, each one with a label and some content.\n *\n * @slot - Use the unnamed slot to add content to the `sbb-tab-group` via `sbb-tab-label` and `sbb-tab` instances.\n * @event {CustomEvent<SbbTabChangedEventDetails>} tabchange - The tabchange event is dispatched when a tab is selected.\n */\nexport class SbbTabGroupElement extends SbbElement {\n  public static override readonly elementName: string = 'sbb-tab-group';\n  public static override styles: CSSResultGroup = [\n    boxSizingStyles,\n    tabGroupCommonStyles,\n    unsafeCSS(style),\n  ];\n  public static readonly events = {\n    tabchange: 'tabchange',\n  } as const;\n\n  private _tabGroupElement!: HTMLElement;\n  private _tabGroupResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: () => this._onTabGroupElementResize(),\n  });\n\n  /**\n   * Size variant, either s, l or xl.\n   * @default 'l' / 's' (lean)\n   */\n  @property()\n  public accessor size: 's' | 'l' | 'xl' = isLean() ? 's' : 'l';\n\n  /**\n   * Sets the initial tab. If it matches a disabled tab or exceeds the length of\n   * the tab group, the first enabled tab will be selected.\n   */\n  @forceType()\n  @property({ attribute: 'initial-selected-index', type: Number })\n  public accessor initialSelectedIndex: number = 0;\n\n  /**\n   * If set to true, the `sbb-tab` elements take 100% height of the `sbb-tab-group`.\n   * It enables controlling the height on the `sbb-tab-group` element.\n   * The content becomes scrollable on overflow.\n   */\n  @forceType()\n  @property({ attribute: 'fixed-height', type: Boolean, reflect: true })\n  public accessor fixedHeight: boolean = false;\n\n  /** Gets the slotted `sbb-tab-label`s. */\n  public get labels(): SbbTabLabelElement[] {\n    /**\n     * The querySelector API is not used because when nested tabs are used,\n     * the returned array contains the inner tabs too, and this breaks the keyboard navigation.\n     */\n    return Array.from(this.children ?? []).filter((child) =>\n      /^sbb-tab-label$/u.test(child.localName),\n    ) as SbbTabLabelElement[];\n  }\n\n  /** Gets the slotted `sbb-tab`s. */\n  public get tabs(): SbbTabElement[] {\n    /**\n     * The querySelector API is not used because when nested tabs are used,\n     * the returned array contains the inner tabs too, and this breaks the keyboard navigation.\n     */\n    return Array.from(this.children ?? []).filter((child) =>\n      /^sbb-tab$/u.test(child.localName),\n    ) as SbbTabElement[];\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('keydown', (e) => this._handleKeyDown(e));\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this.labels.forEach((tabLabel) => tabLabel['linkToTab']());\n    this._initSelection();\n\n    // To avoid animations on initialization, we have to mark the component as initialized and wait a tick.\n    Promise.resolve().then(() => this.internals.states.add('initialized'));\n    this._tabGroupResizeObserver.observe(this._tabGroupElement);\n  }\n\n  /**\n   * Disables a tab by index.\n   * @param index The index of the tab you want to disable.\n   */\n  public disableTab(index: number): void {\n    if (this.labels[index]) {\n      this.labels[index].disabled = true;\n    }\n  }\n\n  /**\n   * Enables a tab by index.\n   * @param index The index of the tab you want to enable.\n   */\n  public enableTab(index: number): void {\n    if (this.labels[index]) {\n      this.labels[index].disabled = false;\n    }\n  }\n\n  /**\n   * Activates a tab by index.\n   * @param index The index of the tab you want to activate.\n   */\n  public activateTab(index: number): void {\n    this.labels[index]?.activate();\n  }\n\n  private _enabledTabs(): SbbTabLabelElement[] {\n    return this.labels.filter((t) => {\n      customElements.upgrade(t);\n      return !t.disabled;\n    });\n  }\n\n  private _onContentSlotChange = (): void => {\n    this.labels.forEach((tabLabel) => tabLabel['linkToTab']());\n    this.labels.find((tabLabel) => tabLabel.active)?.activate();\n  };\n\n  private _onLabelSlotChange = (): void => {\n    this.labels.forEach((tabLabel) => tabLabel['linkToTab']());\n    this._ensureActiveTab();\n  };\n\n  private _ensureActiveTab(): void {\n    if (\n      this.internals.states.has('initialized') &&\n      !this.labels.some((tabLabel) => tabLabel.active)\n    ) {\n      this._initSelection();\n    }\n  }\n\n  private _initSelection(): void {\n    const selectedTabLabel = this.labels[this.initialSelectedIndex];\n    if (selectedTabLabel) {\n      customElements.upgrade(selectedTabLabel);\n      if (\n        this.initialSelectedIndex >= 0 &&\n        this.initialSelectedIndex < this.labels.length &&\n        !selectedTabLabel.disabled\n      ) {\n        selectedTabLabel.activate();\n        return;\n      }\n    }\n    this._enabledTabs()[0]?.activate();\n  }\n\n  private _onTabGroupElementResize(): void {\n    const tabLabels = this.labels;\n    tabLabels.forEach((tabLabel) => {\n      ɵstateController(tabLabel)?.toggle(\n        'has-divider',\n        tabLabel === tabLabels[0] || tabLabel.offsetLeft === tabLabels[0].offsetLeft,\n      );\n    });\n\n    this.style.setProperty('--sbb-tab-group-width', `${this._tabGroupElement.clientWidth}px`);\n  }\n\n  private _handleKeyDown(evt: KeyboardEvent): void {\n    const enabledTabs: SbbTabLabelElement[] = this._enabledTabs();\n\n    if (\n      !enabledTabs ||\n      // don't trap nested handling\n      ((evt.target as HTMLElement) !== this && (evt.target as HTMLElement).parentElement !== this)\n    ) {\n      return;\n    }\n\n    if (isArrowKeyPressed(evt)) {\n      const current: number = enabledTabs.findIndex((t) => t.active);\n      const nextIndex: number = getNextElementIndex(evt, current, enabledTabs.length);\n      enabledTabs[nextIndex]?.activate();\n      enabledTabs[nextIndex]?.focus();\n      evt.preventDefault();\n    }\n  }\n\n  /**\n   * @internal\n   */\n  protected setTabContentHeight(contentHeight: number): void {\n    this.style.setProperty('--sbb-tab-content-height', `${contentHeight}px`);\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div\n        class=\"sbb-tab-group\"\n        role=\"tablist\"\n        ${ref((el?: Element) => (this._tabGroupElement = el as HTMLElement))}\n      >\n        <slot name=\"tab-bar\" @slotchange=${this._onLabelSlotChange}></slot>\n      </div>\n      ${!this.fixedHeight\n        ? html`\n            <div class=\"sbb-tab-group-content\">\n              <slot @slotchange=${throttle(this._onContentSlotChange, 150)}></slot>\n            </div>\n          `\n        : html`<slot @slotchange=${throttle(this._onContentSlotChange, 150)}></slot>`}\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-tab-group': SbbTabGroupElement;\n  }\n}\n"],"mappings":"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"}