@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.
Files changed (115) hide show
  1. package/common/basedatetimecontrol.d.ts +33 -33
  2. package/common/basedatetimecontrol.d.ts.map +1 -1
  3. package/common/baseinputcontrol.d.ts +9 -9
  4. package/common/baseinputcontrol.d.ts.map +1 -1
  5. package/common/basemodelcontrol.d.ts +122 -89
  6. package/common/basemodelcontrol.d.ts.map +1 -1
  7. package/common/baseuploadcontrol.d.ts +140 -140
  8. package/common/baseuploadcontrol.d.ts.map +1 -1
  9. package/controls/checkbox/checkbox.d.ts +7 -3
  10. package/controls/checkbox/checkbox.d.ts.map +1 -1
  11. package/controls/checkbox/radiobuttons.d.ts +5 -4
  12. package/controls/checkbox/radiobuttons.d.ts.map +1 -1
  13. package/controls/contextmenu/contextmenu.d.ts +42 -42
  14. package/controls/contextmenu/contextmenu.d.ts.map +1 -1
  15. package/controls/contextmenu/contextmenuanchor.d.ts +2 -2
  16. package/controls/contextmenu/contextmenuanchor.d.ts.map +1 -1
  17. package/controls/contextmenu/contextmenucontainer.d.ts +2 -2
  18. package/controls/contextmenu/contextmenucontainer.d.ts.map +1 -1
  19. package/controls/datetime/date.d.ts +7 -7
  20. package/controls/datetime/date.d.ts.map +1 -1
  21. package/controls/datetime/datetime.d.ts +7 -7
  22. package/controls/datetime/datetime.d.ts.map +1 -1
  23. package/controls/datetime/time.d.ts +7 -7
  24. package/controls/datetime/time.d.ts.map +1 -1
  25. package/controls/form/form.d.ts +7 -43
  26. package/controls/form/form.d.ts.map +1 -1
  27. package/controls/input/inputdecimal.d.ts +21 -21
  28. package/controls/input/inputdecimal.d.ts.map +1 -1
  29. package/controls/layout/formlayout.d.ts +45 -0
  30. package/controls/layout/formlayout.d.ts.map +1 -0
  31. package/controls/layout/formlayout.ngfactory.d.ts +4 -0
  32. package/controls/layout/formlayout.ngfactory.d.ts.map +1 -0
  33. package/controls/layout/formlayout.ngsummary.d.ts +2 -0
  34. package/controls/layout/formlayout.ngsummary.d.ts.map +1 -0
  35. package/controls/list/dropdown.d.ts +45 -45
  36. package/controls/list/dropdown.d.ts.map +1 -1
  37. package/controls/multilanguage/multilanguageinput.d.ts +5 -4
  38. package/controls/multilanguage/multilanguageinput.d.ts.map +1 -1
  39. package/controls/multilanguage/multilanguageinputarea.d.ts +5 -4
  40. package/controls/multilanguage/multilanguageinputarea.d.ts.map +1 -1
  41. package/controls/tinymce/tinymce.d.ts +63 -63
  42. package/controls/tinymce/tinymce.d.ts.map +1 -1
  43. package/esm2020/common/basedatetimecontrol.mjs +75 -81
  44. package/esm2020/common/baseinputcontrol.mjs +20 -20
  45. package/esm2020/common/basemodelcontrol.mjs +303 -209
  46. package/esm2020/common/baseuploadcontrol.mjs +208 -207
  47. package/esm2020/controls/checkbox/checkbox.mjs +11 -5
  48. package/esm2020/controls/checkbox/radiobuttons.mjs +13 -12
  49. package/esm2020/controls/contextmenu/contextmenu.mjs +75 -65
  50. package/esm2020/controls/contextmenu/contextmenuanchor.mjs +6 -4
  51. package/esm2020/controls/contextmenu/contextmenucontainer.mjs +6 -4
  52. package/esm2020/controls/datetime/date.mjs +12 -12
  53. package/esm2020/controls/datetime/datetime.mjs +15 -15
  54. package/esm2020/controls/datetime/time.mjs +15 -15
  55. package/esm2020/controls/form/form.mjs +17 -71
  56. package/esm2020/controls/input/inputdecimal.mjs +58 -53
  57. package/esm2020/controls/layout/formlayout.mjs +72 -0
  58. package/esm2020/controls/layout/formlayout.ngfactory.mjs +4 -0
  59. package/esm2020/controls/layout/formlayout.ngsummary.mjs +2 -0
  60. package/esm2020/controls/list/dropdown.mjs +104 -85
  61. package/esm2020/controls/multilanguage/multilanguageinput.mjs +10 -9
  62. package/esm2020/controls/multilanguage/multilanguageinputarea.mjs +10 -9
  63. package/esm2020/controls/tinymce/tinymce.mjs +84 -77
  64. package/esm2020/interfaces/ISacConfigurationService.mjs +2 -0
  65. package/esm2020/interfaces/ISacConfigurationService.ngfactory.mjs +2 -0
  66. package/esm2020/interfaces/ISacConfigurationService.ngsummary.mjs +2 -0
  67. package/esm2020/interfaces/ISacIconService.mjs +1 -1
  68. package/esm2020/interfaces/ISacLabelSizes.mjs +2 -0
  69. package/esm2020/interfaces/ISacLabelSizes.ngfactory.mjs +2 -0
  70. package/esm2020/interfaces/ISacLabelSizes.ngsummary.mjs +2 -0
  71. package/esm2020/public_api.mjs +20 -18
  72. package/esm2020/services/index.mjs +6 -5
  73. package/esm2020/services/sac-configuration.service.mjs +69 -0
  74. package/esm2020/services/sac-configuration.service.ngfactory.mjs +4 -0
  75. package/esm2020/services/sac-configuration.service.ngsummary.mjs +3 -0
  76. package/esm2020/utilities/guid.mjs +16 -0
  77. package/esm2020/utilities/guid.ngfactory.mjs +2 -0
  78. package/esm2020/utilities/guid.ngsummary.mjs +2 -0
  79. package/fesm2015/simpleangularcontrols-sac-common.mjs +2037 -1795
  80. package/fesm2015/simpleangularcontrols-sac-common.mjs.map +1 -1
  81. package/fesm2020/simpleangularcontrols-sac-common.mjs +2035 -1794
  82. package/fesm2020/simpleangularcontrols-sac-common.mjs.map +1 -1
  83. package/interfaces/ISacConfigurationService.d.ts +30 -0
  84. package/interfaces/ISacConfigurationService.d.ts.map +1 -0
  85. package/interfaces/ISacConfigurationService.ngfactory.d.ts +2 -0
  86. package/interfaces/ISacConfigurationService.ngfactory.d.ts.map +1 -0
  87. package/interfaces/ISacConfigurationService.ngsummary.d.ts +2 -0
  88. package/interfaces/ISacConfigurationService.ngsummary.d.ts.map +1 -0
  89. package/interfaces/ISacIconService.d.ts +2 -2
  90. package/interfaces/ISacIconService.d.ts.map +1 -1
  91. package/interfaces/ISacLabelSizes.d.ts +27 -0
  92. package/interfaces/ISacLabelSizes.d.ts.map +1 -0
  93. package/interfaces/ISacLabelSizes.ngfactory.d.ts +2 -0
  94. package/interfaces/ISacLabelSizes.ngfactory.d.ts.map +1 -0
  95. package/interfaces/ISacLabelSizes.ngsummary.d.ts +2 -0
  96. package/interfaces/ISacLabelSizes.ngsummary.d.ts.map +1 -0
  97. package/package.json +2 -2
  98. package/public_api.d.ts +19 -17
  99. package/public_api.d.ts.map +1 -1
  100. package/services/index.d.ts +5 -4
  101. package/services/index.d.ts.map +1 -1
  102. package/services/sac-configuration.service.d.ts +70 -0
  103. package/services/sac-configuration.service.d.ts.map +1 -0
  104. package/services/sac-configuration.service.ngfactory.d.ts +5 -0
  105. package/services/sac-configuration.service.ngfactory.d.ts.map +1 -0
  106. package/services/sac-configuration.service.ngsummary.d.ts +3 -0
  107. package/services/sac-configuration.service.ngsummary.d.ts.map +1 -0
  108. package/simpleangularcontrols-sac-common-13.0.0-rc.4.tgz +0 -0
  109. package/utilities/guid.d.ts +5 -0
  110. package/utilities/guid.d.ts.map +1 -0
  111. package/utilities/guid.ngfactory.d.ts +2 -0
  112. package/utilities/guid.ngfactory.d.ts.map +1 -0
  113. package/utilities/guid.ngsummary.d.ts +2 -0
  114. package/utilities/guid.ngsummary.d.ts.map +1 -0
  115. 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/form/form";
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 parent Formular Component
33
- * @param injector Injector für Komponenten Injection
34
- * @param renderer Rendering Engine
35
- * @param ngZone 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(parent, injector, renderer, ngZone) {
38
- super(parent, injector);
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
- * Resource Key für Validation Message Required bei Control
45
+ * Upload Settings
64
46
  */
65
- this.validationmessagerequired = 'VALIDATION_ERROR_REQUIRED';
47
+ this.options = {};
66
48
  /**
67
- * Resource Key für Validation Message Required in Validation Summary
49
+ * Definiert das Control als Required
68
50
  */
69
- this.validationmessagesummaryrequired = 'VALIDATION_ERROR_SUMMARY_REQUIRED';
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
- * Definiert das Control als Required
57
+ * Resource Key für Validation Message Required bei Control
76
58
  */
77
- this.isrequired = false;
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
- * Cancel all Uploaded files
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
- uploadAll() {
184
- if (this.IsStateToUpload() === true) {
185
- this.uploadService.control({ action: 'upload' });
186
- }
127
+ get IconBrowse() {
128
+ return this.iconService.UploadComponentBrowseIcon;
187
129
  }
188
130
  /**
189
- * Pause all Uploads
131
+ * icon for continous buttons
190
132
  */
191
- pauseAll() {
192
- if (this.IsUploading() === true) {
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
- * Cancel single upload
200
- * @param uploadId ID of File to cancel
137
+ * icon for delete buttons
201
138
  */
202
- cancel(uploadId) {
203
- this.uploadService.control({ action: 'cancel', uploadId: uploadId });
139
+ get IconDelete() {
140
+ return this.iconService.UploadComponentDeleteIcon;
204
141
  }
205
142
  /**
206
- * Cancel Single File
207
- * @param uploadId ID of File to Cancel
143
+ * icon for pause buttons
208
144
  */
209
- pause(uploadId) {
210
- this.uploadService.control({ action: 'pause', uploadId });
145
+ get IconPause() {
146
+ return this.iconService.UploadComponentPauseIcon;
211
147
  }
212
148
  /**
213
- * Upload Single File
214
- *
215
- * @param uploadId ID of File to Upload
149
+ * icon for upload button
216
150
  */
217
- upload(uploadId) {
218
- this.uploadService.control({ action: 'upload', uploadId });
151
+ get IconUpload() {
152
+ return this.iconService.UploadComponentUploadIcon;
219
153
  }
220
- //#endregion
221
- //#region UI Property Helper
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
- * Prüft ob in der Queue Elemente die zum Upload bereit sind vorhanden sind.
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
- * Prüft ob ein Upload eines Files am laufen ist
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
- * Prüft ob ein Upload pausiert
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
- * Validiert das Upload Control
290
- * @param c Control das validiert werden soll
233
+ * Cancel single upload
234
+ * @param uploadId ID of File to cancel
291
235
  */
292
- validateData(c) {
293
- let error = null;
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
- * Setzt die erlaubten Datentypen für den Upload
302
- *
303
- * @param types Erlaubte File Extensions
240
+ * Cancel all Uploaded files
304
241
  */
305
- setAllowedTypes(types) {
306
- // Prüfen UploadInput bereits geladen, ist NULL wenn Extension im Markup nach NgModel gesetzt wird.
307
- if (this.uploadInput && this.uploadInput.nativeElement) {
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
- * Prüft ob die Dateierweiterung gültig ist
321
- *
322
- * @param filename Dateiname
248
+ * Destroy des Controls
323
249
  */
324
- isExtensionValid(filename) {
325
- if (this._allowedtypes === '*') {
326
- return true;
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
- * Prüft ob das File nicht zu gross ist.
339
- *
340
- * @param filesize Max File Size in Bytes
256
+ * Initialisiert das Control
341
257
  */
342
- isFileSizeValid(filesize) {
343
- if (this.maxfilesize === 0) {
344
- return true;
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
- return this.maxfilesize >= filesize;
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
- * Returns the number of uploaded files
312
+ * Cancel Single File
313
+ * @param uploadId ID of File to Cancel
392
314
  */
393
- UploadedFileCount() {
394
- return this.uploads.filter((itm) => itm.status === 'complete').length;
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
- * Icon for browse button
363
+ * Returns the number of uploaded files
405
364
  */
406
- get IconBrowse() {
407
- return this.iconService.UploadComponentBrowseIcon;
365
+ UploadedFileCount() {
366
+ return this.uploads.filter((itm) => itm.status === 'complete').length;
408
367
  }
409
368
  /**
410
- * icon for upload button
369
+ * Prüft ob die Dateierweiterung gültig ist
370
+ *
371
+ * @param filename Dateiname
411
372
  */
412
- get IconUpload() {
413
- return this.iconService.UploadComponentUploadIcon;
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
- * icon for delete buttons
387
+ * Prüft ob das File nicht zu gross ist.
388
+ *
389
+ * @param filesize Max File Size in Bytes
417
390
  */
418
- get IconDelete() {
419
- return this.iconService.UploadComponentDeleteIcon;
391
+ isFileSizeValid(filesize) {
392
+ if (this.maxfilesize === 0) {
393
+ return true;
394
+ }
395
+ return this.maxfilesize >= filesize;
420
396
  }
421
397
  /**
422
- * icon for pause buttons
398
+ * Setzt die erlaubten Datentypen für den Upload
399
+ *
400
+ * @param types Erlaubte File Extensions
423
401
  */
424
- get IconPause() {
425
- return this.iconService.UploadComponentPauseIcon;
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
- * icon for continous buttons
410
+ * Setzt den Upload Endpoit
411
+ * @param url Register URI
429
412
  */
430
- get IconContinue() {
431
- return this.iconService.UploadComponentContinueIcon;
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.SacFormCommon }, { token: i0.Injector }, { token: i0.Renderer2 }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive });
435
- SacUploadBase.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.2.7", type: SacUploadBase, inputs: { validationmessagerequired: "validationmessagerequired", validationmessagesummaryrequired: "validationmessagesummaryrequired", allowedtypes: "allowedtypes", autoupload: "autoupload", enablepause: "enablepause", maxfilesize: "maxfilesize", isrequired: "isrequired", endpoint: "endpoint" }, outputs: { onfileerror: "onfileerror" }, viewQueries: [{ propertyName: "uploadInput", first: true, predicate: ["files"], descendants: true, static: true }], usesInheritance: true, ngImport: i0 });
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.SacFormCommon }, { type: i0.Injector }, { type: i0.Renderer2 }, { type: i0.NgZone }]; }, propDecorators: { validationmessagerequired: [{
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"]}