@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.
- package/core/styles/core.scss +5 -10
- package/core.css +14 -9
- package/custom-elements.json +75 -75
- package/development/notification/notification.component.js +1 -1
- package/development/notification.component-BT3ZQhUI.js +525 -0
- package/development/notification.js +1 -1
- package/development/notification.pure.js +1 -1
- package/notification/notification.component.js +1 -1
- package/notification.component-DA7sZ3m4.js +197 -0
- package/notification.js +1 -1
- package/notification.pure.js +1 -1
- package/off-brand-theme.css +14 -9
- package/package.json +2 -2
- package/safety-theme.css +14 -9
- package/standard-theme.css +14 -9
- package/development/notification.component-B5EBKKf8.js +0 -530
- package/notification.component-DZS8z1oa.js +0 -197
|
@@ -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 };
|