@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,369 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
import { html, isServer, unsafeCSS } from "lit";
|
|
3
|
+
import { property } from "lit/decorators.js";
|
|
4
|
+
import { SbbDisabledMixin, SbbEscapableOverlayController, SbbOpenCloseBaseElement, SbbOverlayPositionController, appendAriaElements, boxSizingStyles, idReference, isAndroid, isIOS, isZeroAnimationDuration, queueDomContentLoaded, readConfig, removeAriaElements, sbbOverlayOutsidePointerEventListener } from "./core.js";
|
|
5
|
+
//#region src/elements/tooltip/tooltip.scss?inline
|
|
6
|
+
var tooltip_default = ":host {\n --sbb-tooltip-max-width: min(\n 25rem,\n calc(100vw - var(--sbb-spacing-fixed-2x))\n );\n --sbb-tooltip-animation-duration: var(\n --sbb-disable-animation-duration,\n var(--sbb-animation-duration-4x)\n );\n position-area: var(--sbb-overlay-position-area);\n position-try-fallbacks: var(--sbb-overlay-position-try-fallbacks);\n display: none;\n position: fixed;\n background-color: transparent;\n pointer-events: var(--sbb-tooltip-pointer-events, all);\n z-index: var(--sbb-tooltip-z-index, var(--sbb-overlay-default-z-index));\n animation-name: var(--sbb-tooltip-animation-name);\n animation-duration: var(--sbb-tooltip-animation-duration);\n animation-timing-function: var(--sbb-tooltip-animation-easing);\n font-size: var(--sbb-tooltip-font-size);\n letter-spacing: var(--sbb-typo-letter-spacing-text);\n border: none;\n inset: initial;\n padding: 0;\n margin: 0;\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-tooltip-animation-name: open;\n display: block;\n}\n\n:host(:is(:state(state-closing),[state--state-closing])) {\n --sbb-tooltip-animation-name: close;\n --sbb-tooltip-pointer-events: none;\n}\n\n:host(:is([data-position~=block-end], [data-position~=bottom], [data-position^=end])) {\n padding-block-start: var(--sbb-tooltip-gap);\n}\n\n:host(:is([data-position~=block-start], [data-position~=top], [data-position^=start])) {\n padding-block-end: var(--sbb-tooltip-gap);\n}\n\n:host(:is([data-position~=inline-start],\n[data-position~=inline-end],\n[data-position~=left],\n[data-position~=right],\n[data-position$=\" start\"],\n[data-position$=\" end\"])) {\n padding-inline: var(--sbb-tooltip-gap);\n}\n\n.sbb-tooltip {\n box-shadow: var(--sbb-box-shadow-level-5-soft);\n border: var(--sbb-border-width-1x) solid var(--sbb-tooltip-border-color);\n border-radius: var(--sbb-tooltip-border-radius);\n padding: var(--sbb-tooltip-padding);\n color: var(--sbb-tooltip-color);\n background-color: var(--sbb-tooltip-background-color);\n min-width: var(--sbb-tooltip-min-width);\n max-width: var(--sbb-tooltip-max-width);\n}\n\n@keyframes open {\n from {\n opacity: 0;\n translate: var(--sbb-tooltip-animation-translate);\n }\n to {\n opacity: 1;\n translate: 0;\n }\n}\n@keyframes close {\n from {\n opacity: 1;\n translate: 0;\n }\n to {\n opacity: 0;\n translate: var(--sbb-tooltip-animation-translate);\n }\n}";
|
|
7
|
+
//#endregion
|
|
8
|
+
//#region src/elements/tooltip/tooltip.component.ts
|
|
9
|
+
/**
|
|
10
|
+
* Time between the user putting the pointer on a tooltip
|
|
11
|
+
* trigger and the long press event being fired.
|
|
12
|
+
*/
|
|
13
|
+
var LONGPRESS_DELAY = 500;
|
|
14
|
+
var isMobile = isAndroid || isIOS;
|
|
15
|
+
var tooltipTriggers = /* @__PURE__ */ new WeakMap();
|
|
16
|
+
/**
|
|
17
|
+
* It displays text content within a tooltip.
|
|
18
|
+
*
|
|
19
|
+
* @slot - Use the unnamed slot to add the text into the tooltip.
|
|
20
|
+
* @cssprop [--sbb-overlay-position-area=block-end] - The primary position for the tooltip.
|
|
21
|
+
* @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] -
|
|
22
|
+
* The list of fallback positions, separated by ',', for the tooltip
|
|
23
|
+
* @cssprop [--sbb-tooltip-z-index=var(--sbb-overlay-default-z-index)] - To specify a custom stack order,
|
|
24
|
+
* the `z-index` can be overridden by defining this CSS variable. The default `z-index` of the
|
|
25
|
+
* component is set to `var(--sbb-overlay-default-z-index)` with a value of `1000`.
|
|
26
|
+
*/
|
|
27
|
+
var SbbTooltipElement = (() => {
|
|
28
|
+
let _classSuper = SbbDisabledMixin(SbbOpenCloseBaseElement);
|
|
29
|
+
let _instanceExtraInitializers = [];
|
|
30
|
+
let _trigger_decorators;
|
|
31
|
+
let _trigger_initializers = [];
|
|
32
|
+
let _trigger_extraInitializers = [];
|
|
33
|
+
let _set_openDelay_decorators;
|
|
34
|
+
let _set_closeDelay_decorators;
|
|
35
|
+
let _set_longPressCloseDelay_decorators;
|
|
36
|
+
return class SbbTooltipElement extends _classSuper {
|
|
37
|
+
static {
|
|
38
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
39
|
+
_trigger_decorators = [idReference(), property()];
|
|
40
|
+
_set_openDelay_decorators = [property({
|
|
41
|
+
attribute: "open-delay",
|
|
42
|
+
type: Number
|
|
43
|
+
})];
|
|
44
|
+
_set_closeDelay_decorators = [property({
|
|
45
|
+
attribute: "close-delay",
|
|
46
|
+
type: Number
|
|
47
|
+
})];
|
|
48
|
+
_set_longPressCloseDelay_decorators = [property({
|
|
49
|
+
attribute: "long-press-close-delay",
|
|
50
|
+
type: Number
|
|
51
|
+
})];
|
|
52
|
+
__esDecorate(this, null, _trigger_decorators, {
|
|
53
|
+
kind: "accessor",
|
|
54
|
+
name: "trigger",
|
|
55
|
+
static: false,
|
|
56
|
+
private: false,
|
|
57
|
+
access: {
|
|
58
|
+
has: (obj) => "trigger" in obj,
|
|
59
|
+
get: (obj) => obj.trigger,
|
|
60
|
+
set: (obj, value) => {
|
|
61
|
+
obj.trigger = value;
|
|
62
|
+
}
|
|
63
|
+
},
|
|
64
|
+
metadata: _metadata
|
|
65
|
+
}, _trigger_initializers, _trigger_extraInitializers);
|
|
66
|
+
__esDecorate(this, null, _set_openDelay_decorators, {
|
|
67
|
+
kind: "setter",
|
|
68
|
+
name: "openDelay",
|
|
69
|
+
static: false,
|
|
70
|
+
private: false,
|
|
71
|
+
access: {
|
|
72
|
+
has: (obj) => "openDelay" in obj,
|
|
73
|
+
set: (obj, value) => {
|
|
74
|
+
obj.openDelay = value;
|
|
75
|
+
}
|
|
76
|
+
},
|
|
77
|
+
metadata: _metadata
|
|
78
|
+
}, null, _instanceExtraInitializers);
|
|
79
|
+
__esDecorate(this, null, _set_closeDelay_decorators, {
|
|
80
|
+
kind: "setter",
|
|
81
|
+
name: "closeDelay",
|
|
82
|
+
static: false,
|
|
83
|
+
private: false,
|
|
84
|
+
access: {
|
|
85
|
+
has: (obj) => "closeDelay" in obj,
|
|
86
|
+
set: (obj, value) => {
|
|
87
|
+
obj.closeDelay = value;
|
|
88
|
+
}
|
|
89
|
+
},
|
|
90
|
+
metadata: _metadata
|
|
91
|
+
}, null, _instanceExtraInitializers);
|
|
92
|
+
__esDecorate(this, null, _set_longPressCloseDelay_decorators, {
|
|
93
|
+
kind: "setter",
|
|
94
|
+
name: "longPressCloseDelay",
|
|
95
|
+
static: false,
|
|
96
|
+
private: false,
|
|
97
|
+
access: {
|
|
98
|
+
has: (obj) => "longPressCloseDelay" in obj,
|
|
99
|
+
set: (obj, value) => {
|
|
100
|
+
obj.longPressCloseDelay = value;
|
|
101
|
+
}
|
|
102
|
+
},
|
|
103
|
+
metadata: _metadata
|
|
104
|
+
}, null, _instanceExtraInitializers);
|
|
105
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, {
|
|
106
|
+
enumerable: true,
|
|
107
|
+
configurable: true,
|
|
108
|
+
writable: true,
|
|
109
|
+
value: _metadata
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
static {
|
|
113
|
+
this.elementName = "sbb-tooltip";
|
|
114
|
+
}
|
|
115
|
+
static {
|
|
116
|
+
this.role = "tooltip";
|
|
117
|
+
}
|
|
118
|
+
static {
|
|
119
|
+
this.styles = [boxSizingStyles, unsafeCSS(tooltip_default)];
|
|
120
|
+
}
|
|
121
|
+
static {
|
|
122
|
+
if (!isServer) queueDomContentLoaded(() => this._initializeTooltipOutlet());
|
|
123
|
+
}
|
|
124
|
+
#trigger_accessor_storage;
|
|
125
|
+
/**
|
|
126
|
+
* The element that will trigger the tooltip overlay.
|
|
127
|
+
*
|
|
128
|
+
* For attribute usage, provide an id reference.
|
|
129
|
+
*/
|
|
130
|
+
get trigger() {
|
|
131
|
+
return this.#trigger_accessor_storage;
|
|
132
|
+
}
|
|
133
|
+
set trigger(value) {
|
|
134
|
+
this.#trigger_accessor_storage = value;
|
|
135
|
+
}
|
|
136
|
+
/**
|
|
137
|
+
* Open the tooltip after a given delay in milliseconds.
|
|
138
|
+
* Global configuration is used as default, if not set.
|
|
139
|
+
*
|
|
140
|
+
* @default null
|
|
141
|
+
*/
|
|
142
|
+
set openDelay(value) {
|
|
143
|
+
this._openDelay = value;
|
|
144
|
+
}
|
|
145
|
+
get openDelay() {
|
|
146
|
+
return this._openDelay ?? readConfig().tooltip?.openDelay ?? 0;
|
|
147
|
+
}
|
|
148
|
+
/**
|
|
149
|
+
* Close the tooltip after a given delay in milliseconds.
|
|
150
|
+
* Global configuration is used as default, if not set.
|
|
151
|
+
*
|
|
152
|
+
* @default null
|
|
153
|
+
*/
|
|
154
|
+
set closeDelay(value) {
|
|
155
|
+
this._closeDelay = value;
|
|
156
|
+
}
|
|
157
|
+
get closeDelay() {
|
|
158
|
+
return this._closeDelay ?? readConfig().tooltip?.closeDelay ?? 0;
|
|
159
|
+
}
|
|
160
|
+
/**
|
|
161
|
+
* Automatically close the tooltip after it has been open by long press.
|
|
162
|
+
* Global configuration is used as default, if not set.
|
|
163
|
+
*
|
|
164
|
+
* @default 1500
|
|
165
|
+
*/
|
|
166
|
+
set longPressCloseDelay(value) {
|
|
167
|
+
this._longPressCloseDelay = +value;
|
|
168
|
+
}
|
|
169
|
+
get longPressCloseDelay() {
|
|
170
|
+
return this._longPressCloseDelay ?? readConfig().tooltip?.longPressCloseDelay ?? 1500;
|
|
171
|
+
}
|
|
172
|
+
constructor() {
|
|
173
|
+
super();
|
|
174
|
+
this.#trigger_accessor_storage = (__runInitializers(this, _instanceExtraInitializers), __runInitializers(this, _trigger_initializers, null));
|
|
175
|
+
this._openDelay = (__runInitializers(this, _trigger_extraInitializers), null);
|
|
176
|
+
this._closeDelay = null;
|
|
177
|
+
this._triggerElement = null;
|
|
178
|
+
this._escapableOverlayController = new SbbEscapableOverlayController(this);
|
|
179
|
+
this._overlayController = new SbbOverlayPositionController(this);
|
|
180
|
+
this.addEventListener("mouseleave", (event) => {
|
|
181
|
+
if ((this.state === "opened" || this.state === "opening") && (!event.relatedTarget || !this._triggerElement?.contains(event.relatedTarget))) this._delayedClose();
|
|
182
|
+
}, { passive: true });
|
|
183
|
+
this.addEventListener("overlayOutsidePointer", () => this.close(), { passive: true });
|
|
184
|
+
this.addEventListener("animationend", (e) => this._onTooltipAnimationEnd(e), { passive: true });
|
|
185
|
+
}
|
|
186
|
+
static _initializeTooltipOutlet() {
|
|
187
|
+
this._tooltipOutlet = document.createElement("div");
|
|
188
|
+
this._tooltipOutlet.classList.add("sbb-overlay-outlet");
|
|
189
|
+
document.body.appendChild(this._tooltipOutlet);
|
|
190
|
+
new MutationObserver((mutations) => {
|
|
191
|
+
for (const mutation of mutations) if (mutation.type === "attributes") this._handleTooltipTrigger(mutation.target);
|
|
192
|
+
else if (mutation.type === "childList") for (const node of [...mutation.addedNodes, ...mutation.removedNodes].filter((n) => n.nodeType === n.ELEMENT_NODE)) {
|
|
193
|
+
this._handleTooltipTrigger(node);
|
|
194
|
+
this._findAndHandleTooltipTriggers(node);
|
|
195
|
+
}
|
|
196
|
+
}).observe(document.documentElement, {
|
|
197
|
+
attributeFilter: [
|
|
198
|
+
"sbb-tooltip",
|
|
199
|
+
"sbb-tooltip-open-delay",
|
|
200
|
+
"sbb-tooltip-close-delay",
|
|
201
|
+
"sbb-tooltip-position"
|
|
202
|
+
],
|
|
203
|
+
childList: true,
|
|
204
|
+
subtree: true
|
|
205
|
+
});
|
|
206
|
+
this._findAndHandleTooltipTriggers(document.body);
|
|
207
|
+
}
|
|
208
|
+
static _findAndHandleTooltipTriggers(root) {
|
|
209
|
+
root.querySelectorAll("[sbb-tooltip]").forEach((e) => this._handleTooltipTrigger(e));
|
|
210
|
+
}
|
|
211
|
+
static _handleTooltipTrigger(triggerElement) {
|
|
212
|
+
const tooltipMessage = triggerElement.getAttribute("sbb-tooltip");
|
|
213
|
+
let tooltip = tooltipTriggers.get(triggerElement);
|
|
214
|
+
if (tooltipMessage && triggerElement.isConnected) {
|
|
215
|
+
if (!tooltip) {
|
|
216
|
+
tooltip = document.createElement("sbb-tooltip");
|
|
217
|
+
tooltipTriggers.set(triggerElement, tooltip);
|
|
218
|
+
this._tooltipOutlet.appendChild(tooltip);
|
|
219
|
+
tooltip.trigger = triggerElement;
|
|
220
|
+
}
|
|
221
|
+
tooltip.textContent = tooltipMessage;
|
|
222
|
+
tooltip.openDelay = triggerElement.hasAttribute("sbb-tooltip-open-delay") ? +triggerElement.getAttribute("sbb-tooltip-open-delay") : null;
|
|
223
|
+
tooltip.closeDelay = triggerElement.hasAttribute("sbb-tooltip-close-delay") ? +triggerElement.getAttribute("sbb-tooltip-close-delay") : null;
|
|
224
|
+
const positions = triggerElement.hasAttribute("sbb-tooltip-position") ? triggerElement.getAttribute("sbb-tooltip-position").split(",").map((p) => p.trim()) : triggerElement.tooltipPositions;
|
|
225
|
+
if (positions && positions.length > 0) {
|
|
226
|
+
tooltip.style.setProperty("--sbb-overlay-position-area", positions[0]);
|
|
227
|
+
tooltip.style.setProperty("--sbb-overlay-position-try-fallbacks", positions.slice(1).join(", "));
|
|
228
|
+
} else {
|
|
229
|
+
tooltip.style.removeProperty("--sbb-overlay-position-area");
|
|
230
|
+
tooltip.style.removeProperty("--sbb-overlay-position-try-fallbacks");
|
|
231
|
+
}
|
|
232
|
+
} else if (tooltip) {
|
|
233
|
+
tooltipTriggers.delete(triggerElement);
|
|
234
|
+
tooltip._destroy?.();
|
|
235
|
+
}
|
|
236
|
+
}
|
|
237
|
+
connectedCallback() {
|
|
238
|
+
super.connectedCallback();
|
|
239
|
+
this.popover = "manual";
|
|
240
|
+
this.state = "closed";
|
|
241
|
+
sbbOverlayOutsidePointerEventListener.connect(this);
|
|
242
|
+
if (this.hasUpdated && this.trigger) this._attach(this.trigger);
|
|
243
|
+
}
|
|
244
|
+
disconnectedCallback() {
|
|
245
|
+
super.disconnectedCallback();
|
|
246
|
+
sbbOverlayOutsidePointerEventListener.disconnect(this);
|
|
247
|
+
this._detach();
|
|
248
|
+
}
|
|
249
|
+
requestUpdate(name, oldValue, options) {
|
|
250
|
+
super.requestUpdate(name, oldValue, options);
|
|
251
|
+
if (isServer) return;
|
|
252
|
+
if ((!name || name === "trigger") && this.hasUpdated) this._attach(this.trigger);
|
|
253
|
+
}
|
|
254
|
+
firstUpdated(changedProperties) {
|
|
255
|
+
super.firstUpdated(changedProperties);
|
|
256
|
+
this._attach(this.trigger);
|
|
257
|
+
}
|
|
258
|
+
open() {
|
|
259
|
+
this._resetOpenCloseTimeout();
|
|
260
|
+
if (this.state !== "closed" && this.state !== "closing" || this.disabled || !this.trigger || !this.dispatchBeforeOpenEvent()) return;
|
|
261
|
+
this.showPopover?.();
|
|
262
|
+
this.state = "opening";
|
|
263
|
+
this._overlayController.connect(this.trigger);
|
|
264
|
+
if (this._isZeroAnimationDuration()) this._handleOpening();
|
|
265
|
+
}
|
|
266
|
+
close() {
|
|
267
|
+
this._resetOpenCloseTimeout();
|
|
268
|
+
if (this.state !== "opened" && this.state !== "opening") return;
|
|
269
|
+
this.dispatchBeforeCloseEvent();
|
|
270
|
+
this.state = "closing";
|
|
271
|
+
if (this._isZeroAnimationDuration()) this._handleClosing();
|
|
272
|
+
}
|
|
273
|
+
_delayedOpen() {
|
|
274
|
+
this._resetOpenCloseTimeout();
|
|
275
|
+
this._openTimeout = setTimeout(() => this.open(), this.openDelay);
|
|
276
|
+
}
|
|
277
|
+
_handleOpening() {
|
|
278
|
+
this.state = "opened";
|
|
279
|
+
this._escapableOverlayController.connect();
|
|
280
|
+
this.dispatchOpenEvent();
|
|
281
|
+
}
|
|
282
|
+
_delayedClose() {
|
|
283
|
+
this._resetOpenCloseTimeout();
|
|
284
|
+
this._closeTimeout = setTimeout(() => this.close(), this.closeDelay);
|
|
285
|
+
}
|
|
286
|
+
_handleClosing() {
|
|
287
|
+
this.state = "closed";
|
|
288
|
+
this.hidePopover?.();
|
|
289
|
+
this._overlayController.disconnect();
|
|
290
|
+
this._escapableOverlayController.disconnect();
|
|
291
|
+
this.dispatchCloseEvent();
|
|
292
|
+
this._openStateController?.abort();
|
|
293
|
+
}
|
|
294
|
+
_onTooltipAnimationEnd(event) {
|
|
295
|
+
if (event.animationName === "open" && this.state === "opening") this._handleOpening();
|
|
296
|
+
else if (event.animationName === "close" && this.state === "closing") this._handleClosing();
|
|
297
|
+
}
|
|
298
|
+
_attach(trigger) {
|
|
299
|
+
if (this._triggerElement) this._detach();
|
|
300
|
+
this._triggerElement = trigger;
|
|
301
|
+
if (!this._triggerElement) return;
|
|
302
|
+
this._triggerElement.ariaDescribedByElements = appendAriaElements(this._triggerElement.ariaDescribedByElements, this);
|
|
303
|
+
this._addTriggerEventHandlers();
|
|
304
|
+
}
|
|
305
|
+
_detach() {
|
|
306
|
+
this._triggerAbortController?.abort();
|
|
307
|
+
this._openStateController?.abort();
|
|
308
|
+
this._resetOpenCloseTimeout();
|
|
309
|
+
clearTimeout(this._longPressOpenTimeout);
|
|
310
|
+
clearTimeout(this._longPressCloseTimeout);
|
|
311
|
+
if (!this._triggerElement) return;
|
|
312
|
+
this._triggerElement.ariaDescribedByElements = removeAriaElements(this._triggerElement.ariaDescribedByElements, this);
|
|
313
|
+
this._triggerElement = null;
|
|
314
|
+
}
|
|
315
|
+
_destroy() {
|
|
316
|
+
this._detach();
|
|
317
|
+
this.remove();
|
|
318
|
+
}
|
|
319
|
+
_addTriggerEventHandlers() {
|
|
320
|
+
const trigger = this._triggerElement;
|
|
321
|
+
if (!trigger) return;
|
|
322
|
+
this._triggerAbortController?.abort();
|
|
323
|
+
this._triggerAbortController = new AbortController();
|
|
324
|
+
const options = {
|
|
325
|
+
signal: this._triggerAbortController.signal,
|
|
326
|
+
passive: true
|
|
327
|
+
};
|
|
328
|
+
if (!isMobile) {
|
|
329
|
+
trigger.addEventListener("mouseenter", () => this._delayedOpen(), options);
|
|
330
|
+
trigger.addEventListener("mouseleave", (event) => {
|
|
331
|
+
const newTarget = event.relatedTarget;
|
|
332
|
+
if (!newTarget || newTarget !== this) this._delayedClose();
|
|
333
|
+
}, options);
|
|
334
|
+
trigger.addEventListener("blur", () => this.close(), options);
|
|
335
|
+
trigger.addEventListener("focus", () => this._delayedOpen(), options);
|
|
336
|
+
}
|
|
337
|
+
trigger.addEventListener("touchstart", () => {
|
|
338
|
+
clearTimeout(this._longPressOpenTimeout);
|
|
339
|
+
clearTimeout(this._longPressCloseTimeout);
|
|
340
|
+
this._longPressOpenTimeout = setTimeout(() => this.open(), LONGPRESS_DELAY);
|
|
341
|
+
}, options);
|
|
342
|
+
trigger.addEventListener("touchend", () => {
|
|
343
|
+
clearTimeout(this._longPressOpenTimeout);
|
|
344
|
+
this._longPressCloseTimeout = setTimeout(() => this.close(), this.longPressCloseDelay);
|
|
345
|
+
}, options);
|
|
346
|
+
trigger.addEventListener("touchcancel", () => {
|
|
347
|
+
clearTimeout(this._longPressOpenTimeout);
|
|
348
|
+
}, options);
|
|
349
|
+
}
|
|
350
|
+
_isZeroAnimationDuration() {
|
|
351
|
+
return isZeroAnimationDuration(this, "--sbb-tooltip-animation-duration");
|
|
352
|
+
}
|
|
353
|
+
_resetOpenCloseTimeout() {
|
|
354
|
+
clearTimeout(this._openTimeout);
|
|
355
|
+
clearTimeout(this._closeTimeout);
|
|
356
|
+
}
|
|
357
|
+
render() {
|
|
358
|
+
return html`
|
|
359
|
+
<div class="sbb-tooltip">
|
|
360
|
+
<slot></slot>
|
|
361
|
+
</div>
|
|
362
|
+
`;
|
|
363
|
+
}
|
|
364
|
+
};
|
|
365
|
+
})();
|
|
366
|
+
//#endregion
|
|
367
|
+
export { SbbTooltipElement as t };
|
|
368
|
+
|
|
369
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"tooltip.component-lvElko6C.js","names":[],"sources":["../../../src/elements/tooltip/tooltip.scss?inline","../../../src/elements/tooltip/tooltip.component.ts"],"sourcesContent":["@use '../core/styles' as sbb;\n\n:host {\n  --sbb-tooltip-max-width: min(\n    #{sbb.px-to-rem-build(400)},\n    calc(100vw - var(--sbb-spacing-fixed-2x))\n  );\n  --sbb-tooltip-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-4x)\n  );\n\n  position-area: var(--sbb-overlay-position-area);\n  position-try-fallbacks: var(--sbb-overlay-position-try-fallbacks);\n  display: none;\n  position: fixed;\n  background-color: transparent;\n  pointer-events: var(--sbb-tooltip-pointer-events, all);\n  z-index: var(--sbb-tooltip-z-index, var(--sbb-overlay-default-z-index));\n  animation-name: var(--sbb-tooltip-animation-name);\n  animation-duration: var(--sbb-tooltip-animation-duration);\n  animation-timing-function: var(--sbb-tooltip-animation-easing);\n  font-size: var(--sbb-tooltip-font-size);\n  letter-spacing: var(--sbb-typo-letter-spacing-text);\n\n  // Reset [popover] styles\n  border: none;\n  inset: initial;\n  padding: 0;\n  margin: 0;\n}\n\n:host(:is(:state(state-opening), :state(state-opened), :state(state-closing))) {\n  --sbb-tooltip-animation-name: open;\n\n  display: block;\n}\n\n:host(:state(state-closing)) {\n  --sbb-tooltip-animation-name: close;\n  --sbb-tooltip-pointer-events: none;\n}\n\n:host(:is([data-position~='block-end'], [data-position~='bottom'], [data-position^='end'])) {\n  padding-block-start: var(--sbb-tooltip-gap);\n}\n\n:host(:is([data-position~='block-start'], [data-position~='top'], [data-position^='start'])) {\n  padding-block-end: var(--sbb-tooltip-gap);\n}\n\n:host(\n  :is(\n    [data-position~='inline-start'],\n    [data-position~='inline-end'],\n    [data-position~='left'],\n    [data-position~='right'],\n    [data-position$=' start'],\n    [data-position$=' end']\n  )\n) {\n  // Add a gap on both sides to distance the tooltip from the trigger and the edge of the viewport.\n  padding-inline: var(--sbb-tooltip-gap);\n}\n\n.sbb-tooltip {\n  box-shadow: var(--sbb-box-shadow-level-5-soft);\n  border: var(--sbb-border-width-1x) solid var(--sbb-tooltip-border-color);\n  border-radius: var(--sbb-tooltip-border-radius);\n  padding: var(--sbb-tooltip-padding);\n  color: var(--sbb-tooltip-color);\n  background-color: var(--sbb-tooltip-background-color);\n  min-width: var(--sbb-tooltip-min-width);\n  max-width: var(--sbb-tooltip-max-width);\n}\n\n@keyframes open {\n  from {\n    opacity: 0;\n    translate: var(--sbb-tooltip-animation-translate);\n  }\n\n  to {\n    opacity: 1;\n    translate: 0;\n  }\n}\n\n@keyframes close {\n  from {\n    opacity: 1;\n    translate: 0;\n  }\n\n  to {\n    opacity: 0;\n    translate: var(--sbb-tooltip-animation-translate);\n  }\n}\n","import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  type PropertyDeclaration,\n  type PropertyValues,\n  type TemplateResult,\n  unsafeCSS,\n} from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport {\n  appendAriaElements,\n  boxSizingStyles,\n  idReference,\n  isAndroid,\n  isIOS,\n  isZeroAnimationDuration,\n  queueDomContentLoaded,\n  readConfig,\n  removeAriaElements,\n  SbbDisabledMixin,\n  SbbEscapableOverlayController,\n  SbbOpenCloseBaseElement,\n  sbbOverlayOutsidePointerEventListener,\n  SbbOverlayPositionController,\n} from '../core.ts';\n\nimport style from './tooltip.scss?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>();\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 class SbbTooltipElement extends SbbDisabledMixin(SbbOpenCloseBaseElement) {\n  public static override readonly elementName: string = 'sbb-tooltip';\n  public static override readonly role = 'tooltip';\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(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      // If a consumer overrides the `sbb-tooltip`, the following code should not be\n      // executed as we can't expect that private methods are mocked.\n      tooltip._destroy?.();\n    }\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.popover = 'manual';\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    this._triggerElement.ariaDescribedByElements = appendAriaElements(\n      this._triggerElement.ariaDescribedByElements,\n      this,\n    );\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    this._triggerElement.ariaDescribedByElements = removeAriaElements(\n      this._triggerElement.ariaDescribedByElements,\n      this,\n    );\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"],"mappings":"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"}
|
package/development/tooltip.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as SbbTooltipElement } from "./tooltip.component-
|
|
1
|
+
import { t as SbbTooltipElement } from "./tooltip.component-lvElko6C.js";
|
|
2
2
|
export { SbbTooltipElement };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { n as e, r as t, t as n } from "../../dialog.component-
|
|
1
|
+
import { n as e, r as t, t as n } from "../../dialog.component-DTbAHlVd.js";
|
|
2
2
|
export { n as SbbDialogCloseEvent, e as SbbDialogElement, t as assignDialogResult };
|
|
@@ -8,12 +8,12 @@ import { ref as l } from "lit/directives/ref.js";
|
|
|
8
8
|
import { SbbOverlayBaseElement as u, SbbOverlayCloseEvent as d, overlayRefs as f } from "./overlay.pure.js";
|
|
9
9
|
import { SbbOverlayCloseEvent as p, assignOverlayResult as m } from "./overlay/overlay-base-element.js";
|
|
10
10
|
//#region src/elements/dialog/dialog/dialog.scss?inline
|
|
11
|
-
var h = ":host{--sbb-dialog-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-6x) );--sbb-dialog-padding-block: var(--sbb-spacing-responsive-xs);--sbb-dialog-shadow-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-4x) );display:none;position:fixed;inset:var(--sbb-dialog-inset);z-index:var(--sbb-dialog-z-index, var(--sbb-overlay-default-z-index))}@media(min-width:64rem){:host{--sbb-dialog-max-width: min( calc(100vw - var(--sbb-spacing-fixed-30x) * 2), var(--sbb-dialog-max-width-default) )}}:host(:is(:state(top-shadow),[state--top-shadow])){--sbb-dialog-block-start-box-shadow: var(--_sbb-dialog-block-shadow)}:host(:is(:is(:state(state-opening),[state--state-opening]),:is(:state(state-opened),[state--state-opened]),:is(:state(state-closing),[state--state-closing]))){display:block}:host(:is(:is(:state(state-opening),[state--state-opening]),:is(:state(state-opened),[state--state-opened]))){--sbb-dialog-pointer-events: all;--sbb-dialog-backdrop-color: var(--sbb-background-color-3)}@media(min-width:64rem){:host(:is(:is(:state(state-opening),[state--state-opening]),:is(:state(state-opened),[state--state-opened]))){--sbb-dialog-backdrop-visibility: visible;--sbb-dialog-backdrop-pointer-events: all}}:host([backdrop=translucent]:is(:is(:state(state-opening),[state--state-opening]),:is(:state(state-opened),[state--state-opened]))){--sbb-dialog-backdrop-color: color-mix(in srgb, var(--sbb-color-black) 50%, transparent)}:host([backdrop=opaque]:not([negative]):is(:is(:state(state-opening),[state--state-opening]),:is(:state(state-opened),[state--state-opened]))){--sbb-dialog-backdrop-color: var(--sbb-background-color-3)}:host(:not([negative])){--_sbb-dialog-color: var(--sbb-dialog-color);--_sbb-dialog-block-shadow: var(--sbb-dialog-block-shadow);--sbb-dialog-actions-border-color: var(--sbb-background-color-4);--sbb-dialog-background-color: var(--sbb-background-color-1)}:host([negative]){--_sbb-dialog-color: var(--sbb-dialog-color-negative);--_sbb-dialog-block-shadow: var(--sbb-dialog-block-shadow-negative);--sbb-dialog-background-color: var(--sbb-background-color-1-negative);--sbb-dialog-actions-border-color: var(--sbb-background-color-4-negative);--sbb-dialog-backdrop-color: var(--sbb-background-color-3-negative);--sbb-focus-outline-color: var(--sbb-focus-outline-color-dark)}:host(:is(:state(bottom-shadow),[state--bottom-shadow])){--sbb-dialog-block-end-box-shadow: var(--_sbb-dialog-block-shadow);--sbb-dialog-actions-border-color: transparent}:host(:not(:is(:state(state-closed),[state--state-closed]))){--sbb-dialog-inset: 0}.sbb-dialog__container{pointer-events:var(--sbb-dialog-pointer-events);display:flex;align-items:center;position:fixed;inset:var(--sbb-dialog-inset)}.sbb-dialog__container:before{content:\"\";visibility:var(--sbb-dialog-backdrop-visibility);pointer-events:var(--sbb-dialog-backdrop-pointer-events);position:fixed;inset:var(--sbb-dialog-inset);background-color:var(--sbb-dialog-backdrop-color);transition-duration:var(--sbb-dialog-animation-duration);transition-timing-function:var(--sbb-dialog-animation-easing);transition-property:background-color,visibility}.sbb-dialog{display:none;position:absolute;inset-inline:0;margin:auto;padding:0;border:none;width:var(--sbb-dialog-width);height:var(--sbb-dialog-height);max-width:var(--sbb-dialog-max-width);max-height:var(--sbb-dialog-max-height);color:var(--_sbb-dialog-color);background-color:var(--sbb-dialog-background-color)}:host(:is(:is(:state(state-opening),[state--state-opening]),:is(:state(state-opened),[state--state-opened]),:is(:state(state-closing),[state--state-closing]))) .sbb-dialog{display:block;animation-name:open;animation-duration:var(--sbb-dialog-animation-duration);animation-timing-function:ease}:host(:is(:state(state-closing),[state--state-closing])) .sbb-dialog{pointer-events:none;animation-name:close}@media(forced-colors:active){.sbb-dialog{outline:var(--sbb-border-width-1x) solid CanvasText}}@media(min-width:64rem){.sbb-dialog{border-radius:var(--sbb-dialog-border-radius);overflow:hidden;height:auto}}:host(:is(:state(has-intermediate-element),[state--has-intermediate-element])) ::slotted(:first-child),.sbb-dialog__wrapper{width:var(--sbb-dialog-width);height:var(--sbb-dialog-height);max-width:var(--sbb-dialog-max-width);max-height:var(--sbb-dialog-max-height)}:host(:is(:state(has-intermediate-element),[state--has-intermediate-element])) ::slotted(:first-child),:host(:not(:is(:state(has-intermediate-element),[state--has-intermediate-element]))) .sbb-dialog__wrapper{display:grid;grid-template:\"title close-button\" auto \"content content\" 1fr \"actions actions\" auto/1fr auto;gap:0}@keyframes open{0%{opacity:0;translate:0 var(--sbb-spacing-fixed-4x)}to{opacity:1;translate:0}}@keyframes close{0%{opacity:1;translate:0}to{opacity:0;translate:0 var(--sbb-spacing-fixed-4x)}}", g =
|
|
12
|
-
let p = u, m,
|
|
11
|
+
var h = ":host{--sbb-dialog-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-6x) );--sbb-dialog-padding-block: var(--sbb-spacing-responsive-xs);--sbb-dialog-shadow-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-4x) );display:none;position:fixed;inset:var(--sbb-dialog-inset);z-index:var(--sbb-dialog-z-index, var(--sbb-overlay-default-z-index))}@media(min-width:64rem){:host{--sbb-dialog-max-width: min( calc(100vw - var(--sbb-spacing-fixed-30x) * 2), var(--sbb-dialog-max-width-default) )}}:host(:is(:state(top-shadow),[state--top-shadow])){--sbb-dialog-block-start-box-shadow: var(--_sbb-dialog-block-shadow)}:host(:is(:is(:state(state-opening),[state--state-opening]),:is(:state(state-opened),[state--state-opened]),:is(:state(state-closing),[state--state-closing]))){display:block}:host(:is(:is(:state(state-opening),[state--state-opening]),:is(:state(state-opened),[state--state-opened]))){--sbb-dialog-pointer-events: all;--sbb-dialog-backdrop-color: var(--sbb-background-color-3)}@media(min-width:64rem){:host(:is(:is(:state(state-opening),[state--state-opening]),:is(:state(state-opened),[state--state-opened]))){--sbb-dialog-backdrop-visibility: visible;--sbb-dialog-backdrop-pointer-events: all}}:host([backdrop=translucent]:is(:is(:state(state-opening),[state--state-opening]),:is(:state(state-opened),[state--state-opened]))){--sbb-dialog-backdrop-color: color-mix(in srgb, var(--sbb-color-black) 50%, transparent)}:host([backdrop=opaque]:not([negative]):is(:is(:state(state-opening),[state--state-opening]),:is(:state(state-opened),[state--state-opened]))){--sbb-dialog-backdrop-color: var(--sbb-background-color-3)}:host(:not([negative])){--_sbb-dialog-color: var(--sbb-dialog-color);--_sbb-dialog-block-shadow: var(--sbb-dialog-block-shadow);--sbb-dialog-actions-border-color: var(--sbb-background-color-4);--sbb-dialog-background-color: var(--sbb-background-color-1)}:host([negative]){--_sbb-dialog-color: var(--sbb-dialog-color-negative);--_sbb-dialog-block-shadow: var(--sbb-dialog-block-shadow-negative);--sbb-dialog-background-color: var(--sbb-background-color-1-negative);--sbb-dialog-actions-border-color: var(--sbb-background-color-4-negative);--sbb-dialog-backdrop-color: var(--sbb-background-color-3-negative);--sbb-focus-outline-color: var(--sbb-focus-outline-color-dark)}:host(:is(:state(bottom-shadow),[state--bottom-shadow])){--sbb-dialog-block-end-box-shadow: var(--_sbb-dialog-block-shadow);--sbb-dialog-actions-border-color: transparent}:host(:not(:is(:state(state-closed),[state--state-closed]))){--sbb-dialog-inset: 0}.sbb-dialog__container{pointer-events:var(--sbb-dialog-pointer-events);display:flex;align-items:center;position:fixed;inset:var(--sbb-dialog-inset)}.sbb-dialog__container:before{content:\"\";visibility:var(--sbb-dialog-backdrop-visibility);pointer-events:var(--sbb-dialog-backdrop-pointer-events);position:fixed;inset:var(--sbb-dialog-inset);background-color:var(--sbb-dialog-backdrop-color);transition-duration:var(--sbb-dialog-animation-duration);transition-timing-function:var(--sbb-dialog-animation-easing);transition-property:background-color,visibility}.sbb-dialog{display:none;position:absolute;inset-inline:0;margin:auto;padding:0;border:none;width:var(--sbb-dialog-width);height:var(--sbb-dialog-height);max-width:var(--sbb-dialog-max-width);max-height:var(--sbb-dialog-max-height);color:var(--_sbb-dialog-color);background-color:var(--sbb-dialog-background-color)}:host(:is(:is(:state(state-opening),[state--state-opening]),:is(:state(state-opened),[state--state-opened]),:is(:state(state-closing),[state--state-closing]))) .sbb-dialog{display:block;animation-name:open;animation-duration:var(--sbb-dialog-animation-duration);animation-timing-function:ease}:host(:is(:state(state-closing),[state--state-closing])) .sbb-dialog{pointer-events:none;animation-name:close}@media(forced-colors:active){.sbb-dialog{outline:var(--sbb-border-width-1x) solid CanvasText}}@media(min-width:64rem){.sbb-dialog{border-radius:var(--sbb-dialog-border-radius);overflow:hidden;height:auto}}:host(:is(:state(has-intermediate-element),[state--has-intermediate-element])) ::slotted(:first-child),.sbb-dialog__wrapper{width:var(--sbb-dialog-width);height:var(--sbb-dialog-height);max-width:var(--sbb-dialog-max-width);max-height:var(--sbb-dialog-max-height)}:host(:is(:state(has-intermediate-element),[state--has-intermediate-element])) ::slotted(:first-child),:host(:not(:is(:state(has-intermediate-element),[state--has-intermediate-element]))) .sbb-dialog__wrapper{display:grid;grid-template:\"title close-button\" auto \"content content\" 1fr \"actions actions\" auto/1fr auto;gap:0}@keyframes open{0%{opacity:0;translate:0 var(--sbb-spacing-fixed-4x)}to{opacity:1;translate:0}}@keyframes close{0%{opacity:1;translate:0}to{opacity:0;translate:0 var(--sbb-spacing-fixed-4x)}}", g = (() => {
|
|
12
|
+
let p = u, m, g = [], _ = [], v, y = [], b = [];
|
|
13
13
|
return class extends p {
|
|
14
14
|
static {
|
|
15
15
|
let t = typeof Symbol == "function" && Symbol.metadata ? Object.create(p[Symbol.metadata] ?? null) : void 0;
|
|
16
|
-
m = [r({ attribute: "backdrop-action" })],
|
|
16
|
+
m = [r({ attribute: "backdrop-action" })], v = [r({
|
|
17
17
|
attribute: "backdrop",
|
|
18
18
|
reflect: !0
|
|
19
19
|
})], e(this, null, m, {
|
|
@@ -29,7 +29,7 @@ var h = ":host{--sbb-dialog-animation-duration: var( --sbb-disable-animation-dur
|
|
|
29
29
|
}
|
|
30
30
|
},
|
|
31
31
|
metadata: t
|
|
32
|
-
},
|
|
32
|
+
}, g, _), e(this, null, v, {
|
|
33
33
|
kind: "accessor",
|
|
34
34
|
name: "backdrop",
|
|
35
35
|
static: !1,
|
|
@@ -42,7 +42,7 @@ var h = ":host{--sbb-dialog-animation-duration: var( --sbb-disable-animation-dur
|
|
|
42
42
|
}
|
|
43
43
|
},
|
|
44
44
|
metadata: t
|
|
45
|
-
},
|
|
45
|
+
}, y, b), t && Object.defineProperty(this, Symbol.metadata, {
|
|
46
46
|
enumerable: !0,
|
|
47
47
|
configurable: !0,
|
|
48
48
|
writable: !0,
|
|
@@ -73,7 +73,7 @@ var h = ":host{--sbb-dialog-animation-duration: var( --sbb-disable-animation-dur
|
|
|
73
73
|
this.#t = e;
|
|
74
74
|
}
|
|
75
75
|
constructor() {
|
|
76
|
-
super(), this.#e = t(this,
|
|
76
|
+
super(), this.#e = t(this, g, "close"), this.#t = (t(this, _), t(this, y, "opaque")), this._dialogContentResizeObserver = (t(this, b), new c(this, {
|
|
77
77
|
target: null,
|
|
78
78
|
skipInitial: !0,
|
|
79
79
|
callback: () => setTimeout(() => this._updateOverflowState())
|
|
@@ -86,9 +86,6 @@ var h = ":host{--sbb-dialog-animation-duration: var( --sbb-disable-animation-dur
|
|
|
86
86
|
capture: !0
|
|
87
87
|
});
|
|
88
88
|
}
|
|
89
|
-
connectedCallback() {
|
|
90
|
-
this.id ||= `sbb-dialog-${g++}`, super.connectedCallback();
|
|
91
|
-
}
|
|
92
89
|
announceTitle() {
|
|
93
90
|
this.setAriaLiveRefContent(this.accessibilityLabel || this.querySelector("sbb-dialog-title")?.textContent.trim());
|
|
94
91
|
}
|
|
@@ -168,4 +165,4 @@ var h = ":host{--sbb-dialog-animation-duration: var( --sbb-disable-animation-dur
|
|
|
168
165
|
};
|
|
169
166
|
})();
|
|
170
167
|
//#endregion
|
|
171
|
-
export {
|
|
168
|
+
export { g as n, m as r, p as t };
|
package/dialog.js
CHANGED
|
@@ -2,7 +2,7 @@ import { t as e } from "./dialog-actions.component-ConxJ3VW.js";
|
|
|
2
2
|
import { t } from "./dialog-close-button.component-CLWP-IVb.js";
|
|
3
3
|
import { t as n } from "./dialog-content.component-DvJiuDJI.js";
|
|
4
4
|
import { t as r } from "./dialog-title.component-CRGqiwZu.js";
|
|
5
|
-
import { n as i, r as a, t as o } from "./dialog.component-
|
|
5
|
+
import { n as i, r as a, t as o } from "./dialog.component-DTbAHlVd.js";
|
|
6
6
|
import "./dialog.pure.js";
|
|
7
7
|
i.define(), e.define(), t.define(), n.define(), r.define();
|
|
8
8
|
//#endregion
|
package/dialog.pure.js
CHANGED
|
@@ -2,5 +2,5 @@ import { t as e } from "./dialog-actions.component-ConxJ3VW.js";
|
|
|
2
2
|
import { t } from "./dialog-close-button.component-CLWP-IVb.js";
|
|
3
3
|
import { t as n } from "./dialog-content.component-DvJiuDJI.js";
|
|
4
4
|
import { t as r } from "./dialog-title.component-CRGqiwZu.js";
|
|
5
|
-
import { n as i, r as a, t as o } from "./dialog.component-
|
|
5
|
+
import { n as i, r as a, t as o } from "./dialog.component-DTbAHlVd.js";
|
|
6
6
|
export { e as SbbDialogActionsElement, t as SbbDialogCloseButtonElement, o as SbbDialogCloseEvent, n as SbbDialogContentElement, i as SbbDialogElement, r as SbbDialogTitleElement, a as assignDialogResult };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as e } from "../../header.component-
|
|
1
|
+
import { t as e } from "../../header.component-D-WVEMFn.js";
|
|
2
2
|
export { e as SbbHeaderElement };
|
|
@@ -209,8 +209,8 @@ var m = ":host{--sbb-logo-height: 1rem;--sbb-signet-height: 1rem;--sbb-header-tr
|
|
|
209
209
|
if (this.matches(":is(:state(has-visible-focus-within),[state--has-visible-focus-within])")) return;
|
|
210
210
|
let e = Array.from(this.querySelectorAll(h));
|
|
211
211
|
for (let t of e) {
|
|
212
|
-
let e = t.
|
|
213
|
-
typeof
|
|
212
|
+
let e = t.ariaControlsElements[0];
|
|
213
|
+
typeof e?.close == "function" && e.close();
|
|
214
214
|
}
|
|
215
215
|
}
|
|
216
216
|
render() {
|
package/header.js
CHANGED
|
@@ -2,7 +2,7 @@ import { t as e } from "./header-action-common-BOKlGz-X.js";
|
|
|
2
2
|
import { SbbHeaderButtonElement as t } from "./header/header-button/header-button.component.js";
|
|
3
3
|
import { t as n } from "./header-environment.component-BXPJRKXx.js";
|
|
4
4
|
import { SbbHeaderLinkElement as r } from "./header/header-link/header-link.component.js";
|
|
5
|
-
import { t as i } from "./header.component-
|
|
5
|
+
import { t as i } from "./header.component-D-WVEMFn.js";
|
|
6
6
|
import "./header.pure.js";
|
|
7
7
|
i.define(), t.define(), n.define(), r.define();
|
|
8
8
|
//#endregion
|
package/header.pure.js
CHANGED
|
@@ -2,5 +2,5 @@ import { t as e } from "./header-action-common-BOKlGz-X.js";
|
|
|
2
2
|
import { SbbHeaderButtonElement as t } from "./header/header-button/header-button.component.js";
|
|
3
3
|
import { t as n } from "./header-environment.component-BXPJRKXx.js";
|
|
4
4
|
import { SbbHeaderLinkElement as r } from "./header/header-link/header-link.component.js";
|
|
5
|
-
import { t as i } from "./header.component-
|
|
5
|
+
import { t as i } from "./header.component-D-WVEMFn.js";
|
|
6
6
|
export { e as SbbHeaderActionCommonElementMixin, t as SbbHeaderButtonElement, i as SbbHeaderElement, n as SbbHeaderEnvironmentElement, r as SbbHeaderLinkElement };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as e } from "../../menu-action-common-
|
|
1
|
+
import { t as e } from "../../menu-action-common-krzD_Ca2.js";
|
|
2
2
|
export { e as SbbMenuActionCommonElementMixin };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as e } from "../../menu.component-
|
|
1
|
+
import { t as e } from "../../menu.component-i-X_ag2Y.js";
|
|
2
2
|
export { e as SbbMenuElement };
|
|
@@ -2,7 +2,7 @@ import { html as e, unsafeCSS as t } from "lit";
|
|
|
2
2
|
import { SbbDisabledMixin as n, boxSizingStyles as r } from "./core.js";
|
|
3
3
|
import { SbbIconNameMixin as i } from "./icon.pure.js";
|
|
4
4
|
//#region src/elements/menu/common/menu-action.scss?inline
|
|
5
|
-
var a = ":host{--sbb-menu-action-cursor: var(--sbb-cursor-pointer);outline:none!important;display:block}@media(any-hover:hover){:host(:is(:hover:not([disabled],:disabled,[disabled-interactive]),[aria-expanded=true])){--sbb-menu-background-color: var(--sbb-color-iron);--sbb-menu-background-color: light-dark(var(--sbb-color-iron), var(--sbb-color-milk));--sbb-menu-action-forced-color-border-color: Highlight}}:host(:is([disabled],:disabled,[disabled-interactive])){--sbb-menu-action-cursor: var(--sbb-cursor-default);--sbb-menu-action-color: var(--sbb-color-graphite);--sbb-menu-action-color: light-dark(var(--sbb-color-graphite), var(--sbb-color-granite));--sbb-menu-action-forced-color-border-color: GrayText;pointer-events:none;cursor:var(--sbb-cursor-default)}@media(forced-colors:active){:host(:is([disabled],:disabled,[disabled-interactive])){--sbb-menu-action-color: GrayText}}:host(:is(:state(sbb-menu-trigger),[state--sbb-menu-trigger])){--sbb-menu-action-cursor: var(--sbb-cursor-default)}@media(forced-colors:active){:host(:is(:state(button),[state--button])){--sbb-menu-action-color: ButtonText}}:host([sbb-badge]:not(:is(:state(has-icon-name),[state--has-icon-name]),:is(:state(slotted-icon),[state--slotted-icon]))):after{inset:50% calc(100% - var(--sbb-menu-action-outer-horizontal-padding) - var(--sbb-menu-action-content-padding-inline) - .5 * var(--sbb-size-icon-ui-small)) auto auto!important;translate:50% -50%}:host([sbb-badge]:is(:is(:state(has-icon-name),[state--has-icon-name]),:is(:state(slotted-icon),[state--slotted-icon]))):after{inset:calc(var(--sbb-menu-action-outer-vertical-padding) + var(--sbb-menu-action-content-padding-block) + var(--sbb-badge-position-offset)) calc(100% - var(--sbb-menu-action-outer-horizontal-padding) - var(--sbb-menu-action-content-padding-inline) - var(--sbb-size-icon-ui-small) + var(--sbb-badge-position-offset)) auto auto!important}:host([aria-controls
|
|
5
|
+
var a = ":host{--sbb-menu-action-cursor: var(--sbb-cursor-pointer);outline:none!important;display:block}@media(any-hover:hover){:host(:is(:hover:not([disabled],:disabled,[disabled-interactive]),[aria-expanded=true])){--sbb-menu-background-color: var(--sbb-color-iron);--sbb-menu-background-color: light-dark(var(--sbb-color-iron), var(--sbb-color-milk));--sbb-menu-action-forced-color-border-color: Highlight}}:host(:is([disabled],:disabled,[disabled-interactive])){--sbb-menu-action-cursor: var(--sbb-cursor-default);--sbb-menu-action-color: var(--sbb-color-graphite);--sbb-menu-action-color: light-dark(var(--sbb-color-graphite), var(--sbb-color-granite));--sbb-menu-action-forced-color-border-color: GrayText;pointer-events:none;cursor:var(--sbb-cursor-default)}@media(forced-colors:active){:host(:is([disabled],:disabled,[disabled-interactive])){--sbb-menu-action-color: GrayText}}:host(:is(:state(sbb-menu-trigger),[state--sbb-menu-trigger])){--sbb-menu-action-cursor: var(--sbb-cursor-default)}@media(forced-colors:active){:host(:is(:state(button),[state--button])){--sbb-menu-action-color: ButtonText}}:host([sbb-badge]:not(:is(:state(has-icon-name),[state--has-icon-name]),:is(:state(slotted-icon),[state--slotted-icon]))):after{inset:50% calc(100% - var(--sbb-menu-action-outer-horizontal-padding) - var(--sbb-menu-action-content-padding-inline) - .5 * var(--sbb-size-icon-ui-small)) auto auto!important;translate:50% -50%}:host([sbb-badge]:is(:is(:state(has-icon-name),[state--has-icon-name]),:is(:state(slotted-icon),[state--slotted-icon]))):after{inset:calc(var(--sbb-menu-action-outer-vertical-padding) + var(--sbb-menu-action-content-padding-block) + var(--sbb-badge-position-offset)) calc(100% - var(--sbb-menu-action-outer-horizontal-padding) - var(--sbb-menu-action-content-padding-inline) - var(--sbb-size-icon-ui-small) + var(--sbb-badge-position-offset)) auto auto!important}:host([aria-controls]){--sbb-menu-action-submenu-icon-display: flex}:is(.sbb-menu-button,.sbb-menu-link){text-decoration:none;display:block;width:100%;color:var(--sbb-menu-action-color);padding:var(--sbb-menu-action-outer-vertical-padding) var(--sbb-menu-action-outer-horizontal-padding);cursor:var(--sbb-menu-action-cursor);outline:none}.sbb-menu-action__content{--sbb-text-font-size: var(--sbb-text-font-size-xs);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-text);letter-spacing:var(--sbb-typo-letter-spacing-text);font-size:var(--sbb-text-font-size);display:flex;align-items:center;gap:var(--sbb-menu-action-gap);padding:var(--sbb-menu-action-content-padding-block) var(--sbb-menu-action-content-padding-inline);border-radius:var(--sbb-menu-action-border-radius);-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;background-color:var(--sbb-menu-background-color)}:host(:focus-visible) .sbb-menu-action__content,:focus-visible .sbb-menu-action__content{outline-offset:var(--sbb-focus-outline-offset);outline:var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width)}@media(forced-colors:active){.sbb-menu-action__content{border:var(--sbb-border-width-2x) solid var(--sbb-menu-action-forced-color-border-color)}}.sbb-menu-action__icon,.sbb-menu-submenu__icon{display:flex;min-width:var(--sbb-size-icon-ui-small);min-height:var(--sbb-size-icon-ui-small)}.sbb-menu-submenu__icon{display:var(--sbb-menu-action-submenu-icon-display, none);margin-inline-start:auto}.sbb-menu-action__label{overflow:hidden;white-space:nowrap;text-overflow:ellipsis}:host(:is([disabled],:disabled,[disabled-interactive])) .sbb-menu-action__label{text-decoration:line-through}", o = (o) => {
|
|
6
6
|
class s extends i(n(o)) {
|
|
7
7
|
static {
|
|
8
8
|
this.styles = [r, t(a)];
|