@sbb-esta/lyne-elements-dev 5.0.0-next-dev.1776724490 → 5.0.0-next-dev.1776756036
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/core/overlay/overlay-trigger-attributes.js +3 -3
- package/core.js +2 -2
- package/custom-elements.json +13 -13
- package/datepicker/datepicker/datepicker.component.js +1 -1
- package/{datepicker.component-BBmEvmW3.js → datepicker.component-CNQGkdr-.js} +11 -11
- package/datepicker.js +1 -1
- package/datepicker.pure.js +1 -1
- package/development/core/overlay/overlay-trigger-attributes.d.ts +4 -4
- package/development/core/overlay/overlay-trigger-attributes.d.ts.map +1 -1
- package/development/core/overlay/overlay-trigger-attributes.js +12 -12
- package/development/core.js +2 -2
- package/development/datepicker/datepicker/datepicker.component.d.ts.map +1 -1
- package/development/datepicker/datepicker/datepicker.component.js +1 -1
- package/development/datepicker.component-Chnvwnp7.js +212 -0
- package/development/datepicker.js +1 -1
- package/development/datepicker.pure.js +1 -1
- package/development/dialog/dialog/dialog.component.d.ts +0 -1
- package/development/dialog/dialog/dialog.component.d.ts.map +1 -1
- package/development/dialog/dialog/dialog.component.js +1 -1
- package/development/{dialog.component-BYVTZAUU.js → dialog.component-B4cZfRCl.js} +1 -6
- package/development/dialog.js +1 -1
- package/development/dialog.pure.js +1 -1
- package/development/header/header/header.component.d.ts.map +1 -1
- package/development/header/header/header.component.js +1 -1
- package/development/{header.component-Hfgz9sSb.js → header.component-B2T2pmHs.js} +2 -3
- package/development/header.js +1 -1
- package/development/header.pure.js +1 -1
- package/development/menu/common/menu-action-common.js +1 -1
- package/development/menu/menu/menu.component.d.ts.map +1 -1
- package/development/menu/menu/menu.component.js +1 -1
- package/development/menu-action-common-CEnwq60Z.js +32 -0
- package/development/menu.component-BM7hhOb4.js +365 -0
- package/development/menu.js +2 -2
- package/development/menu.pure.js +2 -2
- package/development/navigation/navigation/navigation.component.d.ts.map +1 -1
- package/development/navigation/navigation/navigation.component.js +1 -1
- package/development/navigation/navigation-section/navigation-section.component.d.ts.map +1 -1
- package/development/navigation/navigation-section/navigation-section.component.js +1 -1
- package/development/{navigation-section.component-C_9myQKr.js → navigation-section.component-6tqZADWM.js} +6 -8
- package/development/{navigation.component-C8MhqBLY.js → navigation.component-DUy2QGHI.js} +6 -8
- package/development/navigation.js +2 -2
- package/development/navigation.pure.js +2 -2
- package/development/overlay/overlay-base-element.d.ts.map +1 -1
- package/development/overlay/overlay-base-element.js +6 -6
- package/development/overlay/overlay.component.d.ts +0 -1
- package/development/overlay/overlay.component.d.ts.map +1 -1
- package/development/overlay/overlay.component.js +1 -1
- package/development/{overlay.component-BuCkqG6Q.js → overlay.component-CA0fWX47.js} +1 -6
- package/development/overlay.js +1 -1
- package/development/overlay.pure.js +1 -1
- package/development/popover/popover.component.d.ts.map +1 -1
- package/development/popover/popover.component.js +1 -1
- package/development/popover.component-B1gMzBuv.js +527 -0
- package/development/popover.js +1 -1
- package/development/popover.pure.js +1 -1
- package/development/{step-label.component-CxqPgbzK.js → step-label.component-B7M9Yqyz.js} +1 -3
- package/development/{step.component-B2qbHl0l.js → step.component-CVWxYkrv.js} +1 -3
- package/development/stepper/step/step.component.d.ts.map +1 -1
- package/development/stepper/step/step.component.js +1 -1
- package/development/stepper/step-label/step-label.component.d.ts.map +1 -1
- package/development/stepper/step-label/step-label.component.js +1 -1
- package/development/stepper.js +2 -2
- package/development/stepper.pure.js +2 -2
- package/development/{tab.component-DteuwiHv.js → tab.component-CvzGdR9_.js} +1 -3
- package/development/tabs/tab/tab.component.d.ts.map +1 -1
- package/development/tabs/tab/tab.component.js +1 -1
- package/development/tabs.js +1 -1
- package/development/tabs.pure.js +1 -1
- package/development/tooltip/tooltip.component.d.ts.map +1 -1
- package/development/tooltip/tooltip.component.js +1 -1
- package/development/tooltip.component-lvElko6C.js +369 -0
- package/development/tooltip.js +1 -1
- package/development/tooltip.pure.js +1 -1
- package/dialog/dialog/dialog.component.js +1 -1
- package/{dialog.component-ca14M0hZ.js → dialog.component-DTbAHlVd.js} +7 -10
- package/dialog.js +1 -1
- package/dialog.pure.js +1 -1
- package/header/header/header.component.js +1 -1
- package/{header.component-BxizSy1O.js → header.component-D-WVEMFn.js} +2 -2
- package/header.js +1 -1
- package/header.pure.js +1 -1
- package/menu/common/menu-action-common.js +1 -1
- package/menu/menu/menu.component.js +1 -1
- package/{menu-action-common-DY4RrfCy.js → menu-action-common-krzD_Ca2.js} +1 -1
- package/{menu.component-XvtyRok7.js → menu.component-i-X_ag2Y.js} +14 -14
- package/menu.js +2 -2
- package/menu.pure.js +2 -2
- package/navigation/navigation/navigation.component.js +1 -1
- package/navigation/navigation-section/navigation-section.component.js +1 -1
- package/{navigation-section.component-CLcdmPV3.js → navigation-section.component-Db2MWBDn.js} +17 -17
- package/{navigation.component-Cnyb5_4R.js → navigation.component-Bym1kjzt.js} +16 -16
- package/navigation.js +2 -2
- package/navigation.pure.js +2 -2
- package/overlay/overlay-base-element.js +4 -4
- package/overlay/overlay.component.js +1 -1
- package/{overlay.component-OzDUV8t1.js → overlay.component-BydJOM2r.js} +10 -13
- package/overlay.js +1 -1
- package/overlay.pure.js +1 -1
- package/package.json +2 -2
- package/popover/popover.component.js +1 -1
- package/{popover.component-BfSXNxKK.js → popover.component-Dd4rKGml.js} +12 -12
- package/popover.js +1 -1
- package/popover.pure.js +1 -1
- package/{step-label.component-qdfunibJ.js → step-label.component-BXg13qOD.js} +3 -3
- package/{step.component-aBAfTJyO.js → step.component-sQbJslHx.js} +3 -3
- package/stepper/step/step.component.js +1 -1
- package/stepper/step-label/step-label.component.js +1 -1
- package/stepper.js +2 -2
- package/stepper.pure.js +2 -2
- package/{tab.component-DGzqld4u.js → tab.component-D39b0S04.js} +3 -3
- package/tabs/tab/tab.component.js +1 -1
- package/tabs.js +1 -1
- package/tabs.pure.js +1 -1
- package/tooltip/tooltip.component.js +1 -1
- package/{tooltip.component-C5y6zCtF.js → tooltip.component-Do4V1jGd.js} +12 -12
- package/tooltip.js +1 -1
- package/tooltip.pure.js +1 -1
- package/development/datepicker.component-AKlc7SAO.js +0 -214
- package/development/menu-action-common-Crx-dDgH.js +0 -32
- package/development/menu.component-DOv7PKIi.js +0 -367
- package/development/popover.component-B15jFLe9.js +0 -529
- package/development/tooltip.component-BtWTK2R0.js +0 -371
|
@@ -0,0 +1,527 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
import { html, isServer, nothing, unsafeCSS } from "lit";
|
|
3
|
+
import { property } from "lit/decorators.js";
|
|
4
|
+
import { IS_FOCUSABLE_QUERY, SbbEscapableOverlayController, SbbFocusTrapController, SbbLanguageController, SbbMediaQueryPointerCoarse, SbbOpenCloseBaseElement, boxSizingStyles, composedPathHasAttribute, forceType, getElementPosition, i18nClosePopover, idReference, isEventOnElement, isFakeMousedownFromScreenReader, isZeroAnimationDuration, readConfig, removeAriaOverlayTriggerProperties, sbbInputModalityDetector, setAriaOverlayTriggerProperties, ɵstateController } from "./core.js";
|
|
5
|
+
import { SbbSecondaryButtonElement } from "./button.pure.js";
|
|
6
|
+
import { ref } from "lit/directives/ref.js";
|
|
7
|
+
//#region src/elements/popover/popover.scss?inline
|
|
8
|
+
var popover_default = ":host {\n --sbb-focus-outline-color: var(--sbb-focus-outline-color-default);\n --sbb-focus-outline-color: light-dark(\n var(--sbb-focus-outline-color-default),\n var(--sbb-focus-outline-color-dark)\n );\n --sbb-popover-animation-duration: var(\n --sbb-disable-animation-duration,\n var(--sbb-animation-duration-4x)\n );\n --_sbb-popover-inset: 0 auto auto 0;\n --_sbb-popover-transform: translateY(var(--sbb-spacing-fixed-2x));\n outline: none !important;\n display: none;\n}\n\n:host(:is(:is(:state(state-opening),[state--state-opening]), :is(:state(state-opened),[state--state-opened]), :is(:state(state-closing),[state--state-closing]))) {\n --_sbb-popover-inset: 0;\n display: block;\n}\n\n:host(:is(:state(position-above),[state--position-above])) {\n --_sbb-popover-transform: translateY(calc(var(--sbb-spacing-fixed-2x) * -1));\n}\n\n:host(:not([hide-close-button], :is(:state(hover-trigger),[state--hover-trigger]))) {\n --sbb-popover-min-height: calc(var(--sbb-size-element-xs) + 2 * var(--sbb-popover-padding));\n}\n\n.sbb-popover::after,\n.sbb-popover__content::before {\n content: \"\";\n position: absolute;\n display: block;\n width: var(--sbb-popover-arrow-size);\n height: var(--sbb-popover-arrow-size);\n left: var(--_sbb-popover-arrow-position-x, 0);\n bottom: calc(100% - var(--sbb-popover-arrow-size) / 2);\n background-color: var(--sbb-popover-background);\n border-radius: var(--sbb-border-radius-2x) 0;\n transform: rotate(45deg);\n}\n\n.sbb-popover__container {\n position: fixed;\n inset: var(--_sbb-popover-inset);\n pointer-events: none;\n z-index: var(--sbb-popover-z-index, var(--sbb-overlay-default-z-index));\n}\n\n.sbb-popover {\n box-shadow: var(--sbb-box-shadow-level-5-hard);\n display: none;\n position: var(--sbb-popover-position, absolute);\n pointer-events: all;\n top: var(--_sbb-popover-position-y, 0);\n bottom: unset;\n left: var(--_sbb-popover-position-x, 0);\n right: unset;\n border: none;\n border-radius: var(--sbb-popover-border-radius);\n padding: 0;\n max-width: var(--sbb-popover-max-width);\n width: max-content;\n background-color: var(--sbb-popover-background);\n outline: none;\n}\n:host(:focus-visible) .sbb-popover {\n outline-offset: var(--sbb-focus-outline-offset);\n outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);\n}\n:host(:is(:is(:state(state-opening),[state--state-opening]), :is(:state(state-opened),[state--state-opened]), :is(:state(state-closing),[state--state-closing]))) .sbb-popover {\n display: block;\n animation-name: open;\n animation-duration: var(--sbb-popover-animation-duration);\n animation-timing-function: var(--sbb-popover-animation-easing);\n}\n:host(:is(:state(state-closing),[state--state-closing])) .sbb-popover {\n pointer-events: none;\n animation-name: close;\n animation-duration: var(--sbb-popover-animation-duration);\n animation-timing-function: var(--sbb-popover-animation-easing);\n}\n.sbb-popover::after {\n z-index: -1;\n box-shadow: var(--sbb-box-shadow-level-5-hard);\n}\n@media (forced-colors: active) {\n .sbb-popover::after {\n outline: var(--sbb-border-width-1x) solid CanvasText;\n }\n}\n:host(:is(:state(position-above),[state--position-above])) .sbb-popover::after {\n top: calc(100% - var(--sbb-popover-arrow-size) / 2);\n}\n@media (forced-colors: active) {\n .sbb-popover {\n outline: var(--sbb-border-width-1x) solid CanvasText;\n }\n}\n.sbb-popover::before {\n content: \"\";\n display: block;\n position: absolute;\n inset: 0;\n z-index: -1;\n background-color: transparent;\n}\n:host(:is(:state(position-below),[state--position-below])) .sbb-popover::before {\n inset-block-start: calc(-1 * var(--sbb-spacing-fixed-6x));\n}\n:host(:is(:state(position-above),[state--position-above])) .sbb-popover::before {\n inset-block-end: calc(-1 * var(--sbb-spacing-fixed-6x));\n}\n\n.sbb-popover__content {\n display: flex;\n gap: var(--sbb-spacing-fixed-4x);\n border-radius: var(--sbb-popover-border-radius);\n padding-block: var(--sbb-popover-padding) 0;\n padding-inline: var(--sbb-popover-padding);\n outline: none;\n background-color: var(--sbb-popover-background);\n flex-direction: row-reverse;\n min-height: var(--sbb-popover-min-height);\n}\n:host(:is(:state(position-above),[state--position-above])) .sbb-popover__content::before {\n top: calc(100% - var(--sbb-popover-arrow-size) / 2);\n}\n\n.sbb-popover__scrollable-content {\n --sbb-scrollbar-thumb-width: 0.125rem;\n --sbb-scrollbar-thumb-width-hover: 0.25rem;\n --sbb-scrollbar-width-firefox: thin;\n --sbb-scrollbar-color: color-mix(in srgb, var(--sbb-color-black) 30%, transparent);\n --sbb-scrollbar-color: light-dark(\n color-mix(in srgb, var(--sbb-color-black) 30%, transparent),\n color-mix(in srgb, var(--sbb-color-white) 30%, transparent)\n );\n --sbb-scrollbar-color-hover: color-mix(in srgb, var(--sbb-color-black) 60%, transparent);\n --sbb-scrollbar-color-hover: light-dark(\n color-mix(in srgb, var(--sbb-color-black) 60%, transparent),\n color-mix(in srgb, var(--sbb-color-white) 60%, transparent)\n );\n --sbb-scrollbar-track-color: transparent;\n --sbb-scrollbar-width: var(--sbb-spacing-fixed-3x);\n}\n.sbb-popover__scrollable-content::-webkit-scrollbar {\n width: var(--sbb-scrollbar-width);\n height: var(--sbb-scrollbar-width);\n background-color: var(--sbb-scrollbar-track-color, transparent);\n}\n.sbb-popover__scrollable-content::-webkit-scrollbar-corner {\n background-color: var(--sbb-scrollbar-track-color, transparent);\n}\n.sbb-popover__scrollable-content::-webkit-scrollbar-thumb {\n background-color: var(--sbb-scrollbar-color, currentcolor);\n border: calc(0.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width))) solid transparent;\n border-radius: var(--sbb-border-radius-4x);\n background-clip: padding-box;\n}\n.sbb-popover__scrollable-content::-webkit-scrollbar-thumb:hover {\n background-color: var(--sbb-scrollbar-color-hover, currentcolor);\n border-width: calc(0.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width-hover)));\n}\n.sbb-popover__scrollable-content::-webkit-scrollbar-button, .sbb-popover__scrollable-content::-webkit-scrollbar-corner {\n display: none;\n}\n@supports not selector(::-webkit-scrollbar) {\n .sbb-popover__scrollable-content {\n scrollbar-width: var(--sbb-scrollbar-width-firefox);\n scrollbar-color: var(--sbb-scrollbar-color, currentcolor) var(--sbb-scrollbar-track-color, transparent);\n }\n}\n.sbb-popover__scrollable-content {\n display: block;\n padding-block-end: var(--sbb-popover-padding);\n max-height: calc(var(--_sbb-popover-max-height));\n overflow: auto;\n}\n\n@keyframes open {\n from {\n opacity: 0;\n transform: var(--_sbb-popover-transform);\n }\n to {\n opacity: 1;\n transform: translateY(0);\n }\n}\n@keyframes close {\n from {\n opacity: 1;\n transform: translateY(0);\n }\n to {\n opacity: 0;\n transform: var(--_sbb-popover-transform);\n }\n}";
|
|
9
|
+
//#endregion
|
|
10
|
+
//#region src/elements/popover/popover.component.ts
|
|
11
|
+
var VERTICAL_OFFSET = 16;
|
|
12
|
+
var HORIZONTAL_OFFSET = 32;
|
|
13
|
+
var popoversRef = /* @__PURE__ */ new Set();
|
|
14
|
+
var pointerCoarse = isServer ? false : matchMedia(SbbMediaQueryPointerCoarse).matches;
|
|
15
|
+
var SbbPopoverBaseElement = (() => {
|
|
16
|
+
let _classSuper = SbbOpenCloseBaseElement;
|
|
17
|
+
let _trigger_decorators;
|
|
18
|
+
let _trigger_initializers = [];
|
|
19
|
+
let _trigger_extraInitializers = [];
|
|
20
|
+
return class SbbPopoverBaseElement extends _classSuper {
|
|
21
|
+
constructor() {
|
|
22
|
+
super(...arguments);
|
|
23
|
+
this.#trigger_accessor_storage = __runInitializers(this, _trigger_initializers, null);
|
|
24
|
+
this._nextFocusedElement = __runInitializers(this, _trigger_extraInitializers);
|
|
25
|
+
this._skipCloseFocus = false;
|
|
26
|
+
this._escapableOverlayController = new SbbEscapableOverlayController(this);
|
|
27
|
+
this._focusTrapController = new SbbFocusTrapController(this);
|
|
28
|
+
this._blurTimeout = null;
|
|
29
|
+
this._pointerDownListener = (event) => {
|
|
30
|
+
this._isPointerDownEventOnPopover = isEventOnElement(this.overlay, event);
|
|
31
|
+
};
|
|
32
|
+
this._closeOnBackdropClick = (event) => {
|
|
33
|
+
const composedPath = event.composedPath();
|
|
34
|
+
if (!this._isPointerDownEventOnPopover && !isEventOnElement(this.overlay, event) && (!this.trigger || !composedPath.includes(this.trigger))) {
|
|
35
|
+
this._nextFocusedElement = composedPath.filter((el) => el instanceof window.HTMLElement).find((el) => el.matches(IS_FOCUSABLE_QUERY));
|
|
36
|
+
clearTimeout(this.closeTimeout);
|
|
37
|
+
this.close();
|
|
38
|
+
}
|
|
39
|
+
};
|
|
40
|
+
}
|
|
41
|
+
static {
|
|
42
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
43
|
+
_trigger_decorators = [idReference(), property()];
|
|
44
|
+
__esDecorate(this, null, _trigger_decorators, {
|
|
45
|
+
kind: "accessor",
|
|
46
|
+
name: "trigger",
|
|
47
|
+
static: false,
|
|
48
|
+
private: false,
|
|
49
|
+
access: {
|
|
50
|
+
has: (obj) => "trigger" in obj,
|
|
51
|
+
get: (obj) => obj.trigger,
|
|
52
|
+
set: (obj, value) => {
|
|
53
|
+
obj.trigger = value;
|
|
54
|
+
}
|
|
55
|
+
},
|
|
56
|
+
metadata: _metadata
|
|
57
|
+
}, _trigger_initializers, _trigger_extraInitializers);
|
|
58
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, {
|
|
59
|
+
enumerable: true,
|
|
60
|
+
configurable: true,
|
|
61
|
+
writable: true,
|
|
62
|
+
value: _metadata
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
static {
|
|
66
|
+
this.styles = [boxSizingStyles, unsafeCSS(popover_default)];
|
|
67
|
+
}
|
|
68
|
+
#trigger_accessor_storage;
|
|
69
|
+
/**
|
|
70
|
+
* The element that will trigger the popover overlay.
|
|
71
|
+
*
|
|
72
|
+
* For attribute usage, provide an id reference.
|
|
73
|
+
*/
|
|
74
|
+
get trigger() {
|
|
75
|
+
return this.#trigger_accessor_storage;
|
|
76
|
+
}
|
|
77
|
+
set trigger(value) {
|
|
78
|
+
this.#trigger_accessor_storage = value;
|
|
79
|
+
}
|
|
80
|
+
/** Opens the popover on trigger click. */
|
|
81
|
+
open() {
|
|
82
|
+
if (this.state !== "closed" && this.state !== "closing" || !this.overlay || !this.dispatchBeforeOpenEvent()) return;
|
|
83
|
+
for (const popover of popoversRef) if (popover.state === "opened" || popover.state === "opening") popover.close();
|
|
84
|
+
this.showPopover?.();
|
|
85
|
+
this.state = "opening";
|
|
86
|
+
this.inert = true;
|
|
87
|
+
this._setPopoverPosition();
|
|
88
|
+
this._attachWindowEvents();
|
|
89
|
+
this._escapableOverlayController.connect();
|
|
90
|
+
this._nextFocusedElement = void 0;
|
|
91
|
+
this._skipCloseFocus = false;
|
|
92
|
+
if (this._triggerElement) this._triggerElement.ariaExpanded = "true";
|
|
93
|
+
if (this._isZeroAnimationDuration()) this._handleOpening();
|
|
94
|
+
}
|
|
95
|
+
/** Closes the popover. */
|
|
96
|
+
close(target) {
|
|
97
|
+
if (this.state !== "opened" && this.state !== "opening") return;
|
|
98
|
+
this._popoverCloseElement = target;
|
|
99
|
+
if (!this.dispatchBeforeCloseEvent({ closeTarget: target ?? null })) return;
|
|
100
|
+
this.state = "closing";
|
|
101
|
+
this.inert = true;
|
|
102
|
+
if (this._triggerElement) this._triggerElement.ariaExpanded = "false";
|
|
103
|
+
if (this._isZeroAnimationDuration()) this._handleClosing();
|
|
104
|
+
}
|
|
105
|
+
_isZeroAnimationDuration() {
|
|
106
|
+
return isZeroAnimationDuration(this, "--sbb-popover-animation-duration");
|
|
107
|
+
}
|
|
108
|
+
_handleClosing() {
|
|
109
|
+
this.state = "closed";
|
|
110
|
+
this.hidePopover?.();
|
|
111
|
+
this.overlay?.firstElementChild?.scrollTo(0, 0);
|
|
112
|
+
this.removeAttribute("tabindex");
|
|
113
|
+
if (!this._skipCloseFocus) (this._nextFocusedElement || this._triggerElement)?.focus();
|
|
114
|
+
this._escapableOverlayController.disconnect();
|
|
115
|
+
this._openStateController?.abort();
|
|
116
|
+
this._focusTrapController.enabled = false;
|
|
117
|
+
this.dispatchCloseEvent({ closeTarget: this._popoverCloseElement ?? null });
|
|
118
|
+
}
|
|
119
|
+
_handleOpening() {
|
|
120
|
+
this.state = "opened";
|
|
121
|
+
this.inert = false;
|
|
122
|
+
this._setPopoverFocus();
|
|
123
|
+
this._focusTrapController.enabled = true;
|
|
124
|
+
this.dispatchOpenEvent();
|
|
125
|
+
}
|
|
126
|
+
connectedCallback() {
|
|
127
|
+
this.popover = "manual";
|
|
128
|
+
super.connectedCallback();
|
|
129
|
+
this.state = "closed";
|
|
130
|
+
popoversRef.add(this);
|
|
131
|
+
if (this.hasUpdated) this._configureTrigger();
|
|
132
|
+
}
|
|
133
|
+
requestUpdate(name, oldValue, options) {
|
|
134
|
+
super.requestUpdate(name, oldValue, options);
|
|
135
|
+
if (!isServer && (!name || name === "trigger" || name === "hoverTrigger") && this.hasUpdated) this._configureTrigger();
|
|
136
|
+
}
|
|
137
|
+
firstUpdated(changedProperties) {
|
|
138
|
+
super.firstUpdated(changedProperties);
|
|
139
|
+
this._configureTrigger();
|
|
140
|
+
}
|
|
141
|
+
disconnectedCallback() {
|
|
142
|
+
super.disconnectedCallback();
|
|
143
|
+
this._triggerElement = null;
|
|
144
|
+
this._triggerAbortController?.abort();
|
|
145
|
+
this._openStateController?.abort();
|
|
146
|
+
popoversRef.delete(this);
|
|
147
|
+
if (this._blurTimeout) clearTimeout(this._blurTimeout);
|
|
148
|
+
}
|
|
149
|
+
_configureTrigger() {
|
|
150
|
+
if (isServer) return;
|
|
151
|
+
else if (this.hydrationRequired) {
|
|
152
|
+
this.hydrationComplete.then(() => this._configureTrigger());
|
|
153
|
+
return;
|
|
154
|
+
}
|
|
155
|
+
this.configureTrigger(this._triggerElement ?? null);
|
|
156
|
+
}
|
|
157
|
+
configureTrigger(_oldTrigger) {
|
|
158
|
+
this._triggerAbortController?.abort();
|
|
159
|
+
removeAriaOverlayTriggerProperties(this._triggerElement);
|
|
160
|
+
this._triggerElement = this.trigger;
|
|
161
|
+
if (!this._triggerElement) return;
|
|
162
|
+
setAriaOverlayTriggerProperties(this, this._triggerElement, "dialog", this.state);
|
|
163
|
+
this._triggerAbortController = new AbortController();
|
|
164
|
+
this.registerTriggerListeners(this._triggerAbortController.signal);
|
|
165
|
+
}
|
|
166
|
+
registerTriggerListeners(signal) {
|
|
167
|
+
this._triggerElement.addEventListener("click", () => this.open(), { signal });
|
|
168
|
+
}
|
|
169
|
+
_attachWindowEvents() {
|
|
170
|
+
this._openStateController = new AbortController();
|
|
171
|
+
document.addEventListener("scroll", () => this._setPopoverPosition(), {
|
|
172
|
+
passive: true,
|
|
173
|
+
signal: this._openStateController.signal,
|
|
174
|
+
capture: true
|
|
175
|
+
});
|
|
176
|
+
window.addEventListener("resize", () => this._setPopoverPosition(), {
|
|
177
|
+
passive: true,
|
|
178
|
+
signal: this._openStateController.signal
|
|
179
|
+
});
|
|
180
|
+
window.addEventListener("pointerdown", this._pointerDownListener, { signal: this._openStateController.signal });
|
|
181
|
+
window.addEventListener("pointerup", this._closeOnBackdropClick, { signal: this._openStateController.signal });
|
|
182
|
+
}
|
|
183
|
+
_closeOnSbbPopoverCloseClick(event) {
|
|
184
|
+
const closeElement = composedPathHasAttribute(event, "sbb-popover-close", this);
|
|
185
|
+
if (closeElement && !closeElement.hasAttribute("disabled")) {
|
|
186
|
+
clearTimeout(this.closeTimeout);
|
|
187
|
+
this.close(closeElement);
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
_onPopoverAnimationEnd(event) {
|
|
191
|
+
if (event.animationName === "open" && this.state === "opening") this._handleOpening();
|
|
192
|
+
else if (event.animationName === "close" && this.state === "closing") this._handleClosing();
|
|
193
|
+
}
|
|
194
|
+
_setPopoverFocus() {
|
|
195
|
+
if (!this._focusTrapController.focusInitialElement() && this._openStateController) {
|
|
196
|
+
this.setAttribute("tabindex", "0");
|
|
197
|
+
this.focus();
|
|
198
|
+
this.addEventListener("blur", (e) => {
|
|
199
|
+
this._blurTimeout = setTimeout(() => {
|
|
200
|
+
if (document.visibilityState !== "hidden") {
|
|
201
|
+
this.removeAttribute("tabindex");
|
|
202
|
+
if (this.contains(e.relatedTarget) || e.relatedTarget === this.trigger) return;
|
|
203
|
+
if (this.state === "opened" || this.state === "opening") this._skipCloseFocus = true;
|
|
204
|
+
this.close();
|
|
205
|
+
}
|
|
206
|
+
});
|
|
207
|
+
}, { signal: this._openStateController.signal });
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
_setPopoverPosition() {
|
|
211
|
+
if (!this.overlay || !this._triggerElement) return;
|
|
212
|
+
const popoverPosition = getElementPosition(this.overlay, this._triggerElement, this.shadowRoot.querySelector(".sbb-popover__container"), {
|
|
213
|
+
verticalOffset: VERTICAL_OFFSET,
|
|
214
|
+
horizontalOffset: HORIZONTAL_OFFSET,
|
|
215
|
+
centered: true,
|
|
216
|
+
responsiveHeight: true
|
|
217
|
+
});
|
|
218
|
+
const verticalPosition = popoverPosition.alignment.vertical;
|
|
219
|
+
for (const position of ["above", "below"]) this.toggleState(`position-${position}`, position === verticalPosition);
|
|
220
|
+
const arrowXPosition = this._triggerElement.getBoundingClientRect().left - popoverPosition.left + this._triggerElement.clientWidth / 2 - 8;
|
|
221
|
+
this.style.setProperty("--_sbb-popover-position-x", `${popoverPosition.left}px`);
|
|
222
|
+
this.style.setProperty("--_sbb-popover-position-y", `${popoverPosition.top}px`);
|
|
223
|
+
this.style.setProperty("--_sbb-popover-arrow-position-x", `${arrowXPosition}px`);
|
|
224
|
+
this.style.setProperty("--_sbb-popover-max-height", popoverPosition.maxHeight);
|
|
225
|
+
}
|
|
226
|
+
dispatchBeforeCloseEvent(detail) {
|
|
227
|
+
/**
|
|
228
|
+
* @type {CustomEvent<{ closeTarget: HTMLElement | null }>}
|
|
229
|
+
* Emits whenever the component begins the closing transition. Can be canceled.
|
|
230
|
+
*/
|
|
231
|
+
return this.dispatchEvent(new CustomEvent("beforeclose", {
|
|
232
|
+
detail,
|
|
233
|
+
cancelable: true
|
|
234
|
+
}));
|
|
235
|
+
}
|
|
236
|
+
dispatchCloseEvent(detail) {
|
|
237
|
+
/**
|
|
238
|
+
* @type {CustomEvent<{ closeTarget: HTMLElement | null }>}
|
|
239
|
+
* Emits whenever the component is closed.
|
|
240
|
+
*/
|
|
241
|
+
return this.dispatchEvent(new CustomEvent("close", { detail }));
|
|
242
|
+
}
|
|
243
|
+
render() {
|
|
244
|
+
return html`
|
|
245
|
+
<div class="sbb-popover__container">
|
|
246
|
+
<div
|
|
247
|
+
@animationend=${this._onPopoverAnimationEnd}
|
|
248
|
+
class="sbb-popover"
|
|
249
|
+
role="tooltip"
|
|
250
|
+
${ref((el) => this.overlay = el)}
|
|
251
|
+
>
|
|
252
|
+
<div
|
|
253
|
+
@click=${(event) => this._closeOnSbbPopoverCloseClick(event)}
|
|
254
|
+
class="sbb-popover__content"
|
|
255
|
+
>
|
|
256
|
+
${this.renderContent()}
|
|
257
|
+
</div>
|
|
258
|
+
</div>
|
|
259
|
+
</div>
|
|
260
|
+
`;
|
|
261
|
+
}
|
|
262
|
+
};
|
|
263
|
+
})();
|
|
264
|
+
/**
|
|
265
|
+
* It displays contextual information within a popover.
|
|
266
|
+
*
|
|
267
|
+
* @slot - Use the unnamed slot to add content into the popover.
|
|
268
|
+
* @cssprop [--sbb-popover-z-index=var(--sbb-overlay-default-z-index)] - To specify a custom stack order,
|
|
269
|
+
* the `z-index` can be overridden by defining this CSS variable. The default `z-index` of the
|
|
270
|
+
* component is set to `var(--sbb-overlay-default-z-index)` with a value of `1000`.
|
|
271
|
+
*/
|
|
272
|
+
var SbbPopoverElement = (() => {
|
|
273
|
+
let _classSuper = SbbPopoverBaseElement;
|
|
274
|
+
let _instanceExtraInitializers = [];
|
|
275
|
+
let _hideCloseButton_decorators;
|
|
276
|
+
let _hideCloseButton_initializers = [];
|
|
277
|
+
let _hideCloseButton_extraInitializers = [];
|
|
278
|
+
let _hoverTrigger_decorators;
|
|
279
|
+
let _hoverTrigger_initializers = [];
|
|
280
|
+
let _hoverTrigger_extraInitializers = [];
|
|
281
|
+
let _set_openDelay_decorators;
|
|
282
|
+
let _set_closeDelay_decorators;
|
|
283
|
+
let _accessibilityCloseLabel_decorators;
|
|
284
|
+
let _accessibilityCloseLabel_initializers = [];
|
|
285
|
+
let _accessibilityCloseLabel_extraInitializers = [];
|
|
286
|
+
return class SbbPopoverElement extends _classSuper {
|
|
287
|
+
constructor() {
|
|
288
|
+
super(...arguments);
|
|
289
|
+
this.#hideCloseButton_accessor_storage = (__runInitializers(this, _instanceExtraInitializers), __runInitializers(this, _hideCloseButton_initializers, false));
|
|
290
|
+
this.#hoverTrigger_accessor_storage = (__runInitializers(this, _hideCloseButton_extraInitializers), __runInitializers(this, _hoverTrigger_initializers, false));
|
|
291
|
+
this._openDelay = __runInitializers(this, _hoverTrigger_extraInitializers);
|
|
292
|
+
this.#accessibilityCloseLabel_accessor_storage = __runInitializers(this, _accessibilityCloseLabel_initializers, "");
|
|
293
|
+
this._hoverTrigger = (__runInitializers(this, _accessibilityCloseLabel_extraInitializers), false);
|
|
294
|
+
this._language = new SbbLanguageController(this);
|
|
295
|
+
this._overlayAbortController = null;
|
|
296
|
+
this._onTriggerMouseEnter = () => {
|
|
297
|
+
if (this.state === "closed" || this.state === "closing") this._openTimeout = setTimeout(() => {
|
|
298
|
+
sbbInputModalityDetector.reset();
|
|
299
|
+
this.open();
|
|
300
|
+
}, this.openDelay);
|
|
301
|
+
else clearTimeout(this.closeTimeout);
|
|
302
|
+
};
|
|
303
|
+
this._onTriggerMouseLeave = () => {
|
|
304
|
+
if (this.state === "opened" || this.state === "opening") this.closeTimeout = setTimeout(() => this.close(), this.closeDelay);
|
|
305
|
+
else clearTimeout(this._openTimeout);
|
|
306
|
+
};
|
|
307
|
+
this._onOverlayMouseEnter = () => {
|
|
308
|
+
if (this.state !== "opening") clearTimeout(this.closeTimeout);
|
|
309
|
+
};
|
|
310
|
+
this._onOverlayMouseLeave = () => {
|
|
311
|
+
if (this.state !== "opening") this.closeTimeout = setTimeout(() => this.close(), this.closeDelay);
|
|
312
|
+
};
|
|
313
|
+
}
|
|
314
|
+
static {
|
|
315
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
316
|
+
_hideCloseButton_decorators = [forceType(), property({
|
|
317
|
+
attribute: "hide-close-button",
|
|
318
|
+
type: Boolean,
|
|
319
|
+
reflect: true
|
|
320
|
+
})];
|
|
321
|
+
_hoverTrigger_decorators = [forceType(), property({
|
|
322
|
+
attribute: "hover-trigger",
|
|
323
|
+
type: Boolean
|
|
324
|
+
})];
|
|
325
|
+
_set_openDelay_decorators = [property({
|
|
326
|
+
attribute: "open-delay",
|
|
327
|
+
type: Number
|
|
328
|
+
})];
|
|
329
|
+
_set_closeDelay_decorators = [property({
|
|
330
|
+
attribute: "close-delay",
|
|
331
|
+
type: Number
|
|
332
|
+
})];
|
|
333
|
+
_accessibilityCloseLabel_decorators = [forceType(), property({ attribute: "accessibility-close-label" })];
|
|
334
|
+
__esDecorate(this, null, _hideCloseButton_decorators, {
|
|
335
|
+
kind: "accessor",
|
|
336
|
+
name: "hideCloseButton",
|
|
337
|
+
static: false,
|
|
338
|
+
private: false,
|
|
339
|
+
access: {
|
|
340
|
+
has: (obj) => "hideCloseButton" in obj,
|
|
341
|
+
get: (obj) => obj.hideCloseButton,
|
|
342
|
+
set: (obj, value) => {
|
|
343
|
+
obj.hideCloseButton = value;
|
|
344
|
+
}
|
|
345
|
+
},
|
|
346
|
+
metadata: _metadata
|
|
347
|
+
}, _hideCloseButton_initializers, _hideCloseButton_extraInitializers);
|
|
348
|
+
__esDecorate(this, null, _hoverTrigger_decorators, {
|
|
349
|
+
kind: "accessor",
|
|
350
|
+
name: "hoverTrigger",
|
|
351
|
+
static: false,
|
|
352
|
+
private: false,
|
|
353
|
+
access: {
|
|
354
|
+
has: (obj) => "hoverTrigger" in obj,
|
|
355
|
+
get: (obj) => obj.hoverTrigger,
|
|
356
|
+
set: (obj, value) => {
|
|
357
|
+
obj.hoverTrigger = value;
|
|
358
|
+
}
|
|
359
|
+
},
|
|
360
|
+
metadata: _metadata
|
|
361
|
+
}, _hoverTrigger_initializers, _hoverTrigger_extraInitializers);
|
|
362
|
+
__esDecorate(this, null, _set_openDelay_decorators, {
|
|
363
|
+
kind: "setter",
|
|
364
|
+
name: "openDelay",
|
|
365
|
+
static: false,
|
|
366
|
+
private: false,
|
|
367
|
+
access: {
|
|
368
|
+
has: (obj) => "openDelay" in obj,
|
|
369
|
+
set: (obj, value) => {
|
|
370
|
+
obj.openDelay = value;
|
|
371
|
+
}
|
|
372
|
+
},
|
|
373
|
+
metadata: _metadata
|
|
374
|
+
}, null, _instanceExtraInitializers);
|
|
375
|
+
__esDecorate(this, null, _set_closeDelay_decorators, {
|
|
376
|
+
kind: "setter",
|
|
377
|
+
name: "closeDelay",
|
|
378
|
+
static: false,
|
|
379
|
+
private: false,
|
|
380
|
+
access: {
|
|
381
|
+
has: (obj) => "closeDelay" in obj,
|
|
382
|
+
set: (obj, value) => {
|
|
383
|
+
obj.closeDelay = value;
|
|
384
|
+
}
|
|
385
|
+
},
|
|
386
|
+
metadata: _metadata
|
|
387
|
+
}, null, _instanceExtraInitializers);
|
|
388
|
+
__esDecorate(this, null, _accessibilityCloseLabel_decorators, {
|
|
389
|
+
kind: "accessor",
|
|
390
|
+
name: "accessibilityCloseLabel",
|
|
391
|
+
static: false,
|
|
392
|
+
private: false,
|
|
393
|
+
access: {
|
|
394
|
+
has: (obj) => "accessibilityCloseLabel" in obj,
|
|
395
|
+
get: (obj) => obj.accessibilityCloseLabel,
|
|
396
|
+
set: (obj, value) => {
|
|
397
|
+
obj.accessibilityCloseLabel = value;
|
|
398
|
+
}
|
|
399
|
+
},
|
|
400
|
+
metadata: _metadata
|
|
401
|
+
}, _accessibilityCloseLabel_initializers, _accessibilityCloseLabel_extraInitializers);
|
|
402
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, {
|
|
403
|
+
enumerable: true,
|
|
404
|
+
configurable: true,
|
|
405
|
+
writable: true,
|
|
406
|
+
value: _metadata
|
|
407
|
+
});
|
|
408
|
+
}
|
|
409
|
+
static {
|
|
410
|
+
this.elementName = "sbb-popover";
|
|
411
|
+
}
|
|
412
|
+
static {
|
|
413
|
+
this.elementDependencies = [SbbSecondaryButtonElement];
|
|
414
|
+
}
|
|
415
|
+
#hideCloseButton_accessor_storage;
|
|
416
|
+
/** Whether the close button should be hidden. */
|
|
417
|
+
get hideCloseButton() {
|
|
418
|
+
return this.#hideCloseButton_accessor_storage;
|
|
419
|
+
}
|
|
420
|
+
set hideCloseButton(value) {
|
|
421
|
+
this.#hideCloseButton_accessor_storage = value;
|
|
422
|
+
}
|
|
423
|
+
#hoverTrigger_accessor_storage;
|
|
424
|
+
/** Whether the popover should be triggered on hover. */
|
|
425
|
+
get hoverTrigger() {
|
|
426
|
+
return this.#hoverTrigger_accessor_storage;
|
|
427
|
+
}
|
|
428
|
+
set hoverTrigger(value) {
|
|
429
|
+
this.#hoverTrigger_accessor_storage = value;
|
|
430
|
+
}
|
|
431
|
+
/**
|
|
432
|
+
* Open the popover after a given delay in milliseconds.
|
|
433
|
+
* Global configuration is used as default, if not set.
|
|
434
|
+
*
|
|
435
|
+
* @default 0
|
|
436
|
+
*/
|
|
437
|
+
set openDelay(value) {
|
|
438
|
+
this._openDelay = +value;
|
|
439
|
+
}
|
|
440
|
+
get openDelay() {
|
|
441
|
+
return this._openDelay ?? readConfig().popover?.openDelay ?? 0;
|
|
442
|
+
}
|
|
443
|
+
/**
|
|
444
|
+
* Close the popover after a given delay in milliseconds.
|
|
445
|
+
* Global configuration is used as default, if not set.
|
|
446
|
+
*
|
|
447
|
+
* @default 0
|
|
448
|
+
*/
|
|
449
|
+
set closeDelay(value) {
|
|
450
|
+
this._closeDelay = +value;
|
|
451
|
+
}
|
|
452
|
+
get closeDelay() {
|
|
453
|
+
return this._closeDelay ?? readConfig().popover?.closeDelay ?? 0;
|
|
454
|
+
}
|
|
455
|
+
#accessibilityCloseLabel_accessor_storage;
|
|
456
|
+
/** This will be forwarded as aria-label to the close button element. */
|
|
457
|
+
get accessibilityCloseLabel() {
|
|
458
|
+
return this.#accessibilityCloseLabel_accessor_storage;
|
|
459
|
+
}
|
|
460
|
+
set accessibilityCloseLabel(value) {
|
|
461
|
+
this.#accessibilityCloseLabel_accessor_storage = value;
|
|
462
|
+
}
|
|
463
|
+
configureTrigger(oldTrigger) {
|
|
464
|
+
const hoverTrigger = this.hoverTrigger && !pointerCoarse;
|
|
465
|
+
if (this.trigger === oldTrigger && hoverTrigger === this._hoverTrigger) return;
|
|
466
|
+
if (this._hoverTrigger !== hoverTrigger) {
|
|
467
|
+
this._hoverTrigger = hoverTrigger;
|
|
468
|
+
this.toggleState("hover-trigger", this._hoverTrigger);
|
|
469
|
+
this._registerOverlayListeners();
|
|
470
|
+
}
|
|
471
|
+
super.configureTrigger(oldTrigger);
|
|
472
|
+
}
|
|
473
|
+
_registerOverlayListeners() {
|
|
474
|
+
this._overlayAbortController?.abort();
|
|
475
|
+
if (this._hoverTrigger) {
|
|
476
|
+
this._overlayAbortController = new AbortController();
|
|
477
|
+
this.overlay?.addEventListener("mouseenter", () => this._onOverlayMouseEnter(), { signal: this._overlayAbortController.signal });
|
|
478
|
+
this.overlay?.addEventListener("mouseleave", () => this._onOverlayMouseLeave(), { signal: this._overlayAbortController.signal });
|
|
479
|
+
}
|
|
480
|
+
}
|
|
481
|
+
registerTriggerListeners(signal) {
|
|
482
|
+
if (this._hoverTrigger && this.trigger) {
|
|
483
|
+
this.trigger.addEventListener("mouseenter", this._onTriggerMouseEnter, { signal });
|
|
484
|
+
this.trigger.addEventListener("mouseleave", this._onTriggerMouseLeave, { signal });
|
|
485
|
+
this.trigger.addEventListener("keydown", (evt) => {
|
|
486
|
+
if (evt.code === "Space" || evt.code === "Enter") this.open();
|
|
487
|
+
}, { signal });
|
|
488
|
+
this.trigger.addEventListener("mousedown", (evt) => {
|
|
489
|
+
if (isFakeMousedownFromScreenReader(evt)) this.open();
|
|
490
|
+
}, { signal });
|
|
491
|
+
} else super.registerTriggerListeners(signal);
|
|
492
|
+
}
|
|
493
|
+
firstUpdated(changedProperties) {
|
|
494
|
+
super.firstUpdated(changedProperties);
|
|
495
|
+
this._registerOverlayListeners();
|
|
496
|
+
}
|
|
497
|
+
open() {
|
|
498
|
+
super.open();
|
|
499
|
+
if (this.hoverTrigger && this.trigger) ɵstateController(this.trigger).add("force-hover");
|
|
500
|
+
}
|
|
501
|
+
close() {
|
|
502
|
+
super.close();
|
|
503
|
+
ɵstateController(this.trigger)?.delete("force-hover");
|
|
504
|
+
}
|
|
505
|
+
renderContent() {
|
|
506
|
+
const closeButton = html`
|
|
507
|
+
<sbb-secondary-button
|
|
508
|
+
aria-label=${this.accessibilityCloseLabel || i18nClosePopover[this._language.current]}
|
|
509
|
+
size="s"
|
|
510
|
+
type="button"
|
|
511
|
+
icon-name="cross-small"
|
|
512
|
+
sbb-popover-close
|
|
513
|
+
></sbb-secondary-button>
|
|
514
|
+
`;
|
|
515
|
+
return html`
|
|
516
|
+
${!this.hideCloseButton && !this._hoverTrigger ? closeButton : nothing}
|
|
517
|
+
<span class="sbb-popover__scrollable-content">
|
|
518
|
+
<slot>No content</slot>
|
|
519
|
+
</span>
|
|
520
|
+
`;
|
|
521
|
+
}
|
|
522
|
+
};
|
|
523
|
+
})();
|
|
524
|
+
//#endregion
|
|
525
|
+
export { SbbPopoverElement as n, SbbPopoverBaseElement as t };
|
|
526
|
+
|
|
527
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"popover.component-B1gMzBuv.js","names":[],"sources":["../../../src/elements/popover/popover.scss?inline","../../../src/elements/popover/popover.component.ts"],"sourcesContent":["@use '../core/styles' as sbb;\n\n:host {\n  // As the popover has always a white background, we have to fix the focus outline color\n  // to default color for cases where the popover is used in a negative context.\n  --sbb-focus-outline-color: light-dark(\n    var(--sbb-focus-outline-color-default),\n    var(--sbb-focus-outline-color-dark)\n  );\n  --sbb-popover-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-4x)\n  );\n  --_sbb-popover-inset: 0 auto auto 0;\n  --_sbb-popover-transform: translateY(var(--sbb-spacing-fixed-2x));\n\n  // Use !important here to not interfere with Firefox focus ring definition\n  // which appears in normalize CSS of several frameworks.\n  outline: none !important;\n  display: none;\n}\n\n:host(:is(:state(state-opening), :state(state-opened), :state(state-closing))) {\n  --_sbb-popover-inset: 0;\n\n  display: block;\n}\n\n:host(:state(position-above)) {\n  --_sbb-popover-transform: translateY(calc(var(--sbb-spacing-fixed-2x) * -1));\n}\n\n:host(:not([hide-close-button], :state(hover-trigger))) {\n  --sbb-popover-min-height: calc(var(--sbb-size-element-xs) + 2 * var(--sbb-popover-padding));\n}\n\n// Popover arrow and arrow top cover\n.sbb-popover::after,\n.sbb-popover__content::before {\n  content: '';\n  position: absolute;\n  display: block;\n  width: var(--sbb-popover-arrow-size);\n  height: var(--sbb-popover-arrow-size);\n  left: var(--_sbb-popover-arrow-position-x, 0);\n  bottom: calc(100% - calc(var(--sbb-popover-arrow-size) / 2));\n  background-color: var(--sbb-popover-background);\n  border-radius: var(--sbb-border-radius-2x) 0;\n  transform: rotate(45deg);\n}\n\n.sbb-popover__container {\n  position: fixed;\n  inset: var(--_sbb-popover-inset);\n  pointer-events: none;\n  z-index: var(--sbb-popover-z-index, var(--sbb-overlay-default-z-index));\n}\n\n.sbb-popover {\n  box-shadow: var(--sbb-box-shadow-level-5-hard);\n  display: none;\n  position: var(--sbb-popover-position, absolute);\n  pointer-events: all;\n  top: var(--_sbb-popover-position-y, 0);\n  bottom: unset;\n  left: var(--_sbb-popover-position-x, 0);\n  right: unset;\n  border: none;\n  border-radius: var(--sbb-popover-border-radius);\n  padding: 0;\n  max-width: var(--sbb-popover-max-width);\n  width: max-content;\n  background-color: var(--sbb-popover-background);\n  outline: none;\n\n  :host(:focus-visible) & {\n    @include sbb.focus-outline;\n  }\n\n  :host(:is(:state(state-opening), :state(state-opened), :state(state-closing))) & {\n    display: block;\n\n    animation: {\n      name: open;\n      duration: var(--sbb-popover-animation-duration);\n      timing-function: var(--sbb-popover-animation-easing);\n    }\n  }\n\n  :host(:state(state-closing)) & {\n    pointer-events: none;\n    animation: {\n      name: close;\n      duration: var(--sbb-popover-animation-duration);\n      timing-function: var(--sbb-popover-animation-easing);\n    }\n  }\n\n  // Popover arrow\n  &::after {\n    z-index: -1;\n    box-shadow: var(--sbb-box-shadow-level-5-hard);\n\n    @include sbb.if-forced-colors {\n      outline: var(--sbb-border-width-1x) solid CanvasText;\n    }\n\n    :host(:state(position-above)) & {\n      top: calc(100% - calc(var(--sbb-popover-arrow-size) / 2));\n    }\n  }\n\n  @include sbb.if-forced-colors {\n    outline: var(--sbb-border-width-1x) solid CanvasText;\n  }\n\n  // Transparent area which increases hover area in order to not trigger closing too early.\n  &::before {\n    content: '';\n    display: block;\n    position: absolute;\n    inset: 0;\n    z-index: -1;\n    background-color: transparent;\n\n    :host(:state(position-below)) & {\n      inset-block-start: calc(-1 * var(--sbb-spacing-fixed-6x));\n    }\n\n    :host(:state(position-above)) & {\n      inset-block-end: calc(-1 * var(--sbb-spacing-fixed-6x));\n    }\n  }\n}\n\n.sbb-popover__content {\n  display: flex;\n  gap: var(--sbb-spacing-fixed-4x);\n  border-radius: var(--sbb-popover-border-radius);\n  padding-block: var(--sbb-popover-padding) 0;\n  padding-inline: var(--sbb-popover-padding);\n  outline: none;\n  background-color: var(--sbb-popover-background);\n  flex-direction: row-reverse;\n  min-height: var(--sbb-popover-min-height);\n\n  :host(:state(position-above)) & {\n    &::before {\n      top: calc(100% - calc(var(--sbb-popover-arrow-size) / 2));\n    }\n  }\n}\n\n.sbb-popover__scrollable-content {\n  @include sbb.scrollbar;\n\n  display: block;\n  padding-block-end: var(--sbb-popover-padding);\n  max-height: calc(var(--_sbb-popover-max-height));\n  overflow: auto;\n}\n\n@keyframes open {\n  from {\n    opacity: 0;\n    transform: var(--_sbb-popover-transform);\n  }\n\n  to {\n    opacity: 1;\n    transform: translateY(0);\n  }\n}\n\n@keyframes close {\n  from {\n    opacity: 1;\n    transform: translateY(0);\n  }\n\n  to {\n    opacity: 0;\n    transform: var(--_sbb-popover-transform);\n  }\n}\n","import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  nothing,\n  type PropertyDeclaration,\n  type PropertyValues,\n  type TemplateResult,\n  unsafeCSS,\n} from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport { SbbSecondaryButtonElement } from '../button.pure.ts';\nimport {\n  boxSizingStyles,\n  composedPathHasAttribute,\n  forceType,\n  getElementPosition,\n  i18nClosePopover,\n  idReference,\n  IS_FOCUSABLE_QUERY,\n  isEventOnElement,\n  isFakeMousedownFromScreenReader,\n  isZeroAnimationDuration,\n  readConfig,\n  removeAriaOverlayTriggerProperties,\n  type SbbElementType,\n  SbbEscapableOverlayController,\n  SbbFocusTrapController,\n  sbbInputModalityDetector,\n  SbbLanguageController,\n  SbbMediaQueryPointerCoarse,\n  SbbOpenCloseBaseElement,\n  setAriaOverlayTriggerProperties,\n  ɵstateController,\n} from '../core.ts';\n\nimport style from './popover.scss?inline';\n\nconst VERTICAL_OFFSET = 16;\nconst HORIZONTAL_OFFSET = 32;\n\nconst popoversRef = new Set<SbbPopoverBaseElement>();\nconst pointerCoarse = isServer ? false : matchMedia(SbbMediaQueryPointerCoarse).matches;\n\nexport abstract class SbbPopoverBaseElement extends SbbOpenCloseBaseElement {\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(style)];\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  // The element which should receive focus after closing based on where in the backdrop the user clicks.\n  private _nextFocusedElement?: HTMLElement;\n  private _skipCloseFocus: boolean = false;\n  private _popoverCloseElement?: HTMLElement;\n  private _isPointerDownEventOnPopover?: boolean;\n  private _triggerElement?: HTMLElement | null;\n  private _triggerAbortController?: AbortController;\n  private _openStateController?: AbortController;\n  private _escapableOverlayController = new SbbEscapableOverlayController(this);\n  private _focusTrapController = new SbbFocusTrapController(this);\n  private _blurTimeout: ReturnType<typeof setTimeout> | null = null;\n  protected closeTimeout?: ReturnType<typeof setTimeout>;\n  protected overlay?: HTMLDivElement;\n\n  /** Opens the popover on trigger click. */\n  public open(): void {\n    if (\n      (this.state !== 'closed' && this.state !== 'closing') ||\n      !this.overlay ||\n      !this.dispatchBeforeOpenEvent()\n    ) {\n      return;\n    }\n\n    // Close the other popovers\n    for (const popover of popoversRef) {\n      if (popover.state === 'opened' || popover.state === 'opening') {\n        popover.close();\n      }\n    }\n\n    this.showPopover?.();\n    this.state = 'opening';\n    this.inert = true;\n    this._setPopoverPosition();\n    this._attachWindowEvents();\n    this._escapableOverlayController.connect();\n    this._nextFocusedElement = undefined;\n    this._skipCloseFocus = false;\n    if (this._triggerElement) {\n      this._triggerElement.ariaExpanded = 'true';\n    }\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  /** Closes the popover. */\n  public close(target?: HTMLElement): void {\n    if (this.state !== 'opened' && this.state !== 'opening') {\n      return;\n    }\n\n    this._popoverCloseElement = target;\n    if (!this.dispatchBeforeCloseEvent({ closeTarget: target ?? null })) {\n      return;\n    }\n\n    this.state = 'closing';\n    this.inert = true;\n    if (this._triggerElement) {\n      this._triggerElement.ariaExpanded = 'false';\n    }\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 _isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-popover-animation-duration');\n  }\n\n  private _handleClosing(): void {\n    this.state = 'closed';\n    this.hidePopover?.();\n\n    this.overlay?.firstElementChild?.scrollTo(0, 0);\n    this.removeAttribute('tabindex');\n\n    if (!this._skipCloseFocus) {\n      const elementToFocus = this._nextFocusedElement || this._triggerElement;\n\n      // To enable focusing other element than the trigger, we need to call focus() a second time.\n      elementToFocus?.focus();\n    }\n\n    this._escapableOverlayController.disconnect();\n    this._openStateController?.abort();\n    this._focusTrapController.enabled = false;\n    this.dispatchCloseEvent({ closeTarget: this._popoverCloseElement ?? null });\n  }\n\n  private _handleOpening(): void {\n    this.state = 'opened';\n    this.inert = false;\n    this._setPopoverFocus();\n    this._focusTrapController.enabled = true;\n    this.dispatchOpenEvent();\n  }\n\n  public override connectedCallback(): void {\n    this.popover = 'manual';\n    super.connectedCallback();\n    this.state = 'closed';\n    popoversRef.add(this);\n    if (this.hasUpdated) {\n      this._configureTrigger();\n    }\n  }\n\n  public override requestUpdate(\n    name?: PropertyKey,\n    oldValue?: unknown,\n    options?: PropertyDeclaration,\n  ): void {\n    super.requestUpdate(name, oldValue, options);\n\n    // Checking for hoverTrigger is a special case, as only the SbbPopoverElement\n    // subclass has this property.\n    if (!isServer && (!name || name === 'trigger' || name === 'hoverTrigger') && this.hasUpdated) {\n      this._configureTrigger();\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n    this._configureTrigger();\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._triggerElement = null;\n    this._triggerAbortController?.abort();\n    this._openStateController?.abort();\n    popoversRef.delete(this);\n    if (this._blurTimeout) {\n      clearTimeout(this._blurTimeout);\n    }\n  }\n\n  // Check if the trigger is valid and attach click event listeners.\n  private _configureTrigger(): void {\n    if (isServer) {\n      return;\n    } else if (this.hydrationRequired) {\n      this.hydrationComplete.then(() => this._configureTrigger());\n      return;\n    }\n\n    this.configureTrigger(this._triggerElement ?? null);\n  }\n\n  protected configureTrigger(_oldTrigger: HTMLElement | null): void {\n    this._triggerAbortController?.abort();\n\n    removeAriaOverlayTriggerProperties(this._triggerElement);\n    this._triggerElement = this.trigger;\n\n    if (!this._triggerElement) {\n      return;\n    }\n\n    setAriaOverlayTriggerProperties(this, this._triggerElement, 'dialog', this.state);\n\n    this._triggerAbortController = new AbortController();\n    this.registerTriggerListeners(this._triggerAbortController.signal);\n  }\n\n  protected registerTriggerListeners(signal: AbortSignal): void {\n    this._triggerElement!.addEventListener('click', () => this.open(), { signal });\n  }\n\n  private _attachWindowEvents(): void {\n    this._openStateController = new AbortController();\n    document.addEventListener('scroll', () => this._setPopoverPosition(), {\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._setPopoverPosition(), {\n      passive: true,\n      signal: this._openStateController.signal,\n    });\n    // Close popover on backdrop click\n    window.addEventListener('pointerdown', this._pointerDownListener, {\n      signal: this._openStateController.signal,\n    });\n    window.addEventListener('pointerup', this._closeOnBackdropClick, {\n      signal: this._openStateController.signal,\n    });\n  }\n\n  // Close the popover on click of any element that has the 'sbb-popover-close' attribute.\n  private _closeOnSbbPopoverCloseClick(event: Event): void {\n    const closeElement = composedPathHasAttribute(event, 'sbb-popover-close', this);\n\n    if (closeElement && !closeElement.hasAttribute('disabled')) {\n      clearTimeout(this.closeTimeout);\n      this.close(closeElement);\n    }\n  }\n\n  // Check if the pointerdown event target is triggered on the popover.\n  private _pointerDownListener = (event: PointerEvent): void => {\n    this._isPointerDownEventOnPopover = isEventOnElement(this.overlay!, event);\n  };\n\n  // Close popover on backdrop click.\n  private _closeOnBackdropClick = (event: PointerEvent): void => {\n    const composedPath = event.composedPath();\n    if (\n      !this._isPointerDownEventOnPopover &&\n      !isEventOnElement(this.overlay!, event) &&\n      (!this.trigger || !composedPath.includes(this.trigger))\n    ) {\n      this._nextFocusedElement = composedPath\n        .filter((el) => el instanceof window.HTMLElement)\n        .find((el) => (el as HTMLElement).matches(IS_FOCUSABLE_QUERY)) as HTMLElement;\n      clearTimeout(this.closeTimeout);\n      this.close();\n    }\n  };\n\n  // Set popover position (x, y) to '0' once the popover is closed and the transition ended to prevent the\n  // viewport from overflowing. And set the focus to the first focusable element once the popover is open.\n  // In rare cases it can be that the animationEnd event is triggered twice.\n  // To avoid entering a corrupt state, exit when state is not expected.\n  private _onPopoverAnimationEnd(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  // Set focus on the first focusable element.\n  private _setPopoverFocus(): void {\n    const focused = this._focusTrapController.focusInitialElement();\n\n    if (!focused && this._openStateController) {\n      this.setAttribute('tabindex', '0');\n      this.focus();\n\n      // When a blur occurs, we know that the popover has to be closed,\n      // because there are no interactive elements inside the popover.\n      // When a window/tab change occurs, a blur event is also fired. However, when the current window/tab\n      // becomes active again, it focuses once again the popover.\n      // Therefore, we cannot listen to the blur event only once.\n      // To prevent accidentally closing the popover, we need to check for the window/tab state.\n      // We can achieve this by using visibilityState, which only works with setTimeout().\n      this.addEventListener(\n        'blur',\n        (e: FocusEvent): void => {\n          this._blurTimeout = setTimeout(() => {\n            if (document.visibilityState !== 'hidden') {\n              this.removeAttribute('tabindex');\n\n              // In Safari on iOS it can occur, that a blur event triggers on the popover\n              // although the focus remains inside the popover.\n              // Therefore, we need to stop the closing if the relatedTarget is contained in the popover or it is the trigger.\n              if (this.contains(e.relatedTarget as Node) || e.relatedTarget === this.trigger) {\n                return;\n              }\n\n              if (this.state === 'opened' || this.state === 'opening') {\n                this._skipCloseFocus = true;\n              }\n              this.close();\n            }\n          });\n        },\n        {\n          signal: this._openStateController.signal,\n        },\n      );\n    }\n  }\n\n  private _setPopoverPosition(): void {\n    if (!this.overlay || !this._triggerElement) {\n      return;\n    }\n\n    const popoverPosition = getElementPosition(\n      this.overlay,\n      this._triggerElement,\n      this.shadowRoot!.querySelector('.sbb-popover__container')!,\n      {\n        verticalOffset: VERTICAL_OFFSET,\n        horizontalOffset: HORIZONTAL_OFFSET,\n        centered: true,\n        responsiveHeight: true,\n      },\n    );\n    const verticalPosition = popoverPosition.alignment.vertical;\n    for (const position of ['above', 'below']) {\n      this.toggleState(`position-${position}`, position === verticalPosition);\n    }\n\n    const arrowXPosition =\n      this._triggerElement.getBoundingClientRect().left -\n      popoverPosition.left +\n      this._triggerElement.clientWidth / 2 -\n      8; // half the size of the popover arrow\n\n    this.style.setProperty('--_sbb-popover-position-x', `${popoverPosition.left}px`);\n    this.style.setProperty('--_sbb-popover-position-y', `${popoverPosition.top}px`);\n    this.style.setProperty('--_sbb-popover-arrow-position-x', `${arrowXPosition}px`);\n    this.style.setProperty('--_sbb-popover-max-height', popoverPosition.maxHeight);\n  }\n\n  protected abstract renderContent(): TemplateResult;\n\n  protected override dispatchBeforeCloseEvent(detail?: {\n    closeTarget: HTMLElement | null;\n  }): boolean {\n    /**\n     * @type {CustomEvent<{ closeTarget: HTMLElement | null }>}\n     * Emits whenever the component begins the closing transition. Can be canceled.\n     */\n    return this.dispatchEvent(\n      new CustomEvent<{ closeTarget: HTMLElement | null }>('beforeclose', {\n        detail,\n        cancelable: true,\n      }),\n    );\n  }\n\n  protected override dispatchCloseEvent(detail?: { closeTarget: HTMLElement | null }): boolean {\n    /**\n     * @type {CustomEvent<{ closeTarget: HTMLElement | null }>}\n     * Emits whenever the component is closed.\n     */\n    return this.dispatchEvent(\n      new CustomEvent<{ closeTarget: HTMLElement | null }>('close', { detail }),\n    );\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-popover__container\">\n        <div\n          @animationend=${this._onPopoverAnimationEnd}\n          class=\"sbb-popover\"\n          role=\"tooltip\"\n          ${ref((el?: Element) => (this.overlay = el as HTMLDivElement))}\n        >\n          <div\n            @click=${(event: Event) => this._closeOnSbbPopoverCloseClick(event)}\n            class=\"sbb-popover__content\"\n          >\n            ${this.renderContent()}\n          </div>\n        </div>\n      </div>\n    `;\n  }\n}\n\n/**\n * It displays contextual information within a popover.\n *\n * @slot - Use the unnamed slot to add content into the popover.\n * @cssprop [--sbb-popover-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 class SbbPopoverElement extends SbbPopoverBaseElement {\n  public static override readonly elementName: string = 'sbb-popover';\n  public static override elementDependencies: SbbElementType[] = [SbbSecondaryButtonElement];\n\n  /** Whether the close button should be hidden. */\n  @forceType()\n  @property({ attribute: 'hide-close-button', type: Boolean, reflect: true })\n  public accessor hideCloseButton: boolean = false;\n\n  /** Whether the popover should be triggered on hover. */\n  @forceType()\n  @property({ attribute: 'hover-trigger', type: Boolean })\n  public accessor hoverTrigger: boolean = false;\n\n  /**\n   * Open the popover 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().popover?.openDelay ?? 0;\n  }\n  private _openDelay?: number;\n\n  /**\n   * Close the popover 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().popover?.closeDelay ?? 0;\n  }\n  private _closeDelay?: number;\n\n  /** This will be forwarded as aria-label to the close button element. */\n  @forceType()\n  @property({ attribute: 'accessibility-close-label' })\n  public accessor accessibilityCloseLabel: string = '';\n\n  private _hoverTrigger = false;\n  private _openTimeout?: ReturnType<typeof setTimeout>;\n  private _language = new SbbLanguageController(this);\n  private _overlayAbortController: AbortController | null = null;\n\n  protected override configureTrigger(oldTrigger: HTMLElement | null): void {\n    // Check whether the trigger can be hovered. Some devices might interpret the media query (hover: hover) differently,\n    // and not respect the fallback mechanism on the click. Therefore, the following is preferred to identify\n    // all non-touchscreen devices.\n    const hoverTrigger = this.hoverTrigger && !pointerCoarse;\n\n    if (this.trigger === oldTrigger && hoverTrigger === this._hoverTrigger) {\n      return;\n    }\n\n    if (this._hoverTrigger !== hoverTrigger) {\n      this._hoverTrigger = hoverTrigger;\n      this.toggleState('hover-trigger', this._hoverTrigger);\n      this._registerOverlayListeners();\n    }\n\n    super.configureTrigger(oldTrigger);\n  }\n\n  private _registerOverlayListeners(): void {\n    this._overlayAbortController?.abort();\n\n    if (this._hoverTrigger) {\n      this._overlayAbortController = new AbortController();\n      this.overlay?.addEventListener('mouseenter', () => this._onOverlayMouseEnter(), {\n        signal: this._overlayAbortController.signal,\n      });\n      this.overlay?.addEventListener('mouseleave', () => this._onOverlayMouseLeave(), {\n        signal: this._overlayAbortController.signal,\n      });\n    }\n  }\n\n  protected override registerTriggerListeners(signal: AbortSignal): void {\n    if (this._hoverTrigger && this.trigger) {\n      this.trigger.addEventListener('mouseenter', this._onTriggerMouseEnter, { signal });\n      this.trigger.addEventListener('mouseleave', this._onTriggerMouseLeave, { signal });\n      this.trigger.addEventListener(\n        'keydown',\n        (evt: KeyboardEvent) => {\n          if (evt.code === 'Space' || evt.code === 'Enter') {\n            this.open();\n          }\n        },\n        { signal },\n      );\n      this.trigger.addEventListener(\n        'mousedown',\n        (evt: MouseEvent) => {\n          // Without this check, NVDA can't open the popover on keyboard interaction.\n          if (isFakeMousedownFromScreenReader(evt)) {\n            this.open();\n          }\n        },\n        { signal },\n      );\n    } else {\n      super.registerTriggerListeners(signal);\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._registerOverlayListeners();\n  }\n\n  public override open(): void {\n    super.open();\n\n    if (this.hoverTrigger && this.trigger) {\n      ɵstateController(this.trigger).add('force-hover');\n    }\n  }\n\n  public override close(): void {\n    super.close();\n\n    ɵstateController(this.trigger)?.delete('force-hover');\n  }\n\n  private _onTriggerMouseEnter = (): void => {\n    if (this.state === 'closed' || this.state === 'closing') {\n      this._openTimeout = setTimeout(() => {\n        // If the trigger is focused by keyboard and hovered with the mouse, the outline would be visible.\n        // So we reset the input modality to hide the outline.\n        sbbInputModalityDetector.reset();\n        this.open();\n      }, this.openDelay);\n    } else {\n      clearTimeout(this.closeTimeout);\n    }\n  };\n\n  private _onTriggerMouseLeave = (): void => {\n    if (this.state === 'opened' || this.state === 'opening') {\n      this.closeTimeout = setTimeout(() => this.close(), this.closeDelay);\n    } else {\n      clearTimeout(this._openTimeout);\n    }\n  };\n\n  private _onOverlayMouseEnter = (): void => {\n    if (this.state !== 'opening') {\n      clearTimeout(this.closeTimeout);\n    }\n  };\n\n  private _onOverlayMouseLeave = (): void => {\n    if (this.state !== 'opening') {\n      this.closeTimeout = setTimeout(() => this.close(), this.closeDelay);\n    }\n  };\n\n  protected override renderContent(): TemplateResult {\n    const closeButton = html`\n      <sbb-secondary-button\n        aria-label=${this.accessibilityCloseLabel || i18nClosePopover[this._language.current]}\n        size=\"s\"\n        type=\"button\"\n        icon-name=\"cross-small\"\n        sbb-popover-close\n      ></sbb-secondary-button>\n    `;\n\n    return html`\n      ${!this.hideCloseButton && !this._hoverTrigger ? closeButton : nothing}\n      <span class=\"sbb-popover__scrollable-content\">\n        <slot>No content</slot>\n      </span>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-popover': SbbPopoverElement;\n  }\n}\n"],"mappings":"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"}
|
package/development/popover.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { n as SbbPopoverElement, t as SbbPopoverBaseElement } from "./popover.component-
|
|
1
|
+
import { n as SbbPopoverElement, t as SbbPopoverBaseElement } from "./popover.component-B1gMzBuv.js";
|
|
2
2
|
import "./popover.pure.js";
|
|
3
3
|
//#region src/elements/popover.ts
|
|
4
4
|
/** @entrypoint */
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { n as SbbPopoverElement, t as SbbPopoverBaseElement } from "./popover.component-
|
|
1
|
+
import { n as SbbPopoverElement, t as SbbPopoverBaseElement } from "./popover.component-B1gMzBuv.js";
|
|
2
2
|
export { SbbPopoverBaseElement, SbbPopoverElement };
|