@sbb-esta/lyne-elements 3.9.0 → 3.11.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 (120) hide show
  1. package/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.component.js +1 -1
  2. package/autocomplete-grid/autocomplete-grid-row/autocomplete-grid-row.component.js +1 -1
  3. package/calendar/calendar.component.d.ts +2 -1
  4. package/calendar/calendar.component.d.ts.map +1 -1
  5. package/calendar/calendar.component.js +211 -225
  6. package/carousel/carousel/carousel.component.d.ts.map +1 -1
  7. package/carousel/carousel/carousel.component.js +5 -5
  8. package/core/controllers/escapable-overlay-controller.d.ts +3 -0
  9. package/core/controllers/escapable-overlay-controller.d.ts.map +1 -1
  10. package/core/controllers/overlay-position-controller.d.ts +60 -0
  11. package/core/controllers/overlay-position-controller.d.ts.map +1 -0
  12. package/core/controllers/overlay-position-controller.js +224 -0
  13. package/core/controllers.d.ts +1 -0
  14. package/core/controllers.d.ts.map +1 -1
  15. package/core/controllers.js +12 -10
  16. package/core/styles/core.scss +27 -2
  17. package/core.css +21 -2
  18. package/custom-elements.json +2238 -769
  19. package/development/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.component.js +7 -1
  20. package/development/autocomplete-grid/autocomplete-grid-row/autocomplete-grid-row.component.js +2 -1
  21. package/development/calendar/calendar.component.d.ts +2 -1
  22. package/development/calendar/calendar.component.d.ts.map +1 -1
  23. package/development/calendar/calendar.component.js +20 -36
  24. package/development/carousel/carousel/carousel.component.d.ts.map +1 -1
  25. package/development/carousel/carousel/carousel.component.js +2 -2
  26. package/development/core/controllers/escapable-overlay-controller.d.ts +3 -0
  27. package/development/core/controllers/escapable-overlay-controller.d.ts.map +1 -1
  28. package/development/core/controllers/escapable-overlay-controller.js +1 -1
  29. package/development/core/controllers/overlay-position-controller.d.ts +60 -0
  30. package/development/core/controllers/overlay-position-controller.d.ts.map +1 -0
  31. package/development/core/controllers/overlay-position-controller.js +306 -0
  32. package/development/core/controllers.d.ts +1 -0
  33. package/development/core/controllers.d.ts.map +1 -1
  34. package/development/core/controllers.js +3 -1
  35. package/development/mini-calendar/mini-calendar/mini-calendar.component.d.ts +35 -0
  36. package/development/mini-calendar/mini-calendar/mini-calendar.component.d.ts.map +1 -0
  37. package/development/mini-calendar/mini-calendar/mini-calendar.component.js +201 -0
  38. package/development/mini-calendar/mini-calendar-day/mini-calendar-day.component.d.ts +23 -0
  39. package/development/mini-calendar/mini-calendar-day/mini-calendar-day.component.d.ts.map +1 -0
  40. package/development/mini-calendar/mini-calendar-day/mini-calendar-day.component.js +181 -0
  41. package/development/mini-calendar/mini-calendar-day.d.ts +5 -0
  42. package/development/mini-calendar/mini-calendar-day.d.ts.map +1 -0
  43. package/development/mini-calendar/mini-calendar-day.js +5 -0
  44. package/development/mini-calendar/mini-calendar-month/mini-calendar-month.component.d.ts +25 -0
  45. package/development/mini-calendar/mini-calendar-month/mini-calendar-month.component.d.ts.map +1 -0
  46. package/development/mini-calendar/mini-calendar-month/mini-calendar-month.component.js +123 -0
  47. package/development/mini-calendar/mini-calendar-month.d.ts +5 -0
  48. package/development/mini-calendar/mini-calendar-month.d.ts.map +1 -0
  49. package/development/mini-calendar/mini-calendar-month.js +5 -0
  50. package/development/mini-calendar/mini-calendar.d.ts +5 -0
  51. package/development/mini-calendar/mini-calendar.d.ts.map +1 -0
  52. package/development/mini-calendar/mini-calendar.js +5 -0
  53. package/development/mini-calendar.d.ts +7 -0
  54. package/development/mini-calendar.d.ts.map +1 -0
  55. package/development/mini-calendar.js +9 -0
  56. package/development/paginator/common/paginator-common.d.ts.map +1 -1
  57. package/development/paginator/common/paginator-common.js +14 -3
  58. package/development/sidebar/icon-sidebar-button/icon-sidebar-button.component.d.ts +4 -1
  59. package/development/sidebar/icon-sidebar-button/icon-sidebar-button.component.d.ts.map +1 -1
  60. package/development/sidebar/icon-sidebar-button/icon-sidebar-button.component.js +5 -1
  61. package/development/sidebar/icon-sidebar-link/icon-sidebar-link.component.d.ts +4 -1
  62. package/development/sidebar/icon-sidebar-link/icon-sidebar-link.component.d.ts.map +1 -1
  63. package/development/sidebar/icon-sidebar-link/icon-sidebar-link.component.js +5 -1
  64. package/development/tabs/tab/tab.component.d.ts +9 -0
  65. package/development/tabs/tab/tab.component.d.ts.map +1 -1
  66. package/development/tabs/tab/tab.component.js +48 -7
  67. package/development/tabs/tab-group/tab-group.component.d.ts +7 -3
  68. package/development/tabs/tab-group/tab-group.component.d.ts.map +1 -1
  69. package/development/tabs/tab-group/tab-group.component.js +19 -39
  70. package/development/tabs/tab-label/tab-label.component.d.ts.map +1 -1
  71. package/development/tabs/tab-label/tab-label.component.js +4 -3
  72. package/development/tooltip/tooltip.component.d.ts +11 -4
  73. package/development/tooltip/tooltip.component.d.ts.map +1 -1
  74. package/development/tooltip/tooltip.component.js +57 -78
  75. package/index.d.ts +6 -0
  76. package/index.js +6 -0
  77. package/mini-calendar/mini-calendar/mini-calendar.component.d.ts +35 -0
  78. package/mini-calendar/mini-calendar/mini-calendar.component.d.ts.map +1 -0
  79. package/mini-calendar/mini-calendar/mini-calendar.component.js +133 -0
  80. package/mini-calendar/mini-calendar-day/mini-calendar-day.component.d.ts +23 -0
  81. package/mini-calendar/mini-calendar-day/mini-calendar-day.component.d.ts.map +1 -0
  82. package/mini-calendar/mini-calendar-day/mini-calendar-day.component.js +66 -0
  83. package/mini-calendar/mini-calendar-day.d.ts +5 -0
  84. package/mini-calendar/mini-calendar-day.d.ts.map +1 -0
  85. package/mini-calendar/mini-calendar-day.js +4 -0
  86. package/mini-calendar/mini-calendar-month/mini-calendar-month.component.d.ts +25 -0
  87. package/mini-calendar/mini-calendar-month/mini-calendar-month.component.d.ts.map +1 -0
  88. package/mini-calendar/mini-calendar-month/mini-calendar-month.component.js +59 -0
  89. package/mini-calendar/mini-calendar-month.d.ts +5 -0
  90. package/mini-calendar/mini-calendar-month.d.ts.map +1 -0
  91. package/mini-calendar/mini-calendar-month.js +4 -0
  92. package/mini-calendar/mini-calendar.d.ts +5 -0
  93. package/mini-calendar/mini-calendar.d.ts.map +1 -0
  94. package/mini-calendar/mini-calendar.js +4 -0
  95. package/mini-calendar.d.ts +7 -0
  96. package/mini-calendar.d.ts.map +1 -0
  97. package/mini-calendar.js +8 -0
  98. package/off-brand-theme.css +21 -2
  99. package/package.json +21 -1
  100. package/paginator/common/paginator-common.d.ts.map +1 -1
  101. package/paginator/common/paginator-common.js +30 -25
  102. package/safety-theme.css +21 -2
  103. package/sidebar/icon-sidebar-button/icon-sidebar-button.component.d.ts +4 -1
  104. package/sidebar/icon-sidebar-button/icon-sidebar-button.component.d.ts.map +1 -1
  105. package/sidebar/icon-sidebar-button/icon-sidebar-button.component.js +9 -6
  106. package/sidebar/icon-sidebar-link/icon-sidebar-link.component.d.ts +4 -1
  107. package/sidebar/icon-sidebar-link/icon-sidebar-link.component.d.ts.map +1 -1
  108. package/sidebar/icon-sidebar-link/icon-sidebar-link.component.js +13 -10
  109. package/standard-theme.css +21 -2
  110. package/tabs/tab/tab.component.d.ts +9 -0
  111. package/tabs/tab/tab.component.d.ts.map +1 -1
  112. package/tabs/tab/tab.component.js +37 -18
  113. package/tabs/tab-group/tab-group.component.d.ts +7 -3
  114. package/tabs/tab-group/tab-group.component.d.ts.map +1 -1
  115. package/tabs/tab-group/tab-group.component.js +51 -52
  116. package/tabs/tab-label/tab-label.component.d.ts.map +1 -1
  117. package/tabs/tab-label/tab-label.component.js +12 -12
  118. package/tooltip/tooltip.component.d.ts +11 -4
  119. package/tooltip/tooltip.component.d.ts.map +1 -1
  120. package/tooltip/tooltip.component.js +60 -84
