@simpleangularcontrols/sac-common 16.0.0-rc.1 → 16.0.0-rc.3
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/README.md +8 -16
- package/common/basedatetimecontrol.d.ts +33 -33
- package/common/basedatetimecontrol.d.ts.map +1 -1
- package/common/baseinputcontrol.d.ts +9 -9
- package/common/baseinputcontrol.d.ts.map +1 -1
- package/common/basemodelcontrol.d.ts +117 -89
- package/common/basemodelcontrol.d.ts.map +1 -1
- package/common/baseuploadcontrol.d.ts +140 -140
- package/common/baseuploadcontrol.d.ts.map +1 -1
- package/controls/checkbox/checkbox.d.ts +7 -3
- package/controls/checkbox/checkbox.d.ts.map +1 -1
- package/controls/checkbox/radiobuttons.d.ts +5 -4
- package/controls/checkbox/radiobuttons.d.ts.map +1 -1
- package/controls/contextmenu/contextmenu.d.ts +42 -42
- package/controls/contextmenu/contextmenu.d.ts.map +1 -1
- package/controls/contextmenu/contextmenuanchor.d.ts +2 -2
- package/controls/contextmenu/contextmenuanchor.d.ts.map +1 -1
- package/controls/contextmenu/contextmenucontainer.d.ts +2 -2
- package/controls/contextmenu/contextmenucontainer.d.ts.map +1 -1
- package/controls/datetime/date.d.ts +7 -7
- package/controls/datetime/date.d.ts.map +1 -1
- package/controls/datetime/datetime.d.ts +7 -7
- package/controls/datetime/datetime.d.ts.map +1 -1
- package/controls/datetime/time.d.ts +7 -7
- package/controls/datetime/time.d.ts.map +1 -1
- package/controls/form/form.d.ts +7 -43
- package/controls/form/form.d.ts.map +1 -1
- package/controls/input/inputdecimal.d.ts +21 -21
- package/controls/input/inputdecimal.d.ts.map +1 -1
- package/controls/layout/formlayout.d.ts +45 -0
- package/controls/layout/formlayout.d.ts.map +1 -0
- package/controls/list/dropdown.d.ts +45 -45
- package/controls/list/dropdown.d.ts.map +1 -1
- package/controls/multilanguage/multilanguageinput.d.ts +5 -4
- package/controls/multilanguage/multilanguageinput.d.ts.map +1 -1
- package/controls/multilanguage/multilanguageinputarea.d.ts +5 -4
- package/controls/multilanguage/multilanguageinputarea.d.ts.map +1 -1
- package/controls/tinymce/tinymce.d.ts +63 -63
- package/controls/tinymce/tinymce.d.ts.map +1 -1
- package/esm2022/common/basedatetimecontrol.mjs +75 -81
- package/esm2022/common/baseinputcontrol.mjs +20 -20
- package/esm2022/common/basemodelcontrol.mjs +280 -202
- package/esm2022/common/baseuploadcontrol.mjs +225 -224
- package/esm2022/controls/checkbox/checkbox.mjs +11 -5
- package/esm2022/controls/checkbox/radiobuttons.mjs +13 -12
- package/esm2022/controls/contextmenu/contextmenu.mjs +85 -75
- package/esm2022/controls/contextmenu/contextmenuanchor.mjs +6 -4
- package/esm2022/controls/contextmenu/contextmenucontainer.mjs +6 -4
- package/esm2022/controls/datetime/date.mjs +12 -12
- package/esm2022/controls/datetime/datetime.mjs +15 -15
- package/esm2022/controls/datetime/time.mjs +15 -15
- package/esm2022/controls/form/form.mjs +26 -80
- package/esm2022/controls/input/inputdecimal.mjs +58 -53
- package/esm2022/controls/layout/formlayout.mjs +73 -0
- package/esm2022/controls/list/dropdown.mjs +110 -91
- package/esm2022/controls/multilanguage/multilanguageinput.mjs +10 -9
- package/esm2022/controls/multilanguage/multilanguageinputarea.mjs +10 -9
- package/esm2022/controls/tinymce/tinymce.mjs +102 -95
- package/esm2022/interfaces/ISacLabelSizes.mjs +2 -0
- package/esm2022/public_api.mjs +20 -18
- package/fesm2022/simpleangularcontrols-sac-common.mjs +1958 -1814
- package/fesm2022/simpleangularcontrols-sac-common.mjs.map +1 -1
- package/interfaces/ISacLabelSizes.d.ts +27 -0
- package/interfaces/ISacLabelSizes.d.ts.map +1 -0
- package/package.json +1 -1
- package/public_api.d.ts +19 -17
- package/public_api.d.ts.map +1 -1
- package/simpleangularcontrols-sac-common-16.0.0-rc.3.tgz +0 -0
- package/simpleangularcontrols-sac-common-13.0.0-rc.1.tgz +0 -0
- package/simpleangularcontrols-sac-common-16.0.0-rc.1.tgz +0 -0
|
@@ -6,83 +6,25 @@ import { SACLOCALISATION_SERVICE, SacDefaultLocalisationService, } from '../serv
|
|
|
6
6
|
import { Validation } from '../validation';
|
|
7
7
|
import { SacBaseModelControl } from './basemodelcontrol';
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
|
-
import * as i1 from "../controls/
|
|
10
|
-
|
|
11
|
-
* Klasse für den Upload einer Datei in der Upload Component
|
|
12
|
-
*/
|
|
13
|
-
export class SacUploadFile {
|
|
14
|
-
/**
|
|
15
|
-
* Konstruktor
|
|
16
|
-
* @param ufile Upload Status
|
|
17
|
-
*/
|
|
18
|
-
constructor(ufile) {
|
|
19
|
-
this.uploadId = ufile.uploadId;
|
|
20
|
-
this.name = ufile.name;
|
|
21
|
-
this.progress = ufile.progress;
|
|
22
|
-
this.status = ufile.status;
|
|
23
|
-
this.documentid = null;
|
|
24
|
-
}
|
|
25
|
-
}
|
|
9
|
+
import * as i1 from "../controls/layout/formlayout";
|
|
10
|
+
// #region Classes
|
|
26
11
|
/**
|
|
27
12
|
* Base Klasse für Uploader Control
|
|
28
13
|
*/
|
|
29
14
|
class SacUploadBase extends SacBaseModelControl {
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
*/
|
|
33
|
-
set allowedtypes(types) {
|
|
34
|
-
this._allowedtypes = types;
|
|
35
|
-
this.setAllowedTypes(types);
|
|
36
|
-
}
|
|
37
|
-
get allowedtypes() {
|
|
38
|
-
return this._allowedtypes;
|
|
39
|
-
}
|
|
40
|
-
/**
|
|
41
|
-
* Files nach der Auswahl automatisch hochladen
|
|
42
|
-
*/
|
|
43
|
-
set autoupload(v) {
|
|
44
|
-
this._autoupload = v;
|
|
45
|
-
this.options.autoUpload = v;
|
|
46
|
-
this.uploadService.connect(this.options);
|
|
47
|
-
}
|
|
48
|
-
get autoupload() {
|
|
49
|
-
return this._autoupload;
|
|
50
|
-
}
|
|
51
|
-
/**
|
|
52
|
-
* Uploads können unterbrochen werden
|
|
53
|
-
*/
|
|
54
|
-
set enablepause(v) {
|
|
55
|
-
this._enablepause = v;
|
|
56
|
-
}
|
|
57
|
-
get enablepause() {
|
|
58
|
-
return this._enablepause;
|
|
59
|
-
}
|
|
60
|
-
//#endregion
|
|
61
|
-
/**
|
|
62
|
-
* Definiert den Registration Endpoint für Uploads.
|
|
63
|
-
*/
|
|
64
|
-
set endpoint(v) {
|
|
65
|
-
this._endpoint = v;
|
|
66
|
-
this.setEndpoint(v);
|
|
67
|
-
}
|
|
68
|
-
get endpoint() {
|
|
69
|
-
return this._endpoint;
|
|
70
|
-
}
|
|
15
|
+
// #endregion Properties
|
|
16
|
+
// #region Constructors
|
|
71
17
|
/**
|
|
72
18
|
* Constructor
|
|
73
|
-
* @param
|
|
74
|
-
* @param injector Injector
|
|
75
|
-
* @param renderer
|
|
76
|
-
* @param ngZone
|
|
19
|
+
* @param formlayout SacFormLayoutCommon to define scoped layout settings
|
|
20
|
+
* @param injector Injector for injecting services
|
|
21
|
+
* @param renderer angular rendering engine
|
|
22
|
+
* @param ngZone ngzone for handling external scripts
|
|
77
23
|
*/
|
|
78
|
-
constructor(
|
|
79
|
-
super(
|
|
24
|
+
constructor(formlayout, injector, renderer, ngZone) {
|
|
25
|
+
super(formlayout, injector);
|
|
80
26
|
this.renderer = renderer;
|
|
81
27
|
this.ngZone = ngZone;
|
|
82
|
-
/**
|
|
83
|
-
* Upload Settings
|
|
84
|
-
*/
|
|
85
|
-
this.options = {};
|
|
86
28
|
/**
|
|
87
29
|
* Erlaubte Dateitypen
|
|
88
30
|
*/
|
|
@@ -99,23 +41,26 @@ class SacUploadBase extends SacBaseModelControl {
|
|
|
99
41
|
* API Endpoint
|
|
100
42
|
*/
|
|
101
43
|
this._endpoint = null;
|
|
102
|
-
//#region Properties
|
|
103
44
|
/**
|
|
104
|
-
*
|
|
45
|
+
* Upload Settings
|
|
105
46
|
*/
|
|
106
|
-
this.
|
|
47
|
+
this.options = {};
|
|
107
48
|
/**
|
|
108
|
-
*
|
|
49
|
+
* Definiert das Control als Required
|
|
109
50
|
*/
|
|
110
|
-
this.
|
|
51
|
+
this.isrequired = false;
|
|
111
52
|
/**
|
|
112
53
|
* Max. Dateigrösse für Files die hochgeladen werden können. 0 deaktiviert den Filter
|
|
113
54
|
*/
|
|
114
55
|
this.maxfilesize = 0;
|
|
115
56
|
/**
|
|
116
|
-
*
|
|
57
|
+
* Resource Key für Validation Message Required bei Control
|
|
117
58
|
*/
|
|
118
|
-
this.
|
|
59
|
+
this.validationmessagerequired = 'VALIDATION_ERROR_REQUIRED';
|
|
60
|
+
/**
|
|
61
|
+
* Resource Key für Validation Message Required in Validation Summary
|
|
62
|
+
*/
|
|
63
|
+
this.validationmessagesummaryrequired = 'VALIDATION_ERROR_SUMMARY_REQUIRED';
|
|
119
64
|
/**
|
|
120
65
|
* Event wenn ein Error in der Komponente ausgelöst wird.
|
|
121
66
|
*/
|
|
@@ -146,107 +91,80 @@ class SacUploadBase extends SacBaseModelControl {
|
|
|
146
91
|
// Subscripe Event for State changes
|
|
147
92
|
this.uploadService.events.subscribe((ufile) => this.onUpload(ufile));
|
|
148
93
|
}
|
|
94
|
+
// #endregion Constructors
|
|
95
|
+
// #region Public Getters And Setters
|
|
149
96
|
/**
|
|
150
|
-
*
|
|
97
|
+
* Erlaubte Dateitypen für den Upload. Format: ".xxx,.yyy,.zzz"
|
|
151
98
|
*/
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
this.listenerFn = this.renderer.listen(this.uploadInput.nativeElement, 'change', this.fileListener);
|
|
156
|
-
this.setAllowedTypes(this._allowedtypes);
|
|
157
|
-
this.setEndpoint(this._endpoint);
|
|
158
|
-
if (this._endpoint === null) {
|
|
159
|
-
throw new Error('endpoint is not defined!');
|
|
160
|
-
}
|
|
161
|
-
this.uploadService.connect(this.options);
|
|
99
|
+
set allowedtypes(types) {
|
|
100
|
+
this._allowedtypes = types;
|
|
101
|
+
this.setAllowedTypes(types);
|
|
162
102
|
}
|
|
163
103
|
/**
|
|
164
|
-
*
|
|
104
|
+
* Files nach der Auswahl automatisch hochladen
|
|
165
105
|
*/
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
106
|
+
set autoupload(v) {
|
|
107
|
+
this._autoupload = v;
|
|
108
|
+
this.options.autoUpload = v;
|
|
109
|
+
this.uploadService.connect(this.options);
|
|
170
110
|
}
|
|
171
|
-
//#region All File Events
|
|
172
111
|
/**
|
|
173
|
-
*
|
|
112
|
+
* Uploads können unterbrochen werden
|
|
174
113
|
*/
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
this.uploadService.control({ action: 'cancel' });
|
|
178
|
-
}
|
|
114
|
+
set enablepause(v) {
|
|
115
|
+
this._enablepause = v;
|
|
179
116
|
}
|
|
180
117
|
/**
|
|
181
|
-
*
|
|
118
|
+
* Definiert den Registration Endpoint für Uploads.
|
|
182
119
|
*/
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
}
|
|
120
|
+
set endpoint(v) {
|
|
121
|
+
this._endpoint = v;
|
|
122
|
+
this.setEndpoint(v);
|
|
187
123
|
}
|
|
188
124
|
/**
|
|
189
|
-
*
|
|
125
|
+
* Icon for browse button
|
|
190
126
|
*/
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
this.uploadService.control({ action: 'pause' });
|
|
194
|
-
}
|
|
127
|
+
get IconBrowse() {
|
|
128
|
+
return this.iconService.UploadComponentBrowseIcon;
|
|
195
129
|
}
|
|
196
|
-
//#endregion
|
|
197
|
-
//#region Singel File Events
|
|
198
130
|
/**
|
|
199
|
-
*
|
|
200
|
-
* @param uploadId ID of File to cancel
|
|
131
|
+
* icon for continous buttons
|
|
201
132
|
*/
|
|
202
|
-
|
|
203
|
-
this.
|
|
133
|
+
get IconContinue() {
|
|
134
|
+
return this.iconService.UploadComponentContinueIcon;
|
|
204
135
|
}
|
|
205
136
|
/**
|
|
206
|
-
*
|
|
207
|
-
* @param uploadId ID of File to Cancel
|
|
137
|
+
* icon for delete buttons
|
|
208
138
|
*/
|
|
209
|
-
|
|
210
|
-
this.
|
|
139
|
+
get IconDelete() {
|
|
140
|
+
return this.iconService.UploadComponentDeleteIcon;
|
|
211
141
|
}
|
|
212
142
|
/**
|
|
213
|
-
*
|
|
214
|
-
*
|
|
215
|
-
* @param uploadId ID of File to Upload
|
|
143
|
+
* icon for pause buttons
|
|
216
144
|
*/
|
|
217
|
-
|
|
218
|
-
this.
|
|
145
|
+
get IconPause() {
|
|
146
|
+
return this.iconService.UploadComponentPauseIcon;
|
|
219
147
|
}
|
|
220
|
-
//#endregion
|
|
221
|
-
//#region UI Property Helper
|
|
222
148
|
/**
|
|
223
|
-
*
|
|
224
|
-
* @returns Elemente in der Queue
|
|
149
|
+
* icon for upload button
|
|
225
150
|
*/
|
|
226
|
-
|
|
227
|
-
return this.
|
|
151
|
+
get IconUpload() {
|
|
152
|
+
return this.iconService.UploadComponentUploadIcon;
|
|
228
153
|
}
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
* @returns Elemente für Upload vorhanden
|
|
232
|
-
*/
|
|
233
|
-
IsStateToUpload() {
|
|
234
|
-
return (this.uploads.filter((itm) => itm.status === 'added' || itm.status === 'paused').length > 0);
|
|
154
|
+
get allowedtypes() {
|
|
155
|
+
return this._allowedtypes;
|
|
235
156
|
}
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
* @returns Upload ist am laufen
|
|
239
|
-
*/
|
|
240
|
-
IsUploading() {
|
|
241
|
-
return this.uploads.filter((itm) => itm.status === 'uploading').length > 0;
|
|
157
|
+
get autoupload() {
|
|
158
|
+
return this._autoupload;
|
|
242
159
|
}
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
* @returns Pausierter Upload ist vorhanden
|
|
246
|
-
*/
|
|
247
|
-
IsPaused() {
|
|
248
|
-
return this.uploads.filter((itm) => itm.status === 'paused').length > 0;
|
|
160
|
+
get enablepause() {
|
|
161
|
+
return this._enablepause;
|
|
249
162
|
}
|
|
163
|
+
get endpoint() {
|
|
164
|
+
return this._endpoint;
|
|
165
|
+
}
|
|
166
|
+
// #endregion Public Getters And Setters
|
|
167
|
+
// #region Public Methods
|
|
250
168
|
/**
|
|
251
169
|
* Name der Datei die Hochgeladen wird
|
|
252
170
|
* @returns Observable des Dateinamens.
|
|
@@ -259,6 +177,13 @@ class SacUploadBase extends SacBaseModelControl {
|
|
|
259
177
|
return this.lngResourceService.GetString('UPLOAD_NO_FILE_SELECTED');
|
|
260
178
|
}
|
|
261
179
|
}
|
|
180
|
+
/**
|
|
181
|
+
* Gibt an ob Queue Elemente beinhaltet
|
|
182
|
+
* @returns Elemente in der Queue
|
|
183
|
+
*/
|
|
184
|
+
HasQueueItem() {
|
|
185
|
+
return this.uploads.length > 0;
|
|
186
|
+
}
|
|
262
187
|
/**
|
|
263
188
|
* Gibt an ob ein Upload abgeschlossen ist
|
|
264
189
|
* @returns Upload erfolgreich
|
|
@@ -271,6 +196,27 @@ class SacUploadBase extends SacBaseModelControl {
|
|
|
271
196
|
return false;
|
|
272
197
|
}
|
|
273
198
|
}
|
|
199
|
+
/**
|
|
200
|
+
* Prüft ob ein Upload pausiert
|
|
201
|
+
* @returns Pausierter Upload ist vorhanden
|
|
202
|
+
*/
|
|
203
|
+
IsPaused() {
|
|
204
|
+
return this.uploads.filter((itm) => itm.status === 'paused').length > 0;
|
|
205
|
+
}
|
|
206
|
+
/**
|
|
207
|
+
* Prüft ob in der Queue Elemente die zum Upload bereit sind vorhanden sind.
|
|
208
|
+
* @returns Elemente für Upload vorhanden
|
|
209
|
+
*/
|
|
210
|
+
IsStateToUpload() {
|
|
211
|
+
return (this.uploads.filter((itm) => itm.status === 'added' || itm.status === 'paused').length > 0);
|
|
212
|
+
}
|
|
213
|
+
/**
|
|
214
|
+
* Prüft ob ein Upload eines Files am laufen ist
|
|
215
|
+
* @returns Upload ist am laufen
|
|
216
|
+
*/
|
|
217
|
+
IsUploading() {
|
|
218
|
+
return this.uploads.filter((itm) => itm.status === 'uploading').length > 0;
|
|
219
|
+
}
|
|
274
220
|
/**
|
|
275
221
|
* Gibt den Uploadfortschritt zurück
|
|
276
222
|
* @returns Upload Fortschritt. Wert von 0-100
|
|
@@ -283,67 +229,42 @@ class SacUploadBase extends SacBaseModelControl {
|
|
|
283
229
|
return 0;
|
|
284
230
|
}
|
|
285
231
|
}
|
|
286
|
-
//#endregion
|
|
287
|
-
//#region Validation
|
|
288
232
|
/**
|
|
289
|
-
*
|
|
290
|
-
* @param
|
|
233
|
+
* Cancel single upload
|
|
234
|
+
* @param uploadId ID of File to cancel
|
|
291
235
|
*/
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
if (this.isrequired) {
|
|
295
|
-
error = Validation.required(this.validationmessagerequired, this.validationmessagesummaryrequired)(c);
|
|
296
|
-
}
|
|
297
|
-
return error;
|
|
236
|
+
cancel(uploadId) {
|
|
237
|
+
this.uploadService.control({ action: 'cancel', uploadId: uploadId });
|
|
298
238
|
}
|
|
299
|
-
//#endregion
|
|
300
239
|
/**
|
|
301
|
-
*
|
|
302
|
-
*
|
|
303
|
-
* @param types Erlaubte File Extensions
|
|
240
|
+
* Cancel all Uploaded files
|
|
304
241
|
*/
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
this.renderer.setAttribute(this.uploadInput.nativeElement, 'accept', types);
|
|
242
|
+
cancelAll() {
|
|
243
|
+
if (this.HasQueueItem() === true) {
|
|
244
|
+
this.uploadService.control({ action: 'cancel' });
|
|
309
245
|
}
|
|
310
|
-
this.options.allowedTypes = types;
|
|
311
|
-
}
|
|
312
|
-
/**
|
|
313
|
-
* Setzt den Upload Endpoit
|
|
314
|
-
* @param url Register URI
|
|
315
|
-
*/
|
|
316
|
-
setEndpoint(url) {
|
|
317
|
-
this.options.endpoint = url;
|
|
318
246
|
}
|
|
319
247
|
/**
|
|
320
|
-
*
|
|
321
|
-
*
|
|
322
|
-
* @param filename Dateiname
|
|
248
|
+
* Destroy des Controls
|
|
323
249
|
*/
|
|
324
|
-
|
|
325
|
-
if (this.
|
|
326
|
-
|
|
250
|
+
ngOnDestroy() {
|
|
251
|
+
if (this.listenerFn) {
|
|
252
|
+
this.listenerFn();
|
|
327
253
|
}
|
|
328
|
-
let isValid = false;
|
|
329
|
-
const extensions = this._allowedtypes.split(',');
|
|
330
|
-
extensions.forEach((itm) => {
|
|
331
|
-
if (filename.toLowerCase().endsWith(itm.toLowerCase())) {
|
|
332
|
-
isValid = true;
|
|
333
|
-
}
|
|
334
|
-
});
|
|
335
|
-
return isValid;
|
|
336
254
|
}
|
|
337
255
|
/**
|
|
338
|
-
*
|
|
339
|
-
*
|
|
340
|
-
* @param filesize Max File Size in Bytes
|
|
256
|
+
* Initialisiert das Control
|
|
341
257
|
*/
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
258
|
+
ngOnInit() {
|
|
259
|
+
super.ngOnInit();
|
|
260
|
+
// Init Event Listener for Input File Control and Handling Files
|
|
261
|
+
this.listenerFn = this.renderer.listen(this.uploadInput.nativeElement, 'change', this.fileListener);
|
|
262
|
+
this.setAllowedTypes(this._allowedtypes);
|
|
263
|
+
this.setEndpoint(this._endpoint);
|
|
264
|
+
if (this._endpoint === null) {
|
|
265
|
+
throw new Error('endpoint is not defined!');
|
|
345
266
|
}
|
|
346
|
-
|
|
267
|
+
this.uploadService.connect(this.options);
|
|
347
268
|
}
|
|
348
269
|
/**
|
|
349
270
|
* Upload Event
|
|
@@ -388,11 +309,49 @@ class SacUploadBase extends SacBaseModelControl {
|
|
|
388
309
|
this.UpdateFileCount();
|
|
389
310
|
}
|
|
390
311
|
/**
|
|
391
|
-
*
|
|
312
|
+
* Cancel Single File
|
|
313
|
+
* @param uploadId ID of File to Cancel
|
|
392
314
|
*/
|
|
393
|
-
|
|
394
|
-
|
|
315
|
+
pause(uploadId) {
|
|
316
|
+
this.uploadService.control({ action: 'pause', uploadId });
|
|
317
|
+
}
|
|
318
|
+
/**
|
|
319
|
+
* Pause all Uploads
|
|
320
|
+
*/
|
|
321
|
+
pauseAll() {
|
|
322
|
+
if (this.IsUploading() === true) {
|
|
323
|
+
this.uploadService.control({ action: 'pause' });
|
|
324
|
+
}
|
|
325
|
+
}
|
|
326
|
+
/**
|
|
327
|
+
* Upload Single File
|
|
328
|
+
*
|
|
329
|
+
* @param uploadId ID of File to Upload
|
|
330
|
+
*/
|
|
331
|
+
upload(uploadId) {
|
|
332
|
+
this.uploadService.control({ action: 'upload', uploadId });
|
|
333
|
+
}
|
|
334
|
+
/**
|
|
335
|
+
* Upload all queued Files
|
|
336
|
+
*/
|
|
337
|
+
uploadAll() {
|
|
338
|
+
if (this.IsStateToUpload() === true) {
|
|
339
|
+
this.uploadService.control({ action: 'upload' });
|
|
340
|
+
}
|
|
341
|
+
}
|
|
342
|
+
/**
|
|
343
|
+
* Validiert das Upload Control
|
|
344
|
+
* @param c Control das validiert werden soll
|
|
345
|
+
*/
|
|
346
|
+
validateData(c) {
|
|
347
|
+
let error = null;
|
|
348
|
+
if (this.isrequired) {
|
|
349
|
+
error = Validation.required(this.validationmessagerequired, this.validationmessagesummaryrequired)(c);
|
|
350
|
+
}
|
|
351
|
+
return error;
|
|
395
352
|
}
|
|
353
|
+
// #endregion Public Abstract Methods
|
|
354
|
+
// #region Private Methods
|
|
396
355
|
UpdateFileCount() {
|
|
397
356
|
// HACK: Add addition property to FormControl. Can be fixed if solution for ticket: https://github.com/angular/angular/issues/19686
|
|
398
357
|
if (this.ngControl) {
|
|
@@ -401,61 +360,103 @@ class SacUploadBase extends SacBaseModelControl {
|
|
|
401
360
|
}
|
|
402
361
|
}
|
|
403
362
|
/**
|
|
404
|
-
*
|
|
363
|
+
* Returns the number of uploaded files
|
|
405
364
|
*/
|
|
406
|
-
|
|
407
|
-
return this.
|
|
365
|
+
UploadedFileCount() {
|
|
366
|
+
return this.uploads.filter((itm) => itm.status === 'complete').length;
|
|
408
367
|
}
|
|
409
368
|
/**
|
|
410
|
-
*
|
|
369
|
+
* Prüft ob die Dateierweiterung gültig ist
|
|
370
|
+
*
|
|
371
|
+
* @param filename Dateiname
|
|
411
372
|
*/
|
|
412
|
-
|
|
413
|
-
|
|
373
|
+
isExtensionValid(filename) {
|
|
374
|
+
if (this._allowedtypes === '*') {
|
|
375
|
+
return true;
|
|
376
|
+
}
|
|
377
|
+
let isValid = false;
|
|
378
|
+
const extensions = this._allowedtypes.split(',');
|
|
379
|
+
extensions.forEach((itm) => {
|
|
380
|
+
if (filename.toLowerCase().endsWith(itm.toLowerCase())) {
|
|
381
|
+
isValid = true;
|
|
382
|
+
}
|
|
383
|
+
});
|
|
384
|
+
return isValid;
|
|
414
385
|
}
|
|
415
386
|
/**
|
|
416
|
-
*
|
|
387
|
+
* Prüft ob das File nicht zu gross ist.
|
|
388
|
+
*
|
|
389
|
+
* @param filesize Max File Size in Bytes
|
|
417
390
|
*/
|
|
418
|
-
|
|
419
|
-
|
|
391
|
+
isFileSizeValid(filesize) {
|
|
392
|
+
if (this.maxfilesize === 0) {
|
|
393
|
+
return true;
|
|
394
|
+
}
|
|
395
|
+
return this.maxfilesize >= filesize;
|
|
420
396
|
}
|
|
421
397
|
/**
|
|
422
|
-
*
|
|
398
|
+
* Setzt die erlaubten Datentypen für den Upload
|
|
399
|
+
*
|
|
400
|
+
* @param types Erlaubte File Extensions
|
|
423
401
|
*/
|
|
424
|
-
|
|
425
|
-
|
|
402
|
+
setAllowedTypes(types) {
|
|
403
|
+
// Prüfen UploadInput bereits geladen, ist NULL wenn Extension im Markup nach NgModel gesetzt wird.
|
|
404
|
+
if (this.uploadInput && this.uploadInput.nativeElement) {
|
|
405
|
+
this.renderer.setAttribute(this.uploadInput.nativeElement, 'accept', types);
|
|
406
|
+
}
|
|
407
|
+
this.options.allowedTypes = types;
|
|
426
408
|
}
|
|
427
409
|
/**
|
|
428
|
-
*
|
|
410
|
+
* Setzt den Upload Endpoit
|
|
411
|
+
* @param url Register URI
|
|
429
412
|
*/
|
|
430
|
-
|
|
431
|
-
|
|
413
|
+
setEndpoint(url) {
|
|
414
|
+
this.options.endpoint = url;
|
|
432
415
|
}
|
|
433
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacUploadBase, deps: [{ token: i1.
|
|
434
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: SacUploadBase, inputs: {
|
|
416
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacUploadBase, deps: [{ token: i1.SacFormLayoutCommon }, { token: i0.Injector }, { token: i0.Renderer2 }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
417
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: SacUploadBase, inputs: { isrequired: "isrequired", maxfilesize: "maxfilesize", validationmessagerequired: "validationmessagerequired", validationmessagesummaryrequired: "validationmessagesummaryrequired", allowedtypes: "allowedtypes", autoupload: "autoupload", enablepause: "enablepause", endpoint: "endpoint" }, outputs: { onfileerror: "onfileerror" }, viewQueries: [{ propertyName: "uploadInput", first: true, predicate: ["files"], descendants: true, static: true }], usesInheritance: true, ngImport: i0 }); }
|
|
435
418
|
}
|
|
436
419
|
export { SacUploadBase };
|
|
437
420
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SacUploadBase, decorators: [{
|
|
438
421
|
type: Directive
|
|
439
|
-
}], ctorParameters: function () { return [{ type: i1.
|
|
422
|
+
}], ctorParameters: function () { return [{ type: i1.SacFormLayoutCommon }, { type: i0.Injector }, { type: i0.Renderer2 }, { type: i0.NgZone }]; }, propDecorators: { uploadInput: [{
|
|
423
|
+
type: ViewChild,
|
|
424
|
+
args: ['files', { static: true }]
|
|
425
|
+
}], isrequired: [{
|
|
426
|
+
type: Input
|
|
427
|
+
}], maxfilesize: [{
|
|
428
|
+
type: Input
|
|
429
|
+
}], validationmessagerequired: [{
|
|
440
430
|
type: Input
|
|
441
431
|
}], validationmessagesummaryrequired: [{
|
|
442
432
|
type: Input
|
|
433
|
+
}], onfileerror: [{
|
|
434
|
+
type: Output
|
|
443
435
|
}], allowedtypes: [{
|
|
444
436
|
type: Input
|
|
445
437
|
}], autoupload: [{
|
|
446
438
|
type: Input
|
|
447
439
|
}], enablepause: [{
|
|
448
440
|
type: Input
|
|
449
|
-
}], maxfilesize: [{
|
|
450
|
-
type: Input
|
|
451
|
-
}], isrequired: [{
|
|
452
|
-
type: Input
|
|
453
441
|
}], endpoint: [{
|
|
454
442
|
type: Input
|
|
455
|
-
}], onfileerror: [{
|
|
456
|
-
type: Output
|
|
457
|
-
}], uploadInput: [{
|
|
458
|
-
type: ViewChild,
|
|
459
|
-
args: ['files', { static: true }]
|
|
460
443
|
}] } });
|
|
461
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"baseuploadcontrol.js","sourceRoot":"","sources":["../../../../projects/sac-common/src/common/baseuploadcontrol.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Injector,\r\n  Input,\r\n  NgZone,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  Renderer2,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { AbstractControl, ValidationErrors } from '@angular/forms';\r\nimport {\r\n  IdService,\r\n  UPLOADX_AJAX,\r\n  UPLOADX_FACTORY_OPTIONS,\r\n  UPLOADX_OPTIONS,\r\n  UploadState,\r\n  UploadxOptions,\r\n  UploadxService,\r\n} from 'ngx-uploadx';\r\nimport { Observable, of } from 'rxjs';\r\nimport { SacFormCommon } from '../controls/form/form';\r\nimport { ISacIconService } from '../interfaces/ISacIconService';\r\nimport { ISacLocalisationService } from '../interfaces/ISacLocalisationService';\r\nimport { IUploadControl } from '../interfaces/iuploadcontrol';\r\nimport { SACICON_SERVICE, SacDefaultIconService } from '../services';\r\nimport {\r\n  SACLOCALISATION_SERVICE,\r\n  SacDefaultLocalisationService,\r\n} from '../services/sac-localisation.service';\r\nimport { Validation } from '../validation';\r\nimport { SacBaseModelControl } from './basemodelcontrol';\r\n\r\n/**\r\n * Klasse für den Upload einer Datei in der Upload Component\r\n */\r\nexport class SacUploadFile {\r\n  /**\r\n   * Dateiname\r\n   */\r\n  name: string;\r\n  /**\r\n   * Upload ID\r\n   */\r\n  uploadId: string;\r\n  /**\r\n   * Upload Fortschritt\r\n   */\r\n  progress: number;\r\n  /**\r\n   * Upload Status\r\n   */\r\n  status: string;\r\n  /**\r\n   * Document ID\r\n   */\r\n  documentid: string;\r\n\r\n  /**\r\n   * Konstruktor\r\n   * @param ufile Upload Status\r\n   */\r\n  constructor(ufile: UploadState) {\r\n    this.uploadId = ufile.uploadId;\r\n    this.name = ufile.name;\r\n    this.progress = ufile.progress;\r\n    this.status = ufile.status;\r\n    this.documentid = null;\r\n  }\r\n}\r\n\r\n/**\r\n * Base Klasse für Uploader Control\r\n */\r\n@Directive()\r\nexport abstract class SacUploadBase<VALUE>\r\n  extends SacBaseModelControl<VALUE>\r\n  implements OnInit, OnDestroy\r\n{\r\n  /**\r\n   * Upload Settings\r\n   */\r\n  private options: UploadxOptions = {};\r\n  /**\r\n   * Erlaubte Dateitypen\r\n   */\r\n  private _allowedtypes: string = '*';\r\n  /**\r\n   * Files automatisch hochladen\r\n   */\r\n  private _autoupload: boolean = false;\r\n  /**\r\n   * Pausieren von Uploads erlauben\r\n   */\r\n  private _enablepause: boolean = true;\r\n  /**\r\n   * API Endpoint\r\n   */\r\n  private _endpoint: string = null;\r\n  /**\r\n   * Array von Uploads\r\n   */\r\n  uploads: SacUploadFile[];\r\n  /**\r\n   * Upload Service\r\n   */\r\n  protected uploadService: UploadxService;\r\n\r\n  /**\r\n   * icon service to receive icons for uploader\r\n   */\r\n  protected iconService: ISacIconService;\r\n\r\n  /**\r\n   * Service für Error Localisation\r\n   */\r\n  public lngResourceService: ISacLocalisationService;\r\n\r\n  //#region Properties\r\n\r\n  /**\r\n   * Resource Key für Validation Message Required bei Control\r\n   */\r\n  @Input() validationmessagerequired: string = 'VALIDATION_ERROR_REQUIRED';\r\n  /**\r\n   * Resource Key für Validation Message Required in Validation Summary\r\n   */\r\n  @Input()\r\n  validationmessagesummaryrequired: string =\r\n    'VALIDATION_ERROR_SUMMARY_REQUIRED';\r\n\r\n  /**\r\n   * Erlaubte Dateitypen für den Upload. Format: \".xxx,.yyy,.zzz\"\r\n   */\r\n  @Input()\r\n  set allowedtypes(types: string) {\r\n    this._allowedtypes = types;\r\n    this.setAllowedTypes(types);\r\n  }\r\n  get allowedtypes(): string {\r\n    return this._allowedtypes;\r\n  }\r\n  /**\r\n   * Files nach der Auswahl automatisch hochladen\r\n   */\r\n  @Input()\r\n  set autoupload(v: boolean) {\r\n    this._autoupload = v;\r\n    this.options.autoUpload = v;\r\n    this.uploadService.connect(this.options);\r\n  }\r\n  get autoupload(): boolean {\r\n    return this._autoupload;\r\n  }\r\n\r\n  /**\r\n   * Uploads können unterbrochen werden\r\n   */\r\n  @Input()\r\n  set enablepause(v: boolean) {\r\n    this._enablepause = v;\r\n  }\r\n  get enablepause(): boolean {\r\n    return this._enablepause;\r\n  }\r\n\r\n  /**\r\n   * Max. Dateigrösse für Files die hochgeladen werden können. 0 deaktiviert den Filter\r\n   */\r\n  @Input() maxfilesize: number = 0;\r\n\r\n  /**\r\n   * Definiert das Control als Required\r\n   */\r\n  @Input() isrequired: boolean = false;\r\n\r\n  //#endregion\r\n\r\n  /**\r\n   * Definiert den Registration Endpoint für Uploads.\r\n   */\r\n  @Input()\r\n  set endpoint(v: string) {\r\n    this._endpoint = v;\r\n    this.setEndpoint(v);\r\n  }\r\n  get endpoint(): string {\r\n    return this._endpoint;\r\n  }\r\n\r\n  /**\r\n   * Event wenn ein Error in der Komponente ausgelöst wird.\r\n   */\r\n  @Output() onfileerror = new EventEmitter<string>();\r\n\r\n  /**\r\n   * File Input Control\r\n   */\r\n  @ViewChild('files', { static: true })\r\n  private uploadInput: ElementRef;\r\n  /**\r\n   * Listener für Files\r\n   */\r\n  listenerFn: () => void;\r\n\r\n  /**\r\n   * Constructor\r\n   * @param parent Formular Component\r\n   * @param injector Injector für Komponenten Injection\r\n   * @param renderer Rendering Engine\r\n   * @param ngZone NgZone\r\n   */\r\n  constructor(\r\n    parent: SacFormCommon,\r\n    injector: Injector,\r\n    private renderer: Renderer2,\r\n    private ngZone: NgZone\r\n  ) {\r\n    super(parent, injector);\r\n\r\n    this.lngResourceService = injector.get(\r\n      SACLOCALISATION_SERVICE,\r\n      new SacDefaultLocalisationService()\r\n    );\r\n\r\n    this.iconService = injector.get(\r\n      SACICON_SERVICE,\r\n      new SacDefaultIconService()\r\n    );\r\n\r\n    this.uploads = [];\r\n\r\n    this.options.allowedTypes = '*';\r\n    this.options.concurrency = 1;\r\n    this.options.token = 'sometoken';\r\n    this.options.autoUpload = this._autoupload;\r\n    this.options.withCredentials = true;\r\n    this.options.chunkSize = 1024 * 16 * 8;\r\n    this.options.headers = (f: File) => ({\r\n      'Content-Disposition': `filename=${encodeURI(f.name)}`,\r\n    });\r\n\r\n    // Init new Service Instance\r\n    this.uploadService = new UploadxService();\r\n    this.uploadService.init(this.options);\r\n\r\n    // Subscripe Event for State changes\r\n    this.uploadService.events.subscribe((ufile: UploadState) =>\r\n      this.onUpload(ufile)\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Initialisiert das Control\r\n   */\r\n  ngOnInit() {\r\n    super.ngOnInit();\r\n    // Init Event Listener for Input File Control and Handling Files\r\n    this.listenerFn = this.renderer.listen(\r\n      this.uploadInput.nativeElement,\r\n      'change',\r\n      this.fileListener\r\n    );\r\n\r\n    this.setAllowedTypes(this._allowedtypes);\r\n    this.setEndpoint(this._endpoint);\r\n\r\n    if (this._endpoint === null) {\r\n      throw new Error('endpoint is not defined!');\r\n    }\r\n\r\n    this.uploadService.connect(this.options);\r\n  }\r\n\r\n  /**\r\n   * Destroy des Controls\r\n   */\r\n  ngOnDestroy() {\r\n    if (this.listenerFn) {\r\n      this.listenerFn();\r\n    }\r\n  }\r\n\r\n  //#region All File Events\r\n\r\n  /**\r\n   * Cancel all Uploaded files\r\n   */\r\n  cancelAll() {\r\n    if (this.HasQueueItem() === true) {\r\n      this.uploadService.control({ action: 'cancel' });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Upload all queued Files\r\n   */\r\n  uploadAll() {\r\n    if (this.IsStateToUpload() === true) {\r\n      this.uploadService.control({ action: 'upload' });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Pause all Uploads\r\n   */\r\n  pauseAll() {\r\n    if (this.IsUploading() === true) {\r\n      this.uploadService.control({ action: 'pause' });\r\n    }\r\n  }\r\n\r\n  //#endregion\r\n\r\n  //#region Singel File Events\r\n\r\n  /**\r\n   * Cancel single upload\r\n   * @param uploadId ID of File to cancel\r\n   */\r\n  cancel(uploadId) {\r\n    this.uploadService.control({ action: 'cancel', uploadId: uploadId });\r\n  }\r\n\r\n  /**\r\n   * Cancel Single File\r\n   * @param uploadId ID of File to Cancel\r\n   */\r\n  pause(uploadId) {\r\n    this.uploadService.control({ action: 'pause', uploadId });\r\n  }\r\n\r\n  /**\r\n   * Upload Single File\r\n   *\r\n   * @param uploadId ID of File to Upload\r\n   */\r\n  upload(uploadId) {\r\n    this.uploadService.control({ action: 'upload', uploadId });\r\n  }\r\n\r\n  //#endregion\r\n\r\n  //#region UI Property Helper\r\n\r\n  /**\r\n   * Gibt an ob Queue Elemente beinhaltet\r\n   * @returns Elemente in der Queue\r\n   */\r\n  HasQueueItem(): boolean {\r\n    return this.uploads.length > 0;\r\n  }\r\n\r\n  /**\r\n   * Prüft ob in der Queue Elemente die zum Upload bereit sind vorhanden sind.\r\n   * @returns Elemente für Upload vorhanden\r\n   */\r\n  IsStateToUpload(): boolean {\r\n    return (\r\n      this.uploads.filter(\r\n        (itm) => itm.status === 'added' || itm.status === 'paused'\r\n      ).length > 0\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Prüft ob ein Upload eines Files am laufen ist\r\n   * @returns Upload ist am laufen\r\n   */\r\n  IsUploading(): boolean {\r\n    return this.uploads.filter((itm) => itm.status === 'uploading').length > 0;\r\n  }\r\n\r\n  /**\r\n   * Prüft ob ein Upload pausiert\r\n   * @returns Pausierter Upload ist vorhanden\r\n   */\r\n  IsPaused(): boolean {\r\n    return this.uploads.filter((itm) => itm.status === 'paused').length > 0;\r\n  }\r\n\r\n  /**\r\n   * Name der Datei die Hochgeladen wird\r\n   * @returns Observable des Dateinamens.\r\n   */\r\n  Filename(): Observable<string> {\r\n    if (this.uploads.length > 0) {\r\n      return of(this.uploads[0].name);\r\n    } else {\r\n      return this.lngResourceService.GetString('UPLOAD_NO_FILE_SELECTED');\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Gibt an ob ein Upload abgeschlossen ist\r\n   * @returns Upload erfolgreich\r\n   */\r\n  HasSuccessUpload(): boolean {\r\n    if (this.uploads.length > 0) {\r\n      return (\r\n        this.uploads.filter((itm) => itm.status !== 'complete').length === 0\r\n      );\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Gibt den Uploadfortschritt zurück\r\n   * @returns Upload Fortschritt. Wert von 0-100\r\n   */\r\n  Progress(): number {\r\n    if (this.uploads.length > 0) {\r\n      return this.uploads[0].progress;\r\n    } else {\r\n      return 0;\r\n    }\r\n  }\r\n\r\n  //#endregion\r\n\r\n  //#region Validation\r\n\r\n  /**\r\n   * Validiert das Upload Control\r\n   * @param c Control das validiert werden soll\r\n   */\r\n  validateData(c: AbstractControl): ValidationErrors | null {\r\n    let error: ValidationErrors | null = null;\r\n\r\n    if (this.isrequired) {\r\n      error = Validation.required(\r\n        this.validationmessagerequired,\r\n        this.validationmessagesummaryrequired\r\n      )(c);\r\n    }\r\n\r\n    return error;\r\n  }\r\n\r\n  //#endregion\r\n\r\n  /**\r\n   * Setzt die erlaubten Datentypen für den Upload\r\n   *\r\n   * @param types Erlaubte File Extensions\r\n   */\r\n  private setAllowedTypes(types: string) {\r\n    // Prüfen UploadInput bereits geladen, ist NULL wenn Extension im Markup nach NgModel gesetzt wird.\r\n    if (this.uploadInput && this.uploadInput.nativeElement) {\r\n      this.renderer.setAttribute(\r\n        this.uploadInput.nativeElement,\r\n        'accept',\r\n        types\r\n      );\r\n    }\r\n\r\n    this.options.allowedTypes = types;\r\n  }\r\n\r\n  /**\r\n   * Setzt den Upload Endpoit\r\n   * @param url Register URI\r\n   */\r\n  private setEndpoint(url: string) {\r\n    this.options.endpoint = url;\r\n  }\r\n\r\n  /**\r\n   * Prüft ob die Dateierweiterung gültig ist\r\n   *\r\n   * @param filename Dateiname\r\n   */\r\n  private isExtensionValid(filename: string): boolean {\r\n    if (this._allowedtypes === '*') {\r\n      return true;\r\n    }\r\n\r\n    let isValid: boolean = false;\r\n    const extensions: string[] = this._allowedtypes.split(',');\r\n\r\n    extensions.forEach((itm) => {\r\n      if (filename.toLowerCase().endsWith(itm.toLowerCase())) {\r\n        isValid = true;\r\n      }\r\n    });\r\n\r\n    return isValid;\r\n  }\r\n\r\n  /**\r\n   * Prüft ob das File nicht zu gross ist.\r\n   *\r\n   * @param filesize Max File Size in Bytes\r\n   */\r\n  private isFileSizeValid(filesize: number): boolean {\r\n    if (this.maxfilesize === 0) {\r\n      return true;\r\n    }\r\n\r\n    return this.maxfilesize >= filesize;\r\n  }\r\n\r\n  /**\r\n   * Upload Event\r\n   *\r\n   * @param uploadsOutStream Upload Item\r\n   */\r\n  onUpload(ufile: UploadState) {\r\n    const index = this.uploads.findIndex((f) => f.uploadId === ufile.uploadId);\r\n\r\n    if (ufile.status === 'added' || (ufile.status === 'queue' && index < 0)) {\r\n      if (\r\n        this.isExtensionValid(ufile.name) &&\r\n        this.isFileSizeValid(ufile.size) &&\r\n        this.CustomAddValidation(ufile)\r\n      ) {\r\n        this.uploads.push(new SacUploadFile(ufile));\r\n      } else {\r\n        this.cancel(ufile.uploadId);\r\n\r\n        if (!this.isExtensionValid(ufile.name)) {\r\n          this.onfileerror.emit('INVALID_EXTENSION');\r\n        } else if (!this.isFileSizeValid(ufile.size)) {\r\n          this.onfileerror.emit('INVALID_FILESIZE');\r\n        }\r\n      }\r\n    } else if (ufile.status === 'cancelled') {\r\n      if (index >= 0) {\r\n        this.uploads.splice(index, 1);\r\n      }\r\n\r\n      this.SetUploadValue(null);\r\n    } else if (ufile.status === 'complete') {\r\n      this.uploads[index].progress = ufile.progress;\r\n      this.uploads[index].status = ufile.status;\r\n      this.SetUploadValue(ufile);\r\n    } else {\r\n      if (index >= 0) {\r\n        this.uploads[index].progress = ufile.progress;\r\n        this.uploads[index].status = ufile.status;\r\n      }\r\n    }\r\n\r\n    this.UpdateFileCount();\r\n  }\r\n\r\n  /**\r\n   * Handling von neuen Files im Input Control\r\n   */\r\n  fileListener = () => {\r\n    if (this.uploadInput.nativeElement.files) {\r\n      this.uploadService.handleFiles(this.uploadInput.nativeElement.files);\r\n    }\r\n  };\r\n\r\n  /**\r\n   * Methode welche die Upload ID's in das Model setzt oder löscht\r\n   *\r\n   * @param file Type von File ID's\r\n   */\r\n  abstract SetUploadValue(file: UploadState): void;\r\n\r\n  /**\r\n   * Methode kann für Controls verwendet werden, zusätzliche Validierungen bei hinzufügen der Files zu machen\r\n   *\r\n   * @param file File das hinzugefügt wurde.\r\n   * @returns Valdierung ist erfolgreich\r\n   */\r\n  abstract CustomAddValidation(file: UploadState): boolean;\r\n\r\n  /**\r\n   * Returns the number of uploaded files\r\n   */\r\n  private UploadedFileCount(): number {\r\n    return this.uploads.filter((itm) => itm.status === 'complete').length;\r\n  }\r\n\r\n  private UpdateFileCount(): void {\r\n    // HACK: Add addition property to FormControl. Can be fixed if solution for ticket: https://github.com/angular/angular/issues/19686\r\n    if (this.ngControl) {\r\n      (this.ngControl as unknown as IUploadControl).uploadedfilecount =\r\n        this.UploadedFileCount();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Icon for browse button\r\n   */\r\n  public get IconBrowse(): string {\r\n    return this.iconService.UploadComponentBrowseIcon;\r\n  }\r\n  /**\r\n   * icon for upload button\r\n   */\r\n  public get IconUpload(): string {\r\n    return this.iconService.UploadComponentUploadIcon;\r\n  }\r\n  /**\r\n   * icon for delete buttons\r\n   */\r\n  public get IconDelete(): string {\r\n    return this.iconService.UploadComponentDeleteIcon;\r\n  }\r\n  /**\r\n   * icon for pause buttons\r\n   */\r\n  public get IconPause(): string {\r\n    return this.iconService.UploadComponentPauseIcon;\r\n  }\r\n  /**\r\n   * icon for continous buttons\r\n   */\r\n  public get IconContinue(): string {\r\n    return this.iconService.UploadComponentContinueIcon;\r\n  }\r\n}\r\n"]}
|
|
444
|
+
/**
|
|
445
|
+
* Klasse für den Upload einer Datei in der Upload Component
|
|
446
|
+
*/
|
|
447
|
+
export class SacUploadFile {
|
|
448
|
+
// #endregion Properties
|
|
449
|
+
// #region Constructors
|
|
450
|
+
/**
|
|
451
|
+
* Konstruktor
|
|
452
|
+
* @param ufile Upload Status
|
|
453
|
+
*/
|
|
454
|
+
constructor(ufile) {
|
|
455
|
+
this.uploadId = ufile.uploadId;
|
|
456
|
+
this.name = ufile.name;
|
|
457
|
+
this.progress = ufile.progress;
|
|
458
|
+
this.status = ufile.status;
|
|
459
|
+
this.documentid = null;
|
|
460
|
+
}
|
|
461
|
+
}
|
|
462
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"baseuploadcontrol.js","sourceRoot":"","sources":["../../../../projects/sac-common/src/common/baseuploadcontrol.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Directive,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Injector,\r\n  Input,\r\n  NgZone,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  Renderer2,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { AbstractControl, ValidationErrors } from '@angular/forms';\r\nimport {\r\n  IdService,\r\n  UPLOADX_AJAX,\r\n  UPLOADX_FACTORY_OPTIONS,\r\n  UPLOADX_OPTIONS,\r\n  UploadState,\r\n  UploadxOptions,\r\n  UploadxService,\r\n} from 'ngx-uploadx';\r\nimport { Observable, of } from 'rxjs';\r\nimport { SacFormLayoutCommon } from '../controls/layout/formlayout';\r\nimport { ISacIconService } from '../interfaces/ISacIconService';\r\nimport { ISacLocalisationService } from '../interfaces/ISacLocalisationService';\r\nimport { IUploadControl } from '../interfaces/iuploadcontrol';\r\nimport { SACICON_SERVICE, SacDefaultIconService } from '../services';\r\nimport {\r\n  SACLOCALISATION_SERVICE,\r\n  SacDefaultLocalisationService,\r\n} from '../services/sac-localisation.service';\r\nimport { Validation } from '../validation';\r\nimport { SacBaseModelControl } from './basemodelcontrol';\r\n\r\n// #region Classes\r\n\r\n/**\r\n * Base Klasse für Uploader Control\r\n */\r\n@Directive()\r\nexport abstract class SacUploadBase<VALUE>\r\n  extends SacBaseModelControl<VALUE>\r\n  implements OnInit, OnDestroy\r\n{\r\n  // #region Properties\r\n\r\n  /**\r\n   * File Input Control\r\n   */\r\n  @ViewChild('files', { static: true })\r\n  private uploadInput: ElementRef;\r\n\r\n  /**\r\n   * Erlaubte Dateitypen\r\n   */\r\n  private _allowedtypes: string = '*';\r\n  /**\r\n   * Files automatisch hochladen\r\n   */\r\n  private _autoupload: boolean = false;\r\n  /**\r\n   * Pausieren von Uploads erlauben\r\n   */\r\n  private _enablepause: boolean = true;\r\n  /**\r\n   * API Endpoint\r\n   */\r\n  private _endpoint: string = null;\r\n  /**\r\n   * Upload Settings\r\n   */\r\n  private options: UploadxOptions = {};\r\n\r\n  /**\r\n   * icon service to receive icons for uploader\r\n   */\r\n  protected iconService: ISacIconService;\r\n  /**\r\n   * Upload Service\r\n   */\r\n  protected uploadService: UploadxService;\r\n\r\n  /**\r\n   * Definiert das Control als Required\r\n   */\r\n  @Input() public isrequired: boolean = false;\r\n  /**\r\n   * Max. Dateigrösse für Files die hochgeladen werden können. 0 deaktiviert den Filter\r\n   */\r\n  @Input() public maxfilesize: number = 0;\r\n  /**\r\n   * Resource Key für Validation Message Required bei Control\r\n   */\r\n  @Input() public validationmessagerequired: string =\r\n    'VALIDATION_ERROR_REQUIRED';\r\n  /**\r\n   * Resource Key für Validation Message Required in Validation Summary\r\n   */\r\n  @Input()\r\n  public validationmessagesummaryrequired: string =\r\n    'VALIDATION_ERROR_SUMMARY_REQUIRED';\r\n  /**\r\n   * Event wenn ein Error in der Komponente ausgelöst wird.\r\n   */\r\n  @Output() public onfileerror = new EventEmitter<string>();\r\n\r\n  /**\r\n   * Handling von neuen Files im Input Control\r\n   */\r\n  public fileListener = () => {\r\n    if (this.uploadInput.nativeElement.files) {\r\n      this.uploadService.handleFiles(this.uploadInput.nativeElement.files);\r\n    }\r\n  };\r\n  /**\r\n   * Listener für Files\r\n   */\r\n  public listenerFn: () => void;\r\n  /**\r\n   * Service für Error Localisation\r\n   */\r\n  public lngResourceService: ISacLocalisationService;\r\n  /**\r\n   * Array von Uploads\r\n   */\r\n  public uploads: SacUploadFile[];\r\n\r\n  // #endregion Properties\r\n\r\n  // #region Constructors\r\n\r\n  /**\r\n   * Constructor\r\n   * @param formlayout SacFormLayoutCommon to define scoped layout settings\r\n   * @param injector Injector for injecting services\r\n   * @param renderer angular rendering engine\r\n   * @param ngZone ngzone for handling external scripts\r\n   */\r\n  constructor(\r\n    formlayout: SacFormLayoutCommon,\r\n    injector: Injector,\r\n    private renderer: Renderer2,\r\n    private ngZone: NgZone\r\n  ) {\r\n    super(formlayout, injector);\r\n\r\n    this.lngResourceService = injector.get(\r\n      SACLOCALISATION_SERVICE,\r\n      new SacDefaultLocalisationService()\r\n    );\r\n\r\n    this.iconService = injector.get(\r\n      SACICON_SERVICE,\r\n      new SacDefaultIconService()\r\n    );\r\n\r\n    this.uploads = [];\r\n\r\n    this.options.allowedTypes = '*';\r\n    this.options.concurrency = 1;\r\n    this.options.token = 'sometoken';\r\n    this.options.autoUpload = this._autoupload;\r\n    this.options.withCredentials = true;\r\n    this.options.chunkSize = 1024 * 16 * 8;\r\n    this.options.headers = (f: File) => ({\r\n      'Content-Disposition': `filename=${encodeURI(f.name)}`,\r\n    });\r\n\r\n    // Init new Service Instance\r\n    this.uploadService = new UploadxService();\r\n    this.uploadService.init(this.options);\r\n\r\n    // Subscripe Event for State changes\r\n    this.uploadService.events.subscribe((ufile: UploadState) =>\r\n      this.onUpload(ufile)\r\n    );\r\n  }\r\n\r\n  // #endregion Constructors\r\n\r\n  // #region Public Getters And Setters\r\n\r\n  /**\r\n   * Erlaubte Dateitypen für den Upload. Format: \".xxx,.yyy,.zzz\"\r\n   */\r\n  @Input()\r\n  public set allowedtypes(types: string) {\r\n    this._allowedtypes = types;\r\n    this.setAllowedTypes(types);\r\n  }\r\n\r\n  /**\r\n   * Files nach der Auswahl automatisch hochladen\r\n   */\r\n  @Input()\r\n  public set autoupload(v: boolean) {\r\n    this._autoupload = v;\r\n    this.options.autoUpload = v;\r\n    this.uploadService.connect(this.options);\r\n  }\r\n\r\n  /**\r\n   * Uploads können unterbrochen werden\r\n   */\r\n  @Input()\r\n  public set enablepause(v: boolean) {\r\n    this._enablepause = v;\r\n  }\r\n\r\n  /**\r\n   * Definiert den Registration Endpoint für Uploads.\r\n   */\r\n  @Input()\r\n  public set endpoint(v: string) {\r\n    this._endpoint = v;\r\n    this.setEndpoint(v);\r\n  }\r\n\r\n  /**\r\n   * Icon for browse button\r\n   */\r\n  public get IconBrowse(): string {\r\n    return this.iconService.UploadComponentBrowseIcon;\r\n  }\r\n\r\n  /**\r\n   * icon for continous buttons\r\n   */\r\n  public get IconContinue(): string {\r\n    return this.iconService.UploadComponentContinueIcon;\r\n  }\r\n\r\n  /**\r\n   * icon for delete buttons\r\n   */\r\n  public get IconDelete(): string {\r\n    return this.iconService.UploadComponentDeleteIcon;\r\n  }\r\n\r\n  /**\r\n   * icon for pause buttons\r\n   */\r\n  public get IconPause(): string {\r\n    return this.iconService.UploadComponentPauseIcon;\r\n  }\r\n\r\n  /**\r\n   * icon for upload button\r\n   */\r\n  public get IconUpload(): string {\r\n    return this.iconService.UploadComponentUploadIcon;\r\n  }\r\n\r\n  public get allowedtypes(): string {\r\n    return this._allowedtypes;\r\n  }\r\n\r\n  public get autoupload(): boolean {\r\n    return this._autoupload;\r\n  }\r\n\r\n  public get enablepause(): boolean {\r\n    return this._enablepause;\r\n  }\r\n\r\n  public get endpoint(): string {\r\n    return this._endpoint;\r\n  }\r\n\r\n  // #endregion Public Getters And Setters\r\n\r\n  // #region Public Methods\r\n\r\n  /**\r\n   * Name der Datei die Hochgeladen wird\r\n   * @returns Observable des Dateinamens.\r\n   */\r\n  public Filename(): Observable<string> {\r\n    if (this.uploads.length > 0) {\r\n      return of(this.uploads[0].name);\r\n    } else {\r\n      return this.lngResourceService.GetString('UPLOAD_NO_FILE_SELECTED');\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Gibt an ob Queue Elemente beinhaltet\r\n   * @returns Elemente in der Queue\r\n   */\r\n  public HasQueueItem(): boolean {\r\n    return this.uploads.length > 0;\r\n  }\r\n\r\n  /**\r\n   * Gibt an ob ein Upload abgeschlossen ist\r\n   * @returns Upload erfolgreich\r\n   */\r\n  public HasSuccessUpload(): boolean {\r\n    if (this.uploads.length > 0) {\r\n      return (\r\n        this.uploads.filter((itm) => itm.status !== 'complete').length === 0\r\n      );\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Prüft ob ein Upload pausiert\r\n   * @returns Pausierter Upload ist vorhanden\r\n   */\r\n  public IsPaused(): boolean {\r\n    return this.uploads.filter((itm) => itm.status === 'paused').length > 0;\r\n  }\r\n\r\n  /**\r\n   * Prüft ob in der Queue Elemente die zum Upload bereit sind vorhanden sind.\r\n   * @returns Elemente für Upload vorhanden\r\n   */\r\n  public IsStateToUpload(): boolean {\r\n    return (\r\n      this.uploads.filter(\r\n        (itm) => itm.status === 'added' || itm.status === 'paused'\r\n      ).length > 0\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Prüft ob ein Upload eines Files am laufen ist\r\n   * @returns Upload ist am laufen\r\n   */\r\n  public IsUploading(): boolean {\r\n    return this.uploads.filter((itm) => itm.status === 'uploading').length > 0;\r\n  }\r\n\r\n  /**\r\n   * Gibt den Uploadfortschritt zurück\r\n   * @returns Upload Fortschritt. Wert von 0-100\r\n   */\r\n  public Progress(): number {\r\n    if (this.uploads.length > 0) {\r\n      return this.uploads[0].progress;\r\n    } else {\r\n      return 0;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Cancel single upload\r\n   * @param uploadId ID of File to cancel\r\n   */\r\n  public cancel(uploadId) {\r\n    this.uploadService.control({ action: 'cancel', uploadId: uploadId });\r\n  }\r\n\r\n  /**\r\n   * Cancel all Uploaded files\r\n   */\r\n  public cancelAll() {\r\n    if (this.HasQueueItem() === true) {\r\n      this.uploadService.control({ action: 'cancel' });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Destroy des Controls\r\n   */\r\n  public ngOnDestroy() {\r\n    if (this.listenerFn) {\r\n      this.listenerFn();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Initialisiert das Control\r\n   */\r\n  public ngOnInit() {\r\n    super.ngOnInit();\r\n    // Init Event Listener for Input File Control and Handling Files\r\n    this.listenerFn = this.renderer.listen(\r\n      this.uploadInput.nativeElement,\r\n      'change',\r\n      this.fileListener\r\n    );\r\n\r\n    this.setAllowedTypes(this._allowedtypes);\r\n    this.setEndpoint(this._endpoint);\r\n\r\n    if (this._endpoint === null) {\r\n      throw new Error('endpoint is not defined!');\r\n    }\r\n\r\n    this.uploadService.connect(this.options);\r\n  }\r\n\r\n  /**\r\n   * Upload Event\r\n   *\r\n   * @param uploadsOutStream Upload Item\r\n   */\r\n  public onUpload(ufile: UploadState) {\r\n    const index = this.uploads.findIndex((f) => f.uploadId === ufile.uploadId);\r\n\r\n    if (ufile.status === 'added' || (ufile.status === 'queue' && index < 0)) {\r\n      if (\r\n        this.isExtensionValid(ufile.name) &&\r\n        this.isFileSizeValid(ufile.size) &&\r\n        this.CustomAddValidation(ufile)\r\n      ) {\r\n        this.uploads.push(new SacUploadFile(ufile));\r\n      } else {\r\n        this.cancel(ufile.uploadId);\r\n\r\n        if (!this.isExtensionValid(ufile.name)) {\r\n          this.onfileerror.emit('INVALID_EXTENSION');\r\n        } else if (!this.isFileSizeValid(ufile.size)) {\r\n          this.onfileerror.emit('INVALID_FILESIZE');\r\n        }\r\n      }\r\n    } else if (ufile.status === 'cancelled') {\r\n      if (index >= 0) {\r\n        this.uploads.splice(index, 1);\r\n      }\r\n\r\n      this.SetUploadValue(null);\r\n    } else if (ufile.status === 'complete') {\r\n      this.uploads[index].progress = ufile.progress;\r\n      this.uploads[index].status = ufile.status;\r\n      this.SetUploadValue(ufile);\r\n    } else {\r\n      if (index >= 0) {\r\n        this.uploads[index].progress = ufile.progress;\r\n        this.uploads[index].status = ufile.status;\r\n      }\r\n    }\r\n\r\n    this.UpdateFileCount();\r\n  }\r\n\r\n  /**\r\n   * Cancel Single File\r\n   * @param uploadId ID of File to Cancel\r\n   */\r\n  public pause(uploadId) {\r\n    this.uploadService.control({ action: 'pause', uploadId });\r\n  }\r\n\r\n  /**\r\n   * Pause all Uploads\r\n   */\r\n  public pauseAll() {\r\n    if (this.IsUploading() === true) {\r\n      this.uploadService.control({ action: 'pause' });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Upload Single File\r\n   *\r\n   * @param uploadId ID of File to Upload\r\n   */\r\n  public upload(uploadId) {\r\n    this.uploadService.control({ action: 'upload', uploadId });\r\n  }\r\n\r\n  /**\r\n   * Upload all queued Files\r\n   */\r\n  public uploadAll() {\r\n    if (this.IsStateToUpload() === true) {\r\n      this.uploadService.control({ action: 'upload' });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Validiert das Upload Control\r\n   * @param c Control das validiert werden soll\r\n   */\r\n  public validateData(c: AbstractControl): ValidationErrors | null {\r\n    let error: ValidationErrors | null = null;\r\n\r\n    if (this.isrequired) {\r\n      error = Validation.required(\r\n        this.validationmessagerequired,\r\n        this.validationmessagesummaryrequired\r\n      )(c);\r\n    }\r\n\r\n    return error;\r\n  }\r\n\r\n  // #endregion Public Methods\r\n\r\n  // #region Public Abstract Methods\r\n\r\n  /**\r\n   * Methode kann für Controls verwendet werden, zusätzliche Validierungen bei hinzufügen der Files zu machen\r\n   *\r\n   * @param file File das hinzugefügt wurde.\r\n   * @returns Valdierung ist erfolgreich\r\n   */\r\n  public abstract CustomAddValidation(file: UploadState): boolean;\r\n  /**\r\n   * Methode welche die Upload ID's in das Model setzt oder löscht\r\n   *\r\n   * @param file Type von File ID's\r\n   */\r\n  public abstract SetUploadValue(file: UploadState): void;\r\n\r\n  // #endregion Public Abstract Methods\r\n\r\n  // #region Private Methods\r\n\r\n  private UpdateFileCount(): void {\r\n    // HACK: Add addition property to FormControl. Can be fixed if solution for ticket: https://github.com/angular/angular/issues/19686\r\n    if (this.ngControl) {\r\n      (this.ngControl as unknown as IUploadControl).uploadedfilecount =\r\n        this.UploadedFileCount();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Returns the number of uploaded files\r\n   */\r\n  private UploadedFileCount(): number {\r\n    return this.uploads.filter((itm) => itm.status === 'complete').length;\r\n  }\r\n\r\n  /**\r\n   * Prüft ob die Dateierweiterung gültig ist\r\n   *\r\n   * @param filename Dateiname\r\n   */\r\n  private isExtensionValid(filename: string): boolean {\r\n    if (this._allowedtypes === '*') {\r\n      return true;\r\n    }\r\n\r\n    let isValid: boolean = false;\r\n    const extensions: string[] = this._allowedtypes.split(',');\r\n\r\n    extensions.forEach((itm) => {\r\n      if (filename.toLowerCase().endsWith(itm.toLowerCase())) {\r\n        isValid = true;\r\n      }\r\n    });\r\n\r\n    return isValid;\r\n  }\r\n\r\n  /**\r\n   * Prüft ob das File nicht zu gross ist.\r\n   *\r\n   * @param filesize Max File Size in Bytes\r\n   */\r\n  private isFileSizeValid(filesize: number): boolean {\r\n    if (this.maxfilesize === 0) {\r\n      return true;\r\n    }\r\n\r\n    return this.maxfilesize >= filesize;\r\n  }\r\n\r\n  /**\r\n   * Setzt die erlaubten Datentypen für den Upload\r\n   *\r\n   * @param types Erlaubte File Extensions\r\n   */\r\n  private setAllowedTypes(types: string) {\r\n    // Prüfen UploadInput bereits geladen, ist NULL wenn Extension im Markup nach NgModel gesetzt wird.\r\n    if (this.uploadInput && this.uploadInput.nativeElement) {\r\n      this.renderer.setAttribute(\r\n        this.uploadInput.nativeElement,\r\n        'accept',\r\n        types\r\n      );\r\n    }\r\n\r\n    this.options.allowedTypes = types;\r\n  }\r\n\r\n  /**\r\n   * Setzt den Upload Endpoit\r\n   * @param url Register URI\r\n   */\r\n  private setEndpoint(url: string) {\r\n    this.options.endpoint = url;\r\n  }\r\n\r\n  // #endregion Private Methods\r\n}\r\n\r\n/**\r\n * Klasse für den Upload einer Datei in der Upload Component\r\n */\r\nexport class SacUploadFile {\r\n  // #region Properties\r\n\r\n  /**\r\n   * Document ID\r\n   */\r\n  public documentid: string;\r\n  /**\r\n   * Dateiname\r\n   */\r\n  public name: string;\r\n  /**\r\n   * Upload Fortschritt\r\n   */\r\n  public progress: number;\r\n  /**\r\n   * Upload Status\r\n   */\r\n  public status: string;\r\n  /**\r\n   * Upload ID\r\n   */\r\n  public uploadId: string;\r\n\r\n  // #endregion Properties\r\n\r\n  // #region Constructors\r\n\r\n  /**\r\n   * Konstruktor\r\n   * @param ufile Upload Status\r\n   */\r\n  constructor(ufile: UploadState) {\r\n    this.uploadId = ufile.uploadId;\r\n    this.name = ufile.name;\r\n    this.progress = ufile.progress;\r\n    this.status = ufile.status;\r\n    this.documentid = null;\r\n  }\r\n\r\n  // #endregion Constructors\r\n}\r\n\r\n// #endregion Classes\r\n"]}
|