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

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,214 +0,0 @@
1
- import { __esDecorate, __runInitializers } from "tslib";
2
- import { html, nothing, unsafeCSS } from "lit";
3
- import { property } from "lit/decorators.js";
4
- import { SbbDarkModeController, SbbLanguageController, SbbOpenCloseBaseElement, SbbReadonlyMixin, boxSizingStyles, i18nCloseAlert, isLean, isZeroAnimationDuration } from "./core.js";
5
- import { SbbTransparentButtonElement } from "./button.pure.js";
6
- import { SbbDividerElement } from "./divider.pure.js";
7
- import { SbbIconNameMixin } from "./icon.pure.js";
8
- //#region src/elements/alert/alert/alert.scss?inline
9
- var alert_default = ":host {\n display: block;\n --sbb-alert-background-color: var(--sbb-background-color-1-inverted);\n --sbb-alert-border-radius: var(--sbb-border-radius-4x);\n --sbb-alert-color: var(--sbb-color-aluminium);\n --sbb-alert-color: light-dark(var(--sbb-color-aluminium), var(--sbb-color-anthracite));\n --sbb-alert-padding: var(--sbb-spacing-responsive-xxs) var(--sbb-spacing-responsive-xs);\n --sbb-alert-icon-size: 1.25rem;\n --sbb-alert-close-icon-margin: var(--sbb-spacing-responsive-xxs);\n --sbb-alert-gap: var(--sbb-spacing-fixed-2x) var(--sbb-spacing-responsive-xs);\n --sbb-alert-animation-duration: var(\n --sbb-disable-animation-duration,\n var(--sbb-animation-duration-6x)\n );\n --sbb-alert-timing-function: ease-in;\n --sbb-alert-title-margin-block: 0;\n}\n@media (min-width: calc(64rem)) {\n :host {\n --sbb-alert-icon-size: 1.75rem;\n }\n}\n@media (forced-colors: active) {\n :host {\n outline: var(--sbb-border-width-1x) solid CanvasText;\n border-radius: var(--sbb-alert-border-radius);\n }\n}\n\n:host(:is(:state(state-opening),[state--state-opening]):not([animation=open], [animation=all])) {\n --sbb-disable-animation-duration: 0s;\n}\n\n:host(:is(:state(state-closing),[state--state-closing]):not([animation=close], [animation=all])) {\n --sbb-disable-animation-duration: 0s;\n}\n\n:host([size=s]) {\n --sbb-alert-gap: var(--sbb-spacing-fixed-1x) var(--sbb-spacing-responsive-xxs);\n --sbb-alert-close-icon-margin: var(--sbb-spacing-responsive-xxxs);\n}\n\n:host([size=l]) {\n --sbb-alert-icon-size: var(--sbb-size-icon-ui-small);\n --sbb-alert-title-margin-block: 0 var(--sbb-spacing-fixed-1x);\n}\n@media (min-width: calc(64rem)) {\n :host([size=l]) {\n --sbb-alert-icon-size: 2.125rem;\n }\n}\n\n:host(:not(:is(:state(dark),[state--dark]))) {\n --sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);\n}\n\n.sbb-alert__transition-wrapper {\n display: grid;\n grid-template-rows: 0fr;\n opacity: 0;\n}\n:host(:is(:is(:state(state-opened),[state--state-opened]), :is(:state(state-closing),[state--state-closing]))) .sbb-alert__transition-wrapper {\n grid-template-rows: 1fr;\n opacity: 1;\n}\n:host(:is(:state(state-opening),[state--state-opening])) .sbb-alert__transition-wrapper {\n animation-name: open, open-opacity;\n animation-fill-mode: forwards;\n animation-duration: var(--sbb-alert-animation-duration);\n animation-timing-function: var(--sbb-alert-timing-function);\n animation-delay: 0s, var(--sbb-alert-animation-duration);\n}\n:host(:is(:state(state-closing),[state--state-closing])) .sbb-alert__transition-wrapper {\n animation-name: close-opacity, close;\n animation-fill-mode: forwards;\n animation-duration: var(--sbb-alert-animation-duration);\n animation-timing-function: var(--sbb-alert-timing-function);\n animation-delay: 0s, var(--sbb-disable-animation-duration, var(--sbb-animation-duration-2x));\n}\n\n.sbb-alert__transition-sub-wrapper {\n overflow: hidden;\n}\n\n.sbb-alert {\n --sbb-text-font-size: var(--sbb-text-font-size-s);\n font-family: var(--sbb-typo-font-family);\n font-weight: normal;\n line-height: var(--sbb-typo-line-height-text);\n letter-spacing: var(--sbb-typo-letter-spacing-text);\n font-size: var(--sbb-text-font-size);\n display: grid;\n grid-template-columns: 1fr auto;\n align-items: center;\n gap: var(--sbb-alert-gap);\n min-width: fit-content;\n padding: var(--sbb-alert-padding);\n overflow: hidden;\n color: var(--sbb-alert-color);\n background-color: var(--sbb-alert-background-color);\n border-radius: var(--sbb-alert-border-radius);\n}\n@media (min-width: calc(37.5rem)) {\n .sbb-alert {\n grid-template-columns: auto 1fr auto;\n align-items: flex-start;\n }\n}\n\n.sbb-alert__icon {\n display: flex;\n align-items: start;\n padding-block: var(--sbb-spacing-fixed-1x);\n min-width: var(--sbb-alert-icon-size);\n --sbb-icon-svg-width: var(--sbb-alert-icon-size);\n --sbb-icon-svg-height: var(--sbb-alert-icon-size);\n}\n\n.sbb-alert__content {\n color-scheme: only light;\n order: 3;\n grid-column: 1/3;\n}\n@media (min-width: calc(37.5rem)) {\n .sbb-alert__content {\n order: initial;\n grid-column-start: initial;\n grid-column-end: initial;\n }\n}\n\n.sbb-alert__content-slot {\n display: inline;\n margin: 0;\n padding: 0;\n}\n\n.sbb-alert__close-button-wrapper {\n color-scheme: only light;\n display: flex;\n justify-content: flex-end;\n align-items: center;\n height: 100%;\n}\n\n@media (min-width: calc(37.5rem)) {\n .sbb-alert__close-button {\n margin-inline-start: var(--sbb-alert-close-icon-margin);\n }\n}\n\n.sbb-alert__close-button-divider {\n display: none;\n}\n@media (min-width: calc(37.5rem)) {\n .sbb-alert__close-button-divider {\n display: block;\n height: calc(100% - var(--sbb-spacing-fixed-1x) * 2);\n }\n}\n\n@keyframes open {\n from {\n grid-template-rows: 0fr;\n }\n to {\n grid-template-rows: 1fr;\n }\n}\n@keyframes open-opacity {\n from {\n opacity: 0;\n }\n to {\n opacity: 1;\n }\n}\n@keyframes close {\n from {\n grid-template-rows: 1fr;\n }\n to {\n grid-template-rows: 0fr;\n }\n}\n@keyframes close-opacity {\n from {\n opacity: 1;\n }\n to {\n opacity: 0;\n }\n}\n::slotted(sbb-title) {\n margin-block: var(--sbb-alert-title-margin-block);\n}";
10
- //#endregion
11
- //#region src/elements/alert/alert/alert.component.ts
12
- /**
13
- * It displays messages which require user's attention.
14
- *
15
- * @slot - Use the unnamed slot to add content to the `sbb-alert`. At a minimum an `sbb-title` element and a descriptive text should be used.
16
- * @slot icon - Should be a `sbb-icon` which is displayed next to the title. Styling is optimized for icons of type HIM-CUS.
17
- * @slot title - Slot for the title. For the standard `sbb-title` element, the slot is automatically assigned when slotted in the unnamed slot.
18
- */
19
- var SbbAlertElement = (() => {
20
- let _classSuper = SbbIconNameMixin(SbbReadonlyMixin(SbbOpenCloseBaseElement));
21
- let _size_decorators;
22
- let _size_initializers = [];
23
- let _size_extraInitializers = [];
24
- let _animation_decorators;
25
- let _animation_initializers = [];
26
- let _animation_extraInitializers = [];
27
- return class SbbAlertElement extends _classSuper {
28
- constructor() {
29
- super(...arguments);
30
- this.#size_accessor_storage = __runInitializers(this, _size_initializers, isLean() ? "s" : "m");
31
- this.#animation_accessor_storage = (__runInitializers(this, _size_extraInitializers), __runInitializers(this, _animation_initializers, "all"));
32
- this._language = (__runInitializers(this, _animation_extraInitializers), new SbbLanguageController(this));
33
- this._darkModeController = new SbbDarkModeController(this, () => {
34
- this._syncLinks();
35
- this._configureTitle();
36
- this.requestUpdate();
37
- });
38
- }
39
- static {
40
- const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
41
- _size_decorators = [property({ reflect: true })];
42
- _animation_decorators = [property({ reflect: true })];
43
- __esDecorate(this, null, _size_decorators, {
44
- kind: "accessor",
45
- name: "size",
46
- static: false,
47
- private: false,
48
- access: {
49
- has: (obj) => "size" in obj,
50
- get: (obj) => obj.size,
51
- set: (obj, value) => {
52
- obj.size = value;
53
- }
54
- },
55
- metadata: _metadata
56
- }, _size_initializers, _size_extraInitializers);
57
- __esDecorate(this, null, _animation_decorators, {
58
- kind: "accessor",
59
- name: "animation",
60
- static: false,
61
- private: false,
62
- access: {
63
- has: (obj) => "animation" in obj,
64
- get: (obj) => obj.animation,
65
- set: (obj, value) => {
66
- obj.animation = value;
67
- }
68
- },
69
- metadata: _metadata
70
- }, _animation_initializers, _animation_extraInitializers);
71
- if (_metadata) Object.defineProperty(this, Symbol.metadata, {
72
- enumerable: true,
73
- configurable: true,
74
- writable: true,
75
- value: _metadata
76
- });
77
- }
78
- static {
79
- this.elementName = "sbb-alert";
80
- }
81
- static {
82
- this.elementDependencies = [SbbTransparentButtonElement, SbbDividerElement];
83
- }
84
- static {
85
- this.styles = [boxSizingStyles, unsafeCSS(alert_default)];
86
- }
87
- static {
88
- this.events = {
89
- beforeopen: "beforeopen",
90
- open: "open",
91
- beforeclose: "beforeclose",
92
- close: "close"
93
- };
94
- }
95
- #size_accessor_storage;
96
- /**
97
- * You can choose between `s`, `m` or `l` size.
98
- * @default 'm' / 's' (lean)
99
- */
100
- get size() {
101
- return this.#size_accessor_storage;
102
- }
103
- set size(value) {
104
- this.#size_accessor_storage = value;
105
- }
106
- #animation_accessor_storage;
107
- /** The enabled animations. */
108
- get animation() {
109
- return this.#animation_accessor_storage;
110
- }
111
- set animation(value) {
112
- this.#animation_accessor_storage = value;
113
- }
114
- /** Open the alert. */
115
- open() {
116
- this.state = "opening";
117
- if (!this.dispatchBeforeOpenEvent()) return;
118
- if (this._isZeroAnimationDuration()) this._handleOpening();
119
- }
120
- /** Close the alert. */
121
- close() {
122
- if (this.state === "opened" && this.dispatchBeforeCloseEvent()) {
123
- this.state = "closing";
124
- if (this._isZeroAnimationDuration()) this._handleClosing();
125
- }
126
- }
127
- firstUpdated(changedProperties) {
128
- super.firstUpdated(changedProperties);
129
- this.open();
130
- }
131
- willUpdate(changedProperties) {
132
- super.willUpdate(changedProperties);
133
- if (changedProperties.has("size")) this._configureTitle();
134
- }
135
- _isZeroAnimationDuration() {
136
- return isZeroAnimationDuration(this, "--sbb-alert-animation-duration");
137
- }
138
- _onAnimationEnd(event) {
139
- if (this.state === "opening" && event.animationName === "open-opacity") this._handleOpening();
140
- else if (this.state === "closing" && event.animationName === "close") this._handleClosing();
141
- }
142
- _handleOpening() {
143
- this.state = "opened";
144
- this.dispatchOpenEvent();
145
- }
146
- _handleClosing() {
147
- this.state = "closed";
148
- this.dispatchCloseEvent();
149
- setTimeout(() => this.remove());
150
- }
151
- _handleSlotchange() {
152
- this._syncLinks();
153
- const title = Array.from(this.children).find((el) => el.localName === "sbb-title");
154
- if (title) title.slot = "title";
155
- }
156
- _syncLinks() {
157
- Array.from(this.querySelectorAll?.("sbb-link") ?? []).forEach((link) => {
158
- customElements.upgrade(link);
159
- link.negative = this._isLightMode();
160
- });
161
- }
162
- _configureTitle() {
163
- const title = this.querySelector?.("sbb-title");
164
- if (title) {
165
- customElements.upgrade(title);
166
- title.negative = this._isLightMode();
167
- title.visualLevel = this.size === "l" ? "3" : "5";
168
- }
169
- }
170
- _isLightMode() {
171
- return !this._darkModeController.matches();
172
- }
173
- renderIconName() {
174
- return super.renderIconName() || "info";
175
- }
176
- render() {
177
- return html`
178
- <div class="sbb-alert__transition-wrapper" @animationend=${this._onAnimationEnd}>
179
- <!-- sub wrapper needed to properly support fade in animation -->
180
- <div class="sbb-alert__transition-sub-wrapper">
181
- <div class="sbb-alert">
182
- <span class="sbb-alert__icon"> ${this.renderIconSlot()} </span>
183
- <span class="sbb-alert__content">
184
- <slot name="title" @slotchange=${this._configureTitle}></slot>
185
- <p class="sbb-alert__content-slot">
186
- <slot @slotchange=${this._handleSlotchange}></slot>
187
- </p>
188
- </span>
189
- ${!this.readOnly ? html`<span class="sbb-alert__close-button-wrapper">
190
- <sbb-divider
191
- orientation="vertical"
192
- ?negative=${this._isLightMode()}
193
- class="sbb-alert__close-button-divider"
194
- ></sbb-divider>
195
- <sbb-transparent-button
196
- ?negative=${this._isLightMode()}
197
- size=${this.size === "l" ? "m" : this.size}
198
- icon-name="cross-small"
199
- @click=${() => this.close()}
200
- aria-label=${i18nCloseAlert[this._language.current]}
201
- class="sbb-alert__close-button"
202
- ></sbb-transparent-button>
203
- </span>` : nothing}
204
- </div>
205
- </div>
206
- </div>
207
- `;
208
- }
209
- };
210
- })();
211
- //#endregion
212
- export { SbbAlertElement as t };
213
-
214
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"alert.component-Cn36k_Hf.js","names":[],"sources":["../../../src/elements/alert/alert/alert.scss?inline","../../../src/elements/alert/alert/alert.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n// Open/Close animation vars\n$open-anim-rows-from: 0fr;\n$open-anim-rows-to: 1fr;\n$open-anim-opacity-from: 0;\n$open-anim-opacity-to: 1;\n\n:host {\n  display: block;\n\n  --sbb-alert-background-color: var(--sbb-background-color-1-inverted);\n  --sbb-alert-border-radius: var(--sbb-border-radius-4x);\n  --sbb-alert-color: light-dark(var(--sbb-color-aluminium), var(--sbb-color-anthracite));\n  --sbb-alert-padding: var(--sbb-spacing-responsive-xxs) var(--sbb-spacing-responsive-xs);\n  --sbb-alert-icon-size: #{sbb.px-to-rem-build(20)};\n  --sbb-alert-close-icon-margin: var(--sbb-spacing-responsive-xxs);\n  --sbb-alert-gap: var(--sbb-spacing-fixed-2x) var(--sbb-spacing-responsive-xs);\n  --sbb-alert-animation-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-6x)\n  );\n  --sbb-alert-timing-function: ease-in;\n  --sbb-alert-title-margin-block: 0;\n\n  @include sbb.mq($from: large) {\n    --sbb-alert-icon-size: #{sbb.px-to-rem-build(28)};\n  }\n\n  @include sbb.if-forced-colors {\n    // Use outline here to not influence content position.\n    // Due to overflow hidden of inner elements it's placed on host.\n    outline: var(--sbb-border-width-1x) solid CanvasText;\n    border-radius: var(--sbb-alert-border-radius);\n  }\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([size='s']) {\n  --sbb-alert-gap: var(--sbb-spacing-fixed-1x) var(--sbb-spacing-responsive-xxs);\n  --sbb-alert-close-icon-margin: var(--sbb-spacing-responsive-xxxs);\n}\n\n:host([size='l']) {\n  --sbb-alert-icon-size: var(--sbb-size-icon-ui-small);\n  --sbb-alert-title-margin-block: 0 var(--sbb-spacing-fixed-1x);\n\n  @include sbb.mq($from: large) {\n    --sbb-alert-icon-size: #{sbb.px-to-rem-build(34)};\n  }\n}\n\n:host(:not(:state(dark))) {\n  --sbb-focus-outline-color: var(--sbb-focus-outline-color-dark);\n}\n\n.sbb-alert__transition-wrapper {\n  display: grid;\n  grid-template-rows: #{$open-anim-rows-from};\n  opacity: #{$open-anim-opacity-from};\n\n  :host(:is(:state(state-opened), :state(state-closing))) & {\n    grid-template-rows: #{$open-anim-rows-to};\n    opacity: #{$open-anim-opacity-to};\n  }\n\n  :host(:state(state-opening)) & {\n    animation-name: open, open-opacity;\n    animation-fill-mode: forwards;\n    animation-duration: var(--sbb-alert-animation-duration);\n    animation-timing-function: var(--sbb-alert-timing-function);\n    animation-delay: 0s, var(--sbb-alert-animation-duration);\n  }\n\n  :host(:state(state-closing)) & {\n    animation: {\n      name: close-opacity, close;\n      fill-mode: forwards;\n      duration: var(--sbb-alert-animation-duration);\n      timing-function: var(--sbb-alert-timing-function);\n      delay: 0s, var(--sbb-disable-animation-duration, var(--sbb-animation-duration-2x));\n    }\n  }\n}\n\n.sbb-alert__transition-sub-wrapper {\n  overflow: hidden;\n}\n\n.sbb-alert {\n  @include sbb.text-s--regular;\n\n  display: grid;\n  grid-template-columns: 1fr auto;\n  align-items: center;\n  gap: var(--sbb-alert-gap);\n  min-width: fit-content;\n  padding: var(--sbb-alert-padding);\n  overflow: hidden;\n  color: var(--sbb-alert-color);\n  background-color: var(--sbb-alert-background-color);\n  border-radius: var(--sbb-alert-border-radius);\n\n  @include sbb.mq($from: small) {\n    grid-template-columns: auto 1fr auto;\n    align-items: flex-start;\n  }\n}\n\n.sbb-alert__icon {\n  display: flex;\n  align-items: start;\n  padding-block: var(--sbb-spacing-fixed-1x);\n  min-width: var(--sbb-alert-icon-size);\n\n  --sbb-icon-svg-width: var(--sbb-alert-icon-size);\n  --sbb-icon-svg-height: var(--sbb-alert-icon-size);\n}\n\n.sbb-alert__content {\n  // As the background turns white, we need to ensure that all content is displayed in light mode.\n  color-scheme: only light;\n  order: 3;\n  grid-column: 1 / 3;\n\n  @include sbb.mq($from: small) {\n    order: initial;\n    grid-column-start: initial;\n    grid-column-end: initial;\n  }\n}\n\n.sbb-alert__content-slot {\n  // Reset paragraph styles\n  display: inline;\n  margin: 0;\n  padding: 0;\n}\n\n.sbb-alert__close-button-wrapper {\n  // As the background turns white, we need to ensure that the button is displayed in light mode.\n  color-scheme: only light;\n  display: flex;\n  justify-content: flex-end;\n  align-items: center;\n  height: 100%;\n}\n\n.sbb-alert__close-button {\n  @include sbb.mq($from: small) {\n    margin-inline-start: var(--sbb-alert-close-icon-margin);\n  }\n}\n\n.sbb-alert__close-button-divider {\n  display: none;\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    grid-template-rows: #{$open-anim-rows-from};\n  }\n\n  to {\n    grid-template-rows: #{$open-anim-rows-to};\n  }\n}\n\n@keyframes open-opacity {\n  from {\n    opacity: #{$open-anim-opacity-from};\n  }\n\n  to {\n    opacity: #{$open-anim-opacity-to};\n  }\n}\n\n@keyframes close {\n  from {\n    grid-template-rows: #{$open-anim-rows-to};\n  }\n\n  to {\n    grid-template-rows: #{$open-anim-rows-from};\n  }\n}\n\n@keyframes close-opacity {\n  from {\n    opacity: #{$open-anim-opacity-to};\n  }\n\n  to {\n    opacity: #{$open-anim-opacity-from};\n  }\n}\n\n::slotted(sbb-title) {\n  // Overwrite sbb-title default margin\n  margin-block: var(--sbb-alert-title-margin-block);\n}\n","import {\n  type CSSResultGroup,\n  html,\n  nothing,\n  type PropertyValues,\n  type TemplateResult,\n  unsafeCSS,\n} from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbTransparentButtonElement } from '../../button.pure.ts';\nimport {\n  boxSizingStyles,\n  i18nCloseAlert,\n  isLean,\n  isZeroAnimationDuration,\n  SbbDarkModeController,\n  type SbbElementType,\n  SbbLanguageController,\n  SbbOpenCloseBaseElement,\n  SbbReadonlyMixin,\n} from '../../core.ts';\nimport { SbbDividerElement } from '../../divider.pure.ts';\nimport { SbbIconNameMixin } from '../../icon.pure.ts';\nimport type { SbbLinkElement } from '../../link.pure.ts';\nimport type { SbbTitleElement } from '../../title.pure.ts';\n\nimport style from './alert.scss?inline';\n\n/**\n * It displays messages which require user's attention.\n *\n * @slot - Use the unnamed slot to add content to the `sbb-alert`. At a minimum an `sbb-title` element and a descriptive text should be used.\n * @slot icon - Should be a `sbb-icon` which is displayed next to the title. Styling is optimized for icons of type HIM-CUS.\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 */\nexport class SbbAlertElement extends SbbIconNameMixin(SbbReadonlyMixin(SbbOpenCloseBaseElement)) {\n  public static override readonly elementName: string = 'sbb-alert';\n  public static override elementDependencies: SbbElementType[] = [\n    SbbTransparentButtonElement,\n    SbbDividerElement,\n  ];\n  public static override styles: CSSResultGroup = [boxSizingStyles, unsafeCSS(style)];\n  public static override readonly events = {\n    beforeopen: 'beforeopen',\n    open: 'open',\n    beforeclose: 'beforeclose',\n    close: 'close',\n  } as const;\n\n  /**\n   * You can choose between `s`, `m` or `l` size.\n   * @default 'm' / 's' (lean)\n   */\n  @property({ reflect: true }) public accessor size: 's' | 'm' | 'l' = isLean() ? 's' : 'm';\n\n  /** The enabled animations. */\n  @property({ reflect: true }) public accessor animation: 'open' | 'close' | 'all' | 'none' = 'all';\n\n  private _language = new SbbLanguageController(this);\n  private _darkModeController = new SbbDarkModeController(this, () => {\n    this._syncLinks();\n    this._configureTitle();\n    this.requestUpdate();\n  });\n\n  /** Open the alert. */\n  public open(): void {\n    this.state = 'opening';\n\n    if (!this.dispatchBeforeOpenEvent()) {\n      return;\n    }\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  /** Close the alert. */\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  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this.open();\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 _isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-alert-animation-duration');\n  }\n\n  private _onAnimationEnd(event: AnimationEvent): void {\n    if (this.state === 'opening' && event.animationName === 'open-opacity') {\n      this._handleOpening();\n    } else if (this.state === 'closing' && event.animationName === 'close') {\n      this._handleClosing();\n    }\n  }\n\n  private _handleOpening(): void {\n    this.state = 'opened';\n    this.dispatchOpenEvent();\n  }\n\n  private _handleClosing(): void {\n    this.state = 'closed';\n    this.dispatchCloseEvent();\n    setTimeout(() => this.remove());\n  }\n\n  private _handleSlotchange(): void {\n    this._syncLinks();\n\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 _syncLinks(): void {\n    Array.from(this.querySelectorAll?.<SbbLinkElement>('sbb-link') ?? []).forEach((link) => {\n      customElements.upgrade(link);\n      link.negative = this._isLightMode();\n    });\n  }\n\n  private _configureTitle(): void {\n    const title = this.querySelector?.<SbbTitleElement>('sbb-title');\n    if (title) {\n      customElements.upgrade(title);\n      title.negative = this._isLightMode();\n      title.visualLevel = this.size === 'l' ? '3' : '5';\n    }\n  }\n\n  private _isLightMode(): boolean {\n    return !this._darkModeController.matches();\n  }\n\n  protected override renderIconName(): string {\n    return super.renderIconName() || 'info';\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-alert__transition-wrapper\" @animationend=${this._onAnimationEnd}>\n        <!-- sub wrapper needed to properly support fade in animation -->\n        <div class=\"sbb-alert__transition-sub-wrapper\">\n          <div class=\"sbb-alert\">\n            <span class=\"sbb-alert__icon\"> ${this.renderIconSlot()} </span>\n            <span class=\"sbb-alert__content\">\n              <slot name=\"title\" @slotchange=${this._configureTitle}></slot>\n              <p class=\"sbb-alert__content-slot\">\n                <slot @slotchange=${this._handleSlotchange}></slot>\n              </p>\n            </span>\n            ${!this.readOnly\n              ? html`<span class=\"sbb-alert__close-button-wrapper\">\n                  <sbb-divider\n                    orientation=\"vertical\"\n                    ?negative=${this._isLightMode()}\n                    class=\"sbb-alert__close-button-divider\"\n                  ></sbb-divider>\n                  <sbb-transparent-button\n                    ?negative=${this._isLightMode()}\n                    size=${this.size === 'l' ? 'm' : this.size}\n                    icon-name=\"cross-small\"\n                    @click=${() => this.close()}\n                    aria-label=${i18nCloseAlert[this._language.current]}\n                    class=\"sbb-alert__close-button\"\n                  ></sbb-transparent-button>\n                </span>`\n              : nothing}\n          </div>\n        </div>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-alert': SbbAlertElement;\n  }\n}\n"],"mappings":"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"}