@sbb-esta/lyne-elements-dev 4.7.0-dev.1773743316 → 4.7.0-dev.1773744201

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,530 +0,0 @@
1
- import { __esDecorate, __runInitializers } from "tslib";
2
- import { css, html, nothing } from "lit";
3
- import { property } from "lit/decorators.js";
4
- import { SbbElement } from "./core/base-elements.js";
5
- import { isLean, isZeroAnimationDuration } from "./core/dom.js";
6
- import { SbbReadonlyMixin } from "./core/mixins.js";
7
- import { boxSizingStyles } from "./core/styles.js";
8
- import { SbbLanguageController } from "./core/controllers.js";
9
- import { i18nCloseNotification } from "./core/i18n.js";
10
- import { SbbIconNameMixin } from "./icon.js";
11
- import "./divider.js";
12
- import { ResizeController } from "@lit-labs/observers/resize-controller.js";
13
- import "./button/secondary-button.js";
14
- //#region src/elements/notification/notification.scss?lit&inline
15
- var notification_default = css`:host {
16
- --sbb-notification-margin: 0;
17
- --sbb-notification-padding-block: var(--sbb-spacing-responsive-xxs);
18
- --sbb-notification-padding-inline: var(--sbb-spacing-responsive-xs);
19
- --sbb-notification-color: var(--sbb-color-2-negative-inverted);
20
- --sbb-notification-background-color: color-mix(in srgb, var(--sbb-notification-type-color) 5%, white);
21
- --sbb-notification-background-color: light-dark(
22
- color-mix(in srgb, var(--sbb-notification-type-color) 5%, white),
23
- color-mix(in srgb, var(--sbb-notification-type-color) 35%, white)
24
- );
25
- --sbb-notification-icon-color: var(--sbb-notification-type-color);
26
- --sbb-notification-border-width: var(--sbb-border-width-1x);
27
- --sbb-notification-border: var(--sbb-notification-border-width) solid
28
- var(--sbb-notification-type-color);
29
- --sbb-notification-base-border-radius: var(--sbb-border-radius-4x);
30
- --sbb-notification-border-radius-start: calc(var(--sbb-notification-base-border-radius) / 2);
31
- --sbb-notification-animation-duration: var(
32
- --sbb-disable-animation-duration,
33
- var(--sbb-animation-duration-4x)
34
- );
35
- --sbb-notification-timing-function: ease-in;
36
- --sbb-notification-content-padding-inline: var(--sbb-spacing-responsive-xxxs)
37
- var(--sbb-spacing-responsive-xs);
38
- --_sbb-notification-icon-authoritative-font-size: 1em;
39
- --_sbb-notification-icon-authoritative-line-height: var(--sbb-typo-line-height-text);
40
- --sbb-focus-outline-color: var(--sbb-focus-outline-color-default);
41
- display: block;
42
- }
43
-
44
- :host(:is(:state(state-opening),[state--state-opening]):not([animation=open], [animation=all])) {
45
- --sbb-disable-animation-duration: 0s;
46
- }
47
-
48
- :host(:is(:state(state-closing),[state--state-closing]):not([animation=close], [animation=all])) {
49
- --sbb-disable-animation-duration: 0s;
50
- }
51
-
52
- :host(:is(:state(resize-disable-animation),[state--resize-disable-animation])) {
53
- --sbb-disable-animation-duration: 0s;
54
- }
55
-
56
- :host(:is(:not([type]), [type=info])) {
57
- --sbb-notification-type-color: var(--sbb-color-smoke);
58
- --sbb-notification-icon-color: var(--sbb-notification-color);
59
- --sbb-notification-divider-opacity-light: 20%;
60
- --sbb-notification-divider-opacity-dark: 20%;
61
- }
62
-
63
- :host([type=note]) {
64
- --sbb-notification-type-color: var(--sbb-color-sky);
65
- --sbb-notification-divider-opacity-light: 20%;
66
- --sbb-notification-divider-opacity-dark: 20%;
67
- }
68
-
69
- :host([type=success]) {
70
- --sbb-notification-type-color: var(--sbb-color-success);
71
- --sbb-notification-divider-opacity-light: 15%;
72
- --sbb-notification-divider-opacity-dark: 30%;
73
- }
74
-
75
- :host([type=warn]) {
76
- --sbb-notification-type-color: var(--sbb-color-warning);
77
- --sbb-notification-icon-color: var(--sbb-notification-color);
78
- --sbb-notification-divider-opacity-light: 25%;
79
- --sbb-notification-divider-opacity-dark: 40%;
80
- }
81
-
82
- :host([type=error]) {
83
- --sbb-notification-type-color: var(--sbb-color-error);
84
- --sbb-notification-divider-opacity-light: 10%;
85
- --sbb-notification-divider-opacity-dark: 25%;
86
- }
87
-
88
- :host([size=s]) {
89
- --sbb-notification-padding-block: var(--sbb-spacing-responsive-xxxs);
90
- --sbb-notification-padding-inline: var(--sbb-spacing-responsive-xxs)
91
- var(--sbb-spacing-responsive-xxxs);
92
- --sbb-notification-content-padding-inline: var(--sbb-spacing-responsive-xxxs)
93
- var(--sbb-spacing-responsive-xxs);
94
- }
95
- @media (min-width: calc(37.5rem)) {
96
- :host([size=s]) {
97
- --sbb-notification-padding-inline: var(--sbb-spacing-responsive-xxs);
98
- }
99
- }
100
-
101
- .sbb-notification__wrapper {
102
- position: relative;
103
- inset-inline-start: calc(var(--sbb-notification-base-border-radius) - var(--sbb-notification-border-width));
104
- width: calc(100% - (var(--sbb-notification-base-border-radius) - var(--sbb-notification-border-width)));
105
- border: var(--sbb-notification-border);
106
- border-radius: var(--sbb-notification-border-radius-start) var(--sbb-notification-base-border-radius) var(--sbb-notification-base-border-radius) var(--sbb-notification-border-radius-start);
107
- opacity: 0;
108
- max-height: 0;
109
- margin: 0;
110
- }
111
- .sbb-notification__wrapper::before {
112
- content: "";
113
- position: absolute;
114
- inset: calc(var(--sbb-notification-border-width) * -1) var(--sbb-notification-base-border-radius) calc(var(--sbb-notification-border-width) * -1) calc(var(--sbb-notification-base-border-radius) * -1);
115
- background-color: var(--sbb-notification-type-color);
116
- border: var(--sbb-notification-border);
117
- border-radius: var(--sbb-notification-base-border-radius);
118
- }
119
- :host(:is(:is(:state(state-opened),[state--state-opened]), :is(:state(state-closing),[state--state-closing]))) .sbb-notification__wrapper {
120
- opacity: 1;
121
- max-height: calc(var(--sbb-notification-height) + var(--sbb-notification-border-width) * 2);
122
- margin: var(--sbb-notification-margin, 0);
123
- }
124
- :host(:is(:state(state-opening),[state--state-opening])) .sbb-notification__wrapper {
125
- animation-name: open;
126
- animation-fill-mode: forwards;
127
- animation-duration: var(--sbb-notification-animation-duration);
128
- animation-timing-function: var(--sbb-notification-timing-function);
129
- }
130
- :host(:is(:state(state-closing),[state--state-closing])) .sbb-notification__wrapper {
131
- animation-name: close, close-height;
132
- animation-fill-mode: forwards;
133
- animation-duration: var(--sbb-notification-animation-duration);
134
- animation-timing-function: var(--sbb-notification-timing-function);
135
- animation-delay: 0s, var(--sbb-disable-animation-duration, var(--sbb-animation-duration-2x));
136
- }
137
-
138
- .sbb-notification {
139
- --sbb-text-font-size: var(--sbb-text-font-size-s);
140
- font-family: var(--sbb-typo-font-family);
141
- font-weight: normal;
142
- line-height: var(--sbb-typo-line-height-text);
143
- letter-spacing: var(--sbb-typo-letter-spacing-text);
144
- font-size: var(--sbb-text-font-size);
145
- position: relative;
146
- display: grid;
147
- grid-template-columns: 1fr auto;
148
- align-items: center;
149
- padding-block: var(--sbb-notification-padding-block);
150
- padding-inline: var(--sbb-notification-padding-inline);
151
- color: var(--sbb-notification-color);
152
- border-radius: var(--sbb-notification-border-radius-start) calc(var(--sbb-notification-base-border-radius) - var(--sbb-notification-border-width)) calc(var(--sbb-notification-base-border-radius) - var(--sbb-notification-border-width)) var(--sbb-notification-border-radius-start);
153
- overflow: hidden;
154
- background-color: var(--sbb-notification-background-color);
155
- }
156
- @media (min-width: calc(37.5rem)) {
157
- .sbb-notification {
158
- grid-template-columns: auto 1fr auto;
159
- align-items: flex-start;
160
- }
161
- }
162
- :host([size=s]) .sbb-notification {
163
- --sbb-text-font-size: var(--sbb-text-font-size-xs);
164
- font-family: var(--sbb-typo-font-family);
165
- font-weight: normal;
166
- line-height: var(--sbb-typo-line-height-text);
167
- letter-spacing: var(--sbb-typo-letter-spacing-text);
168
- font-size: var(--sbb-text-font-size);
169
- }
170
-
171
- .sbb-notification__icon,
172
- ::slotted(sbb-icon) {
173
- color: var(--sbb-notification-icon-color);
174
- --sbb-icon-svg-width: var(--sbb-notification-icon-size);
175
- }
176
- @media (min-width: calc(37.5rem)) {
177
- .sbb-notification__icon,
178
- ::slotted(sbb-icon) {
179
- margin-block-start: max(0rem, (var(--_sbb-notification-icon-authoritative-font-size) * var(--_sbb-notification-icon-authoritative-line-height) - var(--sbb-size-icon-ui-small)) / 2);
180
- }
181
- }
182
-
183
- .sbb-notification__content {
184
- color-scheme: only light;
185
- order: 3;
186
- grid-area: 2/1/3/3;
187
- margin-block-start: var(--sbb-spacing-fixed-2x);
188
- }
189
- @media (min-width: calc(37.5rem)) {
190
- .sbb-notification__content {
191
- order: initial;
192
- grid-area: initial;
193
- margin-block-start: 0;
194
- padding-inline: var(--sbb-notification-content-padding-inline);
195
- }
196
- }
197
-
198
- .sbb-notification__text {
199
- display: inline;
200
- margin: 0;
201
- padding: 0;
202
- }
203
-
204
- .sbb-notification__close-wrapper {
205
- display: flex;
206
- align-items: center;
207
- gap: var(--sbb-spacing-responsive-xxs);
208
- height: 100%;
209
- }
210
-
211
- .sbb-notification__divider {
212
- --sbb-divider-color: color-mix(
213
- in srgb,
214
- var(--sbb-notification-type-color) var(--sbb-notification-divider-opacity-light),
215
- var(--sbb-notification-background-color)
216
- );
217
- --sbb-divider-color: light-dark(
218
- color-mix(
219
- in srgb,
220
- var(--sbb-notification-type-color) var(--sbb-notification-divider-opacity-light),
221
- var(--sbb-notification-background-color)
222
- ),
223
- color-mix(
224
- in srgb,
225
- var(--sbb-notification-type-color) var(--sbb-notification-divider-opacity-dark),
226
- var(--sbb-notification-background-color)
227
- )
228
- );
229
- display: none;
230
- position: relative;
231
- inset-inline-start: var(--sbb-border-width-1x);
232
- }
233
- @media (min-width: calc(37.5rem)) {
234
- .sbb-notification__divider {
235
- display: block;
236
- height: calc(100% - var(--sbb-spacing-fixed-1x) * 2);
237
- }
238
- }
239
-
240
- @keyframes open {
241
- from {
242
- opacity: 0;
243
- max-height: 0;
244
- margin: 0;
245
- }
246
- to {
247
- opacity: 1;
248
- max-height: calc(var(--sbb-notification-height) + var(--sbb-notification-border-width) * 2);
249
- margin: var(--sbb-notification-margin, 0);
250
- }
251
- }
252
- @keyframes close {
253
- from {
254
- opacity: 1;
255
- margin: var(--sbb-notification-margin, 0);
256
- }
257
- to {
258
- opacity: 0;
259
- margin: 0;
260
- }
261
- }
262
- @keyframes close-height {
263
- from {
264
- max-height: calc(var(--sbb-notification-height) + var(--sbb-notification-border-width) * 2);
265
- }
266
- to {
267
- max-height: 0;
268
- }
269
- }
270
- ::slotted(sbb-title) {
271
- margin: 0;
272
- }`;
273
- //#endregion
274
- //#region src/elements/notification/notification.component.ts
275
- var notificationTypes = new Map([
276
- ["info", "circle-information-small"],
277
- ["note", "circle-information-small"],
278
- ["success", "circle-tick-small"],
279
- ["warn", "circle-exclamation-point-small"],
280
- ["error", "circle-cross-small"]
281
- ]);
282
- var DEBOUNCE_TIME = 150;
283
- /**
284
- * It displays messages which require a user's attention without interrupting its tasks.
285
- *
286
- * @slot - Use the unnamed slot to add content to the `sbb-notification`. Content should consist of an optional `sbb-title` element and text content.
287
- * @slot title - Slot for the title. For the standard `sbb-title` element, the slot is automatically assigned when slotted in the unnamed slot.
288
- * @slot icon - Use this slot to display a custom icon by providing an `sbb-icon` component.
289
- * @cssprop [--sbb-notification-margin=0] - Can be used to modify the margin in order to get a smoother animation.
290
- * See style section for more information.
291
- */
292
- var SbbNotificationElement = (() => {
293
- let _classSuper = SbbIconNameMixin(SbbReadonlyMixin(SbbElement));
294
- let _type_decorators;
295
- let _type_initializers = [];
296
- let _type_extraInitializers = [];
297
- let _size_decorators;
298
- let _size_initializers = [];
299
- let _size_extraInitializers = [];
300
- let _animation_decorators;
301
- let _animation_initializers = [];
302
- let _animation_extraInitializers = [];
303
- return class SbbNotificationElement extends _classSuper {
304
- static {
305
- const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
306
- _type_decorators = [property({ reflect: true })];
307
- _size_decorators = [property({ reflect: true })];
308
- _animation_decorators = [property({ reflect: true })];
309
- __esDecorate(this, null, _type_decorators, {
310
- kind: "accessor",
311
- name: "type",
312
- static: false,
313
- private: false,
314
- access: {
315
- has: (obj) => "type" in obj,
316
- get: (obj) => obj.type,
317
- set: (obj, value) => {
318
- obj.type = value;
319
- }
320
- },
321
- metadata: _metadata
322
- }, _type_initializers, _type_extraInitializers);
323
- __esDecorate(this, null, _size_decorators, {
324
- kind: "accessor",
325
- name: "size",
326
- static: false,
327
- private: false,
328
- access: {
329
- has: (obj) => "size" in obj,
330
- get: (obj) => obj.size,
331
- set: (obj, value) => {
332
- obj.size = value;
333
- }
334
- },
335
- metadata: _metadata
336
- }, _size_initializers, _size_extraInitializers);
337
- __esDecorate(this, null, _animation_decorators, {
338
- kind: "accessor",
339
- name: "animation",
340
- static: false,
341
- private: false,
342
- access: {
343
- has: (obj) => "animation" in obj,
344
- get: (obj) => obj.animation,
345
- set: (obj, value) => {
346
- obj.animation = value;
347
- }
348
- },
349
- metadata: _metadata
350
- }, _animation_initializers, _animation_extraInitializers);
351
- if (_metadata) Object.defineProperty(this, Symbol.metadata, {
352
- enumerable: true,
353
- configurable: true,
354
- writable: true,
355
- value: _metadata
356
- });
357
- }
358
- static {
359
- this.elementName = "sbb-notification";
360
- }
361
- static {
362
- this.styles = [boxSizingStyles, notification_default];
363
- }
364
- static {
365
- this.events = {
366
- beforeopen: "beforeopen",
367
- open: "open",
368
- beforeclose: "beforeclose",
369
- close: "close"
370
- };
371
- }
372
- #type_accessor_storage;
373
- /** The type of the notification. */
374
- get type() {
375
- return this.#type_accessor_storage;
376
- }
377
- set type(value) {
378
- this.#type_accessor_storage = value;
379
- }
380
- #size_accessor_storage;
381
- /**
382
- * Size variant, either s or m.
383
- * @default 'm' / 's' (lean)
384
- */
385
- get size() {
386
- return this.#size_accessor_storage;
387
- }
388
- set size(value) {
389
- this.#size_accessor_storage = value;
390
- }
391
- #animation_accessor_storage;
392
- /** The enabled animations. */
393
- get animation() {
394
- return this.#animation_accessor_storage;
395
- }
396
- set animation(value) {
397
- this.#animation_accessor_storage = value;
398
- }
399
- /** The state of the component. */
400
- set _state(state) {
401
- if (this._stateInternal) this.internals.states.delete(`state-${this._stateInternal}`);
402
- this._stateInternal = state;
403
- if (this._stateInternal) this.internals.states.add(`state-${this._stateInternal}`);
404
- }
405
- get _state() {
406
- return this._stateInternal;
407
- }
408
- constructor() {
409
- super();
410
- this.#type_accessor_storage = __runInitializers(this, _type_initializers, "info");
411
- this.#size_accessor_storage = (__runInitializers(this, _type_extraInitializers), __runInitializers(this, _size_initializers, isLean() ? "s" : "m"));
412
- this.#animation_accessor_storage = (__runInitializers(this, _size_extraInitializers), __runInitializers(this, _animation_initializers, "all"));
413
- this._stateInternal = __runInitializers(this, _animation_extraInitializers);
414
- this._resizeObserverTimeout = null;
415
- this._language = new SbbLanguageController(this);
416
- this._notificationResizeObserver = new ResizeController(this, {
417
- target: null,
418
- skipInitial: true,
419
- callback: () => this._onNotificationResize()
420
- });
421
- this._state = "closed";
422
- }
423
- willUpdate(changedProperties) {
424
- super.willUpdate(changedProperties);
425
- if (changedProperties.has("size")) this._configureTitle();
426
- }
427
- _open() {
428
- if (this._state === "closed") {
429
- this._state = "opening";
430
- /** Emits when the opening animation starts. */
431
- this.dispatchEvent(new Event("beforeopen"));
432
- if (this._isZeroAnimationDuration()) this._handleOpening();
433
- }
434
- }
435
- close() {
436
- if (this._state === "opened" && this._dispatchBeforeCloseEvent()) {
437
- this._state = "closing";
438
- if (this._isZeroAnimationDuration()) this._handleClosing();
439
- }
440
- }
441
- _dispatchBeforeCloseEvent() {
442
- /** Emits when the closing animation starts. Can be canceled to prevent the component from closing. */
443
- return this.dispatchEvent(new Event("beforeclose", { cancelable: true }));
444
- }
445
- firstUpdated(changedProperties) {
446
- super.firstUpdated(changedProperties);
447
- this._notificationElement = this.shadowRoot?.querySelector(".sbb-notification__wrapper");
448
- this.updateComplete.then(() => {
449
- this._setNotificationHeight();
450
- this._open();
451
- });
452
- }
453
- _isZeroAnimationDuration() {
454
- return isZeroAnimationDuration(this, "--sbb-notification-animation-duration");
455
- }
456
- _setNotificationHeight() {
457
- if (!this._notificationElement?.scrollHeight) return;
458
- const notificationHeight = `${this._notificationElement.scrollHeight}px`;
459
- this.style.setProperty("--sbb-notification-height", notificationHeight);
460
- }
461
- _onNotificationResize() {
462
- if (this._state !== "opened") return;
463
- if (this._resizeObserverTimeout) clearTimeout(this._resizeObserverTimeout);
464
- this.internals.states.add("resize-disable-animation");
465
- this._resizeObserverTimeout = setTimeout(() => this.internals.states.delete("resize-disable-animation"), DEBOUNCE_TIME);
466
- setTimeout(() => this._setNotificationHeight());
467
- }
468
- _onNotificationAnimationEnd(event) {
469
- if (this._state === "opening" && event.animationName === "open") this._handleOpening();
470
- if (this._state === "closing" && event.animationName === "close-height") this._handleClosing();
471
- }
472
- _handleOpening() {
473
- this._state = "opened";
474
- this._notificationResizeObserver.observe(this._notificationElement);
475
- /** Emits when the opening animation ends. */
476
- this.dispatchEvent(new Event("open"));
477
- }
478
- _handleClosing() {
479
- this._state = "closed";
480
- /** Emits when the closing animation ends. */
481
- this.dispatchEvent(new Event("close"));
482
- this._notificationResizeObserver.unobserve(this._notificationElement);
483
- setTimeout(() => this.remove());
484
- }
485
- _handleSlotchange() {
486
- const title = Array.from(this.children).find((el) => el.localName === "sbb-title");
487
- if (title) title.slot = "title";
488
- }
489
- _configureTitle() {
490
- const title = this.querySelector?.("sbb-title");
491
- if (title) {
492
- customElements.upgrade(title);
493
- title.visualLevel = this.size === "m" ? "5" : "6";
494
- }
495
- }
496
- renderIconName() {
497
- return super.renderIconName() || notificationTypes.get(this.type);
498
- }
499
- render() {
500
- return html`
501
- <div class="sbb-notification__wrapper" @animationend=${this._onNotificationAnimationEnd}>
502
- <div class="sbb-notification">
503
- ${this.renderIconSlot("sbb-notification__icon")}
504
- <span class="sbb-notification__content">
505
- <slot name="title" @slotchange=${this._configureTitle}></slot>
506
- <p class="sbb-notification__text">
507
- <slot @slotchange=${this._handleSlotchange}></slot>
508
- </p>
509
- </span>
510
-
511
- ${!this.readOnly ? html`<span class="sbb-notification__close-wrapper">
512
- <sbb-divider class="sbb-notification__divider" orientation="vertical"></sbb-divider>
513
- <sbb-secondary-button
514
- size=${this.size}
515
- icon-name="cross-small"
516
- @click=${() => this.close()}
517
- aria-label=${i18nCloseNotification[this._language.current]}
518
- class="sbb-notification__close"
519
- ></sbb-secondary-button>
520
- </span>` : nothing}
521
- </div>
522
- </div>
523
- `;
524
- }
525
- };
526
- })();
527
- //#endregion
528
- export { SbbNotificationElement as t };
529
-
530
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"notification.component-B5EBKKf8.js","names":[],"sources":["../../../src/elements/notification/notification.scss?lit&inline","../../../src/elements/notification/notification.component.ts"],"sourcesContent":["@use '../core/styles' as sbb;\n\n// Open/Close animation vars\n$open-anim-margin-from: 0;\n$open-anim-margin-to: var(--sbb-notification-margin, 0);\n$open-anim-opacity-from: 0;\n$open-anim-opacity-to: 1;\n$open-anim-height-from: 0;\n$open-anim-height-to: calc(\n  var(--sbb-notification-height) + (var(--sbb-notification-border-width) * 2)\n);\n\n:host {\n  --sbb-notification-margin: 0;\n  --sbb-notification-padding-block: var(--sbb-spacing-responsive-xxs);\n  --sbb-notification-padding-inline: var(--sbb-spacing-responsive-xs);\n  --sbb-notification-color: var(--sbb-color-2-negative-inverted);\n  --sbb-notification-background-color: light-dark(\n    color-mix(in srgb, var(--sbb-notification-type-color) 5%, white),\n    color-mix(in srgb, var(--sbb-notification-type-color) 35%, white)\n  );\n  --sbb-notification-icon-color: var(--sbb-notification-type-color);\n  --sbb-notification-border-width: var(--sbb-border-width-1x);\n  --sbb-notification-border: var(--sbb-notification-border-width) solid\n    var(--sbb-notification-type-color);\n  --sbb-notification-base-border-radius: var(--sbb-border-radius-4x);\n  --sbb-notification-border-radius-start: calc(var(--sbb-notification-base-border-radius) / 2);\n  --sbb-notification-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-4x)\n  );\n  --sbb-notification-timing-function: ease-in;\n  --sbb-notification-content-padding-inline: var(--sbb-spacing-responsive-xxxs)\n    var(--sbb-spacing-responsive-xs);\n  --_sbb-notification-icon-authoritative-font-size: 1em;\n  --_sbb-notification-icon-authoritative-line-height: var(--sbb-typo-line-height-text);\n\n  // As the notification has always a light background, we have to fix the focus outline color\n  // to default color for cases where the notification is used in a negative context.\n  --sbb-focus-outline-color: var(--sbb-focus-outline-color-default);\n\n  display: block;\n}\n\n// By default, the open animation is disabled\n:host(:state(state-opening):not([animation='open'], [animation='all'])) {\n  @include sbb.disable-animation;\n}\n\n:host(:state(state-closing):not([animation='close'], [animation='all'])) {\n  @include sbb.disable-animation;\n}\n\n:host(:state(resize-disable-animation)) {\n  @include sbb.disable-animation;\n}\n\n// Types\n:host(:is(:not([type]), [type='info'])) {\n  --sbb-notification-type-color: var(--sbb-color-smoke);\n  --sbb-notification-icon-color: var(--sbb-notification-color);\n  --sbb-notification-divider-opacity-light: 20%;\n  --sbb-notification-divider-opacity-dark: 20%;\n}\n\n:host([type='note']) {\n  --sbb-notification-type-color: var(--sbb-color-sky);\n  --sbb-notification-divider-opacity-light: 20%;\n  --sbb-notification-divider-opacity-dark: 20%;\n}\n\n:host([type='success']) {\n  --sbb-notification-type-color: var(--sbb-color-success);\n  --sbb-notification-divider-opacity-light: 15%;\n  --sbb-notification-divider-opacity-dark: 30%;\n}\n\n:host([type='warn']) {\n  --sbb-notification-type-color: var(--sbb-color-warning);\n  --sbb-notification-icon-color: var(--sbb-notification-color);\n  --sbb-notification-divider-opacity-light: 25%;\n  --sbb-notification-divider-opacity-dark: 40%;\n}\n\n:host([type='error']) {\n  --sbb-notification-type-color: var(--sbb-color-error);\n  --sbb-notification-divider-opacity-light: 10%;\n  --sbb-notification-divider-opacity-dark: 25%;\n}\n\n:host([size='s']) {\n  --sbb-notification-padding-block: var(--sbb-spacing-responsive-xxxs);\n  --sbb-notification-padding-inline: var(--sbb-spacing-responsive-xxs)\n    var(--sbb-spacing-responsive-xxxs);\n  --sbb-notification-content-padding-inline: var(--sbb-spacing-responsive-xxxs)\n    var(--sbb-spacing-responsive-xxs);\n\n  @include sbb.mq($from: small) {\n    --sbb-notification-padding-inline: var(--sbb-spacing-responsive-xxs);\n  }\n}\n\n.sbb-notification__wrapper {\n  position: relative;\n  inset-inline-start: calc(\n    var(--sbb-notification-base-border-radius) - var(--sbb-notification-border-width)\n  );\n  width: calc(\n    100% - calc(var(--sbb-notification-base-border-radius) - var(--sbb-notification-border-width))\n  );\n  border: var(--sbb-notification-border);\n  border-radius: var(--sbb-notification-border-radius-start)\n    var(--sbb-notification-base-border-radius) var(--sbb-notification-base-border-radius)\n    var(--sbb-notification-border-radius-start);\n  opacity: #{$open-anim-opacity-from};\n  max-height: #{$open-anim-height-from};\n  margin: #{$open-anim-margin-from};\n\n  &::before {\n    content: '';\n    position: absolute;\n    inset: calc(var(--sbb-notification-border-width) * -1)\n      var(--sbb-notification-base-border-radius) calc(var(--sbb-notification-border-width) * -1)\n      calc(var(--sbb-notification-base-border-radius) * -1);\n    background-color: var(--sbb-notification-type-color);\n    border: var(--sbb-notification-border);\n    border-radius: var(--sbb-notification-base-border-radius);\n  }\n\n  :host(:is(:state(state-opened), :state(state-closing))) & {\n    opacity: #{$open-anim-opacity-to};\n    max-height: #{$open-anim-height-to};\n    margin: #{$open-anim-margin-to};\n  }\n\n  :host(:state(state-opening)) & {\n    animation: {\n      name: open;\n      fill-mode: forwards;\n      duration: var(--sbb-notification-animation-duration);\n      timing-function: var(--sbb-notification-timing-function);\n    }\n  }\n\n  :host(:state(state-closing)) & {\n    animation: {\n      name: close, close-height;\n      fill-mode: forwards;\n      duration: var(--sbb-notification-animation-duration);\n      timing-function: var(--sbb-notification-timing-function);\n      delay: 0s, var(--sbb-disable-animation-duration, var(--sbb-animation-duration-2x));\n    }\n  }\n}\n\n.sbb-notification {\n  @include sbb.text-s--regular;\n\n  position: relative;\n  display: grid;\n  grid-template-columns: 1fr auto;\n  align-items: center;\n  padding-block: var(--sbb-notification-padding-block);\n  padding-inline: var(--sbb-notification-padding-inline);\n  color: var(--sbb-notification-color);\n  border-radius: var(--sbb-notification-border-radius-start)\n    calc(var(--sbb-notification-base-border-radius) - var(--sbb-notification-border-width))\n    calc(var(--sbb-notification-base-border-radius) - var(--sbb-notification-border-width))\n    var(--sbb-notification-border-radius-start);\n  overflow: hidden;\n  background-color: var(--sbb-notification-background-color);\n\n  @include sbb.mq($from: small) {\n    grid-template-columns: auto 1fr auto;\n    align-items: flex-start;\n  }\n\n  :host([size='s']) & {\n    @include sbb.text-xs--regular;\n  }\n}\n\n.sbb-notification__icon,\n::slotted(sbb-icon) {\n  color: var(--sbb-notification-icon-color);\n\n  // This is an undocumented feature for sbb.ch, to have the ability to hide the icon.\n  --sbb-icon-svg-width: var(--sbb-notification-icon-size);\n\n  @include sbb.mq($from: small) {\n    margin-block-start: max(\n      0rem,\n      calc(\n        (\n            (\n                var(--_sbb-notification-icon-authoritative-font-size) *\n                  var(--_sbb-notification-icon-authoritative-line-height)\n              ) - var(--sbb-size-icon-ui-small)\n          ) /\n          2\n      )\n    );\n  }\n}\n\n.sbb-notification__content {\n  // The content of the notification is always displayed in positive mode,\n  // therefore, to have slotted content correctly display, we need only allow light mode.\n  color-scheme: only light;\n  order: 3;\n  grid-area: 2 / 1 / 3 / 3;\n  margin-block-start: var(--sbb-spacing-fixed-2x);\n\n  @include sbb.mq($from: small) {\n    order: initial;\n    grid-area: initial;\n    margin-block-start: 0;\n    padding-inline: var(--sbb-notification-content-padding-inline);\n  }\n}\n\n.sbb-notification__text {\n  // Reset paragraph styles\n  display: inline;\n  margin: 0;\n  padding: 0;\n}\n\n.sbb-notification__close-wrapper {\n  display: flex;\n  align-items: center;\n  gap: var(--sbb-spacing-responsive-xxs);\n  height: 100%;\n}\n\n.sbb-notification__divider {\n  --sbb-divider-color: light-dark(\n    color-mix(\n      in srgb,\n      var(--sbb-notification-type-color) var(--sbb-notification-divider-opacity-light),\n      var(--sbb-notification-background-color)\n    ),\n    color-mix(\n      in srgb,\n      var(--sbb-notification-type-color) var(--sbb-notification-divider-opacity-dark),\n      var(--sbb-notification-background-color)\n    )\n  );\n\n  display: none;\n  position: relative;\n  inset-inline-start: var(--sbb-border-width-1x);\n\n  @include sbb.mq($from: small) {\n    display: block;\n    height: calc(100% - (var(--sbb-spacing-fixed-1x) * 2));\n  }\n}\n\n@keyframes open {\n  from {\n    opacity: #{$open-anim-opacity-from};\n    max-height: #{$open-anim-height-from};\n    margin: #{$open-anim-margin-from};\n  }\n\n  to {\n    opacity: #{$open-anim-opacity-to};\n    max-height: #{$open-anim-height-to};\n    margin: #{$open-anim-margin-to};\n  }\n}\n\n@keyframes close {\n  from {\n    opacity: #{$open-anim-opacity-to};\n    margin: #{$open-anim-margin-to};\n  }\n\n  to {\n    opacity: #{$open-anim-opacity-from};\n    margin: #{$open-anim-margin-from};\n  }\n}\n\n@keyframes close-height {\n  from {\n    max-height: #{$open-anim-height-to};\n  }\n\n  to {\n    max-height: #{$open-anim-height-from};\n  }\n}\n\n::slotted(sbb-title) {\n  // Overwrite sbb-title default margin\n  margin: 0;\n}\n","import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport { type CSSResultGroup, html, nothing, type PropertyValues, type TemplateResult } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbElement } from '../core/base-elements.ts';\nimport { SbbLanguageController } from '../core/controllers.ts';\nimport { isLean, isZeroAnimationDuration } from '../core/dom.ts';\nimport { i18nCloseNotification } from '../core/i18n.ts';\nimport type { SbbOpenedClosedState } from '../core/interfaces.ts';\nimport { SbbReadonlyMixin } from '../core/mixins.ts';\nimport { boxSizingStyles } from '../core/styles.ts';\nimport { SbbIconNameMixin } from '../icon.ts';\nimport type { SbbTitleElement } from '../title.ts';\n\nimport style from './notification.scss?lit&inline';\n\nimport '../button/secondary-button.ts';\nimport '../divider.ts';\n\nconst notificationTypes = new Map([\n  ['info', 'circle-information-small'],\n  ['note', 'circle-information-small'],\n  ['success', 'circle-tick-small'],\n  ['warn', 'circle-exclamation-point-small'],\n  ['error', 'circle-cross-small'],\n]);\n\nconst DEBOUNCE_TIME = 150;\n\n/**\n * It displays messages which require a user's attention without interrupting its tasks.\n *\n * @slot - Use the unnamed slot to add content to the `sbb-notification`. Content should consist of an optional `sbb-title` element and text content.\n * @slot title - Slot for the title. For the standard `sbb-title` element, the slot is automatically assigned when slotted in the unnamed slot.\n * @slot icon - Use this slot to display a custom icon by providing an `sbb-icon` component.\n * @cssprop [--sbb-notification-margin=0] - Can be used to modify the margin in order to get a smoother animation.\n * See style section for more information.\n */\nexport class SbbNotificationElement extends SbbIconNameMixin(SbbReadonlyMixin(SbbElement)) {\n  public static override readonly elementName: string = 'sbb-notification';\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  public static readonly events = {\n    beforeopen: 'beforeopen',\n    open: 'open',\n    beforeclose: 'beforeclose',\n    close: 'close',\n  } as const;\n\n  /** The type of the notification. */\n  @property({ reflect: true }) public accessor type:\n    | 'info'\n    | 'note'\n    | 'success'\n    | 'warn'\n    | 'error' = 'info';\n\n  /**\n   * Size variant, either s or m.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true }) public accessor size: 's' | 'm' = isLean() ? 's' : 'm';\n\n  /** The enabled animations. */\n  @property({ reflect: true }) public accessor animation: 'open' | 'close' | 'all' | 'none' = 'all';\n\n  /** The state of the component. */\n  private set _state(state: SbbOpenedClosedState) {\n    if (this._stateInternal) {\n      this.internals.states.delete(`state-${this._stateInternal}`);\n    }\n    this._stateInternal = state;\n    if (this._stateInternal) {\n      this.internals.states.add(`state-${this._stateInternal}`);\n    }\n  }\n  private get _state(): SbbOpenedClosedState {\n    return this._stateInternal;\n  }\n  private _stateInternal!: SbbOpenedClosedState;\n\n  private _notificationElement!: HTMLElement;\n  private _resizeObserverTimeout: ReturnType<typeof setTimeout> | null = null;\n  private _language = new SbbLanguageController(this);\n  private _notificationResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: () => this._onNotificationResize(),\n  });\n\n  public constructor() {\n    super();\n    this._state = 'closed';\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('size')) {\n      this._configureTitle();\n    }\n  }\n\n  private _open(): void {\n    if (this._state === 'closed') {\n      this._state = 'opening';\n      /** Emits when the opening animation starts. */\n      this.dispatchEvent(new Event('beforeopen'));\n\n      // If the animation duration is zero, the animationend event is not always fired reliably.\n      // In this case we directly set the `opened` state.\n      if (this._isZeroAnimationDuration()) {\n        this._handleOpening();\n      }\n    }\n  }\n\n  public close(): void {\n    if (this._state === 'opened' && this._dispatchBeforeCloseEvent()) {\n      this._state = 'closing';\n\n      // If the animation duration is zero, the animationend event is not always fired reliably.\n      // In this case we directly set the `closed` state.\n      if (this._isZeroAnimationDuration()) {\n        this._handleClosing();\n      }\n    }\n  }\n\n  private _dispatchBeforeCloseEvent(): boolean {\n    /** Emits when the closing animation starts. Can be canceled to prevent the component from closing. */\n    return this.dispatchEvent(new Event('beforeclose', { cancelable: true }));\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._notificationElement = this.shadowRoot?.querySelector(\n      '.sbb-notification__wrapper',\n    ) as HTMLElement;\n    // We need to wait for the component's `updateComplete` in order to set the correct\n    // height to the notification element.\n    this.updateComplete.then(() => {\n      this._setNotificationHeight();\n      this._open();\n    });\n  }\n\n  private _isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-notification-animation-duration');\n  }\n\n  private _setNotificationHeight(): void {\n    if (!this._notificationElement?.scrollHeight) {\n      return;\n    }\n    const notificationHeight = `${this._notificationElement.scrollHeight}px`;\n    this.style.setProperty('--sbb-notification-height', notificationHeight);\n  }\n\n  private _onNotificationResize(): void {\n    if (this._state !== 'opened') {\n      return;\n    }\n\n    if (this._resizeObserverTimeout) {\n      clearTimeout(this._resizeObserverTimeout);\n    }\n\n    // Disable the animation when resizing the notification to avoid strange height transition effects.\n    this.internals.states.add('resize-disable-animation');\n    this._resizeObserverTimeout = setTimeout(\n      () => this.internals.states.delete('resize-disable-animation'),\n      DEBOUNCE_TIME,\n    );\n\n    // To avoid ResizeObserver loops, we set the height a tick later.\n    setTimeout(() => this._setNotificationHeight());\n  }\n\n  private _onNotificationAnimationEnd(event: AnimationEvent): void {\n    if (this._state === 'opening' && event.animationName === 'open') {\n      this._handleOpening();\n    }\n\n    if (this._state === 'closing' && event.animationName === 'close-height') {\n      this._handleClosing();\n    }\n  }\n\n  private _handleOpening(): void {\n    this._state = 'opened';\n    this._notificationResizeObserver.observe(this._notificationElement);\n    /** Emits when the opening animation ends. */\n    this.dispatchEvent(new Event('open'));\n  }\n\n  private _handleClosing(): void {\n    this._state = 'closed';\n    /** Emits when the closing animation ends. */\n    this.dispatchEvent(new Event('close'));\n    this._notificationResizeObserver.unobserve(this._notificationElement);\n    setTimeout(() => this.remove());\n  }\n\n  private _handleSlotchange(): void {\n    const title = Array.from(this.children).find((el) => el.localName === 'sbb-title');\n    if (title) {\n      title.slot = 'title';\n    }\n  }\n\n  private _configureTitle(): void {\n    const title = this.querySelector?.<SbbTitleElement>('sbb-title');\n    if (title) {\n      customElements.upgrade(title);\n      title.visualLevel = this.size === 'm' ? '5' : '6';\n    }\n  }\n\n  protected override renderIconName(): string {\n    return super.renderIconName() || notificationTypes.get(this.type)!;\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-notification__wrapper\" @animationend=${this._onNotificationAnimationEnd}>\n        <div class=\"sbb-notification\">\n          ${this.renderIconSlot('sbb-notification__icon')}\n          <span class=\"sbb-notification__content\">\n            <slot name=\"title\" @slotchange=${this._configureTitle}></slot>\n            <p class=\"sbb-notification__text\">\n              <slot @slotchange=${this._handleSlotchange}></slot>\n            </p>\n          </span>\n\n          ${!this.readOnly\n            ? html`<span class=\"sbb-notification__close-wrapper\">\n                <sbb-divider class=\"sbb-notification__divider\" orientation=\"vertical\"></sbb-divider>\n                <sbb-secondary-button\n                  size=${this.size}\n                  icon-name=\"cross-small\"\n                  @click=${() => this.close()}\n                  aria-label=${i18nCloseNotification[this._language.current]}\n                  class=\"sbb-notification__close\"\n                ></sbb-secondary-button>\n              </span>`\n            : nothing}\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-notification': SbbNotificationElement;\n  }\n}\n"],"mappings":"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"}