@@ -8,14 +8,13 @@ var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "
8
8
  import { __esDecorate, __runInitializers } from "tslib";
9
9
  import { css, isServer, html } from "lit";
10
10
  import { customElement, property } from "lit/decorators.js";
11
- import { ref } from "lit/directives/ref.js";
12
11
  import { SbbOpenCloseBaseElement } from "../core/base-elements.js";
13
12
  import { readConfig } from "../core/config.js";
14
- import { SbbEscapableOverlayController } from "../core/controllers.js";
13
+ import { SbbEscapableOverlayController, SbbOverlayPositionController } from "../core/controllers.js";
15
14
  import { idReference } from "../core/decorators.js";
16
15
  import { queueDomContentLoaded, addToListAttribute, removeFromListAttribute, isZeroAnimationDuration, isAndroid, isIOS } from "../core/dom.js";
17
16
  import { SbbDisabledMixin } from "../core/mixins.js";
18
- import { sbbOverlayOutsidePointerEventListener, getElementPosition } from "../core/overlay.js";
17
+ import { sbbOverlayOutsidePointerEventListener } from "../core/overlay.js";
19
18
  const style = css`*,
20
19
  ::before,
21
20
  ::after {
@@ -23,13 +22,11 @@ const style = css`*,
23
22
  }
