@sbb-esta/lyne-elements-dev 4.9.0-dev.1774601733 → 4.9.0-dev.1774848187
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 +13 -65
- package/core.css +37 -34
- package/development/sidebar/sidebar/sidebar.component.js +1 -1
- package/development/sidebar/sidebar-content/sidebar-content.component.js +1 -1
- package/development/sidebar/sidebar-content.js +1 -1
- package/development/sidebar/sidebar-title/sidebar-title.component.js +1 -1
- package/development/sidebar/sidebar-title.js +1 -1
- package/development/sidebar/sidebar.js +1 -1
- package/development/{sidebar-content.component-rgVbuDj-.js → sidebar-content.component-6oadojLp.js} +4 -4
- package/development/{sidebar-title.component-BFkOaVcL.js → sidebar-title.component-DU-ZLEU0.js} +3 -3
- package/development/sidebar.component-BmLRuuec.js +506 -0
- package/development/sidebar.js +3 -3
- package/development/sidebar.pure.js +3 -3
- package/off-brand-theme.css +37 -34
- package/package.json +2 -2
- package/safety-theme.css +37 -34
- package/sidebar/sidebar/sidebar.component.js +1 -1
- package/sidebar/sidebar-content/sidebar-content.component.js +1 -1
- package/sidebar/sidebar-content.js +1 -1
- package/sidebar/sidebar-title/sidebar-title.component.js +1 -1
- package/sidebar/sidebar-title.js +1 -1
- package/sidebar/sidebar.js +1 -1
- package/{sidebar-content.component-da7RYWO6.js → sidebar-content.component-BYmmHoc5.js} +1 -1
- package/{sidebar-title.component-CjWUiisH.js → sidebar-title.component-lEdsEEMO.js} +1 -1
- package/{sidebar.component-Cde1EWDT.js → sidebar.component-BkTSnoNM.js} +2 -2
- package/sidebar.js +3 -3
- package/sidebar.pure.js +3 -3
- package/standard-theme.css +37 -34
- package/development/sidebar.component-hkvDm_fC.js +0 -506
|
@@ -0,0 +1,506 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
import { css, html, isServer } from "lit";
|
|
3
|
+
import { eventOptions, property } from "lit/decorators.js";
|
|
4
|
+
import { SbbOpenCloseBaseElement } from "./core/base-elements.js";
|
|
5
|
+
import { forceType, handleDistinctChange } from "./core/decorators.js";
|
|
6
|
+
import { isZeroAnimationDuration } from "./core/dom.js";
|
|
7
|
+
import { SbbAnimationCompleteMixin } from "./core/mixins.js";
|
|
8
|
+
import { boxSizingStyles } from "./core/styles.js";
|
|
9
|
+
import { SbbEscapableOverlayController } from "./core/controllers.js";
|
|
10
|
+
import { ResizeController } from "@lit-labs/observers/resize-controller.js";
|
|
11
|
+
import { SbbFocusTrapController } from "./core/a11y.js";
|
|
12
|
+
//#region src/elements/sidebar/sidebar/sidebar.scss?lit&inline
|
|
13
|
+
var sidebar_default = css`:host {
|
|
14
|
+
--sbb-link-text-decoration-line: none;
|
|
15
|
+
--sbb-sidebar-background-color: var(--sbb-background-color-1);
|
|
16
|
+
--sbb-sidebar-scrollbar-placeholder-width: var(--sbb-spacing-fixed-3x);
|
|
17
|
+
--_sbb-sidebar-margin: 0;
|
|
18
|
+
--_sbb-sidebar-margin-block-start: var(--sbb-sidebar-margin);
|
|
19
|
+
--_sbb-sidebar-translate-x: -100%;
|
|
20
|
+
--_sbb-sidebar-z-index: 2;
|
|
21
|
+
--_sbb-sidebar-padding-inline-end: var(--sbb-sidebar-padding);
|
|
22
|
+
--_sbb-sidebar-padding-block-start: var(--sbb-sidebar-padding);
|
|
23
|
+
--_sbb-sidebar-border-radius-start: var(--sbb-sidebar-border-radius);
|
|
24
|
+
--_sbb-sidebar-border-radius-end: 0;
|
|
25
|
+
--_sbb-sidebar-close-button-size: var(--sbb-size-element-xs);
|
|
26
|
+
--_sbb-sidebar-max-width: calc(100% - 2 * var(--_sbb-sidebar-margin));
|
|
27
|
+
display: block;
|
|
28
|
+
width: 20rem;
|
|
29
|
+
}
|
|
30
|
+
@supports (scrollbar-gutter: stable) and (not (-webkit-touch-callout: none)) {
|
|
31
|
+
:host {
|
|
32
|
+
--_sbb-sidebar-padding-inline-end: calc(
|
|
33
|
+
var(--sbb-sidebar-padding) - var(--sbb-sidebar-scrollbar-placeholder-width)
|
|
34
|
+
);
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
:host([color=white]) {
|
|
39
|
+
--sbb-sidebar-background-color: var(--sbb-background-color-1);
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
:host([color=milk]) {
|
|
43
|
+
--sbb-sidebar-background-color: var(--sbb-background-color-3);
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
:host(:is([mode=over], :is(:state(mode-over-forced),[state--mode-over-forced]):not(:is(:state(mode-over-forced-closing),[state--mode-over-forced-closing])))) {
|
|
47
|
+
--_sbb-sidebar-margin: var(--sbb-sidebar-margin);
|
|
48
|
+
--_sbb-sidebar-border-radius-end: var(--sbb-sidebar-border-radius);
|
|
49
|
+
--_sbb-sidebar-z-index: 3;
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
:host(:is(:dir(rtl), [position=end])) {
|
|
53
|
+
--_sbb-sidebar-translate-x: 100%;
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
:host(:dir(rtl)[position=end]) {
|
|
57
|
+
--_sbb-sidebar-translate-x: -100%;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
.sbb-sidebar {
|
|
61
|
+
width: inherit;
|
|
62
|
+
max-width: var(--_sbb-sidebar-max-width);
|
|
63
|
+
background-color: var(--sbb-sidebar-background-color);
|
|
64
|
+
display: flex;
|
|
65
|
+
flex-direction: column;
|
|
66
|
+
position: absolute;
|
|
67
|
+
overflow: hidden;
|
|
68
|
+
inset-block: 0;
|
|
69
|
+
z-index: var(--_sbb-sidebar-z-index);
|
|
70
|
+
border-start-start-radius: var(--_sbb-sidebar-border-radius-start);
|
|
71
|
+
border-start-end-radius: var(--_sbb-sidebar-border-radius-start);
|
|
72
|
+
border-end-start-radius: var(--_sbb-sidebar-border-radius-end);
|
|
73
|
+
border-end-end-radius: var(--_sbb-sidebar-border-radius-end);
|
|
74
|
+
margin: var(--_sbb-sidebar-margin);
|
|
75
|
+
margin-block-start: var(--_sbb-sidebar-margin-block-start);
|
|
76
|
+
transition-duration: var(--sbb-sidebar-container-animation-duration);
|
|
77
|
+
transition-timing-function: var(--sbb-sidebar-container-animation-easing);
|
|
78
|
+
transition-property: width, translate;
|
|
79
|
+
translate: none;
|
|
80
|
+
}
|
|
81
|
+
:host([position=end]) .sbb-sidebar {
|
|
82
|
+
inset-inline-end: 0;
|
|
83
|
+
}
|
|
84
|
+
:host(:is(:state(state-closed),[state--state-closed])) .sbb-sidebar {
|
|
85
|
+
visibility: hidden;
|
|
86
|
+
}
|
|
87
|
+
:host(:is(:is(:state(state-closing),[state--state-closing]), :is(:state(state-closed),[state--state-closed]))) .sbb-sidebar {
|
|
88
|
+
translate: var(--_sbb-sidebar-translate-x) 0;
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
.sbb-sidebar-title-section {
|
|
92
|
+
display: flex;
|
|
93
|
+
width: 100%;
|
|
94
|
+
gap: var(--sbb-sidebar-title-gap);
|
|
95
|
+
background-color: var(--sbb-sidebar-background-color);
|
|
96
|
+
padding-inline: var(--sbb-sidebar-padding);
|
|
97
|
+
transition: box-shadow var(--sbb-animation-easing) var(--sbb-sidebar-container-animation-duration);
|
|
98
|
+
box-shadow: none;
|
|
99
|
+
}
|
|
100
|
+
:host(:is(:state(scrolled),[state--scrolled])) .sbb-sidebar-title-section {
|
|
101
|
+
box-shadow: var(--sbb-box-shadow-level-5-soft);
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
.sbb-sidebar-content-section {
|
|
105
|
+
--sbb-scrollbar-thumb-width: 0.125rem;
|
|
106
|
+
--sbb-scrollbar-thumb-width-hover: 0.25rem;
|
|
107
|
+
--sbb-scrollbar-width-firefox: thin;
|
|
108
|
+
--sbb-scrollbar-color: color-mix(in srgb, var(--sbb-color-black) 30%, transparent);
|
|
109
|
+
--sbb-scrollbar-color: light-dark(
|
|
110
|
+
color-mix(in srgb, var(--sbb-color-black) 30%, transparent),
|
|
111
|
+
color-mix(in srgb, var(--sbb-color-white) 30%, transparent)
|
|
112
|
+
);
|
|
113
|
+
--sbb-scrollbar-color-hover: color-mix(in srgb, var(--sbb-color-black) 60%, transparent);
|
|
114
|
+
--sbb-scrollbar-color-hover: light-dark(
|
|
115
|
+
color-mix(in srgb, var(--sbb-color-black) 60%, transparent),
|
|
116
|
+
color-mix(in srgb, var(--sbb-color-white) 60%, transparent)
|
|
117
|
+
);
|
|
118
|
+
--sbb-scrollbar-track-color: transparent;
|
|
119
|
+
--sbb-scrollbar-width: var(--sbb-spacing-fixed-3x);
|
|
120
|
+
}
|
|
121
|
+
.sbb-sidebar-content-section::-webkit-scrollbar {
|
|
122
|
+
width: var(--sbb-scrollbar-width);
|
|
123
|
+
height: var(--sbb-scrollbar-width);
|
|
124
|
+
background-color: var(--sbb-scrollbar-track-color, transparent);
|
|
125
|
+
}
|
|
126
|
+
.sbb-sidebar-content-section::-webkit-scrollbar-corner {
|
|
127
|
+
background-color: var(--sbb-scrollbar-track-color, transparent);
|
|
128
|
+
}
|
|
129
|
+
.sbb-sidebar-content-section::-webkit-scrollbar-thumb {
|
|
130
|
+
background-color: var(--sbb-scrollbar-color, currentcolor);
|
|
131
|
+
border: calc(0.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width))) solid transparent;
|
|
132
|
+
border-radius: var(--sbb-border-radius-4x);
|
|
133
|
+
background-clip: padding-box;
|
|
134
|
+
}
|
|
135
|
+
.sbb-sidebar-content-section::-webkit-scrollbar-thumb:hover {
|
|
136
|
+
background-color: var(--sbb-scrollbar-color-hover, currentcolor);
|
|
137
|
+
border-width: calc(0.5 * (var(--sbb-scrollbar-width) - var(--sbb-scrollbar-thumb-width-hover)));
|
|
138
|
+
}
|
|
139
|
+
.sbb-sidebar-content-section::-webkit-scrollbar-button, .sbb-sidebar-content-section::-webkit-scrollbar-corner {
|
|
140
|
+
display: none;
|
|
141
|
+
}
|
|
142
|
+
@supports not selector(::-webkit-scrollbar) {
|
|
143
|
+
.sbb-sidebar-content-section {
|
|
144
|
+
scrollbar-width: var(--sbb-scrollbar-width-firefox);
|
|
145
|
+
scrollbar-color: var(--sbb-scrollbar-color, currentcolor) var(--sbb-scrollbar-track-color, transparent);
|
|
146
|
+
}
|
|
147
|
+
}
|
|
148
|
+
.sbb-sidebar-content-section {
|
|
149
|
+
padding-block-start: var(--_sbb-sidebar-padding-block-start);
|
|
150
|
+
padding-inline: var(--sbb-sidebar-padding) var(--_sbb-sidebar-padding-inline-end);
|
|
151
|
+
overflow-y: auto;
|
|
152
|
+
flex-grow: 1;
|
|
153
|
+
outline-color: var(--sbb-focus-outline-color);
|
|
154
|
+
}
|
|
155
|
+
@supports (scrollbar-gutter: stable) {
|
|
156
|
+
.sbb-sidebar-content-section {
|
|
157
|
+
scrollbar-gutter: stable;
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
::slotted(sbb-sidebar-title) {
|
|
162
|
+
flex-grow: 1;
|
|
163
|
+
margin-block: var(--sbb-sidebar-title-padding-block);
|
|
164
|
+
}
|
|
165
|
+
|
|
166
|
+
::slotted(sbb-sidebar-close-button) {
|
|
167
|
+
order: 1;
|
|
168
|
+
margin-inline-end: calc(-1 * (var(--sbb-sidebar-padding) - var(--sbb-sidebar-title-padding-block)));
|
|
169
|
+
margin-block: var(--sbb-sidebar-title-padding-block);
|
|
170
|
+
inset-inline-end: var(--sbb-sidebar-padding);
|
|
171
|
+
}`;
|
|
172
|
+
//#endregion
|
|
173
|
+
//#region src/elements/sidebar/sidebar/sidebar.component.ts
|
|
174
|
+
/**
|
|
175
|
+
* This component corresponds to a sidebar that can be opened on the sidebar container.
|
|
176
|
+
*
|
|
177
|
+
* @slot - Use the unnamed slot to slot any content into the sidebar.
|
|
178
|
+
* @slot title - Use the title slot to add an <sbb-title>.
|
|
179
|
+
*/
|
|
180
|
+
var SbbSidebarElement = (() => {
|
|
181
|
+
let _classSuper = SbbAnimationCompleteMixin(SbbOpenCloseBaseElement);
|
|
182
|
+
let _instanceExtraInitializers = [];
|
|
183
|
+
let _color_decorators;
|
|
184
|
+
let _color_initializers = [];
|
|
185
|
+
let _color_extraInitializers = [];
|
|
186
|
+
let _mode_decorators;
|
|
187
|
+
let _mode_initializers = [];
|
|
188
|
+
let _mode_extraInitializers = [];
|
|
189
|
+
let _position_decorators;
|
|
190
|
+
let _position_initializers = [];
|
|
191
|
+
let _position_extraInitializers = [];
|
|
192
|
+
let _opened_decorators;
|
|
193
|
+
let _opened_initializers = [];
|
|
194
|
+
let _opened_extraInitializers = [];
|
|
195
|
+
let _focusOnOpen_decorators;
|
|
196
|
+
let _focusOnOpen_initializers = [];
|
|
197
|
+
let _focusOnOpen_extraInitializers = [];
|
|
198
|
+
let __detectScrolledState_decorators;
|
|
199
|
+
return class SbbSidebarElement extends _classSuper {
|
|
200
|
+
static {
|
|
201
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
202
|
+
_color_decorators = [property({ reflect: true })];
|
|
203
|
+
_mode_decorators = [forceType((v) => v === "over" ? "over" : "side"), property({ reflect: true })];
|
|
204
|
+
_position_decorators = [
|
|
205
|
+
forceType((v) => v === "end" ? "end" : "start"),
|
|
206
|
+
handleDistinctChange((instance, _newValue, oldValue) => instance._updateSidebarWidth(oldValue)),
|
|
207
|
+
property({ reflect: true })
|
|
208
|
+
];
|
|
209
|
+
_opened_decorators = [forceType(), property({
|
|
210
|
+
type: Boolean,
|
|
211
|
+
reflect: true
|
|
212
|
+
})];
|
|
213
|
+
_focusOnOpen_decorators = [forceType(), property({
|
|
214
|
+
type: Boolean,
|
|
215
|
+
attribute: "focus-on-open"
|
|
216
|
+
})];
|
|
217
|
+
__detectScrolledState_decorators = [eventOptions({ passive: true })];
|
|
218
|
+
__esDecorate(this, null, _color_decorators, {
|
|
219
|
+
kind: "accessor",
|
|
220
|
+
name: "color",
|
|
221
|
+
static: false,
|
|
222
|
+
private: false,
|
|
223
|
+
access: {
|
|
224
|
+
has: (obj) => "color" in obj,
|
|
225
|
+
get: (obj) => obj.color,
|
|
226
|
+
set: (obj, value) => {
|
|
227
|
+
obj.color = value;
|
|
228
|
+
}
|
|
229
|
+
},
|
|
230
|
+
metadata: _metadata
|
|
231
|
+
}, _color_initializers, _color_extraInitializers);
|
|
232
|
+
__esDecorate(this, null, _mode_decorators, {
|
|
233
|
+
kind: "accessor",
|
|
234
|
+
name: "mode",
|
|
235
|
+
static: false,
|
|
236
|
+
private: false,
|
|
237
|
+
access: {
|
|
238
|
+
has: (obj) => "mode" in obj,
|
|
239
|
+
get: (obj) => obj.mode,
|
|
240
|
+
set: (obj, value) => {
|
|
241
|
+
obj.mode = value;
|
|
242
|
+
}
|
|
243
|
+
},
|
|
244
|
+
metadata: _metadata
|
|
245
|
+
}, _mode_initializers, _mode_extraInitializers);
|
|
246
|
+
__esDecorate(this, null, _position_decorators, {
|
|
247
|
+
kind: "accessor",
|
|
248
|
+
name: "position",
|
|
249
|
+
static: false,
|
|
250
|
+
private: false,
|
|
251
|
+
access: {
|
|
252
|
+
has: (obj) => "position" in obj,
|
|
253
|
+
get: (obj) => obj.position,
|
|
254
|
+
set: (obj, value) => {
|
|
255
|
+
obj.position = value;
|
|
256
|
+
}
|
|
257
|
+
},
|
|
258
|
+
metadata: _metadata
|
|
259
|
+
}, _position_initializers, _position_extraInitializers);
|
|
260
|
+
__esDecorate(this, null, _opened_decorators, {
|
|
261
|
+
kind: "accessor",
|
|
262
|
+
name: "opened",
|
|
263
|
+
static: false,
|
|
264
|
+
private: false,
|
|
265
|
+
access: {
|
|
266
|
+
has: (obj) => "opened" in obj,
|
|
267
|
+
get: (obj) => obj.opened,
|
|
268
|
+
set: (obj, value) => {
|
|
269
|
+
obj.opened = value;
|
|
270
|
+
}
|
|
271
|
+
},
|
|
272
|
+
metadata: _metadata
|
|
273
|
+
}, _opened_initializers, _opened_extraInitializers);
|
|
274
|
+
__esDecorate(this, null, _focusOnOpen_decorators, {
|
|
275
|
+
kind: "accessor",
|
|
276
|
+
name: "focusOnOpen",
|
|
277
|
+
static: false,
|
|
278
|
+
private: false,
|
|
279
|
+
access: {
|
|
280
|
+
has: (obj) => "focusOnOpen" in obj,
|
|
281
|
+
get: (obj) => obj.focusOnOpen,
|
|
282
|
+
set: (obj, value) => {
|
|
283
|
+
obj.focusOnOpen = value;
|
|
284
|
+
}
|
|
285
|
+
},
|
|
286
|
+
metadata: _metadata
|
|
287
|
+
}, _focusOnOpen_initializers, _focusOnOpen_extraInitializers);
|
|
288
|
+
__esDecorate(this, null, __detectScrolledState_decorators, {
|
|
289
|
+
kind: "method",
|
|
290
|
+
name: "_detectScrolledState",
|
|
291
|
+
static: false,
|
|
292
|
+
private: false,
|
|
293
|
+
access: {
|
|
294
|
+
has: (obj) => "_detectScrolledState" in obj,
|
|
295
|
+
get: (obj) => obj._detectScrolledState
|
|
296
|
+
},
|
|
297
|
+
metadata: _metadata
|
|
298
|
+
}, null, _instanceExtraInitializers);
|
|
299
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, {
|
|
300
|
+
enumerable: true,
|
|
301
|
+
configurable: true,
|
|
302
|
+
writable: true,
|
|
303
|
+
value: _metadata
|
|
304
|
+
});
|
|
305
|
+
}
|
|
306
|
+
static {
|
|
307
|
+
this.elementName = "sbb-sidebar";
|
|
308
|
+
}
|
|
309
|
+
static {
|
|
310
|
+
this.styles = [boxSizingStyles, sidebar_default];
|
|
311
|
+
}
|
|
312
|
+
#color_accessor_storage;
|
|
313
|
+
/** Background color of the sidebar. Either `white` or `milk`. */
|
|
314
|
+
get color() {
|
|
315
|
+
return this.#color_accessor_storage;
|
|
316
|
+
}
|
|
317
|
+
set color(value) {
|
|
318
|
+
this.#color_accessor_storage = value;
|
|
319
|
+
}
|
|
320
|
+
#mode_accessor_storage;
|
|
321
|
+
/** Mode of the sidebar; one of 'side' or 'over'. */
|
|
322
|
+
get mode() {
|
|
323
|
+
return this.#mode_accessor_storage;
|
|
324
|
+
}
|
|
325
|
+
set mode(value) {
|
|
326
|
+
this.#mode_accessor_storage = value;
|
|
327
|
+
}
|
|
328
|
+
#position_accessor_storage;
|
|
329
|
+
/** The side that the sidebar is attached to. */
|
|
330
|
+
get position() {
|
|
331
|
+
return this.#position_accessor_storage;
|
|
332
|
+
}
|
|
333
|
+
set position(value) {
|
|
334
|
+
this.#position_accessor_storage = value;
|
|
335
|
+
}
|
|
336
|
+
#opened_accessor_storage;
|
|
337
|
+
/**
|
|
338
|
+
* Whether the sidebar is opened or closed.
|
|
339
|
+
* Can be used to initially set the opened state, where
|
|
340
|
+
* the animation will be skipped.
|
|
341
|
+
*/
|
|
342
|
+
get opened() {
|
|
343
|
+
return this.#opened_accessor_storage;
|
|
344
|
+
}
|
|
345
|
+
set opened(value) {
|
|
346
|
+
this.#opened_accessor_storage = value;
|
|
347
|
+
}
|
|
348
|
+
#focusOnOpen_accessor_storage;
|
|
349
|
+
/**
|
|
350
|
+
* Whether the sidebar should focus the first focusable element automatically when opened.
|
|
351
|
+
* Defaults to false in when mode is set to `side`, otherwise defaults to true.
|
|
352
|
+
* If explicitly enabled, focus will be moved into the sidebar in `side` mode as well.
|
|
353
|
+
*/
|
|
354
|
+
get focusOnOpen() {
|
|
355
|
+
return this.#focusOnOpen_accessor_storage;
|
|
356
|
+
}
|
|
357
|
+
set focusOnOpen(value) {
|
|
358
|
+
this.#focusOnOpen_accessor_storage = value;
|
|
359
|
+
}
|
|
360
|
+
/** Returns the SbbSidebarContainerElement where this sidebar is contained. */
|
|
361
|
+
get container() {
|
|
362
|
+
return this._container;
|
|
363
|
+
}
|
|
364
|
+
constructor() {
|
|
365
|
+
super();
|
|
366
|
+
this.#color_accessor_storage = (__runInitializers(this, _instanceExtraInitializers), __runInitializers(this, _color_initializers, "white"));
|
|
367
|
+
this.#mode_accessor_storage = (__runInitializers(this, _color_extraInitializers), __runInitializers(this, _mode_initializers, "side"));
|
|
368
|
+
this.#position_accessor_storage = (__runInitializers(this, _mode_extraInitializers), __runInitializers(this, _position_initializers, "start"));
|
|
369
|
+
this.#opened_accessor_storage = (__runInitializers(this, _position_extraInitializers), __runInitializers(this, _opened_initializers, false));
|
|
370
|
+
this.#focusOnOpen_accessor_storage = (__runInitializers(this, _opened_extraInitializers), __runInitializers(this, _focusOnOpen_initializers, false));
|
|
371
|
+
this._container = (__runInitializers(this, _focusOnOpen_extraInitializers), null);
|
|
372
|
+
this._lastFocusedElement = null;
|
|
373
|
+
this._focusTrapController = new SbbFocusTrapController(this);
|
|
374
|
+
this._escapableOverlayController = new SbbEscapableOverlayController(this);
|
|
375
|
+
this.addController(new ResizeController(this, {
|
|
376
|
+
skipInitial: true,
|
|
377
|
+
callback: () => this._updateSidebarWidth()
|
|
378
|
+
}));
|
|
379
|
+
this.addEventListener?.("click", (e) => {
|
|
380
|
+
if (e.target?.localName === "sbb-sidebar-close-button") this.close();
|
|
381
|
+
});
|
|
382
|
+
}
|
|
383
|
+
connectedCallback() {
|
|
384
|
+
super.connectedCallback();
|
|
385
|
+
this._container = this.closest?.("sbb-sidebar-container");
|
|
386
|
+
this._updateSidebarWidth();
|
|
387
|
+
if (this.isOpen && this._isModeOver()) this._takeFocus();
|
|
388
|
+
}
|
|
389
|
+
disconnectedCallback() {
|
|
390
|
+
super.disconnectedCallback();
|
|
391
|
+
this.container?.style.removeProperty(this._buildCssWidthVar());
|
|
392
|
+
this._container = null;
|
|
393
|
+
}
|
|
394
|
+
willUpdate(changedProperties) {
|
|
395
|
+
super.willUpdate(changedProperties);
|
|
396
|
+
if (changedProperties.has("opened")) {
|
|
397
|
+
if (this.opened) this.open();
|
|
398
|
+
else if (!this.opened) this.close();
|
|
399
|
+
}
|
|
400
|
+
if (changedProperties.has("mode")) if (this.mode === "over" && this.isOpen) this._takeFocus();
|
|
401
|
+
else this.cedeFocus();
|
|
402
|
+
}
|
|
403
|
+
firstUpdated(changedProperties) {
|
|
404
|
+
super.firstUpdated(changedProperties);
|
|
405
|
+
this._updateSidebarWidth();
|
|
406
|
+
}
|
|
407
|
+
/** Toggles the sidebar visibility. */
|
|
408
|
+
toggle() {
|
|
409
|
+
if (this.state === "opening" || this.state === "opened") this.close();
|
|
410
|
+
else this.open();
|
|
411
|
+
}
|
|
412
|
+
/** Opens the sidebar. */
|
|
413
|
+
open() {
|
|
414
|
+
if (this.state === "opening" || this.state === "opened" || !this.dispatchBeforeOpenEvent()) return;
|
|
415
|
+
this.startAnimation();
|
|
416
|
+
if (!isServer && document.activeElement?.localName !== "body") this._lastFocusedElement = document.activeElement;
|
|
417
|
+
this.opened = true;
|
|
418
|
+
this.state = "opening";
|
|
419
|
+
const isZeroAnimationDuration = this._isZeroAnimationDuration() || !this.isConnected;
|
|
420
|
+
const isDuringInitialization = !this.hasUpdated;
|
|
421
|
+
if (!(isDuringInitialization || isZeroAnimationDuration)) return;
|
|
422
|
+
this.internals.states.add("skip-animation");
|
|
423
|
+
if (isDuringInitialization) this.updateComplete.then(() => this._handleOpening());
|
|
424
|
+
else this._handleOpening();
|
|
425
|
+
}
|
|
426
|
+
_isZeroAnimationDuration() {
|
|
427
|
+
return isZeroAnimationDuration(this, "--sbb-sidebar-container-animation-duration");
|
|
428
|
+
}
|
|
429
|
+
_handleOpening() {
|
|
430
|
+
this.state = "opened";
|
|
431
|
+
setTimeout(() => this.internals.states.delete("skip-animation"));
|
|
432
|
+
this._takeFocus();
|
|
433
|
+
this.stopAnimation();
|
|
434
|
+
this.dispatchOpenEvent();
|
|
435
|
+
}
|
|
436
|
+
/** Closes the sidebar. */
|
|
437
|
+
close() {
|
|
438
|
+
if (this.state === "closing" || this.state === "closed" || !this.dispatchBeforeCloseEvent()) return;
|
|
439
|
+
this.startAnimation();
|
|
440
|
+
const isZeroAnimationDuration = this._isZeroAnimationDuration();
|
|
441
|
+
if (!this.hasUpdated || isZeroAnimationDuration) this.internals.states.add("skip-animation");
|
|
442
|
+
else this.state = "closing";
|
|
443
|
+
this.opened = false;
|
|
444
|
+
if (!this.hasUpdated || isZeroAnimationDuration) this._handleClosing();
|
|
445
|
+
}
|
|
446
|
+
_handleClosing() {
|
|
447
|
+
this.state = "closed";
|
|
448
|
+
setTimeout(() => this.internals.states.delete("skip-animation"));
|
|
449
|
+
this.cedeFocus();
|
|
450
|
+
if (!isServer && (this.contains(document.activeElement) || this._isModeOver())) if (this._lastFocusedElement) this._lastFocusedElement?.focus();
|
|
451
|
+
else document.activeElement.blur();
|
|
452
|
+
this._lastFocusedElement = null;
|
|
453
|
+
this.stopAnimation();
|
|
454
|
+
this.dispatchCloseEvent();
|
|
455
|
+
}
|
|
456
|
+
_takeFocus() {
|
|
457
|
+
if (!this.isConnected) return;
|
|
458
|
+
const isModeOver = this._isModeOver();
|
|
459
|
+
if (isModeOver || this.focusOnOpen) this._focusTrapController.focusInitialElement();
|
|
460
|
+
if (isModeOver) {
|
|
461
|
+
this._escapableOverlayController.connect();
|
|
462
|
+
this._focusTrapController.enabled = true;
|
|
463
|
+
}
|
|
464
|
+
}
|
|
465
|
+
cedeFocus() {
|
|
466
|
+
this._focusTrapController.enabled = false;
|
|
467
|
+
this._escapableOverlayController.disconnect();
|
|
468
|
+
}
|
|
469
|
+
_updateSidebarWidth(oldPosition) {
|
|
470
|
+
const container = this.container;
|
|
471
|
+
if (!container) return;
|
|
472
|
+
if (oldPosition) container.style.removeProperty(this._buildCssWidthVar(oldPosition));
|
|
473
|
+
const width = this.offsetWidth;
|
|
474
|
+
if (!width) return;
|
|
475
|
+
const newValue = `${width}px`;
|
|
476
|
+
if (container.style.getPropertyValue(this._buildCssWidthVar()) === newValue) return;
|
|
477
|
+
container.style.setProperty(this._buildCssWidthVar(), newValue);
|
|
478
|
+
}
|
|
479
|
+
_buildCssWidthVar(position = this.position) {
|
|
480
|
+
return `--_sbb-sidebar-container-${position}-width`;
|
|
481
|
+
}
|
|
482
|
+
_isModeOver() {
|
|
483
|
+
return this.mode === "over" || this.matches(":is(:state(mode-over-forced),[state--mode-over-forced])");
|
|
484
|
+
}
|
|
485
|
+
_onTransitionEnd(event) {
|
|
486
|
+
if (event.propertyName !== "translate" || event.target !== event.currentTarget) return;
|
|
487
|
+
if (this.state === "opening") this._handleOpening();
|
|
488
|
+
else if (this.state === "closing") this._handleClosing();
|
|
489
|
+
}
|
|
490
|
+
_detectScrolledState() {
|
|
491
|
+
this.toggleState("scrolled", (this.shadowRoot?.querySelector(".sbb-sidebar-content-section")?.scrollTop ?? 0) > 0);
|
|
492
|
+
}
|
|
493
|
+
render() {
|
|
494
|
+
return html`<div class="sbb-sidebar" @transitionend=${this._onTransitionEnd}>
|
|
495
|
+
<div class="sbb-sidebar-title-section"><slot name="title-section"></slot></div>
|
|
496
|
+
<div class="sbb-sidebar-content-section" @scroll=${() => this._detectScrolledState()}>
|
|
497
|
+
<slot></slot>
|
|
498
|
+
</div>
|
|
499
|
+
</div>`;
|
|
500
|
+
}
|
|
501
|
+
};
|
|
502
|
+
})();
|
|
503
|
+
//#endregion
|
|
504
|
+
export { SbbSidebarElement as t };
|
|
505
|
+
|
|
506
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"sidebar.component-BmLRuuec.js","names":[],"sources":["../../../src/elements/sidebar/sidebar/sidebar.scss?lit&inline","../../../src/elements/sidebar/sidebar/sidebar.component.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-link-text-decoration-line: none;\n  --sbb-sidebar-background-color: var(--sbb-background-color-1);\n  --sbb-sidebar-scrollbar-placeholder-width: var(--sbb-spacing-fixed-3x);\n  --_sbb-sidebar-margin: 0;\n  --_sbb-sidebar-margin-block-start: var(--sbb-sidebar-margin);\n  --_sbb-sidebar-translate-x: -100%;\n  --_sbb-sidebar-z-index: 2;\n  --_sbb-sidebar-padding-inline-end: var(--sbb-sidebar-padding);\n  --_sbb-sidebar-padding-block-start: var(--sbb-sidebar-padding);\n  --_sbb-sidebar-border-radius-start: var(--sbb-sidebar-border-radius);\n  --_sbb-sidebar-border-radius-end: 0;\n  --_sbb-sidebar-close-button-size: var(--sbb-size-element-xs);\n  --_sbb-sidebar-max-width: calc(100% - 2 * var(--_sbb-sidebar-margin));\n\n  display: block;\n  width: #{sbb.px-to-rem-build(320)};\n\n  // Subtract the width of the scrollbar from the padding (Exclude iOS browsers because they use overlay scrollbars)\n  @supports (scrollbar-gutter: stable) and (not (-webkit-touch-callout: none)) {\n    --_sbb-sidebar-padding-inline-end: calc(\n      var(--sbb-sidebar-padding) - var(--sbb-sidebar-scrollbar-placeholder-width)\n    );\n  }\n}\n\n:host([color='white']) {\n  --sbb-sidebar-background-color: var(--sbb-background-color-1);\n}\n\n:host([color='milk']) {\n  --sbb-sidebar-background-color: var(--sbb-background-color-3);\n}\n\n:host(:is([mode='over'], :state(mode-over-forced):not(:state(mode-over-forced-closing)))) {\n  --_sbb-sidebar-margin: var(--sbb-sidebar-margin);\n  --_sbb-sidebar-border-radius-end: var(--sbb-sidebar-border-radius);\n  --_sbb-sidebar-z-index: 3;\n}\n\n:host(:is(:dir(rtl), [position='end'])) {\n  --_sbb-sidebar-translate-x: 100%;\n}\n\n:host(:dir(rtl)[position='end']) {\n  --_sbb-sidebar-translate-x: -100%;\n}\n\n.sbb-sidebar {\n  width: inherit;\n  max-width: var(--_sbb-sidebar-max-width);\n  background-color: var(--sbb-sidebar-background-color);\n  display: flex;\n  flex-direction: column;\n  position: absolute;\n  overflow: hidden;\n  inset-block: 0;\n  z-index: var(--_sbb-sidebar-z-index);\n  border-start-start-radius: var(--_sbb-sidebar-border-radius-start);\n  border-start-end-radius: var(--_sbb-sidebar-border-radius-start);\n  border-end-start-radius: var(--_sbb-sidebar-border-radius-end);\n  border-end-end-radius: var(--_sbb-sidebar-border-radius-end);\n  margin: var(--_sbb-sidebar-margin);\n  margin-block-start: var(--_sbb-sidebar-margin-block-start);\n  transition-duration: var(--sbb-sidebar-container-animation-duration);\n  transition-timing-function: var(--sbb-sidebar-container-animation-easing);\n  transition-property: width, translate;\n  translate: none;\n\n  :host([position='end']) & {\n    inset-inline-end: 0;\n  }\n\n  :host(:state(state-closed)) & {\n    // Stops the sidenav from poking out (e.g. with the box shadow) while it's off-screen.\n    // We can't use `display` because it interrupts the transition and `transition-behavior`\n    // isn't available in all browsers.\n    visibility: hidden;\n  }\n\n  :host(:is(:state(state-closing), :state(state-closed))) & {\n    translate: var(--_sbb-sidebar-translate-x) 0;\n  }\n}\n\n.sbb-sidebar-title-section {\n  display: flex;\n  width: 100%;\n  gap: var(--sbb-sidebar-title-gap);\n  background-color: var(--sbb-sidebar-background-color);\n  padding-inline: var(--sbb-sidebar-padding);\n  transition: box-shadow var(--sbb-animation-easing) var(--sbb-sidebar-container-animation-duration);\n  box-shadow: none;\n\n  :host(:state(scrolled)) & {\n    box-shadow: var(--sbb-box-shadow-level-5-soft);\n  }\n}\n\n.sbb-sidebar-content-section {\n  @include sbb.scrollbar;\n\n  padding-block-start: var(--_sbb-sidebar-padding-block-start);\n  padding-inline: var(--sbb-sidebar-padding) var(--_sbb-sidebar-padding-inline-end);\n  overflow-y: auto;\n  flex-grow: 1;\n\n  // If the element is scrollable and has no focusable content, it gets focused.\n  // To adapt to lyne styles we colorize it\n  outline-color: var(--sbb-focus-outline-color);\n\n  @supports (scrollbar-gutter: stable) {\n    scrollbar-gutter: stable;\n  }\n}\n\n::slotted(sbb-sidebar-title) {\n  flex-grow: 1;\n  margin-block: var(--sbb-sidebar-title-padding-block);\n}\n\n::slotted(sbb-sidebar-close-button) {\n  order: 1;\n\n  // Due to design needs, we have to translate the close button to the right\n  margin-inline-end: calc(\n    -1 * (var(--sbb-sidebar-padding) - var(--sbb-sidebar-title-padding-block))\n  );\n  margin-block: var(--sbb-sidebar-title-padding-block);\n  inset-inline-end: var(--sbb-sidebar-padding);\n}\n","import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport { type CSSResultGroup, html, isServer, type PropertyValues, type TemplateResult } from 'lit';\nimport { eventOptions, property } from 'lit/decorators.js';\n\nimport { SbbFocusTrapController } from '../../core/a11y.ts';\nimport { SbbOpenCloseBaseElement } from '../../core/base-elements.ts';\nimport { SbbEscapableOverlayController } from '../../core/controllers.ts';\nimport { forceType, handleDistinctChange } from '../../core/decorators.ts';\nimport { isZeroAnimationDuration } from '../../core/dom.ts';\nimport { SbbAnimationCompleteMixin } from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbSidebarContainerElement } from '../sidebar-container/sidebar-container.component.ts';\n\nimport style from './sidebar.scss?lit&inline';\n\n/**\n * This component corresponds to a sidebar that can be opened on the sidebar container.\n *\n * @slot - Use the unnamed slot to slot any content into the sidebar.\n * @slot title - Use the title slot to add an <sbb-title>.\n */\nexport class SbbSidebarElement extends SbbAnimationCompleteMixin(SbbOpenCloseBaseElement) {\n  public static override readonly elementName: string = 'sbb-sidebar';\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n\n  /** Background color of the sidebar. Either `white` or `milk`. */\n  @property({ reflect: true })\n  public accessor color: 'white' | 'milk' = 'white';\n\n  /** Mode of the sidebar; one of 'side' or 'over'. */\n  @forceType((v) => (v === 'over' ? 'over' : 'side'))\n  @property({ reflect: true })\n  public accessor mode: 'side' | 'over' = 'side';\n\n  /** The side that the sidebar is attached to. */\n  @forceType((v) => (v === 'end' ? 'end' : 'start'))\n  @handleDistinctChange((instance, _newValue, oldValue) => instance._updateSidebarWidth(oldValue))\n  @property({ reflect: true })\n  public accessor position: 'start' | 'end' = 'start';\n\n  /**\n   * Whether the sidebar is opened or closed.\n   * Can be used to initially set the opened state, where\n   * the animation will be skipped.\n   */\n  @forceType()\n  @property({ type: Boolean, reflect: true })\n  public accessor opened: boolean = false;\n\n  /**\n   * Whether the sidebar should focus the first focusable element automatically when opened.\n   * Defaults to false in when mode is set to `side`, otherwise defaults to true.\n   * If explicitly enabled, focus will be moved into the sidebar in `side` mode as well.\n   */\n  @forceType()\n  @property({ type: Boolean, attribute: 'focus-on-open' })\n  public accessor focusOnOpen: boolean = false;\n\n  /** Returns the SbbSidebarContainerElement where this sidebar is contained. */\n  public get container(): SbbSidebarContainerElement | null {\n    return this._container;\n  }\n  private _container: SbbSidebarContainerElement | null = null;\n\n  private _lastFocusedElement: HTMLElement | null = null;\n  private _focusTrapController = new SbbFocusTrapController(this);\n  private _escapableOverlayController = new SbbEscapableOverlayController(this);\n\n  public constructor() {\n    super();\n    this.addController(\n      new ResizeController(this, {\n        skipInitial: true,\n        callback: () => this._updateSidebarWidth(),\n      }),\n    );\n\n    this.addEventListener?.('click', (e) => {\n      if ((e.target as HTMLElement | undefined)?.localName === 'sbb-sidebar-close-button') {\n        this.close();\n      }\n    });\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n\n    this._container = this.closest?.('sbb-sidebar-container');\n    this._updateSidebarWidth();\n\n    if (this.isOpen && this._isModeOver()) {\n      this._takeFocus();\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this.container?.style.removeProperty(this._buildCssWidthVar());\n    this._container = null;\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('opened')) {\n      if (this.opened) {\n        this.open();\n      } else if (!this.opened) {\n        this.close();\n      }\n    }\n\n    if (changedProperties.has('mode')) {\n      if (this.mode === 'over' && this.isOpen) {\n        this._takeFocus();\n      } else {\n        this.cedeFocus();\n      }\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._updateSidebarWidth();\n  }\n\n  /** Toggles the sidebar visibility. */\n  public toggle(): void {\n    if (this.state === 'opening' || this.state === 'opened') {\n      this.close();\n    } else {\n      this.open();\n    }\n  }\n\n  /** Opens the sidebar. */\n  public open(): void {\n    if (this.state === 'opening' || this.state === 'opened' || !this.dispatchBeforeOpenEvent()) {\n      return;\n    }\n\n    this.startAnimation();\n\n    if (!isServer && document.activeElement?.localName !== 'body') {\n      this._lastFocusedElement = document.activeElement as HTMLElement;\n    }\n\n    this.opened = true;\n    this.state = 'opening';\n\n    const isZeroAnimationDuration = this._isZeroAnimationDuration() || !this.isConnected;\n    const isDuringInitialization = !this.hasUpdated;\n\n    if (!(isDuringInitialization || isZeroAnimationDuration)) {\n      return;\n    }\n    this.internals.states.add('skip-animation');\n\n    // We have to wait for the first update to be completed\n    // in order to have the size of the sidebar ready for the animation.\n    if (isDuringInitialization) {\n      this.updateComplete.then(() => this._handleOpening());\n    } else {\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      this._handleOpening();\n    }\n  }\n\n  private _isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-sidebar-container-animation-duration');\n  }\n\n  private _handleOpening(): void {\n    this.state = 'opened';\n\n    // We have to ensure that removing the animation skip instruction is done a tick later.\n    // Otherwise, it's removed too early and it doesn't have any effect.\n    setTimeout(() => this.internals.states.delete('skip-animation'));\n\n    this._takeFocus();\n    this.stopAnimation();\n    this.dispatchOpenEvent();\n  }\n\n  /** Closes the sidebar. */\n  public close(): void {\n    if (this.state === 'closing' || this.state === 'closed' || !this.dispatchBeforeCloseEvent()) {\n      return;\n    }\n\n    this.startAnimation();\n\n    const isZeroAnimationDuration = this._isZeroAnimationDuration();\n\n    if (!this.hasUpdated || isZeroAnimationDuration) {\n      this.internals.states.add('skip-animation');\n    } else {\n      this.state = 'closing';\n    }\n\n    this.opened = false;\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.hasUpdated || isZeroAnimationDuration) {\n      this._handleClosing();\n    }\n  }\n\n  private _handleClosing(): void {\n    this.state = 'closed';\n    // We have to ensure that removing the animation skip instruction is done a tick later.\n    // Otherwise, it's removed too early and it doesn't have any effect.\n    setTimeout(() => this.internals.states.delete('skip-animation'));\n    this.cedeFocus();\n\n    if (!isServer && (this.contains(document.activeElement) || this._isModeOver())) {\n      if (this._lastFocusedElement) {\n        this._lastFocusedElement?.focus();\n      } else {\n        // We don't know where to set the focus, but have to remove it, so we call blur\n        (document.activeElement as HTMLElement).blur();\n      }\n    }\n    this._lastFocusedElement = null;\n\n    this.stopAnimation();\n    this.dispatchCloseEvent();\n  }\n\n  private _takeFocus(): void {\n    // We prevent calling the focus stuff when not needed\n    if (!this.isConnected) {\n      return;\n    }\n    const isModeOver = this._isModeOver();\n\n    if (isModeOver || this.focusOnOpen) {\n      this._focusTrapController.focusInitialElement();\n    }\n\n    if (isModeOver) {\n      this._escapableOverlayController.connect();\n      this._focusTrapController.enabled = true;\n    }\n  }\n\n  // Internal method that we use externally. `protected` preserves type information for type safe access.\n  protected cedeFocus(): void {\n    this._focusTrapController.enabled = false;\n    this._escapableOverlayController.disconnect();\n  }\n\n  private _updateSidebarWidth(oldPosition?: this['position']): void {\n    const container = this.container;\n    if (!container) {\n      return;\n    }\n\n    if (oldPosition) {\n      container.style.removeProperty(this._buildCssWidthVar(oldPosition));\n    }\n\n    const width = this.offsetWidth;\n    if (!width) {\n      return;\n    }\n\n    const newValue = `${width}px`;\n    const actualValue = container.style.getPropertyValue(this._buildCssWidthVar());\n\n    if (actualValue === newValue) {\n      return;\n    }\n\n    container.style.setProperty(this._buildCssWidthVar(), newValue);\n  }\n\n  private _buildCssWidthVar(position = this.position): string {\n    return `--_sbb-sidebar-container-${position}-width`;\n  }\n\n  private _isModeOver(): boolean {\n    // If the minimum space attribute is set, the sidebar should behave like in mode over.\n    return this.mode === 'over' || this.matches(':state(mode-over-forced)');\n  }\n\n  private _onTransitionEnd(event: TransitionEvent): void {\n    // We ensure that we react to the fade in transition on the sbb-sidebar div\n    if (event.propertyName !== 'translate' || event.target !== event.currentTarget) {\n      return;\n    }\n\n    if (this.state === 'opening') {\n      this._handleOpening();\n    } else if (this.state === 'closing') {\n      this._handleClosing();\n    }\n  }\n\n  @eventOptions({ passive: true })\n  private _detectScrolledState(): void {\n    this.toggleState(\n      'scrolled',\n      (this.shadowRoot?.querySelector('.sbb-sidebar-content-section')?.scrollTop ?? 0) > 0,\n    );\n  }\n\n  protected override render(): TemplateResult {\n    return html`<div class=\"sbb-sidebar\" @transitionend=${this._onTransitionEnd}>\n      <div class=\"sbb-sidebar-title-section\"><slot name=\"title-section\"></slot></div>\n      <div class=\"sbb-sidebar-content-section\" @scroll=${() => this._detectScrolledState()}>\n        <slot></slot>\n      </div>\n    </div>`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-sidebar': SbbSidebarElement;\n  }\n}\n"],"mappings":"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"}
|
package/development/sidebar.js
CHANGED
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { t as SbbSidebarCloseButtonElement } from "./sidebar-close-button.component-Ckp-_zlH.js";
|
|
2
2
|
import { t as SbbSidebarContainerElement } from "./sidebar-container.component-D4yIuari.js";
|
|
3
|
-
import { t as SbbSidebarContentElement } from "./sidebar-content.component-
|
|
4
|
-
import { t as SbbSidebarTitleElement } from "./sidebar-title.component-
|
|
5
|
-
import { t as SbbSidebarElement } from "./sidebar.component-
|
|
3
|
+
import { t as SbbSidebarContentElement } from "./sidebar-content.component-6oadojLp.js";
|
|
4
|
+
import { t as SbbSidebarTitleElement } from "./sidebar-title.component-DU-ZLEU0.js";
|
|
5
|
+
import { t as SbbSidebarElement } from "./sidebar.component-BmLRuuec.js";
|
|
6
6
|
import "./sidebar.pure.js";
|
|
7
7
|
//#region src/elements/sidebar.ts
|
|
8
8
|
/** @entrypoint */
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { t as SbbSidebarCloseButtonElement } from "./sidebar-close-button.component-Ckp-_zlH.js";
|
|
2
2
|
import { t as SbbSidebarContainerElement } from "./sidebar-container.component-D4yIuari.js";
|
|
3
|
-
import { t as SbbSidebarContentElement } from "./sidebar-content.component-
|
|
4
|
-
import { t as SbbSidebarTitleElement } from "./sidebar-title.component-
|
|
5
|
-
import { t as SbbSidebarElement } from "./sidebar.component-
|
|
3
|
+
import { t as SbbSidebarContentElement } from "./sidebar-content.component-6oadojLp.js";
|
|
4
|
+
import { t as SbbSidebarTitleElement } from "./sidebar-title.component-DU-ZLEU0.js";
|
|
5
|
+
import { t as SbbSidebarElement } from "./sidebar.component-BmLRuuec.js";
|
|
6
6
|
export { SbbSidebarCloseButtonElement, SbbSidebarContainerElement, SbbSidebarContentElement, SbbSidebarElement, SbbSidebarTitleElement };
|
package/off-brand-theme.css
CHANGED
|
@@ -1752,6 +1752,12 @@ slot[name=error]::slotted(*) {
|
|
|
1752
1752
|
--sbb-selection-panel-input-padding-block-m
|
|
1753
1753
|
);
|
|
1754
1754
|
--sbb-selection-expansion-panel-content-padding-inline: var(--sbb-selection-panel-input-padding-inline-m);
|
|
1755
|
+
--sbb-sidebar-background-color: var(--sbb-background-color-1);
|
|
1756
|
+
--sbb-sidebar-title-padding-block: var(--sbb-spacing-fixed-3x);
|
|
1757
|
+
--sbb-sidebar-padding: var(--sbb-spacing-responsive-xs);
|
|
1758
|
+
--sbb-sidebar-border-radius: var(--sbb-border-radius-8x);
|
|
1759
|
+
--sbb-sidebar-margin: var(--sbb-spacing-fixed-3x);
|
|
1760
|
+
--sbb-sidebar-title-gap: var(--sbb-spacing-fixed-2x);
|
|
1755
1761
|
--sbb-signet-background-color: var(--sbb-color-brand);
|
|
1756
1762
|
--sbb-signet-panel-color: var(--sbb-color-brand);
|
|
1757
1763
|
--sbb-signet-icon-color: var(--sbb-color-white);
|
|
@@ -2272,6 +2278,37 @@ sbb-message > [slot=image] :is(sbb-image, img):not(.sbb-figure-overlap-image) {
|
|
|
2272
2278
|
--sbb-option-hint-padding-block-end: var(--sbb-spacing-fixed-1x);
|
|
2273
2279
|
}
|
|
2274
2280
|
|
|
2281
|
+
sbb-sidebar:has(sbb-sidebar-title) {
|
|
2282
|
+
--_sbb-sidebar-padding-block-start: 0;
|
|
2283
|
+
}
|
|
2284
|
+
|
|
2285
|
+
sbb-sidebar:not(:has(sbb-sidebar-title)) sbb-sidebar-close-button {
|
|
2286
|
+
position: absolute;
|
|
2287
|
+
}
|
|
2288
|
+
|
|
2289
|
+
sbb-sidebar-container:has(> sbb-sidebar:is(:state(skip-animation),[state--skip-animation])) {
|
|
2290
|
+
--sbb-sidebar-container-animation-duration: 0s;
|
|
2291
|
+
}
|
|
2292
|
+
sbb-sidebar-container:has(> sbb-sidebar:is([mode=over], :is(:state(mode-over-forced),[state--mode-over-forced])):is(:is(:state(state-opening),[state--state-opening]),
|
|
2293
|
+
:is(:state(state-opened),[state--state-opened]))) {
|
|
2294
|
+
--sbb-sidebar-container__backdrop-visibility: visible;
|
|
2295
|
+
--sbb-sidebar-container-backdrop-opacity: 0.4;
|
|
2296
|
+
}
|
|
2297
|
+
sbb-sidebar-container:is(:has(> sbb-sidebar[position=end]:is(:is(:state(state-closing),[state--state-closing]),
|
|
2298
|
+
:is(:state(state-closed),[state--state-closed]),
|
|
2299
|
+
[mode=over],
|
|
2300
|
+
:is(:state(mode-over-forced),[state--mode-over-forced]))),
|
|
2301
|
+
:not(:has(> sbb-sidebar[position=end]))) > sbb-sidebar-content {
|
|
2302
|
+
--_sbb-sidebar-content-margin-inline-end: 0;
|
|
2303
|
+
}
|
|
2304
|
+
sbb-sidebar-container:is(:has(> sbb-sidebar:not([position=end]):is(:is(:state(state-closing),[state--state-closing]),
|
|
2305
|
+
:is(:state(state-closed),[state--state-closed]),
|
|
2306
|
+
[mode=over],
|
|
2307
|
+
:is(:state(mode-over-forced),[state--mode-over-forced]))),
|
|
2308
|
+
:not(:has(> sbb-sidebar:not([position=end])))) > sbb-sidebar-content {
|
|
2309
|
+
--_sbb-sidebar-content-margin-inline-start: 0;
|
|
2310
|
+
}
|
|
2311
|
+
|
|
2275
2312
|
sbb-tab-nav-bar .sbb-tab-amount {
|
|
2276
2313
|
margin: 0;
|
|
2277
2314
|
color: var(--sbb-tab-label-amount-color);
|
|
@@ -2455,40 +2492,6 @@ sbb-train-formation[view=top] sbb-train-wagon {
|
|
|
2455
2492
|
--sbb-train-wagon-wagon-end-right-shape: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='40' viewBox='0 0 80 40' fill='none'%3E%3Cpath d='M8.5,0.5 h51.5 a19.5,19.5 0 0 1 19.5,19.5 v0 a19.5,19.5 0 0 1 -19.5,19.5 h-51.5 a8,8 0 0 1 -8,-8 v-23 a8,8 0 0 1 8,-8 z' stroke='%23000000' stroke-width='1'/%3E%3C/svg%3E");
|
|
2456
2493
|
}
|
|
2457
2494
|
|
|
2458
|
-
sbb-sidebar-container:has(> sbb-sidebar:is(:state(skip-animation),[state--skip-animation])) {
|
|
2459
|
-
--sbb-sidebar-container-animation-duration: 0s;
|
|
2460
|
-
}
|
|
2461
|
-
|
|
2462
|
-
sbb-sidebar-container:is(:has(> sbb-sidebar:not([position=end]):is(:is(:state(state-closing),[state--state-closing]),
|
|
2463
|
-
:is(:state(state-closed),[state--state-closed]),
|
|
2464
|
-
[mode=over],
|
|
2465
|
-
:is(:state(mode-over-forced),[state--mode-over-forced]))),
|
|
2466
|
-
:not(:has(> sbb-sidebar:not([position=end])))) > sbb-sidebar-content {
|
|
2467
|
-
--sbb-sidebar-content__margin-inline-start: 0;
|
|
2468
|
-
}
|
|
2469
|
-
|
|
2470
|
-
sbb-sidebar-container:is(:has(> sbb-sidebar[position=end]:is(:is(:state(state-closing),[state--state-closing]),
|
|
2471
|
-
:is(:state(state-closed),[state--state-closed]),
|
|
2472
|
-
[mode=over],
|
|
2473
|
-
:is(:state(mode-over-forced),[state--mode-over-forced]))),
|
|
2474
|
-
:not(:has(> sbb-sidebar[position=end]))) > sbb-sidebar-content {
|
|
2475
|
-
--sbb-sidebar-content__margin-inline-end: 0;
|
|
2476
|
-
}
|
|
2477
|
-
|
|
2478
|
-
sbb-sidebar-container:has(> sbb-sidebar:is([mode=over], :is(:state(mode-over-forced),[state--mode-over-forced])):is(:is(:state(state-opening),[state--state-opening]),
|
|
2479
|
-
:is(:state(state-opened),[state--state-opened]))) {
|
|
2480
|
-
--sbb-sidebar-container__backdrop-visibility: visible;
|
|
2481
|
-
--sbb-sidebar-container-backdrop-opacity: 0.4;
|
|
2482
|
-
}
|
|
2483
|
-
|
|
2484
|
-
sbb-sidebar:not(:has(sbb-sidebar-title)) sbb-sidebar-close-button {
|
|
2485
|
-
position: absolute;
|
|
2486
|
-
}
|
|
2487
|
-
|
|
2488
|
-
sbb-sidebar:has(sbb-sidebar-title) {
|
|
2489
|
-
--sbb-sidebar__padding-block-start: 0;
|
|
2490
|
-
}
|
|
2491
|
-
|
|
2492
2495
|
.sbb-select-trigger {
|
|
2493
2496
|
width: 100%;
|
|
2494
2497
|
height: var(--sbb-size-element-xs);
|