@progress-chef/platform-shared-components 0.0.86 → 0.0.87
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.
|
@@ -5,7 +5,9 @@ import * as i1 from "@angular/common";
|
|
|
5
5
|
import * as i2 from "@progress/kendo-angular-upload";
|
|
6
6
|
import * as i3 from "@angular/forms";
|
|
7
7
|
export class UploaderComponent {
|
|
8
|
-
constructor() {
|
|
8
|
+
constructor(renderer, elRef) {
|
|
9
|
+
this.renderer = renderer;
|
|
10
|
+
this.elRef = elRef;
|
|
9
11
|
this.uploadSaveUrl = "node/enrollment/v1/bulk-enroll"; // should represent an actual API endpoint
|
|
10
12
|
this.uploadRemoveUrl = "";
|
|
11
13
|
this.control = new FormControl();
|
|
@@ -13,7 +15,8 @@ export class UploaderComponent {
|
|
|
13
15
|
this.isDisabled = false;
|
|
14
16
|
this.hasExternalDropzone = false;
|
|
15
17
|
this.showFileList = true;
|
|
16
|
-
this.autoUpload =
|
|
18
|
+
this.autoUpload = false;
|
|
19
|
+
this.showDefaultActionButtons = false; // pass it as true if need to show default action buttons of kendo upload when autoupload is false
|
|
17
20
|
this.actionsLayout = "end";
|
|
18
21
|
this.multiple = false;
|
|
19
22
|
this.batch = false;
|
|
@@ -49,6 +52,9 @@ export class UploaderComponent {
|
|
|
49
52
|
ngOnInit() {
|
|
50
53
|
this.updateAllowedExtensionsText();
|
|
51
54
|
}
|
|
55
|
+
ngAfterViewInit() {
|
|
56
|
+
this.setActionButtonClass();
|
|
57
|
+
}
|
|
52
58
|
updateAllowedExtensionsText() {
|
|
53
59
|
if (this.restrictions && this.restrictions.allowedExtensions && this.restrictions.allowedExtensions.length > 0) {
|
|
54
60
|
this.allowedExtensionsText = `Only ${this.restrictions.allowedExtensions.join(', ').toUpperCase()} ${this.restrictions.allowedExtensions.length > 1 ? 'are ' : 'is '} allowed`;
|
|
@@ -66,6 +72,14 @@ export class UploaderComponent {
|
|
|
66
72
|
this.control.enable();
|
|
67
73
|
}
|
|
68
74
|
}
|
|
75
|
+
if (changes['showDefaultActionButtons']) {
|
|
76
|
+
this.setActionButtonClass(changes['showDefaultActionButtons'].currentValue);
|
|
77
|
+
}
|
|
78
|
+
if (changes['restrictions']) {
|
|
79
|
+
if (changes['restrictions']?.currentValue?.allowedExtensions) {
|
|
80
|
+
this.updateAllowedExtensionsText();
|
|
81
|
+
}
|
|
82
|
+
}
|
|
69
83
|
}
|
|
70
84
|
removeEventHandler(event) {
|
|
71
85
|
this.onRemoveEvent.emit(event);
|
|
@@ -109,13 +123,24 @@ export class UploaderComponent {
|
|
|
109
123
|
focusHandler() {
|
|
110
124
|
this.onFocusEvent.emit();
|
|
111
125
|
}
|
|
112
|
-
|
|
113
|
-
|
|
126
|
+
setActionButtonClass(showDefaultActionButtons = this.showDefaultActionButtons) {
|
|
127
|
+
if (this.kendoUpload) {
|
|
128
|
+
const uploadElement = this.elRef.nativeElement.querySelector('kendo-upload');
|
|
129
|
+
if (!this.autoUpload && !showDefaultActionButtons) {
|
|
130
|
+
this.renderer.addClass(uploadElement, 'custom-upload');
|
|
131
|
+
}
|
|
132
|
+
else {
|
|
133
|
+
this.renderer?.removeClass(uploadElement, 'custom-upload');
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: UploaderComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
138
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: UploaderComponent, selector: "lib-uploader", inputs: { uploadSaveUrl: "uploadSaveUrl", uploadRemoveUrl: "uploadRemoveUrl", control: "control", model: "model", isDisabled: "isDisabled", hasExternalDropzone: "hasExternalDropzone", showFileList: "showFileList", autoUpload: "autoUpload", showDefaultActionButtons: "showDefaultActionButtons", actionsLayout: "actionsLayout", multiple: "multiple", batch: "batch", concurrent: "concurrent", withCredentials: "withCredentials", restrictions: "restrictions", chunkSettings: "chunkSettings" }, outputs: { onRemoveEvent: "onRemoveEvent", onCancelEvent: "onCancelEvent", onUploadEvent: "onUploadEvent", onResumeEvent: "onResumeEvent", onSelectEvent: "onSelectEvent", onSuccessEvent: "onSuccessEvent", onUploadProgressEvent: "onUploadProgressEvent", onValueChangeEvent: "onValueChangeEvent", onErrorEvent: "onErrorEvent", onPauseEvent: "onPauseEvent", onCompleteEvent: "onCompleteEvent", onBlurEvent: "onBlurEvent", onFocusEvent: "onFocusEvent", onclearEvent: "onclearEvent" }, queries: [{ propertyName: "fileTemplate", first: true, predicate: ["uploadTemplate"], descendants: true }], viewQueries: [{ propertyName: "kendoUpload", first: true, predicate: ["libUploader"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<kendo-uploaddropzone zoneId=\"dropZone\" *ngIf=\"hasExternalDropzone\">\n {{allowedExtensionsText}}\n</kendo-uploaddropzone>\n<kendo-upload #uploader [saveUrl]=\"uploadSaveUrl\" [removeUrl]=\"uploadRemoveUrl\" [autoUpload]=\"autoUpload\"\n [actionsLayout]=\"actionsLayout\" [withCredentials]=\"withCredentials\" [multiple]=\"multiple\" [batch]=\"batch\"\n [restrictions]=\"restrictions\" [chunkable]=\"chunkSettings\" [concurrent]=\"concurrent\" [formControl]=\"control\"\n [(ngModel)]=\"model\" zoneId=\"dropZone\" (cancel)=\"cancelEventHandler($event)\" (clear)=\"clearEventHandler()\"\n (complete)=\"completeEventHandler()\" (error)=\"errorEventHandler($event)\" (blur)=\"blurHandler()\"\n (focus)=\"focusHandler()\" (pause)=\"pauseEventHandler($event)\" (remove)=\"removeEventHandler($event)\"\n (resume)=\"resumeEventHandler($event)\" (select)=\"selectEventHandler($event)\" (success)=\"successEventHandler($event)\"\n (upload)=\"uploadEventHandler($event)\" (uploadProgress)=\"uploadProgressEventHandler($event)\"\n (valueChange)=\"valueChangeEventHandler($event)\" [showFileList]=\"showFileList\" #libUploader=\"kendoUpload\">\n <ng-template *ngIf=\"fileTemplate\" kendoUploadFileTemplate let-files let-state=\"state\">\n <ng-container *ngTemplateOutlet=\"fileTemplate; context: { $implicit: { files: files, state: state } }\">\n </ng-container>\n </ng-template>\n</kendo-upload>\n", styles: [":host ::ng-deep .custom-upload .k-actions{display:none!important}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.FileTemplateDirective, selector: "[kendoUploadFileTemplate], [kendoFileSelectFileTemplate]" }, { kind: "component", type: i2.UploadDropZoneComponent, selector: "kendo-uploaddropzone", inputs: ["zoneId", "icon", "iconClass", "svgIcon"], exportAs: ["kendoUploadDropZone"] }, { kind: "component", type: i2.UploadComponent, selector: "kendo-upload", inputs: ["autoUpload", "batch", "withCredentials", "saveField", "saveHeaders", "saveMethod", "saveUrl", "responseType", "removeField", "removeHeaders", "removeMethod", "removeUrl", "chunkable", "concurrent", "multiple", "disabled", "showFileList", "tabindex", "zoneId", "tabIndex", "accept", "restrictions", "focusableId", "actionsLayout"], outputs: ["blur", "cancel", "clear", "complete", "error", "focus", "pause", "remove", "resume", "select", "success", "upload", "uploadProgress", "valueChange"], exportAs: ["kendoUpload"] }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }] }); }
|
|
114
139
|
}
|
|
115
140
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: UploaderComponent, decorators: [{
|
|
116
141
|
type: Component,
|
|
117
|
-
args: [{ selector: 'lib-uploader', template: "<kendo-uploaddropzone zoneId=\"dropZone\" *ngIf=\"hasExternalDropzone\">\n {{allowedExtensionsText}}\n</kendo-uploaddropzone>\n<kendo-upload #uploader [saveUrl]=\"uploadSaveUrl\" [removeUrl]=\"uploadRemoveUrl\" [autoUpload]=\"autoUpload\"\n [actionsLayout]=\"actionsLayout\" [withCredentials]=\"withCredentials\" [multiple]=\"multiple\" [batch]=\"batch\"\n [restrictions]=\"restrictions\" [chunkable]=\"chunkSettings\" [concurrent]=\"concurrent\" [formControl]=\"control\"\n [(ngModel)]=\"model\" zoneId=\"dropZone\" (cancel)=\"cancelEventHandler($event)\" (clear)=\"clearEventHandler()\"\n (complete)=\"completeEventHandler()\" (error)=\"errorEventHandler($event)\" (blur)=\"blurHandler()\"\n (focus)=\"focusHandler()\" (pause)=\"pauseEventHandler($event)\" (remove)=\"removeEventHandler($event)\"\n (resume)=\"resumeEventHandler($event)\" (select)=\"selectEventHandler($event)\" (success)=\"successEventHandler($event)\"\n (upload)=\"uploadEventHandler($event)\" (uploadProgress)=\"uploadProgressEventHandler($event)\"\n (valueChange)=\"valueChangeEventHandler($event)\" [showFileList]=\"showFileList\" #libUploader=\"kendoUpload\">\n <ng-template *ngIf=\"fileTemplate\" kendoUploadFileTemplate let-files let-state=\"state\">\n <ng-container *ngTemplateOutlet=\"fileTemplate; context: { $implicit: { files: files, state: state } }\">\n </ng-container>\n </ng-template>\n</kendo-upload>\n" }]
|
|
118
|
-
}], propDecorators: { uploadSaveUrl: [{
|
|
142
|
+
args: [{ selector: 'lib-uploader', template: "<kendo-uploaddropzone zoneId=\"dropZone\" *ngIf=\"hasExternalDropzone\">\n {{allowedExtensionsText}}\n</kendo-uploaddropzone>\n<kendo-upload #uploader [saveUrl]=\"uploadSaveUrl\" [removeUrl]=\"uploadRemoveUrl\" [autoUpload]=\"autoUpload\"\n [actionsLayout]=\"actionsLayout\" [withCredentials]=\"withCredentials\" [multiple]=\"multiple\" [batch]=\"batch\"\n [restrictions]=\"restrictions\" [chunkable]=\"chunkSettings\" [concurrent]=\"concurrent\" [formControl]=\"control\"\n [(ngModel)]=\"model\" zoneId=\"dropZone\" (cancel)=\"cancelEventHandler($event)\" (clear)=\"clearEventHandler()\"\n (complete)=\"completeEventHandler()\" (error)=\"errorEventHandler($event)\" (blur)=\"blurHandler()\"\n (focus)=\"focusHandler()\" (pause)=\"pauseEventHandler($event)\" (remove)=\"removeEventHandler($event)\"\n (resume)=\"resumeEventHandler($event)\" (select)=\"selectEventHandler($event)\" (success)=\"successEventHandler($event)\"\n (upload)=\"uploadEventHandler($event)\" (uploadProgress)=\"uploadProgressEventHandler($event)\"\n (valueChange)=\"valueChangeEventHandler($event)\" [showFileList]=\"showFileList\" #libUploader=\"kendoUpload\">\n <ng-template *ngIf=\"fileTemplate\" kendoUploadFileTemplate let-files let-state=\"state\">\n <ng-container *ngTemplateOutlet=\"fileTemplate; context: { $implicit: { files: files, state: state } }\">\n </ng-container>\n </ng-template>\n</kendo-upload>\n", styles: [":host ::ng-deep .custom-upload .k-actions{display:none!important}\n"] }]
|
|
143
|
+
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }]; }, propDecorators: { uploadSaveUrl: [{
|
|
119
144
|
type: Input
|
|
120
145
|
}], uploadRemoveUrl: [{
|
|
121
146
|
type: Input
|
|
@@ -131,6 +156,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
131
156
|
type: Input
|
|
132
157
|
}], autoUpload: [{
|
|
133
158
|
type: Input
|
|
159
|
+
}], showDefaultActionButtons: [{
|
|
160
|
+
type: Input
|
|
134
161
|
}], actionsLayout: [{
|
|
135
162
|
type: Input
|
|
136
163
|
}], multiple: [{
|
|
@@ -180,4 +207,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
180
207
|
type: ViewChild,
|
|
181
208
|
args: ['libUploader']
|
|
182
209
|
}] } });
|
|
183
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"uploader.component.js","sourceRoot":"","sources":["../../../../../../projects/shared/src/lib/atoms/uploader/uploader.component.ts","../../../../../../projects/shared/src/lib/atoms/uploader/uploader.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injectable, OnChanges, SimpleChanges, Input, OnInit, ContentChild, TemplateRef, ViewChild, Output, EventEmitter } from '@angular/core';\nimport { FormControl } from '@angular/forms';\nimport {\n  FileInfo, FileRestrictions, ChunkSettings, SelectEvent,\n  RemoveEvent,\n  ErrorEvent,\n  CancelEvent,\n  PauseEvent,\n  ResumeEvent,\n  SuccessEvent,\n  UploadEvent,\n  UploadProgressEvent,\n  UploadComponent,\n  FileState\n} from \"@progress/kendo-angular-upload\";\n\n@Component({\n  selector: 'lib-uploader',\n  templateUrl: './uploader.component.html',\n  styleUrls: ['./uploader.component.css']\n})\nexport class UploaderComponent implements OnChanges, OnInit {\n  @Input() uploadSaveUrl = \"node/enrollment/v1/bulk-enroll\"; // should represent an actual API endpoint\n  @Input() uploadRemoveUrl = \"\";\n  @Input() control: FormControl = new FormControl();\n  @Input() model: Array<FileInfo> = [];\n  @Input() isDisabled: boolean = false;\n  @Input() hasExternalDropzone: boolean = false;\n  @Input() showFileList: boolean = true;\n  @Input() autoUpload: boolean = true;\n  @Input() actionsLayout: \"start\" | \"center\" | \"end\" | \"stretched\" = \"end\";\n  @Input() multiple: boolean = false;\n  @Input() batch: boolean = false;\n  @Input() concurrent: boolean = true; /**to upload the files one by one, set this option to false */\n  @Input() withCredentials: boolean = true;\n  @Input() restrictions: FileRestrictions = {\n    allowedExtensions: [\".png\", \".jpeg\"],\n    maxFileSize: 4194304,\n    minFileSize: 5,\n  };\n  @Input() chunkSettings: ChunkSettings | boolean = {\n    size: 102400,\n    autoRetryAfter: 1000,\n    maxAutoRetries: 0,\n    resumable: true /**to upload the files without allowing the user to pause the upload process, set this parameter to false */\n  };\n  @Output() onRemoveEvent = new EventEmitter<RemoveEvent>();\n  @Output() onCancelEvent = new EventEmitter<CancelEvent>();\n  @Output() onUploadEvent = new EventEmitter<UploadEvent>();\n  @Output() onResumeEvent = new EventEmitter<ResumeEvent>();\n  @Output() onSelectEvent = new EventEmitter<SelectEvent>();\n  @Output() onSuccessEvent = new EventEmitter<SuccessEvent>();\n  @Output() onUploadProgressEvent = new EventEmitter<UploadProgressEvent>();\n  @Output() onValueChangeEvent = new EventEmitter<FileInfo[]>();\n  @Output() onErrorEvent = new EventEmitter<ErrorEvent>();\n  @Output() onPauseEvent = new EventEmitter<PauseEvent>();\n  @Output() onCompleteEvent = new EventEmitter<any>();\n  @Output() onBlurEvent = new EventEmitter<any>();\n  @Output() onFocusEvent = new EventEmitter<any>();\n  @Output() onclearEvent = new EventEmitter<any>();\n  @ContentChild('uploadTemplate') fileTemplate!: TemplateRef<any> | null;\n  @ViewChild('libUploader') kendoUpload!: UploadComponent;\n\n  allowedExtensionsText: string = '';\n\n  ngOnInit(): void {\n    this.updateAllowedExtensionsText();\n  }\n\n  updateAllowedExtensionsText(): void {\n    if (this.restrictions && this.restrictions.allowedExtensions && this.restrictions.allowedExtensions.length > 0) {\n      this.allowedExtensionsText = `Only ${this.restrictions.allowedExtensions.join(', ').toUpperCase()} ${this.restrictions.allowedExtensions.length > 1 ? 'are ' : 'is '} allowed`;\n    } else {\n      this.allowedExtensionsText = '';\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['isDisabled']) {\n      if (changes['isDisabled']?.currentValue) {\n        this.control.disable();\n      } else {\n        this.control.enable();\n      }\n    }\n  }\n\n  removeEventHandler(event: RemoveEvent) {\n    this.onRemoveEvent.emit(event);\n  }\n\n  cancelEventHandler(event: CancelEvent) {\n    this.onCancelEvent.emit(event);\n  }\n\n  uploadEventHandler(event: UploadEvent) {\n    this.onUploadEvent.emit(event);\n  }\n\n  resumeEventHandler(event: ResumeEvent) {\n    this.onResumeEvent.emit(event);\n  }\n\n  selectEventHandler(event: SelectEvent) {\n    this.onSelectEvent.emit(event);\n  }\n  successEventHandler(event: SuccessEvent) {\n    this.onSuccessEvent.emit(event);\n  }\n  uploadProgressEventHandler(event: UploadProgressEvent) {\n    this.onUploadProgressEvent.emit(event);\n  }\n  valueChangeEventHandler(event: FileInfo[]) {\n    this.onValueChangeEvent.emit(event);\n  }\n\n  errorEventHandler(event: ErrorEvent) {\n    this.onErrorEvent.emit(event);\n  }\n\n  pauseEventHandler(event: PauseEvent) {\n    this.onPauseEvent.emit(event);\n  }\n\n  clearEventHandler() {\n    this.onclearEvent.emit();\n  }\n  completeEventHandler() {\n    this.onCompleteEvent.emit();\n  }\n  blurHandler() {\n    this.onBlurEvent.emit();\n  }\n  focusHandler() {\n    this.onFocusEvent.emit();\n  }\n\n}\n","<kendo-uploaddropzone zoneId=\"dropZone\" *ngIf=\"hasExternalDropzone\">\n  {{allowedExtensionsText}}\n</kendo-uploaddropzone>\n<kendo-upload #uploader [saveUrl]=\"uploadSaveUrl\" [removeUrl]=\"uploadRemoveUrl\" [autoUpload]=\"autoUpload\"\n  [actionsLayout]=\"actionsLayout\" [withCredentials]=\"withCredentials\" [multiple]=\"multiple\" [batch]=\"batch\"\n  [restrictions]=\"restrictions\" [chunkable]=\"chunkSettings\" [concurrent]=\"concurrent\" [formControl]=\"control\"\n  [(ngModel)]=\"model\" zoneId=\"dropZone\" (cancel)=\"cancelEventHandler($event)\" (clear)=\"clearEventHandler()\"\n  (complete)=\"completeEventHandler()\" (error)=\"errorEventHandler($event)\" (blur)=\"blurHandler()\"\n  (focus)=\"focusHandler()\" (pause)=\"pauseEventHandler($event)\" (remove)=\"removeEventHandler($event)\"\n  (resume)=\"resumeEventHandler($event)\" (select)=\"selectEventHandler($event)\" (success)=\"successEventHandler($event)\"\n  (upload)=\"uploadEventHandler($event)\" (uploadProgress)=\"uploadProgressEventHandler($event)\"\n  (valueChange)=\"valueChangeEventHandler($event)\" [showFileList]=\"showFileList\" #libUploader=\"kendoUpload\">\n  <ng-template *ngIf=\"fileTemplate\" kendoUploadFileTemplate let-files let-state=\"state\">\n    <ng-container *ngTemplateOutlet=\"fileTemplate; context: { $implicit: { files: files, state: state } }\">\n    </ng-container>\n  </ng-template>\n</kendo-upload>\n"]}
|
|
210
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"uploader.component.js","sourceRoot":"","sources":["../../../../../../projects/shared/src/lib/atoms/uploader/uploader.component.ts","../../../../../../projects/shared/src/lib/atoms/uploader/uploader.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Injectable, OnChanges, SimpleChanges, Input, OnInit, ContentChild, TemplateRef, ViewChild, Output, EventEmitter, Renderer2, ElementRef, AfterViewInit } from '@angular/core';\nimport { FormControl } from '@angular/forms';\nimport {\n  FileInfo, FileRestrictions, ChunkSettings, SelectEvent,\n  RemoveEvent,\n  ErrorEvent,\n  CancelEvent,\n  PauseEvent,\n  ResumeEvent,\n  SuccessEvent,\n  UploadEvent,\n  UploadProgressEvent,\n  UploadComponent,\n  FileState\n} from \"@progress/kendo-angular-upload\";\n\n@Component({\n  selector: 'lib-uploader',\n  templateUrl: './uploader.component.html',\n  styleUrls: ['./uploader.component.css']\n})\nexport class UploaderComponent implements OnChanges, OnInit, AfterViewInit {\n  @Input() uploadSaveUrl = \"node/enrollment/v1/bulk-enroll\"; // should represent an actual API endpoint\n  @Input() uploadRemoveUrl = \"\";\n  @Input() control: FormControl = new FormControl();\n  @Input() model: Array<FileInfo> = [];\n  @Input() isDisabled: boolean = false;\n  @Input() hasExternalDropzone: boolean = false;\n  @Input() showFileList: boolean = true;\n  @Input() autoUpload: boolean = false;\n  @Input() showDefaultActionButtons: boolean = false; // pass it as true if need to show default action buttons of kendo upload when autoupload is false\n  @Input() actionsLayout: \"start\" | \"center\" | \"end\" | \"stretched\" = \"end\";\n  @Input() multiple: boolean = false;\n  @Input() batch: boolean = false;\n  @Input() concurrent: boolean = true; /**to upload the files one by one, set this option to false */\n  @Input() withCredentials: boolean = true;\n  @Input() restrictions: FileRestrictions = {\n    allowedExtensions: [\".png\", \".jpeg\"],\n    maxFileSize: 4194304,\n    minFileSize: 5,\n  };\n  @Input() chunkSettings: ChunkSettings | boolean = {\n    size: 102400,\n    autoRetryAfter: 1000,\n    maxAutoRetries: 0,\n    resumable: true /**to upload the files without allowing the user to pause the upload process, set this parameter to false */\n  };\n  @Output() onRemoveEvent = new EventEmitter<RemoveEvent>();\n  @Output() onCancelEvent = new EventEmitter<CancelEvent>();\n  @Output() onUploadEvent = new EventEmitter<UploadEvent>();\n  @Output() onResumeEvent = new EventEmitter<ResumeEvent>();\n  @Output() onSelectEvent = new EventEmitter<SelectEvent>();\n  @Output() onSuccessEvent = new EventEmitter<SuccessEvent>();\n  @Output() onUploadProgressEvent = new EventEmitter<UploadProgressEvent>();\n  @Output() onValueChangeEvent = new EventEmitter<FileInfo[]>();\n  @Output() onErrorEvent = new EventEmitter<ErrorEvent>();\n  @Output() onPauseEvent = new EventEmitter<PauseEvent>();\n  @Output() onCompleteEvent = new EventEmitter<any>();\n  @Output() onBlurEvent = new EventEmitter<any>();\n  @Output() onFocusEvent = new EventEmitter<any>();\n  @Output() onclearEvent = new EventEmitter<any>();\n  @ContentChild('uploadTemplate') fileTemplate!: TemplateRef<any> | null;\n  @ViewChild('libUploader') kendoUpload!: UploadComponent;\n\n\n  allowedExtensionsText: string = '';\n\n  constructor(private renderer: Renderer2, private elRef: ElementRef) { }\n\n  ngOnInit(): void {\n    this.updateAllowedExtensionsText();\n  }\n  ngAfterViewInit() {\n    this.setActionButtonClass();\n  }\n\n  updateAllowedExtensionsText(): void {\n    if (this.restrictions && this.restrictions.allowedExtensions && this.restrictions.allowedExtensions.length > 0) {\n      this.allowedExtensionsText = `Only ${this.restrictions.allowedExtensions.join(', ').toUpperCase()} ${this.restrictions.allowedExtensions.length > 1 ? 'are ' : 'is '} allowed`;\n    } else {\n      this.allowedExtensionsText = '';\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['isDisabled']) {\n      if (changes['isDisabled']?.currentValue) {\n        this.control.disable();\n      } else {\n        this.control.enable();\n      }\n    }\n    if (changes['showDefaultActionButtons']) {\n      this.setActionButtonClass(changes['showDefaultActionButtons'].currentValue);\n    }\n    if (changes['restrictions']) {\n      if (changes['restrictions']?.currentValue?.allowedExtensions) {\n        this.updateAllowedExtensionsText();\n      }\n    }\n  }\n\n  removeEventHandler(event: RemoveEvent) {\n    this.onRemoveEvent.emit(event);\n  }\n\n  cancelEventHandler(event: CancelEvent) {\n    this.onCancelEvent.emit(event);\n  }\n\n  uploadEventHandler(event: UploadEvent) {\n    this.onUploadEvent.emit(event);\n  }\n\n  resumeEventHandler(event: ResumeEvent) {\n    this.onResumeEvent.emit(event);\n  }\n\n  selectEventHandler(event: SelectEvent) {\n    this.onSelectEvent.emit(event);\n  }\n  successEventHandler(event: SuccessEvent) {\n    this.onSuccessEvent.emit(event);\n  }\n  uploadProgressEventHandler(event: UploadProgressEvent) {\n    this.onUploadProgressEvent.emit(event);\n  }\n  valueChangeEventHandler(event: FileInfo[]) {\n    this.onValueChangeEvent.emit(event);\n  }\n\n  errorEventHandler(event: ErrorEvent) {\n    this.onErrorEvent.emit(event);\n  }\n\n  pauseEventHandler(event: PauseEvent) {\n    this.onPauseEvent.emit(event);\n  }\n\n  clearEventHandler() {\n    this.onclearEvent.emit();\n  }\n  completeEventHandler() {\n    this.onCompleteEvent.emit();\n  }\n  blurHandler() {\n    this.onBlurEvent.emit();\n  }\n  focusHandler() {\n    this.onFocusEvent.emit();\n  }\n\n  setActionButtonClass(showDefaultActionButtons: boolean = this.showDefaultActionButtons) {\n    if (this.kendoUpload) {\n      const uploadElement = this.elRef.nativeElement.querySelector('kendo-upload');\n      if (!this.autoUpload && !showDefaultActionButtons) {\n        this.renderer.addClass(uploadElement, 'custom-upload');\n      } else {\n        this.renderer?.removeClass(uploadElement, 'custom-upload');\n      }\n    }\n  }\n}\n","<kendo-uploaddropzone zoneId=\"dropZone\" *ngIf=\"hasExternalDropzone\">\n  {{allowedExtensionsText}}\n</kendo-uploaddropzone>\n<kendo-upload #uploader [saveUrl]=\"uploadSaveUrl\" [removeUrl]=\"uploadRemoveUrl\" [autoUpload]=\"autoUpload\"\n  [actionsLayout]=\"actionsLayout\" [withCredentials]=\"withCredentials\" [multiple]=\"multiple\" [batch]=\"batch\"\n  [restrictions]=\"restrictions\" [chunkable]=\"chunkSettings\" [concurrent]=\"concurrent\" [formControl]=\"control\"\n  [(ngModel)]=\"model\" zoneId=\"dropZone\" (cancel)=\"cancelEventHandler($event)\" (clear)=\"clearEventHandler()\"\n  (complete)=\"completeEventHandler()\" (error)=\"errorEventHandler($event)\" (blur)=\"blurHandler()\"\n  (focus)=\"focusHandler()\" (pause)=\"pauseEventHandler($event)\" (remove)=\"removeEventHandler($event)\"\n  (resume)=\"resumeEventHandler($event)\" (select)=\"selectEventHandler($event)\" (success)=\"successEventHandler($event)\"\n  (upload)=\"uploadEventHandler($event)\" (uploadProgress)=\"uploadProgressEventHandler($event)\"\n  (valueChange)=\"valueChangeEventHandler($event)\" [showFileList]=\"showFileList\" #libUploader=\"kendoUpload\">\n  <ng-template *ngIf=\"fileTemplate\" kendoUploadFileTemplate let-files let-state=\"state\">\n    <ng-container *ngTemplateOutlet=\"fileTemplate; context: { $implicit: { files: files, state: state } }\">\n    </ng-container>\n  </ng-template>\n</kendo-upload>\n"]}
|
|
@@ -3277,7 +3277,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
3277
3277
|
}] });
|
|
3278
3278
|
|
|
3279
3279
|
class UploaderComponent {
|
|
3280
|
-
constructor() {
|
|
3280
|
+
constructor(renderer, elRef) {
|
|
3281
|
+
this.renderer = renderer;
|
|
3282
|
+
this.elRef = elRef;
|
|
3281
3283
|
this.uploadSaveUrl = "node/enrollment/v1/bulk-enroll"; // should represent an actual API endpoint
|
|
3282
3284
|
this.uploadRemoveUrl = "";
|
|
3283
3285
|
this.control = new FormControl();
|
|
@@ -3285,7 +3287,8 @@ class UploaderComponent {
|
|
|
3285
3287
|
this.isDisabled = false;
|
|
3286
3288
|
this.hasExternalDropzone = false;
|
|
3287
3289
|
this.showFileList = true;
|
|
3288
|
-
this.autoUpload =
|
|
3290
|
+
this.autoUpload = false;
|
|
3291
|
+
this.showDefaultActionButtons = false; // pass it as true if need to show default action buttons of kendo upload when autoupload is false
|
|
3289
3292
|
this.actionsLayout = "end";
|
|
3290
3293
|
this.multiple = false;
|
|
3291
3294
|
this.batch = false;
|
|
@@ -3321,6 +3324,9 @@ class UploaderComponent {
|
|
|
3321
3324
|
ngOnInit() {
|
|
3322
3325
|
this.updateAllowedExtensionsText();
|
|
3323
3326
|
}
|
|
3327
|
+
ngAfterViewInit() {
|
|
3328
|
+
this.setActionButtonClass();
|
|
3329
|
+
}
|
|
3324
3330
|
updateAllowedExtensionsText() {
|
|
3325
3331
|
if (this.restrictions && this.restrictions.allowedExtensions && this.restrictions.allowedExtensions.length > 0) {
|
|
3326
3332
|
this.allowedExtensionsText = `Only ${this.restrictions.allowedExtensions.join(', ').toUpperCase()} ${this.restrictions.allowedExtensions.length > 1 ? 'are ' : 'is '} allowed`;
|
|
@@ -3338,6 +3344,14 @@ class UploaderComponent {
|
|
|
3338
3344
|
this.control.enable();
|
|
3339
3345
|
}
|
|
3340
3346
|
}
|
|
3347
|
+
if (changes['showDefaultActionButtons']) {
|
|
3348
|
+
this.setActionButtonClass(changes['showDefaultActionButtons'].currentValue);
|
|
3349
|
+
}
|
|
3350
|
+
if (changes['restrictions']) {
|
|
3351
|
+
if (changes['restrictions']?.currentValue?.allowedExtensions) {
|
|
3352
|
+
this.updateAllowedExtensionsText();
|
|
3353
|
+
}
|
|
3354
|
+
}
|
|
3341
3355
|
}
|
|
3342
3356
|
removeEventHandler(event) {
|
|
3343
3357
|
this.onRemoveEvent.emit(event);
|
|
@@ -3381,13 +3395,24 @@ class UploaderComponent {
|
|
|
3381
3395
|
focusHandler() {
|
|
3382
3396
|
this.onFocusEvent.emit();
|
|
3383
3397
|
}
|
|
3384
|
-
|
|
3385
|
-
|
|
3398
|
+
setActionButtonClass(showDefaultActionButtons = this.showDefaultActionButtons) {
|
|
3399
|
+
if (this.kendoUpload) {
|
|
3400
|
+
const uploadElement = this.elRef.nativeElement.querySelector('kendo-upload');
|
|
3401
|
+
if (!this.autoUpload && !showDefaultActionButtons) {
|
|
3402
|
+
this.renderer.addClass(uploadElement, 'custom-upload');
|
|
3403
|
+
}
|
|
3404
|
+
else {
|
|
3405
|
+
this.renderer?.removeClass(uploadElement, 'custom-upload');
|
|
3406
|
+
}
|
|
3407
|
+
}
|
|
3408
|
+
}
|
|
3409
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: UploaderComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
3410
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: UploaderComponent, selector: "lib-uploader", inputs: { uploadSaveUrl: "uploadSaveUrl", uploadRemoveUrl: "uploadRemoveUrl", control: "control", model: "model", isDisabled: "isDisabled", hasExternalDropzone: "hasExternalDropzone", showFileList: "showFileList", autoUpload: "autoUpload", showDefaultActionButtons: "showDefaultActionButtons", actionsLayout: "actionsLayout", multiple: "multiple", batch: "batch", concurrent: "concurrent", withCredentials: "withCredentials", restrictions: "restrictions", chunkSettings: "chunkSettings" }, outputs: { onRemoveEvent: "onRemoveEvent", onCancelEvent: "onCancelEvent", onUploadEvent: "onUploadEvent", onResumeEvent: "onResumeEvent", onSelectEvent: "onSelectEvent", onSuccessEvent: "onSuccessEvent", onUploadProgressEvent: "onUploadProgressEvent", onValueChangeEvent: "onValueChangeEvent", onErrorEvent: "onErrorEvent", onPauseEvent: "onPauseEvent", onCompleteEvent: "onCompleteEvent", onBlurEvent: "onBlurEvent", onFocusEvent: "onFocusEvent", onclearEvent: "onclearEvent" }, queries: [{ propertyName: "fileTemplate", first: true, predicate: ["uploadTemplate"], descendants: true }], viewQueries: [{ propertyName: "kendoUpload", first: true, predicate: ["libUploader"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<kendo-uploaddropzone zoneId=\"dropZone\" *ngIf=\"hasExternalDropzone\">\n {{allowedExtensionsText}}\n</kendo-uploaddropzone>\n<kendo-upload #uploader [saveUrl]=\"uploadSaveUrl\" [removeUrl]=\"uploadRemoveUrl\" [autoUpload]=\"autoUpload\"\n [actionsLayout]=\"actionsLayout\" [withCredentials]=\"withCredentials\" [multiple]=\"multiple\" [batch]=\"batch\"\n [restrictions]=\"restrictions\" [chunkable]=\"chunkSettings\" [concurrent]=\"concurrent\" [formControl]=\"control\"\n [(ngModel)]=\"model\" zoneId=\"dropZone\" (cancel)=\"cancelEventHandler($event)\" (clear)=\"clearEventHandler()\"\n (complete)=\"completeEventHandler()\" (error)=\"errorEventHandler($event)\" (blur)=\"blurHandler()\"\n (focus)=\"focusHandler()\" (pause)=\"pauseEventHandler($event)\" (remove)=\"removeEventHandler($event)\"\n (resume)=\"resumeEventHandler($event)\" (select)=\"selectEventHandler($event)\" (success)=\"successEventHandler($event)\"\n (upload)=\"uploadEventHandler($event)\" (uploadProgress)=\"uploadProgressEventHandler($event)\"\n (valueChange)=\"valueChangeEventHandler($event)\" [showFileList]=\"showFileList\" #libUploader=\"kendoUpload\">\n <ng-template *ngIf=\"fileTemplate\" kendoUploadFileTemplate let-files let-state=\"state\">\n <ng-container *ngTemplateOutlet=\"fileTemplate; context: { $implicit: { files: files, state: state } }\">\n </ng-container>\n </ng-template>\n</kendo-upload>\n", styles: [":host ::ng-deep .custom-upload .k-actions{display:none!important}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2$8.FileTemplateDirective, selector: "[kendoUploadFileTemplate], [kendoFileSelectFileTemplate]" }, { kind: "component", type: i2$8.UploadDropZoneComponent, selector: "kendo-uploaddropzone", inputs: ["zoneId", "icon", "iconClass", "svgIcon"], exportAs: ["kendoUploadDropZone"] }, { kind: "component", type: i2$8.UploadComponent, selector: "kendo-upload", inputs: ["autoUpload", "batch", "withCredentials", "saveField", "saveHeaders", "saveMethod", "saveUrl", "responseType", "removeField", "removeHeaders", "removeMethod", "removeUrl", "chunkable", "concurrent", "multiple", "disabled", "showFileList", "tabindex", "zoneId", "tabIndex", "accept", "restrictions", "focusableId", "actionsLayout"], outputs: ["blur", "cancel", "clear", "complete", "error", "focus", "pause", "remove", "resume", "select", "success", "upload", "uploadProgress", "valueChange"], exportAs: ["kendoUpload"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }] }); }
|
|
3386
3411
|
}
|
|
3387
3412
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: UploaderComponent, decorators: [{
|
|
3388
3413
|
type: Component,
|
|
3389
|
-
args: [{ selector: 'lib-uploader', template: "<kendo-uploaddropzone zoneId=\"dropZone\" *ngIf=\"hasExternalDropzone\">\n {{allowedExtensionsText}}\n</kendo-uploaddropzone>\n<kendo-upload #uploader [saveUrl]=\"uploadSaveUrl\" [removeUrl]=\"uploadRemoveUrl\" [autoUpload]=\"autoUpload\"\n [actionsLayout]=\"actionsLayout\" [withCredentials]=\"withCredentials\" [multiple]=\"multiple\" [batch]=\"batch\"\n [restrictions]=\"restrictions\" [chunkable]=\"chunkSettings\" [concurrent]=\"concurrent\" [formControl]=\"control\"\n [(ngModel)]=\"model\" zoneId=\"dropZone\" (cancel)=\"cancelEventHandler($event)\" (clear)=\"clearEventHandler()\"\n (complete)=\"completeEventHandler()\" (error)=\"errorEventHandler($event)\" (blur)=\"blurHandler()\"\n (focus)=\"focusHandler()\" (pause)=\"pauseEventHandler($event)\" (remove)=\"removeEventHandler($event)\"\n (resume)=\"resumeEventHandler($event)\" (select)=\"selectEventHandler($event)\" (success)=\"successEventHandler($event)\"\n (upload)=\"uploadEventHandler($event)\" (uploadProgress)=\"uploadProgressEventHandler($event)\"\n (valueChange)=\"valueChangeEventHandler($event)\" [showFileList]=\"showFileList\" #libUploader=\"kendoUpload\">\n <ng-template *ngIf=\"fileTemplate\" kendoUploadFileTemplate let-files let-state=\"state\">\n <ng-container *ngTemplateOutlet=\"fileTemplate; context: { $implicit: { files: files, state: state } }\">\n </ng-container>\n </ng-template>\n</kendo-upload>\n" }]
|
|
3390
|
-
}], propDecorators: { uploadSaveUrl: [{
|
|
3414
|
+
args: [{ selector: 'lib-uploader', template: "<kendo-uploaddropzone zoneId=\"dropZone\" *ngIf=\"hasExternalDropzone\">\n {{allowedExtensionsText}}\n</kendo-uploaddropzone>\n<kendo-upload #uploader [saveUrl]=\"uploadSaveUrl\" [removeUrl]=\"uploadRemoveUrl\" [autoUpload]=\"autoUpload\"\n [actionsLayout]=\"actionsLayout\" [withCredentials]=\"withCredentials\" [multiple]=\"multiple\" [batch]=\"batch\"\n [restrictions]=\"restrictions\" [chunkable]=\"chunkSettings\" [concurrent]=\"concurrent\" [formControl]=\"control\"\n [(ngModel)]=\"model\" zoneId=\"dropZone\" (cancel)=\"cancelEventHandler($event)\" (clear)=\"clearEventHandler()\"\n (complete)=\"completeEventHandler()\" (error)=\"errorEventHandler($event)\" (blur)=\"blurHandler()\"\n (focus)=\"focusHandler()\" (pause)=\"pauseEventHandler($event)\" (remove)=\"removeEventHandler($event)\"\n (resume)=\"resumeEventHandler($event)\" (select)=\"selectEventHandler($event)\" (success)=\"successEventHandler($event)\"\n (upload)=\"uploadEventHandler($event)\" (uploadProgress)=\"uploadProgressEventHandler($event)\"\n (valueChange)=\"valueChangeEventHandler($event)\" [showFileList]=\"showFileList\" #libUploader=\"kendoUpload\">\n <ng-template *ngIf=\"fileTemplate\" kendoUploadFileTemplate let-files let-state=\"state\">\n <ng-container *ngTemplateOutlet=\"fileTemplate; context: { $implicit: { files: files, state: state } }\">\n </ng-container>\n </ng-template>\n</kendo-upload>\n", styles: [":host ::ng-deep .custom-upload .k-actions{display:none!important}\n"] }]
|
|
3415
|
+
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }]; }, propDecorators: { uploadSaveUrl: [{
|
|
3391
3416
|
type: Input
|
|
3392
3417
|
}], uploadRemoveUrl: [{
|
|
3393
3418
|
type: Input
|
|
@@ -3403,6 +3428,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
3403
3428
|
type: Input
|
|
3404
3429
|
}], autoUpload: [{
|
|
3405
3430
|
type: Input
|
|
3431
|
+
}], showDefaultActionButtons: [{
|
|
3432
|
+
type: Input
|
|
3406
3433
|
}], actionsLayout: [{
|
|
3407
3434
|
type: Input
|
|
3408
3435
|
}], multiple: [{
|