24
23
 
25
24
  :host {
26
- --sbb-tooltip-position: absolute;
27
- --sbb-tooltip-position-x: 0;
28
- --sbb-tooltip-position-y: 0;
29
25
  --sbb-tooltip-pointer-events: all;
26
+ --sbb-tooltip-min-width: var(--sbb-spacing-fixed-8x);
30
27
  --sbb-tooltip-max-width: min(
31
28
  25rem,
32
- calc(100% - var(--sbb-spacing-fixed-2x))
29
+ calc(100vw - var(--sbb-spacing-fixed-2x))
33
30
  );
34
31
  --sbb-tooltip-border-color: var(--sbb-background-color-1-inverted);
35
32
  --sbb-tooltip-border-radius: var(--sbb-border-radius-8x);
@@ -42,10 +39,25 @@ const style = css`*,
42
39
  );
43
40
  --sbb-tooltip-animation-easing: ease-out;
44
41
  --sbb-tooltip-animation-translate: 0 var(--sbb-spacing-fixed-2x);
42
+ --sbb-tooltip-gap: var(--sbb-spacing-fixed-2x);
43
+ --sbb-overlay-position-area: block-start;
44
+ --sbb-overlay-position-try-fallbacks:
45
+ block-start span-inline-end, block-start span-inline-start, block-end,
46
+ block-end span-inline-end, block-end span-inline-start;
47
+ position-area: var(--sbb-overlay-position-area);
48
+ position-try-fallbacks: var(--sbb-overlay-position-try-fallbacks);
45
49
  display: none;
46
50
  position: fixed;
47
- inset: 0;
51
+ background-color: transparent;
52
+ pointer-events: var(--sbb-tooltip-pointer-events);
48
53
  z-index: var(--sbb-tooltip-z-index, var(--sbb-overlay-default-z-index));
54
+ animation-name: var(--sbb-tooltip-animation-name);
55
+ animation-duration: var(--sbb-tooltip-animation-duration);
56
+ animation-timing-function: var(--sbb-tooltip-animation-easing);
57
+ border: none;
58
+ inset: initial;
59
+ padding: 0;
60
+ margin: 0;
49
61
  }
50
62
 
51
63
  :host([data-state]:not([data-state=closed])) {
@@ -58,12 +70,21 @@ const style = css`*,
58
70
  --sbb-tooltip-pointer-events: none;
59
71
  }
60
72
 
