@acorex/components 6.5.9 → 6.5.11
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/esm2020/lib/upload-file/upload-file.component.mjs +43 -5
- package/fesm2015/acorex-components.mjs +42 -4
- package/fesm2015/acorex-components.mjs.map +1 -1
- package/fesm2020/acorex-components.mjs +42 -4
- package/fesm2020/acorex-components.mjs.map +1 -1
- package/lib/upload-file/upload-file.component.d.ts +5 -1
- package/package.json +1 -1
@@ -15,11 +15,39 @@ export class AXUploadFileComponent extends AXBaseComponent {
|
|
15
15
|
this.injectionService = injectionService;
|
16
16
|
this.rendrer = rendrer;
|
17
17
|
this.cdr = cdr;
|
18
|
+
this.contentType = 'image';
|
18
19
|
this.size = "md";
|
19
20
|
this.type = 'inline';
|
20
21
|
this.disabled = false;
|
21
22
|
this.onLoad = new EventEmitter();
|
22
23
|
this.onProgress = new EventEmitter();
|
24
|
+
this.onRemove = new EventEmitter();
|
25
|
+
this.fileTypes = [
|
26
|
+
{
|
27
|
+
type: 'image',
|
28
|
+
accept: ['image/gif', 'image/jpeg', 'image/png'],
|
29
|
+
},
|
30
|
+
{
|
31
|
+
type: 'audio',
|
32
|
+
accept: ['audio/mp3'],
|
33
|
+
},
|
34
|
+
{
|
35
|
+
type: 'ebook',
|
36
|
+
accept: ['application/pdf'],
|
37
|
+
},
|
38
|
+
{
|
39
|
+
type: 'excel',
|
40
|
+
accept: ['application/vnd.ms-excel', 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'],
|
41
|
+
},
|
42
|
+
{
|
43
|
+
type: 'video',
|
44
|
+
accept: ['video/*'],
|
45
|
+
},
|
46
|
+
{
|
47
|
+
type: 'video/image',
|
48
|
+
accept: ['image/gif', 'image/jpeg', 'image/png', 'video/*'],
|
49
|
+
},
|
50
|
+
];
|
23
51
|
this.files = [];
|
24
52
|
this.fileName = '';
|
25
53
|
}
|
@@ -33,10 +61,13 @@ export class AXUploadFileComponent extends AXBaseComponent {
|
|
33
61
|
this.fileInput.nativeElement.value = null;
|
34
62
|
}
|
35
63
|
open() {
|
36
|
-
this.fileInput.nativeElement.click();
|
64
|
+
this.fileInput.nativeElement.click({ accept: this.accessTypes });
|
37
65
|
}
|
38
66
|
remove() {
|
67
|
+
this.fileInput.nativeElement.value = '';
|
39
68
|
this.files = [];
|
69
|
+
this.fileName = null;
|
70
|
+
this.onRemove.emit();
|
40
71
|
}
|
41
72
|
ngAfterViewInit() {
|
42
73
|
if (this.dropRef != null) {
|
@@ -139,13 +170,18 @@ export class AXUploadFileComponent extends AXBaseComponent {
|
|
139
170
|
reader.readAsDataURL(file);
|
140
171
|
this.files.push(file);
|
141
172
|
}
|
173
|
+
get accessTypes() {
|
174
|
+
return this.fileTypes.find((item) => item.type == this.contentType).accept;
|
175
|
+
}
|
142
176
|
}
|
143
177
|
AXUploadFileComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXUploadFileComponent, deps: [{ token: i0.ElementRef }, { token: i1.AXRenderService }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
144
|
-
AXUploadFileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: AXUploadFileComponent, selector: "ax-upload-file", inputs: { dropRef: "dropRef", progressRef: "progressRef", label: "label", size: "size", type: "type", template: "template", disabled: "disabled" }, outputs: { onLoad: "onLoad", onProgress: "onProgress" }, host: { styleAttribute: "display: block; width:100%; position: relative" }, viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<input #fileInput type=\"file\" accept=\"
|
178
|
+
AXUploadFileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: AXUploadFileComponent, selector: "ax-upload-file", inputs: { contentType: "contentType", dropRef: "dropRef", progressRef: "progressRef", label: "label", size: "size", type: "type", template: "template", disabled: "disabled" }, outputs: { onLoad: "onLoad", onProgress: "onProgress", onRemove: "onRemove" }, host: { styleAttribute: "display: block; width:100%; position: relative" }, viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<input #fileInput type=\"file\" [accept]=\"accessTypes.join(',')\" style=\"display: none;\" (change)=\"onFileChange($event)\" />\r\n\r\n<ng-container *ngIf=\"type == 'inline'; else elseTemplate\">\r\n <ax-form-group size=\"{{size}}\">\r\n <ax-text-box [value]=\"fileName\" readonly=\"true\" [disabled]=\"disabled\"></ax-text-box>\r\n <ax-button type=\"blank light\" icon=\"far fa-times\" (click)=\"remove()\" *ngIf=\"fileName\" [tabIndex]=\"-1\">\r\n </ax-button>\r\n <ax-button type=\"primary blank\" icon=\"far fa-upload\" (click)=\"open()\" [disabled]=\"disabled\" [tabIndex]=\"-1\">\r\n </ax-button>\r\n </ax-form-group>\r\n</ng-container>\r\n\r\n<ng-template #elseTemplate>\r\n <div class=\"ax upload-file-box\" (click)=\"open()\" #dropRef>\r\n </div>\r\n</ng-template>\r\n", components: [{ type: i2.AXFormGroupComponent, selector: "ax-form-group", inputs: ["size"] }, { type: i3.AXTextBoxComponent, selector: "ax-text-box", inputs: ["mask", "type", "showMask", "maxLength", "maskGuid", "maskPlaceholder", "maskKeepCharPositions"] }, { type: i4.AXButtonComponent, selector: "ax-button", inputs: ["type", "icon", "submitBehavior", "cancelBehavior", "block", "loading", "selected"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None });
|
145
179
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXUploadFileComponent, decorators: [{
|
146
180
|
type: Component,
|
147
|
-
args: [{ selector: 'ax-upload-file', encapsulation: ViewEncapsulation.None, host: { style: 'display: block; width:100%; position: relative' }, template: "<input #fileInput type=\"file\" accept=\"
|
148
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.AXRenderService }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }]; }, propDecorators: {
|
181
|
+
args: [{ selector: 'ax-upload-file', encapsulation: ViewEncapsulation.None, host: { style: 'display: block; width:100%; position: relative' }, template: "<input #fileInput type=\"file\" [accept]=\"accessTypes.join(',')\" style=\"display: none;\" (change)=\"onFileChange($event)\" />\r\n\r\n<ng-container *ngIf=\"type == 'inline'; else elseTemplate\">\r\n <ax-form-group size=\"{{size}}\">\r\n <ax-text-box [value]=\"fileName\" readonly=\"true\" [disabled]=\"disabled\"></ax-text-box>\r\n <ax-button type=\"blank light\" icon=\"far fa-times\" (click)=\"remove()\" *ngIf=\"fileName\" [tabIndex]=\"-1\">\r\n </ax-button>\r\n <ax-button type=\"primary blank\" icon=\"far fa-upload\" (click)=\"open()\" [disabled]=\"disabled\" [tabIndex]=\"-1\">\r\n </ax-button>\r\n </ax-form-group>\r\n</ng-container>\r\n\r\n<ng-template #elseTemplate>\r\n <div class=\"ax upload-file-box\" (click)=\"open()\" #dropRef>\r\n </div>\r\n</ng-template>\r\n" }]
|
182
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.AXRenderService }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { contentType: [{
|
183
|
+
type: Input
|
184
|
+
}], dropRef: [{
|
149
185
|
type: Input
|
150
186
|
}], progressRef: [{
|
151
187
|
type: Input
|
@@ -166,5 +202,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
166
202
|
type: Output
|
167
203
|
}], onProgress: [{
|
168
204
|
type: Output
|
205
|
+
}], onRemove: [{
|
206
|
+
type: Output
|
169
207
|
}] } });
|
170
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload-file.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/upload-file/upload-file.component.ts","../../../../../../projects/acorex/components/src/lib/upload-file/upload-file.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewChild,\r\n  Input,\r\n  ElementRef,\r\n  ViewEncapsulation,\r\n  TemplateRef,\r\n  Renderer2,\r\n  EventEmitter,\r\n  Output,\r\n  ChangeDetectorRef\r\n} from '@angular/core';\r\nimport { AXUploadFileLoadEvent, AXUploadFileProgressEvent } from './upload-file.events';\r\nimport { AXProgressBarComponent } from '../progress-bar/progress-bar.component';\r\nimport { AXBaseTextComponent, AXElementSize, AXBaseSizableComponent, AXBaseComponent } from '../base/element.class';\r\nimport { AXRenderService } from '@acorex/core';\r\n\r\n@Component({\r\n  selector: 'ax-upload-file',\r\n  templateUrl: './upload-file.component.html',\r\n  encapsulation: ViewEncapsulation.None,\r\n  host: { style: 'display: block; width:100%; position: relative' }\r\n})\r\nexport class AXUploadFileComponent extends AXBaseComponent implements AXBaseSizableComponent {\r\n  private overlayDiv: HTMLElement;\r\n\r\n  @Input()\r\n  dropRef: HTMLElement;\r\n\r\n  @Input()\r\n  progressRef: HTMLElement;\r\n\r\n  @Input()\r\n  label: string;\r\n\r\n  @Input()\r\n  size: AXElementSize = \"md\";\r\n\r\n  @ViewChild('fileInput') fileInput: ElementRef;\r\n\r\n  @Input()\r\n  type: 'box' | 'inline' | 'hidden' = 'inline';\r\n\r\n  @Input()\r\n  public template: TemplateRef<any>;\r\n\r\n  @Input() disabled: boolean = false;\r\n  @Output()\r\n  onLoad: EventEmitter<AXUploadFileLoadEvent> = new EventEmitter<AXUploadFileLoadEvent>();\r\n\r\n  @Output()\r\n  onProgress: EventEmitter<AXUploadFileProgressEvent> = new EventEmitter<AXUploadFileProgressEvent>();\r\n\r\n  files: File[] = [];\r\n  focus() { }\r\n\r\n  fileName: string = '';\r\n  constructor(\r\n    private el: ElementRef<HTMLElement>,\r\n    private injectionService: AXRenderService,\r\n    private rendrer: Renderer2,\r\n    protected cdr: ChangeDetectorRef\r\n  ) {\r\n    super();\r\n  }\r\n\r\n\r\n  onDeleteClick(e) {\r\n    e.stopPropagation();\r\n  }\r\n\r\n  onFileChange(e) {\r\n    const files = e.target.files;\r\n    this.addFile(files[0]);\r\n    (this.fileInput.nativeElement as HTMLInputElement).value = null;\r\n  }\r\n\r\n  open() {\r\n    this.fileInput.nativeElement.click();\r\n  }\r\n  remove() {\r\n    this.files = [];\r\n  }\r\n  ngAfterViewInit(): void {\r\n    if (this.dropRef != null) {\r\n    } else {\r\n      this.dropRef = this.el.nativeElement;\r\n    }\r\n    //\r\n    if (this.progressRef != null) {\r\n    } else {\r\n      this.progressRef = this.el.nativeElement;\r\n    }\r\n    //\r\n    if (this.type === 'hidden' || this.type === 'box') {\r\n      this.overlayDiv = this.rendrer.createElement('div') as HTMLElement;\r\n      this.overlayDiv.classList.add('overlay');\r\n      this.overlayDiv.innerHTML = `\r\n      <div class=\"icon-wrapper\">\r\n        <i class=\"far fa-cloud-upload-alt fa-3x\"></i>\r\n        <span>Drop File(s) Here</span>\r\n      </div>\r\n    `;\r\n      this.overlayDiv.addEventListener('drag', this.handleOverlayDragOver);\r\n      this.overlayDiv.addEventListener('dragover', this.handleOverlayDragOver);\r\n      this.overlayDiv.addEventListener('dragleave', this.handleOverlayDragOver);\r\n      this.rendrer.appendChild(this.dropRef, this.overlayDiv);\r\n    }\r\n    //\r\n    this.dropRef.classList.add('ax-upload-drop-over');\r\n    this.dropRef.addEventListener('dragover', this.handleDragOver.bind(this));\r\n    this.dropRef.addEventListener('dragleave', this.handleDragLeave.bind(this));\r\n    this.dropRef.addEventListener('drop', this.handleDrop.bind(this));\r\n  }\r\n\r\n  private handleOverlayDragOver(e: DragEvent) {\r\n    e.preventDefault();\r\n    e.stopPropagation();\r\n    return false;\r\n  }\r\n\r\n  private handleDragOver(e: DragEvent) {\r\n    e.preventDefault();\r\n    e.stopPropagation();\r\n    this.overlayDiv.classList.add('show');\r\n    return false;\r\n  }\r\n\r\n  private handleDragLeave(e: DragEvent) {\r\n    e.preventDefault();\r\n    e.stopPropagation();\r\n    this.overlayDiv.classList.remove('show');\r\n    return false;\r\n  }\r\n\r\n  handleDrop(e: DragEvent) {\r\n    this.handleDragLeave(e);\r\n    for (let i = 0; i < e.dataTransfer.files.length; i++) {\r\n      const file = e.dataTransfer.files[i];\r\n      this.addFile(file);\r\n    }\r\n  }\r\n\r\n  private addFile(file: File) {\r\n    const progressDiv = this.rendrer.createElement('div') as HTMLElement;\r\n    progressDiv.classList.add('ax-upload-progress-panel');\r\n    const progressLabel = this.rendrer.createElement('small') as HTMLElement;\r\n    progressLabel.innerText = file.name;\r\n    this.fileName = file.name;\r\n    this.rendrer.appendChild(this.progressRef, progressDiv);\r\n    const com = this.injectionService.appendComponent(AXProgressBarComponent, { progress: 0 }, progressDiv).instance as AXProgressBarComponent;\r\n    this.rendrer.appendChild(progressDiv, progressLabel);\r\n\r\n    const reader = new FileReader();\r\n    reader.addEventListener('load', (e) => {\r\n      this.onLoad.emit({\r\n        file,\r\n        data: (e as any).target.result\r\n      });\r\n      //\r\n      // Fake Upload\r\n      let pv = 0;\r\n      let uploaded = 0;\r\n      const intv = setInterval(() => {\r\n        uploaded += 1024 * 1000;\r\n        if (uploaded > e.total) {\r\n          uploaded = e.total;\r\n        }\r\n        pv = Math.ceil((uploaded / e.total) * 100);\r\n        com.progress = pv;\r\n        this.onProgress.emit({\r\n          file,\r\n          total: e.total,\r\n          uploaded,\r\n          value: pv\r\n        });\r\n        //\r\n        if (com.progress >= 100) {\r\n          clearInterval(intv);\r\n          setTimeout(() => {\r\n            this.rendrer.removeChild(this.progressRef, progressDiv);\r\n          }, 1000);\r\n        }\r\n      }, 100);\r\n    });\r\n    reader.readAsDataURL(file);\r\n    this.files.push(file);\r\n  }\r\n}\r\n","<input #fileInput type=\"file\" accept=\"image/*\" style=\"display: none;\" (change)=\"onFileChange($event)\" />\r\n\r\n<ng-container *ngIf=\"type == 'inline'; else elseTemplate\">\r\n  <ax-form-group size=\"{{size}}\">\r\n    <ax-text-box [value]=\"fileName\" readonly=\"true\" [disabled]=\"disabled\"></ax-text-box>\r\n    <ax-button type=\"blank light\" icon=\"far fa-times\" (click)=\"remove()\" *ngIf=\"fileName\" [tabIndex]=\"-1\">\r\n    </ax-button>\r\n    <ax-button type=\"primary blank\" icon=\"far fa-upload\" (click)=\"open()\" [disabled]=\"disabled\" [tabIndex]=\"-1\">\r\n    </ax-button>\r\n  </ax-form-group>\r\n</ng-container>\r\n\r\n<ng-template #elseTemplate>\r\n  <div class=\"ax upload-file-box\" (click)=\"open()\" #dropRef>\r\n  </div>\r\n</ng-template>"]}
|
208
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload-file.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/upload-file/upload-file.component.ts","../../../../../../projects/acorex/components/src/lib/upload-file/upload-file.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,SAAS,EACT,KAAK,EACL,UAAU,EACV,iBAAiB,EACjB,WAAW,EACX,SAAS,EACT,YAAY,EACZ,MAAM,EACN,iBAAiB,EAClB,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,sBAAsB,EAAE,MAAM,wCAAwC,CAAC;AAChF,OAAO,EAA8D,eAAe,EAAE,MAAM,uBAAuB,CAAC;AACpH,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;;;;;;;AAQ/C,MAAM,OAAO,qBAAsB,SAAQ,eAAe;IAoExD,YACU,EAA2B,EAC3B,gBAAiC,EACjC,OAAkB,EAChB,GAAsB;QAEhC,KAAK,EAAE,CAAC;QALA,OAAE,GAAF,EAAE,CAAyB;QAC3B,qBAAgB,GAAhB,gBAAgB,CAAiB;QACjC,YAAO,GAAP,OAAO,CAAW;QAChB,QAAG,GAAH,GAAG,CAAmB;QApElC,gBAAW,GAA0D,OAAO,CAAC;QAY7E,SAAI,GAAkB,IAAI,CAAC;QAK3B,SAAI,GAAgC,QAAQ,CAAC;QAKpC,aAAQ,GAAY,KAAK,CAAC;QAEnC,WAAM,GAAwC,IAAI,YAAY,EAAyB,CAAC;QAGxF,eAAU,GAA4C,IAAI,YAAY,EAA6B,CAAC;QAGpG,aAAQ,GAAsB,IAAI,YAAY,EAAE,CAAC;QAEjD,cAAS,GAAS;YAChB;gBACE,IAAI,EAAE,OAAO;gBACb,MAAM,EAAE,CAAC,WAAW,EAAE,YAAY,EAAE,WAAW,CAAC;aACjD;YACD;gBACE,IAAI,EAAE,OAAO;gBACb,MAAM,EAAE,CAAC,WAAW,CAAC;aACtB;YACD;gBACE,IAAI,EAAE,OAAO;gBACb,MAAM,EAAE,CAAC,iBAAiB,CAAC;aAC5B;YACD;gBACE,IAAI,EAAE,OAAO;gBACb,MAAM,EAAE,CAAC,0BAA0B,EAAE,mEAAmE,CAAC;aAC1G;YACD;gBACE,IAAI,EAAE,OAAO;gBACb,MAAM,EAAE,CAAC,SAAS,CAAC;aACpB;YACD;gBACE,IAAI,EAAE,aAAa;gBACnB,MAAM,EAAE,CAAC,WAAW,EAAE,YAAY,EAAE,WAAW,EAAE,SAAS,CAAC;aAC5D;SACF,CAAC;QAGF,UAAK,GAAW,EAAE,CAAC;QAGnB,aAAQ,GAAW,EAAE,CAAC;IAQtB,CAAC;IAVD,KAAK,KAAK,CAAC;IAaX,aAAa,CAAC,CAAC;QACb,CAAC,CAAC,eAAe,EAAE,CAAC;IACtB,CAAC;IAED,YAAY,CAAC,CAAC;QACZ,MAAM,KAAK,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;QAC7B,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,aAAkC,CAAC,KAAK,GAAG,IAAI,CAAC;IAClE,CAAC;IAED,IAAI;QACF,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,CAAC,EAAC,MAAM,EAAC,IAAI,CAAC,WAAW,EAAC,CAAC,CAAC;IAChE,CAAC;IACD,MAAM;QACJ,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,GAAG,EAAE,CAAA;QACvC,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;QAChB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAA;QACpB,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAA;IACtB,CAAC;IACD,eAAe;QACb,IAAI,IAAI,CAAC,OAAO,IAAI,IAAI,EAAE;SACzB;aAAM;YACL,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC;SACtC;QACD,EAAE;QACF,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,EAAE;SAC7B;aAAM;YACL,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC;SAC1C;QACD,EAAE;QACF,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ,IAAI,IAAI,CAAC,IAAI,KAAK,KAAK,EAAE;YACjD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAgB,CAAC;YACnE,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;YACzC,IAAI,CAAC,UAAU,CAAC,SAAS,GAAG;;;;;KAK7B,CAAC;YACA,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,MAAM,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC;YACrE,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,UAAU,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC;YACzE,IAAI,CAAC,UAAU,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC;YAC1E,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;SACzD;QACD,EAAE;QACF,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC;QAClD,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,UAAU,EAAE,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QAC1E,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QAC5E,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,MAAM,EAAE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IACpE,CAAC;IAEO,qBAAqB,CAAC,CAAY;QACxC,CAAC,CAAC,cAAc,EAAE,CAAC;QACnB,CAAC,CAAC,eAAe,EAAE,CAAC;QACpB,OAAO,KAAK,CAAC;IACf,CAAC;IAEO,cAAc,CAAC,CAAY;QACjC,CAAC,CAAC,cAAc,EAAE,CAAC;QACnB,CAAC,CAAC,eAAe,EAAE,CAAC;QACpB,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;QACtC,OAAO,KAAK,CAAC;IACf,CAAC;IAEO,eAAe,CAAC,CAAY;QAClC,CAAC,CAAC,cAAc,EAAE,CAAC;QACnB,CAAC,CAAC,eAAe,EAAE,CAAC;QACpB,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QACzC,OAAO,KAAK,CAAC;IACf,CAAC;IAED,UAAU,CAAC,CAAY;QACrB,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;QACxB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YACpD,MAAM,IAAI,GAAG,CAAC,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;YACrC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;SACpB;IACH,CAAC;IAEO,OAAO,CAAC,IAAU;QACxB,MAAM,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,KAAK,CAAgB,CAAC;QACrE,WAAW,CAAC,SAAS,CAAC,GAAG,CAAC,0BAA0B,CAAC,CAAC;QACtD,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,OAAO,CAAgB,CAAC;QACzE,aAAa,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC;QACpC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC;QAC1B,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;QACxD,MAAM,GAAG,GAAG,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,sBAAsB,EAAE,EAAE,QAAQ,EAAE,CAAC,EAAE,EAAE,WAAW,CAAC,CAAC,QAAkC,CAAC;QAC3I,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,WAAW,EAAE,aAAa,CAAC,CAAC;QAErD,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;QAChC,MAAM,CAAC,gBAAgB,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,EAAE;YACpC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;gBACf,IAAI;gBACJ,IAAI,EAAG,CAAS,CAAC,MAAM,CAAC,MAAM;aAC/B,CAAC,CAAC;YACH,EAAE;YACF,cAAc;YACd,IAAI,EAAE,GAAG,CAAC,CAAC;YACX,IAAI,QAAQ,GAAG,CAAC,CAAC;YACjB,MAAM,IAAI,GAAG,WAAW,CAAC,GAAG,EAAE;gBAC5B,QAAQ,IAAI,IAAI,GAAG,IAAI,CAAC;gBACxB,IAAI,QAAQ,GAAG,CAAC,CAAC,KAAK,EAAE;oBACtB,QAAQ,GAAG,CAAC,CAAC,KAAK,CAAC;iBACpB;gBACD,EAAE,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,QAAQ,GAAG,CAAC,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,CAAC;gBAC3C,GAAG,CAAC,QAAQ,GAAG,EAAE,CAAC;gBAClB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;oBACnB,IAAI;oBACJ,KAAK,EAAE,CAAC,CAAC,KAAK;oBACd,QAAQ;oBACR,KAAK,EAAE,EAAE;iBACV,CAAC,CAAC;gBACH,EAAE;gBACF,IAAI,GAAG,CAAC,QAAQ,IAAI,GAAG,EAAE;oBACvB,aAAa,CAAC,IAAI,CAAC,CAAC;oBACpB,UAAU,CAAC,GAAG,EAAE;wBACd,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;oBAC1D,CAAC,EAAE,IAAI,CAAC,CAAC;iBACV;YACH,CAAC,EAAE,GAAG,CAAC,CAAC;QACV,CAAC,CAAC,CAAC;QACH,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QAC3B,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACxB,CAAC;IAED,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,WAAW,CAAC,CAAC,MAAM,CAAC;IAC7E,CAAC;;mHA7MU,qBAAqB;uGAArB,qBAAqB,ggBCvBlC,+xBAgBA;4FDOa,qBAAqB;kBANjC,SAAS;+BACE,gBAAgB,iBAEX,iBAAiB,CAAC,IAAI,QAC/B,EAAE,KAAK,EAAE,gDAAgD,EAAE;uLAMjE,WAAW;sBADV,KAAK;gBAIN,OAAO;sBADN,KAAK;gBAIN,WAAW;sBADV,KAAK;gBAIN,KAAK;sBADJ,KAAK;gBAIN,IAAI;sBADH,KAAK;gBAGkB,SAAS;sBAAhC,SAAS;uBAAC,WAAW;gBAGtB,IAAI;sBADH,KAAK;gBAIC,QAAQ;sBADd,KAAK;gBAGG,QAAQ;sBAAhB,KAAK;gBAEN,MAAM;sBADL,MAAM;gBAIP,UAAU;sBADT,MAAM;gBAIP,QAAQ;sBADP,MAAM","sourcesContent":["import {\r\n  Component,\r\n  ViewChild,\r\n  Input,\r\n  ElementRef,\r\n  ViewEncapsulation,\r\n  TemplateRef,\r\n  Renderer2,\r\n  EventEmitter,\r\n  Output,\r\n  ChangeDetectorRef\r\n} from '@angular/core';\r\nimport { AXUploadFileLoadEvent, AXUploadFileProgressEvent } from './upload-file.events';\r\nimport { AXProgressBarComponent } from '../progress-bar/progress-bar.component';\r\nimport { AXBaseTextComponent, AXElementSize, AXBaseSizableComponent, AXBaseComponent } from '../base/element.class';\r\nimport { AXRenderService } from '@acorex/core';\r\n\r\n@Component({\r\n  selector: 'ax-upload-file',\r\n  templateUrl: './upload-file.component.html',\r\n  encapsulation: ViewEncapsulation.None,\r\n  host: { style: 'display: block; width:100%; position: relative' }\r\n})\r\nexport class AXUploadFileComponent extends AXBaseComponent implements AXBaseSizableComponent {\r\n  private overlayDiv: HTMLElement;\r\n\r\n  @Input()\r\n  contentType: 'image' | 'excel' | 'audio' | 'video' | 'video/image' = 'image';\r\n\r\n  @Input()\r\n  dropRef: HTMLElement;\r\n\r\n  @Input()\r\n  progressRef: HTMLElement;\r\n\r\n  @Input()\r\n  label: string;\r\n\r\n  @Input()\r\n  size: AXElementSize = \"md\";\r\n\r\n  @ViewChild('fileInput') fileInput: ElementRef;\r\n\r\n  @Input()\r\n  type: 'box' | 'inline' | 'hidden' = 'inline';\r\n\r\n  @Input()\r\n  public template: TemplateRef<any>;\r\n\r\n  @Input() disabled: boolean = false;\r\n  @Output()\r\n  onLoad: EventEmitter<AXUploadFileLoadEvent> = new EventEmitter<AXUploadFileLoadEvent>();\r\n\r\n  @Output()\r\n  onProgress: EventEmitter<AXUploadFileProgressEvent> = new EventEmitter<AXUploadFileProgressEvent>();\r\n\r\n  @Output()\r\n  onRemove: EventEmitter<any> = new EventEmitter();\r\n\r\n  fileTypes:any[] = [\r\n    {\r\n      type: 'image',\r\n      accept: ['image/gif', 'image/jpeg', 'image/png'],\r\n    },\r\n    {\r\n      type: 'audio',\r\n      accept: ['audio/mp3'],\r\n    },\r\n    {\r\n      type: 'ebook',\r\n      accept: ['application/pdf'],\r\n    },\r\n    {\r\n      type: 'excel',\r\n      accept: ['application/vnd.ms-excel', 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'],\r\n    },\r\n    {\r\n      type: 'video',\r\n      accept: ['video/*'],\r\n    },\r\n    {\r\n      type: 'video/image',\r\n      accept: ['image/gif', 'image/jpeg', 'image/png', 'video/*'],\r\n    },\r\n  ];\r\n\r\n\r\n  files: File[] = [];\r\n  focus() { }\r\n\r\n  fileName: string = '';\r\n  constructor(\r\n    private el: ElementRef<HTMLElement>,\r\n    private injectionService: AXRenderService,\r\n    private rendrer: Renderer2,\r\n    protected cdr: ChangeDetectorRef\r\n  ) {\r\n    super();\r\n  }\r\n\r\n\r\n  onDeleteClick(e) {\r\n    e.stopPropagation();\r\n  }\r\n\r\n  onFileChange(e) {\r\n    const files = e.target.files;\r\n    this.addFile(files[0]);\r\n    (this.fileInput.nativeElement as HTMLInputElement).value = null;\r\n  }\r\n\r\n  open() {\r\n    this.fileInput.nativeElement.click({accept:this.accessTypes});\r\n  }\r\n  remove() {\r\n    this.fileInput.nativeElement.value = ''\r\n    this.files = [];\r\n    this.fileName = null\r\n    this.onRemove.emit()\r\n  }\r\n  ngAfterViewInit(): void {\r\n    if (this.dropRef != null) {\r\n    } else {\r\n      this.dropRef = this.el.nativeElement;\r\n    }\r\n    //\r\n    if (this.progressRef != null) {\r\n    } else {\r\n      this.progressRef = this.el.nativeElement;\r\n    }\r\n    //\r\n    if (this.type === 'hidden' || this.type === 'box') {\r\n      this.overlayDiv = this.rendrer.createElement('div') as HTMLElement;\r\n      this.overlayDiv.classList.add('overlay');\r\n      this.overlayDiv.innerHTML = `\r\n      <div class=\"icon-wrapper\">\r\n        <i class=\"far fa-cloud-upload-alt fa-3x\"></i>\r\n        <span>Drop File(s) Here</span>\r\n      </div>\r\n    `;\r\n      this.overlayDiv.addEventListener('drag', this.handleOverlayDragOver);\r\n      this.overlayDiv.addEventListener('dragover', this.handleOverlayDragOver);\r\n      this.overlayDiv.addEventListener('dragleave', this.handleOverlayDragOver);\r\n      this.rendrer.appendChild(this.dropRef, this.overlayDiv);\r\n    }\r\n    //\r\n    this.dropRef.classList.add('ax-upload-drop-over');\r\n    this.dropRef.addEventListener('dragover', this.handleDragOver.bind(this));\r\n    this.dropRef.addEventListener('dragleave', this.handleDragLeave.bind(this));\r\n    this.dropRef.addEventListener('drop', this.handleDrop.bind(this));\r\n  }\r\n\r\n  private handleOverlayDragOver(e: DragEvent) {\r\n    e.preventDefault();\r\n    e.stopPropagation();\r\n    return false;\r\n  }\r\n\r\n  private handleDragOver(e: DragEvent) {\r\n    e.preventDefault();\r\n    e.stopPropagation();\r\n    this.overlayDiv.classList.add('show');\r\n    return false;\r\n  }\r\n\r\n  private handleDragLeave(e: DragEvent) {\r\n    e.preventDefault();\r\n    e.stopPropagation();\r\n    this.overlayDiv.classList.remove('show');\r\n    return false;\r\n  }\r\n\r\n  handleDrop(e: DragEvent) {\r\n    this.handleDragLeave(e);\r\n    for (let i = 0; i < e.dataTransfer.files.length; i++) {\r\n      const file = e.dataTransfer.files[i];\r\n      this.addFile(file);\r\n    }\r\n  }\r\n\r\n  private addFile(file: File) {\r\n    const progressDiv = this.rendrer.createElement('div') as HTMLElement;\r\n    progressDiv.classList.add('ax-upload-progress-panel');\r\n    const progressLabel = this.rendrer.createElement('small') as HTMLElement;\r\n    progressLabel.innerText = file.name;\r\n    this.fileName = file.name;\r\n    this.rendrer.appendChild(this.progressRef, progressDiv);\r\n    const com = this.injectionService.appendComponent(AXProgressBarComponent, { progress: 0 }, progressDiv).instance as AXProgressBarComponent;\r\n    this.rendrer.appendChild(progressDiv, progressLabel);\r\n\r\n    const reader = new FileReader();\r\n    reader.addEventListener('load', (e) => {\r\n      this.onLoad.emit({\r\n        file,\r\n        data: (e as any).target.result\r\n      });\r\n      //\r\n      // Fake Upload\r\n      let pv = 0;\r\n      let uploaded = 0;\r\n      const intv = setInterval(() => {\r\n        uploaded += 1024 * 1000;\r\n        if (uploaded > e.total) {\r\n          uploaded = e.total;\r\n        }\r\n        pv = Math.ceil((uploaded / e.total) * 100);\r\n        com.progress = pv;\r\n        this.onProgress.emit({\r\n          file,\r\n          total: e.total,\r\n          uploaded,\r\n          value: pv\r\n        });\r\n        //\r\n        if (com.progress >= 100) {\r\n          clearInterval(intv);\r\n          setTimeout(() => {\r\n            this.rendrer.removeChild(this.progressRef, progressDiv);\r\n          }, 1000);\r\n        }\r\n      }, 100);\r\n    });\r\n    reader.readAsDataURL(file);\r\n    this.files.push(file);\r\n  }\r\n\r\n  get accessTypes(): string[] {\r\n    return this.fileTypes.find((item) => item.type == this.contentType).accept;\r\n  }\r\n}\r\n","<input #fileInput type=\"file\" [accept]=\"accessTypes.join(',')\" style=\"display: none;\" (change)=\"onFileChange($event)\" />\r\n\r\n<ng-container *ngIf=\"type == 'inline'; else elseTemplate\">\r\n  <ax-form-group size=\"{{size}}\">\r\n    <ax-text-box [value]=\"fileName\" readonly=\"true\" [disabled]=\"disabled\"></ax-text-box>\r\n    <ax-button type=\"blank light\" icon=\"far fa-times\" (click)=\"remove()\" *ngIf=\"fileName\" [tabIndex]=\"-1\">\r\n    </ax-button>\r\n    <ax-button type=\"primary blank\" icon=\"far fa-upload\" (click)=\"open()\" [disabled]=\"disabled\" [tabIndex]=\"-1\">\r\n    </ax-button>\r\n  </ax-form-group>\r\n</ng-container>\r\n\r\n<ng-template #elseTemplate>\r\n  <div class=\"ax upload-file-box\" (click)=\"open()\" #dropRef>\r\n  </div>\r\n</ng-template>\r\n"]}
|
@@ -15702,11 +15702,39 @@ class AXUploadFileComponent extends AXBaseComponent {
|
|
15702
15702
|
this.injectionService = injectionService;
|
15703
15703
|
this.rendrer = rendrer;
|
15704
15704
|
this.cdr = cdr;
|
15705
|
+
this.contentType = 'image';
|
15705
15706
|
this.size = "md";
|
15706
15707
|
this.type = 'inline';
|
15707
15708
|
this.disabled = false;
|
15708
15709
|
this.onLoad = new EventEmitter();
|
15709
15710
|
this.onProgress = new EventEmitter();
|
15711
|
+
this.onRemove = new EventEmitter();
|
15712
|
+
this.fileTypes = [
|
15713
|
+
{
|
15714
|
+
type: 'image',
|
15715
|
+
accept: ['image/gif', 'image/jpeg', 'image/png'],
|
15716
|
+
},
|
15717
|
+
{
|
15718
|
+
type: 'audio',
|
15719
|
+
accept: ['audio/mp3'],
|
15720
|
+
},
|
15721
|
+
{
|
15722
|
+
type: 'ebook',
|
15723
|
+
accept: ['application/pdf'],
|
15724
|
+
},
|
15725
|
+
{
|
15726
|
+
type: 'excel',
|
15727
|
+
accept: ['application/vnd.ms-excel', 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'],
|
15728
|
+
},
|
15729
|
+
{
|
15730
|
+
type: 'video',
|
15731
|
+
accept: ['video/*'],
|
15732
|
+
},
|
15733
|
+
{
|
15734
|
+
type: 'video/image',
|
15735
|
+
accept: ['image/gif', 'image/jpeg', 'image/png', 'video/*'],
|
15736
|
+
},
|
15737
|
+
];
|
15710
15738
|
this.files = [];
|
15711
15739
|
this.fileName = '';
|
15712
15740
|
}
|
@@ -15720,10 +15748,13 @@ class AXUploadFileComponent extends AXBaseComponent {
|
|
15720
15748
|
this.fileInput.nativeElement.value = null;
|
15721
15749
|
}
|
15722
15750
|
open() {
|
15723
|
-
this.fileInput.nativeElement.click();
|
15751
|
+
this.fileInput.nativeElement.click({ accept: this.accessTypes });
|
15724
15752
|
}
|
15725
15753
|
remove() {
|
15754
|
+
this.fileInput.nativeElement.value = '';
|
15726
15755
|
this.files = [];
|
15756
|
+
this.fileName = null;
|
15757
|
+
this.onRemove.emit();
|
15727
15758
|
}
|
15728
15759
|
ngAfterViewInit() {
|
15729
15760
|
if (this.dropRef != null) {
|
@@ -15826,13 +15857,18 @@ class AXUploadFileComponent extends AXBaseComponent {
|
|
15826
15857
|
reader.readAsDataURL(file);
|
15827
15858
|
this.files.push(file);
|
15828
15859
|
}
|
15860
|
+
get accessTypes() {
|
15861
|
+
return this.fileTypes.find((item) => item.type == this.contentType).accept;
|
15862
|
+
}
|
15829
15863
|
}
|
15830
15864
|
AXUploadFileComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXUploadFileComponent, deps: [{ token: i0.ElementRef }, { token: i1$2.AXRenderService }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
15831
|
-
AXUploadFileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: AXUploadFileComponent, selector: "ax-upload-file", inputs: { dropRef: "dropRef", progressRef: "progressRef", label: "label", size: "size", type: "type", template: "template", disabled: "disabled" }, outputs: { onLoad: "onLoad", onProgress: "onProgress" }, host: { styleAttribute: "display: block; width:100%; position: relative" }, viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<input #fileInput type=\"file\" accept=\"
|
15865
|
+
AXUploadFileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.11", type: AXUploadFileComponent, selector: "ax-upload-file", inputs: { contentType: "contentType", dropRef: "dropRef", progressRef: "progressRef", label: "label", size: "size", type: "type", template: "template", disabled: "disabled" }, outputs: { onLoad: "onLoad", onProgress: "onProgress", onRemove: "onRemove" }, host: { styleAttribute: "display: block; width:100%; position: relative" }, viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<input #fileInput type=\"file\" [accept]=\"accessTypes.join(',')\" style=\"display: none;\" (change)=\"onFileChange($event)\" />\r\n\r\n<ng-container *ngIf=\"type == 'inline'; else elseTemplate\">\r\n <ax-form-group size=\"{{size}}\">\r\n <ax-text-box [value]=\"fileName\" readonly=\"true\" [disabled]=\"disabled\"></ax-text-box>\r\n <ax-button type=\"blank light\" icon=\"far fa-times\" (click)=\"remove()\" *ngIf=\"fileName\" [tabIndex]=\"-1\">\r\n </ax-button>\r\n <ax-button type=\"primary blank\" icon=\"far fa-upload\" (click)=\"open()\" [disabled]=\"disabled\" [tabIndex]=\"-1\">\r\n </ax-button>\r\n </ax-form-group>\r\n</ng-container>\r\n\r\n<ng-template #elseTemplate>\r\n <div class=\"ax upload-file-box\" (click)=\"open()\" #dropRef>\r\n </div>\r\n</ng-template>\r\n", components: [{ type: AXFormGroupComponent, selector: "ax-form-group", inputs: ["size"] }, { type: AXTextBoxComponent, selector: "ax-text-box", inputs: ["mask", "type", "showMask", "maxLength", "maskGuid", "maskPlaceholder", "maskKeepCharPositions"] }, { type: AXButtonComponent, selector: "ax-button", inputs: ["type", "icon", "submitBehavior", "cancelBehavior", "block", "loading", "selected"] }], directives: [{ type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], encapsulation: i0.ViewEncapsulation.None });
|
15832
15866
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImport: i0, type: AXUploadFileComponent, decorators: [{
|
15833
15867
|
type: Component,
|
15834
|
-
args: [{ selector: 'ax-upload-file', encapsulation: ViewEncapsulation.None, host: { style: 'display: block; width:100%; position: relative' }, template: "<input #fileInput type=\"file\" accept=\"
|
15835
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1$2.AXRenderService }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }]; }, propDecorators: {
|
15868
|
+
args: [{ selector: 'ax-upload-file', encapsulation: ViewEncapsulation.None, host: { style: 'display: block; width:100%; position: relative' }, template: "<input #fileInput type=\"file\" [accept]=\"accessTypes.join(',')\" style=\"display: none;\" (change)=\"onFileChange($event)\" />\r\n\r\n<ng-container *ngIf=\"type == 'inline'; else elseTemplate\">\r\n <ax-form-group size=\"{{size}}\">\r\n <ax-text-box [value]=\"fileName\" readonly=\"true\" [disabled]=\"disabled\"></ax-text-box>\r\n <ax-button type=\"blank light\" icon=\"far fa-times\" (click)=\"remove()\" *ngIf=\"fileName\" [tabIndex]=\"-1\">\r\n </ax-button>\r\n <ax-button type=\"primary blank\" icon=\"far fa-upload\" (click)=\"open()\" [disabled]=\"disabled\" [tabIndex]=\"-1\">\r\n </ax-button>\r\n </ax-form-group>\r\n</ng-container>\r\n\r\n<ng-template #elseTemplate>\r\n <div class=\"ax upload-file-box\" (click)=\"open()\" #dropRef>\r\n </div>\r\n</ng-template>\r\n" }]
|
15869
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1$2.AXRenderService }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { contentType: [{
|
15870
|
+
type: Input
|
15871
|
+
}], dropRef: [{
|
15836
15872
|
type: Input
|
15837
15873
|
}], progressRef: [{
|
15838
15874
|
type: Input
|
@@ -15853,6 +15889,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
15853
15889
|
type: Output
|
15854
15890
|
}], onProgress: [{
|
15855
15891
|
type: Output
|
15892
|
+
}], onRemove: [{
|
15893
|
+
type: Output
|
15856
15894
|
}] } });
|
15857
15895
|
|
15858
15896
|
class AXUploadFileModule {
|