@sbb-esta/lyne-elements-dev 5.0.0-next-dev.1776960216 → 5.0.0-next-dev.1777019159

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (34) hide show
  1. package/alert/alert/alert.component.js +1 -1
  2. package/alert/alert-group/alert-group.component.js +1 -1
  3. package/{alert-group.component-CAjj3FtE.js → alert-group.component-BCYOVicl.js} +5 -7
  4. package/alert.component-BQsF0R1M.js +161 -0
  5. package/alert.js +2 -2
  6. package/alert.pure.js +2 -2
  7. package/core/styles/core.scss +11 -1
  8. package/core.css +28 -8
  9. package/custom-elements.json +618 -618
  10. package/development/alert/alert/alert.component.d.ts +1 -0
  11. package/development/alert/alert/alert.component.d.ts.map +1 -1
  12. package/development/alert/alert/alert.component.js +1 -1
  13. package/development/alert/alert-group/alert-group.component.d.ts.map +1 -1
  14. package/development/alert/alert-group/alert-group.component.js +1 -1
  15. package/development/alert-group.component-D4KxKTd2.js +186 -0
  16. package/development/alert.component-Pv-Ol6XU.js +213 -0
  17. package/development/alert.js +2 -2
  18. package/development/alert.pure.js +2 -2
  19. package/development/dialog/dialog/dialog.component.js +1 -1
  20. package/development/dialog.component-BTXyWi17.js +233 -0
  21. package/development/dialog.js +1 -1
  22. package/development/dialog.pure.js +1 -1
  23. package/dialog/dialog/dialog.component.js +1 -1
  24. package/{dialog.component-DTbAHlVd.js → dialog.component-ChB9gCyY.js} +1 -1
  25. package/dialog.js +1 -1
  26. package/dialog.pure.js +1 -1
  27. package/off-brand-theme.css +28 -8
  28. package/package.json +2 -2
  29. package/safety-theme.css +28 -8
  30. package/standard-theme.css +28 -8
  31. package/alert.component-C42LwoGa.js +0 -163
  32. package/development/alert-group.component-DeI6kuwn.js +0 -188
  33. package/development/alert.component-Cn36k_Hf.js +0 -214
  34. package/development/dialog.component-B4cZfRCl.js +0 -233