61
- :host([data-position=below]) {
62
- --sbb-tooltip-hover-patch-inset: calc(-1 * var(--sbb-spacing-fixed-4x)) 0;
73
+ :host(:is([data-position~=block-end], [data-position~=bottom], [data-position^=end])) {
74
+ padding-block-start: var(--sbb-tooltip-gap);
75
+ }
76
+
77
+ :host(:is([data-position~=block-start], [data-position~=top], [data-position^=start])) {
78
+ padding-block-end: var(--sbb-tooltip-gap);
63
79
  }
64
80
 
65
- :host([data-position=above]) {
66
- --sbb-tooltip-hover-patch-inset: 0 calc(-1 * var(--sbb-spacing-fixed-4x));
81
+ :host(:is([data-position~=inline-start],
82
+ [data-position~=inline-end],
83
+ [data-position~=left],
84
+ [data-position~=right],
85
+ [data-position$=" start"],
86
+ [data-position$=" end"])) {
87
+ padding-inline: var(--sbb-tooltip-gap);
67
88
  }
68
89
 
69
90
  .sbb-tooltip {
@@ -74,32 +95,13 @@ const style = css`*,
74
95
  line-height: var(--sbb-typo-line-height-body-text);
75
96
  letter-spacing: var(--sbb-typo-letter-spacing-body-text);
76
97
  font-size: var(--sbb-text-font-size);
77
- position: var(--sbb-tooltip-position);
78
- pointer-events: var(--sbb-tooltip-pointer-events);
79
- top: var(--sbb-tooltip-position-y);
80
- bottom: unset;
81
- left: var(--sbb-tooltip-position-x);
82
- right: unset;
83
98
  border: var(--sbb-border-width-1x) solid var(--sbb-tooltip-border-color);
84
99
  border-radius: var(--sbb-tooltip-border-radius);
85
100
  padding: var(--sbb-tooltip-padding);
86
- max-width: var(--sbb-tooltip-max-width);
87
- width: max-content;
88
101
  color: var(--sbb-tooltip-color);
89
102
  background-color: var(--sbb-tooltip-background-color);
90
- outline: none;
91
- animation-name: var(--sbb-tooltip-animation-name);
92
- animation-duration: var(--sbb-tooltip-animation-duration);
93
- animation-timing-function: var(--sbb-tooltip-animation-easing);
94
- }
95
- .sbb-tooltip::before {
96
- content: "";
97
- display: block;
98
- position: absolute;
99
- inset: 0;
100
- z-index: -1;
101
- background-color: transparent;
102
- inset-block: var(--sbb-tooltip-hover-patch-inset);
103
+ min-width: var(--sbb-tooltip-min-width);
104
+ max-width: var(--sbb-tooltip-max-width);
103
105
  }
104
106
 
105
107
  @keyframes open {
@@ -123,8 +125,6 @@ const style = css`*,
123
125
  }
124
126
  }`;
125
127
  const LONGPRESS_DELAY = 500;
126
- const VERTICAL_OFFSET = 8;
127
- const HORIZONTAL_OFFSET = 16;
128
128
  const isMobile = isAndroid || isIOS;
129
129
  const tooltipTriggers = /* @__PURE__ */ new WeakMap();
130
130
  let nextId = 0;
@@ -151,15 +151,17 @@ let SbbTooltipElement = (() => {
151
151
  this._closeDelay = null;
152
152
  this._triggerElement = null;
153
153
  this._escapableOverlayController = new SbbEscapableOverlayController(this);
154
+ this._overlayController = new SbbOverlayPositionController(this);
154
155
  this.addEventListener("mouseleave", (event) => {
155
156
  if ((this.state === "opened" || this.state === "opening") && (!event.relatedTarget || !this._triggerElement?.contains(event.relatedTarget))) {
156
157
  this._delayedClose();
157
158
  }
158
159
  }, { passive: true });
159
160
  this.addEventListener("overlayOutsidePointer", () => this.close(), { passive: true });
161
+ this.addEventListener("animationend", (e) => this._onTooltipAnimationEnd(e), { passive: true });
160
162
  }
161
163
  /**
162
- * The element that will trigger the popover overlay.
164
+ * The element that will trigger the tooltip overlay.
163
165
  *
164
166
  * For attribute usage, provide an id reference.
165
167
  */
@@ -209,10 +211,6 @@ let SbbTooltipElement = (() => {
209
211
  this._tooltipOutlet = document.createElement("div");
210
212
  this._tooltipOutlet.classList.add("sbb-overlay-outlet");
211
213
  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
- ]);
216
214
  new MutationObserver((mutations) => {
217
215
  for (const mutation of mutations) {
218
216
  if (mutation.type === "attributes") {
@@ -225,7 +223,12 @@ let SbbTooltipElement = (() => {
225
223
  }
226
224
  }
227
225
  }).observe(document.documentElement, {
228
- attributeFilter: ["sbb-tooltip", ...attributeMap.keys()],
226
+ attributeFilter: [
227
+ "sbb-tooltip",
228
+ "sbb-tooltip-open-delay",
229
+ "sbb-tooltip-close-delay",
230
+ "sbb-tooltip-position"
231
+ ],
229
232
  childList: true,
230
233
  subtree: true
231
234
  });
@@ -247,6 +250,14 @@ let SbbTooltipElement = (() => {
247
250
  tooltip.textContent = tooltipMessage;
248
251
  tooltip.openDelay = triggerElement.hasAttribute("sbb-tooltip-open-delay") ? +triggerElement.getAttribute("sbb-tooltip-open-delay") : null;
249
252
  tooltip.closeDelay = triggerElement.hasAttribute("sbb-tooltip-close-delay") ? +triggerElement.getAttribute("sbb-tooltip-close-delay") : null;
253
+ const positions = triggerElement.hasAttribute("sbb-tooltip-position") ? triggerElement.getAttribute("sbb-tooltip-position").split(",").map((p) => p.trim()) : triggerElement.tooltipPositions;
254
+ if (positions && positions.length > 0) {
255
+ tooltip.style.setProperty("--sbb-overlay-position-area", positions[0]);
256
+ tooltip.style.setProperty("--sbb-overlay-position-try-fallbacks", positions.slice(1).join(", "));
257
+ } else {
258
+ tooltip.style.removeProperty("--sbb-overlay-position-area");
259
+ tooltip.style.removeProperty("--sbb-overlay-position-try-fallbacks");
260
+ }
250
261
  } else if (tooltip) {
251
262
  tooltipTriggers.delete(triggerElement);
252
263
  tooltip._destroy();
@@ -282,12 +293,12 @@ let SbbTooltipElement = (() => {
282
293
  }
283
294
  open() {
284
295
  this._resetOpenCloseTimeout();
285
- if (this.state !== "closed" && this.state !== "closing" || this.disabled || !this.overlay || !this.dispatchBeforeOpenEvent()) {
296
+ if (this.state !== "closed" && this.state !== "closing" || this.disabled || !this.trigger || !this.dispatchBeforeOpenEvent()) {
286
297
  return;
287
298
  }
288
299
  this.showPopover?.();
289
300
  this.state = "opening";
290
- this._setTooltipPosition();
301
+ this._overlayController.connect(this.trigger);
291
302
  if (this._isZeroAnimationDuration()) {
292
303
  this._handleOpening();
293
304
  }
@@ -309,7 +320,6 @@ let SbbTooltipElement = (() => {
309
320
  }
310
321
  _handleOpening() {
311
322
  this.state = "opened";
312
- this._attachWindowEvents();
313
323
  this._escapableOverlayController.connect();
314
324
  this.dispatchOpenEvent();
315
325
  }
@@ -320,6 +330,7 @@ let SbbTooltipElement = (() => {
320
330
  _handleClosing() {
321
331
  this.state = "closed";
322
332
  this.hidePopover?.();
333
+ this._overlayController.disconnect();
323
334
  this._escapableOverlayController.disconnect();
324
335
  this.dispatchCloseEvent();
325
336
  this._openStateController?.abort();
@@ -358,20 +369,6 @@ let SbbTooltipElement = (() => {
358
369
  this._detach();
359
370
  this.remove();
360
371
  }
361
- _setTooltipPosition() {
362
- if (!this.overlay || !this._triggerElement) {
363
- return;
364
- }
365
- const position = getElementPosition(this.overlay, this._triggerElement, this, {
366
- verticalOffset: VERTICAL_OFFSET,
367
- horizontalOffset: HORIZONTAL_OFFSET,
368
- centered: true,
369
- responsiveHeight: true
370
- });
371
- this.setAttribute("data-position", position.alignment.vertical);
372
- this.style.setProperty("--sbb-tooltip-position-x", `${position.left}px`);
373
- this.style.setProperty("--sbb-tooltip-position-y", `${position.top}px`);
374
- }
375
372
  _addTriggerEventHandlers() {
376
373
  const trigger = this._triggerElement;
377
374
  if (!trigger) {
@@ -407,20 +404,6 @@ let SbbTooltipElement = (() => {
407
404
  clearTimeout(this._longPressOpenTimeout);
408
405
  }, options);
409
406
  }
410
- _attachWindowEvents() {
411
- this._openStateController = new AbortController();
412
- document.addEventListener("scroll", () => this._setTooltipPosition(), {
413
- passive: true,
414
- signal: this._openStateController.signal,
415
- // Without capture, other scroll contexts would not bubble to this event listener.
416
- // Capture allows us to react to all scroll contexts in this DOM.
417
- capture: true
418
- });
419
- window.addEventListener("resize", () => this._setTooltipPosition(), {
420
- passive: true,
421
- signal: this._openStateController.signal
422
- });
423
- }
424
407
  _isZeroAnimationDuration() {
425
408
  return isZeroAnimationDuration(this, "--sbb-tooltip-animation-duration");
426
409
  }
@@ -430,11 +413,7 @@ let SbbTooltipElement = (() => {
430
413
  }
431
414
  render() {
432
415
  return html`
433
- <div
434
- @animationend=${this._onTooltipAnimationEnd}
435
- class="sbb-tooltip"
436
- ${ref((el) => this.overlay = el)}
437
- >
416
+ <div class="sbb-tooltip">
438
417
  <slot></slot>
439
418
  </div>
440
419
  `;
@@ -470,4 +449,4 @@ let SbbTooltipElement = (() => {
470
449
  export {
471
450
  SbbTooltipElement
472
451
  };
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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"}
452
+ //# 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';\n\nimport { SbbOpenCloseBaseElement } from '../core/base-elements.js';\nimport { readConfig } from '../core/config.js';\nimport {\n  SbbEscapableOverlayController,\n  SbbOverlayPositionController,\n} 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 { sbbOverlayOutsidePointerEventListener } from '../core/overlay.js';\n\nimport style from './tooltip.scss?lit&inline';\n\n/**\n * Defines the default position for the tooltip if this element is used as a trigger.\n */\nexport interface SbbTooltipDefaultPositions {\n  readonly tooltipPositions: string[];\n}\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;\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-overlay-position-area=block-end] - The primary position for the tooltip.\n * @cssprop [--sbb-overlay-position-try-fallbacks=block-end span-inline-end, block-end span-inline-start, block-start, block-start span-inline-end, block-start span-inline-start] -\n * The list of fallback positions, separated by ',', for 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 tooltip 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  private _triggerElement: HTMLElement | null = null;\n  private _triggerAbortController?: AbortController;\n  private _openStateController!: AbortController;\n  private _escapableOverlayController = new SbbEscapableOverlayController(this);\n  private _overlayController = new SbbOverlayPositionController(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    this.addEventListener('animationend', (e) => this._onTooltipAnimationEnd(e), { 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: [\n        'sbb-tooltip',\n        'sbb-tooltip-open-delay',\n        'sbb-tooltip-close-delay',\n        'sbb-tooltip-position',\n      ],\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\n      // Read the positions from the trigger (either from the attribute or the property)\n      const positions = triggerElement.hasAttribute('sbb-tooltip-position')\n        ? triggerElement\n            .getAttribute('sbb-tooltip-position')!\n            .split(',')\n            .map((p) => p.trim())\n        : (triggerElement as unknown as SbbTooltipDefaultPositions).tooltipPositions;\n\n      if (positions && positions.length > 0) {\n        tooltip.style.setProperty('--sbb-overlay-position-area', positions[0]);\n        tooltip.style.setProperty(\n          '--sbb-overlay-position-try-fallbacks',\n          positions.slice(1).join(', '),\n        );\n      } else {\n        tooltip.style.removeProperty('--sbb-overlay-position-area');\n        tooltip.style.removeProperty('--sbb-overlay-position-try-fallbacks');\n      }\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.trigger ||\n      !this.dispatchBeforeOpenEvent()\n    ) {\n      return;\n    }\n\n    this.showPopover?.();\n    this.state = 'opening';\n    this._overlayController.connect(this.trigger);\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._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    this._overlayController.disconnect();\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 _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 _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 class=\"sbb-tooltip\">\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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"}
package/index.d.ts CHANGED
@@ -65,6 +65,9 @@ import { SbbNavigationListElement } from "./navigation/navigation-list/navigatio
65
65
  import { SbbNavigationLinkElement } from "./navigation/navigation-link/navigation-link.component.js";
66
66
  import { SbbNavigationButtonElement } from "./navigation/navigation-button/navigation-button.component.js";
67
67
  import { SbbNavigationElement } from "./navigation/navigation/navigation.component.js";
68
+ import { SbbMiniCalendarMonthElement } from "./mini-calendar/mini-calendar-month/mini-calendar-month.component.js";
69
+ import { SbbMiniCalendarDayElement } from "./mini-calendar/mini-calendar-day/mini-calendar-day.component.js";
70
+ import { SbbMiniCalendarElement } from "./mini-calendar/mini-calendar/mini-calendar.component.js";
68
71
  import { SbbMessageElement } from "./message/message.component.js";
69
72
  import { SbbMenuLinkElement } from "./menu/menu-link/menu-link.component.js";
70
73
  import { SbbMenuButtonElement } from "./menu/menu-button/menu-button.component.js";
@@ -250,6 +253,9 @@ declare global {
250
253
  var SbbMessageElement: SbbMessageElement;
251
254
  var SbbMiniButtonElement: SbbMiniButtonElement;
252
255
  var SbbMiniButtonGroupElement: SbbMiniButtonGroupElement;
256
+ var SbbMiniCalendarDayElement: SbbMiniCalendarDayElement;
257
+ var SbbMiniCalendarElement: SbbMiniCalendarElement;
258
+ var SbbMiniCalendarMonthElement: SbbMiniCalendarMonthElement;
253
259
  var SbbNavigationButtonElement: SbbNavigationButtonElement;
254
260
  var SbbNavigationElement: SbbNavigationElement;
255
261
  var SbbNavigationLinkElement: SbbNavigationLinkElement;
package/index.js CHANGED
@@ -65,6 +65,9 @@ import { SbbNavigationListElement } from "./navigation/navigation-list/navigatio
65
65
  import { SbbNavigationLinkElement } from "./navigation/navigation-link/navigation-link.component.js";
66
66
  import { SbbNavigationButtonElement } from "./navigation/navigation-button/navigation-button.component.js";
67
67
  import { SbbNavigationElement } from "./navigation/navigation/navigation.component.js";
68
+ import { SbbMiniCalendarMonthElement } from "./mini-calendar/mini-calendar-month/mini-calendar-month.component.js";
69
+ import { SbbMiniCalendarDayElement } from "./mini-calendar/mini-calendar-day/mini-calendar-day.component.js";
70
+ import { SbbMiniCalendarElement } from "./mini-calendar/mini-calendar/mini-calendar.component.js";
68
71
  import { SbbMessageElement } from "./message/message.component.js";
69
72
  import { SbbMenuLinkElement } from "./menu/menu-link/menu-link.component.js";
70
73
  import { SbbMenuButtonElement } from "./menu/menu-button/menu-button.component.js";
@@ -249,6 +252,9 @@ globalThis.SbbMenuLinkElement = SbbMenuLinkElement;
249
252
  globalThis.SbbMessageElement = SbbMessageElement;
250
253
  globalThis.SbbMiniButtonElement = SbbMiniButtonElement;
251
254
  globalThis.SbbMiniButtonGroupElement = SbbMiniButtonGroupElement;
255
+ globalThis.SbbMiniCalendarDayElement = SbbMiniCalendarDayElement;
256
+ globalThis.SbbMiniCalendarElement = SbbMiniCalendarElement;
257
+ globalThis.SbbMiniCalendarMonthElement = SbbMiniCalendarMonthElement;
252
258
  globalThis.SbbNavigationButtonElement = SbbNavigationButtonElement;
253
259
  globalThis.SbbNavigationElement = SbbNavigationElement;
254
260
  globalThis.SbbNavigationLinkElement = SbbNavigationLinkElement;
@@ -0,0 +1,35 @@
1
+ import { CSSResultGroup, TemplateResult, LitElement } from 'lit';
2
+ import { SbbOrientation } from '../../core/interfaces.js';
3
+ /**
4
+ * It displays a minimal calendar, together with the `sbb-mini-calendar-month` and `sbb-mini-calendar-day`.
5
+ *
6
+ * @slot - Use the unnamed slot to add `sbb-mini-calendar-month` elements.
7
+ */
8
+ export declare class SbbMiniCalendarElement<T = Date> extends LitElement {
9
+ static styles: CSSResultGroup;
10
+ /** The orientation of days in the calendar. */
11
+ accessor orientation: SbbOrientation;
12
+ private _keydownAbortController;
13
+ private _dateAdapter;
14
+ constructor();
15
+ private _getMiniCalendarMonths;
16
+ private _getMiniCalendarDays;
17
+ private _setMonthsShowYear;
18
+ private _handleKeydownCalendarDay;
19
+ private _navigateByKeyboardDayView;
20
+ private _findDayArrowKeys;
21
+ private _findDaySpecialKeys;
22
+ private _handleSlotchange;
23
+ private _setupKeydownListener;
24
+ /** @internal */
25
+ focus(): void;
26
+ connectedCallback(): void;
27
+ disconnectedCallback(): void;
28
+ protected render(): TemplateResult;
29
+ }
30
+ declare global {
31
+ interface HTMLElementTagNameMap {
32
+ 'sbb-mini-calendar': SbbMiniCalendarElement;
33
+ }
34
+ }
35
+ //# sourceMappingURL=mini-calendar.component.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mini-calendar.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/mini-calendar/mini-calendar/mini-calendar.component.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AAOvC,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAM/D;;;;GAIG;AACH,qBAEM,sBAAsB,CAAC,CAAC,GAAG,IAAI,CAAE,SAAQ,UAAU;IACvD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,+CAA+C;IAC/C,SACgB,WAAW,EAAE,cAAc,CAAgB;IAE3D,OAAO,CAAC,uBAAuB,CAAgC;IAC/D,OAAO,CAAC,YAAY,CAA4E;;IAahG,OAAO,CAAC,sBAAsB;IAI9B,OAAO,CAAC,oBAAoB;IAQ5B,OAAO,CAAC,kBAAkB;IAe1B,OAAO,CAAC,yBAAyB;IAgBjC,OAAO,CAAC,0BAA0B;IAwDlC,OAAO,CAAC,iBAAiB;IAiBzB,OAAO,CAAC,mBAAmB;IAkB3B,OAAO,CAAC,iBAAiB;IAIzB,OAAO,CAAC,qBAAqB;IAa7B,gBAAgB;IACA,KAAK,IAAI,IAAI;IAMb,iBAAiB,IAAI,IAAI;IAKzB,oBAAoB,IAAI,IAAI;cAKzB,MAAM,IAAI,cAAc;CAO5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,mBAAmB,EAAE,sBAAsB,CAAC;KAC7C;CACF"}
@@ -0,0 +1,133 @@
1
+ var A = (a) => {
2
+ throw TypeError(a);
3
+ };
4
+ var C = (a, i, o) => i.has(a) || A("Cannot " + o);
5
+ var k = (a, i, o) => (C(a, i, "read from private field"), o ? o.call(a) : i.get(a)), S = (a, i, o) => i.has(a) ? A("Cannot add the same private member more than once") : i instanceof WeakSet ? i.add(a) : i.set(a, o), y = (a, i, o, d) => (C(a, i, "write to private field"), d ? d.call(a, o) : i.set(a, o), o);
6
+ import { __esDecorate as K, __runInitializers as w } from "tslib";
7
+ import { MutationController as M } from "@lit-labs/observers/mutation-controller.js";
8
+ import { css as x, LitElement as z, html as I } from "lit";
9
+ import { customElement as v, property as E } from "lit/decorators.js";
10
+ import { isArrowKeyOrPageKeysPressed as O } from "../../core/a11y.js";
11
+ import { readConfig as L } from "../../core/config/config.js";
12
+ import { defaultDateAdapter as N } from "../../core/datetime/native-date-adapter.js";
13
+ const P = x`*,:before,:after{box-sizing:border-box}:host{display:block}`;
14
+ let H = (() => {
15
+ var u, f;
16
+ let a = [v("sbb-mini-calendar")], i, o = [], d, D = z, b, m = [], g = [];
17
+ return f = class extends D {
18
+ constructor() {
19
+ super();
20
+ S(this, u);
21
+ y(this, u, w(this, m, "horizontal")), this._keydownAbortController = (w(this, g), null), this._dateAdapter = L().datetime?.dateAdapter ?? N, this.addController(new M(this, {
22
+ config: { childList: !0, subtree: !0 },
23
+ callback: () => this._setMonthsShowYear()
24
+ }));
25
+ }
26
+ /** The orientation of days in the calendar. */
27
+ get orientation() {
28
+ return k(this, u);
29
+ }
30
+ set orientation(t) {
31
+ y(this, u, t);
32
+ }
33
+ _getMiniCalendarMonths() {
34
+ return Array.from(this.querySelectorAll?.("sbb-mini-calendar-month") ?? []);
35
+ }
36
+ _getMiniCalendarDays() {
37
+ return Array.from(this._getMiniCalendarMonths().flatMap((t) => Array.from(t.querySelectorAll?.("sbb-mini-calendar-day") ?? [])));
38
+ }
39
+ _setMonthsShowYear() {
40
+ this._getMiniCalendarMonths().forEach((t, e) => {
41
+ const s = t.date.split("-");
42
+ s.length > 0 && (e === 0 || +s[1] == 1 ? t.toggleState("show-year", !0) : t.toggleState("show-year", !1));
43
+ });
44
+ }
45
+ _handleKeydownCalendarDay(t) {
46
+ O(t) && t.preventDefault();
47
+ const e = this._getMiniCalendarDays(), s = e.find((n) => n === t.target), r = this._navigateByKeyboardDayView(e, s, t), c = document.activeElement;
48
+ r !== c && (r.tabIndex = 0, r?.focus(), c.tabIndex = -1);
49
+ }
50
+ _navigateByKeyboardDayView(t, e, s) {
51
+ const r = this.orientation === "horizontal" ? { leftRight: 1, upDown: 7 } : { leftRight: 7, upDown: 1 }, c = this._dateAdapter.parse(e.date), n = this._dateAdapter.getDate(c), h = this._dateAdapter.getFirstWeekOffset(c);
52
+ switch (s.key) {
53
+ case "ArrowUp":
54
+ return this._findDayArrowKeys(t, e, -r.upDown);
55
+ case "ArrowDown":
56
+ return this._findDayArrowKeys(t, e, r.upDown);
57
+ case "ArrowLeft":
58
+ return this._findDayArrowKeys(t, e, -r.leftRight);
59
+ case "ArrowRight":
60
+ return this._findDayArrowKeys(t, e, r.leftRight);
61
+ case "PageUp":
62
+ if (this.orientation === "horizontal") {
63
+ const l = n - (n % 7 || 7);
64
+ return this._findDaySpecialKeys(t, e, -l, r.upDown);
65
+ } else {
66
+ const p = (Math.ceil((n + h) / 7) - 1) * 7 - h + 1 - n;
67
+ return this._findDaySpecialKeys(t, e, p, r.upDown);
68
+ }
69
+ case "PageDown":
70
+ if (this.orientation === "horizontal") {
71
+ const l = this._dateAdapter.getNumDaysInMonth(c), _ = l - n - (l - n) % 7;
72
+ return this._findDaySpecialKeys(t, e, _, -r.upDown);
73
+ } else {
74
+ const p = Math.ceil((n + h) / 7) * 7 - h - n;
75
+ return this._findDaySpecialKeys(t, e, p, -r.upDown);
76
+ }
77
+ case "Home": {
78
+ const l = n - 1;
79
+ return this._findDaySpecialKeys(t, e, -l, 1);
80
+ }
81
+ case "End": {
82
+ const l = this._dateAdapter.getNumDaysInMonth(c);
83
+ return this._findDaySpecialKeys(t, e, l - n, -1);
84
+ }
85
+ default:
86
+ return e;
87
+ }
88
+ }
89
+ _findDayArrowKeys(t, e, s) {
90
+ const r = this._dateAdapter.addCalendarDays(this._dateAdapter.deserialize(e.date), s), c = this._dateAdapter.toIso8601(r), n = t.find((h) => h.date === c);
91
+ return n || e;
92
+ }
93
+ _findDaySpecialKeys(t, e, s, r) {
94
+ const c = this._dateAdapter.addCalendarDays(this._dateAdapter.deserialize(e.date), s), n = this._dateAdapter.toIso8601(c), h = t.find((l) => l.date === n);
95
+ return h || this._findDaySpecialKeys(t, e, s + r, r);
96
+ }
97
+ _handleSlotchange() {
98
+ this._setupKeydownListener();
99
+ }
100
+ _setupKeydownListener() {
101
+ this._keydownAbortController?.abort(), this._keydownAbortController = new AbortController(), this._getMiniCalendarDays().forEach((t, e) => {
102
+ t.addEventListener("keydown", (s) => this._handleKeydownCalendarDay(s), {
103
+ signal: this._keydownAbortController.signal
104
+ }), e !== 0 && (t.tabIndex = -1);
105
+ });
106
+ }
107
+ /** @internal */
108
+ focus() {
109
+ this._getMiniCalendarDays()?.find((t) => t.tabIndex === 0)?.focus();
110
+ }
111
+ connectedCallback() {
112
+ super.connectedCallback(), this._setupKeydownListener();
113
+ }
114
+ disconnectedCallback() {
115
+ super.disconnectedCallback(), this._keydownAbortController?.abort();
116
+ }
117
+ render() {
118
+ return I`
119
+ <div class="sbb-mini-calendar">
120
+ <slot @slotchange=${this._handleSlotchange}></slot>
121
+ </div>
122
+ `;
123
+ }
124
+ }, u = new WeakMap(), d = f, (() => {
125
+ const t = typeof Symbol == "function" && Symbol.metadata ? Object.create(D[Symbol.metadata] ?? null) : void 0;
126
+ b = [E({ reflect: !0 })], K(f, null, b, { kind: "accessor", name: "orientation", static: !1, private: !1, access: { has: (e) => "orientation" in e, get: (e) => e.orientation, set: (e, s) => {
127
+ e.orientation = s;
128
+ } }, metadata: t }, m, g), K(null, i = { value: d }, a, { kind: "class", name: d.name, metadata: t }, null, o), d = i.value, t && Object.defineProperty(d, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: t });
129
+ })(), f.styles = P, w(d, o), d;
130
+ })();
131
+ export {
132
+ H as SbbMiniCalendarElement
133
+ };
@@ -0,0 +1,23 @@
1
+ import { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';
2
+ import { SbbButtonBaseElement } from '../../core/base-elements.js';
3
+ /**
4
+ * It displays a day in the `sbb-mini-calendar-month`.
5
+ */
6
+ export declare class SbbMiniCalendarDayElement<T = Date> extends SbbButtonBaseElement {
7
+ static styles: CSSResultGroup;
8
+ private _dateAdapter;
9
+ /** Date as ISO string (YYYY-MM-DD) */
10
+ accessor date: string;
11
+ /** The type of the marker. */
12
+ accessor marker: 'target' | 'circle' | 'slash' | 'cross' | string;
13
+ /** The color of the marker. */
14
+ accessor color: 'charcoal' | 'cloud' | 'orange' | 'red' | 'sky' | string;
15
+ protected willUpdate(changedProperties: PropertyValues<this>): void;
16
+ protected renderTemplate(): TemplateResult;
17
+ }
18
+ declare global {
19
+ interface HTMLElementTagNameMap {
20
+ 'sbb-mini-calendar-day': SbbMiniCalendarDayElement;
21
+ }
22
+ }
23
+ //# sourceMappingURL=mini-calendar-day.component.d.ts.map