@sbb-esta/lyne-elements-dev 5.0.0-next.1-dev.1777534945 → 5.0.0-next.1-dev.1777543026
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/autocomplete/autocomplete-base-element.js +1 -1
- package/autocomplete/autocomplete.component.js +1 -1
- package/{autocomplete-base-element-CSCv_WVh.js → autocomplete-base-element-BiLyvcN-.js} +1 -1
- package/autocomplete.js +1 -1
- package/autocomplete.pure.js +1 -1
- package/core/styles/mixins/scrollbar.scss +0 -6
- package/core/styles/scrollbar.scss +19 -24
- package/core/styles/styles.js +2 -2
- package/core.css +0 -37
- package/core.js +2 -2
- package/custom-elements.json +66 -16
- package/development/autocomplete/autocomplete-base-element.js +1 -1
- package/development/autocomplete/autocomplete.component.js +1 -1
- package/development/{autocomplete-base-element-Bwkns3IL.js → autocomplete-base-element-BxBpn8_e.js} +2 -2
- package/development/autocomplete.js +1 -1
- package/development/autocomplete.pure.js +1 -1
- package/development/core/styles/styles.d.ts +1 -0
- package/development/core/styles/styles.d.ts.map +1 -1
- package/development/core/styles/styles.js +2 -2
- package/development/core.js +2 -2
- package/development/dialog/dialog-content/dialog-content.component.d.ts +1 -0
- package/development/dialog/dialog-content/dialog-content.component.d.ts.map +1 -1
- package/development/dialog/dialog-content/dialog-content.component.js +1 -1
- package/development/{dialog-content.component-B7Grxjk6.js → dialog-content.component-Bzt-PL6f.js} +10 -3
- package/development/dialog.js +1 -1
- package/development/dialog.pure.js +1 -1
- package/development/file-selector/common/file-selector-common.d.ts +1 -2
- package/development/file-selector/common/file-selector-common.d.ts.map +1 -1
- package/development/file-selector/common/file-selector-common.js +2 -2
- package/development/file-selector/file-selector/file-selector.component.d.ts +1 -2
- package/development/file-selector/file-selector/file-selector.component.d.ts.map +1 -1
- package/development/file-selector/file-selector/file-selector.component.js +3 -6
- 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-BH_iIjcB.js +417 -0
- package/development/{file-selector-dropzone.component-DRUUWI1A.js → file-selector-dropzone.component-ZCanLwF-.js} +4 -8
- package/development/file-selector.js +3 -3
- package/development/file-selector.pure.js +3 -3
- package/development/map-container/map-container.component.d.ts.map +1 -1
- package/development/map-container/map-container.component.js +1 -1
- package/development/map-container.component-DoFCVBoh.js +180 -0
- package/development/map-container.js +1 -1
- package/development/map-container.pure.js +1 -1
- package/development/menu/menu/menu.component.d.ts.map +1 -1
- package/development/menu/menu/menu.component.js +1 -1
- package/development/menu.component-CDBUaD8s.js +369 -0
- package/development/menu.js +1 -1
- package/development/menu.pure.js +1 -1
- package/development/navigation/navigation/navigation.component.d.ts.map +1 -1
- package/development/navigation/navigation/navigation.component.js +1 -1
- package/development/navigation/navigation-section/navigation-section.component.d.ts.map +1 -1
- package/development/navigation/navigation-section/navigation-section.component.js +1 -1
- package/development/navigation-section.component-D3_XVwyt.js +350 -0
- package/development/navigation.component-Cco4llBt.js +319 -0
- package/development/navigation.js +2 -2
- package/development/navigation.pure.js +2 -2
- package/development/overlay/overlay.component.d.ts.map +1 -1
- package/development/overlay/overlay.component.js +1 -1
- package/development/overlay.component-DBzb0PdD.js +206 -0
- package/development/overlay.js +1 -1
- package/development/overlay.pure.js +1 -1
- package/development/popover/popover.component.d.ts +1 -0
- package/development/popover/popover.component.d.ts.map +1 -1
- package/development/popover/popover.component.js +1 -1
- package/development/popover.component-Dj0INQsI.js +564 -0
- package/development/popover.js +1 -1
- package/development/popover.pure.js +1 -1
- package/development/select/select.component.js +1 -1
- package/development/{select.component-C1Xfvvii.js → select.component-D_9pjl7T.js} +2 -2
- package/development/select.js +1 -1
- package/development/select.pure.js +1 -1
- package/development/sidebar/sidebar/sidebar.component.d.ts.map +1 -1
- package/development/sidebar/sidebar/sidebar.component.js +1 -1
- package/development/sidebar.component-CYLbI1Vp.js +356 -0
- package/development/sidebar.js +1 -1
- package/development/sidebar.pure.js +1 -1
- package/development/styles-B_IWjHc5.js +22 -0
- package/development/table/table-wrapper/table-wrapper.component.js +1 -1
- package/development/table-wrapper.component-D8IFPow6.js +119 -0
- package/development/table.js +1 -1
- package/development/table.pure.js +1 -1
- package/dialog/dialog-content/dialog-content.component.js +1 -1
- package/{dialog-content.component-are-UBx3.js → dialog-content.component-iRLHPKPb.js} +7 -2
- package/dialog.js +1 -1
- package/dialog.pure.js +1 -1
- package/file-selector/common/file-selector-common.js +2 -2
- package/file-selector/file-selector/file-selector.component.js +10 -13
- package/file-selector/file-selector-dropzone/file-selector-dropzone.component.js +1 -1
- package/{file-selector-common-jpJmVqAw.js → file-selector-common-PcqPdsnN.js} +44 -38
- package/{file-selector-dropzone.component-DDRTu6p2.js → file-selector-dropzone.component-2XUfh1NC.js} +20 -24
- package/file-selector.js +5 -5
- package/file-selector.pure.js +4 -4
- package/map-container/map-container.component.js +1 -1
- package/{map-container.component-Btnl3n9d.js → map-container.component-5I5DW5dJ.js} +23 -16
- package/map-container.js +1 -1
- package/map-container.pure.js +1 -1
- package/menu/menu/menu.component.js +1 -1
- package/{menu.component-CpNMheMG.js → menu.component-Bd37u3Ps.js} +26 -22
- package/menu.js +1 -1
- package/menu.pure.js +1 -1
- package/navigation/navigation/navigation.component.js +1 -1
- package/navigation/navigation-section/navigation-section.component.js +1 -1
- package/{navigation-section.component-219JlVIe.js → navigation-section.component-B_0xi30L.js} +24 -20
- package/{navigation.component-gLrMCbh9.js → navigation.component-CmrLIeDB.js} +24 -20
- package/navigation.js +2 -2
- package/navigation.pure.js +2 -2
- package/off-brand-theme.css +33 -134
- package/overlay/overlay.component.js +1 -1
- package/overlay.component-D2jtCeeb.js +156 -0
- package/overlay.js +1 -1
- package/overlay.pure.js +1 -1
- package/package.json +2 -2
- package/popover/popover.component.js +1 -1
- package/{popover.component-DnY9obd7.js → popover.component-CiMeNnO-.js} +27 -24
- package/popover.js +1 -1
- package/popover.pure.js +1 -1
- package/safety-theme.css +33 -134
- package/scrollbar.css +33 -97
- package/select/select.component.js +1 -1
- package/{select.component-Bhvd_sUV.js → select.component-BXPU7X_X.js} +1 -1
- package/select.js +1 -1
- package/select.pure.js +1 -1
- package/sidebar/sidebar/sidebar.component.js +1 -1
- package/{sidebar.component-Dpf9jZ1P.js → sidebar.component-CeUPJaqy.js} +28 -21
- package/sidebar.js +1 -1
- package/sidebar.pure.js +1 -1
- package/standard-theme.css +33 -134
- package/styles-Cb4jdMeE.js +5 -0
- package/table/table-wrapper/table-wrapper.component.js +1 -1
- package/{table-wrapper.component-DGL8RaxF.js → table-wrapper.component-CZ90q3pY.js} +1 -1
- package/table.js +1 -1
- package/table.pure.js +1 -1
- package/development/file-selector-common-BwkZZzA0.js +0 -409
- package/development/map-container.component-BLF21LG7.js +0 -173
- package/development/menu.component-BpKGNICN.js +0 -365
- package/development/navigation-section.component-DumXFFfg.js +0 -346
- package/development/navigation.component-CpoBEP55.js +0 -315
- package/development/overlay.component-CC_quHYI.js +0 -206
- package/development/popover.component-DT-cfDqo.js +0 -561
- package/development/sidebar.component-DR2JGwnM.js +0 -349
- package/development/styles-6T7UvhxK.js +0 -18
- package/development/table-wrapper.component-CjMOENHV.js +0 -119
- package/overlay.component-B00EoAd5.js +0 -156
- package/styles-D5okOWF1.js +0 -5
|
@@ -0,0 +1,417 @@
|
|
|
1
|
+
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
|
+
import { nothing, unsafeCSS } from "lit";
|
|
3
|
+
import { property } from "lit/decorators.js";
|
|
4
|
+
import { SbbDisabledMixin, SbbFormAssociatedMixin, SbbLanguageController, boxSizingStyles, forceType, forwardEvent, i18nFileSelectorButtonLabel, i18nFileSelectorButtonLabelMultiple, i18nFileSelectorCurrentlySelected, i18nFileSelectorDeleteFile, isLean, sbbInputModalityDetector, screenReaderOnlyStyles, ɵ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
|
+
//#region src/elements/file-selector/common/file-selector-common.scss?inline
|
|
9
|
+
var file_selector_common_default = ":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__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}";
|
|
10
|
+
//#endregion
|
|
11
|
+
//#region src/elements/file-selector/common/file-selector-common.ts
|
|
12
|
+
var SbbFileSelectorCommonElementMixin = (superclass) => {
|
|
13
|
+
return (() => {
|
|
14
|
+
let _classSuper = SbbDisabledMixin(SbbFormAssociatedMixin(superclass));
|
|
15
|
+
let _instanceExtraInitializers = [];
|
|
16
|
+
let _size_decorators;
|
|
17
|
+
let _size_initializers = [];
|
|
18
|
+
let _size_extraInitializers = [];
|
|
19
|
+
let _multiple_decorators;
|
|
20
|
+
let _multiple_initializers = [];
|
|
21
|
+
let _multiple_extraInitializers = [];
|
|
22
|
+
let _multipleMode_decorators;
|
|
23
|
+
let _multipleMode_initializers = [];
|
|
24
|
+
let _multipleMode_extraInitializers = [];
|
|
25
|
+
let _accept_decorators;
|
|
26
|
+
let _accept_initializers = [];
|
|
27
|
+
let _accept_extraInitializers = [];
|
|
28
|
+
let _accessibilityLabel_decorators;
|
|
29
|
+
let _accessibilityLabel_initializers = [];
|
|
30
|
+
let _accessibilityLabel_extraInitializers = [];
|
|
31
|
+
let _set_value_decorators;
|
|
32
|
+
let _set_files_decorators;
|
|
33
|
+
return class SbbFileSelectorCommonElement extends _classSuper {
|
|
34
|
+
constructor() {
|
|
35
|
+
super(...arguments);
|
|
36
|
+
this.#size_accessor_storage = (__runInitializers(this, _instanceExtraInitializers), __runInitializers(this, _size_initializers, isLean() ? "s" : "m"));
|
|
37
|
+
this.#multiple_accessor_storage = (__runInitializers(this, _size_extraInitializers), __runInitializers(this, _multiple_initializers, false));
|
|
38
|
+
this.#multipleMode_accessor_storage = (__runInitializers(this, _multiple_extraInitializers), __runInitializers(this, _multipleMode_initializers, "default"));
|
|
39
|
+
this.#accept_accessor_storage = (__runInitializers(this, _multipleMode_extraInitializers), __runInitializers(this, _accept_initializers, ""));
|
|
40
|
+
this.#accessibilityLabel_accessor_storage = (__runInitializers(this, _accept_extraInitializers), __runInitializers(this, _accessibilityLabel_initializers, ""));
|
|
41
|
+
this._files = (__runInitializers(this, _accessibilityLabel_extraInitializers), []);
|
|
42
|
+
this._suffixes = [
|
|
43
|
+
"B",
|
|
44
|
+
"kB",
|
|
45
|
+
"MB",
|
|
46
|
+
"GB",
|
|
47
|
+
"TB"
|
|
48
|
+
];
|
|
49
|
+
this.language = new SbbLanguageController(this);
|
|
50
|
+
this._counter = 0;
|
|
51
|
+
}
|
|
52
|
+
static {
|
|
53
|
+
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
54
|
+
_size_decorators = [property({ reflect: true })];
|
|
55
|
+
_multiple_decorators = [forceType(), property({ type: Boolean })];
|
|
56
|
+
_multipleMode_decorators = [property({ attribute: "multiple-mode" })];
|
|
57
|
+
_accept_decorators = [forceType(), property()];
|
|
58
|
+
_accessibilityLabel_decorators = [forceType(), property({ attribute: "accessibility-label" })];
|
|
59
|
+
_set_value_decorators = [property({ attribute: false })];
|
|
60
|
+
_set_files_decorators = [property({ attribute: false })];
|
|
61
|
+
__esDecorate(this, null, _size_decorators, {
|
|
62
|
+
kind: "accessor",
|
|
63
|
+
name: "size",
|
|
64
|
+
static: false,
|
|
65
|
+
private: false,
|
|
66
|
+
access: {
|
|
67
|
+
has: (obj) => "size" in obj,
|
|
68
|
+
get: (obj) => obj.size,
|
|
69
|
+
set: (obj, value) => {
|
|
70
|
+
obj.size = value;
|
|
71
|
+
}
|
|
72
|
+
},
|
|
73
|
+
metadata: _metadata
|
|
74
|
+
}, _size_initializers, _size_extraInitializers);
|
|
75
|
+
__esDecorate(this, null, _multiple_decorators, {
|
|
76
|
+
kind: "accessor",
|
|
77
|
+
name: "multiple",
|
|
78
|
+
static: false,
|
|
79
|
+
private: false,
|
|
80
|
+
access: {
|
|
81
|
+
has: (obj) => "multiple" in obj,
|
|
82
|
+
get: (obj) => obj.multiple,
|
|
83
|
+
set: (obj, value) => {
|
|
84
|
+
obj.multiple = value;
|
|
85
|
+
}
|
|
86
|
+
},
|
|
87
|
+
metadata: _metadata
|
|
88
|
+
}, _multiple_initializers, _multiple_extraInitializers);
|
|
89
|
+
__esDecorate(this, null, _multipleMode_decorators, {
|
|
90
|
+
kind: "accessor",
|
|
91
|
+
name: "multipleMode",
|
|
92
|
+
static: false,
|
|
93
|
+
private: false,
|
|
94
|
+
access: {
|
|
95
|
+
has: (obj) => "multipleMode" in obj,
|
|
96
|
+
get: (obj) => obj.multipleMode,
|
|
97
|
+
set: (obj, value) => {
|
|
98
|
+
obj.multipleMode = value;
|
|
99
|
+
}
|
|
100
|
+
},
|
|
101
|
+
metadata: _metadata
|
|
102
|
+
}, _multipleMode_initializers, _multipleMode_extraInitializers);
|
|
103
|
+
__esDecorate(this, null, _accept_decorators, {
|
|
104
|
+
kind: "accessor",
|
|
105
|
+
name: "accept",
|
|
106
|
+
static: false,
|
|
107
|
+
private: false,
|
|
108
|
+
access: {
|
|
109
|
+
has: (obj) => "accept" in obj,
|
|
110
|
+
get: (obj) => obj.accept,
|
|
111
|
+
set: (obj, value) => {
|
|
112
|
+
obj.accept = value;
|
|
113
|
+
}
|
|
114
|
+
},
|
|
115
|
+
metadata: _metadata
|
|
116
|
+
}, _accept_initializers, _accept_extraInitializers);
|
|
117
|
+
__esDecorate(this, null, _accessibilityLabel_decorators, {
|
|
118
|
+
kind: "accessor",
|
|
119
|
+
name: "accessibilityLabel",
|
|
120
|
+
static: false,
|
|
121
|
+
private: false,
|
|
122
|
+
access: {
|
|
123
|
+
has: (obj) => "accessibilityLabel" in obj,
|
|
124
|
+
get: (obj) => obj.accessibilityLabel,
|
|
125
|
+
set: (obj, value) => {
|
|
126
|
+
obj.accessibilityLabel = value;
|
|
127
|
+
}
|
|
128
|
+
},
|
|
129
|
+
metadata: _metadata
|
|
130
|
+
}, _accessibilityLabel_initializers, _accessibilityLabel_extraInitializers);
|
|
131
|
+
__esDecorate(this, null, _set_value_decorators, {
|
|
132
|
+
kind: "setter",
|
|
133
|
+
name: "value",
|
|
134
|
+
static: false,
|
|
135
|
+
private: false,
|
|
136
|
+
access: {
|
|
137
|
+
has: (obj) => "value" in obj,
|
|
138
|
+
set: (obj, value) => {
|
|
139
|
+
obj.value = value;
|
|
140
|
+
}
|
|
141
|
+
},
|
|
142
|
+
metadata: _metadata
|
|
143
|
+
}, null, _instanceExtraInitializers);
|
|
144
|
+
__esDecorate(this, null, _set_files_decorators, {
|
|
145
|
+
kind: "setter",
|
|
146
|
+
name: "files",
|
|
147
|
+
static: false,
|
|
148
|
+
private: false,
|
|
149
|
+
access: {
|
|
150
|
+
has: (obj) => "files" in obj,
|
|
151
|
+
set: (obj, value) => {
|
|
152
|
+
obj.files = value;
|
|
153
|
+
}
|
|
154
|
+
},
|
|
155
|
+
metadata: _metadata
|
|
156
|
+
}, null, _instanceExtraInitializers);
|
|
157
|
+
if (_metadata) Object.defineProperty(this, Symbol.metadata, {
|
|
158
|
+
enumerable: true,
|
|
159
|
+
configurable: true,
|
|
160
|
+
writable: true,
|
|
161
|
+
value: _metadata
|
|
162
|
+
});
|
|
163
|
+
}
|
|
164
|
+
static {
|
|
165
|
+
this.elementDependencies = [SbbSecondaryButtonElement];
|
|
166
|
+
}
|
|
167
|
+
static {
|
|
168
|
+
this.events = { filechanged: "filechanged" };
|
|
169
|
+
}
|
|
170
|
+
static {
|
|
171
|
+
this.styles = [
|
|
172
|
+
boxSizingStyles,
|
|
173
|
+
screenReaderOnlyStyles,
|
|
174
|
+
unsafeCSS(file_selector_common_default)
|
|
175
|
+
];
|
|
176
|
+
}
|
|
177
|
+
#size_accessor_storage;
|
|
178
|
+
/**
|
|
179
|
+
* Size variant, either s or m.
|
|
180
|
+
* @default 'm' / 's' (lean)
|
|
181
|
+
*/
|
|
182
|
+
get size() {
|
|
183
|
+
return this.#size_accessor_storage;
|
|
184
|
+
}
|
|
185
|
+
set size(value) {
|
|
186
|
+
this.#size_accessor_storage = value;
|
|
187
|
+
}
|
|
188
|
+
#multiple_accessor_storage;
|
|
189
|
+
/** Whether more than one file can be selected. */
|
|
190
|
+
get multiple() {
|
|
191
|
+
return this.#multiple_accessor_storage;
|
|
192
|
+
}
|
|
193
|
+
set multiple(value) {
|
|
194
|
+
this.#multiple_accessor_storage = value;
|
|
195
|
+
}
|
|
196
|
+
#multipleMode_accessor_storage;
|
|
197
|
+
/** Whether the newly added files should override the previously added ones. */
|
|
198
|
+
get multipleMode() {
|
|
199
|
+
return this.#multipleMode_accessor_storage;
|
|
200
|
+
}
|
|
201
|
+
set multipleMode(value) {
|
|
202
|
+
this.#multipleMode_accessor_storage = value;
|
|
203
|
+
}
|
|
204
|
+
#accept_accessor_storage;
|
|
205
|
+
/** A comma-separated list of allowed unique file type specifiers. */
|
|
206
|
+
get accept() {
|
|
207
|
+
return this.#accept_accessor_storage;
|
|
208
|
+
}
|
|
209
|
+
set accept(value) {
|
|
210
|
+
this.#accept_accessor_storage = value;
|
|
211
|
+
}
|
|
212
|
+
#accessibilityLabel_accessor_storage;
|
|
213
|
+
/** This will be forwarded as aria-label to the native input element. */
|
|
214
|
+
get accessibilityLabel() {
|
|
215
|
+
return this.#accessibilityLabel_accessor_storage;
|
|
216
|
+
}
|
|
217
|
+
set accessibilityLabel(value) {
|
|
218
|
+
this.#accessibilityLabel_accessor_storage = value;
|
|
219
|
+
}
|
|
220
|
+
/** The path of the first selected file. Empty string ('') if no file is selected */
|
|
221
|
+
set value(value) {
|
|
222
|
+
this._hiddenInput.value = value ?? "";
|
|
223
|
+
if (!value) this.files = [];
|
|
224
|
+
}
|
|
225
|
+
get value() {
|
|
226
|
+
return this._hiddenInput?.value;
|
|
227
|
+
}
|
|
228
|
+
/** The list of selected files. */
|
|
229
|
+
set files(value) {
|
|
230
|
+
this._files = value ?? [];
|
|
231
|
+
const dt = new DataTransfer();
|
|
232
|
+
this.files.forEach((e) => dt.items.add(e));
|
|
233
|
+
this._hiddenInput.files = dt.files;
|
|
234
|
+
this.updateFormValue();
|
|
235
|
+
}
|
|
236
|
+
get files() {
|
|
237
|
+
return this._files;
|
|
238
|
+
}
|
|
239
|
+
/**
|
|
240
|
+
* Form type of element.
|
|
241
|
+
* @default 'file'
|
|
242
|
+
*/
|
|
243
|
+
get type() {
|
|
244
|
+
return "file";
|
|
245
|
+
}
|
|
246
|
+
formResetCallback() {
|
|
247
|
+
this.files = [];
|
|
248
|
+
}
|
|
249
|
+
formStateRestoreCallback(state, _reason) {
|
|
250
|
+
if (!state) return;
|
|
251
|
+
this.files = state.getAll(this.name);
|
|
252
|
+
}
|
|
253
|
+
updateFormValue() {
|
|
254
|
+
const formValue = new FormData();
|
|
255
|
+
this.files.forEach((file) => formValue.append(this.name, file));
|
|
256
|
+
this.internals.setFormValue(formValue);
|
|
257
|
+
}
|
|
258
|
+
_checkFileEquality(file1, file2) {
|
|
259
|
+
return file1.name === file2.name && file1.size === file2.size && file1.lastModified === file2.lastModified;
|
|
260
|
+
}
|
|
261
|
+
_onFocus() {
|
|
262
|
+
if (sbbInputModalityDetector.mostRecentModality === "keyboard") ɵstateController(this.loadButton).add("focus-visible");
|
|
263
|
+
}
|
|
264
|
+
_onBlur() {
|
|
265
|
+
ɵstateController(this.loadButton).delete("focus-visible");
|
|
266
|
+
}
|
|
267
|
+
_readFiles(event) {
|
|
268
|
+
const fileInput = event.target;
|
|
269
|
+
if (fileInput.files) this.createFileList(fileInput.files);
|
|
270
|
+
forwardEvent(event, this);
|
|
271
|
+
}
|
|
272
|
+
createFileList(files) {
|
|
273
|
+
const fileArray = Array.from(files);
|
|
274
|
+
if (!this.multiple && files.length > 1 || this.accept && fileArray.some((file) => !this.accept.split(",").some((a) => file.name.endsWith(a.trim())))) return;
|
|
275
|
+
if (!this.multiple || this.multipleMode !== "persistent" || this.files.length === 0) this.files = fileArray;
|
|
276
|
+
else this.files = fileArray.filter((newFile) => this.files.findIndex((oldFile) => this._checkFileEquality(newFile, oldFile)) === -1).concat(this.files);
|
|
277
|
+
this._updateA11yLiveRegion();
|
|
278
|
+
this._dispatchFileChangedEvent();
|
|
279
|
+
}
|
|
280
|
+
getButtonLabel() {
|
|
281
|
+
return this.multiple ? i18nFileSelectorButtonLabelMultiple[this.language.current] : i18nFileSelectorButtonLabel[this.language.current];
|
|
282
|
+
}
|
|
283
|
+
_removeFile(file) {
|
|
284
|
+
this.files = this.files.filter((f) => !this._checkFileEquality(file, f));
|
|
285
|
+
this._updateA11yLiveRegion();
|
|
286
|
+
/** The input event fires when the value has been changed as a direct result of a user action. */
|
|
287
|
+
this.dispatchEvent(new InputEvent("input", {
|
|
288
|
+
bubbles: true,
|
|
289
|
+
composed: true
|
|
290
|
+
}));
|
|
291
|
+
/**
|
|
292
|
+
* The change event is fired when the user modifies the element's value.
|
|
293
|
+
* Unlike the input event, the change event is not necessarily fired
|
|
294
|
+
* for each alteration to an element's value.
|
|
295
|
+
*/
|
|
296
|
+
this.dispatchEvent(new Event("change", { bubbles: true }));
|
|
297
|
+
this._dispatchFileChangedEvent();
|
|
298
|
+
}
|
|
299
|
+
_dispatchFileChangedEvent() {
|
|
300
|
+
/**
|
|
301
|
+
* @type {CustomEvent<Readonly<File>[]>}
|
|
302
|
+
* An event which is emitted each time the file list changes.
|
|
303
|
+
*/
|
|
304
|
+
this.dispatchEvent(new CustomEvent("filechanged", {
|
|
305
|
+
bubbles: true,
|
|
306
|
+
composed: true,
|
|
307
|
+
detail: this.files
|
|
308
|
+
}));
|
|
309
|
+
}
|
|
310
|
+
/** Calculates the correct unit for the file's size. */
|
|
311
|
+
_formatFileSize(size) {
|
|
312
|
+
const i = Math.floor(Math.log(size) / Math.log(1024));
|
|
313
|
+
return `${(size / Math.pow(1024, i)).toFixed(0)} ${this._suffixes[i]}`;
|
|
314
|
+
}
|
|
315
|
+
_updateA11yLiveRegion() {
|
|
316
|
+
this._liveRegion.innerText = i18nFileSelectorCurrentlySelected(this.files.map((e) => e.name))[this.language.current];
|
|
317
|
+
}
|
|
318
|
+
_renderFileList() {
|
|
319
|
+
const TAG_NAME = this.files.length > 1 ? {
|
|
320
|
+
WRAPPER: "ul",
|
|
321
|
+
ELEMENT: "li"
|
|
322
|
+
} : {
|
|
323
|
+
WRAPPER: "div",
|
|
324
|
+
ELEMENT: "span"
|
|
325
|
+
};
|
|
326
|
+
return html$1`
|
|
327
|
+
<${unsafeStatic(TAG_NAME.WRAPPER)} class="sbb-file-selector__file-list">
|
|
328
|
+
${this.files.map((file) => html$1`
|
|
329
|
+
<${unsafeStatic(TAG_NAME.ELEMENT)} class="sbb-file-selector__file">
|
|
330
|
+
<span class="sbb-file-selector__file-details">
|
|
331
|
+
<span class="sbb-file-selector__file-name">${file.name}</span>
|
|
332
|
+
<span class="sbb-file-selector__file-size">${this._formatFileSize(file.size)}</span>
|
|
333
|
+
</span>
|
|
334
|
+
<sbb-secondary-button
|
|
335
|
+
size=${this.size}
|
|
336
|
+
icon-name="trash-small"
|
|
337
|
+
@click=${() => this._removeFile(file)}
|
|
338
|
+
aria-label=${`${i18nFileSelectorDeleteFile[this.language.current]} - ${file.name}`}
|
|
339
|
+
></sbb-secondary-button>
|
|
340
|
+
</${unsafeStatic(TAG_NAME.ELEMENT)}>`)}
|
|
341
|
+
</${unsafeStatic(TAG_NAME.WRAPPER)}>
|
|
342
|
+
`;
|
|
343
|
+
}
|
|
344
|
+
_onDragEnter(event) {
|
|
345
|
+
this._counter++;
|
|
346
|
+
if (!this.disabled && !this.formDisabled) {
|
|
347
|
+
this._setDragState(event.target, true);
|
|
348
|
+
this._blockEvent(event);
|
|
349
|
+
}
|
|
350
|
+
}
|
|
351
|
+
_onDragLeave(event) {
|
|
352
|
+
this._counter--;
|
|
353
|
+
if (!this.disabled && !this.formDisabled && event.target === this._dragTarget && this._counter === 0) {
|
|
354
|
+
this._setDragState();
|
|
355
|
+
this._blockEvent(event);
|
|
356
|
+
}
|
|
357
|
+
}
|
|
358
|
+
_onFileDrop(event) {
|
|
359
|
+
this._counter = 0;
|
|
360
|
+
if (!this.disabled && !this.formDisabled) {
|
|
361
|
+
this._setDragState();
|
|
362
|
+
this._blockEvent(event);
|
|
363
|
+
this.createFileList(event.dataTransfer.files);
|
|
364
|
+
}
|
|
365
|
+
}
|
|
366
|
+
_blockEvent(event) {
|
|
367
|
+
event.stopPropagation();
|
|
368
|
+
event.preventDefault();
|
|
369
|
+
}
|
|
370
|
+
_setDragState(dragTarget = void 0, isDragEnter = false) {
|
|
371
|
+
this._dragTarget = dragTarget;
|
|
372
|
+
this.toggleState("active", isDragEnter);
|
|
373
|
+
ɵstateController(this.loadButton).toggle("active", isDragEnter);
|
|
374
|
+
}
|
|
375
|
+
render() {
|
|
376
|
+
const ariaLabel = this.accessibilityLabel ? `${this.getButtonLabel()} - ${this.accessibilityLabel}` : void 0;
|
|
377
|
+
return html$1`
|
|
378
|
+
<div
|
|
379
|
+
class="sbb-file-selector__input-container"
|
|
380
|
+
@dragenter=${this._onDragEnter}
|
|
381
|
+
@dragover=${this._blockEvent}
|
|
382
|
+
@dragleave=${this._onDragLeave}
|
|
383
|
+
@drop=${this._onFileDrop}
|
|
384
|
+
>
|
|
385
|
+
${this.renderTemplate(html$1`<input
|
|
386
|
+
class="sbb-screen-reader-only"
|
|
387
|
+
type="file"
|
|
388
|
+
?disabled=${this.disabled || this.formDisabled}
|
|
389
|
+
?multiple=${this.multiple}
|
|
390
|
+
accept=${this.accept || nothing}
|
|
391
|
+
aria-label=${ariaLabel || nothing}
|
|
392
|
+
@change=${this._readFiles}
|
|
393
|
+
@focus=${this._onFocus}
|
|
394
|
+
@blur=${this._onBlur}
|
|
395
|
+
${ref((el) => {
|
|
396
|
+
this._hiddenInput = el;
|
|
397
|
+
})}
|
|
398
|
+
/>`)}
|
|
399
|
+
</div>
|
|
400
|
+
<p
|
|
401
|
+
role="status"
|
|
402
|
+
class="sbb-screen-reader-only"
|
|
403
|
+
${ref((p) => this._liveRegion = p)}
|
|
404
|
+
></p>
|
|
405
|
+
${this.files.length > 0 ? this._renderFileList() : nothing}
|
|
406
|
+
<div class="sbb-file-selector__error">
|
|
407
|
+
<slot name="error"></slot>
|
|
408
|
+
</div>
|
|
409
|
+
`;
|
|
410
|
+
}
|
|
411
|
+
};
|
|
412
|
+
})();
|
|
413
|
+
};
|
|
414
|
+
//#endregion
|
|
415
|
+
export { SbbFileSelectorCommonElementMixin as t };
|
|
416
|
+
|
|
417
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"file-selector-common-BH_iIjcB.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__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 { type CSSResultGroup, 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  boxSizingStyles,\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  screenReaderOnlyStyles,\n  ɵstateController,\n} from '../../core.ts';\n\nimport style from './file-selector-common.scss?inline';\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    public static styles: CSSResultGroup = [\n      boxSizingStyles,\n      screenReaderOnlyStyles,\n      unsafeCSS(style),\n    ];\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-screen-reader-only\"\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-screen-reader-only\"\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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"}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import { __esDecorate, __runInitializers } from "tslib";
|
|
2
2
|
import { unsafeCSS } from "lit";
|
|
3
3
|
import { property } from "lit/decorators.js";
|
|
4
|
-
import { SbbElement,
|
|
4
|
+
import { SbbElement, forceType, i18nFileSelectorSubtitleLabel, i18nFileSelectorSubtitleLabelMultiple } from "./core.js";
|
|
5
5
|
import { html as html$1 } from "lit/static-html.js";
|
|
6
6
|
import { SbbSecondaryButtonStaticElement } from "./button.pure.js";
|
|
7
7
|
import { SbbIconElement } from "./icon.pure.js";
|
|
8
8
|
import { ref } from "lit/directives/ref.js";
|
|
9
|
-
import { SbbFileSelectorCommonElementMixin
|
|
9
|
+
import { SbbFileSelectorCommonElementMixin } from "./file-selector/common/file-selector-common.js";
|
|
10
10
|
//#region src/elements/file-selector/file-selector-dropzone/file-selector-dropzone.scss?inline
|
|
11
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 font-size: var(--sbb-heading-font-size-6);\n letter-spacing: var(--sbb-typo-letter-spacing-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
12
|
//#endregion
|
|
@@ -53,11 +53,7 @@ var SbbFileSelectorDropzoneElement = (() => {
|
|
|
53
53
|
this.elementDependencies = [SbbIconElement, SbbSecondaryButtonStaticElement];
|
|
54
54
|
}
|
|
55
55
|
static {
|
|
56
|
-
this.styles = [
|
|
57
|
-
boxSizingStyles,
|
|
58
|
-
fileSelectorCommonStyle,
|
|
59
|
-
unsafeCSS(file_selector_dropzone_default)
|
|
60
|
-
];
|
|
56
|
+
this.styles = [unsafeCSS(file_selector_dropzone_default)];
|
|
61
57
|
}
|
|
62
58
|
static {
|
|
63
59
|
this.events = { filechanged: "filechanged" };
|
|
@@ -107,4 +103,4 @@ var SbbFileSelectorDropzoneElement = (() => {
|
|
|
107
103
|
//#endregion
|
|
108
104
|
export { SbbFileSelectorDropzoneElement as t };
|
|
109
105
|
|
|
110
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
106
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1zZWxlY3Rvci1kcm9wem9uZS5jb21wb25lbnQtWkNhbkx3Ri0uanMiLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2VsZW1lbnRzL2ZpbGUtc2VsZWN0b3IvZmlsZS1zZWxlY3Rvci1kcm9wem9uZS9maWxlLXNlbGVjdG9yLWRyb3B6b25lLnNjc3M/aW5saW5lIiwiLi4vLi4vLi4vc3JjL2VsZW1lbnRzL2ZpbGUtc2VsZWN0b3IvZmlsZS1zZWxlY3Rvci1kcm9wem9uZS9maWxlLXNlbGVjdG9yLWRyb3B6b25lLmNvbXBvbmVudC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJAdXNlICcuLi8uLi9jb3JlL3N0eWxlcycgYXMgc2JiO1xuXG46aG9zdChbc2l6ZT0nbSddKSB7XG4gIC0tX3NiYi1maWxlLXNlbGVjdG9yLWRyb3B6b25lLWljb24tbWVkaXVtLWRpc3BsYXk6IGJsb2NrO1xuICAtLV9zYmItZmlsZS1zZWxlY3Rvci1kcm9wem9uZS1pY29uLXNtYWxsLWRpc3BsYXk6IG5vbmU7XG59XG5cbjpob3N0KFtzaXplPSdzJ10pIHtcbiAgLS1fc2JiLWZpbGUtc2VsZWN0b3ItZHJvcHpvbmUtaWNvbi1tZWRpdW0tZGlzcGxheTogbm9uZTtcbiAgLS1fc2JiLWZpbGUtc2VsZWN0b3ItZHJvcHpvbmUtaWNvbi1zbWFsbC1kaXNwbGF5OiBibG9jaztcbn1cblxuLnNiYi1maWxlLXNlbGVjdG9yX19kcm9wem9uZS1hcmVhIHtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgcGFkZGluZzogdmFyKC0tc2JiLXNwYWNpbmctcmVzcG9uc2l2ZS1zKTtcbiAgYmFja2dyb3VuZC1jb2xvcjogdmFyKC0tc2JiLWZpbGUtc2VsZWN0b3ItYmFja2dyb3VuZC1jb2xvcik7XG4gIGJvcmRlcjogdmFyKC0tc2JiLWJvcmRlci13aWR0aC0xeCkgZGFzaGVkIHZhcigtLXNiYi1maWxlLXNlbGVjdG9yLWJvcmRlci1jb2xvcik7XG4gIGJvcmRlci1yYWRpdXM6IHZhcigtLXNiYi1ib3JkZXItcmFkaXVzLTR4KTtcbiAgdHJhbnNpdGlvbi1kdXJhdGlvbjogdmFyKC0tc2JiLWZpbGUtc2VsZWN0b3ItdHJhbnNpdGlvbi1kdXJhdGlvbik7XG4gIHRyYW5zaXRpb24tdGltaW5nLWZ1bmN0aW9uOiB2YXIoLS1zYmItZmlsZS1zZWxlY3Rvci10cmFuc2l0aW9uLWVhc2luZy1mdW5jdGlvbik7XG4gIHRyYW5zaXRpb24tcHJvcGVydHk6IGJhY2tncm91bmQtY29sb3IsIGJvcmRlci1jb2xvcjtcbn1cblxuLnNiYi1maWxlLXNlbGVjdG9yX19kcm9wem9uZS1hcmVhLS1pY29uIHtcbiAgY29sb3I6IHZhcigtLXNiYi1maWxlLXNlbGVjdG9yLWNvbG9yKTtcbiAgbGluZS1oZWlnaHQ6IDA7XG5cbiAgc2JiLWljb25bbmFtZT0nZm9sZGVyLW9wZW4tbWVkaXVtJ10ge1xuICAgIGRpc3BsYXk6IHZhcigtLV9zYmItZmlsZS1zZWxlY3Rvci1kcm9wem9uZS1pY29uLW1lZGl1bS1kaXNwbGF5KTtcbiAgfVxuXG4gIHNiYi1pY29uW25hbWU9J2ZvbGRlci1vcGVuLXNtYWxsJ10ge1xuICAgIGRpc3BsYXk6IHZhcigtLV9zYmItZmlsZS1zZWxlY3Rvci1kcm9wem9uZS1pY29uLXNtYWxsLWRpc3BsYXkpO1xuICB9XG59XG5cbi5zYmItZmlsZS1zZWxlY3Rvcl9fZHJvcHpvbmUtYXJlYS0tdGl0bGUge1xuICBmb250LXdlaWdodDogYm9sZDtcbiAgZm9udC1zaXplOiB2YXIoLS1zYmItaGVhZGluZy1mb250LXNpemUtNik7XG4gIGxldHRlci1zcGFjaW5nOiB2YXIoLS1zYmItdHlwby1sZXR0ZXItc3BhY2luZy1oZWFkaW5nKTtcbiAgdGV4dC1hbGlnbjogY2VudGVyO1xuICBjb2xvcjogdmFyKC0tc2JiLWZpbGUtc2VsZWN0b3ItY29sb3IpO1xufVxuXG4uc2JiLWZpbGUtc2VsZWN0b3JfX2Ryb3B6b25lLWFyZWEtLXN1YnRpdGxlIHtcbiAgQGluY2x1ZGUgc2JiLnRleHQteHMtLXJlZ3VsYXI7XG5cbiAgdGV4dC1hbGlnbjogY2VudGVyO1xuICBjb2xvcjogdmFyKC0tc2JiLWZpbGUtc2VsZWN0b3Itc3VidGl0bGUtY29sb3IpO1xuICBtYXJnaW4tYmxvY2stZW5kOiB2YXIoLS1zYmItc3BhY2luZy1maXhlZC00eCk7XG59XG4iLCJpbXBvcnQgeyB0eXBlIENTU1Jlc3VsdEdyb3VwLCB0eXBlIFRlbXBsYXRlUmVzdWx0LCB1bnNhZmVDU1MgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgcHJvcGVydHkgfSBmcm9tICdsaXQvZGVjb3JhdG9ycy5qcyc7XG5pbXBvcnQgeyByZWYgfSBmcm9tICdsaXQvZGlyZWN0aXZlcy9yZWYuanMnO1xuaW1wb3J0IHsgaHRtbCB9IGZyb20gJ2xpdC9zdGF0aWMtaHRtbC5qcyc7XG5cbmltcG9ydCB7IFNiYlNlY29uZGFyeUJ1dHRvblN0YXRpY0VsZW1lbnQgfSBmcm9tICcuLi8uLi9idXR0b24ucHVyZS50cyc7XG5pbXBvcnQge1xuICBmb3JjZVR5cGUsXG4gIGkxOG5GaWxlU2VsZWN0b3JTdWJ0aXRsZUxhYmVsLFxuICBpMThuRmlsZVNlbGVjdG9yU3VidGl0bGVMYWJlbE11bHRpcGxlLFxuICBTYmJFbGVtZW50LFxuICB0eXBlIFNiYkVsZW1lbnRUeXBlLFxufSBmcm9tICcuLi8uLi9jb3JlLnRzJztcbmltcG9ydCB7IFNiYkljb25FbGVtZW50IH0gZnJvbSAnLi4vLi4vaWNvbi5wdXJlLnRzJztcbmltcG9ydCB7IFNiYkZpbGVTZWxlY3RvckNvbW1vbkVsZW1lbnRNaXhpbiB9IGZyb20gJy4uL2NvbW1vbi9maWxlLXNlbGVjdG9yLWNvbW1vbi50cyc7XG5cbmltcG9ydCBzdHlsZSBmcm9tICcuL2ZpbGUtc2VsZWN0b3ItZHJvcHpvbmUuc2Nzcz9pbmxpbmUnO1xuXG4vKipcbiAqIEl0IGFsbG93cyB0byBzZWxlY3Qgb25lIG9yIG1vcmUgZmlsZSBmcm9tIHN0b3JhZ2UgZGV2aWNlcyB2aWEgYnV0dG9uIGNsaWNrIG9yIGRyYWcgYW5kIGRyb3AsIGFuZCBkaXNwbGF5IHRoZW0uXG4gKlxuICogQHNsb3QgZXJyb3IgLSBVc2UgdGhpcyB0byBwcm92aWRlIGEgYHNiYi1lcnJvcmAgdG8gc2hvdyBhbiBlcnJvciBtZXNzYWdlLlxuICovXG5leHBvcnQgY2xhc3MgU2JiRmlsZVNlbGVjdG9yRHJvcHpvbmVFbGVtZW50IGV4dGVuZHMgU2JiRmlsZVNlbGVjdG9yQ29tbW9uRWxlbWVudE1peGluKFNiYkVsZW1lbnQpIHtcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSByZWFkb25seSBlbGVtZW50TmFtZTogc3RyaW5nID0gJ3NiYi1maWxlLXNlbGVjdG9yLWRyb3B6b25lJztcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSBlbGVtZW50RGVwZW5kZW5jaWVzOiBTYmJFbGVtZW50VHlwZVtdID0gW1xuICAgIFNiYkljb25FbGVtZW50LFxuICAgIFNiYlNlY29uZGFyeUJ1dHRvblN0YXRpY0VsZW1lbnQsXG4gIF07XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IFt1bnNhZmVDU1Moc3R5bGUpXTtcbiAgcHVibGljIHN0YXRpYyByZWFkb25seSBldmVudHMgPSB7XG4gICAgZmlsZWNoYW5nZWQ6ICdmaWxlY2hhbmdlZCcsXG4gIH0gYXMgY29uc3Q7XG5cbiAgLyoqIFRoZSB0aXRsZSBkaXNwbGF5ZWQgaW4gYGRyb3B6b25lYCB2YXJpYW50LiAqL1xuICBAZm9yY2VUeXBlKClcbiAgQHByb3BlcnR5KHsgYXR0cmlidXRlOiAndGl0bGUtY29udGVudCcgfSlcbiAgcHVibGljIGFjY2Vzc29yIHRpdGxlQ29udGVudDogc3RyaW5nID0gJyc7XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlclRlbXBsYXRlKGlucHV0OiBUZW1wbGF0ZVJlc3VsdCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGBcbiAgICAgIDxsYWJlbD5cbiAgICAgICAgPHNwYW4gY2xhc3M9XCJzYmItZmlsZS1zZWxlY3Rvcl9fZHJvcHpvbmUtYXJlYVwiPlxuICAgICAgICAgIDxzcGFuIGNsYXNzPVwic2JiLWZpbGUtc2VsZWN0b3JfX2Ryb3B6b25lLWFyZWEtLWljb25cIj5cbiAgICAgICAgICAgIDxzYmItaWNvbiBuYW1lPVwiZm9sZGVyLW9wZW4tbWVkaXVtXCI+PC9zYmItaWNvbj5cbiAgICAgICAgICAgIDxzYmItaWNvbiBuYW1lPVwiZm9sZGVyLW9wZW4tc21hbGxcIj48L3NiYi1pY29uPlxuICAgICAgICAgIDwvc3Bhbj5cbiAgICAgICAgICA8c3BhbiBjbGFzcz1cInNiYi1maWxlLXNlbGVjdG9yX19kcm9wem9uZS1hcmVhLS10aXRsZVwiPiR7dGhpcy50aXRsZUNvbnRlbnR9PC9zcGFuPlxuICAgICAgICAgIDxzcGFuIGNsYXNzPVwic2JiLWZpbGUtc2VsZWN0b3JfX2Ryb3B6b25lLWFyZWEtLXN1YnRpdGxlXCI+XG4gICAgICAgICAgICAke3RoaXMubXVsdGlwbGVcbiAgICAgICAgICAgICAgPyBpMThuRmlsZVNlbGVjdG9yU3VidGl0bGVMYWJlbE11bHRpcGxlW3RoaXMubGFuZ3VhZ2UuY3VycmVudF1cbiAgICAgICAgICAgICAgOiBpMThuRmlsZVNlbGVjdG9yU3VidGl0bGVMYWJlbFt0aGlzLmxhbmd1YWdlLmN1cnJlbnRdfVxuICAgICAgICAgIDwvc3Bhbj5cbiAgICAgICAgICA8c3BhbiBjbGFzcz1cInNiYi1maWxlLXNlbGVjdG9yX19kcm9wem9uZS1hcmVhLS1idXR0b25cIj5cbiAgICAgICAgICAgIDxzYmItc2Vjb25kYXJ5LWJ1dHRvbi1zdGF0aWNcbiAgICAgICAgICAgICAgc2l6ZT0ke3RoaXMuc2l6ZX1cbiAgICAgICAgICAgICAgP2Rpc2FibGVkPSR7dGhpcy5kaXNhYmxlZCB8fCB0aGlzLmZvcm1EaXNhYmxlZH1cbiAgICAgICAgICAgICAgJHtyZWYoKGVsPzogRWxlbWVudCk6IHZvaWQgPT4ge1xuICAgICAgICAgICAgICAgIHRoaXMubG9hZEJ1dHRvbiA9IGVsIGFzIFNiYlNlY29uZGFyeUJ1dHRvblN0YXRpY0VsZW1lbnQ7XG4gICAgICAgICAgICAgIH0pfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAke3RoaXMuZ2V0QnV0dG9uTGFiZWwoKX1cbiAgICAgICAgICAgIDwvc2JiLXNlY29uZGFyeS1idXR0b24tc3RhdGljPlxuICAgICAgICAgIDwvc3Bhbj5cbiAgICAgICAgPC9zcGFuPlxuICAgICAgICAke2lucHV0fVxuICAgICAgPC9sYWJlbD5cbiAgICBgO1xuICB9XG59XG5cbmRlY2xhcmUgZ2xvYmFsIHtcbiAgaW50ZXJmYWNlIEhUTUxFbGVtZW50VGFnTmFtZU1hcCB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvblxuICAgICdzYmItZmlsZS1zZWxlY3Rvci1kcm9wem9uZSc6IFNiYkZpbGVTZWxlY3RvckRyb3B6b25lRWxlbWVudDtcbiAgfVxufVxuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7SUN1QmEsd0NBQThCO21CQUFTLGtDQUFrQyxXQUFXOzs7O2NBQXBGLHVDQUF1QyxZQUE2Qzs7OytCQVk5RixXQUFXLEVBQ1gsU0FBUyxFQUFFLFdBQVcsaUJBQWlCLENBQUMsQ0FBQTtBQUN6QyxnQkFBQSxNQUFBLE1BQUEsMEJBQUE7SUFBQSxNQUFBO0lBQUEsTUFBQTtJQUFBLFFBQUE7SUFBQSxTQUFBO0lBQUEsUUFBQTtLQUFBLE1BQUEsUUFBQSxrQkFBQTtLQUFBLE1BQUEsUUFBQSxJQUFnQjtLQUFZLE1BQUEsS0FBQSxVQUFBO0FBQUEsVUFBWixlQUFZOztLQUFBO0lBQUEsVUFBQTtJQUFBLEVBQUEsNEJBQUEsZ0NBQUE7Ozs7Ozs7OztBQWJJLFFBQUEsY0FBc0I7OztBQUMvQixRQUFBLHNCQUF3QyxDQUM3RCxnQkFDQSxnQ0FDRDs7O0FBQ3NCLFFBQUEsU0FBeUIsQ0FBQyxVQUFVLCtCQUFNLENBQUM7OztBQUMzQyxRQUFBLFNBQVMsRUFDOUIsYUFBYSxlQUNMOztFQUtWLGlDQUFBLGtCQUFBLE1BQUEsNEJBQXVDLEdBQUU7O0VBQXpDLElBQWdCLGVBQVk7QUFBQSxVQUFBLE1BQUE7O0VBQTVCLElBQWdCLGFBQVksT0FBQTtBQUFBLFNBQUEsZ0NBQUE7O0VBRVQsZUFBZSxPQUFxQjtBQUNyRCxVQUFPLE1BQUk7Ozs7Ozs7a0VBT21ELEtBQUssYUFBWTs7Y0FFckUsS0FBSyxXQUNILHNDQUFzQyxLQUFLLFNBQVMsV0FDcEQsOEJBQThCLEtBQUssU0FBUyxTQUFBOzs7O3FCQUl2QyxLQUFLLEtBQUE7MEJBQ0EsS0FBSyxZQUFZLEtBQUssYUFBQTtnQkFDaEMsS0FBSyxPQUFzQjtBQUMzQixTQUFLLGFBQWE7S0FDbEIsQ0FBQTs7Z0JBRUEsS0FBSyxnQkFBZ0IsQ0FBQTs7OztVQUkzQixNQUFBIn0=
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { t as SbbFileSelectorDropzoneElement } from "./file-selector-dropzone.component-
|
|
1
|
+
import { t as SbbFileSelectorCommonElementMixin } from "./file-selector-common-BH_iIjcB.js";
|
|
2
|
+
import { t as SbbFileSelectorDropzoneElement } from "./file-selector-dropzone.component-ZCanLwF-.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
|
|
@@ -7,6 +7,6 @@ import "./file-selector.pure.js";
|
|
|
7
7
|
SbbFileSelectorElement.define();
|
|
8
8
|
SbbFileSelectorDropzoneElement.define();
|
|
9
9
|
//#endregion
|
|
10
|
-
export { SbbFileSelectorCommonElementMixin, SbbFileSelectorDropzoneElement, SbbFileSelectorElement
|
|
10
|
+
export { SbbFileSelectorCommonElementMixin, SbbFileSelectorDropzoneElement, SbbFileSelectorElement };
|
|
11
11
|
|
|
12
12
|
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1zZWxlY3Rvci5qcyIsIm5hbWVzIjpbXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZWxlbWVudHMvZmlsZS1zZWxlY3Rvci50cyJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQGVudHJ5cG9pbnQgKi9cbmltcG9ydCB7IFNiYkZpbGVTZWxlY3RvckRyb3B6b25lRWxlbWVudCwgU2JiRmlsZVNlbGVjdG9yRWxlbWVudCB9IGZyb20gJy4vZmlsZS1zZWxlY3Rvci5wdXJlLnRzJztcblxuZXhwb3J0ICogZnJvbSAnLi9maWxlLXNlbGVjdG9yLnB1cmUudHMnO1xuXG5TYmJGaWxlU2VsZWN0b3JFbGVtZW50LmRlZmluZSgpO1xuU2JiRmlsZVNlbGVjdG9yRHJvcHpvbmVFbGVtZW50LmRlZmluZSgpO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFLQSx1QkFBdUIsUUFBUTtBQUMvQiwrQkFBK0IsUUFBUSJ9
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { t as SbbFileSelectorDropzoneElement } from "./file-selector-dropzone.component-
|
|
1
|
+
import { t as SbbFileSelectorCommonElementMixin } from "./file-selector-common-BH_iIjcB.js";
|
|
2
|
+
import { t as SbbFileSelectorDropzoneElement } from "./file-selector-dropzone.component-ZCanLwF-.js";
|
|
3
3
|
import { SbbFileSelectorElement } from "./file-selector/file-selector/file-selector.component.js";
|
|
4
|
-
export { SbbFileSelectorCommonElementMixin, SbbFileSelectorDropzoneElement, SbbFileSelectorElement
|
|
4
|
+
export { SbbFileSelectorCommonElementMixin, SbbFileSelectorDropzoneElement, SbbFileSelectorElement };
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"map-container.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/map-container/map-container.component.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,cAAc,EAGnB,KAAK,cAAc,EACnB,KAAK,cAAc,EAEpB,MAAM,KAAK,CAAC;AAIb,OAAO,EAKL,UAAU,EACV,KAAK,cAAc,
|
|
1
|
+
{"version":3,"file":"map-container.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/map-container/map-container.component.ts"],"names":[],"mappings":"AACA,OAAO,EACL,KAAK,cAAc,EAGnB,KAAK,cAAc,EACnB,KAAK,cAAc,EAEpB,MAAM,KAAK,CAAC;AAIb,OAAO,EAKL,UAAU,EACV,KAAK,cAAc,EAGpB,MAAM,YAAY,CAAC;AAIpB;;;;;;;;;;;;;;GAcG;AACH,qBAAa,sBAAuB,SAAQ,UAAU;IACpD,gBAAgC,WAAW,EAAE,MAAM,CAAuB;IAC1E,OAAuB,mBAAmB,EAAE,cAAc,EAAE,CAA4B;IACxF,OAAuB,MAAM,EAAE,cAAc,CAI3C;IAEF,2EAA2E;IAC3E,SAEgB,kBAAkB,EAAE,OAAO,CAAS;IAE3C,OAAO,CAAC,QAAQ,CAAC,sBAAsB,CAAS;IAEzD,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,SAAS,CAGd;cAEgB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAczD,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAO9E,OAAO,CAAC,YAAY;IAIpB;;;OAGG;IACH,OAAO,CAAC,oBAAoB;IAI5B;;;;OAIG;IACH,OAAO,CAAC,kCAAkC;cAQvB,MAAM,IAAI,cAAc;CA2B5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,mBAAmB,EAAE,sBAAsB,CAAC;KAC7C;CACF"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { t as SbbMapContainerElement } from "../map-container.component-
|
|
1
|
+
import { t as SbbMapContainerElement } from "../map-container.component-DoFCVBoh.js";
|
|
2
2
|
export { SbbMapContainerElement };
|