@@ -1,233 +0,0 @@
1
- import { __esDecorate, __runInitializers } from "tslib";
2
- import { unsafeCSS } from "lit";
3
- import { property } from "lit/decorators.js";
4
- import { SbbScreenReaderOnlyElement, boxSizingStyles, isZeroAnimationDuration } from "./core.js";
5
- import { html as html$1 } from "lit/static-html.js";
6
- import { ResizeController } from "@lit-labs/observers/resize-controller.js";
7
- import { ref } from "lit/directives/ref.js";
8
- import { SbbOverlayBaseElement, SbbOverlayCloseEvent, overlayRefs } from "./overlay.pure.js";
9
- import { SbbOverlayCloseEvent as SbbDialogCloseEvent, assignOverlayResult as assignDialogResult } from "./overlay/overlay-base-element.js";
10
- //#region src/elements/dialog/dialog/dialog.scss?inline
11
- var dialog_default = ":host {\n --sbb-dialog-animation-duration: var(\n --sbb-disable-animation-duration,\n var(--sbb-animation-duration-6x)\n );\n --sbb-dialog-padding-block: var(--sbb-spacing-responsive-xs);\n --sbb-dialog-shadow-animation-duration: var(\n --sbb-disable-animation-duration,\n var(--sbb-animation-duration-4x)\n );\n display: none;\n position: fixed;\n inset: var(--sbb-dialog-inset);\n z-index: var(--sbb-dialog-z-index, var(--sbb-overlay-default-z-index));\n}\n@media (min-width: calc(64rem)) {\n :host {\n --sbb-dialog-max-width: min(\n calc(100vw - var(--sbb-spacing-fixed-30x) * 2),\n var(--sbb-dialog-max-width-default)\n );\n }\n}\n\n:host(:is(:state(top-shadow),[state--top-shadow])) {\n --sbb-dialog-block-start-box-shadow: var(--_sbb-dialog-block-shadow);\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 display: block;\n}\n\n:host(:is(:is(:state(state-opening),[state--state-opening]), :is(:state(state-opened),[state--state-opened]))) {\n --sbb-dialog-pointer-events: all;\n --sbb-dialog-backdrop-color: var(--sbb-background-color-3);\n}\n@media (min-width: calc(64rem)) {\n :host(:is(:is(:state(state-opening),[state--state-opening]), :is(:state(state-opened),[state--state-opened]))) {\n --sbb-dialog-backdrop-visibility: visible;\n --sbb-dialog-backdrop-pointer-events: all;\n }\n}\n\n:host([backdrop=translucent]:is(:is(:state(state-opening),[state--state-opening]), :is(:state(state-opened),[state--state-opened]))) {\n --sbb-dialog-backdrop-color: color-mix(in srgb, var(--sbb-color-black) 50%, transparent);\n}\n\n:host([backdrop=opaque]:not([negative]):is(:is(:state(state-opening),[state--state-opening]), :is(:state(state-opened),[state--state-opened]))) {\n --sbb-dialog-backdrop-color: var(--sbb-background-color-3);\n}\n\n:host(:not([negative])) {\n --_sbb-dialog-color: var(--sbb-dialog-color);\n --_sbb-dialog-block-shadow: var(--sbb-dialog-block-shadow);\n --sbb-dialog-actions-border-color: var(--sbb-background-color-4);\n --sbb-dialog-background-color: var(--sbb-background-color-1);\n}\n\n:host([negative]) {\n --_sbb-dialog-color: var(--sbb-dialog-color-negative);\n --_sbb-dialog-block-shadow: var(--sbb-dialog-block-shadow-negative);\n --sbb-dialog-background-color: var(--sbb-background-color-1-negative);\n --sbb-dialog-actions-border-color: var(--sbb-background-color-4-negative);\n --sbb-dialog-backdrop-color: var(--sbb-background-color-3-negative);\n --sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);\n}\n\n:host(:is(:state(bottom-shadow),[state--bottom-shadow])) {\n --sbb-dialog-block-end-box-shadow: var(--_sbb-dialog-block-shadow);\n --sbb-dialog-actions-border-color: transparent;\n}\n\n:host(:not(:is(:state(state-closed),[state--state-closed]))) {\n --sbb-dialog-inset: 0;\n}\n\n.sbb-dialog__container {\n pointer-events: var(--sbb-dialog-pointer-events);\n display: flex;\n align-items: center;\n position: fixed;\n inset: var(--sbb-dialog-inset);\n}\n.sbb-dialog__container::before {\n content: \"\";\n visibility: var(--sbb-dialog-backdrop-visibility);\n pointer-events: var(--sbb-dialog-backdrop-pointer-events);\n position: fixed;\n inset: var(--sbb-dialog-inset);\n background-color: var(--sbb-dialog-backdrop-color);\n transition-duration: var(--sbb-dialog-animation-duration);\n transition-timing-function: var(--sbb-dialog-animation-easing);\n transition-property: background-color, visibility;\n}\n\n.sbb-dialog {\n display: none;\n position: absolute;\n inset-inline: 0;\n margin: auto;\n padding: 0;\n border: none;\n width: var(--sbb-dialog-width);\n height: var(--sbb-dialog-height);\n max-width: var(--sbb-dialog-max-width);\n max-height: var(--sbb-dialog-max-height);\n color: var(--_sbb-dialog-color);\n background-color: var(--sbb-dialog-background-color);\n}\n:host(:is(:is(:state(state-opening),[state--state-opening]), :is(:state(state-opened),[state--state-opened]), :is(:state(state-closing),[state--state-closing]))) .sbb-dialog {\n display: block;\n animation-name: open;\n animation-duration: var(--sbb-dialog-animation-duration);\n animation-timing-function: ease;\n}\n:host(:is(:state(state-closing),[state--state-closing])) .sbb-dialog {\n pointer-events: none;\n animation-name: close;\n}\n@media (forced-colors: active) {\n .sbb-dialog {\n outline: var(--sbb-border-width-1x) solid CanvasText;\n }\n}\n@media (min-width: calc(64rem)) {\n .sbb-dialog {\n border-radius: var(--sbb-dialog-border-radius);\n overflow: hidden;\n height: auto;\n }\n}\n\n:host(:is(:state(has-intermediate-element),[state--has-intermediate-element])) ::slotted(:first-child),\n.sbb-dialog__wrapper {\n width: var(--sbb-dialog-width);\n height: var(--sbb-dialog-height);\n max-width: var(--sbb-dialog-max-width);\n max-height: var(--sbb-dialog-max-height);\n}\n\n:host(:is(:state(has-intermediate-element),[state--has-intermediate-element])) ::slotted(:first-child),\n:host(:not(:is(:state(has-intermediate-element),[state--has-intermediate-element]))) .sbb-dialog__wrapper {\n display: grid;\n grid-template: \"title close-button\" auto \"content content\" 1fr \"actions actions\" auto/1fr auto;\n gap: 0;\n}\n\n@keyframes open {\n from {\n opacity: 0;\n translate: 0 var(--sbb-spacing-fixed-4x);\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: 0 var(--sbb-spacing-fixed-4x);\n }\n}";
12
- //#endregion
13
- //#region src/elements/dialog/dialog/dialog.component.ts
14
- /**
15
- * It displays an interactive overlay element.
16
- *
17
- * @slot - Use the unnamed slot to provide a `sbb-dialog-title`, `sbb-dialog-content` and an optional `sbb-dialog-actions`.
18
- * @cssprop [--sbb-dialog-z-index=var(--sbb-overlay-default-z-index)] - To specify a custom stack order,
19
- * the `z-index` can be overridden by defining this CSS variable. The default `z-index` of the
20
- * component is set to `var(--sbb-overlay-default-z-index)` with a value of `1000`.
21
- */
22
- var SbbDialogElement = (() => {
23
- let _classSuper = SbbOverlayBaseElement;
24
- let _backdropAction_decorators;
25
- let _backdropAction_initializers = [];
26
- let _backdropAction_extraInitializers = [];
27
- let _backdrop_decorators;
28
- let _backdrop_initializers = [];
29
- let _backdrop_extraInitializers = [];
30
- return class SbbDialogElement extends _classSuper {
31
- static {
32
- const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
33
- _backdropAction_decorators = [property({ attribute: "backdrop-action" })];
34
- _backdrop_decorators = [property({
35
- attribute: "backdrop",
36
- reflect: true
37
- })];
38
- __esDecorate(this, null, _backdropAction_decorators, {
39
- kind: "accessor",
40
- name: "backdropAction",
41
- static: false,
42
- private: false,
43
- access: {
44
- has: (obj) => "backdropAction" in obj,
45
- get: (obj) => obj.backdropAction,
46
- set: (obj, value) => {
47
- obj.backdropAction = value;
48
- }
49
- },
50
- metadata: _metadata
51
- }, _backdropAction_initializers, _backdropAction_extraInitializers);
52
- __esDecorate(this, null, _backdrop_decorators, {
53
- kind: "accessor",
54
- name: "backdrop",
55
- static: false,
56
- private: false,
57
- access: {
58
- has: (obj) => "backdrop" in obj,
59
- get: (obj) => obj.backdrop,
60
- set: (obj, value) => {
61
- obj.backdrop = value;
62
- }
63
- },
64
- metadata: _metadata
65
- }, _backdrop_initializers, _backdrop_extraInitializers);
66
- if (_metadata) Object.defineProperty(this, Symbol.metadata, {
67
- enumerable: true,
68
- configurable: true,
69
- writable: true,
70
- value: _metadata
71
- });
72
- }
73
- static {
74
- this.elementName = "sbb-dialog";
75
- }
76
- static {
77
- this.elementDependencies = [SbbScreenReaderOnlyElement];
78
- }
79
- static {
80
- this.styles = [boxSizingStyles, unsafeCSS(dialog_default)];
81
- }
82
- #backdropAction_accessor_storage;
83
- /** Backdrop click action. */
84
- get backdropAction() {
85
- return this.#backdropAction_accessor_storage;
86
- }
87
- set backdropAction(value) {
88
- this.#backdropAction_accessor_storage = value;
89
- }
90
- #backdrop_accessor_storage;
91
- /** Backdrop density. */
92
- get backdrop() {
93
- return this.#backdrop_accessor_storage;
94
- }
95
- set backdrop(value) {
96
- this.#backdrop_accessor_storage = value;
97
- }
98
- constructor() {
99
- super();
100
- this.#backdropAction_accessor_storage = __runInitializers(this, _backdropAction_initializers, "close");
101
- this.#backdrop_accessor_storage = (__runInitializers(this, _backdropAction_extraInitializers), __runInitializers(this, _backdrop_initializers, "opaque"));
102
- this._dialogContentResizeObserver = (__runInitializers(this, _backdrop_extraInitializers), new ResizeController(this, {
103
- target: null,
104
- skipInitial: true,
105
- callback: () => setTimeout(() => this._updateOverflowState())
106
- }));
107
- this._isPointerDownEventOnDialog = false;
108
- this.closeAttribute = "sbb-dialog-close";
109
- this.closeTag = "sbb-dialog-close-button";
110
- /** Check if the pointerdown event target is triggered on the dialog. */
111
- this._pointerDownListener = (event) => {
112
- if (this.backdropAction !== "close") return;
113
- this._isPointerDownEventOnDialog = !!this._dialogElement && event.composedPath().includes(this._dialogElement);
114
- };
115
- /** Close dialog on backdrop click. */
116
- this._closeOnBackdropClick = (event) => {
117
- if (this.backdropAction === "close" && !this._isPointerDownEventOnDialog && this._dialogElement && !event.composedPath().includes(this._dialogElement)) this.close();
118
- };
119
- this.addEventListener?.("pointerdown", this._pointerDownListener);
120
- this.addEventListener?.("pointerup", this._closeOnBackdropClick);
121
- this.addEventListener("scroll", () => this._updateOverflowState(), {
122
- passive: true,
123
- capture: true
124
- });
125
- }
126
- /** Announce the accessibility label or dialog title for screen readers. */
127
- announceTitle() {
128
- this.setAriaLiveRefContent(this.accessibilityLabel || this.querySelector("sbb-dialog-title")?.textContent.trim());
129
- }
130
- isZeroAnimationDuration() {
131
- return isZeroAnimationDuration(this, "--sbb-dialog-animation-duration");
132
- }
133
- handleClosing() {
134
- const contentElement = this._contentElement();
135
- contentElement?.scrollTo(0, 0);
136
- this.state = "closed";
137
- this.hidePopover?.();
138
- this.inertController.deactivate();
139
- if (!this.skipFocusRestoration) this.lastFocusedElement?.focus();
140
- this.openOverlayController?.abort();
141
- this.focusTrapController.enabled = false;
142
- if (contentElement) this._dialogContentResizeObserver.hostDisconnected();
143
- this.removeInstanceFromGlobalCollection();
144
- if (!overlayRefs.length) this.scrollHandler.enableScroll();
145
- this.escapableOverlayController.disconnect();
146
- this.dispatchCloseEvent({
147
- returnValue: this.returnValue,
148
- closeTarget: this.overlayCloseElement
149
- });
150
- }
151
- handleOpening() {
152
- this.state = "opened";
153
- this.inertController.activate();
154
- this.focusTrapController.focusInitialElement();
155
- this.focusTrapController.enabled = true;
156
- setTimeout(() => this.announceTitle());
157
- const contentElement = this._contentElement();
158
- if (contentElement) this._dialogContentResizeObserver.observe(contentElement);
159
- this.dispatchOpenEvent();
160
- }
161
- firstUpdated(changedProperties) {
162
- super.firstUpdated(changedProperties);
163
- if (this.isOpen) this.announceTitle();
164
- this._syncTitleNegative();
165
- }
166
- willUpdate(changedProperties) {
167
- super.willUpdate(changedProperties);
168
- if (changedProperties.has("negative")) this._syncTitleNegative();
169
- }
170
- _handleSlotChange() {
171
- this._syncTitleNegative();
172
- this._detectIntermediateElement();
173
- }
174
- _syncTitleNegative() {
175
- const dialogTitle = this.querySelector?.("sbb-dialog-title");
176
- const closeButton = this.querySelector?.("sbb-dialog-close-button");
177
- if (dialogTitle) dialogTitle.negative = this.negative;
178
- if (closeButton) closeButton.negative = this.negative;
179
- }
180
- _detectIntermediateElement() {
181
- const hasNoExpectedDirectChildren = this.querySelector(":scope > :is(sbb-dialog-title, sbb-dialog-close-button, sbb-dialog-content, sbb-dialog-actions)") === null;
182
- this.toggleState("has-intermediate-element", hasNoExpectedDirectChildren);
183
- }
184
- _updateOverflowState() {
185
- const contentElement = this._contentElement();
186
- this.toggleState("top-shadow", (contentElement?.scrollTop ?? 0) > 0);
187
- this.toggleState("bottom-shadow", (contentElement?.scrollTop ?? 0) + (contentElement?.offsetHeight ?? 0) < (contentElement?.scrollHeight ?? 0));
188
- }
189
- _contentElement() {
190
- return this.querySelector("sbb-dialog-content");
191
- }
192
- dispatchBeforeCloseEvent(_detail) {
193
- /** @type {SbbDialogCloseEvent} Emits whenever the component begins the closing transition. Can be canceled. */
194
- return this.dispatchEvent(new SbbOverlayCloseEvent("beforeclose", {
195
- cancelable: true,
196
- closeAttribute: this.closeAttribute,
197
- closeTarget: this.overlayCloseElement,
198
- result: this.returnValue
199
- }));
200
- }
201
- dispatchCloseEvent(_detail) {
202
- /** @type {SbbDialogCloseEvent} Emits whenever the component is closed. */
203
- return this.dispatchEvent(new SbbOverlayCloseEvent("close", {
204
- closeAttribute: this.closeAttribute,
205
- closeTarget: this.overlayCloseElement,
206
- result: this.returnValue
207
- }));
208
- }
209
- render() {
210
- return html$1`
211
- <div class="sbb-dialog__container">
212
- <div
213
- @animationend=${this.onOverlayAnimationEnd}
214
- class="sbb-dialog"
215
- ${ref((el) => this._dialogElement = el)}
216
- >
217
- <div
218
- @click=${(event) => this.closeOnSbbOverlayCloseClick(event)}
219
- class="sbb-dialog__wrapper"
220
- >
221
- <slot @slotchange=${() => this._handleSlotChange()}></slot>
222
- </div>
223
- </div>
224
- </div>
225
- <sbb-screen-reader-only aria-live="polite"></sbb-screen-reader-only>
226
- `;
227
- }
228
- };
229
- })();
230
- //#endregion
231
- export { SbbDialogElement as n, assignDialogResult as r, SbbDialogCloseEvent as t };
232
-
233
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"dialog.component-B4cZfRCl.js","names":[],"sources":["../../../src/elements/dialog/dialog/dialog.scss?inline","../../../src/elements/dialog/dialog/dialog.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-dialog-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-6x)\n  );\n  --sbb-dialog-padding-block: var(--sbb-spacing-responsive-xs);\n  --sbb-dialog-shadow-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-4x)\n  );\n\n  display: none;\n  position: fixed;\n  inset: var(--sbb-dialog-inset);\n  z-index: var(--sbb-dialog-z-index, var(--sbb-overlay-default-z-index));\n\n  @include sbb.mq($from: large) {\n    --sbb-dialog-max-width: min(\n      calc(100vw - var(--sbb-spacing-fixed-30x) * 2),\n      var(--sbb-dialog-max-width-default)\n    );\n  }\n}\n\n:host(:state(top-shadow)) {\n  --sbb-dialog-block-start-box-shadow: var(--_sbb-dialog-block-shadow);\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-dialog-pointer-events: all;\n  --sbb-dialog-backdrop-color: var(--sbb-background-color-3);\n\n  @include sbb.mq($from: large) {\n    --sbb-dialog-backdrop-visibility: visible;\n    --sbb-dialog-backdrop-pointer-events: all;\n  }\n}\n\n:host([backdrop='translucent']:is(:state(state-opening), :state(state-opened))) {\n  --sbb-dialog-backdrop-color: color-mix(in srgb, var(--sbb-color-black) 50%, transparent);\n}\n\n:host([backdrop='opaque']:not([negative]):is(:state(state-opening), :state(state-opened))) {\n  --sbb-dialog-backdrop-color: var(--sbb-background-color-3);\n}\n\n:host(:not([negative])) {\n  --_sbb-dialog-color: var(--sbb-dialog-color);\n  --_sbb-dialog-block-shadow: var(--sbb-dialog-block-shadow);\n  --sbb-dialog-actions-border-color: var(--sbb-background-color-4);\n  --sbb-dialog-background-color: var(--sbb-background-color-1);\n}\n\n:host([negative]) {\n  --_sbb-dialog-color: var(--sbb-dialog-color-negative);\n  --_sbb-dialog-block-shadow: var(--sbb-dialog-block-shadow-negative);\n  --sbb-dialog-background-color: var(--sbb-background-color-1-negative);\n  --sbb-dialog-actions-border-color: var(--sbb-background-color-4-negative);\n  --sbb-dialog-backdrop-color: var(--sbb-background-color-3-negative);\n  --sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);\n}\n\n:host(:state(bottom-shadow)) {\n  --sbb-dialog-block-end-box-shadow: var(--_sbb-dialog-block-shadow);\n  --sbb-dialog-actions-border-color: transparent;\n}\n\n:host(:not(:state(state-closed))) {\n  --sbb-dialog-inset: 0;\n}\n\n.sbb-dialog__container {\n  pointer-events: var(--sbb-dialog-pointer-events);\n  display: flex;\n  align-items: center;\n  position: fixed;\n  inset: var(--sbb-dialog-inset);\n\n  // Dialog backdrop (not visible on mobile)\n  &::before {\n    content: '';\n    visibility: var(--sbb-dialog-backdrop-visibility);\n    pointer-events: var(--sbb-dialog-backdrop-pointer-events);\n    position: fixed;\n    inset: var(--sbb-dialog-inset);\n    background-color: var(--sbb-dialog-backdrop-color);\n    transition: {\n      duration: var(--sbb-dialog-animation-duration);\n      timing-function: var(--sbb-dialog-animation-easing);\n      property: background-color, visibility;\n    }\n  }\n}\n\n.sbb-dialog {\n  display: none;\n  position: absolute;\n  inset-inline: 0;\n  margin: auto;\n  padding: 0;\n  border: none;\n  width: var(--sbb-dialog-width);\n  height: var(--sbb-dialog-height);\n  max-width: var(--sbb-dialog-max-width);\n  max-height: var(--sbb-dialog-max-height);\n  color: var(--_sbb-dialog-color);\n  background-color: var(--sbb-dialog-background-color);\n\n  :host(:is(:state(state-opening), :state(state-opened), :state(state-closing))) & {\n    display: block;\n\n    animation: {\n      name: open;\n      duration: var(--sbb-dialog-animation-duration);\n      timing-function: ease;\n    }\n  }\n\n  :host(:state(state-closing)) & {\n    pointer-events: none;\n    animation-name: close;\n  }\n\n  @include sbb.if-forced-colors {\n    outline: var(--sbb-border-width-1x) solid CanvasText;\n  }\n\n  @include sbb.mq($from: large) {\n    border-radius: var(--sbb-dialog-border-radius);\n    overflow: hidden;\n    height: auto;\n  }\n}\n\n:host(:state(has-intermediate-element)) ::slotted(:first-child),\n.sbb-dialog__wrapper {\n  width: var(--sbb-dialog-width);\n  height: var(--sbb-dialog-height);\n  max-width: var(--sbb-dialog-max-width);\n  max-height: var(--sbb-dialog-max-height);\n}\n\n:host(:state(has-intermediate-element)) ::slotted(:first-child),\n:host(:not(:state(has-intermediate-element))) .sbb-dialog__wrapper {\n  display: grid;\n  grid-template:\n    'title close-button' auto\n    'content content' 1fr\n    'actions actions' auto / 1fr auto;\n  gap: 0;\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    translate: 0 var(--sbb-spacing-fixed-4x);\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: 0 var(--sbb-spacing-fixed-4x);\n  }\n}\n","import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport { type CSSResultGroup, type PropertyValues, type TemplateResult, unsafeCSS } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\nimport { html } from 'lit/static-html.js';\n\nimport type { SbbElementType, SbbOverlayCloseEventDetails } from '../../core.ts';\nimport {\n  boxSizingStyles,\n  isZeroAnimationDuration,\n  SbbScreenReaderOnlyElement,\n} from '../../core.ts';\nimport {\n  overlayRefs,\n  SbbOverlayBaseElement,\n  SbbOverlayCloseEvent as SbbDialogCloseEvent,\n} from '../../overlay.pure.ts';\nimport type { SbbDialogContentElement } from '../dialog-content/dialog-content.component.ts';\n\nimport style from './dialog.scss?inline';\n\nexport {\n  assignOverlayResult as assignDialogResult,\n  SbbOverlayCloseEvent as SbbDialogCloseEvent,\n} from '../../overlay/overlay-base-element.ts';\n\n/**\n * It displays an interactive overlay element.\n *\n * @slot - Use the unnamed slot to provide a `sbb-dialog-title`, `sbb-dialog-content` and an optional `sbb-dialog-actions`.\n * @cssprop [--sbb-dialog-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 SbbDialogElement extends SbbOverlayBaseElement {\n  public static override readonly elementName: string = 'sbb-dialog';\n  public static override elementDependencies: SbbElementType[] = [SbbScreenReaderOnlyElement];\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(style)];\n\n  /** Backdrop click action. */\n  @property({ attribute: 'backdrop-action' }) public accessor backdropAction: 'close' | 'none' =\n    'close';\n\n  /** Backdrop density. */\n  @property({ attribute: 'backdrop', reflect: true }) public accessor backdrop:\n    | 'opaque'\n    | 'translucent' = 'opaque';\n\n  // We use a timeout as a workaround to the \"ResizeObserver loop completed with undelivered notifications\" error.\n  // For more details:\n  // - https://github.com/WICG/resize-observer/issues/38#issuecomment-422126006\n  // - https://github.com/juggle/resize-observer/issues/103#issuecomment-1711148285\n  private _dialogContentResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: () => setTimeout(() => this._updateOverflowState()),\n  });\n\n  private _dialogElement?: HTMLElement;\n  private _isPointerDownEventOnDialog: boolean = false;\n  protected closeAttribute: string = 'sbb-dialog-close';\n  protected override closeTag: string = 'sbb-dialog-close-button';\n\n  public constructor() {\n    super();\n    // Close dialog on backdrop click\n    this.addEventListener?.('pointerdown', this._pointerDownListener);\n    this.addEventListener?.('pointerup', this._closeOnBackdropClick);\n    this.addEventListener('scroll', () => this._updateOverflowState(), {\n      passive: true,\n      capture: true,\n    });\n  }\n\n  /** Announce the accessibility label or dialog title for screen readers. */\n  public announceTitle(): void {\n    this.setAriaLiveRefContent(\n      this.accessibilityLabel || this.querySelector('sbb-dialog-title')?.textContent.trim(),\n    );\n  }\n\n  protected isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-dialog-animation-duration');\n  }\n\n  protected handleClosing(): void {\n    const contentElement = this._contentElement();\n\n    contentElement?.scrollTo(0, 0);\n    this.state = 'closed';\n    this.hidePopover?.();\n\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    if (contentElement) {\n      this._dialogContentResizeObserver.hostDisconnected();\n    }\n    this.removeInstanceFromGlobalCollection();\n    // Enable scrolling for content below the dialog if no dialog 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  protected handleOpening(): void {\n    this.state = 'opened';\n    this.inertController.activate();\n    this.focusTrapController.focusInitialElement();\n    this.focusTrapController.enabled = true;\n    // Use timeout to read label after focused element\n    setTimeout(() => this.announceTitle());\n\n    const contentElement = this._contentElement();\n    if (contentElement) {\n      this._dialogContentResizeObserver.observe(contentElement);\n    }\n    this.dispatchOpenEvent();\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.announceTitle();\n    }\n\n    this._syncTitleNegative();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('negative')) {\n      this._syncTitleNegative();\n    }\n  }\n\n  private _handleSlotChange(): void {\n    this._syncTitleNegative();\n    this._detectIntermediateElement();\n  }\n\n  private _syncTitleNegative(): void {\n    const dialogTitle = this.querySelector?.('sbb-dialog-title');\n    const closeButton = this.querySelector?.('sbb-dialog-close-button');\n\n    if (dialogTitle) {\n      dialogTitle.negative = this.negative;\n    }\n\n    if (closeButton) {\n      closeButton.negative = this.negative;\n    }\n  }\n\n  private _detectIntermediateElement(): void {\n    const hasNoExpectedDirectChildren =\n      this.querySelector(\n        ':scope > :is(sbb-dialog-title, sbb-dialog-close-button, sbb-dialog-content, sbb-dialog-actions)',\n      ) === null;\n\n    this.toggleState('has-intermediate-element', hasNoExpectedDirectChildren);\n  }\n\n  /** Check if the pointerdown event target is triggered on the dialog. */\n  private _pointerDownListener = (event: PointerEvent): void => {\n    if (this.backdropAction !== 'close') {\n      return;\n    }\n\n    this._isPointerDownEventOnDialog =\n      !!this._dialogElement && event.composedPath().includes(this._dialogElement);\n  };\n\n  /** Close dialog on backdrop click. */\n  private _closeOnBackdropClick = (event: PointerEvent): void => {\n    if (\n      this.backdropAction === 'close' &&\n      !this._isPointerDownEventOnDialog &&\n      this._dialogElement &&\n      !event.composedPath().includes(this._dialogElement)\n    ) {\n      this.close();\n    }\n  };\n\n  private _updateOverflowState(): void {\n    const contentElement = this._contentElement();\n    this.toggleState('top-shadow', (contentElement?.scrollTop ?? 0) > 0);\n    this.toggleState(\n      'bottom-shadow',\n      (contentElement?.scrollTop ?? 0) + (contentElement?.offsetHeight ?? 0) <\n        (contentElement?.scrollHeight ?? 0),\n    );\n  }\n\n  private _contentElement(): SbbDialogContentElement | null {\n    return this.querySelector('sbb-dialog-content');\n  }\n\n  // TODO: remove parameter `detail`\n  protected override dispatchBeforeCloseEvent(_detail?: SbbOverlayCloseEventDetails): boolean {\n    /** @type {SbbDialogCloseEvent} Emits whenever the component begins the closing transition. Can be canceled. */\n    return this.dispatchEvent(\n      new SbbDialogCloseEvent('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 {SbbDialogCloseEvent} Emits whenever the component is closed. */\n    return this.dispatchEvent(\n      new SbbDialogCloseEvent('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-dialog__container\">\n        <div\n          @animationend=${this.onOverlayAnimationEnd}\n          class=\"sbb-dialog\"\n          ${ref((el?: Element) => (this._dialogElement = el as HTMLDivElement))}\n        >\n          <div\n            @click=${(event: Event) => this.closeOnSbbOverlayCloseClick(event)}\n            class=\"sbb-dialog__wrapper\"\n          >\n            <slot @slotchange=${() => this._handleSlotChange()}></slot>\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-dialog': SbbDialogElement;\n  }\n}\n"],"mappings":"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"}