@eo-sdk/client 11.7.0-rc.1 → 11.8.0-rc.2
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/app/eo-client/about-state/about-state.component.d.ts.map +1 -1
- package/app/eo-client/dashboard/dashboard.component.d.ts +3 -2
- package/app/eo-client/dashboard/dashboard.component.d.ts.map +1 -1
- package/app/eo-client/dashboard/widgets/signature-statistics-widget/signature-statistics-setup/signature-statistics-setup.component.d.ts +30 -0
- package/app/eo-client/dashboard/widgets/signature-statistics-widget/signature-statistics-setup/signature-statistics-setup.component.d.ts.map +1 -0
- package/app/eo-client/dashboard/widgets/signature-statistics-widget/signature-statistics-widget.component.d.ts +23 -0
- package/app/eo-client/dashboard/widgets/signature-statistics-widget/signature-statistics-widget.component.d.ts.map +1 -0
- package/app/eo-client/dashboard/widgets/signature-statistics-widget/signature-statistics.interface.d.ts +20 -0
- package/app/eo-client/dashboard/widgets/signature-statistics-widget/signature-statistics.interface.d.ts.map +1 -0
- package/app/eo-client/eo-client.module.d.ts +32 -29
- package/app/eo-client/eo-client.module.d.ts.map +1 -1
- package/app/eo-client/settings/settings.component.d.ts +15 -16
- package/app/eo-client/settings/settings.component.d.ts.map +1 -1
- package/app/eo-client/settings/settings.interface.d.ts +25 -0
- package/app/eo-client/settings/settings.interface.d.ts.map +1 -0
- package/app/eo-framework/app-shell/app-bar/app-search/app-search.component.d.ts +0 -1
- package/app/eo-framework/app-shell/app-bar/app-search/app-search.component.d.ts.map +1 -1
- package/app/eo-framework/form-elements/datetime-range/datetime-range.component.d.ts.map +1 -1
- package/app/eo-framework/form-elements/dynamic-list/dynamic-list.component.d.ts +78 -23
- package/app/eo-framework/form-elements/dynamic-list/dynamic-list.component.d.ts.map +1 -1
- package/app/eo-framework/form-elements/dynamic-list/dynamic-list.service.d.ts +24 -0
- package/app/eo-framework/form-elements/dynamic-list/dynamic-list.service.d.ts.map +1 -0
- package/app/eo-framework/grid/filters/dynamic-list-filter.component.d.ts +5 -5
- package/app/eo-framework/grid/filters/dynamic-list-filter.component.d.ts.map +1 -1
- package/app/eo-framework/inbox-details/inbox-details.component.d.ts.map +1 -1
- package/app/eo-framework/object-form/object-form-helper.service.d.ts +31 -11
- package/app/eo-framework/object-form/object-form-helper.service.d.ts.map +1 -1
- package/app/eo-framework/upload-overlay/upload-overlay.component.d.ts +51 -26
- package/app/eo-framework/upload-overlay/upload-overlay.component.d.ts.map +1 -1
- package/app/eo-framework-core/agent/agent.service.d.ts +7 -2
- package/app/eo-framework-core/agent/agent.service.d.ts.map +1 -1
- package/assets/_default/i18n/de.json +21 -3
- package/assets/_default/i18n/en.json +21 -3
- package/esm2022/app/eo-client/about-state/about-state.component.mjs +3 -3
- package/esm2022/app/eo-client/dashboard/dashboard.component.mjs +20 -6
- package/esm2022/app/eo-client/dashboard/widgets/signature-statistics-widget/signature-statistics-setup/signature-statistics-setup.component.mjs +114 -0
- package/esm2022/app/eo-client/dashboard/widgets/signature-statistics-widget/signature-statistics-widget.component.mjs +80 -0
- package/esm2022/app/eo-client/dashboard/widgets/signature-statistics-widget/signature-statistics.interface.mjs +2 -0
- package/esm2022/app/eo-client/eo-client.module.mjs +11 -1
- package/esm2022/app/eo-client/process-state/process-state.component.mjs +1 -1
- package/esm2022/app/eo-client/settings/settings.component.mjs +42 -24
- package/esm2022/app/eo-client/settings/settings.interface.mjs +2 -0
- package/esm2022/app/eo-framework/actions/actions/open-document-action/open-document-action.mjs +2 -2
- package/esm2022/app/eo-framework/app-shell/app-bar/app-search/app-search.component.mjs +7 -9
- package/esm2022/app/eo-framework/form-elements/datetime-range/datetime-range.component.mjs +3 -2
- package/esm2022/app/eo-framework/form-elements/dynamic-list/dynamic-list.component.mjs +215 -94
- package/esm2022/app/eo-framework/form-elements/dynamic-list/dynamic-list.service.mjs +39 -0
- package/esm2022/app/eo-framework/form-elements/string/string.component.mjs +2 -2
- package/esm2022/app/eo-framework/grid/filters/dynamic-list-filter.component.mjs +16 -22
- package/esm2022/app/eo-framework/inbox-details/inbox-details.component.mjs +8 -3
- package/esm2022/app/eo-framework/object-details/object-history/object-history.component.mjs +2 -2
- package/esm2022/app/eo-framework/object-form/object-form/form-element/form-element.component.mjs +3 -3
- package/esm2022/app/eo-framework/object-form/object-form/object-form-group/object-form-group.component.mjs +3 -3
- package/esm2022/app/eo-framework/object-form/object-form-edit/object-form-edit.component.mjs +3 -3
- package/esm2022/app/eo-framework/object-form/object-form-helper.service.mjs +43 -16
- package/esm2022/app/eo-framework/stored-query/stored-query-details/dynamic-property-switch/dynamic-property-switch.component.mjs +4 -3
- package/esm2022/app/eo-framework/upload-overlay/upload-overlay.component.mjs +163 -92
- package/esm2022/app/eo-framework-core/agent/agent.service.mjs +13 -2
- package/fesm2022/eo-sdk-client.mjs +727 -266
- package/fesm2022/eo-sdk-client.mjs.map +1 -1
- package/package.json +3 -2
|
@@ -1,29 +1,170 @@
|
|
|
1
1
|
import { of as observableOf, forkJoin as observableForkJoin, Observable } from 'rxjs';
|
|
2
2
|
import { Component, ViewChild } from '@angular/core';
|
|
3
3
|
import { EnaioEvent, UploadTarget, UploadFileItem, Utils, EnvironmentEnaio } from '@eo-sdk/core';
|
|
4
|
+
import { LocaleDatePipe } from '../../eo-framework-core';
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
import * as i1 from "@angular/router";
|
|
6
7
|
import * as i2 from "@eo-sdk/core";
|
|
7
|
-
import * as i3 from "
|
|
8
|
-
import * as i4 from "@
|
|
9
|
-
import * as i5 from "
|
|
10
|
-
import * as i6 from "../ui/
|
|
11
|
-
import * as i7 from "
|
|
8
|
+
import * as i3 from "../../eo-framework-core";
|
|
9
|
+
import * as i4 from "@angular/common";
|
|
10
|
+
import * as i5 from "@ngx-translate/core";
|
|
11
|
+
import * as i6 from "../ui/eo-icon/eo-icon.component";
|
|
12
|
+
import * as i7 from "../ui/loading-spinner/loading-spinner.component";
|
|
13
|
+
import * as i8 from "../accordion/simple-accordion/simple-accordion.component";
|
|
14
|
+
import * as i9 from "../../eo-framework-core/pipes/filesize.pipe";
|
|
12
15
|
export class UploadOverlayComponent {
|
|
13
|
-
constructor(router, renderer, prepareService, translate, systemService, eventService, uploadRegistry) {
|
|
16
|
+
constructor(router, renderer, prepareService, translate, userService, agentService, systemService, eventService, storageService, uploadRegistry) {
|
|
14
17
|
this.router = router;
|
|
15
18
|
this.renderer = renderer;
|
|
16
19
|
this.prepareService = prepareService;
|
|
17
20
|
this.translate = translate;
|
|
21
|
+
this.userService = userService;
|
|
22
|
+
this.agentService = agentService;
|
|
18
23
|
this.systemService = systemService;
|
|
19
24
|
this.eventService = eventService;
|
|
25
|
+
this.storageService = storageService;
|
|
20
26
|
this.uploadRegistry = uploadRegistry;
|
|
21
27
|
this.queue = [];
|
|
22
28
|
this.validUploadTargets = [];
|
|
29
|
+
this.folderFavorites = [];
|
|
30
|
+
this.lastOpenedFolder = [];
|
|
31
|
+
this.targetTypes = [
|
|
32
|
+
{
|
|
33
|
+
type: 'root',
|
|
34
|
+
iconSrc: 'assets/_default/svg/ic_create_document.svg',
|
|
35
|
+
targetClass: 'upload-target-general',
|
|
36
|
+
name: 'eo.upload.global.root.title',
|
|
37
|
+
description: 'eo.upload.global.root.description'
|
|
38
|
+
},
|
|
39
|
+
{
|
|
40
|
+
type: 'object',
|
|
41
|
+
iconSrc: 'assets/_default/svg/ic_document_file.svg',
|
|
42
|
+
targetClass: 'upload-target-replace',
|
|
43
|
+
name: 'eo.upload.global.object.title'
|
|
44
|
+
},
|
|
45
|
+
{
|
|
46
|
+
type: 'context',
|
|
47
|
+
iconSrc: 'assets/_default/svg/ic_create_document_in_folder.svg',
|
|
48
|
+
targetClass: 'upload-target-context',
|
|
49
|
+
name: 'eo.upload.global.context.title',
|
|
50
|
+
},
|
|
51
|
+
{
|
|
52
|
+
type: 'contexttree',
|
|
53
|
+
iconSrc: 'assets/_default/svg/ic_create_document_in_folder.svg',
|
|
54
|
+
targetClass: 'upload-target-contexttree',
|
|
55
|
+
name: 'eo.add.title.location.subfolder'
|
|
56
|
+
},
|
|
57
|
+
{
|
|
58
|
+
type: 'custom',
|
|
59
|
+
iconSrc: 'assets/_default/svg/ic_upload.svg',
|
|
60
|
+
targetClass: 'upload-target-custom',
|
|
61
|
+
name: '',
|
|
62
|
+
}
|
|
63
|
+
];
|
|
23
64
|
this.uploadTargets = [];
|
|
24
65
|
this.dragEventCount = 0;
|
|
66
|
+
this.cacheKey = 'accordion.state--';
|
|
67
|
+
this.datePipe = new LocaleDatePipe(translate);
|
|
68
|
+
}
|
|
69
|
+
ngOnInit() {
|
|
70
|
+
this.init();
|
|
71
|
+
}
|
|
72
|
+
ngOnDestroy() {
|
|
73
|
+
if (this.dragEnterListener) {
|
|
74
|
+
this.dragEnterListener();
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Proceed upload with a selected upload target.
|
|
79
|
+
* @param uploadTarget - the target to upload files to
|
|
80
|
+
*/
|
|
81
|
+
proceedWithUpload(uploadTarget) {
|
|
82
|
+
if (uploadTarget.type !== UploadTarget.CUSTOM && this.queue.length > 1) {
|
|
83
|
+
// For more than one file to be uploaded to a none custom target, we let the user decide if
|
|
84
|
+
// batch upload should be used or not ...
|
|
85
|
+
this.selectedUploadTarget = uploadTarget;
|
|
86
|
+
}
|
|
87
|
+
else if (uploadTarget.type === UploadTarget.OBJECT) {
|
|
88
|
+
// ... otherwise upload is started immediately
|
|
89
|
+
this.startUpload(uploadTarget, [null, this.getStateRoute()]);
|
|
90
|
+
}
|
|
91
|
+
else {
|
|
92
|
+
this.startUpload(uploadTarget, [null, '/prepare']);
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
/**
|
|
96
|
+
* Proceed upload using the selected upload target.
|
|
97
|
+
* @param useBatchUpload - flag indicating whether or not to use batch upload
|
|
98
|
+
*/
|
|
99
|
+
proceedWithSelectedTarget(useBatchUpload) {
|
|
100
|
+
this.startUpload(this.selectedUploadTarget, [useBatchUpload, '/prepare']);
|
|
101
|
+
}
|
|
102
|
+
/**
|
|
103
|
+
* Resets the selected upload target.
|
|
104
|
+
*/
|
|
105
|
+
resetSelectedUploadTarget() {
|
|
106
|
+
this.selectedUploadTarget = null;
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* Removes a file from the list of files to be uploaded.
|
|
110
|
+
* @param fileItem - the file item to be removed
|
|
111
|
+
*/
|
|
112
|
+
removeFileItem(fileItem) {
|
|
113
|
+
this.queue = this.queue.filter((f) => f.id !== fileItem.id);
|
|
114
|
+
if (!this.queue.length) {
|
|
115
|
+
this.close();
|
|
116
|
+
}
|
|
117
|
+
else {
|
|
118
|
+
// update available upload targets because their validity
|
|
119
|
+
// may be based on the queue size
|
|
120
|
+
this.validateUploadTargets();
|
|
121
|
+
this.setQueueSize();
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
getStateRoute() {
|
|
125
|
+
return this.router.url;
|
|
126
|
+
}
|
|
127
|
+
onAgentToggle(info) {
|
|
128
|
+
this.storageService.setItem(this.cacheKey + 'agent-folder', JSON.stringify(info));
|
|
129
|
+
}
|
|
130
|
+
onFavoriteToggle(info) {
|
|
131
|
+
this.storageService.setItem(this.cacheKey + 'favorite-folder', JSON.stringify(info));
|
|
132
|
+
}
|
|
133
|
+
getFolder() {
|
|
134
|
+
//folder from agent
|
|
135
|
+
this.agentService.getLastOpenedFoldersInfo().subscribe((res) => {
|
|
136
|
+
this.lastOpenedFolder = res.map((item) => {
|
|
137
|
+
let target = new UploadTarget(item.id, 'agent', item?.title, this.systemService.getObjectType(item.type).iconId, item.type);
|
|
138
|
+
target.description = item?.data?.description;
|
|
139
|
+
return target;
|
|
140
|
+
});
|
|
141
|
+
this.lastOpenedFolder.forEach(target => target.onUploadSuccess = () => this.router.navigate(['/prepare']));
|
|
142
|
+
});
|
|
143
|
+
// Folder from favorite
|
|
144
|
+
this.userService.getFavorites().subscribe((res) => {
|
|
145
|
+
const favoritesFiltered = res.filter((item) => item.target.folder === true);
|
|
146
|
+
this.folderFavorites = favoritesFiltered.map(item => {
|
|
147
|
+
let target = new UploadTarget(item.target.id, 'favorite', item.title, item.target.icon.id, item.target.type);
|
|
148
|
+
target.description = this.datePipe.transform(item.created);
|
|
149
|
+
return target;
|
|
150
|
+
});
|
|
151
|
+
this.folderFavorites.forEach(target => target.onUploadSuccess = () => this.router.navigate(['/prepare']));
|
|
152
|
+
});
|
|
153
|
+
}
|
|
154
|
+
/**
|
|
155
|
+
* Close the upload overlay and release all bound resources.
|
|
156
|
+
*/
|
|
157
|
+
close() {
|
|
158
|
+
// unbind bound event listener, when they are not needed anymore
|
|
159
|
+
this.unbindListeners();
|
|
160
|
+
// clear upload queue
|
|
161
|
+
this.queue = [];
|
|
162
|
+
// hide the overlay
|
|
163
|
+
this.setFileOver(false);
|
|
164
|
+
this.invalidInput = false;
|
|
25
165
|
}
|
|
26
166
|
init() {
|
|
167
|
+
this.getFolder();
|
|
27
168
|
// global drag&drop upload will only be available on desktop (web or electron)
|
|
28
169
|
if (EnvironmentEnaio.isMobileEnvironment()) {
|
|
29
170
|
return false;
|
|
@@ -83,7 +224,7 @@ export class UploadOverlayComponent {
|
|
|
83
224
|
// todo: replace by renderer solution when available (https://github.com/angular/angular/issues/15674)
|
|
84
225
|
this.overlayEl.nativeElement.focus();
|
|
85
226
|
// bind late (only, when needed) to dragleave event to avoid heavy processing on every drag event
|
|
86
|
-
this.dragLeaveListener = this.renderer.listen(this.overlayEl.nativeElement, 'dragleave', (
|
|
227
|
+
this.dragLeaveListener = this.renderer.listen(this.overlayEl.nativeElement, 'dragleave', () => {
|
|
87
228
|
this.dragEventCount--;
|
|
88
229
|
if (this.dragEventCount === 0) {
|
|
89
230
|
this.close();
|
|
@@ -128,6 +269,8 @@ export class UploadOverlayComponent {
|
|
|
128
269
|
event.stopPropagation();
|
|
129
270
|
}
|
|
130
271
|
onFilesDropped(fileItems) {
|
|
272
|
+
this.getFolder();
|
|
273
|
+
this.getCachedAccordionState();
|
|
131
274
|
// clear queue when new files are added
|
|
132
275
|
// todo: remove in future releases to support collective file adding
|
|
133
276
|
this.queue = [];
|
|
@@ -153,12 +296,14 @@ export class UploadOverlayComponent {
|
|
|
153
296
|
*/
|
|
154
297
|
validateUploadTargets() {
|
|
155
298
|
this.hasValidUploadTargets = true;
|
|
299
|
+
this.getFolder();
|
|
156
300
|
observableForkJoin(this.uploadTargets.map(t => this.validateUploadTarget(t)))
|
|
157
301
|
.subscribe((res) => {
|
|
158
302
|
this.validUploadTargets = res.filter(r => r.valid).map(filtered => filtered.target).reverse().sort((a, b) => {
|
|
159
303
|
return a.type === 'context' ? -1 : b.type === 'context' ? 1 : 0; // Context should be on top
|
|
160
304
|
});
|
|
161
|
-
|
|
305
|
+
this.validUploadTargets = [...this.validUploadTargets, ...this.folderFavorites, ...this.lastOpenedFolder];
|
|
306
|
+
}, () => {
|
|
162
307
|
this.validUploadTargets = [];
|
|
163
308
|
}, () => {
|
|
164
309
|
this.hasValidUploadTargets = this.validUploadTargets.length > 0;
|
|
@@ -177,7 +322,7 @@ export class UploadOverlayComponent {
|
|
|
177
322
|
valid = this.queue.length > 0 && res.types.length > 0;
|
|
178
323
|
o.next({ target: target, valid: valid });
|
|
179
324
|
o.complete();
|
|
180
|
-
},
|
|
325
|
+
}, () => {
|
|
181
326
|
o.next({ target: target, valid: false });
|
|
182
327
|
o.complete();
|
|
183
328
|
});
|
|
@@ -208,7 +353,7 @@ export class UploadOverlayComponent {
|
|
|
208
353
|
}
|
|
209
354
|
o.next({ target: target, valid: valid });
|
|
210
355
|
o.complete();
|
|
211
|
-
},
|
|
356
|
+
}, () => {
|
|
212
357
|
o.next({ target: target, valid: false });
|
|
213
358
|
o.complete();
|
|
214
359
|
});
|
|
@@ -219,55 +364,9 @@ export class UploadOverlayComponent {
|
|
|
219
364
|
}
|
|
220
365
|
});
|
|
221
366
|
}
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
*/
|
|
226
|
-
removeFileItem(fileItem) {
|
|
227
|
-
this.queue = this.queue.filter((f) => f.id !== fileItem.id);
|
|
228
|
-
if (!this.queue.length) {
|
|
229
|
-
this.close();
|
|
230
|
-
}
|
|
231
|
-
else {
|
|
232
|
-
// update available upload targets because their validity
|
|
233
|
-
// may be based on the queue size
|
|
234
|
-
this.validateUploadTargets();
|
|
235
|
-
this.setQueueSize();
|
|
236
|
-
}
|
|
237
|
-
}
|
|
238
|
-
/**
|
|
239
|
-
* Proceed upload with a selected upload target.
|
|
240
|
-
* @param uploadTarget - the target to upload files to
|
|
241
|
-
*/
|
|
242
|
-
proceedWithUpload(uploadTarget) {
|
|
243
|
-
if (uploadTarget.type !== UploadTarget.CUSTOM && this.queue.length > 1) {
|
|
244
|
-
// For more than one file to be uploaded to a none custom target, we let the user decide if
|
|
245
|
-
// batch upload should be used or not ...
|
|
246
|
-
this.selectedUploadTarget = uploadTarget;
|
|
247
|
-
}
|
|
248
|
-
else if (uploadTarget.type === UploadTarget.OBJECT) {
|
|
249
|
-
// ... otherwise upload is started immediately
|
|
250
|
-
this.startUpload(uploadTarget, [null, this.getStateRoute()]);
|
|
251
|
-
}
|
|
252
|
-
else {
|
|
253
|
-
this.startUpload(uploadTarget, [null, '/prepare']);
|
|
254
|
-
}
|
|
255
|
-
}
|
|
256
|
-
/**
|
|
257
|
-
* Proceed upload using the selected upload target.
|
|
258
|
-
* @param useBatchUpload - flag indicating whether or not to use batch upload
|
|
259
|
-
*/
|
|
260
|
-
proceedWithSelectedTarget(useBatchUpload) {
|
|
261
|
-
this.startUpload(this.selectedUploadTarget, [useBatchUpload, '/prepare']);
|
|
262
|
-
}
|
|
263
|
-
/**
|
|
264
|
-
* Resets the selected upload target.
|
|
265
|
-
*/
|
|
266
|
-
resetSelectedUploadTarget() {
|
|
267
|
-
this.selectedUploadTarget = null;
|
|
268
|
-
}
|
|
269
|
-
getStateRoute() {
|
|
270
|
-
return this.router.url;
|
|
367
|
+
getCachedAccordionState() {
|
|
368
|
+
this.agentAccSelected = JSON.parse(this.storageService.getItem(this.cacheKey + 'agent-folder'));
|
|
369
|
+
this.favoritesAccSelected = JSON.parse(this.storageService.getItem(this.cacheKey + 'favorite-folder'));
|
|
271
370
|
}
|
|
272
371
|
successfulUpload(target, uploadTarget) {
|
|
273
372
|
this.eventService.trigger(EnaioEvent.DMS_OBJECT_UPDATED, uploadTarget.referenceObject);
|
|
@@ -318,18 +417,6 @@ export class UploadOverlayComponent {
|
|
|
318
417
|
}
|
|
319
418
|
this.queueSize = s;
|
|
320
419
|
}
|
|
321
|
-
/**
|
|
322
|
-
* Close the upload overlay and release all bound resources.
|
|
323
|
-
*/
|
|
324
|
-
close() {
|
|
325
|
-
// unbind bound event listener, when they are not needed anymore
|
|
326
|
-
this.unbindListeners();
|
|
327
|
-
// clear upload queue
|
|
328
|
-
this.queue = [];
|
|
329
|
-
// hide the overlay
|
|
330
|
-
this.setFileOver(false);
|
|
331
|
-
this.invalidInput = false;
|
|
332
|
-
}
|
|
333
420
|
setFileOver(value) {
|
|
334
421
|
this.fileOver = value;
|
|
335
422
|
this.uploadRegistry.setOverlayActive(value);
|
|
@@ -368,30 +455,14 @@ export class UploadOverlayComponent {
|
|
|
368
455
|
pasteContainsFiles(event) {
|
|
369
456
|
return Array.from(event.clipboardData.items || []).filter(i => i.kind === 'file').length;
|
|
370
457
|
}
|
|
371
|
-
|
|
372
|
-
targetTrackByFn(index, item) {
|
|
373
|
-
return item.id;
|
|
374
|
-
}
|
|
375
|
-
// ngFor tracking function for file items
|
|
376
|
-
trackByFn(index, item) {
|
|
377
|
-
return index;
|
|
378
|
-
}
|
|
379
|
-
ngOnInit() {
|
|
380
|
-
this.init();
|
|
381
|
-
}
|
|
382
|
-
ngOnDestroy() {
|
|
383
|
-
if (this.dragEnterListener) {
|
|
384
|
-
this.dragEnterListener();
|
|
385
|
-
}
|
|
386
|
-
}
|
|
387
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.4", ngImport: i0, type: UploadOverlayComponent, deps: [{ token: i1.Router }, { token: i0.Renderer2 }, { token: i2.PrepareService }, { token: i2.TranslateService }, { token: i2.SystemService }, { token: i2.EventService }, { token: i2.UploadRegistryService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
388
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.0.4", type: UploadOverlayComponent, selector: "eo-upload-overlay", viewQueries: [{ propertyName: "overlayEl", first: true, predicate: ["overlay"], descendants: true }], ngImport: i0, template: "<div id=\"eo-upload-overlay\" #overlay class=\"dark\" *ngIf=\"fileOver\" tabindex=\"1\"\n [ngClass]=\"{hasFiles: queue.length, invalid: invalidInput, singleFile: queue.length === 1, uploading: isUploading}\">\n\n <eo-icon class=\"button white close\" [iconSrc]=\"'assets/_default/svg/ic_clear.svg'\" (click)=\"close()\"></eo-icon>\n\n <div class=\"count\">\n <div>{{queue.length}}</div>\n <div class=\"queueSize\">{{queueSize | fileSize}}</div>\n </div>\n\n <h1 translate>eo.upload.global.headline</h1>\n <eo-icon class=\"uploady\" [iconSrc]=\"'assets/_default/svg/ic_upload.svg'\"></eo-icon>\n\n <!-- batch upload dialog -->\n <div class=\"batch-dialog\" *ngIf=\"!invalidInput && selectedUploadTarget && !isUploading\">\n\n <h2 translate>eo.upload.global.choose.title</h2>\n <p translate>eo.upload.global.choose.message</p>\n <div class=\"actions\">\n <button (click)=\"resetSelectedUploadTarget()\" translate>eo.cta.button.cancel</button>\n <button (click)=\"proceedWithSelectedTarget(false)\" class=\"primary\" translate>eo.upload.global.choose.single</button>\n <button (click)=\"proceedWithSelectedTarget(true)\" class=\"primary\" translate>eo.upload.global.choose.multi</button>\n </div>\n </div>\n\n <!-- invalid input dialog -->\n <div class=\"batch-dialog\" *ngIf=\"hasValidUploadTargets && invalidInput\">\n\n <h2 translate>eo.upload.global.invalid.title</h2>\n <p translate>eo.upload.global.invalid.message</p>\n <div class=\"actions\">\n <button (click)=\"close()\" translate>eo.upload.global.close</button>\n </div>\n </div>\n\n <!-- no upload targets available -->\n <div class=\"batch-dialog\" *ngIf=\"!hasValidUploadTargets\">\n\n <h2 translate>eo.upload.global.notarget.title</h2>\n <p translate>eo.upload.global.notarget.message</p>\n <div class=\"actions\">\n <button (click)=\"close()\" translate>eo.upload.global.close</button>\n </div>\n </div>\n\n <div class=\"contents\" *ngIf=\"hasValidUploadTargets && !invalidInput && !selectedUploadTarget && !isUploading\">\n\n <!-- list of available upload targets -->\n <div class=\"targets\">\n\n <div class=\"target-list\">\n\n <div class=\"upload-target\" *ngFor=\"let t of validUploadTargets; trackBy: targetTrackByFn\"\n (click)=\"proceedWithUpload(t)\"\n [ngSwitch]=\"t.type\">\n\n <!-- upload to root -->\n <ng-container *ngSwitchCase=\"'root'\" >\n <eo-icon [iconSrc]=\"'assets/_default/svg/ic_create_document.svg'\"></eo-icon>\n <div class=\"upload-target-general\">\n <div class=\"name\" translate>eo.upload.global.root.title</div>\n <div class=\"description\" translate>eo.upload.global.root.description</div>\n </div>\n </ng-container>\n\n <!-- replace file of a specific dms object -->\n <ng-container *ngSwitchCase=\"'object'\">\n <eo-icon [iconSrc]=\"'assets/_default/svg/ic_document_file.svg'\"></eo-icon>\n <div class=\"upload-target-replace\">\n <div class=\"name\" translate>eo.upload.global.object.title</div>\n <div class=\"description\">{{t.description}}</div>\n </div>\n </ng-container>\n\n <!-- add new files to a context folder -->\n <ng-container *ngSwitchCase=\"'context'\">\n <eo-icon [iconSrc]=\"'assets/_default/svg/ic_create_document_in_folder.svg'\"></eo-icon>\n <div class=\"upload-target-context\">\n <div class=\"name\">{{'eo.upload.global.context.title'|translate:({context:t.referenceObject.type.label})}}</div>\n <div class=\"description\">{{t.description}}</div>\n </div>\n </ng-container>\n\n <!-- add new files to a context folder structure tree entry -->\n <ng-container *ngSwitchCase=\"'contexttree'\">\n <eo-icon [iconSrc]=\"'assets/_default/svg/ic_create_document_in_folder.svg'\"></eo-icon>\n <div class=\"upload-target-contexttree\">\n <div class=\"name\">{{'eo.add.title.location.subfolder'|translate: ({folder: t.subFolder.name})}}</div>\n </div>\n </ng-container>\n\n <!-- custom upload target (e.g. from plugin component) -->\n <ng-container *ngSwitchCase=\"'custom'\">\n <eo-icon [iconSrc]=\"'assets/_default/svg/ic_upload.svg'\"></eo-icon>\n <div class=\"upload-target-custom\">\n <div class=\"name\">{{t.name}}</div>\n <div class=\"description\">{{t.description}}</div>\n </div>\n </ng-container>\n </div>\n\n </div>\n\n </div>\n\n <!-- list of files dragged to the component -->\n <div class=\"files\">\n <div class=\"files-list\">\n <div class=\"file-item\" *ngFor=\"let i of queue; trackBy: trackByFn\">\n <div>\n <div class=\"name\">{{i.name}}</div>\n <div class=\"desc\"><span class=\"size\">{{i.size | fileSize}}</span><span class=\"desc-text\"> {{i.type}}</span></div>\n </div>\n <eo-icon class=\"button white\" (click)=\"removeFileItem(i)\" [iconSrc]=\"'assets/_default/svg/ic_clear.svg'\"></eo-icon>\n </div>\n </div>\n </div>\n\n </div>\n\n <div class=\"loading\" *ngIf=\"isUploading\"><eo-loading-spinner [size]=\"'large'\"></eo-loading-spinner></div>\n\n\n</div>\n", styles: [":host #eo-upload-overlay{position:absolute;inset:0;z-index:9900;background-color:rgba(var(--color-black-rgb),.85);animation:eoFadeIn var(--app-default-transition-duration);display:flex;flex-flow:column;align-items:center;justify-content:center;color:var(--color-white);overflow:auto}:host #eo-upload-overlay h1{font-size:4em;font-weight:300;color:rgba(var(--color-white-rgb),.5);animation:eoFadeInDown var(--app-default-transition-duration)}:host #eo-upload-overlay .uploady{animation:uploady 2s linear infinite;width:20vw;height:20vw;display:block}:host #eo-upload-overlay .close{position:absolute;right:var(--app-pane-padding);top:var(--app-pane-padding)}:host #eo-upload-overlay .count{position:absolute;display:none;right:calc(var(--app-pane-padding) * 3);top:calc(var(--app-pane-padding) * 3);font-size:10vh;flex-flow:column;align-items:flex-end;line-height:1em;animation:eoFadeInDown var(--app-default-transition-duration)}:host #eo-upload-overlay .count .queueSize{font-size:var(--font-caption);line-height:var(--font-caption);margin-top:calc(var(--app-pane-padding) / 2);border-radius:2px;padding:calc(var(--app-pane-padding) / 4) calc(var(--app-pane-padding) / 2);background-color:rgba(var(--color-white-rgb),.2)}:host #eo-upload-overlay .batch-dialog{max-width:350px}:host #eo-upload-overlay .batch-dialog .actions{display:flex;padding-top:var(--app-pane-padding);justify-content:flex-end}:host #eo-upload-overlay .batch-dialog .actions button{margin:0 calc(var(--app-pane-padding) / 4)}:host #eo-upload-overlay .contents{display:none;flex-flow:row wrap;max-height:100%;margin:var(--app-pane-padding)}:host #eo-upload-overlay .targets{order:1;margin:0 calc(var(--app-pane-padding) / 2);display:flex;flex-flow:column;justify-content:center;position:relative}:host #eo-upload-overlay .targets .target-list{animation:eoFadeInRight var(--app-default-transition-duration);overflow-y:auto}:host #eo-upload-overlay .targets .target-list h2{font-size:var(--font-subhead);font-weight:400}:host #eo-upload-overlay .targets .target-list .upload-target{background:rgba(var(--color-accent),.6);border:1px solid rgba(var(--color-white-rgb),.4);margin:calc(var(--app-pane-padding) / 2) 0;padding:calc(var(--app-pane-padding) / 2);border-radius:2px;transition:all var(--app-default-transition-duration) ease-in-out;-webkit-transition:all var(--app-default-transition-duration) ease-in-out;-moz-transition:all var(--app-default-transition-duration) ease-in-out;-o-transition:all var(--app-default-transition-duration) ease-in-out;display:flex;cursor:pointer;flex-flow:row nowrap;align-items:center}:host #eo-upload-overlay .targets .target-list .upload-target eo-icon{flex:0 0 auto;margin:0 calc(var(--app-pane-padding) / 2)}:host #eo-upload-overlay .targets .target-list .upload-target>div{flex:1 1 auto;margin:0 calc(var(--app-pane-padding) / 2)}:host #eo-upload-overlay .targets .target-list .upload-target>div .name{font-size:var(--font-subhead)}:host #eo-upload-overlay .targets .target-list .upload-target>div .description{font-size:var(--font-caption);opacity:.7}:host #eo-upload-overlay .targets .target-list .upload-target:hover{background-color:var(--color-accent)}:host #eo-upload-overlay .files{order:0;padding:calc(var(--app-pane-padding) / 4);margin:0 calc(var(--app-pane-padding) / 2);overflow-y:auto;border-radius:2px;animation:eoFadeInLeft var(--app-default-transition-duration);display:flex;flex-flow:column;justify-content:center}:host #eo-upload-overlay .files .files-list{height:100%}:host #eo-upload-overlay .files .files-list .file-item{display:flex;flex-flow:row nowrap;align-items:center;cursor:default;padding:calc(var(--app-pane-padding) / 2) calc(var(--app-pane-padding) / 4);margin-bottom:calc(var(--app-pane-padding) / 4);background-color:rgba(var(--color-white-rgb),.1);-webkit-user-select:none;user-select:none}:host #eo-upload-overlay .files .files-list .file-item>div{flex:1 1 auto;padding:0 calc(var(--app-pane-padding) / 2)}:host #eo-upload-overlay .files .files-list .file-item>div .desc{color:rgba(var(--color-white-rgb),.75);font-size:var(--font-hint);margin-top:calc(var(--app-pane-padding) / 4)}:host #eo-upload-overlay .files .files-list .file-item>div .size{border-radius:2px;display:inline-block;padding:0 4px;background-color:rgba(var(--color-white-rgb),.2)}:host #eo-upload-overlay .files .files-list .file-item eo-icon{flex:0 0 auto;width:18px;height:18px;padding:calc(var(--app-pane-padding) / 2)}:host #eo-upload-overlay.invalid>h1,:host #eo-upload-overlay.invalid .uploady{display:none}:host #eo-upload-overlay.hasFiles .uploady{display:none}:host #eo-upload-overlay.hasFiles .count{display:flex}:host #eo-upload-overlay.hasFiles .contents{display:flex}:host #eo-upload-overlay.singleFile .contents{flex-flow:column}:host #eo-upload-overlay.singleFile .contents .files{padding:0;order:1}:host #eo-upload-overlay.singleFile .contents .targets{order:0;margin-bottom:var(--app-pane-padding)}:host #eo-upload-overlay.uploading h1,:host #eo-upload-overlay.uploading .close{display:none}@keyframes uploady{0%{transform:translateY(0);opacity:.1}50%{transform:translateY(-40px);opacity:.3}to{transform:translateY(0);opacity:.1}}\n"], dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i3.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i4.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i5.EoIconComponent, selector: "eo-icon", inputs: ["objectType", "iconId", "iconSrc", "badge", "iconTitle"] }, { kind: "component", type: i6.LoadingSpinnerComponent, selector: "eo-loading-spinner", inputs: ["size", "mode"] }, { kind: "pipe", type: i4.TranslatePipe, name: "translate" }, { kind: "pipe", type: i7.FileSizePipe, name: "fileSize" }] }); }
|
|
458
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.4", ngImport: i0, type: UploadOverlayComponent, deps: [{ token: i1.Router }, { token: i0.Renderer2 }, { token: i2.PrepareService }, { token: i2.TranslateService }, { token: i2.UserService }, { token: i3.AgentService }, { token: i2.SystemService }, { token: i2.EventService }, { token: i2.LocalStorageService }, { token: i2.UploadRegistryService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
459
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.4", type: UploadOverlayComponent, selector: "eo-upload-overlay", viewQueries: [{ propertyName: "overlayEl", first: true, predicate: ["overlay"], descendants: true }], ngImport: i0, template: "<div id=\"eo-upload-overlay\" #overlay class=\"dark\" *ngIf=\"fileOver\" tabindex=\"1\"\n [ngClass]=\"{file: queue.length, invalid: invalidInput, uploading: isUploading}\">\n\n <eo-icon class=\"button white close\" [iconSrc]=\"'assets/_default/svg/ic_clear.svg'\" (click)=\"close()\"></eo-icon>\n\n <div class=\"count\">\n <div>{{queue.length}}</div>\n <div class=\"queueSize\">{{queueSize | fileSize}}</div>\n </div>\n\n <div class=\"headline\">\n <h1 translate>eo.upload.global.headline</h1>\n </div>\n \n <eo-icon class=\"uploady\" [iconSrc]=\"'assets/_default/svg/ic_upload.svg'\"></eo-icon>\n\n <!-- batch upload dialog -->\n <div class=\"batch-dialog\" *ngIf=\"!invalidInput && selectedUploadTarget && !isUploading\">\n\n <h2 translate>eo.upload.global.choose.title</h2>\n <p translate>eo.upload.global.choose.message</p>\n <div class=\"actions\">\n <button (click)=\"resetSelectedUploadTarget()\" translate>eo.cta.button.cancel</button>\n <button (click)=\"proceedWithSelectedTarget(false)\" class=\"primary\"\n translate>eo.upload.global.choose.single</button>\n <button (click)=\"proceedWithSelectedTarget(true)\" class=\"primary\" translate>eo.upload.global.choose.multi</button>\n </div>\n </div>\n\n <!-- invalid input dialog -->\n <div class=\"batch-dialog\" *ngIf=\"hasValidUploadTargets && invalidInput\">\n\n <h2 translate>eo.upload.global.invalid.title</h2>\n <p translate>eo.upload.global.invalid.message</p>\n <div class=\"actions\">\n <button (click)=\"close()\" translate>eo.upload.global.close</button>\n </div>\n </div>\n\n <!-- no upload targets available -->\n <div class=\"batch-dialog\" *ngIf=\"!hasValidUploadTargets\">\n\n <h2 translate>eo.upload.global.notarget.title</h2>\n <p translate>eo.upload.global.notarget.message</p>\n <div class=\"actions\">\n <button (click)=\"close()\" translate>eo.upload.global.close</button>\n </div>\n </div>\n\n <div class=\"contents\" *ngIf=\"hasValidUploadTargets && !invalidInput && !selectedUploadTarget && !isUploading\">\n\n <div class=\"section\">\n <!-- list of available upload targets -->\n <div class=\"targets\">\n <div class=\"target-list\">\n @for (targetType of targetTypes; track targetType.type) {\n @for (t of validUploadTargets; track t.id) {\n @if (t.type === targetType.type) {\n <ng-container *ngTemplateOutlet=\"uploadTargetTemplate; context: {\n iconSrc: targetType.iconSrc,\n targetClass: targetType.targetClass,\n name: targetType.type === 'custom' ? t.name : (targetType.type === 'context' ? (targetType.name | translate : { context: t.referenceObject.type.label }) : (targetType. name | translate)),\n description: targetType.type === 'custom' || targetType.type === 'object' || targetType. type === 'context' ? t.description : (targetType.description | translate),\n targets: t\n }\">\n </ng-container>\n }\n }\n }\n </div>\n </div>\n\n <!-- upload to favorite -->\n @if (folderFavorites.length > 0) {\n <eo-simple-accordion [selected]=\"favoritesAccSelected\" [header]=\"'eo.upload.global.context.favorite' | translate\"\n (selectChange)=\"onFavoriteToggle($event)\">\n <div class=\"targets\">\n <div class=\"target-list\">\n @for (t of validUploadTargets; track $index) {\n @if (t.type === 'favorite') {\n <div class=\"upload-target\" (click)=\"proceedWithUpload(t)\">\n <ng-container>\n <eo-icon [iconId]=\"t.iconId\"></eo-icon>\n <div class=\"upload-target-favorite\">\n <div class=\"name\">{{t.title}}\n <div class=\"description\">{{t.description}}</div>\n </div>\n </div>\n </ng-container>\n </div>\n }\n }\n </div>\n </div>\n </eo-simple-accordion>\n }\n\n @if(lastOpenedFolder.length > 0){\n <eo-simple-accordion [selected]=\"agentAccSelected\" [header]=\"'eo.upload.global.context.agent' | translate\"\n (selectChange)=\"onAgentToggle($event)\">\n <!-- upload to last opened folder -->\n <div class=\"targets\">\n <div class=\"target-list\">\n @for (t of validUploadTargets; track $index) {\n @if (t.type === 'agent') {\n <div class=\"upload-target\" (click)=\"proceedWithUpload(t)\">\n <ng-container>\n <eo-icon [iconId]=\"t.iconId\"></eo-icon>\n <div class=\"upload-target-agent\">\n <div class=\"name\">{{t?.title}}\n <div class=\"description\">{{t?.description}}</div>\n </div>\n </div>\n </ng-container>\n </div>\n }\n }\n </div>\n </div>\n </eo-simple-accordion>\n }\n </div>\n <!-- list of files dragged to the component -->\n <div class=\"files\" [ngClass]=\"{file: queue.length, invalid: invalidInput, uploading: isUploading}\">\n <div class=\"files-list\">\n @for (i of queue; track $index) {\n <div class=\"file-item\">\n <div>\n <div class=\"name\">{{i.name}}</div>\n <div class=\"desc\"><span class=\"size\">{{i.size | fileSize}}</span>\n <span class=\"desc-text\"> {{i.type}}</span></div>\n </div>\n <eo-icon class=\"button white\" (click)=\"removeFileItem(i)\"\n [iconSrc]=\"'assets/_default/svg/ic_clear.svg'\"></eo-icon>\n </div>\n }\n </div>\n </div>\n </div>\n\n @if (isUploading) {\n <div class=\"loading\">\n <eo-loading-spinner [size]=\"'large'\"></eo-loading-spinner>\n </div>\n }\n</div>\n\n<ng-template #uploadTargetTemplate let-iconSrc=\"iconSrc\" let-targetClass=\"targetClass\" let-name=\"name\"\n let-description=\"description\" let-targets=\"targets\">\n <div class=\"upload-target\" (click)=\"proceedWithUpload(targets)\">\n <ng-container>\n <eo-icon [iconSrc]=\"iconSrc\"></eo-icon>\n <div [ngClass]=\"targetClass\">\n <div class=\"name\">{{ name }}</div>\n <div class=\"description\">{{ description }}</div>\n </div>\n </ng-container>\n </div>\n</ng-template>\n", styles: [":host #eo-upload-overlay{position:absolute;inset:0;z-index:9900;background-color:rgba(var(--color-black-rgb),.85);animation:eoFadeIn var(--app-default-transition-duration);display:flex;flex-flow:column;align-items:center;justify-content:center;color:var(--color-white);overflow:hidden}:host #eo-upload-overlay .headline{display:flex;width:100%;min-width:200px;justify-content:center;overflow:hidden;align-content:center;flex-wrap:wrap}:host #eo-upload-overlay .headline h1{font-size:4em;font-weight:var(--font-weight-light);color:rgba(var(--color-white-rgb),.5);animation:eoFadeInDown var(--app-default-transition-duration);overflow-x:hidden;text-overflow:ellipsis;white-space:nowrap}:host #eo-upload-overlay .uploady{animation:uploady 2s linear infinite;width:20vw;height:20vw;display:block}:host #eo-upload-overlay .close{position:absolute;right:var(--app-pane-padding);top:var(--app-pane-padding)}:host #eo-upload-overlay .count{position:absolute;display:none;right:calc(var(--app-pane-padding) * 3);top:calc(var(--app-pane-padding) * 3);font-size:10vh;flex-flow:column;align-items:flex-end;line-height:1em;animation:eoFadeInDown var(--app-default-transition-duration)}:host #eo-upload-overlay .count .queueSize{font-size:var(--font-caption);line-height:var(--font-caption);margin-top:calc(var(--app-pane-padding) / 2);border-radius:2px;padding:calc(var(--app-pane-padding) / 4) calc(var(--app-pane-padding) / 2);background-color:rgba(var(--color-white-rgb),.2)}:host #eo-upload-overlay .batch-dialog{max-width:350px}:host #eo-upload-overlay .batch-dialog .actions{display:flex;padding-top:var(--app-pane-padding);justify-content:flex-end}:host #eo-upload-overlay .batch-dialog .actions button{margin:0 calc(var(--app-pane-padding) / 4)}:host #eo-upload-overlay .contents{display:none;flex-flow:row wrap;margin:var(--app-pane-padding);max-width:100%;max-height:100%;width:100%;height:100%}:host #eo-upload-overlay .targets{order:1;margin:0 calc(var(--app-pane-padding) / 2);display:flex;flex-flow:column;justify-content:center;position:relative}:host #eo-upload-overlay .targets .target-list{animation:eoFadeInRight var(--app-default-transition-duration);overflow-y:auto}:host #eo-upload-overlay .targets .target-list h2{font-size:var(--font-subhead);font-weight:400}:host #eo-upload-overlay .targets .target-list .upload-target{background:rgba(var(--color-accent),.6);border:1px solid rgba(var(--color-white-rgb),.4);margin:calc(var(--app-pane-padding) / 2) 0;padding:calc(var(--app-pane-padding) / 2);border-radius:2px;transition:all var(--app-default-transition-duration) ease-in-out;-webkit-transition:all var(--app-default-transition-duration) ease-in-out;-moz-transition:all var(--app-default-transition-duration) ease-in-out;-o-transition:all var(--app-default-transition-duration) ease-in-out;display:flex;cursor:pointer;flex-flow:row nowrap;align-items:center}:host #eo-upload-overlay .targets .target-list .upload-target eo-icon{flex:0 0 auto;margin:0 calc(var(--app-pane-padding) / 2)}:host #eo-upload-overlay .targets .target-list .upload-target>div{flex:1 1 auto;margin:0 calc(var(--app-pane-padding) / 2);overflow-x:hidden;text-overflow:ellipsis;white-space:nowrap;padding:0 calc(var(--app-pane-padding) / 2)}:host #eo-upload-overlay .targets .target-list .upload-target>div .name{font-size:var(--font-subhead);overflow-x:hidden;text-overflow:ellipsis;white-space:nowrap}:host #eo-upload-overlay .targets .target-list .upload-target>div .description{width:100%;max-width:250px;overflow-x:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:var(--font-caption);opacity:.7}:host #eo-upload-overlay .targets .target-list .upload-target:hover{background-color:var(--color-accent)}:host #eo-upload-overlay .files{padding:calc(var(--app-pane-padding) / 4);margin:0 calc(var(--app-pane-padding) / 2);overflow-y:auto;border-radius:2px;max-width:150px;width:95%;min-width:25%;animation:eoFadeInLeft var(--app-default-transition-duration);display:flex;flex-flow:column;justify-content:center}:host #eo-upload-overlay .files .files-list{height:100%;width:100%}:host #eo-upload-overlay .files .files-list .file-item{display:flex;align-items:center;cursor:default;padding:calc(var(--app-pane-padding) / 2) calc(var(--app-pane-padding) / 4);margin-bottom:calc(var(--app-pane-padding) / 4);background-color:rgba(var(--color-white-rgb),.1);-webkit-user-select:none;user-select:none}:host #eo-upload-overlay .files .files-list .file-item>div{flex:1 1 auto;padding:0 calc(var(--app-pane-padding) / 2);overflow-x:hidden;text-overflow:ellipsis;white-space:nowrap}:host #eo-upload-overlay .files .files-list .file-item>div .name{font-size:var(--font-subhead);overflow-x:hidden;text-overflow:ellipsis;white-space:nowrap}:host #eo-upload-overlay .files .files-list .file-item>div .desc{color:rgba(var(--color-white-rgb),.75);font-size:var(--font-hint);margin-top:calc(var(--app-pane-padding) / 4)}:host #eo-upload-overlay .files .files-list .file-item>div .size{border-radius:2px;display:inline-block;padding:0 4px;background-color:rgba(var(--color-white-rgb),.2)}:host #eo-upload-overlay .files .files-list .file-item eo-icon{flex:0 0 auto;width:18px;height:18px;padding:calc(var(--app-pane-padding) / 2)}:host #eo-upload-overlay.invalid>h1,:host #eo-upload-overlay.invalid .uploady{display:none}:host #eo-upload-overlay.file .uploady{display:none}:host #eo-upload-overlay.file .contents{flex-flow:row-reverse;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;flex:1 1;flex-direction:row-reverse}:host #eo-upload-overlay.file .contents .section{display:flow-root;width:25%;min-width:200px;flex:0 0 auto;max-height:fit-content;overflow:hidden;box-sizing:content-box}:host #eo-upload-overlay.file .contents .targets{order:0;margin-bottom:var(--app-pane-padding)}:host #eo-upload-overlay.uploading h1,:host #eo-upload-overlay.uploading .close{display:none}@keyframes uploady{0%{transform:translateY(0);opacity:.1}50%{transform:translateY(-40px);opacity:.3}to{transform:translateY(0);opacity:.1}}::ng-deep eo-simple-accordion{display:flex;flex-flow:column;flex:0 0 auto}::ng-deep eo-simple-accordion:not(.selected){margin-bottom:var(--app-pane-padding)}::ng-deep eo-simple-accordion>section{min-height:50px;max-height:190px;overflow-y:auto;overflow-x:hidden}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i5.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i6.EoIconComponent, selector: "eo-icon", inputs: ["objectType", "iconId", "iconSrc", "badge", "iconTitle"] }, { kind: "component", type: i7.LoadingSpinnerComponent, selector: "eo-loading-spinner", inputs: ["size", "mode"] }, { kind: "component", type: i8.SimpleAccordionComponent, selector: "eo-simple-accordion", inputs: ["header", "item", "styles", "headerClass", "selected"], outputs: ["selectChange"] }, { kind: "pipe", type: i5.TranslatePipe, name: "translate" }, { kind: "pipe", type: i9.FileSizePipe, name: "fileSize" }] }); }
|
|
389
460
|
}
|
|
390
461
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.4", ngImport: i0, type: UploadOverlayComponent, decorators: [{
|
|
391
462
|
type: Component,
|
|
392
|
-
args: [{ selector: 'eo-upload-overlay', template: "<div id=\"eo-upload-overlay\" #overlay class=\"dark\" *ngIf=\"fileOver\" tabindex=\"1\"\n [ngClass]=\"{hasFiles: queue.length, invalid: invalidInput, singleFile: queue.length === 1, uploading: isUploading}\">\n\n <eo-icon class=\"button white close\" [iconSrc]=\"'assets/_default/svg/ic_clear.svg'\" (click)=\"close()\"></eo-icon>\n\n <div class=\"count\">\n <div>{{queue.length}}</div>\n <div class=\"queueSize\">{{queueSize | fileSize}}</div>\n </div>\n\n <h1 translate>eo.upload.global.headline</h1>\n <eo-icon class=\"uploady\" [iconSrc]=\"'assets/_default/svg/ic_upload.svg'\"></eo-icon>\n\n <!-- batch upload dialog -->\n <div class=\"batch-dialog\" *ngIf=\"!invalidInput && selectedUploadTarget && !isUploading\">\n\n <h2 translate>eo.upload.global.choose.title</h2>\n <p translate>eo.upload.global.choose.message</p>\n <div class=\"actions\">\n <button (click)=\"resetSelectedUploadTarget()\" translate>eo.cta.button.cancel</button>\n <button (click)=\"proceedWithSelectedTarget(false)\" class=\"primary\" translate>eo.upload.global.choose.single</button>\n <button (click)=\"proceedWithSelectedTarget(true)\" class=\"primary\" translate>eo.upload.global.choose.multi</button>\n </div>\n </div>\n\n <!-- invalid input dialog -->\n <div class=\"batch-dialog\" *ngIf=\"hasValidUploadTargets && invalidInput\">\n\n <h2 translate>eo.upload.global.invalid.title</h2>\n <p translate>eo.upload.global.invalid.message</p>\n <div class=\"actions\">\n <button (click)=\"close()\" translate>eo.upload.global.close</button>\n </div>\n </div>\n\n <!-- no upload targets available -->\n <div class=\"batch-dialog\" *ngIf=\"!hasValidUploadTargets\">\n\n <h2 translate>eo.upload.global.notarget.title</h2>\n <p translate>eo.upload.global.notarget.message</p>\n <div class=\"actions\">\n <button (click)=\"close()\" translate>eo.upload.global.close</button>\n </div>\n </div>\n\n <div class=\"contents\" *ngIf=\"hasValidUploadTargets && !invalidInput && !selectedUploadTarget && !isUploading\">\n\n <!-- list of available upload targets -->\n <div class=\"targets\">\n\n <div class=\"target-list\">\n\n <div class=\"upload-target\" *ngFor=\"let t of validUploadTargets; trackBy: targetTrackByFn\"\n (click)=\"proceedWithUpload(t)\"\n [ngSwitch]=\"t.type\">\n\n <!-- upload to root -->\n <ng-container *ngSwitchCase=\"'root'\" >\n <eo-icon [iconSrc]=\"'assets/_default/svg/ic_create_document.svg'\"></eo-icon>\n <div class=\"upload-target-general\">\n <div class=\"name\" translate>eo.upload.global.root.title</div>\n <div class=\"description\" translate>eo.upload.global.root.description</div>\n </div>\n </ng-container>\n\n <!-- replace file of a specific dms object -->\n <ng-container *ngSwitchCase=\"'object'\">\n <eo-icon [iconSrc]=\"'assets/_default/svg/ic_document_file.svg'\"></eo-icon>\n <div class=\"upload-target-replace\">\n <div class=\"name\" translate>eo.upload.global.object.title</div>\n <div class=\"description\">{{t.description}}</div>\n </div>\n </ng-container>\n\n <!-- add new files to a context folder -->\n <ng-container *ngSwitchCase=\"'context'\">\n <eo-icon [iconSrc]=\"'assets/_default/svg/ic_create_document_in_folder.svg'\"></eo-icon>\n <div class=\"upload-target-context\">\n <div class=\"name\">{{'eo.upload.global.context.title'|translate:({context:t.referenceObject.type.label})}}</div>\n <div class=\"description\">{{t.description}}</div>\n </div>\n </ng-container>\n\n <!-- add new files to a context folder structure tree entry -->\n <ng-container *ngSwitchCase=\"'contexttree'\">\n <eo-icon [iconSrc]=\"'assets/_default/svg/ic_create_document_in_folder.svg'\"></eo-icon>\n <div class=\"upload-target-contexttree\">\n <div class=\"name\">{{'eo.add.title.location.subfolder'|translate: ({folder: t.subFolder.name})}}</div>\n </div>\n </ng-container>\n\n <!-- custom upload target (e.g. from plugin component) -->\n <ng-container *ngSwitchCase=\"'custom'\">\n <eo-icon [iconSrc]=\"'assets/_default/svg/ic_upload.svg'\"></eo-icon>\n <div class=\"upload-target-custom\">\n <div class=\"name\">{{t.name}}</div>\n <div class=\"description\">{{t.description}}</div>\n </div>\n </ng-container>\n </div>\n\n </div>\n\n </div>\n\n <!-- list of files dragged to the component -->\n <div class=\"files\">\n <div class=\"files-list\">\n <div class=\"file-item\" *ngFor=\"let i of queue; trackBy: trackByFn\">\n <div>\n <div class=\"name\">{{i.name}}</div>\n <div class=\"desc\"><span class=\"size\">{{i.size | fileSize}}</span><span class=\"desc-text\"> {{i.type}}</span></div>\n </div>\n <eo-icon class=\"button white\" (click)=\"removeFileItem(i)\" [iconSrc]=\"'assets/_default/svg/ic_clear.svg'\"></eo-icon>\n </div>\n </div>\n </div>\n\n </div>\n\n <div class=\"loading\" *ngIf=\"isUploading\"><eo-loading-spinner [size]=\"'large'\"></eo-loading-spinner></div>\n\n\n</div>\n", styles: [":host #eo-upload-overlay{position:absolute;inset:0;z-index:9900;background-color:rgba(var(--color-black-rgb),.85);animation:eoFadeIn var(--app-default-transition-duration);display:flex;flex-flow:column;align-items:center;justify-content:center;color:var(--color-white);overflow:auto}:host #eo-upload-overlay h1{font-size:4em;font-weight:300;color:rgba(var(--color-white-rgb),.5);animation:eoFadeInDown var(--app-default-transition-duration)}:host #eo-upload-overlay .uploady{animation:uploady 2s linear infinite;width:20vw;height:20vw;display:block}:host #eo-upload-overlay .close{position:absolute;right:var(--app-pane-padding);top:var(--app-pane-padding)}:host #eo-upload-overlay .count{position:absolute;display:none;right:calc(var(--app-pane-padding) * 3);top:calc(var(--app-pane-padding) * 3);font-size:10vh;flex-flow:column;align-items:flex-end;line-height:1em;animation:eoFadeInDown var(--app-default-transition-duration)}:host #eo-upload-overlay .count .queueSize{font-size:var(--font-caption);line-height:var(--font-caption);margin-top:calc(var(--app-pane-padding) / 2);border-radius:2px;padding:calc(var(--app-pane-padding) / 4) calc(var(--app-pane-padding) / 2);background-color:rgba(var(--color-white-rgb),.2)}:host #eo-upload-overlay .batch-dialog{max-width:350px}:host #eo-upload-overlay .batch-dialog .actions{display:flex;padding-top:var(--app-pane-padding);justify-content:flex-end}:host #eo-upload-overlay .batch-dialog .actions button{margin:0 calc(var(--app-pane-padding) / 4)}:host #eo-upload-overlay .contents{display:none;flex-flow:row wrap;max-height:100%;margin:var(--app-pane-padding)}:host #eo-upload-overlay .targets{order:1;margin:0 calc(var(--app-pane-padding) / 2);display:flex;flex-flow:column;justify-content:center;position:relative}:host #eo-upload-overlay .targets .target-list{animation:eoFadeInRight var(--app-default-transition-duration);overflow-y:auto}:host #eo-upload-overlay .targets .target-list h2{font-size:var(--font-subhead);font-weight:400}:host #eo-upload-overlay .targets .target-list .upload-target{background:rgba(var(--color-accent),.6);border:1px solid rgba(var(--color-white-rgb),.4);margin:calc(var(--app-pane-padding) / 2) 0;padding:calc(var(--app-pane-padding) / 2);border-radius:2px;transition:all var(--app-default-transition-duration) ease-in-out;-webkit-transition:all var(--app-default-transition-duration) ease-in-out;-moz-transition:all var(--app-default-transition-duration) ease-in-out;-o-transition:all var(--app-default-transition-duration) ease-in-out;display:flex;cursor:pointer;flex-flow:row nowrap;align-items:center}:host #eo-upload-overlay .targets .target-list .upload-target eo-icon{flex:0 0 auto;margin:0 calc(var(--app-pane-padding) / 2)}:host #eo-upload-overlay .targets .target-list .upload-target>div{flex:1 1 auto;margin:0 calc(var(--app-pane-padding) / 2)}:host #eo-upload-overlay .targets .target-list .upload-target>div .name{font-size:var(--font-subhead)}:host #eo-upload-overlay .targets .target-list .upload-target>div .description{font-size:var(--font-caption);opacity:.7}:host #eo-upload-overlay .targets .target-list .upload-target:hover{background-color:var(--color-accent)}:host #eo-upload-overlay .files{order:0;padding:calc(var(--app-pane-padding) / 4);margin:0 calc(var(--app-pane-padding) / 2);overflow-y:auto;border-radius:2px;animation:eoFadeInLeft var(--app-default-transition-duration);display:flex;flex-flow:column;justify-content:center}:host #eo-upload-overlay .files .files-list{height:100%}:host #eo-upload-overlay .files .files-list .file-item{display:flex;flex-flow:row nowrap;align-items:center;cursor:default;padding:calc(var(--app-pane-padding) / 2) calc(var(--app-pane-padding) / 4);margin-bottom:calc(var(--app-pane-padding) / 4);background-color:rgba(var(--color-white-rgb),.1);-webkit-user-select:none;user-select:none}:host #eo-upload-overlay .files .files-list .file-item>div{flex:1 1 auto;padding:0 calc(var(--app-pane-padding) / 2)}:host #eo-upload-overlay .files .files-list .file-item>div .desc{color:rgba(var(--color-white-rgb),.75);font-size:var(--font-hint);margin-top:calc(var(--app-pane-padding) / 4)}:host #eo-upload-overlay .files .files-list .file-item>div .size{border-radius:2px;display:inline-block;padding:0 4px;background-color:rgba(var(--color-white-rgb),.2)}:host #eo-upload-overlay .files .files-list .file-item eo-icon{flex:0 0 auto;width:18px;height:18px;padding:calc(var(--app-pane-padding) / 2)}:host #eo-upload-overlay.invalid>h1,:host #eo-upload-overlay.invalid .uploady{display:none}:host #eo-upload-overlay.hasFiles .uploady{display:none}:host #eo-upload-overlay.hasFiles .count{display:flex}:host #eo-upload-overlay.hasFiles .contents{display:flex}:host #eo-upload-overlay.singleFile .contents{flex-flow:column}:host #eo-upload-overlay.singleFile .contents .files{padding:0;order:1}:host #eo-upload-overlay.singleFile .contents .targets{order:0;margin-bottom:var(--app-pane-padding)}:host #eo-upload-overlay.uploading h1,:host #eo-upload-overlay.uploading .close{display:none}@keyframes uploady{0%{transform:translateY(0);opacity:.1}50%{transform:translateY(-40px);opacity:.3}to{transform:translateY(0);opacity:.1}}\n"] }]
|
|
393
|
-
}], ctorParameters: () => [{ type: i1.Router }, { type: i0.Renderer2 }, { type: i2.PrepareService }, { type: i2.TranslateService }, { type: i2.SystemService }, { type: i2.EventService }, { type: i2.UploadRegistryService }], propDecorators: { overlayEl: [{
|
|
463
|
+
args: [{ selector: 'eo-upload-overlay', template: "<div id=\"eo-upload-overlay\" #overlay class=\"dark\" *ngIf=\"fileOver\" tabindex=\"1\"\n [ngClass]=\"{file: queue.length, invalid: invalidInput, uploading: isUploading}\">\n\n <eo-icon class=\"button white close\" [iconSrc]=\"'assets/_default/svg/ic_clear.svg'\" (click)=\"close()\"></eo-icon>\n\n <div class=\"count\">\n <div>{{queue.length}}</div>\n <div class=\"queueSize\">{{queueSize | fileSize}}</div>\n </div>\n\n <div class=\"headline\">\n <h1 translate>eo.upload.global.headline</h1>\n </div>\n \n <eo-icon class=\"uploady\" [iconSrc]=\"'assets/_default/svg/ic_upload.svg'\"></eo-icon>\n\n <!-- batch upload dialog -->\n <div class=\"batch-dialog\" *ngIf=\"!invalidInput && selectedUploadTarget && !isUploading\">\n\n <h2 translate>eo.upload.global.choose.title</h2>\n <p translate>eo.upload.global.choose.message</p>\n <div class=\"actions\">\n <button (click)=\"resetSelectedUploadTarget()\" translate>eo.cta.button.cancel</button>\n <button (click)=\"proceedWithSelectedTarget(false)\" class=\"primary\"\n translate>eo.upload.global.choose.single</button>\n <button (click)=\"proceedWithSelectedTarget(true)\" class=\"primary\" translate>eo.upload.global.choose.multi</button>\n </div>\n </div>\n\n <!-- invalid input dialog -->\n <div class=\"batch-dialog\" *ngIf=\"hasValidUploadTargets && invalidInput\">\n\n <h2 translate>eo.upload.global.invalid.title</h2>\n <p translate>eo.upload.global.invalid.message</p>\n <div class=\"actions\">\n <button (click)=\"close()\" translate>eo.upload.global.close</button>\n </div>\n </div>\n\n <!-- no upload targets available -->\n <div class=\"batch-dialog\" *ngIf=\"!hasValidUploadTargets\">\n\n <h2 translate>eo.upload.global.notarget.title</h2>\n <p translate>eo.upload.global.notarget.message</p>\n <div class=\"actions\">\n <button (click)=\"close()\" translate>eo.upload.global.close</button>\n </div>\n </div>\n\n <div class=\"contents\" *ngIf=\"hasValidUploadTargets && !invalidInput && !selectedUploadTarget && !isUploading\">\n\n <div class=\"section\">\n <!-- list of available upload targets -->\n <div class=\"targets\">\n <div class=\"target-list\">\n @for (targetType of targetTypes; track targetType.type) {\n @for (t of validUploadTargets; track t.id) {\n @if (t.type === targetType.type) {\n <ng-container *ngTemplateOutlet=\"uploadTargetTemplate; context: {\n iconSrc: targetType.iconSrc,\n targetClass: targetType.targetClass,\n name: targetType.type === 'custom' ? t.name : (targetType.type === 'context' ? (targetType.name | translate : { context: t.referenceObject.type.label }) : (targetType. name | translate)),\n description: targetType.type === 'custom' || targetType.type === 'object' || targetType. type === 'context' ? t.description : (targetType.description | translate),\n targets: t\n }\">\n </ng-container>\n }\n }\n }\n </div>\n </div>\n\n <!-- upload to favorite -->\n @if (folderFavorites.length > 0) {\n <eo-simple-accordion [selected]=\"favoritesAccSelected\" [header]=\"'eo.upload.global.context.favorite' | translate\"\n (selectChange)=\"onFavoriteToggle($event)\">\n <div class=\"targets\">\n <div class=\"target-list\">\n @for (t of validUploadTargets; track $index) {\n @if (t.type === 'favorite') {\n <div class=\"upload-target\" (click)=\"proceedWithUpload(t)\">\n <ng-container>\n <eo-icon [iconId]=\"t.iconId\"></eo-icon>\n <div class=\"upload-target-favorite\">\n <div class=\"name\">{{t.title}}\n <div class=\"description\">{{t.description}}</div>\n </div>\n </div>\n </ng-container>\n </div>\n }\n }\n </div>\n </div>\n </eo-simple-accordion>\n }\n\n @if(lastOpenedFolder.length > 0){\n <eo-simple-accordion [selected]=\"agentAccSelected\" [header]=\"'eo.upload.global.context.agent' | translate\"\n (selectChange)=\"onAgentToggle($event)\">\n <!-- upload to last opened folder -->\n <div class=\"targets\">\n <div class=\"target-list\">\n @for (t of validUploadTargets; track $index) {\n @if (t.type === 'agent') {\n <div class=\"upload-target\" (click)=\"proceedWithUpload(t)\">\n <ng-container>\n <eo-icon [iconId]=\"t.iconId\"></eo-icon>\n <div class=\"upload-target-agent\">\n <div class=\"name\">{{t?.title}}\n <div class=\"description\">{{t?.description}}</div>\n </div>\n </div>\n </ng-container>\n </div>\n }\n }\n </div>\n </div>\n </eo-simple-accordion>\n }\n </div>\n <!-- list of files dragged to the component -->\n <div class=\"files\" [ngClass]=\"{file: queue.length, invalid: invalidInput, uploading: isUploading}\">\n <div class=\"files-list\">\n @for (i of queue; track $index) {\n <div class=\"file-item\">\n <div>\n <div class=\"name\">{{i.name}}</div>\n <div class=\"desc\"><span class=\"size\">{{i.size | fileSize}}</span>\n <span class=\"desc-text\"> {{i.type}}</span></div>\n </div>\n <eo-icon class=\"button white\" (click)=\"removeFileItem(i)\"\n [iconSrc]=\"'assets/_default/svg/ic_clear.svg'\"></eo-icon>\n </div>\n }\n </div>\n </div>\n </div>\n\n @if (isUploading) {\n <div class=\"loading\">\n <eo-loading-spinner [size]=\"'large'\"></eo-loading-spinner>\n </div>\n }\n</div>\n\n<ng-template #uploadTargetTemplate let-iconSrc=\"iconSrc\" let-targetClass=\"targetClass\" let-name=\"name\"\n let-description=\"description\" let-targets=\"targets\">\n <div class=\"upload-target\" (click)=\"proceedWithUpload(targets)\">\n <ng-container>\n <eo-icon [iconSrc]=\"iconSrc\"></eo-icon>\n <div [ngClass]=\"targetClass\">\n <div class=\"name\">{{ name }}</div>\n <div class=\"description\">{{ description }}</div>\n </div>\n </ng-container>\n </div>\n</ng-template>\n", styles: [":host #eo-upload-overlay{position:absolute;inset:0;z-index:9900;background-color:rgba(var(--color-black-rgb),.85);animation:eoFadeIn var(--app-default-transition-duration);display:flex;flex-flow:column;align-items:center;justify-content:center;color:var(--color-white);overflow:hidden}:host #eo-upload-overlay .headline{display:flex;width:100%;min-width:200px;justify-content:center;overflow:hidden;align-content:center;flex-wrap:wrap}:host #eo-upload-overlay .headline h1{font-size:4em;font-weight:var(--font-weight-light);color:rgba(var(--color-white-rgb),.5);animation:eoFadeInDown var(--app-default-transition-duration);overflow-x:hidden;text-overflow:ellipsis;white-space:nowrap}:host #eo-upload-overlay .uploady{animation:uploady 2s linear infinite;width:20vw;height:20vw;display:block}:host #eo-upload-overlay .close{position:absolute;right:var(--app-pane-padding);top:var(--app-pane-padding)}:host #eo-upload-overlay .count{position:absolute;display:none;right:calc(var(--app-pane-padding) * 3);top:calc(var(--app-pane-padding) * 3);font-size:10vh;flex-flow:column;align-items:flex-end;line-height:1em;animation:eoFadeInDown var(--app-default-transition-duration)}:host #eo-upload-overlay .count .queueSize{font-size:var(--font-caption);line-height:var(--font-caption);margin-top:calc(var(--app-pane-padding) / 2);border-radius:2px;padding:calc(var(--app-pane-padding) / 4) calc(var(--app-pane-padding) / 2);background-color:rgba(var(--color-white-rgb),.2)}:host #eo-upload-overlay .batch-dialog{max-width:350px}:host #eo-upload-overlay .batch-dialog .actions{display:flex;padding-top:var(--app-pane-padding);justify-content:flex-end}:host #eo-upload-overlay .batch-dialog .actions button{margin:0 calc(var(--app-pane-padding) / 4)}:host #eo-upload-overlay .contents{display:none;flex-flow:row wrap;margin:var(--app-pane-padding);max-width:100%;max-height:100%;width:100%;height:100%}:host #eo-upload-overlay .targets{order:1;margin:0 calc(var(--app-pane-padding) / 2);display:flex;flex-flow:column;justify-content:center;position:relative}:host #eo-upload-overlay .targets .target-list{animation:eoFadeInRight var(--app-default-transition-duration);overflow-y:auto}:host #eo-upload-overlay .targets .target-list h2{font-size:var(--font-subhead);font-weight:400}:host #eo-upload-overlay .targets .target-list .upload-target{background:rgba(var(--color-accent),.6);border:1px solid rgba(var(--color-white-rgb),.4);margin:calc(var(--app-pane-padding) / 2) 0;padding:calc(var(--app-pane-padding) / 2);border-radius:2px;transition:all var(--app-default-transition-duration) ease-in-out;-webkit-transition:all var(--app-default-transition-duration) ease-in-out;-moz-transition:all var(--app-default-transition-duration) ease-in-out;-o-transition:all var(--app-default-transition-duration) ease-in-out;display:flex;cursor:pointer;flex-flow:row nowrap;align-items:center}:host #eo-upload-overlay .targets .target-list .upload-target eo-icon{flex:0 0 auto;margin:0 calc(var(--app-pane-padding) / 2)}:host #eo-upload-overlay .targets .target-list .upload-target>div{flex:1 1 auto;margin:0 calc(var(--app-pane-padding) / 2);overflow-x:hidden;text-overflow:ellipsis;white-space:nowrap;padding:0 calc(var(--app-pane-padding) / 2)}:host #eo-upload-overlay .targets .target-list .upload-target>div .name{font-size:var(--font-subhead);overflow-x:hidden;text-overflow:ellipsis;white-space:nowrap}:host #eo-upload-overlay .targets .target-list .upload-target>div .description{width:100%;max-width:250px;overflow-x:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:var(--font-caption);opacity:.7}:host #eo-upload-overlay .targets .target-list .upload-target:hover{background-color:var(--color-accent)}:host #eo-upload-overlay .files{padding:calc(var(--app-pane-padding) / 4);margin:0 calc(var(--app-pane-padding) / 2);overflow-y:auto;border-radius:2px;max-width:150px;width:95%;min-width:25%;animation:eoFadeInLeft var(--app-default-transition-duration);display:flex;flex-flow:column;justify-content:center}:host #eo-upload-overlay .files .files-list{height:100%;width:100%}:host #eo-upload-overlay .files .files-list .file-item{display:flex;align-items:center;cursor:default;padding:calc(var(--app-pane-padding) / 2) calc(var(--app-pane-padding) / 4);margin-bottom:calc(var(--app-pane-padding) / 4);background-color:rgba(var(--color-white-rgb),.1);-webkit-user-select:none;user-select:none}:host #eo-upload-overlay .files .files-list .file-item>div{flex:1 1 auto;padding:0 calc(var(--app-pane-padding) / 2);overflow-x:hidden;text-overflow:ellipsis;white-space:nowrap}:host #eo-upload-overlay .files .files-list .file-item>div .name{font-size:var(--font-subhead);overflow-x:hidden;text-overflow:ellipsis;white-space:nowrap}:host #eo-upload-overlay .files .files-list .file-item>div .desc{color:rgba(var(--color-white-rgb),.75);font-size:var(--font-hint);margin-top:calc(var(--app-pane-padding) / 4)}:host #eo-upload-overlay .files .files-list .file-item>div .size{border-radius:2px;display:inline-block;padding:0 4px;background-color:rgba(var(--color-white-rgb),.2)}:host #eo-upload-overlay .files .files-list .file-item eo-icon{flex:0 0 auto;width:18px;height:18px;padding:calc(var(--app-pane-padding) / 2)}:host #eo-upload-overlay.invalid>h1,:host #eo-upload-overlay.invalid .uploady{display:none}:host #eo-upload-overlay.file .uploady{display:none}:host #eo-upload-overlay.file .contents{flex-flow:row-reverse;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;flex:1 1;flex-direction:row-reverse}:host #eo-upload-overlay.file .contents .section{display:flow-root;width:25%;min-width:200px;flex:0 0 auto;max-height:fit-content;overflow:hidden;box-sizing:content-box}:host #eo-upload-overlay.file .contents .targets{order:0;margin-bottom:var(--app-pane-padding)}:host #eo-upload-overlay.uploading h1,:host #eo-upload-overlay.uploading .close{display:none}@keyframes uploady{0%{transform:translateY(0);opacity:.1}50%{transform:translateY(-40px);opacity:.3}to{transform:translateY(0);opacity:.1}}::ng-deep eo-simple-accordion{display:flex;flex-flow:column;flex:0 0 auto}::ng-deep eo-simple-accordion:not(.selected){margin-bottom:var(--app-pane-padding)}::ng-deep eo-simple-accordion>section{min-height:50px;max-height:190px;overflow-y:auto;overflow-x:hidden}\n"] }]
|
|
464
|
+
}], ctorParameters: () => [{ type: i1.Router }, { type: i0.Renderer2 }, { type: i2.PrepareService }, { type: i2.TranslateService }, { type: i2.UserService }, { type: i3.AgentService }, { type: i2.SystemService }, { type: i2.EventService }, { type: i2.LocalStorageService }, { type: i2.UploadRegistryService }], propDecorators: { overlayEl: [{
|
|
394
465
|
type: ViewChild,
|
|
395
466
|
args: ['overlay']
|
|
396
467
|
}] } });
|
|
397
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload-overlay.component.js","sourceRoot":"","sources":["../../../../../../../src/app/eo-framework/upload-overlay/upload-overlay.component.ts","../../../../../../../src/app/eo-framework/upload-overlay/upload-overlay.component.html"],"names":[],"mappings":"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","sourcesContent":["import {of as observableOf, forkJoin as observableForkJoin, Observable} from 'rxjs';\nimport {Component, OnInit, Renderer2, ViewChild, ElementRef, OnDestroy, HostListener} from '@angular/core';\nimport {Router} from '@angular/router';\nimport {\n  ObjectType,\n  EventService,\n  EnaioEvent,\n  UploadRegistryService,\n  UploadTarget,\n  UploadFileItem,\n  PrepareService,\n  Utils,\n  TranslateService,\n  EnvironmentEnaio, SystemService\n} from '@eo-sdk/core';\n\n@Component({\n  selector: 'eo-upload-overlay',\n  templateUrl: './upload-overlay.component.html',\n  styleUrls: ['./upload-overlay.component.scss']\n})\nexport class UploadOverlayComponent implements OnInit, OnDestroy {\n\n  @ViewChild('overlay') overlayEl: ElementRef;\n\n  queue: UploadFileItem[] = [];\n  fileOver: boolean;\n  isUploading: boolean;\n  hasValidUploadTargets: boolean;\n  invalidInput: boolean;\n  queueSize: number;\n  validUploadTargets: UploadTarget[] = [];\n  selectedUploadTarget: UploadTarget;\n\n  private uploadTargets: UploadTarget[] = [];\n  private dragLeaveListener: Function;\n  private dropListener: Function;\n  private dragOverListener: Function;\n  private escKeyListener: Function;\n  private dragEnterListener: Function;\n  private pasteListener: Function;\n  private dragEventCount = 0;\n\n  constructor(private router: Router,\n              private renderer: Renderer2,\n              private prepareService: PrepareService,\n              private translate: TranslateService,\n              private systemService: SystemService,\n              private eventService: EventService,\n              private uploadRegistry: UploadRegistryService) {\n  }\n\n  private init() {\n\n    // global drag&drop upload will only be available on desktop (web or electron)\n    if (EnvironmentEnaio.isMobileEnvironment()) {\n      return false;\n    }\n\n    // subscribe for the list of registered upload targets\n    this.uploadRegistry.uploadTargets$.subscribe((uploadTargets: UploadTarget[]) => {\n      this.uploadTargets = uploadTargets;\n    });\n\n    this.pasteListener = this.renderer.listen('document', 'paste', (e: ClipboardEvent) => {\n      this.onPaste(e);\n    });\n\n    this.dragEnterListener = this.renderer.listen('document', 'dragenter', (e: DragEvent) => {\n      this.onDragEnter(e);\n    });\n  }\n\n  private onPaste(e: ClipboardEvent) {\n    if (this.isUploading) {\n      return false;\n    }\n    this.hasValidUploadTargets = true;\n    this.invalidInput = false;\n    if (!this.fileOver && this.pasteContainsFiles(e)) {\n      let transfer = e.clipboardData;\n      if (!transfer) {\n        return;\n      }\n\n      // check for directories\n      for (let i = 0; i < transfer.items.length; i++) {\n        if (transfer.items[i].kind === 'string') {\n          this.invalidInput = true;\n          return;\n        }\n        const fe = transfer.items[i].webkitGetAsEntry();\n        if (fe && fe.isDirectory) {\n            this.invalidInput = true;\n            return;\n        }\n      }\n      if (!this.invalidInput) {\n        this._preventAndStop(e);\n        this.setFileOver(true);\n        this.onFilesDropped(Array.from(transfer.files));\n      }\n    }\n  }\n\n  private onDragEnter(e: DragEvent) {\n    if (this.isUploading) {\n      return false;\n    }\n    this.hasValidUploadTargets = true;\n    if (!this.fileOver && this.dragContainsFiles(e)) {\n      this.dragEventCount = 0;\n      this.setFileOver(true);\n\n\n      // use timeout here to force angular digest cycle before continuing, because we are accessing dom elements\n      // that are not there (*ngIf) until fileOver is set to true.\n      setTimeout(() => {\n        // todo: replace by renderer solution when available (https://github.com/angular/angular/issues/15674)\n        this.overlayEl.nativeElement.focus();\n        // bind late (only, when needed) to dragleave event to avoid heavy processing on every drag event\n        this.dragLeaveListener = this.renderer.listen(this.overlayEl.nativeElement, 'dragleave', (evt) => {\n          this.dragEventCount--;\n          if (this.dragEventCount === 0) {\n            this.close();\n          }\n        });\n\n        this.dropListener = this.renderer.listen(this.overlayEl.nativeElement, 'drop', (evt) => {\n          let transfer = this._getTransfer(evt);\n          if (!transfer) {\n            return;\n          }\n          this._preventAndStop(evt);\n\n          // check for directories\n          for (let i = 0; i < transfer.items.length; i++) {\n            const fe = transfer.items[i].webkitGetAsEntry();\n            if (fe && fe.isDirectory) {\n              this.invalidInput = true;\n            }\n          }\n          if (!this.invalidInput) {\n            this.onFilesDropped(transfer.files);\n          }\n        });\n\n        this.dragOverListener = this.renderer.listen(this.overlayEl.nativeElement, 'dragover', (evt) => {\n          let transfer = this._getTransfer(evt);\n          if (!transfer) {\n            return;\n          }\n          transfer.dropEffect = 'copy';\n          this._preventAndStop(evt);\n        });\n      }, 0);\n    } else {\n      this.dragEventCount++;\n    }\n  }\n\n  private _getTransfer(event: any): any {\n    return event.dataTransfer ? event.dataTransfer : event.originalEvent.dataTransfer; // jQuery fix;\n  }\n\n  private _preventAndStop(event: any): any {\n    event.preventDefault();\n    event.stopPropagation();\n  }\n\n  private onFilesDropped(fileItems: File[]) {\n    // clear queue when new files are added\n    // todo: remove in future releases to support collective file adding\n    this.queue = [];\n    for (let file of fileItems) {\n      this.queue.push(new UploadFileItem(file));\n    }\n\n    // bind ESC key listener for closing the dialog as late as possible\n    if (!this.escKeyListener) {\n      this.escKeyListener = this.renderer.listen('document', 'keyup', (e) => {\n        e.stopPropagation();\n        if (e.keyCode === 27) {\n          this.close();\n        }\n      });\n    }\n    // calculate total size of queue\n    this.setQueueSize();\n    // filter available targets\n    this.validateUploadTargets();\n  }\n\n  /**\n   * Filter list of registered upload targets, so only valid targets will be shown.\n   */\n  private validateUploadTargets() {\n    this.hasValidUploadTargets = true;\n    observableForkJoin(this.uploadTargets.map(t => this.validateUploadTarget(t)))\n      .subscribe(\n        (res: { target: UploadTarget, valid: boolean }[]) => {\n          this.validUploadTargets = res.filter(r => r.valid).map(filtered => filtered.target).reverse().sort((a, b) => {\n            return a.type === 'context' ? -1 : b.type === 'context' ? 1 : 0; // Context should be on top\n          });\n        }, err => {\n          this.validUploadTargets = [];\n        }, () => {\n          this.hasValidUploadTargets = this.validUploadTargets.length > 0;\n        }\n      );\n  }\n\n  private validateUploadTarget(target: UploadTarget): Observable<{ target: UploadTarget, valid: boolean }> {\n\n    if (!this.queue) {\n      return observableOf({target: target, valid: false});\n    }\n\n    return Observable.create(o => {\n      let valid = false;\n\n      if (target.type === UploadTarget.ROOT) {\n\n        // todo: are there other restrictions on root target?\n        this.prepareService.getPrepareChildTypes(null, true)\n          .subscribe(\n            (res: { parent: string, types: ObjectType[] }) => {\n              valid = this.queue.length > 0 && res.types.length > 0;\n              o.next({target: target, valid: valid});\n              o.complete();\n            }, err => {\n              o.next({target: target, valid: false});\n              o.complete();\n            }\n          );\n      } else if (target.type === UploadTarget.OBJECT) {\n\n        // todo: check if the reference object supports the given file type\n        valid = target.referenceObject &&\n          target.referenceObject.type.maxFiles > 0 &&\n          !target.referenceObject.lock &&\n          !target.referenceObject.isFinalized &&\n          (target.referenceObject.rights && target.referenceObject.rights.edit) &&\n          this.queue.length === 1 &&\n          target.referenceObject.data.yuvsigstatus !== 'signed' &&\n          target.referenceObject.data.yuvsigstatus !== 'inprocess';\n        o.next({target: target, valid: valid});\n        o.complete();\n      } else if (target.type === UploadTarget.CONTEXT || target.type === UploadTarget.CONTEXT_TREE) {\n\n        // todo: add checks related to the reference object (e.g. allowed file types)\n        this.prepareService.getPrepareChildTypes(target.referenceObject.id, true)\n          .subscribe(\n            (res: { parent: string, types: ObjectType[] }) => {\n              valid = target.referenceObject && this.queue.length > 0 && res.types.length > 0;\n\n              // for CONTEXT_TREE targets also check if the desired node\n              // type is part of the prepare child types\n              if (target.type === UploadTarget.CONTEXT_TREE && target.subFolder) {\n                const subFolder: any = target.subFolder;\n                valid = !!res.types.find(t => this.systemService.implementsType(t, subFolder.data.type));\n              }\n\n              o.next({target: target, valid: valid});\n              o.complete();\n            }, err => {\n              o.next({target: target, valid: false});\n              o.complete();\n            }\n          );\n      } else {\n        o.next({target: target, valid: false});\n        o.complete();\n      }\n    });\n  }\n\n  /**\n   * Removes a file from the list of files to be uploaded.\n   * @param fileItem - the file item to be removed\n   */\n  public removeFileItem(fileItem: UploadFileItem) {\n\n    this.queue = this.queue.filter((f) => f.id !== fileItem.id);\n    if (!this.queue.length) {\n      this.close();\n    } else {\n      // update available upload targets because their validity\n      // may be based on the queue size\n      this.validateUploadTargets();\n      this.setQueueSize();\n    }\n  }\n\n  /**\n   * Proceed upload with a selected upload target.\n   * @param uploadTarget - the target to upload files to\n   */\n  public proceedWithUpload(uploadTarget: UploadTarget) {\n\n    if (uploadTarget.type !== UploadTarget.CUSTOM && this.queue.length > 1) {\n      // For more than one file to be uploaded to a none custom target, we let the user decide if\n      // batch upload should be used or not ...\n\n\n      this.selectedUploadTarget = uploadTarget;\n    } else if (uploadTarget.type === UploadTarget.OBJECT) {\n      // ... otherwise upload is started immediately\n      this.startUpload(uploadTarget, [null, this.getStateRoute()]);\n    } else {\n      this.startUpload(uploadTarget, [null, '/prepare']);\n    }\n  }\n\n  /**\n   * Proceed upload using the selected upload target.\n   * @param useBatchUpload - flag indicating whether or not to use batch upload\n   */\n  public proceedWithSelectedTarget(useBatchUpload: boolean) {\n    this.startUpload(this.selectedUploadTarget, [useBatchUpload, '/prepare']);\n  }\n\n  /**\n   * Resets the selected upload target.\n   */\n  public resetSelectedUploadTarget() {\n    this.selectedUploadTarget = null;\n  }\n\n  getStateRoute() {\n    return this.router.url;\n  }\n\n\n  private successfulUpload(target, uploadTarget) {\n    this.eventService.trigger(EnaioEvent.DMS_OBJECT_UPDATED, uploadTarget.referenceObject);\n    uploadTarget.onUploadSuccess(target);\n  }\n\n  /**\n   * Start the actual upload.\n   * @param uploadTarget - target to upload the files to\n   * @param useBatchUpload - flag indicating whether or not to use batch upload\n   */\n  private startUpload(uploadTarget: UploadTarget, [...args]) {\n\n    const [useBatchUpload, target] = args;\n\n    this.isUploading = true;\n    this.unbindListeners();\n    this.prepareService\n      .uploadToTarget(uploadTarget, this.queue, useBatchUpload)\n      .subscribe((res) => {\n          this.isUploading = false;\n          if (uploadTarget.subFolder && uploadTarget.subFolder.data.data) {\n            if (Array.isArray(res)) {\n              let obs = [];\n              res.forEach(r => {\n                obs.push(this.prepareService.updatePreparedItemIndexData(r.id, uploadTarget.subFolder.data.data));\n              });\n              observableForkJoin(obs).subscribe(() => this.successfulUpload(target, uploadTarget));\n            } else {\n              this.prepareService\n                .updatePreparedItemIndexData(res.id, uploadTarget.subFolder.data.data)\n                .subscribe(() => this.successfulUpload(target, uploadTarget));\n            }\n          } else {\n            this.successfulUpload(target, uploadTarget);\n          }\n          this.close();\n        }, Utils.throw(() => {\n          this.isUploading = false;\n          uploadTarget.onUploadFail();\n          this.close();\n        },\n        this.translate.instant('eo.upload.global.error.title'),\n        this.translate.instant('eo.upload.global.error.description'))\n      );\n    this.resetSelectedUploadTarget();\n  }\n\n  private setQueueSize() {\n    let s = 0;\n    for (let f of this.queue) {\n      s += f.size;\n    }\n    this.queueSize = s;\n  }\n\n  /**\n   * Close the upload overlay and release all bound resources.\n   */\n  close() {\n    // unbind bound event listener, when they are not needed anymore\n    this.unbindListeners();\n    // clear upload queue\n    this.queue = [];\n    // hide the overlay\n    this.setFileOver(false);\n    this.invalidInput = false;\n  }\n\n  private setFileOver(value: boolean) {\n    this.fileOver = value;\n    this.uploadRegistry.setOverlayActive(value);\n  }\n\n  private unbindListeners() {\n    if (this.dragLeaveListener) {\n      this.dragLeaveListener();\n      this.dragLeaveListener = null;\n    }\n    if (this.dragOverListener) {\n      this.dragOverListener();\n      this.dragOverListener = null;\n    }\n    if (this.dropListener) {\n      this.dropListener();\n      this.dropListener = null;\n    }\n    if (this.escKeyListener) {\n      this.escKeyListener();\n      this.escKeyListener = null;\n    }\n  }\n\n  /**\n   * Indicates whether or not the current drag event contains one or more files.\n   * @param event - the drag event to be checked\n   * @returns number of files\n   */\n   private dragContainsFiles(event: DragEvent): number {\n    return Array.from(event.dataTransfer.items || []).filter(i => i.kind === 'file').length;\n  }\n\n  /**\n   * Indicates whether or not the current paste event contains one or more files.\n   * @param event - the paste event to be checked\n   * @returns number of files\n   */\n  private pasteContainsFiles(event: ClipboardEvent): number {\n    return Array.from(event.clipboardData.items || []).filter(i => i.kind === 'file').length;\n  }\n\n  // ngFor tracking function for upload targets\n  targetTrackByFn(index, item) {\n    return item.id;\n  }\n\n  // ngFor tracking function for file items\n  trackByFn(index, item) {\n    return index;\n  }\n\n  ngOnInit() {\n    this.init();\n  }\n\n  ngOnDestroy() {\n    if (this.dragEnterListener) {\n      this.dragEnterListener();\n    }\n  }\n}\n","<div id=\"eo-upload-overlay\" #overlay class=\"dark\" *ngIf=\"fileOver\" tabindex=\"1\"\n     [ngClass]=\"{hasFiles: queue.length, invalid: invalidInput, singleFile: queue.length === 1, uploading: isUploading}\">\n\n  <eo-icon class=\"button white close\" [iconSrc]=\"'assets/_default/svg/ic_clear.svg'\" (click)=\"close()\"></eo-icon>\n\n  <div class=\"count\">\n    <div>{{queue.length}}</div>\n    <div class=\"queueSize\">{{queueSize | fileSize}}</div>\n  </div>\n\n  <h1 translate>eo.upload.global.headline</h1>\n  <eo-icon class=\"uploady\" [iconSrc]=\"'assets/_default/svg/ic_upload.svg'\"></eo-icon>\n\n  <!-- batch upload dialog -->\n  <div class=\"batch-dialog\" *ngIf=\"!invalidInput && selectedUploadTarget && !isUploading\">\n\n    <h2 translate>eo.upload.global.choose.title</h2>\n    <p translate>eo.upload.global.choose.message</p>\n    <div class=\"actions\">\n      <button (click)=\"resetSelectedUploadTarget()\" translate>eo.cta.button.cancel</button>\n      <button (click)=\"proceedWithSelectedTarget(false)\" class=\"primary\" translate>eo.upload.global.choose.single</button>\n      <button (click)=\"proceedWithSelectedTarget(true)\" class=\"primary\" translate>eo.upload.global.choose.multi</button>\n    </div>\n  </div>\n\n  <!-- invalid input dialog -->\n  <div class=\"batch-dialog\" *ngIf=\"hasValidUploadTargets && invalidInput\">\n\n    <h2 translate>eo.upload.global.invalid.title</h2>\n    <p translate>eo.upload.global.invalid.message</p>\n    <div class=\"actions\">\n      <button (click)=\"close()\" translate>eo.upload.global.close</button>\n    </div>\n  </div>\n\n  <!-- no upload targets available -->\n  <div class=\"batch-dialog\" *ngIf=\"!hasValidUploadTargets\">\n\n    <h2 translate>eo.upload.global.notarget.title</h2>\n    <p translate>eo.upload.global.notarget.message</p>\n    <div class=\"actions\">\n      <button (click)=\"close()\" translate>eo.upload.global.close</button>\n    </div>\n  </div>\n\n  <div class=\"contents\" *ngIf=\"hasValidUploadTargets && !invalidInput && !selectedUploadTarget && !isUploading\">\n\n    <!-- list of available upload targets -->\n    <div class=\"targets\">\n\n      <div class=\"target-list\">\n\n        <div class=\"upload-target\" *ngFor=\"let t of validUploadTargets; trackBy: targetTrackByFn\"\n             (click)=\"proceedWithUpload(t)\"\n             [ngSwitch]=\"t.type\">\n\n          <!-- upload to root -->\n          <ng-container *ngSwitchCase=\"'root'\" >\n            <eo-icon [iconSrc]=\"'assets/_default/svg/ic_create_document.svg'\"></eo-icon>\n            <div class=\"upload-target-general\">\n              <div class=\"name\" translate>eo.upload.global.root.title</div>\n              <div class=\"description\" translate>eo.upload.global.root.description</div>\n            </div>\n          </ng-container>\n\n          <!-- replace file of a specific dms object -->\n          <ng-container *ngSwitchCase=\"'object'\">\n            <eo-icon [iconSrc]=\"'assets/_default/svg/ic_document_file.svg'\"></eo-icon>\n            <div class=\"upload-target-replace\">\n              <div class=\"name\" translate>eo.upload.global.object.title</div>\n              <div class=\"description\">{{t.description}}</div>\n            </div>\n          </ng-container>\n\n          <!-- add new files to a context folder -->\n          <ng-container *ngSwitchCase=\"'context'\">\n            <eo-icon [iconSrc]=\"'assets/_default/svg/ic_create_document_in_folder.svg'\"></eo-icon>\n            <div class=\"upload-target-context\">\n              <div class=\"name\">{{'eo.upload.global.context.title'|translate:({context:t.referenceObject.type.label})}}</div>\n              <div class=\"description\">{{t.description}}</div>\n            </div>\n          </ng-container>\n\n          <!-- add new files to a context folder structure tree entry -->\n          <ng-container *ngSwitchCase=\"'contexttree'\">\n            <eo-icon [iconSrc]=\"'assets/_default/svg/ic_create_document_in_folder.svg'\"></eo-icon>\n            <div class=\"upload-target-contexttree\">\n              <div class=\"name\">{{'eo.add.title.location.subfolder'|translate: ({folder: t.subFolder.name})}}</div>\n            </div>\n          </ng-container>\n\n          <!-- custom upload target (e.g. from plugin component) -->\n          <ng-container *ngSwitchCase=\"'custom'\">\n            <eo-icon [iconSrc]=\"'assets/_default/svg/ic_upload.svg'\"></eo-icon>\n            <div class=\"upload-target-custom\">\n              <div class=\"name\">{{t.name}}</div>\n              <div class=\"description\">{{t.description}}</div>\n            </div>\n          </ng-container>\n        </div>\n\n      </div>\n\n    </div>\n\n    <!-- list of files dragged to the component -->\n    <div class=\"files\">\n      <div class=\"files-list\">\n        <div class=\"file-item\" *ngFor=\"let i of queue; trackBy: trackByFn\">\n          <div>\n            <div class=\"name\">{{i.name}}</div>\n            <div class=\"desc\"><span class=\"size\">{{i.size | fileSize}}</span><span class=\"desc-text\">&nbsp;{{i.type}}</span></div>\n          </div>\n          <eo-icon class=\"button white\" (click)=\"removeFileItem(i)\" [iconSrc]=\"'assets/_default/svg/ic_clear.svg'\"></eo-icon>\n        </div>\n      </div>\n    </div>\n\n  </div>\n\n  <div class=\"loading\" *ngIf=\"isUploading\"><eo-loading-spinner [size]=\"'large'\"></eo-loading-spinner></div>\n\n\n</div>\n"]}
|
|
468
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload-overlay.component.js","sourceRoot":"","sources":["../../../../../../../src/app/eo-framework/upload-overlay/upload-overlay.component.ts","../../../../../../../src/app/eo-framework/upload-overlay/upload-overlay.component.html"],"names":[],"mappings":"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","sourcesContent":["import {of as observableOf, forkJoin as observableForkJoin, Observable} from 'rxjs';\nimport {Component, OnInit, Renderer2, ViewChild, ElementRef, OnDestroy} from '@angular/core';\nimport {Router} from '@angular/router';\nimport {\n  ObjectType,\n  EventService,\n  EnaioEvent,\n  UploadRegistryService,\n  UploadTarget,\n  UploadFileItem,\n  PrepareService,\n  Utils,\n  TranslateService,\n  EnvironmentEnaio, SystemService,\n  UserService,\n  LocalStorageService\n} from '@eo-sdk/core';\nimport {AgentService, LocaleDatePipe} from '../../eo-framework-core';\n\n@Component({\n  selector: 'eo-upload-overlay',\n  templateUrl: './upload-overlay.component.html',\n  styleUrls: ['./upload-overlay.component.scss']\n})\nexport class UploadOverlayComponent implements OnInit, OnDestroy {\n\n  @ViewChild('overlay') overlayEl: ElementRef;\n\n  queue: UploadFileItem[] = [];\n  fileOver: boolean;\n  isUploading: boolean;\n  hasValidUploadTargets: boolean;\n  invalidInput: boolean;\n  queueSize: number;\n  validUploadTargets: UploadTarget[] = [];\n  selectedUploadTarget: UploadTarget;\n  folderFavorites: UploadTarget[] = [];\n  lastOpenedFolder: UploadTarget[] = [];\n  datePipe: LocaleDatePipe;\n  agentAccSelected: boolean;\n  favoritesAccSelected: boolean;\n\n  targetTypes = [\n    {\n      type: 'root',\n      iconSrc: 'assets/_default/svg/ic_create_document.svg',\n      targetClass: 'upload-target-general',\n      name: 'eo.upload.global.root.title',\n      description: 'eo.upload.global.root.description'\n    },\n    {\n      type: 'object',\n      iconSrc: 'assets/_default/svg/ic_document_file.svg',\n      targetClass: 'upload-target-replace',\n      name: 'eo.upload.global.object.title'\n    },\n    {\n      type: 'context',\n      iconSrc: 'assets/_default/svg/ic_create_document_in_folder.svg',\n      targetClass: 'upload-target-context',\n      name: 'eo.upload.global.context.title',\n    },\n    {\n      type: 'contexttree',\n      iconSrc: 'assets/_default/svg/ic_create_document_in_folder.svg',\n      targetClass: 'upload-target-contexttree',\n      name: 'eo.add.title.location.subfolder'\n    },\n    {\n      type: 'custom',\n      iconSrc: 'assets/_default/svg/ic_upload.svg',\n      targetClass: 'upload-target-custom',\n      name: '',\n    }\n  ];\n\n  private uploadTargets: UploadTarget[] = [];\n  private dragLeaveListener: Function;\n  private dropListener: Function;\n  private dragOverListener: Function;\n  private escKeyListener: Function;\n  private dragEnterListener: Function;\n  private pasteListener: Function;\n  private dragEventCount = 0;\n  private cacheKey = 'accordion.state--';\n\n  constructor(private router: Router,\n    private renderer: Renderer2,\n    private prepareService: PrepareService,\n    private translate: TranslateService,\n    private userService: UserService,\n    private agentService: AgentService,\n    private systemService: SystemService,\n    private eventService: EventService,\n    private storageService: LocalStorageService,\n    private uploadRegistry: UploadRegistryService) {\n    this.datePipe = new LocaleDatePipe(translate);\n  }\n\n  ngOnInit(): void {\n    this.init();\n  }\n\n  ngOnDestroy(): void {\n    if (this.dragEnterListener) {\n      this.dragEnterListener();\n    }\n  }\n\n  /**\n   * Proceed upload with a selected upload target.\n   * @param uploadTarget - the target to upload files to\n   */\n  public proceedWithUpload(uploadTarget: UploadTarget): void {\n\n    if (uploadTarget.type !== UploadTarget.CUSTOM && this.queue.length > 1) {\n      // For more than one file to be uploaded to a none custom target, we let the user decide if\n      // batch upload should be used or not ...\n\n\n      this.selectedUploadTarget = uploadTarget;\n    } else if (uploadTarget.type === UploadTarget.OBJECT) {\n      // ... otherwise upload is started immediately\n      this.startUpload(uploadTarget, [null, this.getStateRoute()]);\n    } else {\n      this.startUpload(uploadTarget, [null, '/prepare']);\n    }\n  }\n\n  /**\n   * Proceed upload using the selected upload target.\n   * @param useBatchUpload - flag indicating whether or not to use batch upload\n   */\n  public proceedWithSelectedTarget(useBatchUpload: boolean): void {\n    this.startUpload(this.selectedUploadTarget, [useBatchUpload, '/prepare']);\n  }\n\n  /**\n   * Resets the selected upload target.\n   */\n  public resetSelectedUploadTarget(): void {\n    this.selectedUploadTarget = null;\n  }\n\n  /**\n   * Removes a file from the list of files to be uploaded.\n   * @param fileItem - the file item to be removed\n   */\n  public removeFileItem(fileItem: UploadFileItem): void {\n\n    this.queue = this.queue.filter((f) => f.id !== fileItem.id);\n    if (!this.queue.length) {\n      this.close();\n    } else {\n      // update available upload targets because their validity\n      // may be based on the queue size\n      this.validateUploadTargets();\n      this.setQueueSize();\n    }\n  }\n\n  getStateRoute(): string {\n    return this.router.url;\n  }\n\n  onAgentToggle(info: boolean): void {\n    this.storageService.setItem(this.cacheKey + 'agent-folder', JSON.stringify(info));\n  }\n\n  onFavoriteToggle(info: boolean): void {\n    this.storageService.setItem(this.cacheKey + 'favorite-folder', JSON.stringify(info));\n  }\n\n  getFolder(): void {\n    //folder from agent\n    this.agentService.getLastOpenedFoldersInfo().subscribe((res: []): void => {\n      this.lastOpenedFolder = res.map((item: {title: string; data: {description: string}; id: string; type: string}) => {\n        let target = new UploadTarget(\n          item.id,\n          'agent',\n          item?.title,\n          this.systemService.getObjectType(item.type).iconId,\n          item.type\n        );\n        target.description = item?.data?.description;\n        return target;\n      });\n      this.lastOpenedFolder.forEach(target => target.onUploadSuccess = () => this.router.navigate(['/prepare']));\n    });\n\n    // Folder from favorite\n    this.userService.getFavorites().subscribe((res) => {\n      const favoritesFiltered = res.filter((item: {target: {folder: boolean}}) => item.target.folder === true);\n      this.folderFavorites = favoritesFiltered.map(item => {\n        let target = new UploadTarget(\n          item.target.id,\n          'favorite',\n          item.title,\n          item.target.icon.id,\n          item.target.type,\n        );\n        target.description = this.datePipe.transform(item.created);\n        return target;\n      });\n      this.folderFavorites.forEach(target => target.onUploadSuccess = () => this.router.navigate(['/prepare']));\n    });\n  }\n\n  /**\n   * Close the upload overlay and release all bound resources.\n   */\n  close(): void {\n    // unbind bound event listener, when they are not needed anymore\n    this.unbindListeners();\n    // clear upload queue\n    this.queue = [];\n    // hide the overlay\n    this.setFileOver(false);\n    this.invalidInput = false;\n  }\n\n  private init() {\n    this.getFolder();\n\n    // global drag&drop upload will only be available on desktop (web or electron)\n    if (EnvironmentEnaio.isMobileEnvironment()) {\n      return false;\n    }\n\n    // subscribe for the list of registered upload targets\n    this.uploadRegistry.uploadTargets$.subscribe((uploadTargets: UploadTarget[]) => {\n      this.uploadTargets = uploadTargets;\n    });\n\n    this.pasteListener = this.renderer.listen('document', 'paste', (e: ClipboardEvent) => {\n      this.onPaste(e);\n    });\n\n    this.dragEnterListener = this.renderer.listen('document', 'dragenter', (e: DragEvent) => {\n      this.onDragEnter(e);\n    });\n  }\n\n  private onPaste(e: ClipboardEvent) {\n    if (this.isUploading) {\n      return false;\n    }\n    this.hasValidUploadTargets = true;\n    this.invalidInput = false;\n    if (!this.fileOver && this.pasteContainsFiles(e)) {\n      let transfer = e.clipboardData;\n      if (!transfer) {\n        return;\n      }\n\n      // check for directories\n      for (let i = 0; i < transfer.items.length; i++) {\n        if (transfer.items[i].kind === 'string') {\n          this.invalidInput = true;\n          return;\n        }\n        const fe = transfer.items[i].webkitGetAsEntry();\n        if (fe && fe.isDirectory) {\n          this.invalidInput = true;\n          return;\n        }\n      }\n      if (!this.invalidInput) {\n        this._preventAndStop(e);\n        this.setFileOver(true);\n        this.onFilesDropped(Array.from(transfer.files));\n      }\n    }\n  }\n\n  private onDragEnter(e: DragEvent) {\n    if (this.isUploading) {\n      return false;\n    }\n    this.hasValidUploadTargets = true;\n    if (!this.fileOver && this.dragContainsFiles(e)) {\n      this.dragEventCount = 0;\n      this.setFileOver(true);\n\n      // use timeout here to force angular digest cycle before continuing, because we are accessing dom elements\n      // that are not there (*ngIf) until fileOver is set to true.\n      setTimeout(() => {\n        // todo: replace by renderer solution when available (https://github.com/angular/angular/issues/15674)\n        this.overlayEl.nativeElement.focus();\n        // bind late (only, when needed) to dragleave event to avoid heavy processing on every drag event\n        this.dragLeaveListener = this.renderer.listen(this.overlayEl.nativeElement, 'dragleave', () => {\n          this.dragEventCount--;\n          if (this.dragEventCount === 0) {\n            this.close();\n          }\n        });\n\n        this.dropListener = this.renderer.listen(this.overlayEl.nativeElement, 'drop', (evt) => {\n          let transfer = this._getTransfer(evt);\n          if (!transfer) {\n            return;\n          }\n          this._preventAndStop(evt);\n\n          // check for directories\n          for (let i = 0; i < transfer.items.length; i++) {\n            const fe = transfer.items[i].webkitGetAsEntry();\n            if (fe && fe.isDirectory) {\n              this.invalidInput = true;\n            }\n          }\n          if (!this.invalidInput) {\n            this.onFilesDropped(transfer.files);\n          }\n        });\n\n        this.dragOverListener = this.renderer.listen(this.overlayEl.nativeElement, 'dragover', (evt) => {\n          let transfer = this._getTransfer(evt);\n          if (!transfer) {\n            return;\n          }\n          transfer.dropEffect = 'copy';\n          this._preventAndStop(evt);\n        });\n      }, 0);\n    } else {\n      this.dragEventCount++;\n    }\n  }\n\n  private _getTransfer(event: any): any {\n    return event.dataTransfer ? event.dataTransfer : event.originalEvent.dataTransfer; // jQuery fix;\n  }\n\n  private _preventAndStop(event: any): any {\n    event.preventDefault();\n    event.stopPropagation();\n  }\n\n  private onFilesDropped(fileItems: File[]) {\n    this.getFolder();\n    this.getCachedAccordionState();\n    // clear queue when new files are added\n    // todo: remove in future releases to support collective file adding\n    this.queue = [];\n    for (let file of fileItems) {\n      this.queue.push(new UploadFileItem(file));\n    }\n\n    // bind ESC key listener for closing the dialog as late as possible\n    if (!this.escKeyListener) {\n      this.escKeyListener = this.renderer.listen('document', 'keyup', (e) => {\n        e.stopPropagation();\n        if (e.keyCode === 27) {\n          this.close();\n        }\n      });\n    }\n    // calculate total size of queue\n    this.setQueueSize();\n    // filter available targets\n    this.validateUploadTargets();\n  }\n\n  /**\n   * Filter list of registered upload targets, so only valid targets will be shown.\n   */\n  private validateUploadTargets() {\n    this.hasValidUploadTargets = true;\n    this.getFolder();\n    observableForkJoin(this.uploadTargets.map(t => this.validateUploadTarget(t)))\n      .subscribe(\n        (res: {target: UploadTarget; valid: boolean}[]) => {\n          this.validUploadTargets = res.filter(r => r.valid).map(filtered => filtered.target).reverse().sort((a, b) => {\n            return a.type === 'context' ? -1 : b.type === 'context' ? 1 : 0; // Context should be on top\n          });\n          this.validUploadTargets = [...this.validUploadTargets, ...this.folderFavorites, ...this.lastOpenedFolder];\n        }, () => {\n          this.validUploadTargets = [];\n        }, () => {\n          this.hasValidUploadTargets = this.validUploadTargets.length > 0;\n        }\n      );\n  }\n\n  private validateUploadTarget(target: UploadTarget): Observable<{target: UploadTarget; valid: boolean}> {\n\n    if (!this.queue) {\n      return observableOf({target: target, valid: false});\n    }\n\n    return Observable.create(o => {\n      let valid = false;\n\n      if (target.type === UploadTarget.ROOT) {\n\n        // todo: are there other restrictions on root target?\n        this.prepareService.getPrepareChildTypes(null, true)\n          .subscribe(\n            (res: {parent: string; types: ObjectType[]}) => {\n              valid = this.queue.length > 0 && res.types.length > 0;\n              o.next({target: target, valid: valid});\n              o.complete();\n            }, () => {\n              o.next({target: target, valid: false});\n              o.complete();\n            }\n          );\n      } else if (target.type === UploadTarget.OBJECT) {\n\n        // todo: check if the reference object supports the given file type\n        valid = target.referenceObject &&\n          target.referenceObject.type.maxFiles > 0 &&\n          !target.referenceObject.lock &&\n          !target.referenceObject.isFinalized &&\n          (target.referenceObject.rights && target.referenceObject.rights.edit) &&\n          this.queue.length === 1 &&\n          target.referenceObject.data.yuvsigstatus !== 'signed' &&\n          target.referenceObject.data.yuvsigstatus !== 'inprocess';\n        o.next({target: target, valid: valid});\n        o.complete();\n      } else if (target.type === UploadTarget.CONTEXT || target.type === UploadTarget.CONTEXT_TREE) {\n\n        // todo: add checks related to the reference object (e.g. allowed file types)\n        this.prepareService.getPrepareChildTypes(target.referenceObject.id, true)\n          .subscribe(\n            (res: {parent: string; types: ObjectType[]}) => {\n              valid = target.referenceObject && this.queue.length > 0 && res.types.length > 0;\n\n              // for CONTEXT_TREE targets also check if the desired node\n              // type is part of the prepare child types\n              if (target.type === UploadTarget.CONTEXT_TREE && target.subFolder) {\n                const subFolder = target.subFolder;\n                valid = !!res.types.find(t => this.systemService.implementsType(t, subFolder.data.type));\n              }\n\n              o.next({target: target, valid: valid});\n              o.complete();\n            }, () => {\n              o.next({target: target, valid: false});\n              o.complete();\n            }\n          );\n      } else {\n        o.next({target: target, valid: false});\n        o.complete();\n      }\n    });\n  }\n\n  private getCachedAccordionState(): void {\n    this.agentAccSelected = JSON.parse(this.storageService.getItem(this.cacheKey + 'agent-folder'));\n    this.favoritesAccSelected = JSON.parse(this.storageService.getItem(this.cacheKey + 'favorite-folder'));\n  }\n\n  private successfulUpload(target, uploadTarget): void {\n    this.eventService.trigger(EnaioEvent.DMS_OBJECT_UPDATED, uploadTarget.referenceObject);\n    uploadTarget.onUploadSuccess(target);\n  }\n\n  /**\n   * Start the actual upload.\n   * @param uploadTarget - target to upload the files to\n   * @param useBatchUpload - flag indicating whether or not to use batch upload\n   */\n  private startUpload(uploadTarget: UploadTarget, [...args]): void {\n\n    const [useBatchUpload, target] = args;\n\n    this.isUploading = true;\n    this.unbindListeners();\n    this.prepareService\n      .uploadToTarget(uploadTarget, this.queue, useBatchUpload)\n      .subscribe((res) => {\n        this.isUploading = false;\n        if (uploadTarget.subFolder && uploadTarget.subFolder.data.data) {\n          if (Array.isArray(res)) {\n            let obs = [];\n            res.forEach(r => {\n              obs.push(this.prepareService.updatePreparedItemIndexData(r.id, uploadTarget.subFolder.data.data));\n            });\n            observableForkJoin(obs).subscribe(() => this.successfulUpload(target, uploadTarget));\n          } else {\n            this.prepareService\n              .updatePreparedItemIndexData(res.id, uploadTarget.subFolder.data.data)\n              .subscribe(() => this.successfulUpload(target, uploadTarget));\n          }\n        } else {\n          this.successfulUpload(target, uploadTarget);\n        }\n        this.close();\n      }, Utils.throw(() => {\n        this.isUploading = false;\n        uploadTarget.onUploadFail();\n        this.close();\n      },\n        this.translate.instant('eo.upload.global.error.title'),\n        this.translate.instant('eo.upload.global.error.description'))\n      );\n    this.resetSelectedUploadTarget();\n  }\n\n  private setQueueSize(): void {\n    let s = 0;\n    for (let f of this.queue) {\n      s += f.size;\n    }\n    this.queueSize = s;\n  }\n\n  private setFileOver(value: boolean): void {\n    this.fileOver = value;\n    this.uploadRegistry.setOverlayActive(value);\n  }\n\n  private unbindListeners(): void {\n    if (this.dragLeaveListener) {\n      this.dragLeaveListener();\n      this.dragLeaveListener = null;\n    }\n    if (this.dragOverListener) {\n      this.dragOverListener();\n      this.dragOverListener = null;\n    }\n    if (this.dropListener) {\n      this.dropListener();\n      this.dropListener = null;\n    }\n    if (this.escKeyListener) {\n      this.escKeyListener();\n      this.escKeyListener = null;\n    }\n  }\n\n  /**\n   * Indicates whether or not the current drag event contains one or more files.\n   * @param event - the drag event to be checked\n   * @returns number of files\n   */\n  private dragContainsFiles(event: DragEvent): number {\n    return Array.from(event.dataTransfer.items || []).filter(i => i.kind === 'file').length;\n  }\n\n  /**\n   * Indicates whether or not the current paste event contains one or more files.\n   * @param event - the paste event to be checked\n   * @returns number of files\n   */\n  private pasteContainsFiles(event: ClipboardEvent): number {\n    return Array.from(event.clipboardData.items || []).filter(i => i.kind === 'file').length;\n  }\n}\n","<div id=\"eo-upload-overlay\" #overlay class=\"dark\" *ngIf=\"fileOver\" tabindex=\"1\"\n  [ngClass]=\"{file: queue.length, invalid: invalidInput, uploading: isUploading}\">\n\n  <eo-icon class=\"button white close\" [iconSrc]=\"'assets/_default/svg/ic_clear.svg'\" (click)=\"close()\"></eo-icon>\n\n  <div class=\"count\">\n    <div>{{queue.length}}</div>\n    <div class=\"queueSize\">{{queueSize | fileSize}}</div>\n  </div>\n\n  <div class=\"headline\">\n    <h1 translate>eo.upload.global.headline</h1>\n  </div>\n  \n  <eo-icon class=\"uploady\" [iconSrc]=\"'assets/_default/svg/ic_upload.svg'\"></eo-icon>\n\n  <!-- batch upload dialog -->\n  <div class=\"batch-dialog\" *ngIf=\"!invalidInput && selectedUploadTarget && !isUploading\">\n\n    <h2 translate>eo.upload.global.choose.title</h2>\n    <p translate>eo.upload.global.choose.message</p>\n    <div class=\"actions\">\n      <button (click)=\"resetSelectedUploadTarget()\" translate>eo.cta.button.cancel</button>\n      <button (click)=\"proceedWithSelectedTarget(false)\" class=\"primary\"\n        translate>eo.upload.global.choose.single</button>\n      <button (click)=\"proceedWithSelectedTarget(true)\" class=\"primary\" translate>eo.upload.global.choose.multi</button>\n    </div>\n  </div>\n\n  <!-- invalid input dialog -->\n  <div class=\"batch-dialog\" *ngIf=\"hasValidUploadTargets && invalidInput\">\n\n    <h2 translate>eo.upload.global.invalid.title</h2>\n    <p translate>eo.upload.global.invalid.message</p>\n    <div class=\"actions\">\n      <button (click)=\"close()\" translate>eo.upload.global.close</button>\n    </div>\n  </div>\n\n  <!-- no upload targets available -->\n  <div class=\"batch-dialog\" *ngIf=\"!hasValidUploadTargets\">\n\n    <h2 translate>eo.upload.global.notarget.title</h2>\n    <p translate>eo.upload.global.notarget.message</p>\n    <div class=\"actions\">\n      <button (click)=\"close()\" translate>eo.upload.global.close</button>\n    </div>\n  </div>\n\n  <div class=\"contents\" *ngIf=\"hasValidUploadTargets && !invalidInput && !selectedUploadTarget && !isUploading\">\n\n    <div class=\"section\">\n      <!-- list of available upload targets -->\n      <div class=\"targets\">\n        <div class=\"target-list\">\n          @for (targetType of targetTypes; track targetType.type) {\n            @for (t of validUploadTargets; track t.id) {\n              @if (t.type === targetType.type) {\n                <ng-container *ngTemplateOutlet=\"uploadTargetTemplate; context: {\n                          iconSrc: targetType.iconSrc,\n                          targetClass: targetType.targetClass,\n                          name: targetType.type === 'custom' ? t.name : (targetType.type === 'context' ?      (targetType.name | translate : { context: t.referenceObject.type.label }) :     (targetType. name | translate)),\n                          description: targetType.type === 'custom' || targetType.type === 'object' ||    targetType.  type === 'context' ? t.description : (targetType.description |   translate),\n                          targets: t\n                        }\">\n                </ng-container>\n              }\n            }\n          }\n        </div>\n      </div>\n\n      <!-- upload to favorite -->\n      @if (folderFavorites.length > 0) {\n        <eo-simple-accordion [selected]=\"favoritesAccSelected\" [header]=\"'eo.upload.global.context.favorite' | translate\"\n                             (selectChange)=\"onFavoriteToggle($event)\">\n          <div class=\"targets\">\n            <div class=\"target-list\">\n              @for (t of validUploadTargets; track $index) {\n                @if (t.type === 'favorite') {\n                  <div class=\"upload-target\" (click)=\"proceedWithUpload(t)\">\n                    <ng-container>\n                      <eo-icon [iconId]=\"t.iconId\"></eo-icon>\n                      <div class=\"upload-target-favorite\">\n                        <div class=\"name\">{{t.title}}\n                          <div class=\"description\">{{t.description}}</div>\n                        </div>\n                      </div>\n                    </ng-container>\n                  </div>\n                }\n              }\n            </div>\n          </div>\n        </eo-simple-accordion>\n      }\n\n      @if(lastOpenedFolder.length > 0){\n        <eo-simple-accordion [selected]=\"agentAccSelected\" [header]=\"'eo.upload.global.context.agent' | translate\"\n                             (selectChange)=\"onAgentToggle($event)\">\n          <!-- upload to last opened folder  -->\n          <div class=\"targets\">\n            <div class=\"target-list\">\n              @for (t of validUploadTargets; track $index) {\n                @if (t.type === 'agent') {\n                  <div class=\"upload-target\" (click)=\"proceedWithUpload(t)\">\n                    <ng-container>\n                      <eo-icon [iconId]=\"t.iconId\"></eo-icon>\n                      <div class=\"upload-target-agent\">\n                        <div class=\"name\">{{t?.title}}\n                          <div class=\"description\">{{t?.description}}</div>\n                        </div>\n                      </div>\n                    </ng-container>\n                  </div>\n                }\n              }\n            </div>\n          </div>\n        </eo-simple-accordion>\n      }\n    </div>\n    <!-- list of files dragged to the component -->\n    <div class=\"files\" [ngClass]=\"{file: queue.length, invalid: invalidInput, uploading: isUploading}\">\n      <div class=\"files-list\">\n        @for (i of queue; track $index) {\n          <div class=\"file-item\">\n              <div>\n                <div class=\"name\">{{i.name}}</div>\n                <div class=\"desc\"><span class=\"size\">{{i.size | fileSize}}</span>\n                  <span class=\"desc-text\">&nbsp;{{i.type}}</span></div>\n              </div>\n              <eo-icon class=\"button white\" (click)=\"removeFileItem(i)\"\n                      [iconSrc]=\"'assets/_default/svg/ic_clear.svg'\"></eo-icon>\n          </div>\n        }\n      </div>\n    </div>\n  </div>\n\n  @if (isUploading) {\n    <div class=\"loading\">\n      <eo-loading-spinner [size]=\"'large'\"></eo-loading-spinner>\n    </div>\n  }\n</div>\n\n<ng-template #uploadTargetTemplate let-iconSrc=\"iconSrc\" let-targetClass=\"targetClass\" let-name=\"name\"\n  let-description=\"description\" let-targets=\"targets\">\n  <div class=\"upload-target\" (click)=\"proceedWithUpload(targets)\">\n    <ng-container>\n      <eo-icon [iconSrc]=\"iconSrc\"></eo-icon>\n      <div [ngClass]=\"targetClass\">\n        <div class=\"name\">{{ name }}</div>\n        <div class=\"description\">{{ description }}</div>\n      </div>\n    </ng-container>\n  </div>\n</ng-template>\n"]}
|