@sbb-esta/lyne-elements-dev 4.9.0-dev.1774516800 → 4.9.0-dev.1774519787
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/styles/core.scss +6 -2
- package/core.css +7 -0
- package/custom-elements.json +668 -668
- package/development/overlay/overlay.component.js +1 -1
- package/development/overlay.component-H1N5AUm0.js +408 -0
- package/development/overlay.js +1 -1
- package/development/overlay.pure.js +1 -1
- package/off-brand-theme.css +7 -0
- package/overlay/overlay.component.js +1 -1
- package/{overlay.component-CaBxt4sb.js → overlay.component-QYenVZtj.js} +1 -1
- package/overlay.js +1 -1
- package/overlay.pure.js +1 -1
- package/package.json +2 -2
- package/safety-theme.css +7 -0
- package/standard-theme.css +7 -0
- package/development/overlay.component-Btd42clm.js +0 -411
|
@@ -1,411 +0,0 @@
|
|
|
1
|
-
import { SbbOverlayBaseElement, SbbOverlayCloseEvent, overlayRefs } from "./overlay/overlay-base-element.js";
|
|
2
|
-
import { __esDecorate, __runInitializers } from "tslib";
|
|
3
|
-
import { css } from "lit";
|
|
4
|
-
import { property } from "lit/decorators.js";
|
|
5
|
-
import { forceType } from "./core/decorators.js";
|
|
6
|
-
import { isZeroAnimationDuration } from "./core/dom.js";
|
|
7
|
-
import { forwardEvent } from "./core/eventing.js";
|
|
8
|
-
import { boxSizingStyles } from "./core/styles.js";
|
|
9
|
-
import { html as html$1 } from "lit/static-html.js";
|
|
10
|
-
import { i18nCloseDialog } from "./core/i18n.js";
|
|
11
|
-
import "./button/transparent-button.js";
|
|
12
|
-
import { ref } from "lit/directives/ref.js";
|
|
13
|
-
import "./button/secondary-button.js";
|
|
14
|
-
import "./screen-reader-only.js";
|
|
15
|
-
import "./container.js";
|
|
16
|
-
//#region src/elements/overlay/overlay.scss?lit&inline
|
|
17
|
-
var overlay_default = css`:host {
|
|
18
|
-
--sbb-scrollbar-thumb-width: 0.125rem;
|
|
19
|
-
--sbb-scrollbar-thumb-width-hover: 0.25rem;
|
|
20
|
-
--sbb-scrollbar-width-firefox: thin;
|
|
21
|
-
--sbb-scrollbar-color: color-mix(in srgb, var(--sbb-color-black) 30%, transparent);
|
|
22
|
-
--sbb-scrollbar-color: light-dark(
|
|
23
|
-
color-mix(in srgb, var(--sbb-color-black) 30%, transparent),
|
|
24
|
-
color-mix(in srgb, var(--sbb-color-white) 30%, transparent)
|
|
25
|
-
);
|
|
26
|
-
--sbb-scrollbar-color-hover: color-mix(in srgb, var(--sbb-color-black) 60%, transparent);
|
|
27
|
-
--sbb-scrollbar-color-hover: light-dark(
|
|
28
|
-
color-mix(in srgb, var(--sbb-color-black) 60%, transparent),
|
|
29
|
-
color-mix(in srgb, var(--sbb-color-white) 60%, transparent)
|
|
30
|
-
);
|
|
31
|
-
--sbb-scrollbar-track-color: transparent;
|
|
32
|
-
--sbb-overlay-background-color: var(--sbb-background-color-3);
|
|
33
|
-
--sbb-overlay-height: 100%;
|
|
34
|
-
--sbb-overlay-inset: 0 auto auto 0;
|
|
35
|
-
--sbb-overlay-padding-block: calc(var(--sbb-spacing-fixed-14x) + var(--sbb-spacing-responsive-l));
|
|
36
|
-
--sbb-overlay-animation-duration: var(
|
|
37
|
-
--sbb-disable-animation-duration,
|
|
38
|
-
var(--sbb-animation-duration-6x)
|
|
39
|
-
);
|
|
40
|
-
--sbb-overlay-animation-easing: ease;
|
|
41
|
-
--sbb-overlay-pointer-events: none;
|
|
42
|
-
display: none;
|
|
43
|
-
position: fixed;
|
|
44
|
-
inset: var(--sbb-overlay-inset);
|
|
45
|
-
z-index: var(--sbb-overlay-z-index, var(--sbb-overlay-default-z-index));
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
:host(:is(:is(:state(state-opening),[state--state-opening]), :is(:state(state-opened),[state--state-opened]), :is(:state(state-closing),[state--state-closing]))) {
|
|
49
|
-
display: block;
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
:host(:is(:is(:state(state-opening),[state--state-opening]), :is(:state(state-opened),[state--state-opened]))) {
|
|
53
|
-
--sbb-overlay-pointer-events: all;
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
:host([negative]) {
|
|
57
|
-
--sbb-scrollbar-color: color-mix(in srgb, var(--sbb-color-white) 30%, transparent);
|
|
58
|
-
--sbb-scrollbar-color-hover: color-mix(in srgb, var(--sbb-color-white) 60%, transparent);
|
|
59
|
-
--sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);
|
|
60
|
-
--sbb-overlay-color: var(--sbb-color-1-negative);
|
|
61
|
-
--sbb-overlay-background-color: var(--sbb-background-color-3-negative);
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
:host(:not(:is(:state(state-closed),[state--state-closed]))) {
|
|
65
|
-
--sbb-overlay-inset: 0;
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
.sbb-overlay__container {
|
|
69
|
-
background-color: var(--sbb-overlay-background-color);
|
|
70
|
-
pointer-events: var(--sbb-overlay-pointer-events);
|
|
71
|
-
display: none;
|
|
72
|
-
align-items: center;
|
|
73
|
-
position: fixed;
|
|
74
|
-
inset: var(--sbb-overlay-inset);
|
|
75
|
-
}
|
|
76
|
-
:host(:is(:is(:state(state-opening),[state--state-opening]), :is(:state(state-opened),[state--state-opened]), :is(:state(state-closing),[state--state-closing]))) .sbb-overlay__container {
|
|
77
|
-
display: flex;
|
|
78
|
-
animation-name: open;
|
|
79
|
-
animation-duration: var(--sbb-overlay-animation-duration);
|
|
80
|
-
animation-timing-function: var(--sbb-overlay-animation-easing);
|
|
81
|
-
}
|
|
82
|
-
:host(:is(:state(state-closing),[state--state-closing])) .sbb-overlay__container {
|
|
83
|
-
pointer-events: none;
|
|
84
|
-
animation-name: close;
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
.sbb-overlay {
|
|
88
|
-
position: absolute;
|
|
89
|
-
inset-inline: 0;
|
|
90
|
-
margin: auto;
|
|
91
|
-
padding: 0;
|
|
92
|
-
border: none;
|
|
93
|
-
height: var(--sbb-overlay-height);
|
|
94
|
-
overflow: auto;
|
|
95
|
-
color: var(--sbb-overlay-color);
|
|
96
|
-
}
|
|
97
|
-
:host(:is(:is(:state(state-opening),[state--state-opening]), :is(:state(state-opened),[state--state-opened]), :is(:state(state-closing),[state--state-closing]))) .sbb-overlay {
|
|
98
|
-
animation-name: open-move-in;
|
|
99
|
-
animation-duration: var(--sbb-overlay-animation-duration);
|
|
100
|
-
animation-timing-function: var(--sbb-overlay-animation-easing);
|
|
101
|
-
}
|
|
102
|
-
:host(:is(:state(state-closing),[state--state-closing])) .sbb-overlay {
|
|
103
|
-
animation-name: close-move-out;
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
.sbb-overlay__wrapper {
|
|
107
|
-
display: flex;
|
|
108
|
-
flex-direction: column;
|
|
109
|
-
width: 100%;
|
|
110
|
-
height: var(--sbb-overlay-height);
|
|
111
|
-
outline: none;
|
|
112
|
-
position: fixed;
|
|
113
|
-
}
|
|
114
|
-
@media (min-width: calc(64rem)) {
|
|
115
|
-
.sbb-overlay__wrapper {
|
|
116
|
-
position: sticky;
|
|
117
|
-
inset-block-start: 0;
|
|
118
|
-
height: auto;
|
|
119
|
-
}
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
.sbb-overlay__header {
|
|
123
|
-
position: absolute;
|
|
124
|
-
inset-inline-start: 0;
|
|
125
|
-
display: flex;
|
|
126
|
-
pointer-events: none;
|
|
127
|
-
align-items: start;
|
|
128
|
-
justify-content: space-between;
|
|
129
|
-
width: 100%;
|
|
130
|
-
padding: var(--sbb-spacing-responsive-xs);
|
|
131
|
-
padding-block-end: 0;
|
|
132
|
-
z-index: 1;
|
|
133
|
-
}
|
|
134
|
-
.sbb-overlay__header * {
|
|
135
|
-
pointer-events: all;
|
|
136
|
-
}
|
|
137
|
-
|
|
138
|
-
.sbb-overlay__close {
|
|
139
|
-
margin-inline-start: auto;
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
.sbb-overlay__content {
|
|
143
|
-
--sbb-scrollbar-width: var(--sbb-spacing-fixed-3x);
|
|
144
|
-
}
|
|
145
|
-
.sbb-overlay__content::-webkit-scrollbar {
|
|
146
|
-
width: var(--sbb-scrollbar-width);
|
|
147
|
-
height: var(--sbb-scrollbar-width);
|
|
148
|
-
background-color: var(--sbb-scrollbar-track-color, transparent);
|
|
149
|
-
}
|
|
150
|
-
.sbb-overlay__content::-webkit-scrollbar-corner {
|
|
151
|
-
background-color: var(--sbb-scrollbar-track-color, transparent);
|
|
152
|
-
}
|
|
153
|
-
.sbb-overlay__content::-webkit-scrollbar-thumb {
|
|
154
|
-
background-color: var(--sbb-scrollbar-color, currentcolor);
|
|
155
|
-
border: calc(0.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width))) solid transparent;
|
|
156
|
-
border-radius: var(--sbb-border-radius-4x);
|
|
157
|
-
background-clip: padding-box;
|
|
158
|
-
}
|
|
159
|
-
.sbb-overlay__content::-webkit-scrollbar-thumb:hover {
|
|
160
|
-
background-color: var(--sbb-scrollbar-color-hover, currentcolor);
|
|
161
|
-
border-width: calc(0.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width-hover)));
|
|
162
|
-
}
|
|
163
|
-
.sbb-overlay__content::-webkit-scrollbar-button, .sbb-overlay__content::-webkit-scrollbar-corner {
|
|
164
|
-
display: none;
|
|
165
|
-
}
|
|
166
|
-
@supports not selector(::-webkit-scrollbar) {
|
|
167
|
-
.sbb-overlay__content {
|
|
168
|
-
scrollbar-width: var(--sbb-scrollbar-width-firefox);
|
|
169
|
-
scrollbar-color: var(--sbb-scrollbar-color, currentcolor) var(--sbb-scrollbar-track-color, transparent);
|
|
170
|
-
}
|
|
171
|
-
}
|
|
172
|
-
.sbb-overlay__content {
|
|
173
|
-
height: 100vh;
|
|
174
|
-
overflow: auto;
|
|
175
|
-
-webkit-overflow-scrolling: touch;
|
|
176
|
-
}
|
|
177
|
-
|
|
178
|
-
.sbb-overlay__content-container {
|
|
179
|
-
padding-block: var(--sbb-overlay-padding-block);
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
@keyframes open {
|
|
183
|
-
from {
|
|
184
|
-
opacity: 0;
|
|
185
|
-
}
|
|
186
|
-
to {
|
|
187
|
-
opacity: 1;
|
|
188
|
-
}
|
|
189
|
-
}
|
|
190
|
-
@keyframes open-move-in {
|
|
191
|
-
from {
|
|
192
|
-
transform: translateY(var(--sbb-spacing-fixed-4x));
|
|
193
|
-
}
|
|
194
|
-
to {
|
|
195
|
-
transform: translateY(0%);
|
|
196
|
-
}
|
|
197
|
-
}
|
|
198
|
-
@keyframes close {
|
|
199
|
-
from {
|
|
200
|
-
opacity: 1;
|
|
201
|
-
}
|
|
202
|
-
to {
|
|
203
|
-
opacity: 0;
|
|
204
|
-
}
|
|
205
|
-
}
|
|
206
|
-
@keyframes close-move-out {
|
|
207
|
-
from {
|
|
208
|
-
transform: translateY(0%);
|
|
209
|
-
}
|
|
210
|
-
to {
|
|
211
|
-
transform: translateY(var(--sbb-spacing-fixed-4x));
|
|
212
|
-
}
|
|
213
|
-
}`;
|
|
214
|
-
//#endregion
|
|
215
|
-
//#region src/elements/overlay/overlay.component.ts
|
|
216
|
-
var nextId = 0;
|
|
217
|
-
/**
|
|
218
|
-
* It displays an interactive overlay element.
|
|
219
|
-
*
|
|
220
|
-
* @slot - Use the unnamed slot to provide a content for the overlay.
|
|
221
|
-
* @cssprop [--sbb-overlay-z-index=var(--sbb-overlay-default-z-index)] - To specify a custom stack order,
|
|
222
|
-
* the `z-index` can be overridden by defining this CSS variable. The default `z-index` of the
|
|
223
|
-
* component is set to `var(--sbb-overlay-default-z-index)` with a value of `1000`.
|
|
224
|
-
*/
|
|
225
|
-
var SbbOverlayElement = (() => {
|
|
226
|
-
let _classSuper = SbbOverlayBaseElement;
|
|
227
|
-
let _expanded_decorators;
|
|
228
|
-
let _expanded_initializers = [];
|
|
229
|
-
let _expanded_extraInitializers = [];
|
|
230
|
-
let _accessibilityCloseLabel_decorators;
|
|
231
|
-
let _accessibilityCloseLabel_initializers = [];
|
|
232
|
-
let _accessibilityCloseLabel_extraInitializers = [];
|
|
233
|
-
return class SbbOverlayElement extends _classSuper {
|
|
234
|
-
constructor() {
|
|
235
|
-
super(...arguments);
|
|
236
|
-
this.#expanded_accessor_storage = __runInitializers(this, _expanded_initializers, false);
|
|
237
|
-
this.#accessibilityCloseLabel_accessor_storage = (__runInitializers(this, _expanded_extraInitializers), __runInitializers(this, _accessibilityCloseLabel_initializers, ""));
|
|
238
|
-
this.closeAttribute = (__runInitializers(this, _accessibilityCloseLabel_extraInitializers), "sbb-overlay-close");
|
|
239
|
-
this._overlayContentElement = null;
|
|
240
|
-
}
|
|
241
|
-
static {
|
|
242
|
-
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
243
|
-
_expanded_decorators = [forceType(), property({
|
|
244
|
-
reflect: true,
|
|
245
|
-
type: Boolean
|
|
246
|
-
})];
|
|
247
|
-
_accessibilityCloseLabel_decorators = [forceType(), property({ attribute: "accessibility-close-label" })];
|
|
248
|
-
__esDecorate(this, null, _expanded_decorators, {
|
|
249
|
-
kind: "accessor",
|
|
250
|
-
name: "expanded",
|
|
251
|
-
static: false,
|
|
252
|
-
private: false,
|
|
253
|
-
access: {
|
|
254
|
-
has: (obj) => "expanded" in obj,
|
|
255
|
-
get: (obj) => obj.expanded,
|
|
256
|
-
set: (obj, value) => {
|
|
257
|
-
obj.expanded = value;
|
|
258
|
-
}
|
|
259
|
-
},
|
|
260
|
-
metadata: _metadata
|
|
261
|
-
}, _expanded_initializers, _expanded_extraInitializers);
|
|
262
|
-
__esDecorate(this, null, _accessibilityCloseLabel_decorators, {
|
|
263
|
-
kind: "accessor",
|
|
264
|
-
name: "accessibilityCloseLabel",
|
|
265
|
-
static: false,
|
|
266
|
-
private: false,
|
|
267
|
-
access: {
|
|
268
|
-
has: (obj) => "accessibilityCloseLabel" in obj,
|
|
269
|
-
get: (obj) => obj.accessibilityCloseLabel,
|
|
270
|
-
set: (obj, value) => {
|
|
271
|
-
obj.accessibilityCloseLabel = value;
|
|
272
|
-
}
|
|
273
|
-
},
|
|
274
|
-
metadata: _metadata
|
|
275
|
-
}, _accessibilityCloseLabel_initializers, _accessibilityCloseLabel_extraInitializers);
|
|
276
|
-
if (_metadata) Object.defineProperty(this, Symbol.metadata, {
|
|
277
|
-
enumerable: true,
|
|
278
|
-
configurable: true,
|
|
279
|
-
writable: true,
|
|
280
|
-
value: _metadata
|
|
281
|
-
});
|
|
282
|
-
}
|
|
283
|
-
static {
|
|
284
|
-
this.elementName = "sbb-overlay";
|
|
285
|
-
}
|
|
286
|
-
static {
|
|
287
|
-
this.styles = [boxSizingStyles, overlay_default];
|
|
288
|
-
}
|
|
289
|
-
static {
|
|
290
|
-
this.events = {
|
|
291
|
-
beforeopen: "beforeopen",
|
|
292
|
-
open: "open",
|
|
293
|
-
beforeclose: "beforeclose",
|
|
294
|
-
close: "close"
|
|
295
|
-
};
|
|
296
|
-
}
|
|
297
|
-
#expanded_accessor_storage;
|
|
298
|
-
/**
|
|
299
|
-
* Whether to allow the overlay content to stretch to full width.
|
|
300
|
-
* By default, the content has the appropriate page size.
|
|
301
|
-
*/
|
|
302
|
-
get expanded() {
|
|
303
|
-
return this.#expanded_accessor_storage;
|
|
304
|
-
}
|
|
305
|
-
set expanded(value) {
|
|
306
|
-
this.#expanded_accessor_storage = value;
|
|
307
|
-
}
|
|
308
|
-
#accessibilityCloseLabel_accessor_storage;
|
|
309
|
-
/** This will be forwarded as aria-label to the close button element. */
|
|
310
|
-
get accessibilityCloseLabel() {
|
|
311
|
-
return this.#accessibilityCloseLabel_accessor_storage;
|
|
312
|
-
}
|
|
313
|
-
set accessibilityCloseLabel(value) {
|
|
314
|
-
this.#accessibilityCloseLabel_accessor_storage = value;
|
|
315
|
-
}
|
|
316
|
-
connectedCallback() {
|
|
317
|
-
this.id ||= `sbb-overlay-${nextId++}`;
|
|
318
|
-
super.connectedCallback();
|
|
319
|
-
}
|
|
320
|
-
firstUpdated(changedProperties) {
|
|
321
|
-
super.firstUpdated(changedProperties);
|
|
322
|
-
if (this.isOpen) this.setAriaLiveRefContent();
|
|
323
|
-
}
|
|
324
|
-
isZeroAnimationDuration() {
|
|
325
|
-
return isZeroAnimationDuration(this, "--sbb-overlay-animation-duration");
|
|
326
|
-
}
|
|
327
|
-
handleOpening() {
|
|
328
|
-
this.state = "opened";
|
|
329
|
-
this.inertController.activate();
|
|
330
|
-
this.focusTrapController.focusInitialElement();
|
|
331
|
-
setTimeout(() => this.setAriaLiveRefContent(this.accessibilityLabel));
|
|
332
|
-
this.focusTrapController.enabled = true;
|
|
333
|
-
this.dispatchOpenEvent();
|
|
334
|
-
}
|
|
335
|
-
handleClosing() {
|
|
336
|
-
this._overlayContentElement?.scrollTo(0, 0);
|
|
337
|
-
this.state = "closed";
|
|
338
|
-
this.hidePopover?.();
|
|
339
|
-
this.inertController.deactivate();
|
|
340
|
-
if (!this.skipFocusRestoration) this.lastFocusedElement?.focus();
|
|
341
|
-
this.openOverlayController?.abort();
|
|
342
|
-
this.focusTrapController.enabled = false;
|
|
343
|
-
this.removeInstanceFromGlobalCollection();
|
|
344
|
-
if (!overlayRefs.length) this.scrollHandler.enableScroll();
|
|
345
|
-
this.escapableOverlayController.disconnect();
|
|
346
|
-
this.dispatchCloseEvent({
|
|
347
|
-
returnValue: this.returnValue,
|
|
348
|
-
closeTarget: this.overlayCloseElement
|
|
349
|
-
});
|
|
350
|
-
}
|
|
351
|
-
dispatchBeforeCloseEvent(_detail) {
|
|
352
|
-
/** @type {SbbOverlayCloseEvent} Emits whenever the component begins the closing transition. Can be canceled. */
|
|
353
|
-
return this.dispatchEvent(new SbbOverlayCloseEvent("beforeclose", {
|
|
354
|
-
cancelable: true,
|
|
355
|
-
closeAttribute: this.closeAttribute,
|
|
356
|
-
closeTarget: this.overlayCloseElement,
|
|
357
|
-
result: this.returnValue
|
|
358
|
-
}));
|
|
359
|
-
}
|
|
360
|
-
dispatchCloseEvent(_detail) {
|
|
361
|
-
/** @type {SbbOverlayCloseEvent} Emits whenever the component is closed. */
|
|
362
|
-
return this.dispatchEvent(new SbbOverlayCloseEvent("close", {
|
|
363
|
-
closeAttribute: this.closeAttribute,
|
|
364
|
-
closeTarget: this.overlayCloseElement,
|
|
365
|
-
result: this.returnValue
|
|
366
|
-
}));
|
|
367
|
-
}
|
|
368
|
-
render() {
|
|
369
|
-
return html$1`
|
|
370
|
-
<div class="sbb-overlay__container" @animationend=${this.onOverlayAnimationEnd}>
|
|
371
|
-
<div class="sbb-overlay">
|
|
372
|
-
<div
|
|
373
|
-
@click=${(event) => this.closeOnSbbOverlayCloseClick(event)}
|
|
374
|
-
class="sbb-overlay__wrapper"
|
|
375
|
-
>
|
|
376
|
-
<div class="sbb-overlay__header">
|
|
377
|
-
<sbb-secondary-button
|
|
378
|
-
class="sbb-overlay__close"
|
|
379
|
-
aria-label="${this.accessibilityCloseLabel || i18nCloseDialog[this.language.current]}"
|
|
380
|
-
?negative=${this.negative}
|
|
381
|
-
size="m"
|
|
382
|
-
type="button"
|
|
383
|
-
icon-name="cross-small"
|
|
384
|
-
sbb-overlay-close
|
|
385
|
-
></sbb-secondary-button>
|
|
386
|
-
</div>
|
|
387
|
-
<div
|
|
388
|
-
class="sbb-overlay__content"
|
|
389
|
-
${ref((el) => this._overlayContentElement = el)}
|
|
390
|
-
@scroll=${(e) => forwardEvent(e, document)}
|
|
391
|
-
>
|
|
392
|
-
<sbb-container
|
|
393
|
-
class="sbb-overlay__content-container"
|
|
394
|
-
?expanded=${this.expanded}
|
|
395
|
-
color="transparent"
|
|
396
|
-
>
|
|
397
|
-
<slot></slot>
|
|
398
|
-
</sbb-container>
|
|
399
|
-
</div>
|
|
400
|
-
</div>
|
|
401
|
-
</div>
|
|
402
|
-
</div>
|
|
403
|
-
<sbb-screen-reader-only aria-live="polite"></sbb-screen-reader-only>
|
|
404
|
-
`;
|
|
405
|
-
}
|
|
406
|
-
};
|
|
407
|
-
})();
|
|
408
|
-
//#endregion
|
|
409
|
-
export { SbbOverlayElement as t };
|
|
410
|
-
|
|
411
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"overlay.component-Btd42clm.js","names":[],"sources":["../../../src/elements/overlay/overlay.scss?lit&inline","../../../src/elements/overlay/overlay.component.ts"],"sourcesContent":["@use '../core/styles' as sbb;\n\n:host {\n  @include sbb.scrollbar-variables;\n\n  --sbb-overlay-background-color: var(--sbb-background-color-3);\n  --sbb-overlay-height: 100%;\n  --sbb-overlay-inset: 0 auto auto 0;\n  --sbb-overlay-padding-block: calc(var(--sbb-spacing-fixed-14x) + var(--sbb-spacing-responsive-l));\n  --sbb-overlay-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-6x)\n  );\n  --sbb-overlay-animation-easing: ease;\n  --sbb-overlay-pointer-events: none;\n\n  display: none;\n  position: fixed;\n  inset: var(--sbb-overlay-inset);\n  z-index: var(--sbb-overlay-z-index, var(--sbb-overlay-default-z-index));\n}\n\n:host(:is(:state(state-opening), :state(state-opened), :state(state-closing))) {\n  display: block;\n}\n\n:host(:is(:state(state-opening), :state(state-opened))) {\n  --sbb-overlay-pointer-events: all;\n}\n\n:host([negative]) {\n  @include sbb.scrollbar-variables--color-negative;\n\n  --sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);\n  --sbb-overlay-color: var(--sbb-color-1-negative);\n  --sbb-overlay-background-color: var(--sbb-background-color-3-negative);\n}\n\n:host(:not(:state(state-closed))) {\n  --sbb-overlay-inset: 0;\n}\n\n.sbb-overlay__container {\n  background-color: var(--sbb-overlay-background-color);\n  pointer-events: var(--sbb-overlay-pointer-events);\n  display: none;\n  align-items: center;\n  position: fixed;\n  inset: var(--sbb-overlay-inset);\n\n  :host(:is(:state(state-opening), :state(state-opened), :state(state-closing))) & {\n    display: flex;\n    animation: {\n      name: open;\n      duration: var(--sbb-overlay-animation-duration);\n      timing-function: var(--sbb-overlay-animation-easing);\n    }\n  }\n\n  :host(:state(state-closing)) & {\n    pointer-events: none;\n    animation-name: close;\n  }\n}\n\n.sbb-overlay {\n  position: absolute;\n  inset-inline: 0;\n  margin: auto;\n  padding: 0;\n  border: none;\n  height: var(--sbb-overlay-height);\n  overflow: auto;\n  color: var(--sbb-overlay-color);\n\n  :host(:is(:state(state-opening), :state(state-opened), :state(state-closing))) & {\n    animation: {\n      name: open-move-in;\n      duration: var(--sbb-overlay-animation-duration);\n      timing-function: var(--sbb-overlay-animation-easing);\n    }\n  }\n\n  :host(:state(state-closing)) & {\n    animation-name: close-move-out;\n  }\n}\n\n.sbb-overlay__wrapper {\n  display: flex;\n  flex-direction: column;\n  width: 100%;\n  height: var(--sbb-overlay-height);\n  outline: none;\n  position: fixed;\n\n  @include sbb.mq($from: large) {\n    position: sticky;\n    inset-block-start: 0;\n    height: auto;\n  }\n}\n\n.sbb-overlay__header {\n  position: absolute;\n  inset-inline-start: 0;\n  display: flex;\n  pointer-events: none;\n  align-items: start;\n  justify-content: space-between;\n  width: 100%;\n  padding: var(--sbb-spacing-responsive-xs);\n  padding-block-end: 0;\n  z-index: 1;\n\n  * {\n    pointer-events: all;\n  }\n}\n\n.sbb-overlay__close {\n  margin-inline-start: auto;\n}\n\n.sbb-overlay__content {\n  @include sbb.scrollbar-rules;\n\n  height: 100vh;\n  overflow: auto;\n  -webkit-overflow-scrolling: touch;\n}\n\n.sbb-overlay__content-container {\n  padding-block: var(--sbb-overlay-padding-block);\n}\n\n// It is necessary to use animations with keyframes instead of transitions in order not to alter\n// the default `display: block` of the modal otherwise it causes several problems,\n// especially for accessibility.\n@keyframes open {\n  from {\n    opacity: 0;\n  }\n\n  to {\n    opacity: 1;\n  }\n}\n\n@keyframes open-move-in {\n  from {\n    transform: translateY(var(--sbb-spacing-fixed-4x));\n  }\n\n  to {\n    transform: translateY(0%);\n  }\n}\n\n@keyframes close {\n  from {\n    opacity: 1;\n  }\n\n  to {\n    opacity: 0;\n  }\n}\n\n@keyframes close-move-out {\n  from {\n    transform: translateY(0%);\n  }\n\n  to {\n    transform: translateY(var(--sbb-spacing-fixed-4x));\n  }\n}\n","import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\nimport { html } from 'lit/static-html.js';\n\nimport { forceType } from '../core/decorators.ts';\nimport { isZeroAnimationDuration } from '../core/dom.ts';\nimport { forwardEvent } from '../core/eventing.ts';\nimport { i18nCloseDialog } from '../core/i18n.ts';\nimport type { SbbOverlayCloseEventDetails } from '../core/interfaces.ts';\nimport { boxSizingStyles } from '../core/styles.ts';\n\nimport {\n  overlayRefs,\n  SbbOverlayBaseElement,\n  SbbOverlayCloseEvent,\n} from './overlay-base-element.ts';\nimport style from './overlay.scss?lit&inline';\n\nimport '../button/secondary-button.ts';\nimport '../button/transparent-button.ts';\nimport '../container.ts';\nimport '../screen-reader-only.ts';\n\nlet nextId = 0;\n\n/**\n * It displays an interactive overlay element.\n *\n * @slot - Use the unnamed slot to provide a content for the overlay.\n * @cssprop [--sbb-overlay-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 SbbOverlayElement extends SbbOverlayBaseElement {\n  public static override readonly elementName: string = 'sbb-overlay';\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n\n  // TODO: fix using ...super.events requires: https://github.com/sbb-design-systems/lyne-components/issues/2600\n  public static override readonly events = {\n    beforeopen: 'beforeopen',\n    open: 'open',\n    beforeclose: 'beforeclose',\n    close: 'close',\n  } as const;\n\n  /**\n   * Whether to allow the overlay content to stretch to full width.\n   * By default, the content has the appropriate page size.\n   */\n  @forceType()\n  @property({ reflect: true, type: Boolean })\n  public accessor expanded: boolean = false;\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  protected closeAttribute: string = 'sbb-overlay-close';\n  private _overlayContentElement: HTMLElement | null = null;\n\n  public override connectedCallback(): void {\n    this.id ||= `sbb-overlay-${nextId++}`;\n\n    super.connectedCallback();\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    // If the component is already open on firstUpdate, announce the title\n    if (this.isOpen) {\n      this.setAriaLiveRefContent();\n    }\n  }\n\n  protected isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-overlay-animation-duration');\n  }\n\n  protected handleOpening(): void {\n    this.state = 'opened';\n    this.inertController.activate();\n    this.focusTrapController.focusInitialElement();\n    // Use timeout to read label after focused element\n    setTimeout(() => this.setAriaLiveRefContent(this.accessibilityLabel));\n    this.focusTrapController.enabled = true;\n    this.dispatchOpenEvent();\n  }\n\n  protected override handleClosing(): void {\n    this._overlayContentElement?.scrollTo(0, 0);\n    this.state = 'closed';\n    this.hidePopover?.();\n    this.inertController.deactivate();\n    if (!this.skipFocusRestoration) {\n      // Manually focus last focused element\n      this.lastFocusedElement?.focus();\n    }\n    this.openOverlayController?.abort();\n    this.focusTrapController.enabled = false;\n    this.removeInstanceFromGlobalCollection();\n    // Enable scrolling for content below the overlay if no overlay is open\n    if (!overlayRefs.length) {\n      this.scrollHandler.enableScroll();\n    }\n    this.escapableOverlayController.disconnect();\n    this.dispatchCloseEvent({\n      returnValue: this.returnValue,\n      closeTarget: this.overlayCloseElement,\n    });\n  }\n\n  // TODO: remove parameter `detail`\n  protected override dispatchBeforeCloseEvent(_detail?: SbbOverlayCloseEventDetails): boolean {\n    /** @type {SbbOverlayCloseEvent} Emits whenever the component begins the closing transition. Can be canceled. */\n    return this.dispatchEvent(\n      new SbbOverlayCloseEvent('beforeclose', {\n        cancelable: true,\n        closeAttribute: this.closeAttribute,\n        closeTarget: this.overlayCloseElement,\n        result: this.returnValue,\n      }),\n    );\n  }\n\n  // TODO: remove parameter `detail`\n  protected override dispatchCloseEvent(_detail?: SbbOverlayCloseEventDetails): boolean {\n    /** @type {SbbOverlayCloseEvent} Emits whenever the component is closed. */\n    return this.dispatchEvent(\n      new SbbOverlayCloseEvent('close', {\n        closeAttribute: this.closeAttribute,\n        closeTarget: this.overlayCloseElement,\n        result: this.returnValue,\n      }),\n    );\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-overlay__container\" @animationend=${this.onOverlayAnimationEnd}>\n        <div class=\"sbb-overlay\">\n          <div\n            @click=${(event: Event) => this.closeOnSbbOverlayCloseClick(event)}\n            class=\"sbb-overlay__wrapper\"\n          >\n            <div class=\"sbb-overlay__header\">\n              <sbb-secondary-button\n                class=\"sbb-overlay__close\"\n                aria-label=\"${this.accessibilityCloseLabel ||\n                i18nCloseDialog[this.language.current]}\"\n                ?negative=${this.negative}\n                size=\"m\"\n                type=\"button\"\n                icon-name=\"cross-small\"\n                sbb-overlay-close\n              ></sbb-secondary-button>\n            </div>\n            <div\n              class=\"sbb-overlay__content\"\n              ${ref((el?: Element) => (this._overlayContentElement = el as HTMLDivElement))}\n              @scroll=${(e: Event) => forwardEvent(e, document)}\n            >\n              <sbb-container\n                class=\"sbb-overlay__content-container\"\n                ?expanded=${this.expanded}\n                color=\"transparent\"\n              >\n                <slot></slot>\n              </sbb-container>\n            </div>\n          </div>\n        </div>\n      </div>\n      <sbb-screen-reader-only aria-live=\"polite\"></sbb-screen-reader-only>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-overlay': SbbOverlayElement;\n  }\n}\n"],"mappings":"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"}
|