@sbb-esta/lyne-elements 3.8.0 → 3.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/core/base-elements/open-close-base-element.d.ts +2 -0
- package/core/base-elements/open-close-base-element.d.ts.map +1 -1
- package/core/base-elements/open-close-base-element.js +4 -0
- package/core/controllers/escapable-overlay-controller.js +3 -3
- package/core/controllers/inert-controller.d.ts +8 -1
- package/core/controllers/inert-controller.d.ts.map +1 -1
- package/core/controllers/inert-controller.js +25 -13
- package/core/overlay/position.d.ts +20 -0
- package/core/overlay/position.d.ts.map +1 -1
- package/core/overlay/position.js +34 -23
- package/core/overlay.js +11 -10
- package/core/styles/core.scss +7 -0
- package/core.css +6 -0
- package/custom-elements.json +612 -138
- package/development/core/base-elements/open-close-base-element.d.ts +2 -0
- package/development/core/base-elements/open-close-base-element.d.ts.map +1 -1
- package/development/core/base-elements/open-close-base-element.js +5 -1
- package/development/core/controllers/escapable-overlay-controller.js +2 -2
- package/development/core/controllers/inert-controller.d.ts +8 -1
- package/development/core/controllers/inert-controller.d.ts.map +1 -1
- package/development/core/controllers/inert-controller.js +49 -30
- package/development/core/overlay/position.d.ts +20 -0
- package/development/core/overlay/position.d.ts.map +1 -1
- package/development/core/overlay/position.js +41 -1
- package/development/core/overlay.js +2 -1
- package/development/menu/common/menu-action-common.d.ts.map +1 -1
- package/development/menu/common/menu-action-common.js +20 -3
- package/development/menu/menu/menu.component.d.ts +21 -10
- package/development/menu/menu/menu.component.d.ts.map +1 -1
- package/development/menu/menu/menu.component.js +203 -61
- package/development/option/option/option.component.js +4 -2
- package/development/tabs/tab/tab.component.d.ts +10 -4
- package/development/tabs/tab/tab.component.d.ts.map +1 -1
- package/development/tabs/tab/tab.component.js +15 -16
- package/development/tabs/tab-group/tab-group.component.d.ts +15 -14
- package/development/tabs/tab-group/tab-group.component.d.ts.map +1 -1
- package/development/tabs/tab-group/tab-group.component.js +46 -175
- package/development/tabs/tab-label/tab-label.component.d.ts +21 -2
- package/development/tabs/tab-label/tab-label.component.d.ts.map +1 -1
- package/development/tabs/tab-label/tab-label.component.js +91 -6
- package/development/tooltip/tooltip.component.d.ts +6 -6
- package/development/tooltip/tooltip.component.d.ts.map +1 -1
- package/development/tooltip/tooltip.component.js +14 -7
- package/menu/common/menu-action-common.d.ts.map +1 -1
- package/menu/common/menu-action-common.js +15 -12
- package/menu/menu/menu.component.d.ts +21 -10
- package/menu/menu/menu.component.d.ts.map +1 -1
- package/menu/menu/menu.component.js +144 -80
- package/off-brand-theme.css +6 -0
- package/option/option/option.component.js +1 -1
- package/package.json +1 -1
- package/safety-theme.css +6 -0
- package/standard-theme.css +6 -0
- package/tabs/tab/tab.component.d.ts +10 -4
- package/tabs/tab/tab.component.d.ts.map +1 -1
- package/tabs/tab/tab.component.js +22 -24
- package/tabs/tab-group/tab-group.component.d.ts +15 -14
- package/tabs/tab-group/tab-group.component.d.ts.map +1 -1
- package/tabs/tab-group/tab-group.component.js +68 -122
- package/tabs/tab-label/tab-label.component.d.ts +21 -2
- package/tabs/tab-label/tab-label.component.d.ts.map +1 -1
- package/tabs/tab-label/tab-label.component.js +88 -46
- package/tooltip/tooltip.component.d.ts +6 -6
- package/tooltip/tooltip.component.d.ts.map +1 -1
- package/tooltip/tooltip.component.js +59 -54
|
@@ -238,11 +238,16 @@ let SbbTabLabelElement = (() => {
|
|
|
238
238
|
let _amount_extraInitializers = [];
|
|
239
239
|
_a = class extends _classSuper {
|
|
240
240
|
constructor() {
|
|
241
|
-
super(
|
|
242
|
-
__privateAdd(this, _level_accessor_storage
|
|
243
|
-
__privateAdd(this, _active_accessor_storage
|
|
244
|
-
__privateAdd(this, _amount_accessor_storage
|
|
241
|
+
super();
|
|
242
|
+
__privateAdd(this, _level_accessor_storage);
|
|
243
|
+
__privateAdd(this, _active_accessor_storage);
|
|
244
|
+
__privateAdd(this, _amount_accessor_storage);
|
|
245
|
+
this._selected = false;
|
|
246
|
+
__privateSet(this, _level_accessor_storage, __runInitializers(this, _level_initializers, "1"));
|
|
247
|
+
__privateSet(this, _active_accessor_storage, (__runInitializers(this, _level_extraInitializers), __runInitializers(this, _active_initializers, false)));
|
|
248
|
+
__privateSet(this, _amount_accessor_storage, (__runInitializers(this, _active_extraInitializers), __runInitializers(this, _amount_initializers, "")));
|
|
245
249
|
__runInitializers(this, _amount_extraInitializers);
|
|
250
|
+
this.addEventListener("click", () => this.activate());
|
|
246
251
|
}
|
|
247
252
|
/**
|
|
248
253
|
* The level will correspond to the heading tag generated in the title.
|
|
@@ -254,7 +259,7 @@ let SbbTabLabelElement = (() => {
|
|
|
254
259
|
set level(value) {
|
|
255
260
|
__privateSet(this, _level_accessor_storage, value);
|
|
256
261
|
}
|
|
257
|
-
/** Active tab state */
|
|
262
|
+
/** Active tab state. */
|
|
258
263
|
get active() {
|
|
259
264
|
return __privateGet(this, _active_accessor_storage);
|
|
260
265
|
}
|
|
@@ -268,6 +273,86 @@ let SbbTabLabelElement = (() => {
|
|
|
268
273
|
set amount(value) {
|
|
269
274
|
__privateSet(this, _amount_accessor_storage, value);
|
|
270
275
|
}
|
|
276
|
+
/** Get the `sbb-tab` related to the `sbb-tab-label`. */
|
|
277
|
+
get tab() {
|
|
278
|
+
return this.nextElementSibling?.localName === "sbb-tab" ? this.nextElementSibling : null;
|
|
279
|
+
}
|
|
280
|
+
/** Get the parent `sbb-tab-group`. */
|
|
281
|
+
get group() {
|
|
282
|
+
return this.closest("sbb-tab-group");
|
|
283
|
+
}
|
|
284
|
+
connectedCallback() {
|
|
285
|
+
super.connectedCallback();
|
|
286
|
+
this.slot = "tab-bar";
|
|
287
|
+
this.tabIndex = this.active ? 0 : -1;
|
|
288
|
+
}
|
|
289
|
+
willUpdate(changedProperties) {
|
|
290
|
+
super.willUpdate(changedProperties);
|
|
291
|
+
if (changedProperties.has("active")) {
|
|
292
|
+
this.internals.ariaSelected = `${this.active}`;
|
|
293
|
+
this.tab?.toggleAttribute("data-active", this.active);
|
|
294
|
+
if (this.active && !this.disabled) {
|
|
295
|
+
this.activate();
|
|
296
|
+
} else {
|
|
297
|
+
this.deactivate();
|
|
298
|
+
}
|
|
299
|
+
}
|
|
300
|
+
if (changedProperties.has("disabled") && this.disabled) {
|
|
301
|
+
this.tabIndex = -1;
|
|
302
|
+
if (this.active) {
|
|
303
|
+
this.deactivate();
|
|
304
|
+
this.group?.activateTab(0);
|
|
305
|
+
}
|
|
306
|
+
}
|
|
307
|
+
}
|
|
308
|
+
/** Deactivate the tab. */
|
|
309
|
+
deactivate() {
|
|
310
|
+
this.active = false;
|
|
311
|
+
this._selected = false;
|
|
312
|
+
this.tabIndex = -1;
|
|
313
|
+
}
|
|
314
|
+
/** Select the tab, deactivating the current selected one, and dispatch the tabchange event. */
|
|
315
|
+
activate() {
|
|
316
|
+
if (this.disabled) {
|
|
317
|
+
{
|
|
318
|
+
console.warn("You cannot activate a disabled tab");
|
|
319
|
+
}
|
|
320
|
+
return;
|
|
321
|
+
}
|
|
322
|
+
const tabLabels = this.group?.labels || [];
|
|
323
|
+
const prevActiveTabLabel = tabLabels.find((e) => e._selected);
|
|
324
|
+
if (prevActiveTabLabel !== this) {
|
|
325
|
+
prevActiveTabLabel?.deactivate();
|
|
326
|
+
this.active = true;
|
|
327
|
+
this._selected = true;
|
|
328
|
+
this.tabIndex = 0;
|
|
329
|
+
this.tab?.dispatchEvent(new Event("active", { bubbles: true, composed: true }));
|
|
330
|
+
this.group?.dispatchEvent(new CustomEvent("tabchange", {
|
|
331
|
+
bubbles: true,
|
|
332
|
+
composed: true,
|
|
333
|
+
detail: {
|
|
334
|
+
activeIndex: tabLabels.findIndex((e) => e === this),
|
|
335
|
+
activeTabLabel: this,
|
|
336
|
+
activeTab: this.tab,
|
|
337
|
+
previousIndex: tabLabels.findIndex((e) => e === prevActiveTabLabel),
|
|
338
|
+
previousTabLabel: prevActiveTabLabel,
|
|
339
|
+
previousTab: prevActiveTabLabel?.tab
|
|
340
|
+
}
|
|
341
|
+
}));
|
|
342
|
+
}
|
|
343
|
+
}
|
|
344
|
+
/**
|
|
345
|
+
* @internal
|
|
346
|
+
*/
|
|
347
|
+
linkToTab() {
|
|
348
|
+
if (!this.tab) {
|
|
349
|
+
{
|
|
350
|
+
console.warn(`Missing content: you should provide a related content for the tab ${this.outerHTML}.`);
|
|
351
|
+
}
|
|
352
|
+
return;
|
|
353
|
+
}
|
|
354
|
+
this.internals.ariaControlsElements = [this.tab];
|
|
355
|
+
}
|
|
271
356
|
render() {
|
|
272
357
|
const TAGNAME = `h${Number(this.level) < 7 ? this.level : "1"}`;
|
|
273
358
|
return html`
|
|
@@ -309,4 +394,4 @@ let SbbTabLabelElement = (() => {
|
|
|
309
394
|
export {
|
|
310
395
|
SbbTabLabelElement
|
|
311
396
|
};
|
|
312
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLWxhYmVsLmNvbXBvbmVudC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzL3RhYnMvdGFiLWxhYmVsL3RhYi1sYWJlbC5jb21wb25lbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBDU1NSZXN1bHRHcm91cCwgVGVtcGxhdGVSZXN1bHQgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgTGl0RWxlbWVudCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50LCBwcm9wZXJ0eSB9IGZyb20gJ2xpdC9kZWNvcmF0b3JzLmpzJztcbmltcG9ydCB7IGh0bWwsIHVuc2FmZVN0YXRpYyB9IGZyb20gJ2xpdC9zdGF0aWMtaHRtbC5qcyc7XG5cbmltcG9ydCB7IGZvcmNlVHlwZSwgb21pdEVtcHR5Q29udmVydGVyLCBzbG90U3RhdGUgfSBmcm9tICcuLi8uLi9jb3JlL2RlY29yYXRvcnMuanMnO1xuaW1wb3J0IHsgU2JiRGlzYWJsZWRNaXhpbiwgU2JiRWxlbWVudEludGVybmFsc01peGluIH0gZnJvbSAnLi4vLi4vY29yZS9taXhpbnMuanMnO1xuaW1wb3J0IHsgU2JiSWNvbk5hbWVNaXhpbiB9IGZyb20gJy4uLy4uL2ljb24uanMnO1xuaW1wb3J0IHR5cGUgeyBTYmJUaXRsZUxldmVsIH0gZnJvbSAnLi4vLi4vdGl0bGUuanMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi90YWItbGFiZWwuc2Nzcz9saXQmaW5saW5lJztcblxuLyoqXG4gKiBDb21iaW5lZCB3aXRoIGEgYHNiYi10YWItZ3JvdXBgLCBpdCBkaXNwbGF5cyBhIHRhYidzIHRpdGxlLlxuICpcbiAqIEBzbG90IC0gVXNlIHRoZSB1bm5hbWVkIHNsb3QgdG8gYWRkIGNvbnRlbnQgdG8gdGhlIHRhYiB0aXRsZS5cbiAqIEBzbG90IGljb24gLSBVc2UgdGhpcyBzbG90IHRvIGRpc3BsYXkgYW4gaWNvbiB0byB0aGUgbGVmdCBvZiB0aGUgdGl0bGUsIGJ5IHByb3ZpZGluZyB0aGUgYHNiYi1pY29uYCBjb21wb25lbnQuXG4gKiBAc2xvdCBhbW91bnQgLSBQcm92aWRlIGEgbnVtYmVyIHRvIHNob3cgYW4gYW1vdW50IHRvIHRoZSByaWdodCBvZiB0aGUgdGl0bGUuXG4gKi9cbmV4cG9ydFxuQGN1c3RvbUVsZW1lbnQoJ3NiYi10YWItbGFiZWwnKVxuQHNsb3RTdGF0ZSgpXG5jbGFzcyBTYmJUYWJMYWJlbEVsZW1lbnQgZXh0ZW5kcyBTYmJEaXNhYmxlZE1peGluKFxuICBTYmJJY29uTmFtZU1peGluKFNiYkVsZW1lbnRJbnRlcm5hbHNNaXhpbihMaXRFbGVtZW50KSksXG4pIHtcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSByb2xlID0gJ3RhYic7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IHN0eWxlO1xuXG4gIC8qKlxuICAgKiBUaGUgbGV2ZWwgd2lsbCBjb3JyZXNwb25kIHRvIHRoZSBoZWFkaW5nIHRhZyBnZW5lcmF0ZWQgaW4gdGhlIHRpdGxlLlxuICAgKiBVc2UgdGhpcyBwcm9wZXJ0eSB0byBnZW5lcmF0ZSB0aGUgYXBwcm9wcmlhdGUgaGVhZGVyIHRhZywgdGFraW5nIFNFTyBpbnRvIGNvbnNpZGVyYXRpb24uXG4gICAqL1xuICBAcHJvcGVydHkoKSBwdWJsaWMgYWNjZXNzb3IgbGV2ZWw6IFNiYlRpdGxlTGV2ZWwgPSAnMSc7XG5cbiAgLyoqIEFjdGl2ZSB0YWIgc3RhdGUgKi9cbiAgQGZvcmNlVHlwZSgpXG4gIEBwcm9wZXJ0eSh7IHJlZmxlY3Q6IHRydWUsIHR5cGU6IEJvb2xlYW4gfSlcbiAgcHVibGljIGFjY2Vzc29yIGFjdGl2ZTogYm9vbGVhbiA9IGZhbHNlO1xuXG4gIC8qKiBBbW91bnQgZGlzcGxheWVkIGluc2lkZSB0aGUgdGFiLiAqL1xuICBAZm9yY2VUeXBlKClcbiAgQHByb3BlcnR5KHsgcmVmbGVjdDogdHJ1ZSwgY29udmVydGVyOiBvbWl0RW1wdHlDb252ZXJ0ZXIgfSlcbiAgcHVibGljIGFjY2Vzc29yIGFtb3VudDogc3RyaW5nID0gJyc7XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlcigpOiBUZW1wbGF0ZVJlc3VsdCB7XG4gICAgY29uc3QgVEFHTkFNRSA9IGBoJHtOdW1iZXIodGhpcy5sZXZlbCkgPCA3ID8gdGhpcy5sZXZlbCA6ICcxJ31gO1xuXG4gICAgLyogZXNsaW50LWRpc2FibGUgbGl0L2JpbmRpbmctcG9zaXRpb25zICovXG4gICAgcmV0dXJuIGh0bWxgXG4gICAgICA8ZGl2IGNsYXNzPVwic2JiLXRhYi1sYWJlbF9fd3JhcHBlclwiPlxuICAgICAgICA8JHt1bnNhZmVTdGF0aWMoVEFHTkFNRSl9IGNsYXNzPVwic2JiLXRhYi1sYWJlbFwiPlxuICAgICAgICAgIDxzcGFuIGNsYXNzPVwic2JiLXRhYi1sYWJlbF9faWNvblwiPlxuICAgICAgICAgICAgJHt0aGlzLnJlbmRlckljb25TbG90KCl9XG4gICAgICAgICAgPC9zcGFuPlxuICAgICAgICAgIDxzcGFuIGNsYXNzPVwic2JiLXRhYi1sYWJlbF9fdGV4dFwiPlxuICAgICAgICAgICAgPHNsb3Q+PC9zbG90PlxuICAgICAgICAgIDwvc3Bhbj5cbiAgICAgICAgICA8c3BhbiBjbGFzcz1cInNiYi10YWItbGFiZWxfX2Ftb3VudFwiPlxuICAgICAgICAgICAgPHNsb3QgbmFtZT1cImFtb3VudFwiPiR7dGhpcy5hbW91bnR9PC9zbG90PlxuICAgICAgICAgIDwvc3Bhbj5cbiAgICAgICAgPC8ke3Vuc2FmZVN0YXRpYyhUQUdOQU1FKX0+XG4gICAgICA8L2Rpdj5cbiAgICBgO1xuICB9XG59XG5cbmRlY2xhcmUgZ2xvYmFsIHtcbiAgaW50ZXJmYWNlIEhUTUxFbGVtZW50VGFnTmFtZU1hcCB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvblxuICAgICdzYmItdGFiLWxhYmVsJzogU2JiVGFiTGFiZWxFbGVtZW50O1xu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
|
|
397
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"tab-label.component.js","sources":["../../../../../src/elements/tabs/tab-label/tab-label.component.ts"],"sourcesContent":["import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { LitElement } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { html, unsafeStatic } from 'lit/static-html.js';\n\nimport { forceType, omitEmptyConverter, slotState } from '../../core/decorators.js';\nimport { SbbDisabledMixin, SbbElementInternalsMixin } from '../../core/mixins.js';\nimport { SbbIconNameMixin } from '../../icon.js';\nimport type { SbbTitleLevel } from '../../title.js';\nimport type { SbbTabElement } from '../tab/tab.component.js';\nimport type { SbbTabChangedEventDetails, SbbTabGroupElement } from '../tab-group.js';\n\nimport style from './tab-label.scss?lit&inline';\n\n/**\n * Combined with a `sbb-tab-group`, it displays a tab's title.\n *\n * @slot - Use the unnamed slot to add content to the tab title.\n * @slot icon - Use this slot to display an icon to the left of the title, by providing the `sbb-icon` component.\n * @slot amount - Provide a number to show an amount to the right of the title.\n */\nexport\n@customElement('sbb-tab-label')\n@slotState()\nclass SbbTabLabelElement extends SbbDisabledMixin(\n  SbbIconNameMixin(SbbElementInternalsMixin(LitElement)),\n) {\n  public static override role = 'tab';\n  public static override styles: CSSResultGroup = style;\n\n  /** Whether the tab is selected. */\n  private _selected: boolean = false;\n\n  /**\n   * The level will correspond to the heading tag generated in the title.\n   * Use this property to generate the appropriate header tag, taking SEO into consideration.\n   */\n  @property() public accessor level: SbbTitleLevel = '1';\n\n  /** Active tab state. */\n  @forceType()\n  @property({ reflect: true, type: Boolean })\n  public accessor active: boolean = false;\n\n  /** Amount displayed inside the tab. */\n  @forceType()\n  @property({ reflect: true, converter: omitEmptyConverter })\n  public accessor amount: string = '';\n\n  /** Get the `sbb-tab` related to the `sbb-tab-label`. */\n  public get tab(): SbbTabElement | null {\n    return this.nextElementSibling?.localName === 'sbb-tab'\n      ? (this.nextElementSibling as SbbTabElement)\n      : null;\n  }\n\n  /** Get the parent `sbb-tab-group`. */\n  public get group(): SbbTabGroupElement | null {\n    return this.closest('sbb-tab-group');\n  }\n\n  public constructor() {\n    super();\n\n    this.addEventListener('click', () => this.activate());\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.slot = 'tab-bar';\n    this.tabIndex = this.active ? 0 : -1;\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('active')) {\n      this.internals.ariaSelected = `${this.active}`;\n      this.tab?.toggleAttribute('data-active', this.active);\n\n      if (this.active && !this.disabled) {\n        this.activate();\n      } else {\n        this.deactivate();\n      }\n    }\n\n    if (changedProperties.has('disabled') && this.disabled) {\n      this.tabIndex = -1;\n      if (this.active) {\n        this.deactivate();\n        this.group?.activateTab(0);\n      }\n    }\n  }\n\n  /** Deactivate the tab. */\n  public deactivate(): void {\n    this.active = false;\n    this._selected = false;\n    this.tabIndex = -1;\n  }\n\n  /** Select the tab, deactivating the current selected one, and dispatch the tabchange event. */\n  public activate(): void {\n    if (this.disabled) {\n      if (import.meta.env.DEV) {\n        console.warn('You cannot activate a disabled tab');\n      }\n      return;\n    }\n\n    const tabLabels: SbbTabLabelElement[] = this.group?.labels || [];\n    const prevActiveTabLabel = tabLabels.find((e) => e._selected);\n    if (prevActiveTabLabel !== this) {\n      prevActiveTabLabel?.deactivate();\n      this.active = true;\n      this._selected = true;\n      this.tabIndex = 0;\n      this.tab?.dispatchEvent(new Event('active', { bubbles: true, composed: true }));\n      this.group?.dispatchEvent(\n        new CustomEvent<SbbTabChangedEventDetails>('tabchange', {\n          bubbles: true,\n          composed: true,\n          detail: {\n            activeIndex: tabLabels.findIndex((e) => e === this),\n            activeTabLabel: this,\n            activeTab: this.tab as SbbTabElement,\n            previousIndex: tabLabels.findIndex((e) => e === prevActiveTabLabel),\n            previousTabLabel: prevActiveTabLabel,\n            previousTab: prevActiveTabLabel?.tab as SbbTabElement,\n          },\n        }),\n      );\n    }\n  }\n\n  /**\n   * @internal\n   */\n  protected linkToTab(): void {\n    if (!this.tab) {\n      if (import.meta.env.DEV) {\n        console.warn(\n          `Missing content: you should provide a related content for the tab ${this.outerHTML}.`,\n        );\n      }\n      return;\n    }\n    this.internals.ariaControlsElements = [this.tab];\n  }\n\n  protected override render(): TemplateResult {\n    const TAGNAME = `h${Number(this.level) < 7 ? this.level : '1'}`;\n\n    /* eslint-disable lit/binding-positions */\n    return html`\n      <div class=\"sbb-tab-label__wrapper\">\n        <${unsafeStatic(TAGNAME)} class=\"sbb-tab-label\">\n          <span class=\"sbb-tab-label__icon\">\n            ${this.renderIconSlot()}\n          </span>\n          <span class=\"sbb-tab-label__text\">\n            <slot></slot>\n          </span>\n          <span class=\"sbb-tab-label__amount\">\n            <slot name=\"amount\">${this.amount}</slot>\n          </span>\n        </${unsafeStatic(TAGNAME)}>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-tab-label': SbbTabLabelElement;\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -23,20 +23,20 @@ export declare class SbbTooltipElement extends SbbTooltipElement_base {
|
|
|
23
23
|
* Open the tooltip after a given delay in milliseconds.
|
|
24
24
|
* Global configuration is used as default, if not set.
|
|
25
25
|
*
|
|
26
|
-
* @default
|
|
26
|
+
* @default null
|
|
27
27
|
*/
|
|
28
|
-
set openDelay(value: number);
|
|
28
|
+
set openDelay(value: number | null);
|
|
29
29
|
get openDelay(): number;
|
|
30
|
-
private _openDelay
|
|
30
|
+
private _openDelay;
|
|
31
31
|
/**
|
|
32
32
|
* Close the tooltip after a given delay in milliseconds.
|
|
33
33
|
* Global configuration is used as default, if not set.
|
|
34
34
|
*
|
|
35
|
-
* @default
|
|
35
|
+
* @default null
|
|
36
36
|
*/
|
|
37
|
-
set closeDelay(value: number);
|
|
37
|
+
set closeDelay(value: number | null);
|
|
38
38
|
get closeDelay(): number;
|
|
39
|
-
private _closeDelay
|
|
39
|
+
private _closeDelay;
|
|
40
40
|
/**
|
|
41
41
|
* Automatically close the tooltip after it has been open by long press.
|
|
42
42
|
* Global configuration is used as default, if not set.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"tooltip.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/tooltip/tooltip.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,KAAK,cAAc,EACnB,KAAK,cAAc,EACnB,KAAK,mBAAmB,EACxB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAIb,OAAO,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;;AA6BnE;;;;;;;GAOG;AACH,qBAEM,iBAAkB,SAAQ,sBAAyC;IACvE,gBAAgC,IAAI,aAAa;IACjD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,OAAO,CAAC,MAAM,CAAC,cAAc,CAAU;IAUvC;;;;OAIG;IACH,SAEgB,OAAO,EAAE,WAAW,GAAG,IAAI,CAAQ;IAEnD;;;;;OAKG;IACH,IACW,SAAS,CAAC,KAAK,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"tooltip.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/tooltip/tooltip.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,KAAK,cAAc,EACnB,KAAK,cAAc,EACnB,KAAK,mBAAmB,EACxB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAIb,OAAO,EAAE,uBAAuB,EAAE,MAAM,0BAA0B,CAAC;;AA6BnE;;;;;;;GAOG;AACH,qBAEM,iBAAkB,SAAQ,sBAAyC;IACvE,gBAAgC,IAAI,aAAa;IACjD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,OAAO,CAAC,MAAM,CAAC,cAAc,CAAU;IAUvC;;;;OAIG;IACH,SAEgB,OAAO,EAAE,WAAW,GAAG,IAAI,CAAQ;IAEnD;;;;;OAKG;IACH,IACW,SAAS,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,EAExC;IACD,IAAW,SAAS,IAAI,MAAM,CAE7B;IACD,OAAO,CAAC,UAAU,CAAuB;IAEzC;;;;;OAKG;IACH,IACW,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,EAEzC;IACD,IAAW,UAAU,IAAI,MAAM,CAE9B;IACD,OAAO,CAAC,WAAW,CAAuB;IAE1C;;;;;OAKG;IACH,IACW,mBAAmB,CAAC,KAAK,EAAE,MAAM,EAE3C;IACD,IAAW,mBAAmB,IAAI,MAAM,CAEvC;IACD,OAAO,CAAC,oBAAoB,CAAC,CAAS;IAEtC,SAAS,CAAC,OAAO,CAAC,EAAE,cAAc,CAAC;IAEnC,OAAO,CAAC,eAAe,CAA4B;IACnD,OAAO,CAAC,uBAAuB,CAAC,CAAkB;IAClD,OAAO,CAAC,oBAAoB,CAAmB;IAC/C,OAAO,CAAC,2BAA2B,CAA2C;IAC9E,OAAO,CAAC,YAAY,CAAC,CAAgC;IACrD,OAAO,CAAC,aAAa,CAAC,CAAgC;IACtD,OAAO,CAAC,qBAAqB,CAAC,CAAgC;IAC9D,OAAO,CAAC,sBAAsB,CAAC,CAAgC;;IAwB/D,OAAO,CAAC,MAAM,CAAC,wBAAwB;IAmCvC,OAAO,CAAC,MAAM,CAAC,6BAA6B;IAM5C,OAAO,CAAC,MAAM,CAAC,qBAAqB;IA2BpB,iBAAiB,IAAI,IAAI;IAYzB,oBAAoB,IAAI,IAAI;IAM5B,aAAa,CAC3B,IAAI,CAAC,EAAE,WAAW,EAClB,QAAQ,CAAC,EAAE,OAAO,EAClB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,IAAI;cAWY,YAAY,CAAC,iBAAiB,EAAE,cAAc,GAAG,IAAI;IAKjE,IAAI,IAAI,IAAI;IAsBZ,KAAK,IAAI,IAAI;IAgBpB,OAAO,CAAC,YAAY;IAKpB,OAAO,CAAC,cAAc;IAOtB,OAAO,CAAC,aAAa;IAKrB,OAAO,CAAC,cAAc;IAStB,OAAO,CAAC,sBAAsB;IAQ9B,OAAO,CAAC,OAAO;IAcf,OAAO,CAAC,OAAO;IAgBf,OAAO,CAAC,QAAQ;IAKhB,OAAO,CAAC,mBAAmB;IAiB3B,OAAO,CAAC,wBAAwB;IA0DhC,OAAO,CAAC,mBAAmB;IAe3B,OAAO,CAAC,wBAAwB;IAIhC,OAAO,CAAC,sBAAsB;cAKX,MAAM,IAAI,cAAc;CAW5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,aAAa,EAAE,iBAAiB,CAAC;KAClC;CACF"}
|
|
@@ -147,7 +147,8 @@ let SbbTooltipElement = (() => {
|
|
|
147
147
|
super();
|
|
148
148
|
__privateAdd(this, _trigger_accessor_storage);
|
|
149
149
|
__privateSet(this, _trigger_accessor_storage, (__runInitializers(this, _instanceExtraInitializers), __runInitializers(this, _trigger_initializers, null)));
|
|
150
|
-
this._openDelay = __runInitializers(this, _trigger_extraInitializers);
|
|
150
|
+
this._openDelay = (__runInitializers(this, _trigger_extraInitializers), null);
|
|
151
|
+
this._closeDelay = null;
|
|
151
152
|
this._triggerElement = null;
|
|
152
153
|
this._escapableOverlayController = new SbbEscapableOverlayController(this);
|
|
153
154
|
this.addEventListener("mouseleave", (event) => {
|
|
@@ -172,10 +173,10 @@ let SbbTooltipElement = (() => {
|
|
|
172
173
|
* Open the tooltip after a given delay in milliseconds.
|
|
173
174
|
* Global configuration is used as default, if not set.
|
|
174
175
|
*
|
|
175
|
-
* @default
|
|
176
|
+
* @default null
|
|
176
177
|
*/
|
|
177
178
|
set openDelay(value) {
|
|
178
|
-
this._openDelay =
|
|
179
|
+
this._openDelay = value;
|
|
179
180
|
}
|
|
180
181
|
get openDelay() {
|
|
181
182
|
return this._openDelay ?? readConfig().tooltip?.openDelay ?? 0;
|
|
@@ -184,10 +185,10 @@ let SbbTooltipElement = (() => {
|
|
|
184
185
|
* Close the tooltip after a given delay in milliseconds.
|
|
185
186
|
* Global configuration is used as default, if not set.
|
|
186
187
|
*
|
|
187
|
-
* @default
|
|
188
|
+
* @default null
|
|
188
189
|
*/
|
|
189
190
|
set closeDelay(value) {
|
|
190
|
-
this._closeDelay =
|
|
191
|
+
this._closeDelay = value;
|
|
191
192
|
}
|
|
192
193
|
get closeDelay() {
|
|
193
194
|
return this._closeDelay ?? readConfig().tooltip?.closeDelay ?? 0;
|
|
@@ -208,6 +209,10 @@ let SbbTooltipElement = (() => {
|
|
|
208
209
|
this._tooltipOutlet = document.createElement("div");
|
|
209
210
|
this._tooltipOutlet.classList.add("sbb-overlay-outlet");
|
|
210
211
|
document.body.appendChild(this._tooltipOutlet);
|
|
212
|
+
const attributeMap = /* @__PURE__ */ new Map([
|
|
213
|
+
["sbb-tooltip-open-delay", "open-delay"],
|
|
214
|
+
["sbb-tooltip-close-delay", "close-delay"]
|
|
215
|
+
]);
|
|
211
216
|
new MutationObserver((mutations) => {
|
|
212
217
|
for (const mutation of mutations) {
|
|
213
218
|
if (mutation.type === "attributes") {
|
|
@@ -220,7 +225,7 @@ let SbbTooltipElement = (() => {
|
|
|
220
225
|
}
|
|
221
226
|
}
|
|
222
227
|
}).observe(document.documentElement, {
|
|
223
|
-
attributeFilter: ["sbb-tooltip"],
|
|
228
|
+
attributeFilter: ["sbb-tooltip", ...attributeMap.keys()],
|
|
224
229
|
childList: true,
|
|
225
230
|
subtree: true
|
|
226
231
|
});
|
|
@@ -240,6 +245,8 @@ let SbbTooltipElement = (() => {
|
|
|
240
245
|
tooltip.trigger = triggerElement;
|
|
241
246
|
}
|
|
242
247
|
tooltip.textContent = tooltipMessage;
|
|
248
|
+
tooltip.openDelay = triggerElement.hasAttribute("sbb-tooltip-open-delay") ? +triggerElement.getAttribute("sbb-tooltip-open-delay") : null;
|
|
249
|
+
tooltip.closeDelay = triggerElement.hasAttribute("sbb-tooltip-close-delay") ? +triggerElement.getAttribute("sbb-tooltip-close-delay") : null;
|
|
243
250
|
} else if (tooltip) {
|
|
244
251
|
tooltipTriggers.delete(triggerElement);
|
|
245
252
|
tooltip._destroy();
|
|
@@ -463,4 +470,4 @@ let SbbTooltipElement = (() => {
|
|
|
463
470
|
export {
|
|
464
471
|
SbbTooltipElement
|
|
465
472
|
};
|
|
466
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"tooltip.component.js","sources":["../../../../src/elements/tooltip/tooltip.component.ts"],"sourcesContent":["import {\n  html,\n  isServer,\n  type CSSResultGroup,\n  type TemplateResult,\n  type PropertyDeclaration,\n  type PropertyValues,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport { SbbOpenCloseBaseElement } from '../core/base-elements.js';\nimport { readConfig } from '../core/config.js';\nimport { SbbEscapableOverlayController } from '../core/controllers.js';\nimport { idReference } from '../core/decorators.js';\nimport {\n  addToListAttribute,\n  isAndroid,\n  isIOS,\n  isZeroAnimationDuration,\n  queueDomContentLoaded,\n  removeFromListAttribute,\n} from '../core/dom.js';\nimport { SbbDisabledMixin } from '../core/mixins.js';\nimport { getElementPosition, sbbOverlayOutsidePointerEventListener } from '../core/overlay.js';\n\nimport style from './tooltip.scss?lit&inline';\n\n/**\n * Time between the user putting the pointer on a tooltip\n * trigger and the long press event being fired.\n */\nconst LONGPRESS_DELAY = 500;\nconst VERTICAL_OFFSET = 8;\nconst HORIZONTAL_OFFSET = 16;\n\nconst isMobile = isAndroid || isIOS;\nconst tooltipTriggers = new WeakMap<HTMLElement, SbbTooltipElement>();\nlet nextId = 0;\n\n/**\n * It displays text content within a tooltip.\n *\n * @slot - Use the unnamed slot to add the text into the tooltip.\n * @cssprop [--sbb-tooltip-z-index=var(--sbb-overlay-default-z-index)] - To specify a custom stack order,\n * the `z-index` can be overridden by defining this CSS variable. The default `z-index` of the\n * component is set to `var(--sbb-overlay-default-z-index)` with a value of `1000`.\n */\nexport\n@customElement('sbb-tooltip')\nclass SbbTooltipElement extends SbbDisabledMixin(SbbOpenCloseBaseElement) {\n  public static override readonly role = 'tooltip';\n  public static override styles: CSSResultGroup = style;\n\n  private static _tooltipOutlet: Element;\n\n  static {\n    if (!isServer) {\n      // We don't want to block execution for initialization,\n      // so we defer it until the DOM content is loaded.\n      queueDomContentLoaded(() => this._initializeTooltipOutlet());\n    }\n  }\n\n  /**\n   * The element that will trigger the popover overlay.\n   *\n   * For attribute usage, provide an id reference.\n   */\n  @idReference()\n  @property()\n  public accessor trigger: HTMLElement | null = null;\n\n  /**\n   * Open the tooltip after a given delay in milliseconds.\n   * Global configuration is used as default, if not set.\n   *\n   * @default 0\n   */\n  @property({ attribute: 'open-delay', type: Number })\n  public set openDelay(value: number) {\n    this._openDelay = +value;\n  }\n  public get openDelay(): number {\n    return this._openDelay ?? readConfig().tooltip?.openDelay ?? 0;\n  }\n  private _openDelay?: number;\n\n  /**\n   * Close the tooltip after a given delay in milliseconds.\n   * Global configuration is used as default, if not set.\n   *\n   * @default 0\n   */\n  @property({ attribute: 'close-delay', type: Number })\n  public set closeDelay(value: number) {\n    this._closeDelay = +value;\n  }\n  public get closeDelay(): number {\n    return this._closeDelay ?? readConfig().tooltip?.closeDelay ?? 0;\n  }\n  private _closeDelay?: number;\n\n  /**\n   * Automatically close the tooltip after it has been open by long press.\n   * Global configuration is used as default, if not set.\n   *\n   * @default 1500\n   */\n  @property({ attribute: 'long-press-close-delay', type: Number })\n  public set longPressCloseDelay(value: number) {\n    this._longPressCloseDelay = +value;\n  }\n  public get longPressCloseDelay(): number {\n    return this._longPressCloseDelay ?? readConfig().tooltip?.longPressCloseDelay ?? 1500;\n  }\n  private _longPressCloseDelay?: number;\n\n  protected overlay?: HTMLDivElement;\n\n  private _triggerElement: HTMLElement | null = null;\n  private _triggerAbortController?: AbortController;\n  private _openStateController!: AbortController;\n  private _escapableOverlayController = new SbbEscapableOverlayController(this);\n  private _openTimeout?: ReturnType<typeof setTimeout>;\n  private _closeTimeout?: ReturnType<typeof setTimeout>;\n  private _longPressOpenTimeout?: ReturnType<typeof setTimeout>;\n  private _longPressCloseTimeout?: ReturnType<typeof setTimeout>;\n\n  public constructor() {\n    super();\n\n    // Until the mouse hovers the tooltip, it stays open.\n    // On 'mouseleave' (if the mouse is not moved onto the trigger again), close it.\n    this.addEventListener(\n      'mouseleave',\n      (event) => {\n        if (\n          (this.state === 'opened' || this.state === 'opening') &&\n          (!event.relatedTarget || !this._triggerElement?.contains(event.relatedTarget as Node))\n        ) {\n          this._delayedClose();\n        }\n      },\n      { passive: true },\n    );\n\n    // Any user interaction outside the tooltip, closes it immediately\n    this.addEventListener('overlayOutsidePointer', () => this.close(), { passive: true });\n  }\n\n  private static _initializeTooltipOutlet(): void {\n    this._tooltipOutlet = document.createElement('div');\n    this._tooltipOutlet.classList.add('sbb-overlay-outlet');\n    document.body.appendChild(this._tooltipOutlet);\n\n    // We are using MutationObserver directly here, as it will only be called on client side\n    // and we do not need to disconnect it, as we want it to work during the full lifetime\n    // of the page.\n    new MutationObserver((mutations) => {\n      for (const mutation of mutations) {\n        if (mutation.type === 'attributes') {\n          this._handleTooltipTrigger(mutation.target as HTMLElement);\n        } else if (mutation.type === 'childList') {\n          for (const node of [...mutation.addedNodes, ...mutation.removedNodes].filter(\n            (n): n is HTMLElement => n.nodeType === n.ELEMENT_NODE,\n          )) {\n            this._handleTooltipTrigger(node);\n            this._findAndHandleTooltipTriggers(node);\n          }\n        }\n      }\n    }).observe(document.documentElement, {\n      attributeFilter: ['sbb-tooltip'],\n      childList: true,\n      subtree: true,\n    });\n    this._findAndHandleTooltipTriggers(document.body);\n  }\n\n  private static _findAndHandleTooltipTriggers(root: HTMLElement): void {\n    root\n      .querySelectorAll<HTMLElement>('[sbb-tooltip]')\n      .forEach((e) => this._handleTooltipTrigger(e));\n  }\n\n  private static _handleTooltipTrigger(triggerElement: HTMLElement): void {\n    const tooltipMessage = triggerElement.getAttribute('sbb-tooltip');\n    let tooltip = tooltipTriggers.get(triggerElement);\n\n    if (tooltipMessage && triggerElement.isConnected) {\n      if (!tooltip) {\n        // Create a new sbb-tooltip in the outlet and attach it to the trigger\n        tooltip = document.createElement('sbb-tooltip');\n        tooltipTriggers.set(triggerElement, tooltip);\n        this._tooltipOutlet.appendChild(tooltip);\n        tooltip.trigger = triggerElement;\n      }\n      tooltip.textContent = tooltipMessage;\n    } else if (tooltip) {\n      // The trigger or the attribute has been deleted => delete the connected tooltip\n      tooltipTriggers.delete(triggerElement);\n      tooltip._destroy();\n    }\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.popover = 'manual';\n    this.id ||= `sbb-tooltip-${++nextId}`;\n    this.state = 'closed';\n    sbbOverlayOutsidePointerEventListener.connect(this);\n\n    if (this.hasUpdated && this.trigger) {\n      this._attach(this.trigger);\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    sbbOverlayOutsidePointerEventListener.disconnect(this);\n    this._detach();\n  }\n\n  public override requestUpdate(\n    name?: PropertyKey,\n    oldValue?: unknown,\n    options?: PropertyDeclaration,\n  ): void {\n    super.requestUpdate(name, oldValue, options);\n    if (isServer) {\n      return;\n    }\n\n    if ((!name || name === 'trigger') && this.hasUpdated) {\n      this._attach(this.trigger);\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues): void {\n    super.firstUpdated(changedProperties);\n    this._attach(this.trigger);\n  }\n\n  public open(): void {\n    this._resetOpenCloseTimeout();\n    if (\n      (this.state !== 'closed' && this.state !== 'closing') ||\n      this.disabled ||\n      !this.overlay ||\n      !this.dispatchBeforeOpenEvent()\n    ) {\n      return;\n    }\n\n    this.showPopover?.();\n    this.state = 'opening';\n    this._setTooltipPosition();\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `opened` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleOpening();\n    }\n  }\n\n  public close(): void {\n    this._resetOpenCloseTimeout();\n    if (this.state !== 'opened' && this.state !== 'opening') {\n      return;\n    }\n\n    this.dispatchBeforeCloseEvent();\n    this.state = 'closing';\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `closed` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleClosing();\n    }\n  }\n\n  private _delayedOpen(): void {\n    this._resetOpenCloseTimeout();\n    this._openTimeout = setTimeout(() => this.open(), this.openDelay);\n  }\n\n  private _handleOpening(): void {\n    this.state = 'opened';\n    this._attachWindowEvents();\n    this._escapableOverlayController.connect();\n    this.dispatchOpenEvent();\n  }\n\n  private _delayedClose(): void {\n    this._resetOpenCloseTimeout();\n    this._closeTimeout = setTimeout(() => this.close(), this.closeDelay);\n  }\n\n  private _handleClosing(): void {\n    this.state = 'closed';\n    this.hidePopover?.();\n\n    this._escapableOverlayController.disconnect();\n    this.dispatchCloseEvent();\n    this._openStateController?.abort();\n  }\n\n  private _onTooltipAnimationEnd(event: AnimationEvent): void {\n    if (event.animationName === 'open' && this.state === 'opening') {\n      this._handleOpening();\n    } else if (event.animationName === 'close' && this.state === 'closing') {\n      this._handleClosing();\n    }\n  }\n\n  private _attach(trigger: HTMLElement | null): void {\n    if (this._triggerElement) {\n      // Eventually detach from the old trigger\n      this._detach();\n    }\n\n    this._triggerElement = trigger;\n    if (!this._triggerElement) {\n      return;\n    }\n    addToListAttribute(this._triggerElement, 'aria-describedby', this.id);\n    this._addTriggerEventHandlers();\n  }\n\n  private _detach(): void {\n    this._triggerAbortController?.abort();\n    this._openStateController?.abort();\n\n    // clear timeouts\n    this._resetOpenCloseTimeout();\n    clearTimeout(this._longPressOpenTimeout);\n    clearTimeout(this._longPressCloseTimeout);\n\n    if (!this._triggerElement) {\n      return;\n    }\n    removeFromListAttribute(this._triggerElement, 'aria-describedby', this.id);\n    this._triggerElement = null;\n  }\n\n  private _destroy(): void {\n    this._detach();\n    this.remove();\n  }\n\n  private _setTooltipPosition(): void {\n    if (!this.overlay || !this._triggerElement) {\n      return;\n    }\n\n    const position = getElementPosition(this.overlay, this._triggerElement, this, {\n      verticalOffset: VERTICAL_OFFSET,\n      horizontalOffset: HORIZONTAL_OFFSET,\n      centered: true,\n      responsiveHeight: true,\n    });\n    this.setAttribute('data-position', position.alignment.vertical);\n\n    this.style.setProperty('--sbb-tooltip-position-x', `${position.left}px`);\n    this.style.setProperty('--sbb-tooltip-position-y', `${position.top}px`);\n  }\n\n  private _addTriggerEventHandlers(): void {\n    const trigger = this._triggerElement;\n    if (!trigger) {\n      return;\n    }\n\n    this._triggerAbortController?.abort();\n    this._triggerAbortController = new AbortController();\n    const options: AddEventListenerOptions = {\n      signal: this._triggerAbortController.signal,\n      passive: true,\n    };\n\n    if (!isMobile) {\n      trigger.addEventListener('mouseenter', () => this._delayedOpen(), options);\n      trigger.addEventListener(\n        'mouseleave',\n        (event) => {\n          const newTarget = event.relatedTarget as Node | null;\n          if (!newTarget || newTarget !== this) {\n            this._delayedClose();\n          }\n        },\n        options,\n      );\n\n      // 'blurs' immediately close the tooltip because it is considered an 'interaction with other elements'\n      trigger.addEventListener('blur', () => this.close(), options);\n      trigger.addEventListener('focus', () => this._delayedOpen(), options);\n    }\n\n    // Long-press event handling (mainly for mobile users)\n    trigger.addEventListener(\n      'touchstart',\n      () => {\n        clearTimeout(this._longPressOpenTimeout);\n        clearTimeout(this._longPressCloseTimeout);\n        this._longPressOpenTimeout = setTimeout(() => this.open(), LONGPRESS_DELAY);\n      },\n      options,\n    );\n    trigger.addEventListener(\n      'touchend',\n      () => {\n        clearTimeout(this._longPressOpenTimeout);\n        this._longPressCloseTimeout = setTimeout(() => this.close(), this.longPressCloseDelay);\n      },\n      options,\n    );\n    trigger.addEventListener(\n      'touchcancel',\n      () => {\n        clearTimeout(this._longPressOpenTimeout);\n      },\n      options,\n    );\n  }\n\n  private _attachWindowEvents(): void {\n    this._openStateController = new AbortController();\n    document.addEventListener('scroll', () => this._setTooltipPosition(), {\n      passive: true,\n      signal: this._openStateController.signal,\n      // Without capture, other scroll contexts would not bubble to this event listener.\n      // Capture allows us to react to all scroll contexts in this DOM.\n      capture: true,\n    });\n    window.addEventListener('resize', () => this._setTooltipPosition(), {\n      passive: true,\n      signal: this._openStateController.signal,\n    });\n  }\n\n  private _isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-tooltip-animation-duration');\n  }\n\n  private _resetOpenCloseTimeout(): void {\n    clearTimeout(this._openTimeout);\n    clearTimeout(this._closeTimeout);\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div\n        @animationend=${this._onTooltipAnimationEnd}\n        class=\"sbb-tooltip\"\n        ${ref((el?: Element) => (this.overlay = el as HTMLDivElement))}\n      >\n        <slot></slot>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-tooltip': SbbTooltipElement;\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
473
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"tooltip.component.js","sources":["../../../../src/elements/tooltip/tooltip.component.ts"],"sourcesContent":["import {\n  html,\n  isServer,\n  type CSSResultGroup,\n  type TemplateResult,\n  type PropertyDeclaration,\n  type PropertyValues,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport { SbbOpenCloseBaseElement } from '../core/base-elements.js';\nimport { readConfig } from '../core/config.js';\nimport { SbbEscapableOverlayController } from '../core/controllers.js';\nimport { idReference } from '../core/decorators.js';\nimport {\n  addToListAttribute,\n  isAndroid,\n  isIOS,\n  isZeroAnimationDuration,\n  queueDomContentLoaded,\n  removeFromListAttribute,\n} from '../core/dom.js';\nimport { SbbDisabledMixin } from '../core/mixins.js';\nimport { getElementPosition, sbbOverlayOutsidePointerEventListener } from '../core/overlay.js';\n\nimport style from './tooltip.scss?lit&inline';\n\n/**\n * Time between the user putting the pointer on a tooltip\n * trigger and the long press event being fired.\n */\nconst LONGPRESS_DELAY = 500;\nconst VERTICAL_OFFSET = 8;\nconst HORIZONTAL_OFFSET = 16;\n\nconst isMobile = isAndroid || isIOS;\nconst tooltipTriggers = new WeakMap<HTMLElement, SbbTooltipElement>();\nlet nextId = 0;\n\n/**\n * It displays text content within a tooltip.\n *\n * @slot - Use the unnamed slot to add the text into the tooltip.\n * @cssprop [--sbb-tooltip-z-index=var(--sbb-overlay-default-z-index)] - To specify a custom stack order,\n * the `z-index` can be overridden by defining this CSS variable. The default `z-index` of the\n * component is set to `var(--sbb-overlay-default-z-index)` with a value of `1000`.\n */\nexport\n@customElement('sbb-tooltip')\nclass SbbTooltipElement extends SbbDisabledMixin(SbbOpenCloseBaseElement) {\n  public static override readonly role = 'tooltip';\n  public static override styles: CSSResultGroup = style;\n\n  private static _tooltipOutlet: Element;\n\n  static {\n    if (!isServer) {\n      // We don't want to block execution for initialization,\n      // so we defer it until the DOM content is loaded.\n      queueDomContentLoaded(() => this._initializeTooltipOutlet());\n    }\n  }\n\n  /**\n   * The element that will trigger the popover overlay.\n   *\n   * For attribute usage, provide an id reference.\n   */\n  @idReference()\n  @property()\n  public accessor trigger: HTMLElement | null = null;\n\n  /**\n   * Open the tooltip after a given delay in milliseconds.\n   * Global configuration is used as default, if not set.\n   *\n   * @default null\n   */\n  @property({ attribute: 'open-delay', type: Number })\n  public set openDelay(value: number | null) {\n    this._openDelay = value;\n  }\n  public get openDelay(): number {\n    return this._openDelay ?? readConfig().tooltip?.openDelay ?? 0;\n  }\n  private _openDelay: number | null = null;\n\n  /**\n   * Close the tooltip after a given delay in milliseconds.\n   * Global configuration is used as default, if not set.\n   *\n   * @default null\n   */\n  @property({ attribute: 'close-delay', type: Number })\n  public set closeDelay(value: number | null) {\n    this._closeDelay = value;\n  }\n  public get closeDelay(): number {\n    return this._closeDelay ?? readConfig().tooltip?.closeDelay ?? 0;\n  }\n  private _closeDelay: number | null = null;\n\n  /**\n   * Automatically close the tooltip after it has been open by long press.\n   * Global configuration is used as default, if not set.\n   *\n   * @default 1500\n   */\n  @property({ attribute: 'long-press-close-delay', type: Number })\n  public set longPressCloseDelay(value: number) {\n    this._longPressCloseDelay = +value;\n  }\n  public get longPressCloseDelay(): number {\n    return this._longPressCloseDelay ?? readConfig().tooltip?.longPressCloseDelay ?? 1500;\n  }\n  private _longPressCloseDelay?: number;\n\n  protected overlay?: HTMLDivElement;\n\n  private _triggerElement: HTMLElement | null = null;\n  private _triggerAbortController?: AbortController;\n  private _openStateController!: AbortController;\n  private _escapableOverlayController = new SbbEscapableOverlayController(this);\n  private _openTimeout?: ReturnType<typeof setTimeout>;\n  private _closeTimeout?: ReturnType<typeof setTimeout>;\n  private _longPressOpenTimeout?: ReturnType<typeof setTimeout>;\n  private _longPressCloseTimeout?: ReturnType<typeof setTimeout>;\n\n  public constructor() {\n    super();\n\n    // Until the mouse hovers the tooltip, it stays open.\n    // On 'mouseleave' (if the mouse is not moved onto the trigger again), close it.\n    this.addEventListener(\n      'mouseleave',\n      (event) => {\n        if (\n          (this.state === 'opened' || this.state === 'opening') &&\n          (!event.relatedTarget || !this._triggerElement?.contains(event.relatedTarget as Node))\n        ) {\n          this._delayedClose();\n        }\n      },\n      { passive: true },\n    );\n\n    // Any user interaction outside the tooltip, closes it immediately\n    this.addEventListener('overlayOutsidePointer', () => this.close(), { passive: true });\n  }\n\n  private static _initializeTooltipOutlet(): void {\n    this._tooltipOutlet = document.createElement('div');\n    this._tooltipOutlet.classList.add('sbb-overlay-outlet');\n    document.body.appendChild(this._tooltipOutlet);\n\n    // Key: trigger attribute, value: tooltip attribute\n    const attributeMap = new Map<string, string>([\n      ['sbb-tooltip-open-delay', 'open-delay'],\n      ['sbb-tooltip-close-delay', 'close-delay'],\n    ]);\n\n    // We are using MutationObserver directly here, as it will only be called on client side,\n    // and we do not need to disconnect it, as we want it to work during the full lifetime\n    // of the page.\n    new MutationObserver((mutations) => {\n      for (const mutation of mutations) {\n        if (mutation.type === 'attributes') {\n          this._handleTooltipTrigger(mutation.target as HTMLElement);\n        } else if (mutation.type === 'childList') {\n          for (const node of [...mutation.addedNodes, ...mutation.removedNodes].filter(\n            (n): n is HTMLElement => n.nodeType === n.ELEMENT_NODE,\n          )) {\n            this._handleTooltipTrigger(node);\n            this._findAndHandleTooltipTriggers(node);\n          }\n        }\n      }\n    }).observe(document.documentElement, {\n      attributeFilter: ['sbb-tooltip', ...attributeMap.keys()],\n      childList: true,\n      subtree: true,\n    });\n    this._findAndHandleTooltipTriggers(document.body);\n  }\n\n  private static _findAndHandleTooltipTriggers(root: HTMLElement): void {\n    root\n      .querySelectorAll<HTMLElement>('[sbb-tooltip]')\n      .forEach((e) => this._handleTooltipTrigger(e));\n  }\n\n  private static _handleTooltipTrigger(triggerElement: HTMLElement): void {\n    const tooltipMessage = triggerElement.getAttribute('sbb-tooltip');\n    let tooltip = tooltipTriggers.get(triggerElement);\n\n    if (tooltipMessage && triggerElement.isConnected) {\n      if (!tooltip) {\n        // Create a new sbb-tooltip in the outlet and attach it to the trigger\n        tooltip = document.createElement('sbb-tooltip');\n        tooltipTriggers.set(triggerElement, tooltip);\n        this._tooltipOutlet.appendChild(tooltip);\n        tooltip.trigger = triggerElement;\n      }\n\n      tooltip.textContent = tooltipMessage;\n      tooltip.openDelay = triggerElement.hasAttribute('sbb-tooltip-open-delay')\n        ? +triggerElement.getAttribute('sbb-tooltip-open-delay')!\n        : null;\n      tooltip.closeDelay = triggerElement.hasAttribute('sbb-tooltip-close-delay')\n        ? +triggerElement.getAttribute('sbb-tooltip-close-delay')!\n        : null;\n    } else if (tooltip) {\n      // The trigger or the attribute has been deleted => delete the connected tooltip\n      tooltipTriggers.delete(triggerElement);\n      tooltip._destroy();\n    }\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.popover = 'manual';\n    this.id ||= `sbb-tooltip-${++nextId}`;\n    this.state = 'closed';\n    sbbOverlayOutsidePointerEventListener.connect(this);\n\n    if (this.hasUpdated && this.trigger) {\n      this._attach(this.trigger);\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    sbbOverlayOutsidePointerEventListener.disconnect(this);\n    this._detach();\n  }\n\n  public override requestUpdate(\n    name?: PropertyKey,\n    oldValue?: unknown,\n    options?: PropertyDeclaration,\n  ): void {\n    super.requestUpdate(name, oldValue, options);\n    if (isServer) {\n      return;\n    }\n\n    if ((!name || name === 'trigger') && this.hasUpdated) {\n      this._attach(this.trigger);\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues): void {\n    super.firstUpdated(changedProperties);\n    this._attach(this.trigger);\n  }\n\n  public open(): void {\n    this._resetOpenCloseTimeout();\n    if (\n      (this.state !== 'closed' && this.state !== 'closing') ||\n      this.disabled ||\n      !this.overlay ||\n      !this.dispatchBeforeOpenEvent()\n    ) {\n      return;\n    }\n\n    this.showPopover?.();\n    this.state = 'opening';\n    this._setTooltipPosition();\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `opened` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleOpening();\n    }\n  }\n\n  public close(): void {\n    this._resetOpenCloseTimeout();\n    if (this.state !== 'opened' && this.state !== 'opening') {\n      return;\n    }\n\n    this.dispatchBeforeCloseEvent();\n    this.state = 'closing';\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `closed` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleClosing();\n    }\n  }\n\n  private _delayedOpen(): void {\n    this._resetOpenCloseTimeout();\n    this._openTimeout = setTimeout(() => this.open(), this.openDelay);\n  }\n\n  private _handleOpening(): void {\n    this.state = 'opened';\n    this._attachWindowEvents();\n    this._escapableOverlayController.connect();\n    this.dispatchOpenEvent();\n  }\n\n  private _delayedClose(): void {\n    this._resetOpenCloseTimeout();\n    this._closeTimeout = setTimeout(() => this.close(), this.closeDelay);\n  }\n\n  private _handleClosing(): void {\n    this.state = 'closed';\n    this.hidePopover?.();\n\n    this._escapableOverlayController.disconnect();\n    this.dispatchCloseEvent();\n    this._openStateController?.abort();\n  }\n\n  private _onTooltipAnimationEnd(event: AnimationEvent): void {\n    if (event.animationName === 'open' && this.state === 'opening') {\n      this._handleOpening();\n    } else if (event.animationName === 'close' && this.state === 'closing') {\n      this._handleClosing();\n    }\n  }\n\n  private _attach(trigger: HTMLElement | null): void {\n    if (this._triggerElement) {\n      // Eventually detach from the old trigger\n      this._detach();\n    }\n\n    this._triggerElement = trigger;\n    if (!this._triggerElement) {\n      return;\n    }\n    addToListAttribute(this._triggerElement, 'aria-describedby', this.id);\n    this._addTriggerEventHandlers();\n  }\n\n  private _detach(): void {\n    this._triggerAbortController?.abort();\n    this._openStateController?.abort();\n\n    // clear timeouts\n    this._resetOpenCloseTimeout();\n    clearTimeout(this._longPressOpenTimeout);\n    clearTimeout(this._longPressCloseTimeout);\n\n    if (!this._triggerElement) {\n      return;\n    }\n    removeFromListAttribute(this._triggerElement, 'aria-describedby', this.id);\n    this._triggerElement = null;\n  }\n\n  private _destroy(): void {\n    this._detach();\n    this.remove();\n  }\n\n  private _setTooltipPosition(): void {\n    if (!this.overlay || !this._triggerElement) {\n      return;\n    }\n\n    const position = getElementPosition(this.overlay, this._triggerElement, this, {\n      verticalOffset: VERTICAL_OFFSET,\n      horizontalOffset: HORIZONTAL_OFFSET,\n      centered: true,\n      responsiveHeight: true,\n    });\n    this.setAttribute('data-position', position.alignment.vertical);\n\n    this.style.setProperty('--sbb-tooltip-position-x', `${position.left}px`);\n    this.style.setProperty('--sbb-tooltip-position-y', `${position.top}px`);\n  }\n\n  private _addTriggerEventHandlers(): void {\n    const trigger = this._triggerElement;\n    if (!trigger) {\n      return;\n    }\n\n    this._triggerAbortController?.abort();\n    this._triggerAbortController = new AbortController();\n    const options: AddEventListenerOptions = {\n      signal: this._triggerAbortController.signal,\n      passive: true,\n    };\n\n    if (!isMobile) {\n      trigger.addEventListener('mouseenter', () => this._delayedOpen(), options);\n      trigger.addEventListener(\n        'mouseleave',\n        (event) => {\n          const newTarget = event.relatedTarget as Node | null;\n          if (!newTarget || newTarget !== this) {\n            this._delayedClose();\n          }\n        },\n        options,\n      );\n\n      // 'blurs' immediately close the tooltip because it is considered an 'interaction with other elements'\n      trigger.addEventListener('blur', () => this.close(), options);\n      trigger.addEventListener('focus', () => this._delayedOpen(), options);\n    }\n\n    // Long-press event handling (mainly for mobile users)\n    trigger.addEventListener(\n      'touchstart',\n      () => {\n        clearTimeout(this._longPressOpenTimeout);\n        clearTimeout(this._longPressCloseTimeout);\n        this._longPressOpenTimeout = setTimeout(() => this.open(), LONGPRESS_DELAY);\n      },\n      options,\n    );\n    trigger.addEventListener(\n      'touchend',\n      () => {\n        clearTimeout(this._longPressOpenTimeout);\n        this._longPressCloseTimeout = setTimeout(() => this.close(), this.longPressCloseDelay);\n      },\n      options,\n    );\n    trigger.addEventListener(\n      'touchcancel',\n      () => {\n        clearTimeout(this._longPressOpenTimeout);\n      },\n      options,\n    );\n  }\n\n  private _attachWindowEvents(): void {\n    this._openStateController = new AbortController();\n    document.addEventListener('scroll', () => this._setTooltipPosition(), {\n      passive: true,\n      signal: this._openStateController.signal,\n      // Without capture, other scroll contexts would not bubble to this event listener.\n      // Capture allows us to react to all scroll contexts in this DOM.\n      capture: true,\n    });\n    window.addEventListener('resize', () => this._setTooltipPosition(), {\n      passive: true,\n      signal: this._openStateController.signal,\n    });\n  }\n\n  private _isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-tooltip-animation-duration');\n  }\n\n  private _resetOpenCloseTimeout(): void {\n    clearTimeout(this._openTimeout);\n    clearTimeout(this._closeTimeout);\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div\n        @animationend=${this._onTooltipAnimationEnd}\n        class=\"sbb-tooltip\"\n        ${ref((el?: Element) => (this.overlay = el as HTMLDivElement))}\n      >\n        <slot></slot>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-tooltip': SbbTooltipElement;\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"menu-action-common.d.ts","sourceRoot":"","sources":["../../../../src/elements/menu/common/menu-action-common.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAExE,OAAO,EAAE,KAAK,mBAAmB,EAAoB,MAAM,sBAAsB,CAAC;;AAKlF,MAAM,CAAC,OAAO,OAAO,mCAAoC,SAAQ,wCAEhE;CAAG;AAGJ,eAAO,MAAM,+BAA+B,GAC1C,CAAC,SAAS,mBAAmB,CAAC,oBAAoB,CAAC,EAEnD,YAAY,CAAC,KACZ,mBAAmB,CAAC,mCAAmC,CAAC,GAAG,
|
|
1
|
+
{"version":3,"file":"menu-action-common.d.ts","sourceRoot":"","sources":["../../../../src/elements/menu/common/menu-action-common.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAExE,OAAO,EAAE,KAAK,mBAAmB,EAAoB,MAAM,sBAAsB,CAAC;;AAKlF,MAAM,CAAC,OAAO,OAAO,mCAAoC,SAAQ,wCAEhE;CAAG;AAGJ,eAAO,MAAM,+BAA+B,GAC1C,CAAC,SAAS,mBAAmB,CAAC,oBAAoB,CAAC,EAEnD,YAAY,CAAC,KACZ,mBAAmB,CAAC,mCAAmC,CAAC,GAAG,CAwB7D,CAAC"}
|
|
@@ -1,27 +1,30 @@
|
|
|
1
1
|
import { __esDecorate as r, __runInitializers as c } from "tslib";
|
|
2
2
|
import { css as l } from "lit";
|
|
3
|
-
import { html as
|
|
4
|
-
import { slotState as
|
|
3
|
+
import { html as u } from "lit/static-html.js";
|
|
4
|
+
import { slotState as d } from "../../core/decorators.js";
|
|
5
5
|
import { SbbDisabledMixin as m } from "../../core/mixins.js";
|
|
6
|
-
import { SbbIconNameMixin as
|
|
7
|
-
const
|
|
8
|
-
var
|
|
9
|
-
let b = [
|
|
10
|
-
return
|
|
6
|
+
import { SbbIconNameMixin as p } from "../../icon.js";
|
|
7
|
+
const v = l`*,:before,:after{box-sizing:border-box}:host{outline:none!important;--sbb-menu-action-border-radius: var(--sbb-border-radius-infinity);--sbb-menu-action-outer-horizontal-padding: var(--sbb-spacing-fixed-3x);--sbb-menu-action-outer-vertical-padding: var(--sbb-spacing-fixed-1x);--sbb-menu-action-gap: var(--sbb-spacing-fixed-2x);--sbb-menu-action-cursor: pointer;--sbb-menu-action-color: var(--sbb-color-2-inverted);--sbb-menu-action-forced-color-border-color: CanvasText;--sbb-menu-action-content-padding-inline: var(--sbb-spacing-fixed-2x);--sbb-menu-action-content-padding-block: var(--sbb-spacing-fixed-1x);display:block}@media (any-hover: hover){:host(:is(:hover:not([disabled],:disabled,[disabled-interactive]),[aria-expanded=true])){--sbb-menu-background-color: var(--sbb-color-iron);--sbb-menu-background-color: light-dark(var(--sbb-color-iron), var(--sbb-color-milk));--sbb-menu-action-forced-color-border-color: Highlight}}:host(:is([disabled],:disabled,[disabled-interactive])){--sbb-menu-action-cursor: default;--sbb-menu-action-color: var(--sbb-color-graphite);--sbb-menu-action-color: light-dark(var(--sbb-color-graphite), var(--sbb-color-granite));--sbb-menu-action-forced-color-border-color: GrayText;pointer-events:none;cursor:default}@media (forced-colors: active){:host(:is([disabled],:disabled,[disabled-interactive])){--sbb-menu-action-color: GrayText}}:host([data-sbb-menu-trigger]){--sbb-menu-action-cursor: default}@media (forced-colors: active){:host([data-button]){--sbb-menu-action-color: ButtonText}}:host([sbb-badge]:not([icon-name],[data-slot-names~=icon])):after{inset:50% calc(100% - var(--sbb-menu-action-outer-horizontal-padding) - var(--sbb-menu-action-content-padding-inline) - .5 * var(--sbb-size-icon-ui-small)) auto auto!important;translate:50% -50%}:host([sbb-badge]:is([icon-name],[data-slot-names~=icon])):after{inset:calc(var(--sbb-menu-action-outer-vertical-padding) + var(--sbb-menu-action-content-padding-block) + var(--sbb-badge-position-offset)) calc(100% - var(--sbb-menu-action-outer-horizontal-padding) - var(--sbb-menu-action-content-padding-inline) - var(--sbb-size-icon-ui-small) + var(--sbb-badge-position-offset)) auto auto!important}:host([aria-controls*=sbb-menu]){--sbb-menu-action-submenu-icon-display: flex}:is(.sbb-menu-button,.sbb-menu-link){text-decoration:none;display:block;width:100%;color:var(--sbb-menu-action-color);padding:var(--sbb-menu-action-outer-vertical-padding) var(--sbb-menu-action-outer-horizontal-padding);cursor:var(--sbb-menu-action-cursor);outline:none}.sbb-menu-action__content{--sbb-text-font-size: var(--sbb-font-size-text-xs);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-body-text);letter-spacing:var(--sbb-typo-letter-spacing-body-text);font-size:var(--sbb-text-font-size);display:flex;align-items:center;gap:var(--sbb-menu-action-gap);padding:var(--sbb-menu-action-content-padding-block) var(--sbb-menu-action-content-padding-inline);border-radius:var(--sbb-menu-action-border-radius);-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;background-color:var(--sbb-menu-background-color)}:host(:focus-visible) .sbb-menu-action__content,:focus-visible .sbb-menu-action__content{outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width)}@media (forced-colors: active){.sbb-menu-action__content{border:var(--sbb-border-width-2x) solid var(--sbb-menu-action-forced-color-border-color)}}.sbb-menu-action__icon,.sbb-menu-submenu__icon{display:flex;min-width:var(--sbb-size-icon-ui-small);min-height:var(--sbb-size-icon-ui-small)}.sbb-menu-submenu__icon{display:var(--sbb-menu-action-submenu-icon-display, none);margin-inline-start:auto}.sbb-menu-action__label{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host(:is([disabled],:disabled,[disabled-interactive])) .sbb-menu-action__label{text-decoration:line-through}`, z = (s) => (() => {
|
|
8
|
+
var o;
|
|
9
|
+
let b = [d()], t, a = [], e, i = p(m(s));
|
|
10
|
+
return o = class extends i {
|
|
11
11
|
renderTemplate() {
|
|
12
|
-
return
|
|
12
|
+
return u`
|
|
13
13
|
<span class="sbb-menu-action__content">
|
|
14
14
|
<span class="sbb-menu-action__icon"> ${super.renderIconSlot()} </span>
|
|
15
15
|
<span class="sbb-menu-action__label">
|
|
16
16
|
<slot></slot>
|
|
17
17
|
</span>
|
|
18
|
+
<span class="sbb-menu-submenu__icon">
|
|
19
|
+
<sbb-icon name="chevron-small-right-small"></sbb-icon>
|
|
20
|
+
</span>
|
|
18
21
|
</span>
|
|
19
22
|
`;
|
|
20
23
|
}
|
|
21
|
-
},
|
|
22
|
-
const
|
|
23
|
-
r(null,
|
|
24
|
-
})(),
|
|
24
|
+
}, e = o, (() => {
|
|
25
|
+
const n = typeof Symbol == "function" && Symbol.metadata ? Object.create(i[Symbol.metadata] ?? null) : void 0;
|
|
26
|
+
r(null, t = { value: e }, b, { kind: "class", name: e.name, metadata: n }, null, a), e = t.value, n && Object.defineProperty(e, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: n });
|
|
27
|
+
})(), o.styles = v, c(e, a), e;
|
|
25
28
|
})();
|
|
26
29
|
export {
|
|
27
30
|
z as SbbMenuActionCommonElementMixin
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { CSSResultGroup, PropertyDeclaration, PropertyValues, TemplateResult } from 'lit';
|
|
2
2
|
import { SbbOpenCloseBaseElement } from '../../core/base-elements.js';
|
|
3
3
|
import { SbbMenuButtonElement } from '../menu-button.js';
|
|
4
|
-
import { SbbMenuLinkElement } from '../menu-link.js';
|
|
4
|
+
import { SbbMenuLinkElement } from '../menu-link/menu-link.component.js';
|
|
5
5
|
declare const SbbMenuElement_base: import('../../core/mixins.js').AbstractConstructor<import('../../core/mixins.js').SbbNamedSlotListMixinType<SbbMenuButtonElement | SbbMenuLinkElement>> & typeof SbbOpenCloseBaseElement;
|
|
6
6
|
/**
|
|
7
7
|
* It displays a contextual menu with one or more action element.
|
|
@@ -35,39 +35,50 @@ export declare class SbbMenuElement extends SbbMenuElement_base {
|
|
|
35
35
|
private _focusTrapController;
|
|
36
36
|
private _scrollHandler;
|
|
37
37
|
private _inertController;
|
|
38
|
+
private _mobileBreakpoint;
|
|
38
39
|
private _mediaMatcher;
|
|
39
40
|
private _darkModeController;
|
|
41
|
+
private _language;
|
|
42
|
+
private _nestedMenu;
|
|
40
43
|
constructor();
|
|
44
|
+
protected firstUpdated(changedProperties: PropertyValues<this>): void;
|
|
45
|
+
escapeStrategy(): void;
|
|
41
46
|
/**
|
|
42
47
|
* Opens the menu on trigger click.
|
|
43
48
|
*/
|
|
44
49
|
open(): void;
|
|
45
|
-
/**
|
|
46
|
-
* Closes the menu.
|
|
47
|
-
*/
|
|
50
|
+
/** Closes the menu and all its nested menus. */
|
|
48
51
|
close(): void;
|
|
52
|
+
/** Closes the menu and all related menus nested and parent menus). */
|
|
53
|
+
closeAll(): void;
|
|
54
|
+
/** @param [closeAll='false'] - If true, it ensures animations are correct by toggling some states when closing all related menus at once. */
|
|
55
|
+
private _close;
|
|
49
56
|
private _isZeroAnimationDuration;
|
|
50
57
|
private _handleOpening;
|
|
51
58
|
private _handleClosing;
|
|
52
|
-
/**
|
|
53
|
-
* Handles click and checks if its target is a sbb-menu-button/sbb-menu-link.
|
|
54
|
-
*/
|
|
55
|
-
private _onClick;
|
|
56
59
|
private _handleKeyDown;
|
|
57
60
|
protected createRenderRoot(): HTMLElement | DocumentFragment;
|
|
58
61
|
connectedCallback(): void;
|
|
59
62
|
disconnectedCallback(): void;
|
|
60
63
|
requestUpdate(name?: PropertyKey, oldValue?: unknown, options?: PropertyDeclaration): void;
|
|
61
|
-
protected firstUpdated(changedProperties: PropertyValues<this>): void;
|
|
62
64
|
private _checkListCase;
|
|
63
65
|
private _configureTrigger;
|
|
64
66
|
private _attachWindowEvents;
|
|
65
|
-
private
|
|
67
|
+
private _interactiveElementClick;
|
|
66
68
|
private _pointerDownListener;
|
|
67
69
|
private _closeOnBackdropClick;
|
|
70
|
+
/** Converts the linked list into an array of SbbMenuElement. */
|
|
71
|
+
private _nestedMenus;
|
|
72
|
+
private _parentMenu;
|
|
73
|
+
/** The outermost menu. */
|
|
74
|
+
private _mainMenu;
|
|
75
|
+
private _isNested;
|
|
76
|
+
private _updateNestedInert;
|
|
77
|
+
private _handleMouseOver;
|
|
68
78
|
private _onMenuAnimationEnd;
|
|
69
79
|
private _setMenuPosition;
|
|
70
80
|
private _syncNegative;
|
|
81
|
+
private _isMobile;
|
|
71
82
|
protected render(): TemplateResult;
|
|
72
83
|
}
|
|
73
84
|
declare global {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"menu.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/menu/menu/menu.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAGnB,KAAK,mBAAmB,EACxB,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAUb,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;
|
|
1
|
+
{"version":3,"file":"menu.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/menu/menu/menu.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAGnB,KAAK,mBAAmB,EACxB,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAUb,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AAqBtE,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAC9D,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,qCAAqC,CAAC;AAI9E,OAAO,kBAAkB,CAAC;AAC1B,OAAO,mBAAmB,CAAC;;AAmB3B;;;;;;;GAOG;AACH,qBAEM,cAAe,SAAQ,mBAGH;IACxB,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAgC,IAAI,UAAU;IAC9C,mBAA4B,mBAAmB,WAAwC;IAEvF;;;;OAIG;IACH,SAEgB,OAAO,EAAE,WAAW,GAAG,IAAI,CAAQ;IAEnD;;;OAGG;IACH,SAEgB,sBAAsB,EAAE,MAAM,CAAM;IAEpD,OAAO,CAAC,KAAK,CAAkB;IAC/B,OAAO,CAAC,eAAe,CAA4B;IACnD,OAAO,CAAC,uBAAuB,CAAmB;IAClD,OAAO,CAAC,yBAAyB,CAAkB;IACnD,OAAO,CAAC,uBAAuB,CAAmB;IAClD,OAAO,CAAC,2BAA2B,CAA2C;IAC9E,OAAO,CAAC,oBAAoB,CAAoC;IAChE,OAAO,CAAC,cAAc,CAA0B;IAChD,OAAO,CAAC,gBAAgB,CAAgC;IACxD,OAAO,CAAC,iBAAiB,CAAwC;IACjE,OAAO,CAAC,aAAa,CAQlB;IACH,OAAO,CAAC,mBAAmB,CAA+D;IAC1F,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,WAAW,CAA+B;;cAO/B,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAM9D,cAAc,IAAI,IAAI;IAItC;;OAEG;IACI,IAAI,IAAI,IAAI;IAuCnB,gDAAgD;IACzC,KAAK,IAAI,IAAI;IAIpB,uEAAuE;IAChE,QAAQ,IAAI,IAAI;IAIvB,6IAA6I;IAC7I,OAAO,CAAC,MAAM;IA0Bd,OAAO,CAAC,wBAAwB;IAIhC,OAAO,CAAC,cAAc;IAetB,OAAO,CAAC,cAAc;IA4BtB,OAAO,CAAC,cAAc;cAqDH,gBAAgB,IAAI,WAAW,GAAG,gBAAgB;IAkBrD,iBAAiB,IAAI,IAAI;IASzB,oBAAoB,IAAI,IAAI;IAQ5B,aAAa,CAC3B,IAAI,CAAC,EAAE,WAAW,EAClB,QAAQ,CAAC,EAAE,OAAO,EAClB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,IAAI;IAQP,OAAO,CAAC,cAAc;IAmBtB,OAAO,CAAC,iBAAiB;IA2BzB,OAAO,CAAC,mBAAmB;IA2B3B,OAAO,CAAC,wBAAwB;IAchC,OAAO,CAAC,oBAAoB,CAM1B;IAGF,OAAO,CAAC,qBAAqB,CAc3B;IAEF,gEAAgE;IAChE,OAAO,CAAC,YAAY;IAYpB,OAAO,CAAC,WAAW;IAInB,0BAA0B;IAC1B,OAAO,CAAC,SAAS;IAIjB,OAAO,CAAC,SAAS;IAIjB,OAAO,CAAC,kBAAkB;IAQ1B,OAAO,CAAC,gBAAgB;IAwBxB,OAAO,CAAC,mBAAmB;IAe3B,OAAO,CAAC,gBAAgB;IA+BxB,OAAO,CAAC,aAAa;IAQrB,OAAO,CAAC,SAAS;cAIE,MAAM,IAAI,cAAc;CA+B5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,UAAU,EAAE,cAAc,CAAC;KAC5B;CACF"}
|