@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,197 +0,0 @@
1
- import { __esDecorate as e, __runInitializers as t } from "tslib";
2
- import { css as n, html as r, nothing as i } from "lit";
3
- import { property as a } from "lit/decorators.js";
4
- import { SbbElement as o } from "./core/base-elements.js";
5
- import { isLean as s, isZeroAnimationDuration as c } from "./core/dom.js";
6
- import { SbbReadonlyMixin as l } from "./core/mixins.js";
7
- import { boxSizingStyles as u } from "./core/styles.js";
8
- import { SbbLanguageController as d } from "./core/controllers.js";
9
- import { i18nCloseNotification as f } from "./core/i18n.js";
10
- import { SbbIconNameMixin as p } from "./icon.js";
11
- import "./divider.js";
12
- import { ResizeController as m } from "@lit-labs/observers/resize-controller.js";
13
- import "./button/secondary-button.js";
14
- //#region src/elements/notification/notification.scss?lit&inline
15
- var h = n`:host{--sbb-notification-margin:0;--sbb-notification-padding-block:var(--sbb-spacing-responsive-xxs);--sbb-notification-padding-inline:var(--sbb-spacing-responsive-xs);--sbb-notification-color:var(--sbb-color-2-negative-inverted);--sbb-notification-background-color:var(--lightningcss-light,color-mix(in srgb, var(--sbb-notification-type-color) 5%, white))var(--lightningcss-dark,color-mix(in srgb, var(--sbb-notification-type-color) 35%, white));--sbb-notification-icon-color:var(--sbb-notification-type-color);--sbb-notification-border-width:var(--sbb-border-width-1x);--sbb-notification-border:var(--sbb-notification-border-width) solid var(--sbb-notification-type-color);--sbb-notification-base-border-radius:var(--sbb-border-radius-4x);--sbb-notification-border-radius-start:calc(var(--sbb-notification-base-border-radius) / 2);--sbb-notification-animation-duration:var(--sbb-disable-animation-duration,var(--sbb-animation-duration-4x));--sbb-notification-timing-function:ease-in;--sbb-notification-content-padding-inline:var(--sbb-spacing-responsive-xxxs) var(--sbb-spacing-responsive-xs);--_sbb-notification-icon-authoritative-font-size:1em;--_sbb-notification-icon-authoritative-line-height:var(--sbb-typo-line-height-text);--sbb-focus-outline-color:var(--sbb-focus-outline-color-default);display:block}:host(:is(:state(state-opening),[state--state-opening]):not([animation=open],[animation=all])),:host(:is(:state(state-closing),[state--state-closing]):not([animation=close],[animation=all])),:host(:is(:state(resize-disable-animation),[state--resize-disable-animation])){--sbb-disable-animation-duration:0s}:host(:is(:not([type]),[type=info])){--sbb-notification-type-color:var(--sbb-color-smoke);--sbb-notification-icon-color:var(--sbb-notification-color);--sbb-notification-divider-opacity-light:20%;--sbb-notification-divider-opacity-dark:20%}:host([type=note]){--sbb-notification-type-color:var(--sbb-color-sky);--sbb-notification-divider-opacity-light:20%;--sbb-notification-divider-opacity-dark:20%}:host([type=success]){--sbb-notification-type-color:var(--sbb-color-success);--sbb-notification-divider-opacity-light:15%;--sbb-notification-divider-opacity-dark:30%}:host([type=warn]){--sbb-notification-type-color:var(--sbb-color-warning);--sbb-notification-icon-color:var(--sbb-notification-color);--sbb-notification-divider-opacity-light:25%;--sbb-notification-divider-opacity-dark:40%}:host([type=error]){--sbb-notification-type-color:var(--sbb-color-error);--sbb-notification-divider-opacity-light:10%;--sbb-notification-divider-opacity-dark:25%}:host([size=s]){--sbb-notification-padding-block:var(--sbb-spacing-responsive-xxxs);--sbb-notification-padding-inline:var(--sbb-spacing-responsive-xxs) var(--sbb-spacing-responsive-xxxs);--sbb-notification-content-padding-inline:var(--sbb-spacing-responsive-xxxs) var(--sbb-spacing-responsive-xxs)}@media (width>=37.5rem){:host([size=s]){--sbb-notification-padding-inline:var(--sbb-spacing-responsive-xxs)}}.sbb-notification__wrapper{width:calc(100% - (var(--sbb-notification-base-border-radius) - var(--sbb-notification-border-width)));border:var(--sbb-notification-border);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);opacity:0;max-height:0;margin:0;position:relative;inset-inline-start:calc(var(--sbb-notification-base-border-radius) - var(--sbb-notification-border-width))}.sbb-notification__wrapper:before{content:"";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);background-color:var(--sbb-notification-type-color);border:var(--sbb-notification-border);border-radius:var(--sbb-notification-base-border-radius);position:absolute}:host(:is(:is(:state(state-opened),[state--state-opened]),:is(:state(state-closing),[state--state-closing]))) .sbb-notification__wrapper{opacity:1;max-height:calc(var(--sbb-notification-height) + var(--sbb-notification-border-width) * 2);margin:var(--sbb-notification-margin,0)}:host(:is(:state(state-opening),[state--state-opening])) .sbb-notification__wrapper{animation-name:open;animation-fill-mode:forwards;animation-duration:var(--sbb-notification-animation-duration);animation-timing-function:var(--sbb-notification-timing-function)}:host(:is(:state(state-closing),[state--state-closing])) .sbb-notification__wrapper{animation-name:close,close-height;animation-fill-mode:forwards;animation-duration:var(--sbb-notification-animation-duration);animation-timing-function:var(--sbb-notification-timing-function);animation-delay:0s, var(--sbb-disable-animation-duration,var(--sbb-animation-duration-2x))}.sbb-notification{--sbb-text-font-size:var(--sbb-text-font-size-s);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-text);letter-spacing:var(--sbb-typo-letter-spacing-text);font-size:var(--sbb-text-font-size);padding-block:var(--sbb-notification-padding-block);padding-inline:var(--sbb-notification-padding-inline);color:var(--sbb-notification-color);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);background-color:var(--sbb-notification-background-color);grid-template-columns:1fr auto;align-items:center;display:grid;position:relative;overflow:hidden}@media (width>=37.5rem){.sbb-notification{grid-template-columns:auto 1fr auto;align-items:flex-start}}:host([size=s]) .sbb-notification{--sbb-text-font-size:var(--sbb-text-font-size-xs);font-family:var(--sbb-typo-font-family);font-weight:400;line-height:var(--sbb-typo-line-height-text);letter-spacing:var(--sbb-typo-letter-spacing-text);font-size:var(--sbb-text-font-size)}.sbb-notification__icon,::slotted(sbb-icon){color:var(--sbb-notification-icon-color);--sbb-icon-svg-width:var(--sbb-notification-icon-size)}@media (width>=37.5rem){.sbb-notification__icon,::slotted(sbb-icon){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)}}.sbb-notification__content{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light only;order:3;grid-area:2/1/3/3;margin-block-start:var(--sbb-spacing-fixed-2x)}@media (width>=37.5rem){.sbb-notification__content{order:initial;grid-area:initial;padding-inline:var(--sbb-notification-content-padding-inline);margin-block-start:0}}.sbb-notification__text{margin:0;padding:0;display:inline}.sbb-notification__close-wrapper{align-items:center;gap:var(--sbb-spacing-responsive-xxs);height:100%;display:flex}.sbb-notification__divider{--sbb-divider-color:var(--lightningcss-light,color-mix(in srgb, var(--sbb-notification-type-color) var(--sbb-notification-divider-opacity-light), var(--sbb-notification-background-color)))var(--lightningcss-dark,color-mix(in srgb, var(--sbb-notification-type-color) var(--sbb-notification-divider-opacity-dark), var(--sbb-notification-background-color)));display:none;position:relative;inset-inline-start:var(--sbb-border-width-1x)}@media (width>=37.5rem){.sbb-notification__divider{height:calc(100% - var(--sbb-spacing-fixed-1x) * 2);display:block}}@keyframes open{0%{opacity:0;max-height:0;margin:0}to{opacity:1;max-height:calc(var(--sbb-notification-height) + var(--sbb-notification-border-width) * 2);margin:var(--sbb-notification-margin,0)}}@keyframes close{0%{opacity:1;margin:var(--sbb-notification-margin,0)}to{opacity:0;margin:0}}@keyframes close-height{0%{max-height:calc(var(--sbb-notification-height) + var(--sbb-notification-border-width) * 2)}to{max-height:0}}::slotted(sbb-title){margin:0}`, g = new Map([
16
- ["info", "circle-information-small"],
17
- ["note", "circle-information-small"],
18
- ["success", "circle-tick-small"],
19
- ["warn", "circle-exclamation-point-small"],
20
- ["error", "circle-cross-small"]
21
- ]), _ = 150, v = (() => {
22
- let n = p(l(o)), v, y = [], b = [], x, S = [], C = [], w, T = [], E = [];
23
- return class extends n {
24
- static {
25
- let t = typeof Symbol == "function" && Symbol.metadata ? Object.create(n[Symbol.metadata] ?? null) : void 0;
26
- v = [a({ reflect: !0 })], x = [a({ reflect: !0 })], w = [a({ reflect: !0 })], e(this, null, v, {
27
- kind: "accessor",
28
- name: "type",
29
- static: !1,
30
- private: !1,
31
- access: {
32
- has: (e) => "type" in e,
33
- get: (e) => e.type,
34
- set: (e, t) => {
35
- e.type = t;
36
- }
37
- },
38
- metadata: t
39
- }, y, b), e(this, null, x, {
40
- kind: "accessor",
41
- name: "size",
42
- static: !1,
43
- private: !1,
44
- access: {
45
- has: (e) => "size" in e,
46
- get: (e) => e.size,
47
- set: (e, t) => {
48
- e.size = t;
49
- }
50
- },
51
- metadata: t
52
- }, S, C), e(this, null, w, {
53
- kind: "accessor",
54
- name: "animation",
55
- static: !1,
56
- private: !1,
57
- access: {
58
- has: (e) => "animation" in e,
59
- get: (e) => e.animation,
60
- set: (e, t) => {
61
- e.animation = t;
62
- }
63
- },
64
- metadata: t
65
- }, T, E), t && Object.defineProperty(this, Symbol.metadata, {
66
- enumerable: !0,
67
- configurable: !0,
68
- writable: !0,
69
- value: t
70
- });
71
- }
72
- static {
73
- this.elementName = "sbb-notification";
74
- }
75
- static {
76
- this.styles = [u, h];
77
- }
78
- static {
79
- this.events = {
80
- beforeopen: "beforeopen",
81
- open: "open",
82
- beforeclose: "beforeclose",
83
- close: "close"
84
- };
85
- }
86
- #e;
87
- get type() {
88
- return this.#e;
89
- }
90
- set type(e) {
91
- this.#e = e;
92
- }
93
- #t;
94
- get size() {
95
- return this.#t;
96
- }
97
- set size(e) {
98
- this.#t = e;
99
- }
100
- #n;
101
- get animation() {
102
- return this.#n;
103
- }
104
- set animation(e) {
105
- this.#n = e;
106
- }
107
- set _state(e) {
108
- this._stateInternal && this.internals.states.delete(`state-${this._stateInternal}`), this._stateInternal = e, this._stateInternal && this.internals.states.add(`state-${this._stateInternal}`);
109
- }
110
- get _state() {
111
- return this._stateInternal;
112
- }
113
- constructor() {
114
- super(), this.#e = t(this, y, "info"), this.#t = (t(this, b), t(this, S, s() ? "s" : "m")), this.#n = (t(this, C), t(this, T, "all")), this._stateInternal = t(this, E), this._resizeObserverTimeout = null, this._language = new d(this), this._notificationResizeObserver = new m(this, {
115
- target: null,
116
- skipInitial: !0,
117
- callback: () => this._onNotificationResize()
118
- }), this._state = "closed";
119
- }
120
- willUpdate(e) {
121
- super.willUpdate(e), e.has("size") && this._configureTitle();
122
- }
123
- _open() {
124
- this._state === "closed" && (this._state = "opening", this.dispatchEvent(new Event("beforeopen")), this._isZeroAnimationDuration() && this._handleOpening());
125
- }
126
- close() {
127
- this._state === "opened" && this._dispatchBeforeCloseEvent() && (this._state = "closing", this._isZeroAnimationDuration() && this._handleClosing());
128
- }
129
- _dispatchBeforeCloseEvent() {
130
- return this.dispatchEvent(new Event("beforeclose", { cancelable: !0 }));
131
- }
132
- firstUpdated(e) {
133
- super.firstUpdated(e), this._notificationElement = this.shadowRoot?.querySelector(".sbb-notification__wrapper"), this.updateComplete.then(() => {
134
- this._setNotificationHeight(), this._open();
135
- });
136
- }
137
- _isZeroAnimationDuration() {
138
- return c(this, "--sbb-notification-animation-duration");
139
- }
140
- _setNotificationHeight() {
141
- if (!this._notificationElement?.scrollHeight) return;
142
- let e = `${this._notificationElement.scrollHeight}px`;
143
- this.style.setProperty("--sbb-notification-height", e);
144
- }
145
- _onNotificationResize() {
146
- this._state === "opened" && (this._resizeObserverTimeout && clearTimeout(this._resizeObserverTimeout), this.internals.states.add("resize-disable-animation"), this._resizeObserverTimeout = setTimeout(() => this.internals.states.delete("resize-disable-animation"), _), setTimeout(() => this._setNotificationHeight()));
147
- }
148
- _onNotificationAnimationEnd(e) {
149
- this._state === "opening" && e.animationName === "open" && this._handleOpening(), this._state === "closing" && e.animationName === "close-height" && this._handleClosing();
150
- }
151
- _handleOpening() {
152
- this._state = "opened", this._notificationResizeObserver.observe(this._notificationElement), this.dispatchEvent(new Event("open"));
153
- }
154
- _handleClosing() {
155
- this._state = "closed", this.dispatchEvent(new Event("close")), this._notificationResizeObserver.unobserve(this._notificationElement), setTimeout(() => this.remove());
156
- }
157
- _handleSlotchange() {
158
- let e = Array.from(this.children).find((e) => e.localName === "sbb-title");
159
- e && (e.slot = "title");
160
- }
161
- _configureTitle() {
162
- let e = this.querySelector?.("sbb-title");
163
- e && (customElements.upgrade(e), e.visualLevel = this.size === "m" ? "5" : "6");
164
- }
165
- renderIconName() {
166
- return super.renderIconName() || g.get(this.type);
167
- }
168
- render() {
169
- return r`
170
- <div class="sbb-notification__wrapper" @animationend=${this._onNotificationAnimationEnd}>
171
- <div class="sbb-notification">
172
- ${this.renderIconSlot("sbb-notification__icon")}
173
- <span class="sbb-notification__content">
174
- <slot name="title" @slotchange=${this._configureTitle}></slot>
175
- <p class="sbb-notification__text">
176
- <slot @slotchange=${this._handleSlotchange}></slot>
177
- </p>
178
- </span>
179
-
180
- ${this.readOnly ? i : r`<span class="sbb-notification__close-wrapper">
181
- <sbb-divider class="sbb-notification__divider" orientation="vertical"></sbb-divider>
182
- <sbb-secondary-button
183
- size=${this.size}
184
- icon-name="cross-small"
185
- @click=${() => this.close()}
186
- aria-label=${f[this._language.current]}
187
- class="sbb-notification__close"
188
- ></sbb-secondary-button>
189
- </span>`}
190
- </div>
191
- </div>
192
- `;
193
- }
194
- };
195
- })();
196
- //#endregion
197
- export { v as t };