@simpleangularcontrols/sac-common 10.0.0-rc.14 → 10.0.0-rc.16
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/bundles/simpleangularcontrols-sac-common.umd.js +177 -67
- package/bundles/simpleangularcontrols-sac-common.umd.js.map +1 -1
- package/bundles/simpleangularcontrols-sac-common.umd.min.js +1 -1
- package/bundles/simpleangularcontrols-sac-common.umd.min.js.map +1 -1
- package/common/baseuploadcontrol.d.ts +73 -52
- package/controls/treeview/treeview.d.ts +34 -0
- package/esm2015/common/baseuploadcontrol.js +92 -58
- package/esm2015/controls/treeview/treeview.js +62 -2
- package/esm2015/interfaces/ISacUploadEventCompleteState.js +1 -0
- package/esm2015/interfaces/ISacUploadEventCompleteState.ngfactory.js +7 -0
- package/fesm2015/simpleangularcontrols-sac-common.js +147 -53
- package/fesm2015/simpleangularcontrols-sac-common.js.map +1 -1
- package/interfaces/ISacUploadEventCompleteState.d.ts +5 -0
- package/interfaces/ISacUploadEventCompleteState.ngfactory.d.ts +1 -0
- package/package.json +1 -1
- package/simpleangularcontrols-sac-common-10.0.0-rc.16.tgz +0 -0
- package/simpleangularcontrols-sac-common.metadata.json +1 -1
- package/simpleangularcontrols-sac-common-10.0.0-rc.14.tgz +0 -0
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
import { Directive, ElementRef, EventEmitter, Injector, Input, NgZone, Output, Renderer2, ViewChild, } from '@angular/core';
|
|
2
|
-
import { UploadxService } from 'ngx-uploadx';
|
|
3
|
-
import { of } from 'rxjs';
|
|
4
1
|
import { SacFormLayoutCommon } from '../controls/layout/formlayout';
|
|
5
|
-
import { SACVALIDATIONKEY_SERVICE, SacDefaultValidationKeyService
|
|
6
|
-
import { SACLOCALISATION_SERVICE, SacDefaultLocalisationService
|
|
2
|
+
import { SACVALIDATIONKEY_SERVICE, SacDefaultValidationKeyService } from '../services';
|
|
3
|
+
import { SACLOCALISATION_SERVICE, SacDefaultLocalisationService } from '../services/sac-localisation.service';
|
|
7
4
|
import { Validation } from '../validation';
|
|
8
5
|
import { SacBaseModelControl } from './basemodelcontrol';
|
|
9
|
-
|
|
6
|
+
import { Directive, ElementRef, EventEmitter, Injector, Input, NgZone, Output, Renderer2, ViewChild } from '@angular/core';
|
|
7
|
+
import { UploadxService } from 'ngx-uploadx';
|
|
8
|
+
import { of } from 'rxjs';
|
|
9
|
+
// #region Exported Classes
|
|
10
10
|
/**
|
|
11
11
|
* Base Klasse für Uploader Control
|
|
12
12
|
*/
|
|
@@ -24,6 +24,7 @@ export class SacUploadBase extends SacBaseModelControl {
|
|
|
24
24
|
super(formlayout, injector);
|
|
25
25
|
this.renderer = renderer;
|
|
26
26
|
this.ngZone = ngZone;
|
|
27
|
+
// #region Properties
|
|
27
28
|
/**
|
|
28
29
|
* Erlaubte Dateitypen
|
|
29
30
|
*/
|
|
@@ -40,10 +41,22 @@ export class SacUploadBase extends SacBaseModelControl {
|
|
|
40
41
|
* API Endpoint
|
|
41
42
|
*/
|
|
42
43
|
this._endpoint = null;
|
|
44
|
+
/**
|
|
45
|
+
* Token for Bearer Authentication
|
|
46
|
+
*/
|
|
47
|
+
this._token = null;
|
|
43
48
|
/**
|
|
44
49
|
* Upload Settings
|
|
45
50
|
*/
|
|
46
51
|
this.options = {};
|
|
52
|
+
/**
|
|
53
|
+
* Handling von neuen Files im Input Control
|
|
54
|
+
*/
|
|
55
|
+
this.fileListener = () => {
|
|
56
|
+
if (this.uploadInput.nativeElement.files) {
|
|
57
|
+
this.uploadService.handleFileList(this.uploadInput.nativeElement.files);
|
|
58
|
+
}
|
|
59
|
+
};
|
|
47
60
|
/**
|
|
48
61
|
* Definiert das Control als Required
|
|
49
62
|
*/
|
|
@@ -53,25 +66,21 @@ export class SacUploadBase extends SacBaseModelControl {
|
|
|
53
66
|
*/
|
|
54
67
|
this.maxfilesize = 0;
|
|
55
68
|
/**
|
|
56
|
-
*
|
|
69
|
+
* Event when an error is triggered in the component.
|
|
57
70
|
*/
|
|
58
|
-
this.
|
|
71
|
+
this.onfileerror = new EventEmitter();
|
|
59
72
|
/**
|
|
60
|
-
*
|
|
73
|
+
* Event when a file has been uploaded. The event is triggered for multiple uploads per file.
|
|
61
74
|
*/
|
|
62
|
-
this.
|
|
75
|
+
this.onuploadcomplete = new EventEmitter();
|
|
63
76
|
/**
|
|
64
|
-
*
|
|
77
|
+
* Resource Key für Validation Message Required bei Control
|
|
65
78
|
*/
|
|
66
|
-
this.
|
|
79
|
+
this.validationmessagerequired = this.validationKeyService.ValidationErrorRequired;
|
|
67
80
|
/**
|
|
68
|
-
*
|
|
81
|
+
* Resource Key für Validation Message Required in Validation Summary
|
|
69
82
|
*/
|
|
70
|
-
this.
|
|
71
|
-
if (this.uploadInput.nativeElement.files) {
|
|
72
|
-
this.uploadService.handleFileList(this.uploadInput.nativeElement.files);
|
|
73
|
-
}
|
|
74
|
-
};
|
|
83
|
+
this.validationmessagesummaryrequired = this.validationKeyService.ValidationErrorSummaryRequired;
|
|
75
84
|
this.validationKeyService = injector.get(SACVALIDATIONKEY_SERVICE, new SacDefaultValidationKeyService());
|
|
76
85
|
this.lngResourceService = injector.get(SACLOCALISATION_SERVICE, new SacDefaultLocalisationService(this.validationKeyService));
|
|
77
86
|
this.uploads = [];
|
|
@@ -92,34 +101,6 @@ export class SacUploadBase extends SacBaseModelControl {
|
|
|
92
101
|
}
|
|
93
102
|
// #endregion Constructors
|
|
94
103
|
// #region Public Getters And Setters
|
|
95
|
-
/**
|
|
96
|
-
* Erlaubte Dateitypen für den Upload. Format: ".xxx,.yyy,.zzz"
|
|
97
|
-
*/
|
|
98
|
-
set allowedtypes(types) {
|
|
99
|
-
this._allowedtypes = types;
|
|
100
|
-
this.setAllowedTypes(types);
|
|
101
|
-
}
|
|
102
|
-
/**
|
|
103
|
-
* Files nach der Auswahl automatisch hochladen
|
|
104
|
-
*/
|
|
105
|
-
set autoupload(v) {
|
|
106
|
-
this._autoupload = v;
|
|
107
|
-
this.options.autoUpload = v;
|
|
108
|
-
this.uploadService.connect(this.options);
|
|
109
|
-
}
|
|
110
|
-
/**
|
|
111
|
-
* Uploads können unterbrochen werden
|
|
112
|
-
*/
|
|
113
|
-
set enablepause(v) {
|
|
114
|
-
this._enablepause = v;
|
|
115
|
-
}
|
|
116
|
-
/**
|
|
117
|
-
* Definiert den Registration Endpoint für Uploads.
|
|
118
|
-
*/
|
|
119
|
-
set endpoint(v) {
|
|
120
|
-
this._endpoint = v;
|
|
121
|
-
this.setEndpoint(v);
|
|
122
|
-
}
|
|
123
104
|
/**
|
|
124
105
|
* Icon for browse button
|
|
125
106
|
*/
|
|
@@ -153,17 +134,56 @@ export class SacUploadBase extends SacBaseModelControl {
|
|
|
153
134
|
get allowedtypes() {
|
|
154
135
|
return this._allowedtypes;
|
|
155
136
|
}
|
|
137
|
+
/**
|
|
138
|
+
* Erlaubte Dateitypen für den Upload. Format: ".xxx,.yyy,.zzz"
|
|
139
|
+
*/
|
|
140
|
+
set allowedtypes(types) {
|
|
141
|
+
this._allowedtypes = types;
|
|
142
|
+
this.setAllowedTypes(types);
|
|
143
|
+
}
|
|
156
144
|
get autoupload() {
|
|
157
145
|
return this._autoupload;
|
|
158
146
|
}
|
|
147
|
+
/**
|
|
148
|
+
* Files nach der Auswahl automatisch hochladen
|
|
149
|
+
*/
|
|
150
|
+
set autoupload(v) {
|
|
151
|
+
this._autoupload = v;
|
|
152
|
+
this.options.autoUpload = v;
|
|
153
|
+
this.uploadService.connect(this.options);
|
|
154
|
+
}
|
|
159
155
|
get enablepause() {
|
|
160
156
|
return this._enablepause;
|
|
161
157
|
}
|
|
158
|
+
/**
|
|
159
|
+
* Uploads können unterbrochen werden
|
|
160
|
+
*/
|
|
161
|
+
set enablepause(v) {
|
|
162
|
+
this._enablepause = v;
|
|
163
|
+
}
|
|
162
164
|
get endpoint() {
|
|
163
165
|
return this._endpoint;
|
|
164
166
|
}
|
|
165
|
-
|
|
166
|
-
|
|
167
|
+
/**
|
|
168
|
+
* Definiert den Registration Endpoint für Uploads.
|
|
169
|
+
*/
|
|
170
|
+
set endpoint(v) {
|
|
171
|
+
this._endpoint = v;
|
|
172
|
+
this.setEndpoint(v);
|
|
173
|
+
}
|
|
174
|
+
/**
|
|
175
|
+
* Token for Bearer Authentication
|
|
176
|
+
*/
|
|
177
|
+
get token() {
|
|
178
|
+
return this._token;
|
|
179
|
+
}
|
|
180
|
+
/**
|
|
181
|
+
* Token for Bearer Authentication
|
|
182
|
+
*/
|
|
183
|
+
set token(v) {
|
|
184
|
+
this._token = v;
|
|
185
|
+
this.setToken(v);
|
|
186
|
+
}
|
|
167
187
|
/**
|
|
168
188
|
* Name der Datei die Hochgeladen wird
|
|
169
189
|
* @returns Observable des Dateinamens.
|
|
@@ -189,7 +209,7 @@ export class SacUploadBase extends SacBaseModelControl {
|
|
|
189
209
|
*/
|
|
190
210
|
HasSuccessUpload() {
|
|
191
211
|
if (this.uploads.length > 0) {
|
|
192
|
-
return
|
|
212
|
+
return this.uploads.filter((itm) => itm.status !== 'complete').length === 0;
|
|
193
213
|
}
|
|
194
214
|
else {
|
|
195
215
|
return false;
|
|
@@ -207,7 +227,7 @@ export class SacUploadBase extends SacBaseModelControl {
|
|
|
207
227
|
* @returns Elemente für Upload vorhanden
|
|
208
228
|
*/
|
|
209
229
|
IsStateToUpload() {
|
|
210
|
-
return
|
|
230
|
+
return this.uploads.filter((itm) => itm.status === 'added' || itm.status === 'paused').length > 0;
|
|
211
231
|
}
|
|
212
232
|
/**
|
|
213
233
|
* Prüft ob ein Upload eines Files am laufen ist
|
|
@@ -252,7 +272,7 @@ export class SacUploadBase extends SacBaseModelControl {
|
|
|
252
272
|
}
|
|
253
273
|
}
|
|
254
274
|
/**
|
|
255
|
-
*
|
|
275
|
+
* Initializes the control
|
|
256
276
|
*/
|
|
257
277
|
ngOnInit() {
|
|
258
278
|
super.ngOnInit();
|
|
@@ -260,6 +280,7 @@ export class SacUploadBase extends SacBaseModelControl {
|
|
|
260
280
|
this.listenerFn = this.renderer.listen(this.uploadInput.nativeElement, 'change', this.fileListener);
|
|
261
281
|
this.setAllowedTypes(this._allowedtypes);
|
|
262
282
|
this.setEndpoint(this._endpoint);
|
|
283
|
+
this.setToken(this._token);
|
|
263
284
|
if (this._endpoint === null) {
|
|
264
285
|
throw new Error('endpoint is not defined!');
|
|
265
286
|
}
|
|
@@ -298,6 +319,12 @@ export class SacUploadBase extends SacBaseModelControl {
|
|
|
298
319
|
this.uploads[index].progress = ufile.progress;
|
|
299
320
|
this.uploads[index].status = ufile.status;
|
|
300
321
|
this.SetUploadValue(ufile);
|
|
322
|
+
const uploadState = {
|
|
323
|
+
name: ufile.name,
|
|
324
|
+
size: ufile.size,
|
|
325
|
+
uploadid: this.uploads[index].uploadId,
|
|
326
|
+
};
|
|
327
|
+
this.onuploadcomplete.emit(uploadState);
|
|
301
328
|
}
|
|
302
329
|
else {
|
|
303
330
|
if (index >= 0) {
|
|
@@ -322,6 +349,12 @@ export class SacUploadBase extends SacBaseModelControl {
|
|
|
322
349
|
this.uploadService.control({ action: 'pause' });
|
|
323
350
|
}
|
|
324
351
|
}
|
|
352
|
+
/**
|
|
353
|
+
* Sets the bearer token in the upload service
|
|
354
|
+
*/
|
|
355
|
+
setToken(value) {
|
|
356
|
+
this.options.token = value;
|
|
357
|
+
}
|
|
325
358
|
/**
|
|
326
359
|
* Upload Single File
|
|
327
360
|
*
|
|
@@ -349,13 +382,12 @@ export class SacUploadBase extends SacBaseModelControl {
|
|
|
349
382
|
}
|
|
350
383
|
return error;
|
|
351
384
|
}
|
|
352
|
-
// #endregion Public
|
|
385
|
+
// #endregion Public Methods
|
|
353
386
|
// #region Private Methods
|
|
354
387
|
UpdateFileCount() {
|
|
355
388
|
// HACK: Add addition property to FormControl. Can be fixed if solution for ticket: https://github.com/angular/angular/issues/19686
|
|
356
389
|
if (this.ngControl) {
|
|
357
|
-
this.ngControl.uploadedfilecount =
|
|
358
|
-
this.UploadedFileCount();
|
|
390
|
+
this.ngControl.uploadedfilecount = this.UploadedFileCount();
|
|
359
391
|
}
|
|
360
392
|
}
|
|
361
393
|
/**
|
|
@@ -426,13 +458,15 @@ SacUploadBase.propDecorators = {
|
|
|
426
458
|
uploadInput: [{ type: ViewChild, args: ['files', { static: true },] }],
|
|
427
459
|
isrequired: [{ type: Input }],
|
|
428
460
|
maxfilesize: [{ type: Input }],
|
|
461
|
+
onfileerror: [{ type: Output }],
|
|
462
|
+
onuploadcomplete: [{ type: Output }],
|
|
429
463
|
validationmessagerequired: [{ type: Input }],
|
|
430
464
|
validationmessagesummaryrequired: [{ type: Input }],
|
|
431
|
-
onfileerror: [{ type: Output }],
|
|
432
465
|
allowedtypes: [{ type: Input }],
|
|
433
466
|
autoupload: [{ type: Input }],
|
|
434
467
|
enablepause: [{ type: Input }],
|
|
435
|
-
endpoint: [{ type: Input }]
|
|
468
|
+
endpoint: [{ type: Input }],
|
|
469
|
+
token: [{ type: Input }]
|
|
436
470
|
};
|
|
437
471
|
/**
|
|
438
472
|
* Klasse für den Upload einer Datei in der Upload Component
|
|
@@ -452,5 +486,5 @@ export class SacUploadFile {
|
|
|
452
486
|
this.documentid = null;
|
|
453
487
|
}
|
|
454
488
|
}
|
|
455
|
-
// #endregion Classes
|
|
456
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"baseuploadcontrol.js","sourceRoot":"C:/Projekte/simpleangularcontrols-ng10/ch.jnetwork.sac-controls/projects/sac-common/src/","sources":["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 { UploadState, UploadxOptions, UploadxService } from 'ngx-uploadx';\r\nimport { Observable, of } from 'rxjs';\r\nimport { SacFormLayoutCommon } from '../controls/layout/formlayout';\r\nimport { ISacLocalisationService } from '../interfaces/ISacLocalisationService';\r\nimport { IUploadControl } from '../interfaces/iuploadcontrol';\r\nimport {\r\n  SACVALIDATIONKEY_SERVICE,\r\n  SacDefaultValidationKeyService,\r\n} 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   * 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    this.validationKeyService.ValidationErrorRequired;\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    this.validationKeyService.ValidationErrorSummaryRequired;\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.handleFileList(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.validationKeyService = injector.get(\r\n      SACVALIDATIONKEY_SERVICE,\r\n      new SacDefaultValidationKeyService()\r\n    );\r\n\r\n    this.lngResourceService = injector.get(\r\n      SACLOCALISATION_SERVICE,\r\n      new SacDefaultLocalisationService(this.validationKeyService)\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(this.ngZone);\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(\r\n        this.validationKeyService.UploadNoFilesSelected\r\n      );\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"]}
|
|
489
|
+
// #endregion Exported Classes
|
|
490
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"baseuploadcontrol.js","sourceRoot":"C:/Projekte/simpleangularcontrols-ng10/ch.jnetwork.sac-controls/projects/sac-common/src/","sources":["common/baseuploadcontrol.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,+BAA+B,CAAC;AAIpE,OAAO,EAAE,wBAAwB,EAAE,8BAA8B,EAAE,MAAM,aAAa,CAAC;AACvF,OAAO,EAAE,uBAAuB,EAAE,6BAA6B,EAAE,MAAM,sCAAsC,CAAC;AAC9G,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,YAAY,EAAE,QAAQ,EAAE,KAAK,EAAE,MAAM,EAAqB,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAE9I,OAAO,EAA+B,cAAc,EAAE,MAAM,aAAa,CAAC;AAC1E,OAAO,EAAc,EAAE,EAAE,MAAM,MAAM,CAAC;AAEtC,2BAA2B;AAE3B;;GAEG;AAEH,MAAM,OAAgB,aAAqB,SAAQ,mBAA0B;IAqGzE,wBAAwB;IAExB,uBAAuB;IAEvB;;;;;;OAMG;IACH,YACI,UAA+B,EAC/B,QAAkB,EACV,QAAmB,EACnB,MAAc;QAEtB,KAAK,CAAC,UAAU,EAAE,QAAQ,CAAC,CAAC;QAHpB,aAAQ,GAAR,QAAQ,CAAW;QACnB,WAAM,GAAN,MAAM,CAAQ;QAnH1B,qBAAqB;QAErB;;WAEG;QACK,kBAAa,GAAW,GAAG,CAAC;QAEpC;;WAEG;QACK,gBAAW,GAAY,KAAK,CAAC;QAErC;;WAEG;QACK,iBAAY,GAAY,IAAI,CAAC;QAErC;;WAEG;QACK,cAAS,GAAW,IAAI,CAAC;QAEjC;;WAEG;QACK,WAAM,GAAkB,IAAI,CAAC;QAErC;;WAEG;QACK,YAAO,GAAmB,EAAE,CAAC;QAarC;;WAEG;QACI,iBAAY,GAAG,GAAG,EAAE;YACvB,IAAI,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,EAAE;gBACtC,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;aAC3E;QACL,CAAC,CAAC;QAEF;;WAEG;QACa,eAAU,GAAY,KAAK,CAAC;QAY5C;;WAEG;QACa,gBAAW,GAAW,CAAC,CAAC;QAExC;;WAEG;QAEI,gBAAW,GAAG,IAAI,YAAY,EAAU,CAAC;QAEhD;;WAEG;QAEI,qBAAgB,GAAG,IAAI,YAAY,EAAgC,CAAC;QAO3E;;WAEG;QACa,8BAAyB,GAAW,IAAI,CAAC,oBAAoB,CAAC,uBAAuB,CAAC;QAEtG;;WAEG;QAEI,qCAAgC,GAAW,IAAI,CAAC,oBAAoB,CAAC,8BAA8B,CAAC;QAqBvG,IAAI,CAAC,oBAAoB,GAAG,QAAQ,CAAC,GAAG,CAAC,wBAAwB,EAAE,IAAI,8BAA8B,EAAE,CAAC,CAAC;QAEzG,IAAI,CAAC,kBAAkB,GAAG,QAAQ,CAAC,GAAG,CAClC,uBAAuB,EACvB,IAAI,6BAA6B,CAAC,IAAI,CAAC,oBAAoB,CAAC,CAC/D,CAAC;QAEF,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;QAElB,IAAI,CAAC,OAAO,CAAC,YAAY,GAAG,GAAG,CAAC;QAChC,IAAI,CAAC,OAAO,CAAC,WAAW,GAAG,CAAC,CAAC;QAC7B,IAAI,CAAC,OAAO,CAAC,KAAK,GAAG,WAAW,CAAC;QACjC,IAAI,CAAC,OAAO,CAAC,UAAU,GAAG,IAAI,CAAC,WAAW,CAAC;QAC3C,IAAI,CAAC,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC;QACpC,IAAI,CAAC,OAAO,CAAC,SAAS,GAAG,IAAI,GAAG,EAAE,GAAG,CAAC,CAAC;QACvC,IAAI,CAAC,OAAO,CAAC,OAAO,GAAG,CAAC,CAAO,EAAE,EAAE,CAAC,CAAC;YACjC,qBAAqB,EAAE,YAAY,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE;SACzD,CAAC,CAAC;QAEH,4BAA4B;QAC5B,IAAI,CAAC,aAAa,GAAG,IAAI,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACrD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAEtC,oCAAoC;QACpC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,KAAkB,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;IACtF,CAAC;IAED,0BAA0B;IAE1B,qCAAqC;IAErC;;OAEG;IACH,IAAW,UAAU;QACjB,OAAO,IAAI,CAAC,WAAW,CAAC,yBAAyB,CAAC;IACtD,CAAC;IAED;;OAEG;IACH,IAAW,YAAY;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC,2BAA2B,CAAC;IACxD,CAAC;IAED;;OAEG;IACH,IAAW,UAAU;QACjB,OAAO,IAAI,CAAC,WAAW,CAAC,yBAAyB,CAAC;IACtD,CAAC;IAED;;OAEG;IACH,IAAW,SAAS;QAChB,OAAO,IAAI,CAAC,WAAW,CAAC,wBAAwB,CAAC;IACrD,CAAC;IAED;;OAEG;IACH,IAAW,UAAU;QACjB,OAAO,IAAI,CAAC,WAAW,CAAC,yBAAyB,CAAC;IACtD,CAAC;IAED,IAAW,YAAY;QACnB,OAAO,IAAI,CAAC,aAAa,CAAC;IAC9B,CAAC;IAED;;OAEG;IACH,IACW,YAAY,CAAC,KAAa;QACjC,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;IAChC,CAAC;IAED,IAAW,UAAU;QACjB,OAAO,IAAI,CAAC,WAAW,CAAC;IAC5B,CAAC;IAED;;OAEG;IACH,IACW,UAAU,CAAC,CAAU;QAC5B,IAAI,CAAC,WAAW,GAAG,CAAC,CAAC;QACrB,IAAI,CAAC,OAAO,CAAC,UAAU,GAAG,CAAC,CAAC;QAC5B,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC7C,CAAC;IAED,IAAW,WAAW;QAClB,OAAO,IAAI,CAAC,YAAY,CAAC;IAC7B,CAAC;IAED;;OAEG;IACH,IACW,WAAW,CAAC,CAAU;QAC7B,IAAI,CAAC,YAAY,GAAG,CAAC,CAAC;IAC1B,CAAC;IAED,IAAW,QAAQ;QACf,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAED;;OAEG;IACH,IACW,QAAQ,CAAC,CAAS;QACzB,IAAI,CAAC,SAAS,GAAG,CAAC,CAAC;QACnB,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;IACxB,CAAC;IAED;;OAEG;IACH,IAAW,KAAK;QACZ,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IAED;;OAEG;IACH,IACW,KAAK,CAAC,CAAgB;QAC7B,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;QAChB,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;IACrB,CAAC;IAcD;;;OAGG;IACI,QAAQ;QACX,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;YACzB,OAAO,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;SACnC;aAAM;YACH,OAAO,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,IAAI,CAAC,oBAAoB,CAAC,qBAAqB,CAAC,CAAC;SAC7F;IACL,CAAC;IAED;;;OAGG;IACI,YAAY;QACf,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC;IACnC,CAAC;IAED;;;OAGG;IACI,gBAAgB;QACnB,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;YACzB,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,KAAK,UAAU,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC;SAC/E;aAAM;YACH,OAAO,KAAK,CAAC;SAChB;IACL,CAAC;IAED;;;OAGG;IACI,QAAQ;QACX,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,KAAK,QAAQ,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;IAC5E,CAAC;IAED;;;OAGG;IACI,eAAe;QAClB,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,KAAK,OAAO,IAAI,GAAG,CAAC,MAAM,KAAK,QAAQ,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;IACtG,CAAC;IAED;;;OAGG;IACI,WAAW;QACd,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,KAAK,WAAW,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;IAC/E,CAAC;IAED;;;OAGG;IACI,QAAQ;QACX,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;YACzB,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC;SACnC;aAAM;YACH,OAAO,CAAC,CAAC;SACZ;IACL,CAAC;IASD;;;OAGG;IACI,MAAM,CAAC,QAAQ;QAClB,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;IACzE,CAAC;IAED;;OAEG;IACI,SAAS;QACZ,IAAI,IAAI,CAAC,YAAY,EAAE,KAAK,IAAI,EAAE;YAC9B,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;SACpD;IACL,CAAC;IAED;;OAEG;IACI,WAAW;QACd,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,IAAI,CAAC,UAAU,EAAE,CAAC;SACrB;IACL,CAAC;IAED;;OAEG;IACI,QAAQ;QACX,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,gEAAgE;QAChE,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,QAAQ,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;QAEpG,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QACzC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACjC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAE3B,IAAI,IAAI,CAAC,SAAS,KAAK,IAAI,EAAE;YACzB,MAAM,IAAI,KAAK,CAAC,0BAA0B,CAAC,CAAC;SAC/C;QAED,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IAC7C,CAAC;IAED;;;;OAIG;IACI,QAAQ,CAAC,KAAkB;QAC9B,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,KAAK,CAAC,QAAQ,CAAC,CAAC;QAE3E,IAAI,KAAK,CAAC,MAAM,KAAK,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,KAAK,OAAO,IAAI,KAAK,GAAG,CAAC,CAAC,EAAE;YACrE,IACI,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,IAAI,CAAC;gBACjC,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,IAAI,CAAC;gBAChC,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,EACjC;gBACE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC;aAC/C;iBAAM;gBACH,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;gBAE5B,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE;oBACpC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC;iBAC9C;qBAAM,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE;oBAC1C,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC;iBAC7C;aACJ;SACJ;aAAM,IAAI,KAAK,CAAC,MAAM,KAAK,WAAW,EAAE;YACrC,IAAI,KAAK,IAAI,CAAC,EAAE;gBACZ,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;aACjC;YAED,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC;SAC7B;aAAM,IAAI,KAAK,CAAC,MAAM,KAAK,UAAU,EAAE;YACpC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;YAC9C,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;YAC1C,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;YAE3B,MAAM,WAAW,GAAiC;gBAC9C,IAAI,EAAE,KAAK,CAAC,IAAI;gBAChB,IAAI,EAAE,KAAK,CAAC,IAAI;gBAChB,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,QAAQ;aACzC,CAAC;YAEF,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SAC3C;aAAM;YACH,IAAI,KAAK,IAAI,CAAC,EAAE;gBACZ,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;gBAC9C,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;aAC7C;SACJ;QAED,IAAI,CAAC,eAAe,EAAE,CAAC;IAC3B,CAAC;IAED;;;OAGG;IACI,KAAK,CAAC,QAAQ;QACjB,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAC;IAC9D,CAAC;IAED;;OAEG;IACI,QAAQ;QACX,IAAI,IAAI,CAAC,WAAW,EAAE,KAAK,IAAI,EAAE;YAC7B,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,CAAC;SACnD;IACL,CAAC;IAED;;OAEG;IACI,QAAQ,CAAC,KAAa;QACzB,IAAI,CAAC,OAAO,CAAC,KAAK,GAAG,KAAK,CAAC;IAC/B,CAAC;IAED;;;;OAIG;IACI,MAAM,CAAC,QAAQ;QAClB,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;IAC/D,CAAC;IAED;;OAEG;IACI,SAAS;QACZ,IAAI,IAAI,CAAC,eAAe,EAAE,KAAK,IAAI,EAAE;YACjC,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,MAAM,EAAE,QAAQ,EAAE,CAAC,CAAC;SACpD;IACL,CAAC;IAED;;;OAGG;IACI,YAAY,CAAC,CAAkB;QAClC,IAAI,KAAK,GAA4B,IAAI,CAAC;QAE1C,IAAI,IAAI,CAAC,UAAU,EAAE;YACjB,KAAK,GAAG,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,yBAAyB,EAAE,IAAI,CAAC,gCAAgC,CAAC,CAAC,CAAC,CAAC,CAAC;SACzG;QAED,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,4BAA4B;IAE5B,0BAA0B;IAElB,eAAe;QACnB,mIAAmI;QACnI,IAAI,IAAI,CAAC,SAAS,EAAE;YACf,IAAI,CAAC,SAAuC,CAAC,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC;SAC9F;IACL,CAAC;IAED;;OAEG;IACK,iBAAiB;QACrB,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,KAAK,UAAU,CAAC,CAAC,MAAM,CAAC;IAC1E,CAAC;IAED;;;;OAIG;IACK,gBAAgB,CAAC,QAAgB;QACrC,IAAI,IAAI,CAAC,aAAa,KAAK,GAAG,EAAE;YAC5B,OAAO,IAAI,CAAC;SACf;QAED,IAAI,OAAO,GAAY,KAAK,CAAC;QAC7B,MAAM,UAAU,GAAa,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAE3D,UAAU,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,EAAE;YACvB,IAAI,QAAQ,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC,EAAE;gBACpD,OAAO,GAAG,IAAI,CAAC;aAClB;QACL,CAAC,CAAC,CAAC;QAEH,OAAO,OAAO,CAAC;IACnB,CAAC;IAED;;;;OAIG;IACK,eAAe,CAAC,QAAgB;QACpC,IAAI,IAAI,CAAC,WAAW,KAAK,CAAC,EAAE;YACxB,OAAO,IAAI,CAAC;SACf;QAED,OAAO,IAAI,CAAC,WAAW,IAAI,QAAQ,CAAC;IACxC,CAAC;IAED;;;;OAIG;IACK,eAAe,CAAC,KAAa;QACjC,mGAAmG;QACnG,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE;YACpD,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,QAAQ,EAAE,KAAK,CAAC,CAAC;SAC/E;QAED,IAAI,CAAC,OAAO,CAAC,YAAY,GAAG,KAAK,CAAC;IACtC,CAAC;IAED;;;OAGG;IACK,WAAW,CAAC,GAAW;QAC3B,IAAI,CAAC,OAAO,CAAC,QAAQ,GAAG,GAAG,CAAC;IAChC,CAAC;;;YAxjBJ,SAAS;;;YAlBD,mBAAmB;YAQkB,QAAQ;YAA4C,SAAS;YAA5C,MAAM;;;0BA+ChE,SAAS,SAAC,OAAO,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;yBAoBnC,KAAK;0BAeL,KAAK;0BAKL,MAAM;+BAMN,MAAM;wCAWN,KAAK;+CAKL,KAAK;2BA+FL,KAAK;yBAaL,KAAK;0BAcL,KAAK;uBAYL,KAAK;oBAgBL,KAAK;;AAoUV;;GAEG;AACH,MAAM,OAAO,aAAa;IA4BtB,wBAAwB;IAExB,uBAAuB;IAEvB;;;OAGG;IACH,YAAY,KAAkB;QAC1B,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;QAC/B,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC;QACvB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC;QAC/B,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;QAC3B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IAC3B,CAAC;CAGJ;AAED,8BAA8B","sourcesContent":["import { SacFormLayoutCommon } from '../controls/layout/formlayout';\r\nimport { ISacLocalisationService } from '../interfaces/ISacLocalisationService';\r\nimport { ISacUploadEventCompleteState } from '../interfaces/ISacUploadEventCompleteState';\r\nimport { IUploadControl } from '../interfaces/iuploadcontrol';\r\nimport { SACVALIDATIONKEY_SERVICE, SacDefaultValidationKeyService } from '../services';\r\nimport { SACLOCALISATION_SERVICE, SacDefaultLocalisationService } from '../services/sac-localisation.service';\r\nimport { Validation } from '../validation';\r\nimport { SacBaseModelControl } from './basemodelcontrol';\r\nimport { Directive, ElementRef, EventEmitter, Injector, Input, NgZone, OnDestroy, OnInit, Output, Renderer2, ViewChild } from '@angular/core';\r\nimport { AbstractControl, ValidationErrors } from '@angular/forms';\r\nimport { UploadState, UploadxOptions, UploadxService } from 'ngx-uploadx';\r\nimport { Observable, of } from 'rxjs';\r\n\r\n// #region Exported Classes\r\n\r\n/**\r\n * Base Klasse für Uploader Control\r\n */\r\n@Directive()\r\nexport abstract class SacUploadBase<VALUE> extends SacBaseModelControl<VALUE> implements OnInit, OnDestroy {\r\n    // #region Properties\r\n\r\n    /**\r\n     * Erlaubte Dateitypen\r\n     */\r\n    private _allowedtypes: string = '*';\r\n\r\n    /**\r\n     * Files automatisch hochladen\r\n     */\r\n    private _autoupload: boolean = false;\r\n\r\n    /**\r\n     * Pausieren von Uploads erlauben\r\n     */\r\n    private _enablepause: boolean = true;\r\n\r\n    /**\r\n     * API Endpoint\r\n     */\r\n    private _endpoint: string = null;\r\n\r\n    /**\r\n     * Token for Bearer Authentication\r\n     */\r\n    private _token: string | null = null;\r\n\r\n    /**\r\n     * Upload Settings\r\n     */\r\n    private options: UploadxOptions = {};\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     * Upload Service\r\n     */\r\n    protected uploadService: UploadxService;\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.handleFileList(this.uploadInput.nativeElement.files);\r\n        }\r\n    };\r\n\r\n    /**\r\n     * Definiert das Control als Required\r\n     */\r\n    @Input() public isrequired: boolean = false;\r\n\r\n    /**\r\n     * Listener für Files\r\n     */\r\n    public listenerFn: () => void;\r\n\r\n    /**\r\n     * Service für Error Localisation\r\n     */\r\n    public lngResourceService: ISacLocalisationService;\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() public maxfilesize: number = 0;\r\n\r\n    /**\r\n     * Event when an error is triggered in the component.\r\n     */\r\n    @Output()\r\n    public onfileerror = new EventEmitter<string>();\r\n\r\n    /**\r\n     * Event when a file has been uploaded. The event is triggered for multiple uploads per file.\r\n     */\r\n    @Output()\r\n    public onuploadcomplete = new EventEmitter<ISacUploadEventCompleteState>();\r\n\r\n    /**\r\n     * Array von Uploads\r\n     */\r\n    public uploads: SacUploadFile[];\r\n\r\n    /**\r\n     * Resource Key für Validation Message Required bei Control\r\n     */\r\n    @Input() public validationmessagerequired: string = this.validationKeyService.ValidationErrorRequired;\r\n\r\n    /**\r\n     * Resource Key für Validation Message Required in Validation Summary\r\n     */\r\n    @Input()\r\n    public validationmessagesummaryrequired: string = this.validationKeyService.ValidationErrorSummaryRequired;\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.validationKeyService = injector.get(SACVALIDATIONKEY_SERVICE, new SacDefaultValidationKeyService());\r\n\r\n        this.lngResourceService = injector.get(\r\n            SACLOCALISATION_SERVICE,\r\n            new SacDefaultLocalisationService(this.validationKeyService)\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(this.ngZone);\r\n        this.uploadService.init(this.options);\r\n\r\n        // Subscripe Event for State changes\r\n        this.uploadService.events.subscribe((ufile: UploadState) => this.onUpload(ufile));\r\n    }\r\n\r\n    // #endregion Constructors\r\n\r\n    // #region Public Getters And Setters\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    /**\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    public get autoupload(): boolean {\r\n        return this._autoupload;\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    public get enablepause(): boolean {\r\n        return this._enablepause;\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    public get endpoint(): string {\r\n        return this._endpoint;\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     * Token for Bearer Authentication\r\n     */\r\n    public get token(): string | null {\r\n        return this._token;\r\n    }\r\n\r\n    /**\r\n     * Token for Bearer Authentication\r\n     */\r\n    @Input()\r\n    public set token(v: string | null) {\r\n        this._token = v;\r\n        this.setToken(v);\r\n    }\r\n\r\n    // #endregion Public Getters And Setters\r\n\r\n    // #region Public 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    /**\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(this.validationKeyService.UploadNoFilesSelected);\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 this.uploads.filter((itm) => itm.status !== 'complete').length === 0;\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 this.uploads.filter((itm) => itm.status === 'added' || itm.status === 'paused').length > 0;\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     * 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    /**\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     * Initializes the 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(this.uploadInput.nativeElement, 'change', this.fileListener);\r\n\r\n        this.setAllowedTypes(this._allowedtypes);\r\n        this.setEndpoint(this._endpoint);\r\n        this.setToken(this._token);\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\r\n            const uploadState: ISacUploadEventCompleteState = {\r\n                name: ufile.name,\r\n                size: ufile.size,\r\n                uploadid: this.uploads[index].uploadId,\r\n            };\r\n\r\n            this.onuploadcomplete.emit(uploadState);\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     * Sets the bearer token in the upload service\r\n     */\r\n    public setToken(value: string) {\r\n        this.options.token = value;\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(this.validationmessagerequired, this.validationmessagesummaryrequired)(c);\r\n        }\r\n\r\n        return error;\r\n    }\r\n\r\n    // #endregion Public 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 = 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(this.uploadInput.nativeElement, 'accept', types);\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    /**\r\n     * Dateiname\r\n     */\r\n    public name: string;\r\n\r\n    /**\r\n     * Upload Fortschritt\r\n     */\r\n    public progress: number;\r\n\r\n    /**\r\n     * Upload Status\r\n     */\r\n    public status: string;\r\n\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 Exported Classes\r\n"]}
|