@sbb-esta/lyne-elements-dev 5.0.0-next-dev.1777014673 → 5.0.0-next-dev.1777021773
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 +4 -1
- package/core.css +17 -8
- package/custom-elements.json +1177 -1177
- package/development/dialog/dialog/dialog.component.js +1 -1
- package/development/dialog.component-BTXyWi17.js +233 -0
- package/development/dialog.js +1 -1
- package/development/dialog.pure.js +1 -1
- package/development/file-selector/common/file-selector-common.d.ts.map +1 -1
- package/development/file-selector/common/file-selector-common.js +1 -1
- package/development/file-selector/file-selector-dropzone/file-selector-dropzone.component.d.ts.map +1 -1
- package/development/file-selector/file-selector-dropzone/file-selector-dropzone.component.js +1 -1
- package/development/file-selector-common-BX5f18cJ.js +409 -0
- package/development/file-selector-dropzone.component-DMNom2OW.js +110 -0
- package/development/file-selector.js +2 -2
- package/development/file-selector.pure.js +2 -2
- package/dialog/dialog/dialog.component.js +1 -1
- package/{dialog.component-DTbAHlVd.js → dialog.component-ChB9gCyY.js} +1 -1
- package/dialog.js +1 -1
- package/dialog.pure.js +1 -1
- package/file-selector/common/file-selector-common.js +1 -1
- package/file-selector/file-selector-dropzone/file-selector-dropzone.component.js +1 -1
- package/{file-selector-common-DpccuOQ4.js → file-selector-common-CMLaHuDP.js} +38 -40
- package/{file-selector-dropzone.component-BSF-kegh.js → file-selector-dropzone.component-CWwpvAVD.js} +3 -4
- package/file-selector.js +2 -2
- package/file-selector.pure.js +2 -2
- package/off-brand-theme.css +17 -8
- package/package.json +2 -2
- package/safety-theme.css +17 -8
- package/standard-theme.css +17 -8
- package/development/dialog.component-B4cZfRCl.js +0 -233
- package/development/file-selector-common-DE_jT1fa.js +0 -411
- package/development/file-selector-dropzone.component-B1Y5qOjb.js +0 -111
|
@@ -0,0 +1,409 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
import { nothing, unsafeCSS } from "lit";
|
|
3
|
+
import { property } from "lit/decorators.js";
|
|
4
|
+
import { SbbDisabledMixin, SbbFormAssociatedMixin, SbbLanguageController, forceType, forwardEvent, i18nFileSelectorButtonLabel, i18nFileSelectorButtonLabelMultiple, i18nFileSelectorCurrentlySelected, i18nFileSelectorDeleteFile, isLean, sbbInputModalityDetector, ɵstateController } from "./core.js";
|
|
5
|
+
import { html as html$1, unsafeStatic } from "lit/static-html.js";
|
|
6
|
+
import { SbbSecondaryButtonElement } from "./button.pure.js";
|
|
7
|
+
import { ref } from "lit/directives/ref.js";
|
|
8
|
+
//#endregion
|
|
9
|
+
//#region src/elements/file-selector/common/file-selector-common.ts
|
|
10
|
+
var fileSelectorCommonStyle = unsafeCSS(":host {\n --sbb-file-selector-transition-duration: var(\n --sbb-disable-animation-duration,\n var(--sbb-animation-duration-2x)\n );\n display: block;\n width: 20rem;\n}\n\n@media (forced-colors: active) {\n :host(:disabled) {\n --sbb-file-selector-color: GrayText;\n --sbb-file-selector-subtitle-color: GrayText;\n --sbb-file-selector-border-color: GrayText;\n }\n}\n\n:host(:is(:state(active),[state--active])) {\n --sbb-file-selector-background-color: var(--sbb-background-color-3);\n --sbb-file-selector-border-color: var(--sbb-color-storm);\n --sbb-file-selector-border-color: light-dark(var(--sbb-color-storm), var(--sbb-color-anthracite));\n}\n@media (forced-colors: active) {\n :host(:is(:state(active),[state--active])) {\n --sbb-file-selector-border-color: Highlight;\n }\n}\n\n.sbb-file-selector__input-container {\n -webkit-tap-highlight-color: transparent;\n display: flex;\n flex-direction: column;\n}\n\n.sbb-file-selector__visually-hidden {\n border: 0;\n clip-path: rect(0 0 0 0);\n height: 1px;\n margin: -1px;\n overflow: hidden;\n padding: 0;\n position: absolute;\n white-space: nowrap;\n width: 1px;\n}\n\n.sbb-file-selector__file-list {\n display: flex;\n flex-direction: column;\n row-gap: var(--sbb-spacing-fixed-3x);\n margin-block: 0;\n padding-inline: 0;\n padding-block: var(--sbb-spacing-fixed-6x) var(--sbb-spacing-fixed-1x);\n}\n\n.sbb-file-selector__file {\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: flex;\n gap: var(--sbb-spacing-fixed-4x);\n align-items: center;\n justify-content: space-between;\n}\n\n.sbb-file-selector__file-details {\n display: flex;\n flex: 1;\n justify-content: space-between;\n gap: var(--sbb-spacing-fixed-4x);\n overflow: auto;\n}\n\n.sbb-file-selector__file-name {\n overflow: hidden;\n white-space: nowrap;\n text-overflow: ellipsis;\n}\n\n.sbb-file-selector__file-size {\n white-space: nowrap;\n color: var(--sbb-color-metal);\n color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));\n}\n\n:host(:not(:is(:state(slotted-error),[state--slotted-error]))) .sbb-file-selector__error {\n display: none;\n}");
|
|
11
|
+
var SbbFileSelectorCommonElementMixin = (superclass) => {
|
|
12
|
+
return (() => {
|
|
13
|
+
let _classSuper = SbbDisabledMixin(SbbFormAssociatedMixin(superclass));
|
|
14
|
+
let _instanceExtraInitializers = [];
|
|
15
|
+
let _size_decorators;
|
|
16
|
+
let _size_initializers = [];
|
|
17
|
+
let _size_extraInitializers = [];
|
|
18
|
+
let _multiple_decorators;
|
|
19
|
+
let _multiple_initializers = [];
|
|
20
|
+
let _multiple_extraInitializers = [];
|
|
21
|
+
let _multipleMode_decorators;
|
|
22
|
+
let _multipleMode_initializers = [];
|
|
23
|
+
let _multipleMode_extraInitializers = [];
|
|
24
|
+
let _accept_decorators;
|
|
25
|
+
let _accept_initializers = [];
|
|
26
|
+
let _accept_extraInitializers = [];
|
|
27
|
+
let _accessibilityLabel_decorators;
|
|
28
|
+
let _accessibilityLabel_initializers = [];
|
|
29
|
+
let _accessibilityLabel_extraInitializers = [];
|
|
30
|
+
let _set_value_decorators;
|
|
31
|
+
let _set_files_decorators;
|
|
32
|
+
return class SbbFileSelectorCommonElement extends _classSuper {
|
|
33
|
+
constructor() {
|
|
34
|
+
super(...arguments);
|
|
35
|
+
this.#size_accessor_storage = (__runInitializers(this, _instanceExtraInitializers), __runInitializers(this, _size_initializers, isLean() ? "s" : "m"));
|
|
36
|
+
this.#multiple_accessor_storage = (__runInitializers(this, _size_extraInitializers), __runInitializers(this, _multiple_initializers, false));
|
|
37
|
+
this.#multipleMode_accessor_storage = (__runInitializers(this, _multiple_extraInitializers), __runInitializers(this, _multipleMode_initializers, "default"));
|
|
38
|
+
this.#accept_accessor_storage = (__runInitializers(this, _multipleMode_extraInitializers), __runInitializers(this, _accept_initializers, ""));
|
|
39
|
+
this.#accessibilityLabel_accessor_storage = (__runInitializers(this, _accept_extraInitializers), __runInitializers(this, _accessibilityLabel_initializers, ""));
|
|
40
|
+
this._files = (__runInitializers(this, _accessibilityLabel_extraInitializers), []);
|
|
41
|
+
this._suffixes = [
|
|
42
|
+
"B",
|
|
43
|
+
"kB",
|
|
44
|
+
"MB",
|
|
45
|
+
"GB",
|
|
46
|
+
"TB"
|
|
47
|
+
];
|
|
48
|
+
this.language = new SbbLanguageController(this);
|
|
49
|
+
this._counter = 0;
|
|
50
|
+
}
|
|
51
|
+
static {
|
|
52
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
53
|
+
_size_decorators = [property({ reflect: true })];
|
|
54
|
+
_multiple_decorators = [forceType(), property({ type: Boolean })];
|
|
55
|
+
_multipleMode_decorators = [property({ attribute: "multiple-mode" })];
|
|
56
|
+
_accept_decorators = [forceType(), property()];
|
|
57
|
+
_accessibilityLabel_decorators = [forceType(), property({ attribute: "accessibility-label" })];
|
|
58
|
+
_set_value_decorators = [property({ attribute: false })];
|
|
59
|
+
_set_files_decorators = [property({ attribute: false })];
|
|
60
|
+
__esDecorate(this, null, _size_decorators, {
|
|
61
|
+
kind: "accessor",
|
|
62
|
+
name: "size",
|
|
63
|
+
static: false,
|
|
64
|
+
private: false,
|
|
65
|
+
access: {
|
|
66
|
+
has: (obj) => "size" in obj,
|
|
67
|
+
get: (obj) => obj.size,
|
|
68
|
+
set: (obj, value) => {
|
|
69
|
+
obj.size = value;
|
|
70
|
+
}
|
|
71
|
+
},
|
|
72
|
+
metadata: _metadata
|
|
73
|
+
}, _size_initializers, _size_extraInitializers);
|
|
74
|
+
__esDecorate(this, null, _multiple_decorators, {
|
|
75
|
+
kind: "accessor",
|
|
76
|
+
name: "multiple",
|
|
77
|
+
static: false,
|
|
78
|
+
private: false,
|
|
79
|
+
access: {
|
|
80
|
+
has: (obj) => "multiple" in obj,
|
|
81
|
+
get: (obj) => obj.multiple,
|
|
82
|
+
set: (obj, value) => {
|
|
83
|
+
obj.multiple = value;
|
|
84
|
+
}
|
|
85
|
+
},
|
|
86
|
+
metadata: _metadata
|
|
87
|
+
}, _multiple_initializers, _multiple_extraInitializers);
|
|
88
|
+
__esDecorate(this, null, _multipleMode_decorators, {
|
|
89
|
+
kind: "accessor",
|
|
90
|
+
name: "multipleMode",
|
|
91
|
+
static: false,
|
|
92
|
+
private: false,
|
|
93
|
+
access: {
|
|
94
|
+
has: (obj) => "multipleMode" in obj,
|
|
95
|
+
get: (obj) => obj.multipleMode,
|
|
96
|
+
set: (obj, value) => {
|
|
97
|
+
obj.multipleMode = value;
|
|
98
|
+
}
|
|
99
|
+
},
|
|
100
|
+
metadata: _metadata
|
|
101
|
+
}, _multipleMode_initializers, _multipleMode_extraInitializers);
|
|
102
|
+
__esDecorate(this, null, _accept_decorators, {
|
|
103
|
+
kind: "accessor",
|
|
104
|
+
name: "accept",
|
|
105
|
+
static: false,
|
|
106
|
+
private: false,
|
|
107
|
+
access: {
|
|
108
|
+
has: (obj) => "accept" in obj,
|
|
109
|
+
get: (obj) => obj.accept,
|
|
110
|
+
set: (obj, value) => {
|
|
111
|
+
obj.accept = value;
|
|
112
|
+
}
|
|
113
|
+
},
|
|
114
|
+
metadata: _metadata
|
|
115
|
+
}, _accept_initializers, _accept_extraInitializers);
|
|
116
|
+
__esDecorate(this, null, _accessibilityLabel_decorators, {
|
|
117
|
+
kind: "accessor",
|
|
118
|
+
name: "accessibilityLabel",
|
|
119
|
+
static: false,
|
|
120
|
+
private: false,
|
|
121
|
+
access: {
|
|
122
|
+
has: (obj) => "accessibilityLabel" in obj,
|
|
123
|
+
get: (obj) => obj.accessibilityLabel,
|
|
124
|
+
set: (obj, value) => {
|
|
125
|
+
obj.accessibilityLabel = value;
|
|
126
|
+
}
|
|
127
|
+
},
|
|
128
|
+
metadata: _metadata
|
|
129
|
+
}, _accessibilityLabel_initializers, _accessibilityLabel_extraInitializers);
|
|
130
|
+
__esDecorate(this, null, _set_value_decorators, {
|
|
131
|
+
kind: "setter",
|
|
132
|
+
name: "value",
|
|
133
|
+
static: false,
|
|
134
|
+
private: false,
|
|
135
|
+
access: {
|
|
136
|
+
has: (obj) => "value" in obj,
|
|
137
|
+
set: (obj, value) => {
|
|
138
|
+
obj.value = value;
|
|
139
|
+
}
|
|
140
|
+
},
|
|
141
|
+
metadata: _metadata
|
|
142
|
+
}, null, _instanceExtraInitializers);
|
|
143
|
+
__esDecorate(this, null, _set_files_decorators, {
|
|
144
|
+
kind: "setter",
|
|
145
|
+
name: "files",
|
|
146
|
+
static: false,
|
|
147
|
+
private: false,
|
|
148
|
+
access: {
|
|
149
|
+
has: (obj) => "files" in obj,
|
|
150
|
+
set: (obj, value) => {
|
|
151
|
+
obj.files = value;
|
|
152
|
+
}
|
|
153
|
+
},
|
|
154
|
+
metadata: _metadata
|
|
155
|
+
}, null, _instanceExtraInitializers);
|
|
156
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, {
|
|
157
|
+
enumerable: true,
|
|
158
|
+
configurable: true,
|
|
159
|
+
writable: true,
|
|
160
|
+
value: _metadata
|
|
161
|
+
});
|
|
162
|
+
}
|
|
163
|
+
static {
|
|
164
|
+
this.elementDependencies = [SbbSecondaryButtonElement];
|
|
165
|
+
}
|
|
166
|
+
static {
|
|
167
|
+
this.events = { filechanged: "filechanged" };
|
|
168
|
+
}
|
|
169
|
+
#size_accessor_storage;
|
|
170
|
+
/**
|
|
171
|
+
* Size variant, either s or m.
|
|
172
|
+
* @default 'm' / 's' (lean)
|
|
173
|
+
*/
|
|
174
|
+
get size() {
|
|
175
|
+
return this.#size_accessor_storage;
|
|
176
|
+
}
|
|
177
|
+
set size(value) {
|
|
178
|
+
this.#size_accessor_storage = value;
|
|
179
|
+
}
|
|
180
|
+
#multiple_accessor_storage;
|
|
181
|
+
/** Whether more than one file can be selected. */
|
|
182
|
+
get multiple() {
|
|
183
|
+
return this.#multiple_accessor_storage;
|
|
184
|
+
}
|
|
185
|
+
set multiple(value) {
|
|
186
|
+
this.#multiple_accessor_storage = value;
|
|
187
|
+
}
|
|
188
|
+
#multipleMode_accessor_storage;
|
|
189
|
+
/** Whether the newly added files should override the previously added ones. */
|
|
190
|
+
get multipleMode() {
|
|
191
|
+
return this.#multipleMode_accessor_storage;
|
|
192
|
+
}
|
|
193
|
+
set multipleMode(value) {
|
|
194
|
+
this.#multipleMode_accessor_storage = value;
|
|
195
|
+
}
|
|
196
|
+
#accept_accessor_storage;
|
|
197
|
+
/** A comma-separated list of allowed unique file type specifiers. */
|
|
198
|
+
get accept() {
|
|
199
|
+
return this.#accept_accessor_storage;
|
|
200
|
+
}
|
|
201
|
+
set accept(value) {
|
|
202
|
+
this.#accept_accessor_storage = value;
|
|
203
|
+
}
|
|
204
|
+
#accessibilityLabel_accessor_storage;
|
|
205
|
+
/** This will be forwarded as aria-label to the native input element. */
|
|
206
|
+
get accessibilityLabel() {
|
|
207
|
+
return this.#accessibilityLabel_accessor_storage;
|
|
208
|
+
}
|
|
209
|
+
set accessibilityLabel(value) {
|
|
210
|
+
this.#accessibilityLabel_accessor_storage = value;
|
|
211
|
+
}
|
|
212
|
+
/** The path of the first selected file. Empty string ('') if no file is selected */
|
|
213
|
+
set value(value) {
|
|
214
|
+
this._hiddenInput.value = value ?? "";
|
|
215
|
+
if (!value) this.files = [];
|
|
216
|
+
}
|
|
217
|
+
get value() {
|
|
218
|
+
return this._hiddenInput?.value;
|
|
219
|
+
}
|
|
220
|
+
/** The list of selected files. */
|
|
221
|
+
set files(value) {
|
|
222
|
+
this._files = value ?? [];
|
|
223
|
+
const dt = new DataTransfer();
|
|
224
|
+
this.files.forEach((e) => dt.items.add(e));
|
|
225
|
+
this._hiddenInput.files = dt.files;
|
|
226
|
+
this.updateFormValue();
|
|
227
|
+
}
|
|
228
|
+
get files() {
|
|
229
|
+
return this._files;
|
|
230
|
+
}
|
|
231
|
+
/**
|
|
232
|
+
* Form type of element.
|
|
233
|
+
* @default 'file'
|
|
234
|
+
*/
|
|
235
|
+
get type() {
|
|
236
|
+
return "file";
|
|
237
|
+
}
|
|
238
|
+
formResetCallback() {
|
|
239
|
+
this.files = [];
|
|
240
|
+
}
|
|
241
|
+
formStateRestoreCallback(state, _reason) {
|
|
242
|
+
if (!state) return;
|
|
243
|
+
this.files = state.getAll(this.name);
|
|
244
|
+
}
|
|
245
|
+
updateFormValue() {
|
|
246
|
+
const formValue = new FormData();
|
|
247
|
+
this.files.forEach((file) => formValue.append(this.name, file));
|
|
248
|
+
this.internals.setFormValue(formValue);
|
|
249
|
+
}
|
|
250
|
+
_checkFileEquality(file1, file2) {
|
|
251
|
+
return file1.name === file2.name && file1.size === file2.size && file1.lastModified === file2.lastModified;
|
|
252
|
+
}
|
|
253
|
+
_onFocus() {
|
|
254
|
+
if (sbbInputModalityDetector.mostRecentModality === "keyboard") ɵstateController(this.loadButton).add("focus-visible");
|
|
255
|
+
}
|
|
256
|
+
_onBlur() {
|
|
257
|
+
ɵstateController(this.loadButton).delete("focus-visible");
|
|
258
|
+
}
|
|
259
|
+
_readFiles(event) {
|
|
260
|
+
const fileInput = event.target;
|
|
261
|
+
if (fileInput.files) this.createFileList(fileInput.files);
|
|
262
|
+
forwardEvent(event, this);
|
|
263
|
+
}
|
|
264
|
+
createFileList(files) {
|
|
265
|
+
const fileArray = Array.from(files);
|
|
266
|
+
if (!this.multiple && files.length > 1 || this.accept && fileArray.some((file) => !this.accept.split(",").some((a) => file.name.endsWith(a.trim())))) return;
|
|
267
|
+
if (!this.multiple || this.multipleMode !== "persistent" || this.files.length === 0) this.files = fileArray;
|
|
268
|
+
else this.files = fileArray.filter((newFile) => this.files.findIndex((oldFile) => this._checkFileEquality(newFile, oldFile)) === -1).concat(this.files);
|
|
269
|
+
this._updateA11yLiveRegion();
|
|
270
|
+
this._dispatchFileChangedEvent();
|
|
271
|
+
}
|
|
272
|
+
getButtonLabel() {
|
|
273
|
+
return this.multiple ? i18nFileSelectorButtonLabelMultiple[this.language.current] : i18nFileSelectorButtonLabel[this.language.current];
|
|
274
|
+
}
|
|
275
|
+
_removeFile(file) {
|
|
276
|
+
this.files = this.files.filter((f) => !this._checkFileEquality(file, f));
|
|
277
|
+
this._updateA11yLiveRegion();
|
|
278
|
+
/** The input event fires when the value has been changed as a direct result of a user action. */
|
|
279
|
+
this.dispatchEvent(new InputEvent("input", {
|
|
280
|
+
bubbles: true,
|
|
281
|
+
composed: true
|
|
282
|
+
}));
|
|
283
|
+
/**
|
|
284
|
+
* The change event is fired when the user modifies the element's value.
|
|
285
|
+
* Unlike the input event, the change event is not necessarily fired
|
|
286
|
+
* for each alteration to an element's value.
|
|
287
|
+
*/
|
|
288
|
+
this.dispatchEvent(new Event("change", { bubbles: true }));
|
|
289
|
+
this._dispatchFileChangedEvent();
|
|
290
|
+
}
|
|
291
|
+
_dispatchFileChangedEvent() {
|
|
292
|
+
/**
|
|
293
|
+
* @type {CustomEvent<Readonly<File>[]>}
|
|
294
|
+
* An event which is emitted each time the file list changes.
|
|
295
|
+
*/
|
|
296
|
+
this.dispatchEvent(new CustomEvent("filechanged", {
|
|
297
|
+
bubbles: true,
|
|
298
|
+
composed: true,
|
|
299
|
+
detail: this.files
|
|
300
|
+
}));
|
|
301
|
+
}
|
|
302
|
+
/** Calculates the correct unit for the file's size. */
|
|
303
|
+
_formatFileSize(size) {
|
|
304
|
+
const i = Math.floor(Math.log(size) / Math.log(1024));
|
|
305
|
+
return `${(size / Math.pow(1024, i)).toFixed(0)} ${this._suffixes[i]}`;
|
|
306
|
+
}
|
|
307
|
+
_updateA11yLiveRegion() {
|
|
308
|
+
this._liveRegion.innerText = i18nFileSelectorCurrentlySelected(this.files.map((e) => e.name))[this.language.current];
|
|
309
|
+
}
|
|
310
|
+
_renderFileList() {
|
|
311
|
+
const TAG_NAME = this.files.length > 1 ? {
|
|
312
|
+
WRAPPER: "ul",
|
|
313
|
+
ELEMENT: "li"
|
|
314
|
+
} : {
|
|
315
|
+
WRAPPER: "div",
|
|
316
|
+
ELEMENT: "span"
|
|
317
|
+
};
|
|
318
|
+
return html$1`
|
|
319
|
+
<${unsafeStatic(TAG_NAME.WRAPPER)} class="sbb-file-selector__file-list">
|
|
320
|
+
${this.files.map((file) => html$1`
|
|
321
|
+
<${unsafeStatic(TAG_NAME.ELEMENT)} class="sbb-file-selector__file">
|
|
322
|
+
<span class="sbb-file-selector__file-details">
|
|
323
|
+
<span class="sbb-file-selector__file-name">${file.name}</span>
|
|
324
|
+
<span class="sbb-file-selector__file-size">${this._formatFileSize(file.size)}</span>
|
|
325
|
+
</span>
|
|
326
|
+
<sbb-secondary-button
|
|
327
|
+
size=${this.size}
|
|
328
|
+
icon-name="trash-small"
|
|
329
|
+
@click=${() => this._removeFile(file)}
|
|
330
|
+
aria-label=${`${i18nFileSelectorDeleteFile[this.language.current]} - ${file.name}`}
|
|
331
|
+
></sbb-secondary-button>
|
|
332
|
+
</${unsafeStatic(TAG_NAME.ELEMENT)}>`)}
|
|
333
|
+
</${unsafeStatic(TAG_NAME.WRAPPER)}>
|
|
334
|
+
`;
|
|
335
|
+
}
|
|
336
|
+
_onDragEnter(event) {
|
|
337
|
+
this._counter++;
|
|
338
|
+
if (!this.disabled && !this.formDisabled) {
|
|
339
|
+
this._setDragState(event.target, true);
|
|
340
|
+
this._blockEvent(event);
|
|
341
|
+
}
|
|
342
|
+
}
|
|
343
|
+
_onDragLeave(event) {
|
|
344
|
+
this._counter--;
|
|
345
|
+
if (!this.disabled && !this.formDisabled && event.target === this._dragTarget && this._counter === 0) {
|
|
346
|
+
this._setDragState();
|
|
347
|
+
this._blockEvent(event);
|
|
348
|
+
}
|
|
349
|
+
}
|
|
350
|
+
_onFileDrop(event) {
|
|
351
|
+
this._counter = 0;
|
|
352
|
+
if (!this.disabled && !this.formDisabled) {
|
|
353
|
+
this._setDragState();
|
|
354
|
+
this._blockEvent(event);
|
|
355
|
+
this.createFileList(event.dataTransfer.files);
|
|
356
|
+
}
|
|
357
|
+
}
|
|
358
|
+
_blockEvent(event) {
|
|
359
|
+
event.stopPropagation();
|
|
360
|
+
event.preventDefault();
|
|
361
|
+
}
|
|
362
|
+
_setDragState(dragTarget = void 0, isDragEnter = false) {
|
|
363
|
+
this._dragTarget = dragTarget;
|
|
364
|
+
this.toggleState("active", isDragEnter);
|
|
365
|
+
ɵstateController(this.loadButton).toggle("active", isDragEnter);
|
|
366
|
+
}
|
|
367
|
+
render() {
|
|
368
|
+
const ariaLabel = this.accessibilityLabel ? `${this.getButtonLabel()} - ${this.accessibilityLabel}` : void 0;
|
|
369
|
+
return html$1`
|
|
370
|
+
<div
|
|
371
|
+
class="sbb-file-selector__input-container"
|
|
372
|
+
@dragenter=${this._onDragEnter}
|
|
373
|
+
@dragover=${this._blockEvent}
|
|
374
|
+
@dragleave=${this._onDragLeave}
|
|
375
|
+
@drop=${this._onFileDrop}
|
|
376
|
+
>
|
|
377
|
+
${this.renderTemplate(html$1`<input
|
|
378
|
+
class="sbb-file-selector__visually-hidden"
|
|
379
|
+
type="file"
|
|
380
|
+
?disabled=${this.disabled || this.formDisabled}
|
|
381
|
+
?multiple=${this.multiple}
|
|
382
|
+
accept=${this.accept || nothing}
|
|
383
|
+
aria-label=${ariaLabel || nothing}
|
|
384
|
+
@change=${this._readFiles}
|
|
385
|
+
@focus=${this._onFocus}
|
|
386
|
+
@blur=${this._onBlur}
|
|
387
|
+
${ref((el) => {
|
|
388
|
+
this._hiddenInput = el;
|
|
389
|
+
})}
|
|
390
|
+
/>`)}
|
|
391
|
+
</div>
|
|
392
|
+
<p
|
|
393
|
+
role="status"
|
|
394
|
+
class="sbb-file-selector__visually-hidden"
|
|
395
|
+
${ref((p) => this._liveRegion = p)}
|
|
396
|
+
></p>
|
|
397
|
+
${this.files.length > 0 ? this._renderFileList() : nothing}
|
|
398
|
+
<div class="sbb-file-selector__error">
|
|
399
|
+
<slot name="error"></slot>
|
|
400
|
+
</div>
|
|
401
|
+
`;
|
|
402
|
+
}
|
|
403
|
+
};
|
|
404
|
+
})();
|
|
405
|
+
};
|
|
406
|
+
//#endregion
|
|
407
|
+
export { fileSelectorCommonStyle as n, SbbFileSelectorCommonElementMixin as t };
|
|
408
|
+
|
|
409
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"file-selector-common-BX5f18cJ.js","names":[],"sources":["../../../src/elements/file-selector/common/file-selector-common.scss?inline","../../../src/elements/file-selector/common/file-selector-common.ts"],"sourcesContent":["@use '../../core/styles' as sbb;\n\n:host {\n  --sbb-file-selector-transition-duration: var(\n    --sbb-disable-animation-duration,\n    var(--sbb-animation-duration-2x)\n  );\n\n  display: block;\n  width: #{sbb.px-to-rem-build(320)};\n}\n\n:host(:disabled) {\n  @include sbb.if-forced-colors {\n    --sbb-file-selector-color: GrayText;\n    --sbb-file-selector-subtitle-color: GrayText;\n    --sbb-file-selector-border-color: GrayText;\n  }\n}\n\n:host(:state(active)) {\n  --sbb-file-selector-background-color: var(--sbb-background-color-3);\n  --sbb-file-selector-border-color: light-dark(var(--sbb-color-storm), var(--sbb-color-anthracite));\n\n  @include sbb.if-forced-colors {\n    --sbb-file-selector-border-color: Highlight;\n  }\n}\n\n.sbb-file-selector__input-container {\n  -webkit-tap-highlight-color: transparent;\n  display: flex;\n  flex-direction: column;\n}\n\n.sbb-file-selector__visually-hidden {\n  @include sbb.screen-reader-only;\n}\n\n.sbb-file-selector__file-list {\n  display: flex;\n  flex-direction: column;\n  row-gap: var(--sbb-spacing-fixed-3x);\n  margin-block: 0;\n  padding-inline: 0;\n  padding-block: var(--sbb-spacing-fixed-6x) var(--sbb-spacing-fixed-1x);\n}\n\n.sbb-file-selector__file {\n  @include sbb.text-s--regular;\n\n  display: flex;\n  gap: var(--sbb-spacing-fixed-4x);\n  align-items: center;\n  justify-content: space-between;\n}\n\n.sbb-file-selector__file-details {\n  display: flex;\n  flex: 1;\n  justify-content: space-between;\n  gap: var(--sbb-spacing-fixed-4x);\n  overflow: auto;\n}\n\n.sbb-file-selector__file-name {\n  @include sbb.ellipsis;\n}\n\n.sbb-file-selector__file-size {\n  white-space: nowrap;\n  color: light-dark(var(--sbb-color-metal), var(--sbb-color-smoke));\n}\n\n.sbb-file-selector__error {\n  :host(:not(:state(slotted-error))) & {\n    display: none;\n  }\n}\n","import { nothing, type TemplateResult, unsafeCSS } from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\nimport { html, unsafeStatic } from 'lit/static-html.js';\n\nimport {\n  SbbSecondaryButtonElement,\n  type SbbSecondaryButtonStaticElement,\n} from '../../button.pure.ts';\nimport {\n  type AbstractConstructor,\n  forceType,\n  type FormRestoreReason,\n  type FormRestoreState,\n  forwardEvent,\n  i18nFileSelectorButtonLabel,\n  i18nFileSelectorButtonLabelMultiple,\n  i18nFileSelectorCurrentlySelected,\n  i18nFileSelectorDeleteFile,\n  isLean,\n  SbbDisabledMixin,\n  SbbElement,\n  type SbbElementConstructor,\n  type SbbElementType,\n  SbbFormAssociatedMixin,\n  sbbInputModalityDetector,\n  SbbLanguageController,\n  ɵstateController,\n} from '../../core.ts';\n\nimport fileSelectorCommonStyleString from './file-selector-common.scss?inline';\n\nexport const fileSelectorCommonStyle = unsafeCSS(fileSelectorCommonStyleString);\n\nexport declare abstract class SbbFileSelectorCommonElementMixinType extends SbbDisabledMixin(\n  SbbFormAssociatedMixin(SbbElement),\n) {\n  public accessor size: 's' | 'm';\n  public accessor multiple: boolean;\n  public accessor multipleMode: 'default' | 'persistent';\n  public accessor accept: string;\n  public accessor accessibilityLabel: string;\n  public accessor files: Readonly<File>[];\n  public override get value(): string | null;\n  public override set value(value: string | null);\n  protected loadButton: SbbSecondaryButtonStaticElement;\n  protected language: SbbLanguageController;\n  protected abstract renderTemplate(input: TemplateResult): TemplateResult;\n  protected createFileList(files: FileList): void;\n  protected getButtonLabel(): string;\n  public formResetCallback(): void;\n  public formStateRestoreCallback(state: FormRestoreState | null, reason: FormRestoreReason): void;\n}\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbFileSelectorCommonElementMixin = <\n  T extends AbstractConstructor<SbbElement> & SbbElementConstructor,\n>(\n  superclass: T,\n): AbstractConstructor<SbbFileSelectorCommonElementMixinType> & T => {\n  abstract class SbbFileSelectorCommonElement\n    extends SbbDisabledMixin(SbbFormAssociatedMixin(superclass))\n    implements Partial<SbbFileSelectorCommonElementMixinType>\n  {\n    public static override elementDependencies: SbbElementType[] = [SbbSecondaryButtonElement];\n    public static readonly events = {\n      filechanged: 'filechanged',\n    } as const;\n\n    /**\n     * Size variant, either s or m.\n     * @default 'm' / 's' (lean)\n     */\n    @property({ reflect: true }) public accessor size: 's' | 'm' = isLean() ? 's' : 'm';\n\n    /** Whether more than one file can be selected. */\n    @forceType()\n    @property({ type: Boolean })\n    public accessor multiple: boolean = false;\n\n    /** Whether the newly added files should override the previously added ones. */\n    @property({ attribute: 'multiple-mode' })\n    public accessor multipleMode: 'default' | 'persistent' = 'default';\n\n    /** A comma-separated list of allowed unique file type specifiers. */\n    @forceType()\n    @property()\n    public accessor accept: string = '';\n\n    /** This will be forwarded as aria-label to the native input element. */\n    @forceType()\n    @property({ attribute: 'accessibility-label' })\n    public accessor accessibilityLabel: string = '';\n\n    /** The path of the first selected file. Empty string ('') if no file is selected */\n    @property({ attribute: false })\n    public set value(value: string | null) {\n      this._hiddenInput.value = value ?? '';\n\n      if (!value) {\n        this.files = [];\n      }\n    }\n    public get value(): string | null {\n      return this._hiddenInput?.value;\n    }\n\n    /** The list of selected files. */\n    @property({ attribute: false })\n    public set files(value: Readonly<File>[]) {\n      this._files = value ?? [];\n\n      // update the inner input\n      const dt: DataTransfer = new DataTransfer();\n      this.files.forEach((e: Readonly<File>) => dt.items.add(e));\n      this._hiddenInput.files = dt.files;\n\n      this.updateFormValue();\n    }\n    public get files(): Readonly<File>[] {\n      return this._files;\n    }\n    private _files: Readonly<File>[] = [];\n\n    /**\n     * Form type of element.\n     * @default 'file'\n     */\n    public override get type(): string {\n      return 'file';\n    }\n\n    private _hiddenInput!: HTMLInputElement;\n    private _suffixes: string[] = ['B', 'kB', 'MB', 'GB', 'TB'];\n    private _liveRegion!: HTMLParagraphElement;\n    protected loadButton!: SbbSecondaryButtonStaticElement;\n    protected language = new SbbLanguageController(this);\n\n    // Safari has a peculiar behavior when dragging files on the inner button in 'dropzone' variant;\n    // this will require a counter to correctly handle the dragEnter/dragLeave.\n    private _counter: number = 0;\n    private _dragTarget?: HTMLElement;\n\n    protected abstract renderTemplate(input: TemplateResult): TemplateResult;\n\n    public override formResetCallback(): void {\n      this.files = [];\n    }\n\n    public override formStateRestoreCallback(\n      state: FormRestoreState | null,\n      _reason?: FormRestoreReason,\n    ): void {\n      if (!state) {\n        return;\n      }\n      this.files = (state as FormData).getAll(this.name) as Readonly<File>[];\n    }\n\n    protected override updateFormValue(): void {\n      const formValue = new FormData();\n      this.files.forEach((file) => formValue.append(this.name, file));\n      this.internals.setFormValue(formValue);\n    }\n\n    private _checkFileEquality(file1: Readonly<File>, file2: Readonly<File>): boolean {\n      return (\n        file1.name === file2.name &&\n        file1.size === file2.size &&\n        file1.lastModified === file2.lastModified\n      );\n    }\n\n    private _onFocus(): void {\n      if (sbbInputModalityDetector.mostRecentModality === 'keyboard') {\n        ɵstateController(this.loadButton).add('focus-visible');\n      }\n    }\n\n    private _onBlur(): void {\n      ɵstateController(this.loadButton).delete('focus-visible');\n    }\n\n    private _readFiles(event: Event): void {\n      const fileInput = event.target as HTMLInputElement;\n      if (fileInput.files) {\n        this.createFileList(fileInput.files);\n      }\n      forwardEvent(event, this);\n    }\n\n    protected createFileList(files: FileList): void {\n      const fileArray = Array.from(files);\n      if (\n        (!this.multiple && files.length > 1) ||\n        (this.accept &&\n          fileArray.some(\n            (file) => !this.accept.split(',').some((a) => file.name.endsWith(a.trim())),\n          ))\n      ) {\n        // If multiple files are selected but the selector is not in multiple mode,\n        // ignore the selection (like native behavior).\n        // If the accept attribute is set, check if the selected files match the allowed types.\n        return;\n      }\n\n      if (!this.multiple || this.multipleMode !== 'persistent' || this.files.length === 0) {\n        this.files = fileArray;\n      } else {\n        this.files = fileArray\n          .filter(\n            // Remove duplicates\n            (newFile: Readonly<File>): boolean =>\n              this.files!.findIndex((oldFile: Readonly<File>) =>\n                this._checkFileEquality(newFile, oldFile),\n              ) === -1,\n          )\n          .concat(this.files);\n      }\n      this._updateA11yLiveRegion();\n      this._dispatchFileChangedEvent();\n    }\n\n    protected getButtonLabel(): string {\n      return this.multiple\n        ? i18nFileSelectorButtonLabelMultiple[this.language.current]\n        : i18nFileSelectorButtonLabel[this.language.current];\n    }\n\n    private _removeFile(file: Readonly<File>): void {\n      this.files = this.files.filter((f: Readonly<File>) => !this._checkFileEquality(file, f));\n      this._updateA11yLiveRegion();\n\n      // Dispatch native events as if the reset is done via the file selection window.\n      /** The input event fires when the value has been changed as a direct result of a user action. */\n      this.dispatchEvent(\n        new InputEvent('input', {\n          bubbles: true,\n          composed: true,\n        }),\n      );\n\n      /**\n       * The change event is fired when the user modifies the element's value.\n       * Unlike the input event, the change event is not necessarily fired\n       * for each alteration to an element's value.\n       */\n      this.dispatchEvent(new Event('change', { bubbles: true }));\n      this._dispatchFileChangedEvent();\n    }\n\n    private _dispatchFileChangedEvent(): void {\n      /**\n       * @type {CustomEvent<Readonly<File>[]>}\n       * An event which is emitted each time the file list changes.\n       */\n      this.dispatchEvent(\n        new CustomEvent<Readonly<File>[]>('filechanged', {\n          bubbles: true,\n          composed: true,\n          detail: this.files,\n        }),\n      );\n    }\n\n    /** Calculates the correct unit for the file's size. */\n    private _formatFileSize(size: number): string {\n      const i: number = Math.floor(Math.log(size) / Math.log(1024));\n      return `${(size / Math.pow(1024, i)).toFixed(0)} ${this._suffixes[i]}`;\n    }\n\n    private _updateA11yLiveRegion(): void {\n      this._liveRegion.innerText = i18nFileSelectorCurrentlySelected(this.files.map((e) => e.name))[\n        this.language.current\n      ];\n    }\n\n    private _renderFileList(): TemplateResult {\n      const TAG_NAME: Record<string, string> =\n        this.files.length > 1\n          ? { WRAPPER: 'ul', ELEMENT: 'li' }\n          : { WRAPPER: 'div', ELEMENT: 'span' };\n\n      /* eslint-disable lit/binding-positions */\n      return html`\n      <${unsafeStatic(TAG_NAME.WRAPPER)} class=\"sbb-file-selector__file-list\">\n        ${this.files.map(\n          (file: Readonly<File>) => html`\n            <${unsafeStatic(TAG_NAME.ELEMENT)} class=\"sbb-file-selector__file\">\n                <span class=\"sbb-file-selector__file-details\">\n                  <span class=\"sbb-file-selector__file-name\">${file.name}</span>\n                  <span class=\"sbb-file-selector__file-size\">${this._formatFileSize(file.size)}</span>\n                </span>\n              <sbb-secondary-button\n                size=${this.size}\n                icon-name=\"trash-small\"\n                @click=${() => this._removeFile(file)}\n                aria-label=${`${i18nFileSelectorDeleteFile[this.language.current]} - ${file.name}`}\n              ></sbb-secondary-button>\n            </${unsafeStatic(TAG_NAME.ELEMENT)}>`,\n        )}\n      </${unsafeStatic(TAG_NAME.WRAPPER)}>\n    `;\n      /* eslint-enable lit/binding-positions */\n    }\n\n    private _onDragEnter(event: DragEvent): void {\n      this._counter++;\n      if (!this.disabled && !this.formDisabled) {\n        this._setDragState(event.target as HTMLElement, true);\n        this._blockEvent(event);\n      }\n    }\n\n    private _onDragLeave(event: DragEvent): void {\n      this._counter--;\n      if (\n        !this.disabled &&\n        !this.formDisabled &&\n        event.target === this._dragTarget &&\n        this._counter === 0\n      ) {\n        this._setDragState();\n        this._blockEvent(event);\n      }\n    }\n\n    private _onFileDrop(event: DragEvent): void {\n      this._counter = 0;\n      if (!this.disabled && !this.formDisabled) {\n        this._setDragState();\n        this._blockEvent(event);\n        this.createFileList(event.dataTransfer!.files);\n      }\n    }\n\n    private _blockEvent(event: DragEvent): void {\n      event.stopPropagation();\n      event.preventDefault();\n    }\n\n    private _setDragState(\n      dragTarget: HTMLElement | undefined = undefined,\n      isDragEnter: boolean = false,\n    ): void {\n      this._dragTarget = dragTarget;\n      this.toggleState('active', isDragEnter);\n      ɵstateController(this.loadButton).toggle('active', isDragEnter);\n    }\n\n    protected override render(): TemplateResult {\n      const ariaLabel = this.accessibilityLabel\n        ? `${this.getButtonLabel()} - ${this.accessibilityLabel}`\n        : undefined;\n      return html`\n        <div\n          class=\"sbb-file-selector__input-container\"\n          @dragenter=${this._onDragEnter}\n          @dragover=${this._blockEvent}\n          @dragleave=${this._onDragLeave}\n          @drop=${this._onFileDrop}\n        >\n          ${this.renderTemplate(\n            html`<input\n              class=\"sbb-file-selector__visually-hidden\"\n              type=\"file\"\n              ?disabled=${this.disabled || this.formDisabled}\n              ?multiple=${this.multiple}\n              accept=${this.accept || nothing}\n              aria-label=${ariaLabel || nothing}\n              @change=${this._readFiles}\n              @focus=${this._onFocus}\n              @blur=${this._onBlur}\n              ${ref((el?: Element): void => {\n                this._hiddenInput = el as HTMLInputElement;\n              })}\n            />`,\n          )}\n        </div>\n        <p\n          role=\"status\"\n          class=\"sbb-file-selector__visually-hidden\"\n          ${ref((p?: Element) => (this._liveRegion = p as HTMLParagraphElement))}\n        ></p>\n        ${this.files.length > 0 ? this._renderFileList() : nothing}\n        <div class=\"sbb-file-selector__error\">\n          <slot name=\"error\"></slot>\n        </div>\n      `;\n    }\n  }\n  return SbbFileSelectorCommonElement as unknown as AbstractConstructor<SbbFileSelectorCommonElementMixinType> &\n    T;\n};\n"],"mappings":"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"}
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
import { unsafeCSS } from "lit";
|
|
3
|
+
import { property } from "lit/decorators.js";
|
|
4
|
+
import { SbbElement, boxSizingStyles, forceType, i18nFileSelectorSubtitleLabel, i18nFileSelectorSubtitleLabelMultiple } from "./core.js";
|
|
5
|
+
import { html as html$1 } from "lit/static-html.js";
|
|
6
|
+
import { SbbSecondaryButtonStaticElement } from "./button.pure.js";
|
|
7
|
+
import { SbbIconElement } from "./icon.pure.js";
|
|
8
|
+
import { ref } from "lit/directives/ref.js";
|
|
9
|
+
import { SbbFileSelectorCommonElementMixin, fileSelectorCommonStyle } from "./file-selector/common/file-selector-common.js";
|
|
10
|
+
//#region src/elements/file-selector/file-selector-dropzone/file-selector-dropzone.scss?inline
|
|
11
|
+
var file_selector_dropzone_default = ":host([size=m]) {\n --_sbb-file-selector-dropzone-icon-medium-display: block;\n --_sbb-file-selector-dropzone-icon-small-display: none;\n}\n\n:host([size=s]) {\n --_sbb-file-selector-dropzone-icon-medium-display: none;\n --_sbb-file-selector-dropzone-icon-small-display: block;\n}\n\n.sbb-file-selector__dropzone-area {\n display: flex;\n flex-direction: column;\n align-items: center;\n padding: var(--sbb-spacing-responsive-s);\n background-color: var(--sbb-file-selector-background-color);\n border: var(--sbb-border-width-1x) dashed var(--sbb-file-selector-border-color);\n border-radius: var(--sbb-border-radius-4x);\n transition-duration: var(--sbb-file-selector-transition-duration);\n transition-timing-function: var(--sbb-file-selector-transition-easing-function);\n transition-property: background-color, border-color;\n}\n\n.sbb-file-selector__dropzone-area--icon {\n color: var(--sbb-file-selector-color);\n line-height: 0;\n}\n.sbb-file-selector__dropzone-area--icon sbb-icon[name=folder-open-medium] {\n display: var(--_sbb-file-selector-dropzone-icon-medium-display);\n}\n.sbb-file-selector__dropzone-area--icon sbb-icon[name=folder-open-small] {\n display: var(--_sbb-file-selector-dropzone-icon-small-display);\n}\n\n.sbb-file-selector__dropzone-area--title {\n font-weight: bold;\n --sbb-title-font-size: var(--sbb-title-font-size-level-6-lean, var(--sbb-heading-font-size-6));\n --sbb-title-line-height: var(--sbb-typo-line-height-text);\n margin-block: var(--sbb-title-margin-block, 0);\n margin-inline: 0;\n font-family: var(--sbb-typo-font-family);\n font-weight: bold;\n font-size: var(--sbb-title-font-size);\n letter-spacing: var(--sbb-typo-letter-spacing-heading);\n line-height: var(--sbb-title-line-height, var(--sbb-typo-line-height-heading));\n text-align: center;\n color: var(--sbb-file-selector-color);\n}\n\n.sbb-file-selector__dropzone-area--subtitle {\n --sbb-text-font-size: var(--sbb-text-font-size-xs);\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 text-align: center;\n color: var(--sbb-file-selector-subtitle-color);\n margin-block-end: var(--sbb-spacing-fixed-4x);\n}";
|
|
12
|
+
//#endregion
|
|
13
|
+
//#region src/elements/file-selector/file-selector-dropzone/file-selector-dropzone.component.ts
|
|
14
|
+
/**
|
|
15
|
+
* It allows to select one or more file from storage devices via button click or drag and drop, and display them.
|
|
16
|
+
*
|
|
17
|
+
* @slot error - Use this to provide a `sbb-error` to show an error message.
|
|
18
|
+
*/
|
|
19
|
+
var SbbFileSelectorDropzoneElement = (() => {
|
|
20
|
+
let _classSuper = SbbFileSelectorCommonElementMixin(SbbElement);
|
|
21
|
+
let _titleContent_decorators;
|
|
22
|
+
let _titleContent_initializers = [];
|
|
23
|
+
let _titleContent_extraInitializers = [];
|
|
24
|
+
return class SbbFileSelectorDropzoneElement extends _classSuper {
|
|
25
|
+
static {
|
|
26
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
27
|
+
_titleContent_decorators = [forceType(), property({ attribute: "title-content" })];
|
|
28
|
+
__esDecorate(this, null, _titleContent_decorators, {
|
|
29
|
+
kind: "accessor",
|
|
30
|
+
name: "titleContent",
|
|
31
|
+
static: false,
|
|
32
|
+
private: false,
|
|
33
|
+
access: {
|
|
34
|
+
has: (obj) => "titleContent" in obj,
|
|
35
|
+
get: (obj) => obj.titleContent,
|
|
36
|
+
set: (obj, value) => {
|
|
37
|
+
obj.titleContent = value;
|
|
38
|
+
}
|
|
39
|
+
},
|
|
40
|
+
metadata: _metadata
|
|
41
|
+
}, _titleContent_initializers, _titleContent_extraInitializers);
|
|
42
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, {
|
|
43
|
+
enumerable: true,
|
|
44
|
+
configurable: true,
|
|
45
|
+
writable: true,
|
|
46
|
+
value: _metadata
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
static {
|
|
50
|
+
this.elementName = "sbb-file-selector-dropzone";
|
|
51
|
+
}
|
|
52
|
+
static {
|
|
53
|
+
this.elementDependencies = [SbbIconElement, SbbSecondaryButtonStaticElement];
|
|
54
|
+
}
|
|
55
|
+
static {
|
|
56
|
+
this.styles = [
|
|
57
|
+
boxSizingStyles,
|
|
58
|
+
fileSelectorCommonStyle,
|
|
59
|
+
unsafeCSS(file_selector_dropzone_default)
|
|
60
|
+
];
|
|
61
|
+
}
|
|
62
|
+
static {
|
|
63
|
+
this.events = { filechanged: "filechanged" };
|
|
64
|
+
}
|
|
65
|
+
#titleContent_accessor_storage = __runInitializers(this, _titleContent_initializers, "");
|
|
66
|
+
/** The title displayed in `dropzone` variant. */
|
|
67
|
+
get titleContent() {
|
|
68
|
+
return this.#titleContent_accessor_storage;
|
|
69
|
+
}
|
|
70
|
+
set titleContent(value) {
|
|
71
|
+
this.#titleContent_accessor_storage = value;
|
|
72
|
+
}
|
|
73
|
+
renderTemplate(input) {
|
|
74
|
+
return html$1`
|
|
75
|
+
<label>
|
|
76
|
+
<span class="sbb-file-selector__dropzone-area">
|
|
77
|
+
<span class="sbb-file-selector__dropzone-area--icon">
|
|
78
|
+
<sbb-icon name="folder-open-medium"></sbb-icon>
|
|
79
|
+
<sbb-icon name="folder-open-small"></sbb-icon>
|
|
80
|
+
</span>
|
|
81
|
+
<span class="sbb-file-selector__dropzone-area--title">${this.titleContent}</span>
|
|
82
|
+
<span class="sbb-file-selector__dropzone-area--subtitle">
|
|
83
|
+
${this.multiple ? i18nFileSelectorSubtitleLabelMultiple[this.language.current] : i18nFileSelectorSubtitleLabel[this.language.current]}
|
|
84
|
+
</span>
|
|
85
|
+
<span class="sbb-file-selector__dropzone-area--button">
|
|
86
|
+
<sbb-secondary-button-static
|
|
87
|
+
size=${this.size}
|
|
88
|
+
?disabled=${this.disabled || this.formDisabled}
|
|
89
|
+
${ref((el) => {
|
|
90
|
+
this.loadButton = el;
|
|
91
|
+
})}
|
|
92
|
+
>
|
|
93
|
+
${this.getButtonLabel()}
|
|
94
|
+
</sbb-secondary-button-static>
|
|
95
|
+
</span>
|
|
96
|
+
</span>
|
|
97
|
+
${input}
|
|
98
|
+
</label>
|
|
99
|
+
`;
|
|
100
|
+
}
|
|
101
|
+
constructor() {
|
|
102
|
+
super(...arguments);
|
|
103
|
+
__runInitializers(this, _titleContent_extraInitializers);
|
|
104
|
+
}
|
|
105
|
+
};
|
|
106
|
+
})();
|
|
107
|
+
//#endregion
|
|
108
|
+
export { SbbFileSelectorDropzoneElement as t };
|
|
109
|
+
|
|
110
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1zZWxlY3Rvci1kcm9wem9uZS5jb21wb25lbnQtRE1Ob20yT1cuanMiLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2VsZW1lbnRzL2ZpbGUtc2VsZWN0b3IvZmlsZS1zZWxlY3Rvci1kcm9wem9uZS9maWxlLXNlbGVjdG9yLWRyb3B6b25lLnNjc3M/aW5saW5lIiwiLi4vLi4vLi4vc3JjL2VsZW1lbnRzL2ZpbGUtc2VsZWN0b3IvZmlsZS1zZWxlY3Rvci1kcm9wem9uZS9maWxlLXNlbGVjdG9yLWRyb3B6b25lLmNvbXBvbmVudC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJAdXNlICcuLi8uLi9jb3JlL3N0eWxlcycgYXMgc2JiO1xuXG46aG9zdChbc2l6ZT0nbSddKSB7XG4gIC0tX3NiYi1maWxlLXNlbGVjdG9yLWRyb3B6b25lLWljb24tbWVkaXVtLWRpc3BsYXk6IGJsb2NrO1xuICAtLV9zYmItZmlsZS1zZWxlY3Rvci1kcm9wem9uZS1pY29uLXNtYWxsLWRpc3BsYXk6IG5vbmU7XG59XG5cbjpob3N0KFtzaXplPSdzJ10pIHtcbiAgLS1fc2JiLWZpbGUtc2VsZWN0b3ItZHJvcHpvbmUtaWNvbi1tZWRpdW0tZGlzcGxheTogbm9uZTtcbiAgLS1fc2JiLWZpbGUtc2VsZWN0b3ItZHJvcHpvbmUtaWNvbi1zbWFsbC1kaXNwbGF5OiBibG9jaztcbn1cblxuLnNiYi1maWxlLXNlbGVjdG9yX19kcm9wem9uZS1hcmVhIHtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgcGFkZGluZzogdmFyKC0tc2JiLXNwYWNpbmctcmVzcG9uc2l2ZS1zKTtcbiAgYmFja2dyb3VuZC1jb2xvcjogdmFyKC0tc2JiLWZpbGUtc2VsZWN0b3ItYmFja2dyb3VuZC1jb2xvcik7XG4gIGJvcmRlcjogdmFyKC0tc2JiLWJvcmRlci13aWR0aC0xeCkgZGFzaGVkIHZhcigtLXNiYi1maWxlLXNlbGVjdG9yLWJvcmRlci1jb2xvcik7XG4gIGJvcmRlci1yYWRpdXM6IHZhcigtLXNiYi1ib3JkZXItcmFkaXVzLTR4KTtcbiAgdHJhbnNpdGlvbi1kdXJhdGlvbjogdmFyKC0tc2JiLWZpbGUtc2VsZWN0b3ItdHJhbnNpdGlvbi1kdXJhdGlvbik7XG4gIHRyYW5zaXRpb24tdGltaW5nLWZ1bmN0aW9uOiB2YXIoLS1zYmItZmlsZS1zZWxlY3Rvci10cmFuc2l0aW9uLWVhc2luZy1mdW5jdGlvbik7XG4gIHRyYW5zaXRpb24tcHJvcGVydHk6IGJhY2tncm91bmQtY29sb3IsIGJvcmRlci1jb2xvcjtcbn1cblxuLnNiYi1maWxlLXNlbGVjdG9yX19kcm9wem9uZS1hcmVhLS1pY29uIHtcbiAgY29sb3I6IHZhcigtLXNiYi1maWxlLXNlbGVjdG9yLWNvbG9yKTtcbiAgbGluZS1oZWlnaHQ6IDA7XG5cbiAgc2JiLWljb25bbmFtZT0nZm9sZGVyLW9wZW4tbWVkaXVtJ10ge1xuICAgIGRpc3BsYXk6IHZhcigtLV9zYmItZmlsZS1zZWxlY3Rvci1kcm9wem9uZS1pY29uLW1lZGl1bS1kaXNwbGF5KTtcbiAgfVxuXG4gIHNiYi1pY29uW25hbWU9J2ZvbGRlci1vcGVuLXNtYWxsJ10ge1xuICAgIGRpc3BsYXk6IHZhcigtLV9zYmItZmlsZS1zZWxlY3Rvci1kcm9wem9uZS1pY29uLXNtYWxsLWRpc3BsYXkpO1xuICB9XG59XG5cbi5zYmItZmlsZS1zZWxlY3Rvcl9fZHJvcHpvbmUtYXJlYS0tdGl0bGUge1xuICBAaW5jbHVkZSBzYmIudGV4dC0tYm9sZDtcbiAgQGluY2x1ZGUgc2JiLnRpdGxlLTYoJGV4Y2x1ZGUtc3BhY2luZzogdHJ1ZSk7XG5cbiAgdGV4dC1hbGlnbjogY2VudGVyO1xuICBjb2xvcjogdmFyKC0tc2JiLWZpbGUtc2VsZWN0b3ItY29sb3IpO1xufVxuXG4uc2JiLWZpbGUtc2VsZWN0b3JfX2Ryb3B6b25lLWFyZWEtLXN1YnRpdGxlIHtcbiAgQGluY2x1ZGUgc2JiLnRleHQteHMtLXJlZ3VsYXI7XG5cbiAgdGV4dC1hbGlnbjogY2VudGVyO1xuICBjb2xvcjogdmFyKC0tc2JiLWZpbGUtc2VsZWN0b3Itc3VidGl0bGUtY29sb3IpO1xuICBtYXJnaW4tYmxvY2stZW5kOiB2YXIoLS1zYmItc3BhY2luZy1maXhlZC00eCk7XG59XG4iLCJpbXBvcnQgeyB0eXBlIENTU1Jlc3VsdEdyb3VwLCB0eXBlIFRlbXBsYXRlUmVzdWx0LCB1bnNhZmVDU1MgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgcHJvcGVydHkgfSBmcm9tICdsaXQvZGVjb3JhdG9ycy5qcyc7XG5pbXBvcnQgeyByZWYgfSBmcm9tICdsaXQvZGlyZWN0aXZlcy9yZWYuanMnO1xuaW1wb3J0IHsgaHRtbCB9IGZyb20gJ2xpdC9zdGF0aWMtaHRtbC5qcyc7XG5cbmltcG9ydCB7IFNiYlNlY29uZGFyeUJ1dHRvblN0YXRpY0VsZW1lbnQgfSBmcm9tICcuLi8uLi9idXR0b24ucHVyZS50cyc7XG5pbXBvcnQge1xuICBib3hTaXppbmdTdHlsZXMsXG4gIGZvcmNlVHlwZSxcbiAgaTE4bkZpbGVTZWxlY3RvclN1YnRpdGxlTGFiZWwsXG4gIGkxOG5GaWxlU2VsZWN0b3JTdWJ0aXRsZUxhYmVsTXVsdGlwbGUsXG4gIFNiYkVsZW1lbnQsXG4gIHR5cGUgU2JiRWxlbWVudFR5cGUsXG59IGZyb20gJy4uLy4uL2NvcmUudHMnO1xuaW1wb3J0IHsgU2JiSWNvbkVsZW1lbnQgfSBmcm9tICcuLi8uLi9pY29uLnB1cmUudHMnO1xuaW1wb3J0IHtcbiAgZmlsZVNlbGVjdG9yQ29tbW9uU3R5bGUsXG4gIFNiYkZpbGVTZWxlY3RvckNvbW1vbkVsZW1lbnRNaXhpbixcbn0gZnJvbSAnLi4vY29tbW9uL2ZpbGUtc2VsZWN0b3ItY29tbW9uLnRzJztcblxuaW1wb3J0IHN0eWxlIGZyb20gJy4vZmlsZS1zZWxlY3Rvci1kcm9wem9uZS5zY3NzP2lubGluZSc7XG5cbi8qKlxuICogSXQgYWxsb3dzIHRvIHNlbGVjdCBvbmUgb3IgbW9yZSBmaWxlIGZyb20gc3RvcmFnZSBkZXZpY2VzIHZpYSBidXR0b24gY2xpY2sgb3IgZHJhZyBhbmQgZHJvcCwgYW5kIGRpc3BsYXkgdGhlbS5cbiAqXG4gKiBAc2xvdCBlcnJvciAtIFVzZSB0aGlzIHRvIHByb3ZpZGUgYSBgc2JiLWVycm9yYCB0byBzaG93IGFuIGVycm9yIG1lc3NhZ2UuXG4gKi9cbmV4cG9ydCBjbGFzcyBTYmJGaWxlU2VsZWN0b3JEcm9wem9uZUVsZW1lbnQgZXh0ZW5kcyBTYmJGaWxlU2VsZWN0b3JDb21tb25FbGVtZW50TWl4aW4oU2JiRWxlbWVudCkge1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHJlYWRvbmx5IGVsZW1lbnROYW1lOiBzdHJpbmcgPSAnc2JiLWZpbGUtc2VsZWN0b3ItZHJvcHpvbmUnO1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIGVsZW1lbnREZXBlbmRlbmNpZXM6IFNiYkVsZW1lbnRUeXBlW10gPSBbXG4gICAgU2JiSWNvbkVsZW1lbnQsXG4gICAgU2JiU2Vjb25kYXJ5QnV0dG9uU3RhdGljRWxlbWVudCxcbiAgXTtcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gW1xuICAgIGJveFNpemluZ1N0eWxlcyxcbiAgICBmaWxlU2VsZWN0b3JDb21tb25TdHlsZSxcbiAgICB1bnNhZmVDU1Moc3R5bGUpLFxuICBdO1xuICBwdWJsaWMgc3RhdGljIHJlYWRvbmx5IGV2ZW50cyA9IHtcbiAgICBmaWxlY2hhbmdlZDogJ2ZpbGVjaGFuZ2VkJyxcbiAgfSBhcyBjb25zdDtcblxuICAvKiogVGhlIHRpdGxlIGRpc3BsYXllZCBpbiBgZHJvcHpvbmVgIHZhcmlhbnQuICovXG4gIEBmb3JjZVR5cGUoKVxuICBAcHJvcGVydHkoeyBhdHRyaWJ1dGU6ICd0aXRsZS1jb250ZW50JyB9KVxuICBwdWJsaWMgYWNjZXNzb3IgdGl0bGVDb250ZW50OiBzdHJpbmcgPSAnJztcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyVGVtcGxhdGUoaW5wdXQ6IFRlbXBsYXRlUmVzdWx0KTogVGVtcGxhdGVSZXN1bHQge1xuICAgIHJldHVybiBodG1sYFxuICAgICAgPGxhYmVsPlxuICAgICAgICA8c3BhbiBjbGFzcz1cInNiYi1maWxlLXNlbGVjdG9yX19kcm9wem9uZS1hcmVhXCI+XG4gICAgICAgICAgPHNwYW4gY2xhc3M9XCJzYmItZmlsZS1zZWxlY3Rvcl9fZHJvcHpvbmUtYXJlYS0taWNvblwiPlxuICAgICAgICAgICAgPHNiYi1pY29uIG5hbWU9XCJmb2xkZXItb3Blbi1tZWRpdW1cIj48L3NiYi1pY29uPlxuICAgICAgICAgICAgPHNiYi1pY29uIG5hbWU9XCJmb2xkZXItb3Blbi1zbWFsbFwiPjwvc2JiLWljb24+XG4gICAgICAgICAgPC9zcGFuPlxuICAgICAgICAgIDxzcGFuIGNsYXNzPVwic2JiLWZpbGUtc2VsZWN0b3JfX2Ryb3B6b25lLWFyZWEtLXRpdGxlXCI+JHt0aGlzLnRpdGxlQ29udGVudH08L3NwYW4+XG4gICAgICAgICAgPHNwYW4gY2xhc3M9XCJzYmItZmlsZS1zZWxlY3Rvcl9fZHJvcHpvbmUtYXJlYS0tc3VidGl0bGVcIj5cbiAgICAgICAgICAgICR7dGhpcy5tdWx0aXBsZVxuICAgICAgICAgICAgICA/IGkxOG5GaWxlU2VsZWN0b3JTdWJ0aXRsZUxhYmVsTXVsdGlwbGVbdGhpcy5sYW5ndWFnZS5jdXJyZW50XVxuICAgICAgICAgICAgICA6IGkxOG5GaWxlU2VsZWN0b3JTdWJ0aXRsZUxhYmVsW3RoaXMubGFuZ3VhZ2UuY3VycmVudF19XG4gICAgICAgICAgPC9zcGFuPlxuICAgICAgICAgIDxzcGFuIGNsYXNzPVwic2JiLWZpbGUtc2VsZWN0b3JfX2Ryb3B6b25lLWFyZWEtLWJ1dHRvblwiPlxuICAgICAgICAgICAgPHNiYi1zZWNvbmRhcnktYnV0dG9uLXN0YXRpY1xuICAgICAgICAgICAgICBzaXplPSR7dGhpcy5zaXplfVxuICAgICAgICAgICAgICA/ZGlzYWJsZWQ9JHt0aGlzLmRpc2FibGVkIHx8IHRoaXMuZm9ybURpc2FibGVkfVxuICAgICAgICAgICAgICAke3JlZigoZWw/OiBFbGVtZW50KTogdm9pZCA9PiB7XG4gICAgICAgICAgICAgICAgdGhpcy5sb2FkQnV0dG9uID0gZWwgYXMgU2JiU2Vjb25kYXJ5QnV0dG9uU3RhdGljRWxlbWVudDtcbiAgICAgICAgICAgICAgfSl9XG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgICR7dGhpcy5nZXRCdXR0b25MYWJlbCgpfVxuICAgICAgICAgICAgPC9zYmItc2Vjb25kYXJ5LWJ1dHRvbi1zdGF0aWM+XG4gICAgICAgICAgPC9zcGFuPlxuICAgICAgICA8L3NwYW4+XG4gICAgICAgICR7aW5wdXR9XG4gICAgICA8L2xhYmVsPlxuICAgIGA7XG4gIH1cbn1cblxuZGVjbGFyZSBnbG9iYWwge1xuICBpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25hbWluZy1jb252ZW50aW9uXG4gICAgJ3NiYi1maWxlLXNlbGVjdG9yLWRyb3B6b25lJzogU2JiRmlsZVNlbGVjdG9yRHJvcHpvbmVFbGVtZW50O1xuICB9XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7OztJQzJCYSx3Q0FBOEI7bUJBQVMsa0NBQWtDLFdBQVc7Ozs7Y0FBcEYsdUNBQXVDLFlBQTZDOzs7K0JBZ0I5RixXQUFXLEVBQ1gsU0FBUyxFQUFFLFdBQVcsaUJBQWlCLENBQUMsQ0FBQTtBQUN6QyxnQkFBQSxNQUFBLE1BQUEsMEJBQUE7SUFBQSxNQUFBO0lBQUEsTUFBQTtJQUFBLFFBQUE7SUFBQSxTQUFBO0lBQUEsUUFBQTtLQUFBLE1BQUEsUUFBQSxrQkFBQTtLQUFBLE1BQUEsUUFBQSxJQUFnQjtLQUFZLE1BQUEsS0FBQSxVQUFBO0FBQUEsVUFBWixlQUFZOztLQUFBO0lBQUEsVUFBQTtJQUFBLEVBQUEsNEJBQUEsZ0NBQUE7Ozs7Ozs7OztBQWpCSSxRQUFBLGNBQXNCOzs7QUFDL0IsUUFBQSxzQkFBd0MsQ0FDN0QsZ0JBQ0EsZ0NBQ0Q7OztBQUNzQixRQUFBLFNBQXlCO0lBQzlDO0lBQ0E7SUFDQSxVQUFVLCtCQUFBO0lBQ1g7OztBQUNzQixRQUFBLFNBQVMsRUFDOUIsYUFBYSxlQUNMOztFQUtWLGlDQUFBLGtCQUFBLE1BQUEsNEJBQXVDLEdBQUU7O0VBQXpDLElBQWdCLGVBQVk7QUFBQSxVQUFBLE1BQUE7O0VBQTVCLElBQWdCLGFBQVksT0FBQTtBQUFBLFNBQUEsZ0NBQUE7O0VBRVQsZUFBZSxPQUFxQjtBQUNyRCxVQUFPLE1BQUk7Ozs7Ozs7a0VBT21ELEtBQUssYUFBWTs7Y0FFckUsS0FBSyxXQUNILHNDQUFzQyxLQUFLLFNBQVMsV0FDcEQsOEJBQThCLEtBQUssU0FBUyxTQUFBOzs7O3FCQUl2QyxLQUFLLEtBQUE7MEJBQ0EsS0FBSyxZQUFZLEtBQUssYUFBQTtnQkFDaEMsS0FBSyxPQUFzQjtBQUMzQixTQUFLLGFBQWE7S0FDbEIsQ0FBQTs7Z0JBRUEsS0FBSyxnQkFBZ0IsQ0FBQTs7OztVQUkzQixNQUFBIn0=
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { n as fileSelectorCommonStyle, t as SbbFileSelectorCommonElementMixin } from "./file-selector-common-
|
|
2
|
-
import { t as SbbFileSelectorDropzoneElement } from "./file-selector-dropzone.component-
|
|
1
|
+
import { n as fileSelectorCommonStyle, t as SbbFileSelectorCommonElementMixin } from "./file-selector-common-BX5f18cJ.js";
|
|
2
|
+
import { t as SbbFileSelectorDropzoneElement } from "./file-selector-dropzone.component-DMNom2OW.js";
|
|
3
3
|
import { SbbFileSelectorElement } from "./file-selector/file-selector/file-selector.component.js";
|
|
4
4
|
import "./file-selector.pure.js";
|
|
5
5
|
//#region src/elements/file-selector.ts
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { n as fileSelectorCommonStyle, t as SbbFileSelectorCommonElementMixin } from "./file-selector-common-
|
|
2
|
-
import { t as SbbFileSelectorDropzoneElement } from "./file-selector-dropzone.component-
|
|
1
|
+
import { n as fileSelectorCommonStyle, t as SbbFileSelectorCommonElementMixin } from "./file-selector-common-BX5f18cJ.js";
|
|
2
|
+
import { t as SbbFileSelectorDropzoneElement } from "./file-selector-dropzone.component-DMNom2OW.js";
|
|
3
3
|
import { SbbFileSelectorElement } from "./file-selector/file-selector/file-selector.component.js";
|
|
4
4
|
export { SbbFileSelectorCommonElementMixin, SbbFileSelectorDropzoneElement, SbbFileSelectorElement, fileSelectorCommonStyle };
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { n as e, r as t, t as n } from "../../dialog.component-
|
|
1
|
+
import { n as e, r as t, t as n } from "../../dialog.component-ChB9gCyY.js";
|
|
2
2
|
export { n as SbbDialogCloseEvent, e as SbbDialogElement, t as assignDialogResult };
|
|
@@ -8,7 +8,7 @@ import { ref as l } from "lit/directives/ref.js";
|
|
|
8
8
|
import { SbbOverlayBaseElement as u, SbbOverlayCloseEvent as d, overlayRefs as f } from "./overlay.pure.js";
|
|
9
9
|
import { SbbOverlayCloseEvent as p, assignOverlayResult as m } from "./overlay/overlay-base-element.js";
|
|
10
10
|
//#region src/elements/dialog/dialog/dialog.scss?inline
|
|
11
|
-
var h = ":host{--sbb-dialog-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-6x) );--sbb-dialog-padding-block: var(--sbb-spacing-responsive-xs);--sbb-dialog-shadow-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-4x) );display:none;position:fixed;inset:var(--sbb-dialog-inset);z-index:var(--sbb-dialog-z-index, var(--sbb-overlay-default-z-index))}
|
|
11
|
+
var h = ":host{--sbb-dialog-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-6x) );--sbb-dialog-padding-block: var(--sbb-spacing-responsive-xs);--sbb-dialog-shadow-animation-duration: var( --sbb-disable-animation-duration, var(--sbb-animation-duration-4x) );display:none;position:fixed;inset:var(--sbb-dialog-inset);z-index:var(--sbb-dialog-z-index, var(--sbb-overlay-default-z-index))}:host(:is(:state(top-shadow),[state--top-shadow])){--sbb-dialog-block-start-box-shadow: var(--_sbb-dialog-block-shadow)}:host(:is(:is(:state(state-opening),[state--state-opening]),:is(:state(state-opened),[state--state-opened]),:is(:state(state-closing),[state--state-closing]))){display:block}:host(:is(:is(:state(state-opening),[state--state-opening]),:is(:state(state-opened),[state--state-opened]))){--sbb-dialog-pointer-events: all;--sbb-dialog-backdrop-color: var(--sbb-background-color-3);--sbb-dialog-backdrop-visibility: visible;--sbb-dialog-backdrop-pointer-events: all}:host([backdrop=translucent]:is(:is(:state(state-opening),[state--state-opening]),:is(:state(state-opened),[state--state-opened]))){--sbb-dialog-backdrop-color: color-mix(in srgb, var(--sbb-color-black) 50%, transparent)}:host([backdrop=opaque]:not([negative]):is(:is(:state(state-opening),[state--state-opening]),:is(:state(state-opened),[state--state-opened]))){--sbb-dialog-backdrop-color: var(--sbb-background-color-3)}:host(:not([negative])){--_sbb-dialog-color: var(--sbb-dialog-color);--_sbb-dialog-block-shadow: var(--sbb-dialog-block-shadow);--sbb-dialog-actions-border-color: var(--sbb-background-color-4);--sbb-dialog-background-color: var(--sbb-background-color-1)}:host([negative]){--_sbb-dialog-color: var(--sbb-dialog-color-negative);--_sbb-dialog-block-shadow: var(--sbb-dialog-block-shadow-negative);--sbb-dialog-background-color: var(--sbb-background-color-1-negative);--sbb-dialog-actions-border-color: var(--sbb-background-color-4-negative);--sbb-dialog-backdrop-color: var(--sbb-background-color-3-negative);--sbb-focus-outline-color: var(--sbb-focus-outline-color-dark)}:host(:is(:state(bottom-shadow),[state--bottom-shadow])){--sbb-dialog-block-end-box-shadow: var(--_sbb-dialog-block-shadow);--sbb-dialog-actions-border-color: transparent}:host(:not(:is(:state(state-closed),[state--state-closed]))){--sbb-dialog-inset-block: 0;--sbb-dialog-inset-inline: 0}.sbb-dialog__container{pointer-events:var(--sbb-dialog-pointer-events);display:flex;justify-content:center;align-items:center;position:fixed;inset-block:var(--sbb-dialog-inset-block);inset-inline:var(--sbb-dialog-inset-inline)}.sbb-dialog__container:before{content:\"\";visibility:var(--sbb-dialog-backdrop-visibility);pointer-events:var(--sbb-dialog-backdrop-pointer-events);position:fixed;inset-block:var(--sbb-dialog-inset-block);inset-inline:var(--sbb-dialog-inset-inline);background-color:var(--sbb-dialog-backdrop-color);transition-duration:var(--sbb-dialog-animation-duration);transition-timing-function:var(--sbb-dialog-animation-easing);transition-property:background-color,visibility}.sbb-dialog{display:none;position:absolute;inset-inline:0;inset-block:auto 0;border:none;border-radius:var(--sbb-dialog-border-radius) var(--sbb-dialog-border-radius) 0 0;max-width:var(--sbb-dialog-max-width);max-height:var(--sbb-dialog-max-height);color:var(--_sbb-dialog-color);background-color:var(--sbb-dialog-background-color)}:host(:is(:is(:state(state-opening),[state--state-opening]),:is(:state(state-opened),[state--state-opened]),:is(:state(state-closing),[state--state-closing]))) .sbb-dialog{display:block;animation-name:open;animation-duration:var(--sbb-dialog-animation-duration);animation-timing-function:ease}:host(:is(:state(state-closing),[state--state-closing])) .sbb-dialog{pointer-events:none;animation-name:close}@media(forced-colors:active){.sbb-dialog{outline:var(--sbb-border-width-1x) solid CanvasText}}@media(min-width:37.5rem){.sbb-dialog{height:var(--sbb-dialog-height);width:var(--sbb-dialog-width);inset:unset;border-radius:var(--sbb-dialog-border-radius);overflow:hidden}}:host(:is(:state(has-intermediate-element),[state--has-intermediate-element])) ::slotted(:first-child),.sbb-dialog__wrapper{max-height:var(--sbb-dialog-max-height)}@media(min-width:37.5rem){:host(:is(:state(has-intermediate-element),[state--has-intermediate-element])) ::slotted(:first-child),.sbb-dialog__wrapper{width:var(--sbb-dialog-width);height:var(--sbb-dialog-height)}}:host(:is(:state(has-intermediate-element),[state--has-intermediate-element])) ::slotted(:first-child),:host(:not(:is(:state(has-intermediate-element),[state--has-intermediate-element]))) .sbb-dialog__wrapper{display:grid;grid-template:\"title close-button\" auto \"content content\" 1fr \"actions actions\" auto/1fr auto;gap:0}@keyframes open{0%{opacity:0;translate:0 var(--sbb-dialog-translate-y, 100%)}to{opacity:1;translate:0 0}}@keyframes close{0%{opacity:1;translate:0 0}to{opacity:0;translate:0 var(--sbb-dialog-translate-y, 100%)}}", g = (() => {
|
|
12
12
|
let p = u, m, g = [], _ = [], v, y = [], b = [];
|
|
13
13
|
return class extends p {
|
|
14
14
|
static {
|