@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
@@ -238,11 +238,16 @@ let SbbTabLabelElement = (() => {
238
238
  let _amount_extraInitializers = [];
239
239
  _a = class extends _classSuper {
240
240
  constructor() {
241
- super(...arguments);
242
- __privateAdd(this, _level_accessor_storage, __runInitializers(this, _level_initializers, "1"));
243
- __privateAdd(this, _active_accessor_storage, (__runInitializers(this, _level_extraInitializers), __runInitializers(this, _active_initializers, false)));
244
- __privateAdd(this, _amount_accessor_storage, (__runInitializers(this, _active_extraInitializers), __runInitializers(this, _amount_initializers, "")));
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 0
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 0
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,EAEjC;IACD,IAAW,SAAS,IAAI,MAAM,CAE7B;IACD,OAAO,CAAC,UAAU,CAAC,CAAS;IAE5B;;;;;OAKG;IACH,IACW,UAAU,CAAC,KAAK,EAAE,MAAM,EAElC;IACD,IAAW,UAAU,IAAI,MAAM,CAE9B;IACD,OAAO,CAAC,WAAW,CAAC,CAAS;IAE7B;;;;;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;IA6BvC,OAAO,CAAC,MAAM,CAAC,6BAA6B;IAM5C,OAAO,CAAC,MAAM,CAAC,qBAAqB;IAoBpB,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"}
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 0
176
+ * @default null
176
177
  */
177
178
  set openDelay(value) {
178
- this._openDelay = +value;
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 0
188
+ * @default null
188
189
  */
189
190
  set closeDelay(value) {
190
- this._closeDelay = +value;
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,CAqB7D,CAAC"}
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 d } from "lit/static-html.js";
4
- import { slotState as u } from "../../core/decorators.js";
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 v } from "../../icon.js";
7
- const p = 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(:hover:not([disabled],:disabled,[disabled-interactive])){--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}}@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}: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{display:flex;min-width:var(--sbb-size-icon-ui-small);min-height:var(--sbb-size-icon-ui-small)}.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 e;
9
- let b = [u()], n, a = [], o, i = v(m(s));
10
- return e = class extends i {
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 d`
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
- }, o = e, (() => {
22
- const t = typeof Symbol == "function" && Symbol.metadata ? Object.create(i[Symbol.metadata] ?? null) : void 0;
23
- r(null, n = { value: o }, b, { kind: "class", name: o.name, metadata: t }, null, a), o = n.value, t && Object.defineProperty(o, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: t });
24
- })(), e.styles = p, c(o, a), o;
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 _closeOnInteractiveElementClick;
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;AAkBtE,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAC9D,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;;AAkB1D;;;;;;;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,aAAa,CAQlB;IACH,OAAO,CAAC,mBAAmB,CAA+D;;IAQ1F;;OAEG;IACI,IAAI,IAAI,IAAI;IAyBnB;;OAEG;IACI,KAAK,IAAI,IAAI;IAepB,OAAO,CAAC,wBAAwB;IAIhC,OAAO,CAAC,cAAc;IAUtB,OAAO,CAAC,cAAc;IAsBtB;;OAEG;IACH,OAAO,CAAC,QAAQ;IAOhB,OAAO,CAAC,cAAc;cA2CH,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;cAQY,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAK9E,OAAO,CAAC,cAAc;IAmBtB,OAAO,CAAC,iBAAiB;IAoBzB,OAAO,CAAC,mBAAmB;IAuB3B,OAAO,CAAC,+BAA+B;IAQvC,OAAO,CAAC,oBAAoB,CAE1B;IAGF,OAAO,CAAC,qBAAqB,CAI3B;IAMF,OAAO,CAAC,mBAAmB;IAS3B,OAAO,CAAC,gBAAgB;IAyBxB,OAAO,CAAC,aAAa;cAQF,MAAM,IAAI,cAAc;CAsB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,UAAU,EAAE,cAAc,CAAC;KAC5B;CACF"}
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"}