@rlucan/ui 14.2.5 → 14.2.6
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/{esm2020 → esm2022}/lib/action-button/action-button.component.mjs +99 -99
- package/esm2022/lib/action-icon/action-icon.component.mjs +37 -0
- package/esm2022/lib/autocomplete/autocomplete.component.mjs +391 -0
- package/esm2022/lib/avatar/avatar.component.mjs +34 -0
- package/esm2022/lib/button/button.component.mjs +57 -0
- package/esm2022/lib/checkbox/checkbox.component.mjs +39 -0
- package/{esm2020 → esm2022}/lib/checkbox-group/checkbox-group.component.mjs +91 -91
- package/esm2022/lib/currency/currency.component.mjs +151 -0
- package/esm2022/lib/date/date.component.mjs +68 -0
- package/{esm2020 → esm2022}/lib/dialog/dialog.component.mjs +37 -37
- package/esm2022/lib/directives/force-visibility/force-visibility.directive.mjs +104 -0
- package/esm2022/lib/editor/editor.component.mjs +119 -0
- package/{esm2020 → esm2022}/lib/elements/burger/burger.component.mjs +21 -21
- package/{esm2020 → esm2022}/lib/elements/expander/expander.component.mjs +28 -28
- package/{esm2020 → esm2022}/lib/elements/validation-message/validation-message.component.mjs +47 -47
- package/esm2022/lib/file/file.component.mjs +145 -0
- package/esm2022/lib/file-uploader/ui-file-uploader.component.mjs +405 -0
- package/esm2022/lib/input/input.component.mjs +265 -0
- package/esm2022/lib/input-autocomplete/input-autocomplete.component.mjs +277 -0
- package/esm2022/lib/layouts/base/ui-base-layout.component.mjs +22 -0
- package/esm2022/lib/layouts/base/ui-base.component.mjs +74 -0
- package/esm2022/lib/layouts/simple/ui-simple-layout.component.mjs +18 -0
- package/esm2022/lib/layouts/simple/ui-simple.component.mjs +166 -0
- package/{esm2020 → esm2022}/lib/radio/radio.component.mjs +21 -21
- package/esm2022/lib/radio-group/radio-group.component.mjs +53 -0
- package/esm2022/lib/select/select.component.mjs +115 -0
- package/{esm2020 → esm2022}/lib/services/message-box.service.mjs +112 -112
- package/{esm2020 → esm2022}/lib/services/toast.service.mjs +23 -23
- package/{esm2020 → esm2022}/lib/services/ui-file.service.mjs +71 -71
- package/{esm2020 → esm2022}/lib/services/ui-translate.service.mjs +32 -32
- package/{esm2020 → esm2022}/lib/submit-button/submit-button.component.mjs +72 -72
- package/esm2022/lib/table/table.component.mjs +97 -0
- package/esm2022/lib/text-area/text-area.component.mjs +46 -0
- package/{esm2020 → esm2022}/lib/ui.model.mjs +1 -1
- package/esm2022/lib/ui.module.mjs +269 -0
- package/esm2022/public-api.mjs +35 -0
- package/{esm2020 → esm2022}/rlucan-ui.mjs +4 -4
- package/fesm2022/rlucan-ui.mjs +3442 -0
- package/fesm2022/rlucan-ui.mjs.map +1 -0
- package/index.d.ts +5 -5
- package/lib/action-button/action-button.component.d.ts +32 -32
- package/lib/action-icon/action-icon.component.d.ts +15 -15
- package/lib/autocomplete/autocomplete.component.d.ts +57 -57
- package/lib/avatar/avatar.component.d.ts +14 -14
- package/lib/button/button.component.d.ts +18 -18
- package/lib/checkbox/checkbox.component.d.ts +15 -15
- package/lib/checkbox-group/checkbox-group.component.d.ts +18 -18
- package/lib/currency/currency.component.d.ts +31 -30
- package/lib/date/date.component.d.ts +24 -24
- package/lib/dialog/dialog.component.d.ts +13 -13
- package/lib/directives/force-visibility/force-visibility.directive.d.ts +22 -20
- package/lib/editor/editor.component.d.ts +24 -0
- package/lib/elements/burger/burger.component.d.ts +9 -9
- package/lib/elements/expander/expander.component.d.ts +10 -10
- package/lib/elements/validation-message/validation-message.component.d.ts +12 -12
- package/lib/file/file.component.d.ts +35 -35
- package/lib/file-uploader/ui-file-uploader.component.d.ts +102 -102
- package/lib/input/input.component.d.ts +42 -41
- package/lib/input-autocomplete/input-autocomplete.component.d.ts +44 -0
- package/lib/{base → layouts/base}/ui-base-layout.component.d.ts +8 -8
- package/lib/{base → layouts/base}/ui-base.component.d.ts +23 -23
- package/lib/{simple → layouts/simple}/ui-simple-layout.component.d.ts +8 -7
- package/lib/{simple → layouts/simple}/ui-simple.component.d.ts +40 -39
- package/lib/radio/radio.component.d.ts +8 -8
- package/lib/radio-group/radio-group.component.d.ts +18 -18
- package/lib/select/select.component.d.ts +35 -33
- package/lib/services/message-box.service.d.ts +58 -58
- package/lib/services/toast.service.d.ts +13 -13
- package/lib/services/ui-file.service.d.ts +33 -33
- package/lib/services/ui-translate.service.d.ts +11 -11
- package/lib/submit-button/submit-button.component.d.ts +21 -21
- package/lib/table/table.component.d.ts +36 -36
- package/lib/text-area/text-area.component.d.ts +18 -18
- package/lib/ui.model.d.ts +2 -2
- package/lib/ui.module.d.ts +59 -56
- package/package.json +22 -24
- package/public-api.d.ts +29 -27
- package/scss/ui-defaults.scss +1 -1
- package/src/js/editorjs.mjs +9634 -0
- package/ui.scss +41 -14
- package/esm2020/lib/action-icon/action-icon.component.mjs +0 -37
- package/esm2020/lib/autocomplete/autocomplete.component.mjs +0 -391
- package/esm2020/lib/avatar/avatar.component.mjs +0 -34
- package/esm2020/lib/base/ui-base-layout.component.mjs +0 -22
- package/esm2020/lib/base/ui-base.component.mjs +0 -74
- package/esm2020/lib/button/button.component.mjs +0 -57
- package/esm2020/lib/checkbox/checkbox.component.mjs +0 -39
- package/esm2020/lib/currency/currency.component.mjs +0 -148
- package/esm2020/lib/date/date.component.mjs +0 -68
- package/esm2020/lib/directives/force-visibility/force-visibility.directive.mjs +0 -96
- package/esm2020/lib/file/file.component.mjs +0 -145
- package/esm2020/lib/file-uploader/ui-file-uploader.component.mjs +0 -394
- package/esm2020/lib/input/input.component.mjs +0 -258
- package/esm2020/lib/radio-group/radio-group.component.mjs +0 -53
- package/esm2020/lib/select/select.component.mjs +0 -91
- package/esm2020/lib/simple/ui-simple-layout.component.mjs +0 -15
- package/esm2020/lib/simple/ui-simple.component.mjs +0 -154
- package/esm2020/lib/table/table.component.mjs +0 -97
- package/esm2020/lib/text-area/text-area.component.mjs +0 -46
- package/esm2020/lib/ui.module.mjs +0 -255
- package/esm2020/public-api.mjs +0 -33
- package/fesm2015/rlucan-ui.mjs +0 -3017
- package/fesm2015/rlucan-ui.mjs.map +0 -1
- package/fesm2020/rlucan-ui.mjs +0 -2982
- package/fesm2020/rlucan-ui.mjs.map +0 -1
|
@@ -0,0 +1,405 @@
|
|
|
1
|
+
import { Component, EventEmitter, Host, Inject, Input, Optional, Output, SkipSelf } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { UI_FILESERVICE } from '../services/ui-file.service';
|
|
4
|
+
import { UiSimpleComponent } from '../layouts/simple/ui-simple.component';
|
|
5
|
+
import { UI_TRANSLATESERVICE } from '../services/ui-translate.service';
|
|
6
|
+
import * as i0 from "@angular/core";
|
|
7
|
+
import * as i1 from "@angular/forms";
|
|
8
|
+
import * as i2 from "../services/ui-file.service";
|
|
9
|
+
import * as i3 from "@angular/common";
|
|
10
|
+
import * as i4 from "@angular/material/icon";
|
|
11
|
+
import * as i5 from "@angular/material/tooltip";
|
|
12
|
+
import * as i6 from "ngx-uploader";
|
|
13
|
+
import * as i7 from "@angular/material/progress-spinner";
|
|
14
|
+
import * as i8 from "ngx-image-cropper";
|
|
15
|
+
import * as i9 from "../file/file.component";
|
|
16
|
+
export class UiFileUploaderComponent extends UiSimpleComponent {
|
|
17
|
+
get menuTemplate() {
|
|
18
|
+
return this.templates?.menuTemplate;
|
|
19
|
+
}
|
|
20
|
+
get addFileTemplate() {
|
|
21
|
+
return this.templates?.addFileTemplate;
|
|
22
|
+
}
|
|
23
|
+
get fileTemplate() {
|
|
24
|
+
return this.templates?.fileTemplate;
|
|
25
|
+
}
|
|
26
|
+
constructor(fileServiceConfig, translateService, controlContainer, fileService) {
|
|
27
|
+
super(null, controlContainer);
|
|
28
|
+
this.fileServiceConfig = fileServiceConfig;
|
|
29
|
+
this.translateService = translateService;
|
|
30
|
+
this.controlContainer = controlContainer;
|
|
31
|
+
this.fileService = fileService;
|
|
32
|
+
this.maxFiles = 1;
|
|
33
|
+
this.multiple = true;
|
|
34
|
+
this.crop = false;
|
|
35
|
+
this.cropRounded = false;
|
|
36
|
+
this.fileSize = 'default';
|
|
37
|
+
this.customFileMenu = false;
|
|
38
|
+
this.newFilePosition = 'last';
|
|
39
|
+
this.templates = {};
|
|
40
|
+
this.previewPosition = 'bottom';
|
|
41
|
+
this.imageCropped = new EventEmitter();
|
|
42
|
+
this.fileEvent = new EventEmitter();
|
|
43
|
+
this.uploadOptions = {
|
|
44
|
+
concurrency: this.fileServiceConfig.concurrentUploads
|
|
45
|
+
};
|
|
46
|
+
this.uploading = false;
|
|
47
|
+
this.showCropper = false;
|
|
48
|
+
this.showCropPreview = {};
|
|
49
|
+
this.cropPreviewTimeouts = {};
|
|
50
|
+
this.cropSourceImages = {};
|
|
51
|
+
this.cropperImageLoaded = {};
|
|
52
|
+
this.imagesDone = {};
|
|
53
|
+
this.transform = {};
|
|
54
|
+
this.canvasRotation = {};
|
|
55
|
+
this.refreshAddInput = false;
|
|
56
|
+
this.patchingValues = false;
|
|
57
|
+
this.inputArray = false;
|
|
58
|
+
this.dragging = false;
|
|
59
|
+
this.uploaderId = Math.round(Math.random() * 1000000);
|
|
60
|
+
this.croppedImages = {};
|
|
61
|
+
this.fileService.uploadSubscription.next({ action: 'register', data: this });
|
|
62
|
+
this.fileService.uploadSubscription.subscribe((v) => {
|
|
63
|
+
switch (v.action) {
|
|
64
|
+
case 'uploadStarted':
|
|
65
|
+
this.uploading = true;
|
|
66
|
+
break;
|
|
67
|
+
case 'uploadFailed':
|
|
68
|
+
case 'uploadSuccess':
|
|
69
|
+
setTimeout(() => {
|
|
70
|
+
this.uploading = false;
|
|
71
|
+
});
|
|
72
|
+
this.patchValues();
|
|
73
|
+
}
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
get uploadInput() {
|
|
77
|
+
return this.fileService.uploadInput;
|
|
78
|
+
}
|
|
79
|
+
get editable() {
|
|
80
|
+
return this.componentFormControl.enabled;
|
|
81
|
+
}
|
|
82
|
+
get ngAddStyle() {
|
|
83
|
+
return {
|
|
84
|
+
width: Math.abs(this.fileServiceConfig.imageSizes[this.fileSize][0]) + 'px',
|
|
85
|
+
height: Math.abs(this.fileServiceConfig.imageSizes[this.fileSize][1]) + 'px',
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
get aspectRatio() {
|
|
89
|
+
return this.fileServiceConfig.imageSizes[this.fileSize][0] / this.fileServiceConfig.imageSizes[this.fileSize][1];
|
|
90
|
+
}
|
|
91
|
+
get addFileImgSrc() {
|
|
92
|
+
return this.fileServiceConfig.addFileImgSrc;
|
|
93
|
+
}
|
|
94
|
+
cropDone(f) {
|
|
95
|
+
return !f.$newFile || this.imagesDone[f.$newFile.id];
|
|
96
|
+
}
|
|
97
|
+
// ngOnInit(): void {
|
|
98
|
+
// super.ngOnInit();
|
|
99
|
+
// }
|
|
100
|
+
ngOnDestroy() {
|
|
101
|
+
this.fileService.uploadSubscription.next({ action: 'destroy', data: this });
|
|
102
|
+
}
|
|
103
|
+
remove(f) {
|
|
104
|
+
if (f.$newFile) {
|
|
105
|
+
this.uploadInput.emit({ type: 'remove', id: f.$newFile.id });
|
|
106
|
+
}
|
|
107
|
+
this.files.splice(this.files.indexOf(f), 1);
|
|
108
|
+
this.prepareResponse();
|
|
109
|
+
// this.onChange(this.inputArray ? this.files : (this.files.length > 0 ? this.files[0] : null));
|
|
110
|
+
this.fileEvent.emit({ message: 'fileRemoved', data: f });
|
|
111
|
+
// this.patchValues();
|
|
112
|
+
}
|
|
113
|
+
patchValues() {
|
|
114
|
+
this.patchingValues = true;
|
|
115
|
+
// if (this.inputArray) {
|
|
116
|
+
// this.componentFormControl.setValue(this.files.map(f => f.custom));
|
|
117
|
+
// } else {
|
|
118
|
+
// this.componentFormControl.setValue(this.files.length === 0 ? null : this.files[0].custom);
|
|
119
|
+
// }
|
|
120
|
+
this.patchingValues = false;
|
|
121
|
+
}
|
|
122
|
+
get hasFilesToUpload() {
|
|
123
|
+
return !!this.files.find(f => f.$newFile && f.$newFile.progress.status !== 2);
|
|
124
|
+
}
|
|
125
|
+
canImagePreview(type) {
|
|
126
|
+
return type.startsWith('image/') || type.startsWith('video/');
|
|
127
|
+
}
|
|
128
|
+
onUploadOutput($event, skipCustomValidation = false) {
|
|
129
|
+
// console.log($event);
|
|
130
|
+
switch ($event.type) {
|
|
131
|
+
case 'start':
|
|
132
|
+
break;
|
|
133
|
+
case 'dragOver':
|
|
134
|
+
this.dragging = true;
|
|
135
|
+
break;
|
|
136
|
+
case 'dragOut':
|
|
137
|
+
case 'drop':
|
|
138
|
+
this.dragging = false;
|
|
139
|
+
break;
|
|
140
|
+
case 'addedToQueue':
|
|
141
|
+
if (this.crop && !$event.file.type.startsWith('image/')) {
|
|
142
|
+
this.uploadInput.emit({ type: 'remove', id: $event.file.id });
|
|
143
|
+
this.fileEvent.emit({ message: 'cropInvalidFileType', data: $event.file });
|
|
144
|
+
return;
|
|
145
|
+
}
|
|
146
|
+
if (!skipCustomValidation && this.fileServiceConfig.fileValidation) {
|
|
147
|
+
this.fileServiceConfig.fileValidation(this.fileSize, $event.file).then(valid => {
|
|
148
|
+
if (valid) {
|
|
149
|
+
this.onUploadOutput($event, true);
|
|
150
|
+
}
|
|
151
|
+
else {
|
|
152
|
+
this.uploadInput.emit({ type: 'remove', id: $event.file.id });
|
|
153
|
+
// this.fileEvent.emit({ message: 'cropInvalidFileType', data: $event.file });
|
|
154
|
+
}
|
|
155
|
+
});
|
|
156
|
+
}
|
|
157
|
+
else {
|
|
158
|
+
let f;
|
|
159
|
+
if (this.changeFileIndex !== undefined) {
|
|
160
|
+
f = this.files[this.changeFileIndex];
|
|
161
|
+
if (f.$newFile) {
|
|
162
|
+
this.uploadInput.emit({ type: 'remove', id: f.$newFile.id });
|
|
163
|
+
}
|
|
164
|
+
f.$newFile = $event.file;
|
|
165
|
+
f.custom = $event.file;
|
|
166
|
+
this.changeFileIndex = undefined;
|
|
167
|
+
}
|
|
168
|
+
else {
|
|
169
|
+
f = { custom: $event.file, $newFile: $event.file };
|
|
170
|
+
if (this.newFilePosition === 'last') {
|
|
171
|
+
this.files.push(f);
|
|
172
|
+
}
|
|
173
|
+
else {
|
|
174
|
+
this.files.unshift(f);
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
if (this.canImagePreview($event.file.type)) {
|
|
178
|
+
if (this.crop) {
|
|
179
|
+
this.canvasRotation[$event.file.id] = 0;
|
|
180
|
+
this.cropSourceImages[$event.file.id] = $event.file.nativeFile;
|
|
181
|
+
this.cropperImageLoaded[$event.file.id] = false;
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
this.prepareResponse();
|
|
185
|
+
this.fileEvent.emit({ message: 'fileAdded', data: f });
|
|
186
|
+
}
|
|
187
|
+
break;
|
|
188
|
+
case 'done':
|
|
189
|
+
const df = this.files.find(f => f.$newFile === $event.file);
|
|
190
|
+
if (df) {
|
|
191
|
+
if (df.$newFile.responseStatus === 200) {
|
|
192
|
+
this.files[this.files.indexOf(df)].custom = df.$newFile.response;
|
|
193
|
+
df.$newFile = null;
|
|
194
|
+
}
|
|
195
|
+
else {
|
|
196
|
+
// console.log('error on upload', df.$event);
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
if (!this.hasFilesToUpload) {
|
|
200
|
+
this.prepareResponse(false);
|
|
201
|
+
this.fileService.uploadSubscription.next({
|
|
202
|
+
action: this.files.find(f => !!f.$newFile) ? 'uploadControlFailed' : 'uploadControlSuccess'
|
|
203
|
+
});
|
|
204
|
+
}
|
|
205
|
+
break;
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
prepareResponse(doemit = true) {
|
|
209
|
+
if (this.inputArray) {
|
|
210
|
+
if (!this.responseFiles) {
|
|
211
|
+
this.responseFiles = [];
|
|
212
|
+
}
|
|
213
|
+
this.responseFiles.length = 0;
|
|
214
|
+
this.files.forEach(f => this.responseFiles.push({ ...f.custom, $newFile: f.$newFile }));
|
|
215
|
+
}
|
|
216
|
+
else {
|
|
217
|
+
if (this.files.length === 0) {
|
|
218
|
+
this.responseFiles = null;
|
|
219
|
+
}
|
|
220
|
+
else {
|
|
221
|
+
if (!this.responseFiles) {
|
|
222
|
+
this.responseFiles = {};
|
|
223
|
+
}
|
|
224
|
+
Object.keys(this.files[0].custom).forEach(k => {
|
|
225
|
+
this.responseFiles[k] = this.files[0].custom[k];
|
|
226
|
+
});
|
|
227
|
+
this.responseFiles.$newFile = this.files[0].$newFile;
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
if (doemit) {
|
|
231
|
+
this.onChange(this.responseFiles);
|
|
232
|
+
}
|
|
233
|
+
// console.log('emit', this.files[1], { ...this.files[1].custom, $newFile: this.files[1].$newFile });
|
|
234
|
+
// this.onChange(this.inputArray ?
|
|
235
|
+
// this.files.map(f => ({ ...f.custom, $newFile: f.$newFile})) :
|
|
236
|
+
// (this.files.length > 0 ? { ...this.files[0].custom, $newFile: this.files[0].$newFile } : null));
|
|
237
|
+
// this.onChange(this.inputArray ?
|
|
238
|
+
// this.files :
|
|
239
|
+
// (this.files.length > 0 ? this.files[0] : null));
|
|
240
|
+
}
|
|
241
|
+
beforeSave() {
|
|
242
|
+
return new Promise((res, rej) => {
|
|
243
|
+
this.files.forEach(f => {
|
|
244
|
+
if (f.$newFile && f.$newFile.progress.status === 2) {
|
|
245
|
+
f.$newFile.progress.status = 0;
|
|
246
|
+
}
|
|
247
|
+
if (this.crop && f.$newFile && !this.imagesDone[f.$newFile.id]) {
|
|
248
|
+
this.cropperDone(f.$newFile.id);
|
|
249
|
+
}
|
|
250
|
+
});
|
|
251
|
+
setTimeout(() => {
|
|
252
|
+
res('done');
|
|
253
|
+
}, 250);
|
|
254
|
+
});
|
|
255
|
+
}
|
|
256
|
+
fileChangeEvent(event, f) {
|
|
257
|
+
this.changeFileIndex = this.files.indexOf(f);
|
|
258
|
+
}
|
|
259
|
+
startCropPreview(id) {
|
|
260
|
+
clearTimeout(this.cropPreviewTimeouts[id]);
|
|
261
|
+
this.showCropPreview[id] = !!this.cropSourceImages[id];
|
|
262
|
+
}
|
|
263
|
+
stopCropPreview(id) {
|
|
264
|
+
this.cropPreviewTimeouts[id] = setTimeout(() => {
|
|
265
|
+
this.showCropPreview[id] = false;
|
|
266
|
+
}, 250);
|
|
267
|
+
}
|
|
268
|
+
zoomCroppedImage(dir, id) {
|
|
269
|
+
let scale = this.transform[id].scale;
|
|
270
|
+
scale += dir;
|
|
271
|
+
if (scale < 0.1) {
|
|
272
|
+
scale = 0.1;
|
|
273
|
+
}
|
|
274
|
+
this.transform[id] = {
|
|
275
|
+
...this.transform[id],
|
|
276
|
+
scale
|
|
277
|
+
};
|
|
278
|
+
}
|
|
279
|
+
rotateCroppedImage(dir, id) {
|
|
280
|
+
this.canvasRotation[id] += dir;
|
|
281
|
+
const flippedH = this.transform[id].flipH;
|
|
282
|
+
const flippedV = this.transform[id].flipV;
|
|
283
|
+
this.transform[id] = {
|
|
284
|
+
...this.transform[id],
|
|
285
|
+
flipH: flippedV,
|
|
286
|
+
flipV: flippedH
|
|
287
|
+
};
|
|
288
|
+
}
|
|
289
|
+
onImageCropped(event, id) {
|
|
290
|
+
this.croppedImages[id] = event;
|
|
291
|
+
this.imageCropped.emit(event);
|
|
292
|
+
}
|
|
293
|
+
imageLoaded(id) {
|
|
294
|
+
this.showCropper = true;
|
|
295
|
+
setTimeout(() => {
|
|
296
|
+
this.transform[id] = {
|
|
297
|
+
scale: 1
|
|
298
|
+
};
|
|
299
|
+
});
|
|
300
|
+
}
|
|
301
|
+
cropperReady(sourceImageDimensions, id) {
|
|
302
|
+
this.cropperImageLoaded[id] = true;
|
|
303
|
+
}
|
|
304
|
+
loadImageFailed() {
|
|
305
|
+
}
|
|
306
|
+
toggleMenuVisibility(f) {
|
|
307
|
+
this.fileMenuOpened = f;
|
|
308
|
+
}
|
|
309
|
+
menuClick() {
|
|
310
|
+
this.fileMenuOpened = undefined;
|
|
311
|
+
}
|
|
312
|
+
writeValue(obj) {
|
|
313
|
+
this.inputArray = obj instanceof Array;
|
|
314
|
+
if (this.inputArray) {
|
|
315
|
+
this.files = obj.map(f => ({ custom: f, $newFile: null }));
|
|
316
|
+
}
|
|
317
|
+
else {
|
|
318
|
+
this.files = obj ? [{ custom: obj, $newFile: null }] : [];
|
|
319
|
+
}
|
|
320
|
+
this.cropSourceImages = {};
|
|
321
|
+
}
|
|
322
|
+
cropperDone(id) {
|
|
323
|
+
const f = this.files.find(fx => fx.$newFile && fx.$newFile.id === id);
|
|
324
|
+
if (f) {
|
|
325
|
+
// const url = this.croppedImages[id];
|
|
326
|
+
// console.log(url);
|
|
327
|
+
// fetch(url)
|
|
328
|
+
// .then(res => res.blob())
|
|
329
|
+
// .then(blob => {
|
|
330
|
+
// f.$newFile.nativeFile = new File([ blob ], 'crop.png', {
|
|
331
|
+
// type: 'image/png'
|
|
332
|
+
// });
|
|
333
|
+
// f.$newFile.name = 'crop.png';
|
|
334
|
+
// f.$newFile.size = f.$newFile.nativeFile.size;
|
|
335
|
+
// f.$newFile.type = f.$newFile.nativeFile.type;
|
|
336
|
+
// this.imagesDone[id] = true;
|
|
337
|
+
// console.log(f);
|
|
338
|
+
// })
|
|
339
|
+
const croppedImage = this.croppedImages[id];
|
|
340
|
+
f.$newFile.nativeFile = new File([croppedImage.blob], 'crop.png', {
|
|
341
|
+
type: 'image/png'
|
|
342
|
+
});
|
|
343
|
+
f.$newFile.name = 'crop.png';
|
|
344
|
+
f.$newFile.size = f.$newFile.nativeFile.size;
|
|
345
|
+
f.$newFile.type = f.$newFile.nativeFile.type;
|
|
346
|
+
this.imagesDone[id] = true;
|
|
347
|
+
console.log(f);
|
|
348
|
+
}
|
|
349
|
+
}
|
|
350
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: UiFileUploaderComponent, deps: [{ token: UI_FILESERVICE, optional: true }, { token: UI_TRANSLATESERVICE }, { token: i1.ControlContainer, host: true, optional: true, skipSelf: true }, { token: i2.UiFileService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
351
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.11", type: UiFileUploaderComponent, selector: "ui-file-uploader", inputs: { maxFiles: "maxFiles", multiple: "multiple", crop: "crop", cropRounded: "cropRounded", cropMaxWidth: "cropMaxWidth", fileSize: "fileSize", customFileMenu: "customFileMenu", addHint: "addHint", newFilePosition: "newFilePosition", templates: "templates", previewPosition: "previewPosition" }, outputs: { imageCropped: "imageCropped", fileEvent: "fileEvent" }, providers: [{
|
|
352
|
+
provide: NG_VALUE_ACCESSOR,
|
|
353
|
+
multi: true,
|
|
354
|
+
useExisting: UiFileUploaderComponent,
|
|
355
|
+
}], usesInheritance: true, ngImport: i0, template: "<div class=\"label\" *ngIf=\"label\">\r\n <div class=\"text-container\" [matTooltip]=\"required ? translateService.instant('ui.controls.validation.required') : undefined\" [matTooltipPosition]=\"'above'\">\r\n <div class=\"text\">{{label}}</div>\r\n <div *ngIf=\"required\" class=\"required\">*</div>\r\n </div>\r\n</div>\r\n\r\n<div class=\"files-container\" [ngClass]=\"{dragging: dragging, disabled: uploading || !editable}\">\r\n\r\n <div class=\"existing-files\">\r\n\r\n <div class=\"file-container\" *ngFor=\"let f of files\">\r\n\r\n <div class=\"file-menu\" (click)=\"toggleMenuVisibility(f)\" *ngIf=\"!customFileMenu && editable && !uploading\">\r\n <mat-icon>menu</mat-icon>\r\n </div>\r\n <div class=\"file-menu-container mat-elevation-z2\" [ngClass]=\"{visible: f === fileMenuOpened}\" (click)=\"menuClick()\" (mouseleave)=\"menuClick()\">\r\n <ng-container *ngIf=\"!menuTemplate\">\r\n <label class=\"menu-item\">{{ translateService.instant('ui.controls.ui-file-uploader.menu.change') }}\r\n <input *ngIf=\"!refreshAddInput\" style=\"display: none;\" type=\"file\" ngFileSelect [options]=\"uploadOptions\" (change)=\"fileChangeEvent($event, f)\"\r\n (uploadOutput)=\"onUploadOutput($event)\" [uploadInput]=\"uploadInput\">\r\n </label>\r\n <div class=\"menu-item\" (click)=\"remove(f)\">{{ translateService.instant('ui.controls.ui-file-uploader.menu.delete') }}</div>\r\n </ng-container>\r\n <ng-container *ngIf=\"menuTemplate\">\r\n <ng-template [ngTemplateOutlet]=\"menuTemplate\" [ngTemplateOutletContext]=\"{fileInput: fileInput}\"></ng-template>\r\n <ng-template #fileInput>\r\n <input style=\"display: none;\" type=\"file\" ngFileSelect [options]=\"uploadOptions\" (change)=\"fileChangeEvent($event, f)\"\r\n (uploadOutput)=\"onUploadOutput($event)\" [uploadInput]=\"uploadInput\">\r\n </ng-template>\r\n </ng-container>\r\n </div>\r\n\r\n <div *ngIf=\"crop && !cropDone(f)\" (mouseenter)=\"startCropPreview(f.$newFile.id)\" (mouseleave)=\"stopCropPreview(f.$newFile.id)\">\r\n <div class=\"crop-container\" [ngStyle]=\"ngAddStyle\">\r\n\r\n <ui-file *ngIf=\"false && files.length > 0 && !cropSourceImages\" [fileSize]=\"fileSize\" [srcData]=\"files[0].custom\" [ngClass]=\"{rounded: cropRounded}\"></ui-file>\r\n\r\n <mat-spinner *ngIf=\"!cropperImageLoaded[f.$newFile.id] && cropSourceImages[f.$newFile.id]\" [diameter]=\"75\"></mat-spinner>\r\n\r\n <image-cropper *ngIf=\"cropSourceImages[f.$newFile.id]\"\r\n [imageFile]=\"cropSourceImages[f.$newFile.id]\"\r\n [maintainAspectRatio]=\"true\"\r\n [containWithinAspectRatio]=\"false\"\r\n [aspectRatio]=\"aspectRatio\"\r\n [resizeToWidth]=\"cropMaxWidth\"\r\n [onlyScaleDown]=\"false\"\r\n [roundCropper]=\"cropRounded\"\r\n [canvasRotation]=\"canvasRotation[f.$newFile.id]\"\r\n [transform]=\"transform[f.$newFile.id]\"\r\n [alignImage]=\"'center'\"\r\n [style.display]=\"showCropper ? null : 'none'\"\r\n [format]=\"'png'\"\r\n (imageCropped)=\"onImageCropped($event, f.$newFile.id)\"\r\n (imageLoaded)=\"imageLoaded(f.$newFile.id)\"\r\n (cropperReady)=\"cropperReady($event, f.$newFile.id)\"\r\n (loadImageFailed)=\"loadImageFailed()\"\r\n ></image-cropper>\r\n\r\n <div class=\"crop-preview mat-elevation-z2\" [class]=\"previewPosition\" *ngIf=\"true || (showCropPreview[f.$newFile.id] && cropperImageLoaded[f.$newFile.id])\">\r\n <div class=\"crop-menu\">\r\n <mat-icon (click)=\"zoomCroppedImage(.1, f.$newFile.id)\">zoom_in</mat-icon>\r\n <mat-icon (click)=\"zoomCroppedImage(- .1, f.$newFile.id)\">zoom_out</mat-icon>\r\n <mat-icon (click)=\"rotateCroppedImage(-1, f.$newFile.id)\">rotate_left</mat-icon>\r\n <mat-icon (click)=\"rotateCroppedImage(1, f.$newFile.id)\">rotate_right</mat-icon>\r\n <div style=\"flex: 1 1 100%\"></div>\r\n <label class=\"menu-item\">\r\n <mat-icon>upload_file</mat-icon>\r\n <input style=\"display: none;\" type=\"file\" ngFileSelect [options]=\"uploadOptions\" (change)=\"fileChangeEvent($event, f)\"\r\n (uploadOutput)=\"onUploadOutput($event)\" [uploadInput]=\"uploadInput\">\r\n </label>\r\n <mat-icon (click)=\"remove(f)\">delete_outline</mat-icon>\r\n <div style=\"flex: 1 1 100%\"></div>\r\n <mat-icon (click)=\"cropperDone(f.$newFile.id)\">done</mat-icon>\r\n </div>\r\n <img *ngIf=\"croppedImages[f.$newFile.id]\" [src]=\"croppedImages[f.$newFile.id].objectUrl\" [ngClass]=\"{rounded: cropRounded}\"/>\r\n </div>\r\n\r\n </div>\r\n\r\n\r\n\r\n </div>\r\n\r\n <ng-container *ngIf=\"!crop || cropDone(f)\">\r\n <ng-container *ngIf=\"fileTemplate\">\r\n <ng-template [ngTemplateOutlet]=\"fileTemplate\" [ngTemplateOutletContext]=\"{file: f, fileInput: fileInput2}\"></ng-template>\r\n <ng-template #fileInput2>\r\n <input style=\"display: none;\" type=\"file\" ngFileSelect [options]=\"uploadOptions\" (change)=\"fileChangeEvent($event, f)\"\r\n (uploadOutput)=\"onUploadOutput($event)\" [uploadInput]=\"uploadInput\">\r\n </ng-template>\r\n </ng-container>\r\n\r\n <ui-file *ngIf=\"!fileTemplate\" [fileSize]=\"fileSize\" [srcData]=\"f.$newFile ? f.$newFile: f.custom\" [ngClass]=\"{rounded: crop && cropRounded}\">\r\n </ui-file>\r\n\r\n <ng-container *ngIf=\"f.$newFile\">\r\n <div *ngIf=\"f.$newFile.responseStatus && f.$newFile.responseStatus !== 200\" class=\"progress-container error\">\r\n {{ translateService.instant('ui.controls.ui-file-uploader.uploadError', f.$newFile.response) }}\r\n </div>\r\n <div *ngIf=\"!f.$newFile.responseStatus && f.$newFile.progress.status === 1\" class=\"progress-container\">\r\n <div class=\"progress\" [ngStyle]=\"{width: f.$newFile.progress.data.percentage + '%'}\"></div>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n\r\n </div>\r\n\r\n <div class=\"file-container add\" ngFileDrop [options]=\"uploadOptions\" (uploadOutput)=\"onUploadOutput($event)\" [uploadInput]=\"uploadInput\" [ngClass]=\"{visible: files.length < maxFiles || maxFiles === 0}\" [ngStyle]=\"addFileTemplate ? {} : ngAddStyle\">\r\n <label>\r\n <ng-container *ngIf=\"addFileTemplate\">\r\n <ng-template [ngTemplateOutlet]=\"addFileTemplate\"></ng-template>\r\n </ng-container>\r\n <ng-container *ngIf=\"!addFileTemplate\">\r\n <div class=\"upload-image-container\"></div>\r\n <img [src]=\"addFileImgSrc\" [ngClass]=\"{'with-hint': addHint}\" />\r\n <div *ngIf=\"addHint\" class=\"add-hint\">{{addHint}}</div>\r\n </ng-container>\r\n <input style=\"display: none;\" type=\"file\" ngFileSelect [options]=\"uploadOptions\" (uploadOutput)=\"onUploadOutput($event)\" [uploadInput]=\"uploadInput\" [multiple]=\"maxFiles === 0 && multiple\">\r\n </label>\r\n </div>\r\n\r\n</div>\r\n", styles: [":host{display:flex;flex-wrap:wrap}:host .label .text{font-size:.9em;line-height:1em;padding:6px 0 4px}:host .files-container{display:flex;flex-wrap:wrap;border-style:solid}:host .files-container .existing-files{display:flex;flex-wrap:wrap}:host .files-container.dragging .add label{border:2px dashed grey;background-color:#0000001a}:host .files-container.disabled .add{opacity:.5;pointer-events:none}:host .file-container{max-width:100%;max-height:100%;position:relative;display:flex;align-items:center;justify-content:center}:host .file-container .progress-container{position:absolute;bottom:0;left:1px;right:1px;height:20%;max-height:20px;background-color:#0000001a}:host .file-container .progress-container.error{background-color:red;color:#fff;display:flex;align-items:center;justify-content:center}:host .file-container .progress-container .progress{background-color:#0000004d;height:100%}:host .file-container.add{display:flex;align-items:center;flex-direction:column;transition:opacity .25s;cursor:pointer}:host .file-container.add:not(.visible){display:none}:host .file-container.add img{max-width:100%;max-height:100%}:host .file-container.add img.with-hint{max-height:75%}:host .file-container.add .add-hint{margin-top:8px;font-size:80%;text-align:center}:host .file-container.add label{position:absolute;inset:0;cursor:pointer;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center}:host .file-container.add .upload-image-container{display:none}:host .file-container .file-menu-container{display:none;position:absolute;left:calc(100% - 45px);top:27px;z-index:1000}:host .file-container .file-menu-container ::ng-deep .menu-item{position:relative;padding:12px 24px;cursor:pointer;display:block}:host .file-container .file-menu-container.visible{display:block}:host .file-container .file-menu{display:flex;position:absolute;flex-direction:column;align-items:center;justify-content:center;padding:12px;right:10px;top:10px;background-color:#fff9;border-radius:50%;cursor:pointer;transition:all .25s;z-index:999}:host .file-container:hover .file-menu{background-color:#fff;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}:host .file-container mat-progress-bar{position:absolute;bottom:0;height:6px;left:0;right:0;z-index:1000}:host image-cropper{padding:0}:host ui-file.rounded ::ng-deep img{border-radius:50%}:host .crop-container{display:flex;align-items:center;justify-content:center;position:relative}:host .crop-container mat-spinner{position:absolute;z-index:1}:host .crop-container .crop-preview{position:absolute;top:100%;left:0;right:0;padding:6px;border:1px solid transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000;max-width:350px;margin-right:auto;margin-left:auto}:host .crop-container .crop-preview.left{right:calc(100% + 6px);left:unset;top:0}:host .crop-container .crop-preview.above{bottom:100%;top:unset}:host .crop-container .crop-preview .crop-menu{width:100%;flex:0 0 auto;display:flex}:host .crop-container .crop-preview .crop-menu mat-icon{margin:0 3px;width:calc(1em + 6px);height:1em;font-size:2em;cursor:pointer;user-select:none;flex:1 1 100%}:host .crop-container .crop-preview img{margin:16px 0;max-width:256px;max-height:256px}:host .crop-container .crop-preview img.rounded{border-radius:50%}\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.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i3.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "directive", type: i5.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "directive", type: i6.NgFileDropDirective, selector: "[ngFileDrop]", inputs: ["options", "uploadInput"], outputs: ["uploadOutput"] }, { kind: "directive", type: i6.NgFileSelectDirective, selector: "[ngFileSelect]", inputs: ["options", "uploadInput"], outputs: ["uploadOutput"] }, { kind: "component", type: i7.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "mode", "value", "diameter", "strokeWidth"], exportAs: ["matProgressSpinner"] }, { kind: "component", type: i8.ImageCropperComponent, selector: "image-cropper", inputs: ["imageChangedEvent", "imageURL", "imageBase64", "imageFile", "imageAltText", "cropperFrameAriaLabel", "output", "format", "transform", "maintainAspectRatio", "aspectRatio", "resetCropOnAspectRatioChange", "resizeToWidth", "resizeToHeight", "cropperMinWidth", "cropperMinHeight", "cropperMaxHeight", "cropperMaxWidth", "cropperStaticWidth", "cropperStaticHeight", "canvasRotation", "initialStepSize", "roundCropper", "onlyScaleDown", "imageQuality", "autoCrop", "backgroundColor", "containWithinAspectRatio", "hideResizeSquares", "allowMoveImage", "cropper", "alignImage", "disabled", "hidden"], outputs: ["imageCropped", "startCropImage", "imageLoaded", "cropperReady", "loadImageFailed", "transformChange"] }, { kind: "component", type: i9.FileComponent, selector: "ui-file", inputs: ["fileSize", "srcOptions", "srcData", "srcUrl"] }] }); }
|
|
356
|
+
}
|
|
357
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.11", ngImport: i0, type: UiFileUploaderComponent, decorators: [{
|
|
358
|
+
type: Component,
|
|
359
|
+
args: [{ selector: 'ui-file-uploader', providers: [{
|
|
360
|
+
provide: NG_VALUE_ACCESSOR,
|
|
361
|
+
multi: true,
|
|
362
|
+
useExisting: UiFileUploaderComponent,
|
|
363
|
+
}], template: "<div class=\"label\" *ngIf=\"label\">\r\n <div class=\"text-container\" [matTooltip]=\"required ? translateService.instant('ui.controls.validation.required') : undefined\" [matTooltipPosition]=\"'above'\">\r\n <div class=\"text\">{{label}}</div>\r\n <div *ngIf=\"required\" class=\"required\">*</div>\r\n </div>\r\n</div>\r\n\r\n<div class=\"files-container\" [ngClass]=\"{dragging: dragging, disabled: uploading || !editable}\">\r\n\r\n <div class=\"existing-files\">\r\n\r\n <div class=\"file-container\" *ngFor=\"let f of files\">\r\n\r\n <div class=\"file-menu\" (click)=\"toggleMenuVisibility(f)\" *ngIf=\"!customFileMenu && editable && !uploading\">\r\n <mat-icon>menu</mat-icon>\r\n </div>\r\n <div class=\"file-menu-container mat-elevation-z2\" [ngClass]=\"{visible: f === fileMenuOpened}\" (click)=\"menuClick()\" (mouseleave)=\"menuClick()\">\r\n <ng-container *ngIf=\"!menuTemplate\">\r\n <label class=\"menu-item\">{{ translateService.instant('ui.controls.ui-file-uploader.menu.change') }}\r\n <input *ngIf=\"!refreshAddInput\" style=\"display: none;\" type=\"file\" ngFileSelect [options]=\"uploadOptions\" (change)=\"fileChangeEvent($event, f)\"\r\n (uploadOutput)=\"onUploadOutput($event)\" [uploadInput]=\"uploadInput\">\r\n </label>\r\n <div class=\"menu-item\" (click)=\"remove(f)\">{{ translateService.instant('ui.controls.ui-file-uploader.menu.delete') }}</div>\r\n </ng-container>\r\n <ng-container *ngIf=\"menuTemplate\">\r\n <ng-template [ngTemplateOutlet]=\"menuTemplate\" [ngTemplateOutletContext]=\"{fileInput: fileInput}\"></ng-template>\r\n <ng-template #fileInput>\r\n <input style=\"display: none;\" type=\"file\" ngFileSelect [options]=\"uploadOptions\" (change)=\"fileChangeEvent($event, f)\"\r\n (uploadOutput)=\"onUploadOutput($event)\" [uploadInput]=\"uploadInput\">\r\n </ng-template>\r\n </ng-container>\r\n </div>\r\n\r\n <div *ngIf=\"crop && !cropDone(f)\" (mouseenter)=\"startCropPreview(f.$newFile.id)\" (mouseleave)=\"stopCropPreview(f.$newFile.id)\">\r\n <div class=\"crop-container\" [ngStyle]=\"ngAddStyle\">\r\n\r\n <ui-file *ngIf=\"false && files.length > 0 && !cropSourceImages\" [fileSize]=\"fileSize\" [srcData]=\"files[0].custom\" [ngClass]=\"{rounded: cropRounded}\"></ui-file>\r\n\r\n <mat-spinner *ngIf=\"!cropperImageLoaded[f.$newFile.id] && cropSourceImages[f.$newFile.id]\" [diameter]=\"75\"></mat-spinner>\r\n\r\n <image-cropper *ngIf=\"cropSourceImages[f.$newFile.id]\"\r\n [imageFile]=\"cropSourceImages[f.$newFile.id]\"\r\n [maintainAspectRatio]=\"true\"\r\n [containWithinAspectRatio]=\"false\"\r\n [aspectRatio]=\"aspectRatio\"\r\n [resizeToWidth]=\"cropMaxWidth\"\r\n [onlyScaleDown]=\"false\"\r\n [roundCropper]=\"cropRounded\"\r\n [canvasRotation]=\"canvasRotation[f.$newFile.id]\"\r\n [transform]=\"transform[f.$newFile.id]\"\r\n [alignImage]=\"'center'\"\r\n [style.display]=\"showCropper ? null : 'none'\"\r\n [format]=\"'png'\"\r\n (imageCropped)=\"onImageCropped($event, f.$newFile.id)\"\r\n (imageLoaded)=\"imageLoaded(f.$newFile.id)\"\r\n (cropperReady)=\"cropperReady($event, f.$newFile.id)\"\r\n (loadImageFailed)=\"loadImageFailed()\"\r\n ></image-cropper>\r\n\r\n <div class=\"crop-preview mat-elevation-z2\" [class]=\"previewPosition\" *ngIf=\"true || (showCropPreview[f.$newFile.id] && cropperImageLoaded[f.$newFile.id])\">\r\n <div class=\"crop-menu\">\r\n <mat-icon (click)=\"zoomCroppedImage(.1, f.$newFile.id)\">zoom_in</mat-icon>\r\n <mat-icon (click)=\"zoomCroppedImage(- .1, f.$newFile.id)\">zoom_out</mat-icon>\r\n <mat-icon (click)=\"rotateCroppedImage(-1, f.$newFile.id)\">rotate_left</mat-icon>\r\n <mat-icon (click)=\"rotateCroppedImage(1, f.$newFile.id)\">rotate_right</mat-icon>\r\n <div style=\"flex: 1 1 100%\"></div>\r\n <label class=\"menu-item\">\r\n <mat-icon>upload_file</mat-icon>\r\n <input style=\"display: none;\" type=\"file\" ngFileSelect [options]=\"uploadOptions\" (change)=\"fileChangeEvent($event, f)\"\r\n (uploadOutput)=\"onUploadOutput($event)\" [uploadInput]=\"uploadInput\">\r\n </label>\r\n <mat-icon (click)=\"remove(f)\">delete_outline</mat-icon>\r\n <div style=\"flex: 1 1 100%\"></div>\r\n <mat-icon (click)=\"cropperDone(f.$newFile.id)\">done</mat-icon>\r\n </div>\r\n <img *ngIf=\"croppedImages[f.$newFile.id]\" [src]=\"croppedImages[f.$newFile.id].objectUrl\" [ngClass]=\"{rounded: cropRounded}\"/>\r\n </div>\r\n\r\n </div>\r\n\r\n\r\n\r\n </div>\r\n\r\n <ng-container *ngIf=\"!crop || cropDone(f)\">\r\n <ng-container *ngIf=\"fileTemplate\">\r\n <ng-template [ngTemplateOutlet]=\"fileTemplate\" [ngTemplateOutletContext]=\"{file: f, fileInput: fileInput2}\"></ng-template>\r\n <ng-template #fileInput2>\r\n <input style=\"display: none;\" type=\"file\" ngFileSelect [options]=\"uploadOptions\" (change)=\"fileChangeEvent($event, f)\"\r\n (uploadOutput)=\"onUploadOutput($event)\" [uploadInput]=\"uploadInput\">\r\n </ng-template>\r\n </ng-container>\r\n\r\n <ui-file *ngIf=\"!fileTemplate\" [fileSize]=\"fileSize\" [srcData]=\"f.$newFile ? f.$newFile: f.custom\" [ngClass]=\"{rounded: crop && cropRounded}\">\r\n </ui-file>\r\n\r\n <ng-container *ngIf=\"f.$newFile\">\r\n <div *ngIf=\"f.$newFile.responseStatus && f.$newFile.responseStatus !== 200\" class=\"progress-container error\">\r\n {{ translateService.instant('ui.controls.ui-file-uploader.uploadError', f.$newFile.response) }}\r\n </div>\r\n <div *ngIf=\"!f.$newFile.responseStatus && f.$newFile.progress.status === 1\" class=\"progress-container\">\r\n <div class=\"progress\" [ngStyle]=\"{width: f.$newFile.progress.data.percentage + '%'}\"></div>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n\r\n </div>\r\n\r\n <div class=\"file-container add\" ngFileDrop [options]=\"uploadOptions\" (uploadOutput)=\"onUploadOutput($event)\" [uploadInput]=\"uploadInput\" [ngClass]=\"{visible: files.length < maxFiles || maxFiles === 0}\" [ngStyle]=\"addFileTemplate ? {} : ngAddStyle\">\r\n <label>\r\n <ng-container *ngIf=\"addFileTemplate\">\r\n <ng-template [ngTemplateOutlet]=\"addFileTemplate\"></ng-template>\r\n </ng-container>\r\n <ng-container *ngIf=\"!addFileTemplate\">\r\n <div class=\"upload-image-container\"></div>\r\n <img [src]=\"addFileImgSrc\" [ngClass]=\"{'with-hint': addHint}\" />\r\n <div *ngIf=\"addHint\" class=\"add-hint\">{{addHint}}</div>\r\n </ng-container>\r\n <input style=\"display: none;\" type=\"file\" ngFileSelect [options]=\"uploadOptions\" (uploadOutput)=\"onUploadOutput($event)\" [uploadInput]=\"uploadInput\" [multiple]=\"maxFiles === 0 && multiple\">\r\n </label>\r\n </div>\r\n\r\n</div>\r\n", styles: [":host{display:flex;flex-wrap:wrap}:host .label .text{font-size:.9em;line-height:1em;padding:6px 0 4px}:host .files-container{display:flex;flex-wrap:wrap;border-style:solid}:host .files-container .existing-files{display:flex;flex-wrap:wrap}:host .files-container.dragging .add label{border:2px dashed grey;background-color:#0000001a}:host .files-container.disabled .add{opacity:.5;pointer-events:none}:host .file-container{max-width:100%;max-height:100%;position:relative;display:flex;align-items:center;justify-content:center}:host .file-container .progress-container{position:absolute;bottom:0;left:1px;right:1px;height:20%;max-height:20px;background-color:#0000001a}:host .file-container .progress-container.error{background-color:red;color:#fff;display:flex;align-items:center;justify-content:center}:host .file-container .progress-container .progress{background-color:#0000004d;height:100%}:host .file-container.add{display:flex;align-items:center;flex-direction:column;transition:opacity .25s;cursor:pointer}:host .file-container.add:not(.visible){display:none}:host .file-container.add img{max-width:100%;max-height:100%}:host .file-container.add img.with-hint{max-height:75%}:host .file-container.add .add-hint{margin-top:8px;font-size:80%;text-align:center}:host .file-container.add label{position:absolute;inset:0;cursor:pointer;z-index:10;display:flex;flex-direction:column;align-items:center;justify-content:center}:host .file-container.add .upload-image-container{display:none}:host .file-container .file-menu-container{display:none;position:absolute;left:calc(100% - 45px);top:27px;z-index:1000}:host .file-container .file-menu-container ::ng-deep .menu-item{position:relative;padding:12px 24px;cursor:pointer;display:block}:host .file-container .file-menu-container.visible{display:block}:host .file-container .file-menu{display:flex;position:absolute;flex-direction:column;align-items:center;justify-content:center;padding:12px;right:10px;top:10px;background-color:#fff9;border-radius:50%;cursor:pointer;transition:all .25s;z-index:999}:host .file-container:hover .file-menu{background-color:#fff;box-shadow:0 5px 5px -3px #0003,0 8px 10px 1px #00000024,0 3px 14px 2px #0000001f}:host .file-container mat-progress-bar{position:absolute;bottom:0;height:6px;left:0;right:0;z-index:1000}:host image-cropper{padding:0}:host ui-file.rounded ::ng-deep img{border-radius:50%}:host .crop-container{display:flex;align-items:center;justify-content:center;position:relative}:host .crop-container mat-spinner{position:absolute;z-index:1}:host .crop-container .crop-preview{position:absolute;top:100%;left:0;right:0;padding:6px;border:1px solid transparent;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1000;max-width:350px;margin-right:auto;margin-left:auto}:host .crop-container .crop-preview.left{right:calc(100% + 6px);left:unset;top:0}:host .crop-container .crop-preview.above{bottom:100%;top:unset}:host .crop-container .crop-preview .crop-menu{width:100%;flex:0 0 auto;display:flex}:host .crop-container .crop-preview .crop-menu mat-icon{margin:0 3px;width:calc(1em + 6px);height:1em;font-size:2em;cursor:pointer;user-select:none;flex:1 1 100%}:host .crop-container .crop-preview img{margin:16px 0;max-width:256px;max-height:256px}:host .crop-container .crop-preview img.rounded{border-radius:50%}\n"] }]
|
|
364
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
365
|
+
type: Optional
|
|
366
|
+
}, {
|
|
367
|
+
type: Inject,
|
|
368
|
+
args: [UI_FILESERVICE]
|
|
369
|
+
}] }, { type: undefined, decorators: [{
|
|
370
|
+
type: Inject,
|
|
371
|
+
args: [UI_TRANSLATESERVICE]
|
|
372
|
+
}] }, { type: i1.ControlContainer, decorators: [{
|
|
373
|
+
type: Optional
|
|
374
|
+
}, {
|
|
375
|
+
type: Host
|
|
376
|
+
}, {
|
|
377
|
+
type: SkipSelf
|
|
378
|
+
}] }, { type: i2.UiFileService }]; }, propDecorators: { maxFiles: [{
|
|
379
|
+
type: Input
|
|
380
|
+
}], multiple: [{
|
|
381
|
+
type: Input
|
|
382
|
+
}], crop: [{
|
|
383
|
+
type: Input
|
|
384
|
+
}], cropRounded: [{
|
|
385
|
+
type: Input
|
|
386
|
+
}], cropMaxWidth: [{
|
|
387
|
+
type: Input
|
|
388
|
+
}], fileSize: [{
|
|
389
|
+
type: Input
|
|
390
|
+
}], customFileMenu: [{
|
|
391
|
+
type: Input
|
|
392
|
+
}], addHint: [{
|
|
393
|
+
type: Input
|
|
394
|
+
}], newFilePosition: [{
|
|
395
|
+
type: Input
|
|
396
|
+
}], templates: [{
|
|
397
|
+
type: Input
|
|
398
|
+
}], previewPosition: [{
|
|
399
|
+
type: Input
|
|
400
|
+
}], imageCropped: [{
|
|
401
|
+
type: Output
|
|
402
|
+
}], fileEvent: [{
|
|
403
|
+
type: Output
|
|
404
|
+
}] } });
|
|
405
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ui-file-uploader.component.js","sourceRoot":"","sources":["../../../../../projects/ui/src/lib/file-uploader/ui-file-uploader.component.ts","../../../../../projects/ui/src/lib/file-uploader/ui-file-uploader.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,YAAY,EACZ,IAAI,EACJ,MAAM,EACN,KAAK,EAGL,QAAQ,EACR,MAAM,EACN,QAAQ,EACT,MAAM,eAAe,CAAC;AACvB,OAAO,EAAoB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAErE,OAAO,EAA0C,cAAc,EAAiB,MAAM,6BAA6B,CAAC;AAEpH,OAAO,EAAE,iBAAiB,EAAE,MAAM,uCAAuC,CAAC;AAC1E,OAAO,EAAuB,mBAAmB,EAAE,MAAM,kCAAkC,CAAC;;;;;;;;;;;AA2B5F,MAAM,OAAO,uBAAwB,SAAQ,iBAAiB;IAc5D,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,SAAS,EAAE,YAAY,CAAC;IACtC,CAAC;IAED,IAAI,eAAe;QACjB,OAAO,IAAI,CAAC,SAAS,EAAE,eAAe,CAAC;IACzC,CAAC;IAED,IAAI,YAAY;QACd,OAAO,IAAI,CAAC,SAAS,EAAE,YAAY,CAAC;IACtC,CAAC;IAwCD,YAAwD,iBAAiC,EACzC,gBAAqC,EAC/B,gBAAkC,EACpE,WAA0B;QAE5C,KAAK,CAAC,IAAI,EAAE,gBAAgB,CAAC,CAAC;QALwB,sBAAiB,GAAjB,iBAAiB,CAAgB;QACzC,qBAAgB,GAAhB,gBAAgB,CAAqB;QAC/B,qBAAgB,GAAhB,gBAAgB,CAAkB;QACpE,gBAAW,GAAX,WAAW,CAAe;QAjErC,aAAQ,GAAG,CAAC,CAAC;QACb,aAAQ,GAAG,IAAI,CAAC;QAChB,SAAI,GAAG,KAAK,CAAC;QACb,gBAAW,GAAG,KAAK,CAAC;QAEpB,aAAQ,GAAG,SAAS,CAAC;QACrB,mBAAc,GAAG,KAAK,CAAC;QAEvB,oBAAe,GAAqB,MAAM,CAAC;QAE3C,cAAS,GAAsE,EAAE,CAAA;QAcjF,oBAAe,GAAgC,QAAQ,CAAC;QAEvD,iBAAY,GAAG,IAAI,YAAY,EAAE,CAAC;QAClC,cAAS,GAAG,IAAI,YAAY,EAA0B,CAAC;QAEjE,kBAAa,GAAoB;YAC/B,WAAW,EAAE,IAAI,CAAC,iBAAiB,CAAC,iBAAiB;SACtD,CAAC;QAEK,cAAS,GAAG,KAAK,CAAC;QAIzB,gBAAW,GAAG,KAAK,CAAC;QAEpB,oBAAe,GAAG,EAAE,CAAC;QACrB,wBAAmB,GAAG,EAAE,CAAC;QACzB,qBAAgB,GAAG,EAAE,CAAC;QACtB,uBAAkB,GAAG,EAAE,CAAC;QACxB,eAAU,GAAG,EAAE,CAAC;QAChB,cAAS,GAAmB,EAAE,CAAC;QAC/B,mBAAc,GAAG,EAAE,CAAA;QAMnB,oBAAe,GAAG,KAAK,CAAC;QAIxB,mBAAc,GAAG,KAAK,CAAC;QAEvB,eAAU,GAAG,KAAK,CAAC;QACnB,aAAQ,GAAG,KAAK,CAAC;QAEjB,eAAU,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,OAAO,CAAC,CAAC;QA4BjD,kBAAa,GAAG,EAAE,CAAC;QAnBjB,IAAI,CAAC,WAAW,CAAC,kBAAkB,CAAC,IAAI,CAAC,EAAC,MAAM,EAAE,UAAU,EAAE,IAAI,EAAE,IAAI,EAAC,CAAC,CAAC;QAE3E,IAAI,CAAC,WAAW,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC,CAAM,EAAE,EAAE;YACvD,QAAQ,CAAC,CAAC,MAAM,EAAE;gBAChB,KAAK,eAAe;oBAAE,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;oBAAC,MAAM;gBACnD,KAAK,cAAc,CAAC;gBACpB,KAAK,eAAe;oBAClB,UAAU,CAAC,GAAG,EAAE;wBACd,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;oBACzB,CAAC,CAAC,CAAC;oBACH,IAAI,CAAC,WAAW,EAAE,CAAC;aACtB;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC;IACtC,CAAC;IAID,IAAI,QAAQ;QACV,OAAO,IAAI,CAAC,oBAAoB,CAAC,OAAO,CAAC;IAC3C,CAAC;IAED,IAAI,UAAU;QACZ,OAAO;YACL,KAAK,EAAE,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI;YAC3E,MAAM,EAAE,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI;SAC7E,CAAA;IACH,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,iBAAiB,CAAC,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;IACnH,CAAC;IAED,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,iBAAiB,CAAC,aAAa,CAAC;IAC9C,CAAC;IAED,QAAQ,CAAC,CAAC;QACR,OAAO,CAAC,CAAC,CAAC,QAAQ,IAAI,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;IACvD,CAAC;IAED,qBAAqB;IACrB,sBAAsB;IACtB,IAAI;IAEJ,WAAW;QACT,IAAI,CAAC,WAAW,CAAC,kBAAkB,CAAC,IAAI,CAAC,EAAC,MAAM,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,EAAC,CAAC,CAAC;IAC5E,CAAC;IAED,MAAM,CAAC,CAAM;QACX,IAAI,CAAC,CAAC,QAAQ,EAAE;YACd,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAC,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,EAAE,EAAC,CAAC,CAAC;SAC5D;QACD,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAC5C,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,gGAAgG;QAChG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC;QAC7D,0BAA0B;IACxB,CAAC;IAED,WAAW;QACT,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,yBAAyB;QACzB,uEAAuE;QACvE,WAAW;QACX,+FAA+F;QAC/F,IAAI;QACJ,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;IAC9B,CAAC;IAED,IAAI,gBAAgB;QAClB,OAAO,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC;IAChF,CAAC;IAED,eAAe,CAAC,IAAY;QAC1B,OAAO,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;IAChE,CAAC;IAED,cAAc,CAAC,MAAoB,EAAE,oBAAoB,GAAG,KAAK;QAC/D,uBAAuB;QACvB,QAAQ,MAAM,CAAC,IAAI,EAAE;YACnB,KAAK,OAAO;gBACV,MAAM;YAER,KAAK,UAAU;gBACb,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;gBACrB,MAAM;YACR,KAAK,SAAS,CAAC;YACf,KAAK,MAAM;gBACT,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;gBACtB,MAAM;YAER,KAAK,cAAc;gBACjB,IAAI,IAAI,CAAC,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE;oBACvD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC;oBAC9D,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,qBAAqB,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC;oBAC3E,OAAO;iBACR;gBAED,IAAI,CAAC,oBAAoB,IAAI,IAAI,CAAC,iBAAiB,CAAC,cAAc,EAAE;oBAClE,IAAI,CAAC,iBAAiB,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,EAAE,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;wBAC7E,IAAI,KAAK,EAAE;4BACT,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,IAAI,CAAC,CAAA;yBAClC;6BAAM;4BACL,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,CAAC,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC;4BAC9D,8EAA8E;yBAC/E;oBACH,CAAC,CAAC,CAAA;iBACH;qBAAM;oBACL,IAAI,CAAC,CAAC;oBACN,IAAI,IAAI,CAAC,eAAe,KAAK,SAAS,EAAE;wBACtC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;wBACrC,IAAI,CAAC,CAAC,QAAQ,EAAE;4BACd,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CAAC,QAAQ,CAAC,EAAE,EAAE,CAAC,CAAC;yBAC9D;wBACD,CAAC,CAAC,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC;wBACzB,CAAC,CAAC,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC;wBACvB,IAAI,CAAC,eAAe,GAAG,SAAS,CAAC;qBAClC;yBAAM;wBACL,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,CAAC,IAAI,EAAE,QAAQ,EAAE,MAAM,CAAC,IAAI,EAAE,CAAC;wBACnD,IAAI,IAAI,CAAC,eAAe,KAAK,MAAM,EAAE;4BACnC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;yBACpB;6BAAM;4BACL,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;yBACvB;qBACF;oBACD,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;wBAC1C,IAAI,IAAI,CAAC,IAAI,EAAE;4BACb,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;4BACxC,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC;4BAC/D,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC;yBACjD;qBACF;oBACD,IAAI,CAAC,eAAe,EAAE,CAAC;oBACvB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,OAAO,EAAE,WAAW,EAAE,IAAI,EAAE,CAAC,EAAE,CAAC,CAAC;iBACxD;gBACD,MAAM;YAER,KAAK,MAAM;gBACT,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,MAAM,CAAC,IAAI,CAAC,CAAC;gBAC5D,IAAI,EAAE,EAAE;oBACN,IAAI,EAAE,CAAC,QAAQ,CAAC,cAAc,KAAK,GAAG,EAAE;wBACtC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,GAAG,EAAE,CAAC,QAAQ,CAAC,QAAQ,CAAC;wBACjE,EAAE,CAAC,QAAQ,GAAG,IAAI,CAAC;qBACpB;yBAAM;wBACL,6CAA6C;qBAC9C;iBACF;gBACD,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;oBAC1B,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;oBAC5B,IAAI,CAAC,WAAW,CAAC,kBAAkB,CAAC,IAAI,CAAC;wBACvC,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,sBAAsB;qBAC5F,CAAC,CAAC;iBACJ;gBACD,MAAM;SACT;IACH,CAAC;IAED,eAAe,CAAC,MAAM,GAAG,IAAI;QAC3B,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;gBACvB,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;aACzB;YACD,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC;YAC9B,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,EAAC,GAAG,CAAC,CAAC,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC,QAAQ,EAAC,CAAC,CAAC,CAAC;SACvF;aAAM;YACL,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;gBAC3B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;aAC3B;iBAAM;gBACL,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;oBACvB,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;iBACzB;gBACD,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;oBAC5C,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;gBAClD,CAAC,CAAC,CAAC;gBACH,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC;aACtD;SACF;QACD,IAAI,MAAM,EAAE;YACV,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;SACnC;QAED,qGAAqG;QACrG,kCAAkC;QAClC,kEAAkE;QAClE,qGAAqG;QACrG,kCAAkC;QAClC,iBAAiB;QACjB,qDAAqD;IACvD,CAAC;IAED,UAAU;QACR,OAAO,IAAI,OAAO,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;YAC9B,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE;gBACrB,IAAI,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE;oBAClD,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC;iBAChC;gBACD,IAAI,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,EAAE;oBAC9D,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;iBACjC;YACH,CAAC,CAAC,CAAA;YACF,UAAU,CAAC,GAAG,EAAE;gBACd,GAAG,CAAC,MAAM,CAAC,CAAC;YACd,CAAC,EAAE,GAAG,CAAC,CAAC;QACV,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,eAAe,CAAC,KAAU,EAAE,CAAM;QAChC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;IAC/C,CAAC;IAED,gBAAgB,CAAC,EAAE;QACjB,YAAY,CAAC,IAAI,CAAC,mBAAmB,CAAC,EAAE,CAAC,CAAC,CAAC;QAC3C,IAAI,CAAC,eAAe,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAC;IACzD,CAAC;IAED,eAAe,CAAC,EAAE;QAChB,IAAI,CAAC,mBAAmB,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,GAAG,EAAE;YAC7C,IAAI,CAAC,eAAe,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC;QACnC,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;IAED,gBAAgB,CAAC,GAAG,EAAE,EAAE;QACtB,IAAI,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC;QACrC,KAAK,IAAI,GAAG,CAAC;QACb,IAAI,KAAK,GAAG,GAAG,EAAE;YACf,KAAK,GAAG,GAAG,CAAC;SACb;QACD,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,GAAG;YACnB,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC;YACrB,KAAK;SACN,CAAC;IACJ,CAAC;IAED,kBAAkB,CAAC,GAAG,EAAE,EAAE;QACxB,IAAI,CAAC,cAAc,CAAC,EAAE,CAAC,IAAI,GAAG,CAAC;QAC/B,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC;QAC1C,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC;QAC1C,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,GAAG;YACnB,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC;YACrB,KAAK,EAAE,QAAQ;YACf,KAAK,EAAE,QAAQ;SAChB,CAAC;IACJ,CAAC;IAED,cAAc,CAAC,KAAwB,EAAE,EAAE;QACzC,IAAI,CAAC,aAAa,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAED,WAAW,CAAC,EAAE;QACZ,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,GAAG;gBACnB,KAAK,EAAE,CAAC;aACT,CAAC;QACJ,CAAC,CAAC,CAAC;IACL,CAAC;IAED,YAAY,CAAC,qBAAiC,EAAE,EAAE;QAChD,IAAI,CAAC,kBAAkB,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC;IACrC,CAAC;IAED,eAAe;IACf,CAAC;IAED,oBAAoB,CAAC,CAAC;QACpB,IAAI,CAAC,cAAc,GAAG,CAAC,CAAC;IAC1B,CAAC;IAED,SAAS;QACP,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC;IAClC,CAAC;IAGD,UAAU,CAAC,GAAQ;QACjB,IAAI,CAAC,UAAU,GAAG,GAAG,YAAY,KAAK,CAAC;QACvC,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;SAC5D;aAAM;YACL,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC,CAAC,CAAE,EAAE,MAAM,EAAC,GAAG,EAAE,QAAQ,EAAE,IAAI,EAAC,CAAE,CAAC,CAAC,CAAC,EAAE,CAAC;SAC3D;QACD,IAAI,CAAC,gBAAgB,GAAG,EAAE,CAAC;IAC7B,CAAC;IAED,WAAW,CAAC,EAAE;QACZ,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,QAAQ,IAAI,EAAE,CAAC,QAAQ,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;QACtE,IAAI,CAAC,EAAE;YACL,sCAAsC;YACtC,oBAAoB;YACpB,aAAa;YACb,6BAA6B;YAC7B,oBAAoB;YACpB,+DAA+D;YAC/D,0BAA0B;YAC1B,UAAU;YACV,oCAAoC;YACpC,oDAAoD;YACpD,oDAAoD;YACpD,kCAAkC;YAClC,sBAAsB;YACtB,OAAO;YACP,MAAM,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,EAAE,CAAC,CAAC;YAC5C,CAAC,CAAC,QAAQ,CAAC,UAAU,GAAG,IAAI,IAAI,CAAC,CAAE,YAAY,CAAC,IAAI,CAAE,EAAE,UAAU,EAAE;gBAClE,IAAI,EAAE,WAAW;aAClB,CAAC,CAAC;YACH,CAAC,CAAC,QAAQ,CAAC,IAAI,GAAG,UAAU,CAAC;YAC7B,CAAC,CAAC,QAAQ,CAAC,IAAI,GAAG,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC;YAC7C,CAAC,CAAC,QAAQ,CAAC,IAAI,GAAG,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC;YAC7C,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC;YAC3B,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;SAChB;IACH,CAAC;+GAlYU,uBAAuB,kBAgEF,cAAc,6BAC1B,mBAAmB;mGAjE5B,uBAAuB,0ZANvB,CAAC;gBACV,OAAO,EAAE,iBAAiB;gBAC1B,KAAK,EAAE,IAAI;gBACX,WAAW,EAAE,uBAAuB;aACrC,CAAC,iDC1CJ,67OA4HA;;4FDhFa,uBAAuB;kBAVnC,SAAS;+BACE,kBAAkB,aAGjB,CAAC;4BACV,OAAO,EAAE,iBAAiB;4BAC1B,KAAK,EAAE,IAAI;4BACX,WAAW,yBAAyB;yBACrC,CAAC;;0BAkEW,QAAQ;;0BAAI,MAAM;2BAAC,cAAc;;0BACjC,MAAM;2BAAC,mBAAmB;;0BAC1B,QAAQ;;0BAAI,IAAI;;0BAAI,QAAQ;wEAhEhC,QAAQ;sBAAhB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBAcG,eAAe;sBAAvB,KAAK;gBAEI,YAAY;sBAArB,MAAM;gBACG,SAAS;sBAAlB,MAAM","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  Host,\r\n  Inject,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Optional,\r\n  Output,\r\n  SkipSelf\r\n} from '@angular/core';\r\nimport { ControlContainer, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { UploaderOptions, UploadFile, UploadInput, UploadOutput } from 'ngx-uploader';\r\nimport { IUiFileService, IUiFileServiceMessages, UI_FILESERVICE, UiFileService } from '../services/ui-file.service';\r\nimport { Dimensions, ImageCroppedEvent, ImageTransform } from 'ngx-image-cropper';\r\nimport { UiSimpleComponent } from '../layouts/simple/ui-simple.component';\r\nimport { IUiTranslateService, UI_TRANSLATESERVICE } from '../services/ui-translate.service';\r\nimport { skip } from 'rxjs';\r\n\r\nexport interface UploadOutputEx extends UploadOutput {\r\n  file: UploadFileEx;\r\n}\r\n\r\nexport interface UploadFileEx extends UploadFile {\r\n  imagePreview?: any;\r\n  base64?: any;\r\n}\r\n\r\nexport interface IUiUploaderUserMessage {\r\n  message: IUiFileServiceMessages,\r\n  data: any\r\n}\r\n\r\n@Component({\r\n  selector: 'ui-file-uploader',\r\n  templateUrl: './ui-file-uploader.component.html',\r\n  styleUrls: [ './ui-file-uploader.component.scss'],\r\n  providers: [{\r\n    provide: NG_VALUE_ACCESSOR,\r\n    multi: true,\r\n    useExisting: UiFileUploaderComponent,\r\n  }]\r\n})\r\nexport class UiFileUploaderComponent extends UiSimpleComponent implements OnInit, OnDestroy {\r\n\r\n  @Input() maxFiles = 1;\r\n  @Input() multiple = true;\r\n  @Input() crop = false;\r\n  @Input() cropRounded = false;\r\n  @Input() cropMaxWidth;\r\n  @Input() fileSize = 'default';\r\n  @Input() customFileMenu = false;\r\n  @Input() addHint;\r\n  @Input() newFilePosition: 'first' | 'last' = 'last';\r\n\r\n  @Input() templates: { menuTemplate?: any, addFileTemplate?: any, fileTemplate?: any } = {}\r\n\r\n  get menuTemplate() {\r\n    return this.templates?.menuTemplate;\r\n  }\r\n\r\n  get addFileTemplate() {\r\n    return this.templates?.addFileTemplate;\r\n  }\r\n\r\n  get fileTemplate() {\r\n    return this.templates?.fileTemplate;\r\n  }\r\n\r\n  @Input() previewPosition: 'left' | 'bottom' | 'above' = 'bottom';\r\n\r\n  @Output() imageCropped = new EventEmitter();\r\n  @Output() fileEvent = new EventEmitter<IUiUploaderUserMessage>();\r\n\r\n  uploadOptions: UploaderOptions = {\r\n    concurrency: this.fileServiceConfig.concurrentUploads\r\n  };\r\n\r\n  public uploading = false;\r\n\r\n  changeFileIndex;\r\n\r\n  showCropper = false;\r\n  menuVisible: any;\r\n  showCropPreview = {};\r\n  cropPreviewTimeouts = {};\r\n  cropSourceImages = {};\r\n  cropperImageLoaded = {};\r\n  imagesDone = {};\r\n  transform: ImageTransform = {};\r\n  canvasRotation = {}\r\n\r\n  public files : { custom?: any, $newFile?: UploadFile }[];\r\n\r\n  public responseFiles;\r\n\r\n  refreshAddInput = false;\r\n\r\n  fileMenuOpened;\r\n\r\n  patchingValues = false;\r\n\r\n  inputArray = false;\r\n  dragging = false;\r\n\r\n  uploaderId = Math.round(Math.random() * 1000000);\r\n\r\n  constructor(@Optional() @Inject(UI_FILESERVICE) private fileServiceConfig: IUiFileService,\r\n              @Inject(UI_TRANSLATESERVICE) public translateService: IUiTranslateService,\r\n              @Optional() @Host() @SkipSelf() protected controlContainer: ControlContainer,\r\n              private fileService: UiFileService) {\r\n\r\n    super(null, controlContainer);\r\n\r\n    this.fileService.uploadSubscription.next({action: 'register', data: this});\r\n\r\n    this.fileService.uploadSubscription.subscribe((v: any) => {\r\n      switch (v.action) {\r\n        case 'uploadStarted': this.uploading = true; break;\r\n        case 'uploadFailed':\r\n        case 'uploadSuccess':\r\n          setTimeout(() => {\r\n            this.uploading = false;\r\n          });\r\n          this.patchValues();\r\n      }\r\n    });\r\n  }\r\n\r\n  get uploadInput(): EventEmitter<UploadInput> {\r\n    return this.fileService.uploadInput;\r\n  }\r\n\r\n  croppedImages = {};\r\n\r\n  get editable() {\r\n    return this.componentFormControl.enabled;\r\n  }\r\n\r\n  get ngAddStyle() {\r\n    return {\r\n      width: Math.abs(this.fileServiceConfig.imageSizes[this.fileSize][0]) + 'px',\r\n      height: Math.abs(this.fileServiceConfig.imageSizes[this.fileSize][1]) + 'px',\r\n    }\r\n  }\r\n\r\n  get aspectRatio() {\r\n    return this.fileServiceConfig.imageSizes[this.fileSize][0] / this.fileServiceConfig.imageSizes[this.fileSize][1];\r\n  }\r\n\r\n  get addFileImgSrc() {\r\n    return this.fileServiceConfig.addFileImgSrc;\r\n  }\r\n\r\n  cropDone(f) {\r\n    return !f.$newFile || this.imagesDone[f.$newFile.id];\r\n  }\r\n\r\n  // ngOnInit(): void {\r\n  //   super.ngOnInit();\r\n  // }\r\n\r\n  ngOnDestroy(): void {\r\n    this.fileService.uploadSubscription.next({action: 'destroy', data: this});\r\n  }\r\n\r\n  remove(f: any): void {\r\n    if (f.$newFile) {\r\n      this.uploadInput.emit({type: 'remove', id: f.$newFile.id});\r\n    }\r\n    this.files.splice(this.files.indexOf(f), 1);\r\n    this.prepareResponse();\r\n    // this.onChange(this.inputArray ? this.files : (this.files.length > 0 ? this.files[0] : null));\r\n    this.fileEvent.emit({ message: 'fileRemoved', data: f });\r\n//     this.patchValues();\r\n  }\r\n\r\n  patchValues(): void {\r\n    this.patchingValues = true;\r\n    // if (this.inputArray) {\r\n    //   this.componentFormControl.setValue(this.files.map(f => f.custom));\r\n    // } else {\r\n    //   this.componentFormControl.setValue(this.files.length === 0 ? null : this.files[0].custom);\r\n    // }\r\n    this.patchingValues = false;\r\n  }\r\n\r\n  get hasFilesToUpload(): boolean {\r\n    return !!this.files.find(f => f.$newFile && f.$newFile.progress.status !== 2);\r\n  }\r\n\r\n  canImagePreview(type: string) {\r\n    return type.startsWith('image/') || type.startsWith('video/');\r\n  }\r\n\r\n  onUploadOutput($event: UploadOutput, skipCustomValidation = false): void {\r\n    // console.log($event);\r\n    switch ($event.type) {\r\n      case 'start':\r\n        break;\r\n\r\n      case 'dragOver':\r\n        this.dragging = true;\r\n        break;\r\n      case 'dragOut':\r\n      case 'drop':\r\n        this.dragging = false;\r\n        break;\r\n\r\n      case 'addedToQueue':\r\n        if (this.crop && !$event.file.type.startsWith('image/')) {\r\n          this.uploadInput.emit({ type: 'remove', id: $event.file.id });\r\n          this.fileEvent.emit({ message: 'cropInvalidFileType', data: $event.file });\r\n          return;\r\n        }\r\n\r\n        if (!skipCustomValidation && this.fileServiceConfig.fileValidation) {\r\n          this.fileServiceConfig.fileValidation(this.fileSize, $event.file).then(valid => {\r\n            if (valid) {\r\n              this.onUploadOutput($event, true)\r\n            } else {\r\n              this.uploadInput.emit({ type: 'remove', id: $event.file.id });\r\n              // this.fileEvent.emit({ message: 'cropInvalidFileType', data: $event.file });\r\n            }\r\n          })\r\n        } else {\r\n          let f;\r\n          if (this.changeFileIndex !== undefined) {\r\n            f = this.files[this.changeFileIndex];\r\n            if (f.$newFile) {\r\n              this.uploadInput.emit({ type: 'remove', id: f.$newFile.id });\r\n            }\r\n            f.$newFile = $event.file;\r\n            f.custom = $event.file;\r\n            this.changeFileIndex = undefined;\r\n          } else {\r\n            f = { custom: $event.file, $newFile: $event.file };\r\n            if (this.newFilePosition === 'last') {\r\n              this.files.push(f);\r\n            } else {\r\n              this.files.unshift(f);\r\n            }\r\n          }\r\n          if (this.canImagePreview($event.file.type)) {\r\n            if (this.crop) {\r\n              this.canvasRotation[$event.file.id] = 0;\r\n              this.cropSourceImages[$event.file.id] = $event.file.nativeFile;\r\n              this.cropperImageLoaded[$event.file.id] = false;\r\n            }\r\n          }\r\n          this.prepareResponse();\r\n          this.fileEvent.emit({ message: 'fileAdded', data: f });\r\n        }\r\n        break;\r\n\r\n      case 'done':\r\n        const df = this.files.find(f => f.$newFile === $event.file);\r\n        if (df) {\r\n          if (df.$newFile.responseStatus === 200) {\r\n            this.files[this.files.indexOf(df)].custom = df.$newFile.response;\r\n            df.$newFile = null;\r\n          } else {\r\n            // console.log('error on upload', df.$event);\r\n          }\r\n        }\r\n        if (!this.hasFilesToUpload) {\r\n          this.prepareResponse(false);\r\n          this.fileService.uploadSubscription.next({\r\n            action: this.files.find(f => !!f.$newFile) ? 'uploadControlFailed' : 'uploadControlSuccess'\r\n          });\r\n        }\r\n        break;\r\n    }\r\n  }\r\n\r\n  prepareResponse(doemit = true) {\r\n    if (this.inputArray) {\r\n      if (!this.responseFiles) {\r\n        this.responseFiles = [];\r\n      }\r\n      this.responseFiles.length = 0;\r\n      this.files.forEach(f => this.responseFiles.push({...f.custom, $newFile: f.$newFile}));\r\n    } else {\r\n      if (this.files.length === 0) {\r\n        this.responseFiles = null;\r\n      } else {\r\n        if (!this.responseFiles) {\r\n          this.responseFiles = {};\r\n        }\r\n        Object.keys(this.files[0].custom).forEach(k => {\r\n          this.responseFiles[k] = this.files[0].custom[k];\r\n        });\r\n        this.responseFiles.$newFile = this.files[0].$newFile;\r\n      }\r\n    }\r\n    if (doemit) {\r\n      this.onChange(this.responseFiles);\r\n    }\r\n\r\n    // console.log('emit', this.files[1], { ...this.files[1].custom, $newFile: this.files[1].$newFile });\r\n    // this.onChange(this.inputArray ?\r\n    //   this.files.map(f => ({ ...f.custom, $newFile: f.$newFile})) :\r\n    //   (this.files.length > 0 ? { ...this.files[0].custom, $newFile: this.files[0].$newFile } : null));\r\n    // this.onChange(this.inputArray ?\r\n    //   this.files :\r\n    //   (this.files.length > 0 ? this.files[0] : null));\r\n  }\r\n\r\n  beforeSave() {\r\n    return new Promise((res, rej) => {\r\n      this.files.forEach(f => {\r\n        if (f.$newFile && f.$newFile.progress.status === 2) {\r\n          f.$newFile.progress.status = 0;\r\n        }\r\n        if (this.crop && f.$newFile && !this.imagesDone[f.$newFile.id]) {\r\n          this.cropperDone(f.$newFile.id);\r\n        }\r\n      })\r\n      setTimeout(() => {\r\n        res('done');\r\n      }, 250);\r\n    })\r\n  }\r\n\r\n  fileChangeEvent(event: any, f: any): void {\r\n    this.changeFileIndex = this.files.indexOf(f);\r\n  }\r\n\r\n  startCropPreview(id) {\r\n    clearTimeout(this.cropPreviewTimeouts[id]);\r\n    this.showCropPreview[id] = !!this.cropSourceImages[id];\r\n  }\r\n\r\n  stopCropPreview(id) {\r\n    this.cropPreviewTimeouts[id] = setTimeout(() => {\r\n      this.showCropPreview[id] = false;\r\n    }, 250);\r\n  }\r\n\r\n  zoomCroppedImage(dir, id) {\r\n    let scale = this.transform[id].scale;\r\n    scale += dir;\r\n    if (scale < 0.1) {\r\n      scale = 0.1;\r\n    }\r\n    this.transform[id] = {\r\n      ...this.transform[id],\r\n      scale\r\n    };\r\n  }\r\n\r\n  rotateCroppedImage(dir, id) {\r\n    this.canvasRotation[id] += dir;\r\n    const flippedH = this.transform[id].flipH;\r\n    const flippedV = this.transform[id].flipV;\r\n    this.transform[id] = {\r\n      ...this.transform[id],\r\n      flipH: flippedV,\r\n      flipV: flippedH\r\n    };\r\n  }\r\n\r\n  onImageCropped(event: ImageCroppedEvent, id) {\r\n    this.croppedImages[id] = event;\r\n    this.imageCropped.emit(event);\r\n  }\r\n\r\n  imageLoaded(id) {\r\n    this.showCropper = true;\r\n    setTimeout(() => {\r\n      this.transform[id] = {\r\n        scale: 1\r\n      };\r\n    });\r\n  }\r\n\r\n  cropperReady(sourceImageDimensions: Dimensions, id) {\r\n    this.cropperImageLoaded[id] = true;\r\n  }\r\n\r\n  loadImageFailed() {\r\n  }\r\n\r\n  toggleMenuVisibility(f) {\r\n    this.fileMenuOpened = f;\r\n  }\r\n\r\n  menuClick() {\r\n    this.fileMenuOpened = undefined;\r\n  }\r\n\r\n\r\n  writeValue(obj: any): void {\r\n    this.inputArray = obj instanceof Array;\r\n    if (this.inputArray) {\r\n      this.files = obj.map(f => ({ custom: f, $newFile: null }));\r\n    } else {\r\n      this.files = obj ? [ { custom:obj, $newFile: null} ] : [];\r\n    }\r\n    this.cropSourceImages = {};\r\n  }\r\n\r\n  cropperDone(id) {\r\n    const f = this.files.find(fx => fx.$newFile && fx.$newFile.id === id);\r\n    if (f) {\r\n      // const url = this.croppedImages[id];\r\n      // console.log(url);\r\n      // fetch(url)\r\n      //   .then(res => res.blob())\r\n      //   .then(blob => {\r\n      //     f.$newFile.nativeFile = new File([ blob ], 'crop.png', {\r\n      //       type: 'image/png'\r\n      //     });\r\n      //     f.$newFile.name = 'crop.png';\r\n      //     f.$newFile.size = f.$newFile.nativeFile.size;\r\n      //     f.$newFile.type = f.$newFile.nativeFile.type;\r\n      //     this.imagesDone[id] = true;\r\n      //     console.log(f);\r\n      //   })\r\n      const croppedImage = this.croppedImages[id];\r\n      f.$newFile.nativeFile = new File([ croppedImage.blob ], 'crop.png', {\r\n        type: 'image/png'\r\n      });\r\n      f.$newFile.name = 'crop.png';\r\n      f.$newFile.size = f.$newFile.nativeFile.size;\r\n      f.$newFile.type = f.$newFile.nativeFile.type;\r\n      this.imagesDone[id] = true;\r\n      console.log(f);\r\n    }\r\n  }\r\n}\r\n","<div class=\"label\" *ngIf=\"label\">\r\n  <div class=\"text-container\" [matTooltip]=\"required ? translateService.instant('ui.controls.validation.required') : undefined\" [matTooltipPosition]=\"'above'\">\r\n    <div class=\"text\">{{label}}</div>\r\n    <div *ngIf=\"required\" class=\"required\">*</div>\r\n  </div>\r\n</div>\r\n\r\n<div class=\"files-container\" [ngClass]=\"{dragging: dragging, disabled: uploading || !editable}\">\r\n\r\n  <div class=\"existing-files\">\r\n\r\n    <div class=\"file-container\" *ngFor=\"let f of files\">\r\n\r\n      <div class=\"file-menu\" (click)=\"toggleMenuVisibility(f)\" *ngIf=\"!customFileMenu && editable && !uploading\">\r\n        <mat-icon>menu</mat-icon>\r\n      </div>\r\n      <div class=\"file-menu-container mat-elevation-z2\" [ngClass]=\"{visible: f === fileMenuOpened}\" (click)=\"menuClick()\" (mouseleave)=\"menuClick()\">\r\n        <ng-container *ngIf=\"!menuTemplate\">\r\n          <label class=\"menu-item\">{{ translateService.instant('ui.controls.ui-file-uploader.menu.change') }}\r\n            <input *ngIf=\"!refreshAddInput\" style=\"display: none;\" type=\"file\" ngFileSelect [options]=\"uploadOptions\" (change)=\"fileChangeEvent($event, f)\"\r\n                   (uploadOutput)=\"onUploadOutput($event)\" [uploadInput]=\"uploadInput\">\r\n          </label>\r\n          <div class=\"menu-item\" (click)=\"remove(f)\">{{ translateService.instant('ui.controls.ui-file-uploader.menu.delete') }}</div>\r\n        </ng-container>\r\n        <ng-container *ngIf=\"menuTemplate\">\r\n          <ng-template [ngTemplateOutlet]=\"menuTemplate\" [ngTemplateOutletContext]=\"{fileInput: fileInput}\"></ng-template>\r\n          <ng-template #fileInput>\r\n          <input style=\"display: none;\" type=\"file\" ngFileSelect [options]=\"uploadOptions\" (change)=\"fileChangeEvent($event, f)\"\r\n                 (uploadOutput)=\"onUploadOutput($event)\" [uploadInput]=\"uploadInput\">\r\n          </ng-template>\r\n        </ng-container>\r\n      </div>\r\n\r\n      <div *ngIf=\"crop && !cropDone(f)\" (mouseenter)=\"startCropPreview(f.$newFile.id)\" (mouseleave)=\"stopCropPreview(f.$newFile.id)\">\r\n        <div class=\"crop-container\" [ngStyle]=\"ngAddStyle\">\r\n\r\n          <ui-file *ngIf=\"false && files.length > 0 && !cropSourceImages\" [fileSize]=\"fileSize\" [srcData]=\"files[0].custom\" [ngClass]=\"{rounded: cropRounded}\"></ui-file>\r\n\r\n          <mat-spinner *ngIf=\"!cropperImageLoaded[f.$newFile.id] && cropSourceImages[f.$newFile.id]\" [diameter]=\"75\"></mat-spinner>\r\n\r\n          <image-cropper *ngIf=\"cropSourceImages[f.$newFile.id]\"\r\n                         [imageFile]=\"cropSourceImages[f.$newFile.id]\"\r\n                         [maintainAspectRatio]=\"true\"\r\n                         [containWithinAspectRatio]=\"false\"\r\n                         [aspectRatio]=\"aspectRatio\"\r\n                         [resizeToWidth]=\"cropMaxWidth\"\r\n                         [onlyScaleDown]=\"false\"\r\n                         [roundCropper]=\"cropRounded\"\r\n                         [canvasRotation]=\"canvasRotation[f.$newFile.id]\"\r\n                         [transform]=\"transform[f.$newFile.id]\"\r\n                         [alignImage]=\"'center'\"\r\n                         [style.display]=\"showCropper ? null : 'none'\"\r\n                         [format]=\"'png'\"\r\n                         (imageCropped)=\"onImageCropped($event, f.$newFile.id)\"\r\n                         (imageLoaded)=\"imageLoaded(f.$newFile.id)\"\r\n                         (cropperReady)=\"cropperReady($event, f.$newFile.id)\"\r\n                         (loadImageFailed)=\"loadImageFailed()\"\r\n          ></image-cropper>\r\n\r\n          <div class=\"crop-preview mat-elevation-z2\" [class]=\"previewPosition\" *ngIf=\"true || (showCropPreview[f.$newFile.id] && cropperImageLoaded[f.$newFile.id])\">\r\n            <div class=\"crop-menu\">\r\n              <mat-icon (click)=\"zoomCroppedImage(.1, f.$newFile.id)\">zoom_in</mat-icon>\r\n              <mat-icon (click)=\"zoomCroppedImage(- .1, f.$newFile.id)\">zoom_out</mat-icon>\r\n              <mat-icon (click)=\"rotateCroppedImage(-1, f.$newFile.id)\">rotate_left</mat-icon>\r\n              <mat-icon (click)=\"rotateCroppedImage(1, f.$newFile.id)\">rotate_right</mat-icon>\r\n              <div style=\"flex: 1 1 100%\"></div>\r\n              <label class=\"menu-item\">\r\n                <mat-icon>upload_file</mat-icon>\r\n                <input style=\"display: none;\" type=\"file\" ngFileSelect [options]=\"uploadOptions\" (change)=\"fileChangeEvent($event, f)\"\r\n                       (uploadOutput)=\"onUploadOutput($event)\" [uploadInput]=\"uploadInput\">\r\n              </label>\r\n              <mat-icon (click)=\"remove(f)\">delete_outline</mat-icon>\r\n              <div style=\"flex: 1 1 100%\"></div>\r\n              <mat-icon (click)=\"cropperDone(f.$newFile.id)\">done</mat-icon>\r\n            </div>\r\n            <img *ngIf=\"croppedImages[f.$newFile.id]\" [src]=\"croppedImages[f.$newFile.id].objectUrl\" [ngClass]=\"{rounded: cropRounded}\"/>\r\n          </div>\r\n\r\n        </div>\r\n\r\n\r\n\r\n      </div>\r\n\r\n      <ng-container *ngIf=\"!crop || cropDone(f)\">\r\n        <ng-container *ngIf=\"fileTemplate\">\r\n          <ng-template [ngTemplateOutlet]=\"fileTemplate\" [ngTemplateOutletContext]=\"{file: f, fileInput: fileInput2}\"></ng-template>\r\n          <ng-template #fileInput2>\r\n            <input style=\"display: none;\" type=\"file\" ngFileSelect [options]=\"uploadOptions\" (change)=\"fileChangeEvent($event, f)\"\r\n                   (uploadOutput)=\"onUploadOutput($event)\" [uploadInput]=\"uploadInput\">\r\n          </ng-template>\r\n        </ng-container>\r\n\r\n        <ui-file *ngIf=\"!fileTemplate\" [fileSize]=\"fileSize\" [srcData]=\"f.$newFile ? f.$newFile: f.custom\" [ngClass]=\"{rounded: crop && cropRounded}\">\r\n        </ui-file>\r\n\r\n        <ng-container *ngIf=\"f.$newFile\">\r\n          <div *ngIf=\"f.$newFile.responseStatus && f.$newFile.responseStatus !== 200\" class=\"progress-container error\">\r\n            {{ translateService.instant('ui.controls.ui-file-uploader.uploadError', f.$newFile.response) }}\r\n          </div>\r\n          <div *ngIf=\"!f.$newFile.responseStatus && f.$newFile.progress.status === 1\" class=\"progress-container\">\r\n            <div class=\"progress\" [ngStyle]=\"{width: f.$newFile.progress.data.percentage + '%'}\"></div>\r\n          </div>\r\n        </ng-container>\r\n      </ng-container>\r\n    </div>\r\n\r\n  </div>\r\n\r\n  <div class=\"file-container add\" ngFileDrop  [options]=\"uploadOptions\" (uploadOutput)=\"onUploadOutput($event)\" [uploadInput]=\"uploadInput\" [ngClass]=\"{visible: files.length < maxFiles || maxFiles === 0}\" [ngStyle]=\"addFileTemplate ? {} : ngAddStyle\">\r\n    <label>\r\n      <ng-container *ngIf=\"addFileTemplate\">\r\n        <ng-template [ngTemplateOutlet]=\"addFileTemplate\"></ng-template>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"!addFileTemplate\">\r\n        <div class=\"upload-image-container\"></div>\r\n        <img [src]=\"addFileImgSrc\" [ngClass]=\"{'with-hint': addHint}\" />\r\n        <div *ngIf=\"addHint\" class=\"add-hint\">{{addHint}}</div>\r\n      </ng-container>\r\n      <input style=\"display: none;\" type=\"file\" ngFileSelect [options]=\"uploadOptions\" (uploadOutput)=\"onUploadOutput($event)\" [uploadInput]=\"uploadInput\" [multiple]=\"maxFiles === 0 && multiple\">\r\n    </label>\r\n  </div>\r\n\r\n</div>\r\n"]}
|