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