@simpleangularcontrols/sac-common 13.0.0-rc.2 → 13.0.0-rc.4
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/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 +122 -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/layout/formlayout.ngfactory.d.ts +4 -0
- package/controls/layout/formlayout.ngfactory.d.ts.map +1 -0
- package/controls/layout/formlayout.ngsummary.d.ts +2 -0
- package/controls/layout/formlayout.ngsummary.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/esm2020/common/basedatetimecontrol.mjs +75 -81
- package/esm2020/common/baseinputcontrol.mjs +20 -20
- package/esm2020/common/basemodelcontrol.mjs +303 -209
- package/esm2020/common/baseuploadcontrol.mjs +208 -207
- package/esm2020/controls/checkbox/checkbox.mjs +11 -5
- package/esm2020/controls/checkbox/radiobuttons.mjs +13 -12
- package/esm2020/controls/contextmenu/contextmenu.mjs +75 -65
- package/esm2020/controls/contextmenu/contextmenuanchor.mjs +6 -4
- package/esm2020/controls/contextmenu/contextmenucontainer.mjs +6 -4
- package/esm2020/controls/datetime/date.mjs +12 -12
- package/esm2020/controls/datetime/datetime.mjs +15 -15
- package/esm2020/controls/datetime/time.mjs +15 -15
- package/esm2020/controls/form/form.mjs +17 -71
- package/esm2020/controls/input/inputdecimal.mjs +58 -53
- package/esm2020/controls/layout/formlayout.mjs +72 -0
- package/esm2020/controls/layout/formlayout.ngfactory.mjs +4 -0
- package/esm2020/controls/layout/formlayout.ngsummary.mjs +2 -0
- package/esm2020/controls/list/dropdown.mjs +104 -85
- package/esm2020/controls/multilanguage/multilanguageinput.mjs +10 -9
- package/esm2020/controls/multilanguage/multilanguageinputarea.mjs +10 -9
- package/esm2020/controls/tinymce/tinymce.mjs +84 -77
- package/esm2020/interfaces/ISacConfigurationService.mjs +2 -0
- package/esm2020/interfaces/ISacConfigurationService.ngfactory.mjs +2 -0
- package/esm2020/interfaces/ISacConfigurationService.ngsummary.mjs +2 -0
- package/esm2020/interfaces/ISacIconService.mjs +1 -1
- package/esm2020/interfaces/ISacLabelSizes.mjs +2 -0
- package/esm2020/interfaces/ISacLabelSizes.ngfactory.mjs +2 -0
- package/esm2020/interfaces/ISacLabelSizes.ngsummary.mjs +2 -0
- package/esm2020/public_api.mjs +20 -18
- package/esm2020/services/index.mjs +6 -5
- package/esm2020/services/sac-configuration.service.mjs +69 -0
- package/esm2020/services/sac-configuration.service.ngfactory.mjs +4 -0
- package/esm2020/services/sac-configuration.service.ngsummary.mjs +3 -0
- package/esm2020/utilities/guid.mjs +16 -0
- package/esm2020/utilities/guid.ngfactory.mjs +2 -0
- package/esm2020/utilities/guid.ngsummary.mjs +2 -0
- package/fesm2015/simpleangularcontrols-sac-common.mjs +2037 -1795
- package/fesm2015/simpleangularcontrols-sac-common.mjs.map +1 -1
- package/fesm2020/simpleangularcontrols-sac-common.mjs +2035 -1794
- package/fesm2020/simpleangularcontrols-sac-common.mjs.map +1 -1
- package/interfaces/ISacConfigurationService.d.ts +30 -0
- package/interfaces/ISacConfigurationService.d.ts.map +1 -0
- package/interfaces/ISacConfigurationService.ngfactory.d.ts +2 -0
- package/interfaces/ISacConfigurationService.ngfactory.d.ts.map +1 -0
- package/interfaces/ISacConfigurationService.ngsummary.d.ts +2 -0
- package/interfaces/ISacConfigurationService.ngsummary.d.ts.map +1 -0
- package/interfaces/ISacIconService.d.ts +2 -2
- package/interfaces/ISacIconService.d.ts.map +1 -1
- package/interfaces/ISacLabelSizes.d.ts +27 -0
- package/interfaces/ISacLabelSizes.d.ts.map +1 -0
- package/interfaces/ISacLabelSizes.ngfactory.d.ts +2 -0
- package/interfaces/ISacLabelSizes.ngfactory.d.ts.map +1 -0
- package/interfaces/ISacLabelSizes.ngsummary.d.ts +2 -0
- package/interfaces/ISacLabelSizes.ngsummary.d.ts.map +1 -0
- package/package.json +2 -2
- package/public_api.d.ts +19 -17
- package/public_api.d.ts.map +1 -1
- package/services/index.d.ts +5 -4
- package/services/index.d.ts.map +1 -1
- package/services/sac-configuration.service.d.ts +70 -0
- package/services/sac-configuration.service.d.ts.map +1 -0
- package/services/sac-configuration.service.ngfactory.d.ts +5 -0
- package/services/sac-configuration.service.ngfactory.d.ts.map +1 -0
- package/services/sac-configuration.service.ngsummary.d.ts +3 -0
- package/services/sac-configuration.service.ngsummary.d.ts.map +1 -0
- package/simpleangularcontrols-sac-common-13.0.0-rc.4.tgz +0 -0
- package/utilities/guid.d.ts +5 -0
- package/utilities/guid.d.ts.map +1 -0
- package/utilities/guid.ngfactory.d.ts +2 -0
- package/utilities/guid.ngfactory.d.ts.map +1 -0
- package/utilities/guid.ngsummary.d.ts +2 -0
- package/utilities/guid.ngsummary.d.ts.map +1 -0
- package/simpleangularcontrols-sac-common-13.0.0-rc.2.tgz +0 -0
|
@@ -6,42 +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
|
export class SacUploadBase extends SacBaseModelControl {
|
|
15
|
+
// #endregion Properties
|
|
16
|
+
// #region Constructors
|
|
30
17
|
/**
|
|
31
18
|
* Constructor
|
|
32
|
-
* @param
|
|
33
|
-
* @param injector Injector
|
|
34
|
-
* @param renderer
|
|
35
|
-
* @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
|
|
36
23
|
*/
|
|
37
|
-
constructor(
|
|
38
|
-
super(
|
|
24
|
+
constructor(formlayout, injector, renderer, ngZone) {
|
|
25
|
+
super(formlayout, injector);
|
|
39
26
|
this.renderer = renderer;
|
|
40
27
|
this.ngZone = ngZone;
|
|
41
|
-
/**
|
|
42
|
-
* Upload Settings
|
|
43
|
-
*/
|
|
44
|
-
this.options = {};
|
|
45
28
|
/**
|
|
46
29
|
* Erlaubte Dateitypen
|
|
47
30
|
*/
|
|
@@ -58,23 +41,26 @@ export class SacUploadBase extends SacBaseModelControl {
|
|
|
58
41
|
* API Endpoint
|
|
59
42
|
*/
|
|
60
43
|
this._endpoint = null;
|
|
61
|
-
//#region Properties
|
|
62
44
|
/**
|
|
63
|
-
*
|
|
45
|
+
* Upload Settings
|
|
64
46
|
*/
|
|
65
|
-
this.
|
|
47
|
+
this.options = {};
|
|
66
48
|
/**
|
|
67
|
-
*
|
|
49
|
+
* Definiert das Control als Required
|
|
68
50
|
*/
|
|
69
|
-
this.
|
|
51
|
+
this.isrequired = false;
|
|
70
52
|
/**
|
|
71
53
|
* Max. Dateigrösse für Files die hochgeladen werden können. 0 deaktiviert den Filter
|
|
72
54
|
*/
|
|
73
55
|
this.maxfilesize = 0;
|
|
74
56
|
/**
|
|
75
|
-
*
|
|
57
|
+
* Resource Key für Validation Message Required bei Control
|
|
76
58
|
*/
|
|
77
|
-
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';
|
|
78
64
|
/**
|
|
79
65
|
* Event wenn ein Error in der Komponente ausgelöst wird.
|
|
80
66
|
*/
|
|
@@ -105,6 +91,8 @@ export class SacUploadBase extends SacBaseModelControl {
|
|
|
105
91
|
// Subscripe Event for State changes
|
|
106
92
|
this.uploadService.events.subscribe((ufile) => this.onUpload(ufile));
|
|
107
93
|
}
|
|
94
|
+
// #endregion Constructors
|
|
95
|
+
// #region Public Getters And Setters
|
|
108
96
|
/**
|
|
109
97
|
* Erlaubte Dateitypen für den Upload. Format: ".xxx,.yyy,.zzz"
|
|
110
98
|
*/
|
|
@@ -112,9 +100,6 @@ export class SacUploadBase extends SacBaseModelControl {
|
|
|
112
100
|
this._allowedtypes = types;
|
|
113
101
|
this.setAllowedTypes(types);
|
|
114
102
|
}
|
|
115
|
-
get allowedtypes() {
|
|
116
|
-
return this._allowedtypes;
|
|
117
|
-
}
|
|
118
103
|
/**
|
|
119
104
|
* Files nach der Auswahl automatisch hochladen
|
|
120
105
|
*/
|
|
@@ -123,19 +108,12 @@ export class SacUploadBase extends SacBaseModelControl {
|
|
|
123
108
|
this.options.autoUpload = v;
|
|
124
109
|
this.uploadService.connect(this.options);
|
|
125
110
|
}
|
|
126
|
-
get autoupload() {
|
|
127
|
-
return this._autoupload;
|
|
128
|
-
}
|
|
129
111
|
/**
|
|
130
112
|
* Uploads können unterbrochen werden
|
|
131
113
|
*/
|
|
132
114
|
set enablepause(v) {
|
|
133
115
|
this._enablepause = v;
|
|
134
116
|
}
|
|
135
|
-
get enablepause() {
|
|
136
|
-
return this._enablepause;
|
|
137
|
-
}
|
|
138
|
-
//#endregion
|
|
139
117
|
/**
|
|
140
118
|
* Definiert den Registration Endpoint für Uploads.
|
|
141
119
|
*/
|
|
@@ -143,110 +121,50 @@ export class SacUploadBase extends SacBaseModelControl {
|
|
|
143
121
|
this._endpoint = v;
|
|
144
122
|
this.setEndpoint(v);
|
|
145
123
|
}
|
|
146
|
-
get endpoint() {
|
|
147
|
-
return this._endpoint;
|
|
148
|
-
}
|
|
149
|
-
/**
|
|
150
|
-
* Initialisiert das Control
|
|
151
|
-
*/
|
|
152
|
-
ngOnInit() {
|
|
153
|
-
super.ngOnInit();
|
|
154
|
-
// Init Event Listener for Input File Control and Handling Files
|
|
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);
|
|
162
|
-
}
|
|
163
|
-
/**
|
|
164
|
-
* Destroy des Controls
|
|
165
|
-
*/
|
|
166
|
-
ngOnDestroy() {
|
|
167
|
-
if (this.listenerFn) {
|
|
168
|
-
this.listenerFn();
|
|
169
|
-
}
|
|
170
|
-
}
|
|
171
|
-
//#region All File Events
|
|
172
124
|
/**
|
|
173
|
-
*
|
|
174
|
-
*/
|
|
175
|
-
cancelAll() {
|
|
176
|
-
if (this.HasQueueItem() === true) {
|
|
177
|
-
this.uploadService.control({ action: 'cancel' });
|
|
178
|
-
}
|
|
179
|
-
}
|
|
180
|
-
/**
|
|
181
|
-
* Upload all queued Files
|
|
125
|
+
* Icon for browse button
|
|
182
126
|
*/
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
this.uploadService.control({ action: 'upload' });
|
|
186
|
-
}
|
|
127
|
+
get IconBrowse() {
|
|
128
|
+
return this.iconService.UploadComponentBrowseIcon;
|
|
187
129
|
}
|
|
188
130
|
/**
|
|
189
|
-
*
|
|
131
|
+
* icon for continous buttons
|
|
190
132
|
*/
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
this.uploadService.control({ action: 'pause' });
|
|
194
|
-
}
|
|
133
|
+
get IconContinue() {
|
|
134
|
+
return this.iconService.UploadComponentContinueIcon;
|
|
195
135
|
}
|
|
196
|
-
//#endregion
|
|
197
|
-
//#region Singel File Events
|
|
198
136
|
/**
|
|
199
|
-
*
|
|
200
|
-
* @param uploadId ID of File to cancel
|
|
137
|
+
* icon for delete buttons
|
|
201
138
|
*/
|
|
202
|
-
|
|
203
|
-
this.
|
|
139
|
+
get IconDelete() {
|
|
140
|
+
return this.iconService.UploadComponentDeleteIcon;
|
|
204
141
|
}
|
|
205
142
|
/**
|
|
206
|
-
*
|
|
207
|
-
* @param uploadId ID of File to Cancel
|
|
143
|
+
* icon for pause buttons
|
|
208
144
|
*/
|
|
209
|
-
|
|
210
|
-
this.
|
|
145
|
+
get IconPause() {
|
|
146
|
+
return this.iconService.UploadComponentPauseIcon;
|
|
211
147
|
}
|
|
212
148
|
/**
|
|
213
|
-
*
|
|
214
|
-
*
|
|
215
|
-
* @param uploadId ID of File to Upload
|
|
149
|
+
* icon for upload button
|
|
216
150
|
*/
|
|
217
|
-
|
|
218
|
-
this.
|
|
151
|
+
get IconUpload() {
|
|
152
|
+
return this.iconService.UploadComponentUploadIcon;
|
|
219
153
|
}
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
/**
|
|
223
|
-
* Gibt an ob Queue Elemente beinhaltet
|
|
224
|
-
* @returns Elemente in der Queue
|
|
225
|
-
*/
|
|
226
|
-
HasQueueItem() {
|
|
227
|
-
return this.uploads.length > 0;
|
|
154
|
+
get allowedtypes() {
|
|
155
|
+
return this._allowedtypes;
|
|
228
156
|
}
|
|
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);
|
|
157
|
+
get autoupload() {
|
|
158
|
+
return this._autoupload;
|
|
235
159
|
}
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
* @returns Upload ist am laufen
|
|
239
|
-
*/
|
|
240
|
-
IsUploading() {
|
|
241
|
-
return this.uploads.filter((itm) => itm.status === 'uploading').length > 0;
|
|
160
|
+
get enablepause() {
|
|
161
|
+
return this._enablepause;
|
|
242
162
|
}
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
* @returns Pausierter Upload ist vorhanden
|
|
246
|
-
*/
|
|
247
|
-
IsPaused() {
|
|
248
|
-
return this.uploads.filter((itm) => itm.status === 'paused').length > 0;
|
|
163
|
+
get endpoint() {
|
|
164
|
+
return this._endpoint;
|
|
249
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 @@ export 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 @@ export 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 @@ export 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 @@ export 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 });
|
|
395
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;
|
|
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,60 +360,102 @@ export 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
416
|
}
|
|
434
|
-
SacUploadBase.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SacUploadBase, deps: [{ token: i1.
|
|
435
|
-
SacUploadBase.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.7", type: SacUploadBase, inputs: {
|
|
417
|
+
SacUploadBase.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SacUploadBase, deps: [{ token: i1.SacFormLayoutCommon }, { token: i0.Injector }, { token: i0.Renderer2 }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive });
|
|
418
|
+
SacUploadBase.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.7", 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 });
|
|
436
419
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.7", ngImport: i0, type: SacUploadBase, decorators: [{
|
|
437
420
|
type: Directive
|
|
438
|
-
}], ctorParameters: function () { return [{ type: i1.
|
|
421
|
+
}], ctorParameters: function () { return [{ type: i1.SacFormLayoutCommon }, { type: i0.Injector }, { type: i0.Renderer2 }, { type: i0.NgZone }]; }, propDecorators: { uploadInput: [{
|
|
422
|
+
type: ViewChild,
|
|
423
|
+
args: ['files', { static: true }]
|
|
424
|
+
}], isrequired: [{
|
|
425
|
+
type: Input
|
|
426
|
+
}], maxfilesize: [{
|
|
427
|
+
type: Input
|
|
428
|
+
}], validationmessagerequired: [{
|
|
439
429
|
type: Input
|
|
440
430
|
}], validationmessagesummaryrequired: [{
|
|
441
431
|
type: Input
|
|
432
|
+
}], onfileerror: [{
|
|
433
|
+
type: Output
|
|
442
434
|
}], allowedtypes: [{
|
|
443
435
|
type: Input
|
|
444
436
|
}], autoupload: [{
|
|
445
437
|
type: Input
|
|
446
438
|
}], enablepause: [{
|
|
447
439
|
type: Input
|
|
448
|
-
}], maxfilesize: [{
|
|
449
|
-
type: Input
|
|
450
|
-
}], isrequired: [{
|
|
451
|
-
type: Input
|
|
452
440
|
}], endpoint: [{
|
|
453
441
|
type: Input
|
|
454
|
-
}], onfileerror: [{
|
|
455
|
-
type: Output
|
|
456
|
-
}], uploadInput: [{
|
|
457
|
-
type: ViewChild,
|
|
458
|
-
args: ['files', { static: true }]
|
|
459
442
|
}] } });
|
|
460
|
-
//# 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      injector.get(UPLOADX_OPTIONS, null),\r\n      injector.get(UPLOADX_FACTORY_OPTIONS),\r\n      injector.get(UPLOADX_AJAX),\r\n      this.ngZone,\r\n      injector.get(IdService)\r\n    );\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"]}
|
|
443
|
+
/**
|
|
444
|
+
* Klasse für den Upload einer Datei in der Upload Component
|
|
445
|
+
*/
|
|
446
|
+
export class SacUploadFile {
|
|
447
|
+
// #endregion Properties
|
|
448
|
+
// #region Constructors
|
|
449
|
+
/**
|
|
450
|
+
* Konstruktor
|
|
451
|
+
* @param ufile Upload Status
|
|
452
|
+
*/
|
|
453
|
+
constructor(ufile) {
|
|
454
|
+
this.uploadId = ufile.uploadId;
|
|
455
|
+
this.name = ufile.name;
|
|
456
|
+
this.progress = ufile.progress;
|
|
457
|
+
this.status = ufile.status;
|
|
458
|
+
this.documentid = null;
|
|
459
|
+
}
|
|
460
|
+
}
|
|
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 { 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      injector.get(UPLOADX_OPTIONS, null),\r\n      injector.get(UPLOADX_FACTORY_OPTIONS),\r\n      injector.get(UPLOADX_AJAX),\r\n      this.ngZone,\r\n      injector.get(IdService)\r\n    );\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"]}
|