@acorex/components 16.0.8 → 16.0.10

Sign up to get free protection for your applications and to get access to all the features.
@@ -1,24 +1,27 @@
1
- import { Component, ViewChild, Input, ElementRef, ViewEncapsulation, TemplateRef, Renderer2, EventEmitter, Output, ChangeDetectorRef } from '@angular/core';
1
+ import { AXRenderService, AXTranslator } from '@acorex/core';
2
+ import { ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, Renderer2, TemplateRef, ViewChild, ViewEncapsulation, } from '@angular/core';
3
+ import { AXBaseComponent, } from '../base/element.class';
2
4
  import { AXProgressBarComponent } from '../progress-bar/progress-bar.component';
3
- import { AXBaseComponent } from '../base/element.class';
4
- import { AXRenderService } from '@acorex/core';
5
+ import { AXToastService } from '../toast/toast.service';
5
6
  import * as i0 from "@angular/core";
6
7
  import * as i1 from "@acorex/core";
7
- import * as i2 from "@angular/common";
8
- import * as i3 from "../button/button.component";
9
- import * as i4 from "../textbox/textbox.component";
10
- import * as i5 from "../form-group/form-group.component";
8
+ import * as i2 from "../toast/toast.service";
9
+ import * as i3 from "@angular/common";
10
+ import * as i4 from "../button/button.component";
11
+ import * as i5 from "../textbox/textbox.component";
12
+ import * as i6 from "../form-group/form-group.component";
11
13
  export class AXUploadFileComponent extends AXBaseComponent {
12
14
  el;
13
15
  injectionService;
14
16
  rendrer;
15
17
  cdr;
18
+ toastService;
16
19
  overlayDiv;
17
20
  contentType = 'image';
18
21
  dropRef;
19
22
  progressRef;
20
23
  label;
21
- size = "md";
24
+ size = 'md';
22
25
  fileInput;
23
26
  type = 'inline';
24
27
  template;
@@ -30,45 +33,60 @@ export class AXUploadFileComponent extends AXBaseComponent {
30
33
  {
31
34
  type: 'image',
32
35
  accept: ['image/gif', 'image/jpeg', 'image/png'],
36
+ message: 'عکس',
33
37
  },
34
38
  {
35
39
  type: 'audio',
36
40
  accept: ['audio/mp3'],
41
+ message: 'audio',
37
42
  },
38
43
  {
39
44
  type: 'ebook',
40
45
  accept: ['application/pdf'],
46
+ message: 'pdf',
41
47
  },
42
48
  {
43
49
  type: 'excel',
44
- accept: ['application/vnd.ms-excel', 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'],
50
+ accept: [
51
+ 'application/vnd.ms-excel',
52
+ 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
53
+ 'application/vnd.ms-excel.sheet.macroEnabled.12',
54
+ 'application/vnd.oasis.opendocument.spreadsheet',
55
+ 'text/csv',
56
+ ],
57
+ message: 'اکسل',
45
58
  },
46
59
  {
47
60
  type: 'video',
48
61
  accept: ['video/*'],
62
+ message: 'video',
49
63
  },
50
64
  {
51
65
  type: 'video/image',
52
66
  accept: ['image/gif', 'image/jpeg', 'image/png', 'video/*'],
67
+ message: 'video/image',
53
68
  },
54
69
  {
55
70
  type: 'json',
56
71
  accept: ['application/json'],
72
+ message: 'json',
57
73
  },
58
74
  {
59
75
  type: 'any',
60
76
  accept: ['*/*'],
77
+ message: '',
61
78
  },
62
79
  ];
63
80
  files = [];
64
81
  focus() { }
65
82
  fileName = '';
66
- constructor(el, injectionService, rendrer, cdr) {
83
+ constructor(el, injectionService, rendrer, cdr, toastService) {
67
84
  super();
68
85
  this.el = el;
69
86
  this.injectionService = injectionService;
70
87
  this.rendrer = rendrer;
71
88
  this.cdr = cdr;
89
+ this.toastService = toastService;
72
90
  }
73
91
  onDeleteClick(e) {
74
92
  e.stopPropagation();
@@ -91,31 +109,24 @@ export class AXUploadFileComponent extends AXBaseComponent {
91
109
  if (this.dropRef != null) {
92
110
  }
93
111
  else {
94
- this.dropRef = this.el.nativeElement;
112
+ this.dropRef = this.el.nativeElement.querySelector('.upload-file-box');
95
113
  }
96
114
  //
97
115
  if (this.progressRef != null) {
98
116
  }
99
117
  else {
100
- this.progressRef = this.el.nativeElement;
118
+ this.progressRef =
119
+ this.el.nativeElement.querySelector('.upload-file-box');
101
120
  }
102
121
  //
103
122
  if (this.type === 'hidden' || this.type === 'box') {
104
- this.overlayDiv = this.rendrer.createElement('div');
105
- this.overlayDiv.classList.add('overlay');
106
- this.overlayDiv.innerHTML = `
107
- <div class="icon-wrapper">
108
- <i class="far fa-cloud-upload-alt fa-3x"></i>
109
- <span>Drop File(s) Here</span>
110
- </div>
111
- `;
123
+ this.handleShowEmptyFile();
112
124
  this.overlayDiv.addEventListener('drag', this.handleOverlayDragOver);
113
125
  this.overlayDiv.addEventListener('dragover', this.handleOverlayDragOver);
114
126
  this.overlayDiv.addEventListener('dragleave', this.handleOverlayDragOver);
115
- this.rendrer.appendChild(this.dropRef, this.overlayDiv);
116
127
  }
117
128
  //
118
- this.dropRef.classList.add('ax-upload-drop-over');
129
+ // this.dropRef.classList.add('ax-upload-drop-over');
119
130
  this.dropRef.addEventListener('dragover', this.handleDragOver.bind(this));
120
131
  this.dropRef.addEventListener('dragleave', this.handleDragLeave.bind(this));
121
132
  this.dropRef.addEventListener('drop', this.handleDrop.bind(this));
@@ -145,6 +156,14 @@ export class AXUploadFileComponent extends AXBaseComponent {
145
156
  }
146
157
  }
147
158
  addFile(file) {
159
+ if (this.contentType &&
160
+ this.contentType !== 'any' &&
161
+ !this.fileTypes
162
+ .find((x) => x.type === this.contentType)
163
+ .accept.includes(file.type)) {
164
+ this.toastService.info(`فایل بارگذاری باید از نوع ${this.fileTypes.find((x) => x.type === this.contentType).message} باشد`);
165
+ return;
166
+ }
148
167
  const progressDiv = this.rendrer.createElement('div');
149
168
  progressDiv.classList.add('ax-upload-progress-panel');
150
169
  const progressLabel = this.rendrer.createElement('small');
@@ -157,7 +176,7 @@ export class AXUploadFileComponent extends AXBaseComponent {
157
176
  reader.addEventListener('load', (e) => {
158
177
  this.onLoad.emit({
159
178
  file,
160
- data: e.target.result
179
+ data: e.target.result,
161
180
  });
162
181
  //
163
182
  // Fake Upload
@@ -174,13 +193,41 @@ export class AXUploadFileComponent extends AXBaseComponent {
174
193
  file,
175
194
  total: e.total,
176
195
  uploaded,
177
- value: pv
196
+ value: pv,
178
197
  });
179
198
  //
180
199
  if (com.progress >= 100) {
181
200
  clearInterval(intv);
182
201
  setTimeout(() => {
183
202
  this.rendrer.removeChild(this.progressRef, progressDiv);
203
+ if (this.fileName) {
204
+ this.rendrer.removeChild(this.dropRef, this.overlayDiv);
205
+ this.overlayDiv = this.rendrer.createElement('div');
206
+ this.overlayDiv.classList.add('overlay');
207
+ this.overlayDiv.innerHTML = `
208
+ <div
209
+ style="
210
+ display: flex;
211
+ flex-direction: column;
212
+ align-items: center;
213
+ justify-content: center;
214
+ gap: 8px;
215
+ "
216
+ >
217
+ <i style="color: var(--ax-danger-color)" class="far fa-times fa-3x"></i>
218
+ <span>${this.fileName}</span>
219
+ </div>
220
+
221
+ `;
222
+ const closeIcon = this.overlayDiv.querySelector('.far.fa-times');
223
+ this.rendrer.listen(closeIcon, 'click', (e) => {
224
+ this.remove();
225
+ this.rendrer.removeChild(this.dropRef, this.overlayDiv);
226
+ this.handleShowEmptyFile();
227
+ e.stopPropagation();
228
+ });
229
+ this.rendrer.appendChild(this.dropRef, this.overlayDiv);
230
+ }
184
231
  }, 1000);
185
232
  }
186
233
  }, 100);
@@ -191,13 +238,31 @@ export class AXUploadFileComponent extends AXBaseComponent {
191
238
  get accessTypes() {
192
239
  return this.fileTypes.find((item) => item.type == this.contentType).accept;
193
240
  }
194
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AXUploadFileComponent, deps: [{ token: i0.ElementRef }, { token: i1.AXRenderService }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
195
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", 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)\" />\n\n<ng-container *ngIf=\"type == 'inline'; else elseTemplate\">\n <ax-form-group size=\"{{size}}\">\n <ax-text-box [value]=\"fileName\" readonly=\"true\" [disabled]=\"disabled\"></ax-text-box>\n <ax-button type=\"blank light\" icon=\"far fa-times\" (click)=\"remove()\" *ngIf=\"fileName\" [tabIndex]=\"-1\">\n </ax-button>\n <ax-button type=\"primary blank\" icon=\"far fa-upload\" (click)=\"open()\" [disabled]=\"disabled\" [tabIndex]=\"-1\">\n </ax-button>\n </ax-form-group>\n</ng-container>\n\n<ng-template #elseTemplate>\n <div class=\"ax upload-file-box\" (click)=\"open()\" #dropRef>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.AXButtonComponent, selector: "ax-button", inputs: ["type", "icon", "submitBehavior", "cancelBehavior", "block", "loading", "selected"] }, { kind: "component", type: i4.AXTextBoxComponent, selector: "ax-text-box", inputs: ["mask", "showMask", "type", "maxLength", "maskGuid", "maskPlaceholder", "maskKeepCharPositions"] }, { kind: "component", type: i5.AXFormGroupComponent, selector: "ax-form-group", inputs: ["size"] }], encapsulation: i0.ViewEncapsulation.None });
241
+ handleShowEmptyFile() {
242
+ this.overlayDiv = this.rendrer.createElement('div');
243
+ this.overlayDiv.classList.add('overlay');
244
+ this.overlayDiv.innerHTML = `
245
+ <div style="
246
+ display: flex;
247
+ flex-direction: column;
248
+ align-items: center;
249
+ justify-content: center;
250
+ gap: 8px;
251
+ ">
252
+ <i class="far fa-cloud-upload-alt fa-3x"></i>
253
+ <span>${AXTranslator.get('common.upload')}</span>
254
+ </div>
255
+ `;
256
+ this.rendrer.appendChild(this.dropRef, this.overlayDiv);
257
+ this.dropRef.classList.add('ax-upload-drop-over');
258
+ }
259
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AXUploadFileComponent, deps: [{ token: i0.ElementRef }, { token: i1.AXRenderService }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: i2.AXToastService }], target: i0.ɵɵFactoryTarget.Component });
260
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", 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\n #fileInput\n type=\"file\"\n [accept]=\"accessTypes.join(',')\"\n style=\"display: none\"\n (change)=\"onFileChange($event)\"\n/>\n\n<ng-container *ngIf=\"type == 'inline'; else elseTemplate\">\n <ax-form-group size=\"{{ size }}\">\n <ax-text-box\n [value]=\"fileName\"\n readonly=\"true\"\n [disabled]=\"disabled\"\n ></ax-text-box>\n <ax-button\n type=\"blank light\"\n icon=\"far fa-times\"\n (click)=\"remove()\"\n *ngIf=\"fileName\"\n [tabIndex]=\"-1\"\n >\n </ax-button>\n <ax-button\n type=\"primary blank\"\n icon=\"far fa-upload\"\n (click)=\"open()\"\n [disabled]=\"disabled\"\n [tabIndex]=\"-1\"\n >\n </ax-button>\n </ax-form-group>\n</ng-container>\n\n<ng-template #elseTemplate>\n <div class=\"ax upload-file-box\" (click)=\"open()\" #dropRef></div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.AXButtonComponent, selector: "ax-button", inputs: ["type", "icon", "submitBehavior", "cancelBehavior", "block", "loading", "selected"] }, { kind: "component", type: i5.AXTextBoxComponent, selector: "ax-text-box", inputs: ["mask", "showMask", "type", "maxLength", "maskGuid", "maskPlaceholder", "maskKeepCharPositions"] }, { kind: "component", type: i6.AXFormGroupComponent, selector: "ax-form-group", inputs: ["size"] }], encapsulation: i0.ViewEncapsulation.None });
196
261
  }
197
262
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AXUploadFileComponent, decorators: [{
198
263
  type: Component,
199
- 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)\" />\n\n<ng-container *ngIf=\"type == 'inline'; else elseTemplate\">\n <ax-form-group size=\"{{size}}\">\n <ax-text-box [value]=\"fileName\" readonly=\"true\" [disabled]=\"disabled\"></ax-text-box>\n <ax-button type=\"blank light\" icon=\"far fa-times\" (click)=\"remove()\" *ngIf=\"fileName\" [tabIndex]=\"-1\">\n </ax-button>\n <ax-button type=\"primary blank\" icon=\"far fa-upload\" (click)=\"open()\" [disabled]=\"disabled\" [tabIndex]=\"-1\">\n </ax-button>\n </ax-form-group>\n</ng-container>\n\n<ng-template #elseTemplate>\n <div class=\"ax upload-file-box\" (click)=\"open()\" #dropRef>\n </div>\n</ng-template>\n" }]
200
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.AXRenderService }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { contentType: [{
264
+ args: [{ selector: 'ax-upload-file', encapsulation: ViewEncapsulation.None, host: { style: 'display: block; width:100%; position: relative' }, template: "<input\n #fileInput\n type=\"file\"\n [accept]=\"accessTypes.join(',')\"\n style=\"display: none\"\n (change)=\"onFileChange($event)\"\n/>\n\n<ng-container *ngIf=\"type == 'inline'; else elseTemplate\">\n <ax-form-group size=\"{{ size }}\">\n <ax-text-box\n [value]=\"fileName\"\n readonly=\"true\"\n [disabled]=\"disabled\"\n ></ax-text-box>\n <ax-button\n type=\"blank light\"\n icon=\"far fa-times\"\n (click)=\"remove()\"\n *ngIf=\"fileName\"\n [tabIndex]=\"-1\"\n >\n </ax-button>\n <ax-button\n type=\"primary blank\"\n icon=\"far fa-upload\"\n (click)=\"open()\"\n [disabled]=\"disabled\"\n [tabIndex]=\"-1\"\n >\n </ax-button>\n </ax-form-group>\n</ng-container>\n\n<ng-template #elseTemplate>\n <div class=\"ax upload-file-box\" (click)=\"open()\" #dropRef></div>\n</ng-template>\n" }]
265
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.AXRenderService }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: i2.AXToastService }]; }, propDecorators: { contentType: [{
201
266
  type: Input
202
267
  }], dropRef: [{
203
268
  type: Input
@@ -223,4 +288,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
223
288
  }], onRemove: [{
224
289
  type: Output
225
290
  }] } });
226
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload-file.component.js","sourceRoot":"","sources":["../../../../../../libs/components/src/lib/upload-file/upload-file.component.ts","../../../../../../libs/components/src/lib/upload-file/upload-file.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ViewChild,\n  Input,\n  ElementRef,\n  ViewEncapsulation,\n  TemplateRef,\n  Renderer2,\n  EventEmitter,\n  Output,\n  ChangeDetectorRef\n} from '@angular/core';\nimport { AXUploadFileLoadEvent, AXUploadFileProgressEvent } from './upload-file.events';\nimport { AXProgressBarComponent } from '../progress-bar/progress-bar.component';\nimport { AXBaseTextComponent, AXElementSize, AXBaseSizableComponent, AXBaseComponent } from '../base/element.class';\nimport { AXRenderService } from '@acorex/core';\n\n@Component({\n  selector: 'ax-upload-file',\n  templateUrl: './upload-file.component.html',\n  encapsulation: ViewEncapsulation.None,\n  host: { style: 'display: block; width:100%; position: relative' }\n})\nexport class AXUploadFileComponent extends AXBaseComponent implements AXBaseSizableComponent {\n  private overlayDiv: HTMLElement;\n\n  @Input()\n  contentType: 'image' | 'excel' | 'audio' | 'video' | 'video/image' | 'any' | 'json' = 'image';\n\n  @Input()\n  dropRef: HTMLElement;\n\n  @Input()\n  progressRef: HTMLElement;\n\n  @Input()\n  label: string;\n\n  @Input()\n  size: AXElementSize = \"md\";\n\n  @ViewChild('fileInput') fileInput: ElementRef;\n\n  @Input()\n  type: 'box' | 'inline' | 'hidden' = 'inline';\n\n  @Input()\n  public template: TemplateRef<any>;\n\n  @Input() disabled: boolean = false;\n  @Output()\n  onLoad: EventEmitter<AXUploadFileLoadEvent> = new EventEmitter<AXUploadFileLoadEvent>();\n\n  @Output()\n  onProgress: EventEmitter<AXUploadFileProgressEvent> = new EventEmitter<AXUploadFileProgressEvent>();\n\n  @Output()\n  onRemove: EventEmitter<any> = new EventEmitter();\n\n  fileTypes: any[] = [\n    {\n      type: 'image',\n      accept: ['image/gif', 'image/jpeg', 'image/png'],\n    },\n    {\n      type: 'audio',\n      accept: ['audio/mp3'],\n    },\n    {\n      type: 'ebook',\n      accept: ['application/pdf'],\n    },\n    {\n      type: 'excel',\n      accept: ['application/vnd.ms-excel', 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'],\n    },\n    {\n      type: 'video',\n      accept: ['video/*'],\n    },\n    {\n      type: 'video/image',\n      accept: ['image/gif', 'image/jpeg', 'image/png', 'video/*'],\n    },\n    {\n      type: 'json',\n      accept: ['application/json'],\n    },\n    {\n      type: 'any',\n      accept: ['*/*'],\n    },\n  ];\n\n\n\n  files: File[] = [];\n  focus() { }\n\n  fileName: string = '';\n  constructor(\n    private el: ElementRef<HTMLElement>,\n    private injectionService: AXRenderService,\n    private rendrer: Renderer2,\n    protected cdr: ChangeDetectorRef\n  ) {\n    super();\n  }\n\n\n  onDeleteClick(e) {\n    e.stopPropagation();\n  }\n\n  onFileChange(e) {\n    const files = e.target.files;\n    this.addFile(files[0]);\n    (this.fileInput.nativeElement as HTMLInputElement).value = null;\n  }\n\n  open() {\n    this.fileInput.nativeElement.click({ accept: this.accessTypes });\n  }\n  remove() {\n    this.fileInput.nativeElement.value = ''\n    this.files = [];\n    this.fileName = null\n    this.onRemove.emit()\n  }\n  ngAfterViewInit(): void {\n    if (this.dropRef != null) {\n    } else {\n      this.dropRef = this.el.nativeElement;\n    }\n    //\n    if (this.progressRef != null) {\n    } else {\n      this.progressRef = this.el.nativeElement;\n    }\n    //\n    if (this.type === 'hidden' || this.type === 'box') {\n      this.overlayDiv = this.rendrer.createElement('div') as HTMLElement;\n      this.overlayDiv.classList.add('overlay');\n      this.overlayDiv.innerHTML = `\n      <div class=\"icon-wrapper\">\n        <i class=\"far fa-cloud-upload-alt fa-3x\"></i>\n        <span>Drop File(s) Here</span>\n      </div>\n    `;\n      this.overlayDiv.addEventListener('drag', this.handleOverlayDragOver);\n      this.overlayDiv.addEventListener('dragover', this.handleOverlayDragOver);\n      this.overlayDiv.addEventListener('dragleave', this.handleOverlayDragOver);\n      this.rendrer.appendChild(this.dropRef, this.overlayDiv);\n    }\n    //\n    this.dropRef.classList.add('ax-upload-drop-over');\n    this.dropRef.addEventListener('dragover', this.handleDragOver.bind(this));\n    this.dropRef.addEventListener('dragleave', this.handleDragLeave.bind(this));\n    this.dropRef.addEventListener('drop', this.handleDrop.bind(this));\n  }\n\n  private handleOverlayDragOver(e: DragEvent) {\n    e.preventDefault();\n    e.stopPropagation();\n    return false;\n  }\n\n  private handleDragOver(e: DragEvent) {\n    e.preventDefault();\n    e.stopPropagation();\n    this.overlayDiv.classList.add('show');\n    return false;\n  }\n\n  private handleDragLeave(e: DragEvent) {\n    e.preventDefault();\n    e.stopPropagation();\n    this.overlayDiv.classList.remove('show');\n    return false;\n  }\n\n  handleDrop(e: DragEvent) {\n    this.handleDragLeave(e);\n    for (let i = 0; i < e.dataTransfer.files.length; i++) {\n      const file = e.dataTransfer.files[i];\n      this.addFile(file);\n    }\n  }\n\n  private addFile(file: File) {\n    const progressDiv = this.rendrer.createElement('div') as HTMLElement;\n    progressDiv.classList.add('ax-upload-progress-panel');\n    const progressLabel = this.rendrer.createElement('small') as HTMLElement;\n    progressLabel.innerText = file.name;\n    this.fileName = file.name;\n    this.rendrer.appendChild(this.progressRef, progressDiv);\n    const com = this.injectionService.appendComponent(AXProgressBarComponent, { progress: 0 }, progressDiv).instance as AXProgressBarComponent;\n    this.rendrer.appendChild(progressDiv, progressLabel);\n\n    const reader = new FileReader();\n    reader.addEventListener('load', (e) => {\n      this.onLoad.emit({\n        file,\n        data: (e as any).target.result\n      });\n      //\n      // Fake Upload\n      let pv = 0;\n      let uploaded = 0;\n      const intv = setInterval(() => {\n        uploaded += 1024 * 1000;\n        if (uploaded > e.total) {\n          uploaded = e.total;\n        }\n        pv = Math.ceil((uploaded / e.total) * 100);\n        com.progress = pv;\n        this.onProgress.emit({\n          file,\n          total: e.total,\n          uploaded,\n          value: pv\n        });\n        //\n        if (com.progress >= 100) {\n          clearInterval(intv);\n          setTimeout(() => {\n            this.rendrer.removeChild(this.progressRef, progressDiv);\n          }, 1000);\n        }\n      }, 100);\n    });\n    reader.readAsDataURL(file);\n    this.files.push(file);\n  }\n\n  get accessTypes(): string[] {\n    return this.fileTypes.find((item) => item.type == this.contentType).accept;\n  }\n}\n","<input #fileInput type=\"file\" [accept]=\"accessTypes.join(',')\" style=\"display: none;\" (change)=\"onFileChange($event)\" />\n\n<ng-container *ngIf=\"type == 'inline'; else elseTemplate\">\n  <ax-form-group size=\"{{size}}\">\n    <ax-text-box [value]=\"fileName\" readonly=\"true\" [disabled]=\"disabled\"></ax-text-box>\n    <ax-button type=\"blank light\" icon=\"far fa-times\" (click)=\"remove()\" *ngIf=\"fileName\" [tabIndex]=\"-1\">\n    </ax-button>\n    <ax-button type=\"primary blank\" icon=\"far fa-upload\" (click)=\"open()\" [disabled]=\"disabled\" [tabIndex]=\"-1\">\n    </ax-button>\n  </ax-form-group>\n</ng-container>\n\n<ng-template #elseTemplate>\n  <div class=\"ax upload-file-box\" (click)=\"open()\" #dropRef>\n  </div>\n</ng-template>\n"]}
291
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload-file.component.js","sourceRoot":"","sources":["../../../../../../libs/components/src/lib/upload-file/upload-file.component.ts","../../../../../../libs/components/src/lib/upload-file/upload-file.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXRenderService, AXTranslator } from '@acorex/core';\nimport {\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  Renderer2,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  AXBaseComponent,\n  AXBaseSizableComponent,\n  AXElementSize,\n} from '../base/element.class';\nimport { AXProgressBarComponent } from '../progress-bar/progress-bar.component';\nimport { AXToastService } from '../toast/toast.service';\nimport {\n  AXUploadFileLoadEvent,\n  AXUploadFileProgressEvent,\n} from './upload-file.events';\n\n@Component({\n  selector: 'ax-upload-file',\n  templateUrl: './upload-file.component.html',\n  encapsulation: ViewEncapsulation.None,\n  host: { style: 'display: block; width:100%; position: relative' },\n})\nexport class AXUploadFileComponent\n  extends AXBaseComponent\n  implements AXBaseSizableComponent\n{\n  private overlayDiv: HTMLElement;\n\n  @Input()\n  contentType:\n    | 'image'\n    | 'excel'\n    | 'audio'\n    | 'video'\n    | 'video/image'\n    | 'any'\n    | 'json' = 'image';\n\n  @Input()\n  dropRef: HTMLElement;\n\n  @Input()\n  progressRef: HTMLElement;\n\n  @Input()\n  label: string;\n\n  @Input()\n  size: AXElementSize = 'md';\n\n  @ViewChild('fileInput') fileInput: ElementRef;\n\n  @Input()\n  type: 'box' | 'inline' | 'hidden' = 'inline';\n\n  @Input()\n  public template: TemplateRef<any>;\n\n  @Input() disabled: boolean = false;\n  @Output()\n  onLoad: EventEmitter<AXUploadFileLoadEvent> =\n    new EventEmitter<AXUploadFileLoadEvent>();\n\n  @Output()\n  onProgress: EventEmitter<AXUploadFileProgressEvent> =\n    new EventEmitter<AXUploadFileProgressEvent>();\n\n  @Output()\n  onRemove: EventEmitter<any> = new EventEmitter();\n\n  fileTypes: any[] = [\n    {\n      type: 'image',\n      accept: ['image/gif', 'image/jpeg', 'image/png'],\n      message: 'عکس',\n    },\n    {\n      type: 'audio',\n      accept: ['audio/mp3'],\n      message: 'audio',\n    },\n    {\n      type: 'ebook',\n      accept: ['application/pdf'],\n      message: 'pdf',\n    },\n    {\n      type: 'excel',\n      accept: [\n        'application/vnd.ms-excel',\n        'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',\n        'application/vnd.ms-excel.sheet.macroEnabled.12',\n        'application/vnd.oasis.opendocument.spreadsheet',\n        'text/csv',\n      ],\n      message: 'اکسل',\n    },\n    {\n      type: 'video',\n      accept: ['video/*'],\n      message: 'video',\n    },\n    {\n      type: 'video/image',\n      accept: ['image/gif', 'image/jpeg', 'image/png', 'video/*'],\n      message: 'video/image',\n    },\n    {\n      type: 'json',\n      accept: ['application/json'],\n      message: 'json',\n    },\n    {\n      type: 'any',\n      accept: ['*/*'],\n      message: '',\n    },\n  ];\n\n  files: File[] = [];\n  focus() {}\n\n  fileName: string = '';\n  constructor(\n    private el: ElementRef<HTMLElement>,\n    private injectionService: AXRenderService,\n    private rendrer: Renderer2,\n    protected cdr: ChangeDetectorRef,\n    private toastService: AXToastService\n  ) {\n    super();\n  }\n\n  onDeleteClick(e) {\n    e.stopPropagation();\n  }\n\n  onFileChange(e) {\n    const files = e.target.files;\n    this.addFile(files[0]);\n    (this.fileInput.nativeElement as HTMLInputElement).value = null;\n  }\n\n  open() {\n    this.fileInput.nativeElement.click({ accept: this.accessTypes });\n  }\n  remove() {\n    this.fileInput.nativeElement.value = '';\n    this.files = [];\n    this.fileName = null;\n    this.onRemove.emit();\n  }\n  ngAfterViewInit(): void {\n    if (this.dropRef != null) {\n    } else {\n      this.dropRef = this.el.nativeElement.querySelector('.upload-file-box');\n    }\n    //\n    if (this.progressRef != null) {\n    } else {\n      this.progressRef =\n        this.el.nativeElement.querySelector('.upload-file-box');\n    }\n    //\n    if (this.type === 'hidden' || this.type === 'box') {\n      this.handleShowEmptyFile();\n      this.overlayDiv.addEventListener('drag', this.handleOverlayDragOver);\n      this.overlayDiv.addEventListener('dragover', this.handleOverlayDragOver);\n      this.overlayDiv.addEventListener('dragleave', this.handleOverlayDragOver);\n    }\n    //\n    // this.dropRef.classList.add('ax-upload-drop-over');\n    this.dropRef.addEventListener('dragover', this.handleDragOver.bind(this));\n    this.dropRef.addEventListener('dragleave', this.handleDragLeave.bind(this));\n    this.dropRef.addEventListener('drop', this.handleDrop.bind(this));\n  }\n\n  private handleOverlayDragOver(e: DragEvent) {\n    e.preventDefault();\n    e.stopPropagation();\n    return false;\n  }\n\n  private handleDragOver(e: DragEvent) {\n    e.preventDefault();\n    e.stopPropagation();\n    this.overlayDiv.classList.add('show');\n    return false;\n  }\n\n  private handleDragLeave(e: DragEvent) {\n    e.preventDefault();\n    e.stopPropagation();\n    this.overlayDiv.classList.remove('show');\n    return false;\n  }\n\n  handleDrop(e: DragEvent) {\n    this.handleDragLeave(e);\n    for (let i = 0; i < e.dataTransfer.files.length; i++) {\n      const file = e.dataTransfer.files[i];\n      this.addFile(file);\n    }\n  }\n\n  private addFile(file: File) {\n    if (\n      this.contentType &&\n      this.contentType !== 'any' &&\n      !this.fileTypes\n        .find((x) => x.type === this.contentType)\n        .accept.includes(file.type)\n    ) {\n      this.toastService.info(\n        `فایل بارگذاری باید از نوع ${\n          this.fileTypes.find((x) => x.type === this.contentType).message\n        } باشد`\n      );\n      return;\n    }\n\n    const progressDiv = this.rendrer.createElement('div') as HTMLElement;\n    progressDiv.classList.add('ax-upload-progress-panel');\n    const progressLabel = this.rendrer.createElement('small') as HTMLElement;\n    progressLabel.innerText = file.name;\n    this.fileName = file.name;\n    this.rendrer.appendChild(this.progressRef, progressDiv);\n    const com = this.injectionService.appendComponent(\n      AXProgressBarComponent,\n      { progress: 0 },\n      progressDiv\n    ).instance as AXProgressBarComponent;\n    this.rendrer.appendChild(progressDiv, progressLabel);\n\n    const reader = new FileReader();\n    reader.addEventListener('load', (e) => {\n      this.onLoad.emit({\n        file,\n        data: (e as any).target.result,\n      });\n      //\n      // Fake Upload\n      let pv = 0;\n      let uploaded = 0;\n      const intv = setInterval(() => {\n        uploaded += 1024 * 1000;\n        if (uploaded > e.total) {\n          uploaded = e.total;\n        }\n        pv = Math.ceil((uploaded / e.total) * 100);\n        com.progress = pv;\n        this.onProgress.emit({\n          file,\n          total: e.total,\n          uploaded,\n          value: pv,\n        });\n        //\n        if (com.progress >= 100) {\n          clearInterval(intv);\n          setTimeout(() => {\n            this.rendrer.removeChild(this.progressRef, progressDiv);\n            if (this.fileName) {\n              this.rendrer.removeChild(this.dropRef, this.overlayDiv);\n              this.overlayDiv = this.rendrer.createElement(\n                'div'\n              ) as HTMLElement;\n              this.overlayDiv.classList.add('overlay');\n              this.overlayDiv.innerHTML = `\n              <div\n              style=\"\n                display: flex;\n                flex-direction: column;\n                align-items: center;\n                justify-content: center;\n                gap: 8px;\n              \"\n            >\n            <i style=\"color: var(--ax-danger-color)\" class=\"far fa-times fa-3x\"></i>\n              <span>${this.fileName}</span>\n            </div>\n            \n            `;\n              const closeIcon = this.overlayDiv.querySelector('.far.fa-times');\n              this.rendrer.listen(closeIcon, 'click', (e) => {\n                this.remove();\n                this.rendrer.removeChild(this.dropRef, this.overlayDiv);\n                this.handleShowEmptyFile();\n                e.stopPropagation();\n              });\n              this.rendrer.appendChild(this.dropRef, this.overlayDiv);\n            }\n          }, 1000);\n        }\n      }, 100);\n    });\n    reader.readAsDataURL(file);\n    this.files.push(file);\n  }\n\n  get accessTypes(): string[] {\n    return this.fileTypes.find((item) => item.type == this.contentType).accept;\n  }\n\n  private handleShowEmptyFile() {\n    this.overlayDiv = this.rendrer.createElement('div') as HTMLElement;\n    this.overlayDiv.classList.add('overlay');\n    this.overlayDiv.innerHTML = `\n      <div  style=\"\n      display: flex;\n      flex-direction: column;\n      align-items: center;\n      justify-content: center;\n      gap: 8px;\n    \">\n    <i class=\"far fa-cloud-upload-alt fa-3x\"></i>\n    <span>${AXTranslator.get('common.upload')}</span>\n      </div>\n    `;\n    this.rendrer.appendChild(this.dropRef, this.overlayDiv);\n    this.dropRef.classList.add('ax-upload-drop-over');\n  }\n}\n","<input\n  #fileInput\n  type=\"file\"\n  [accept]=\"accessTypes.join(',')\"\n  style=\"display: none\"\n  (change)=\"onFileChange($event)\"\n/>\n\n<ng-container *ngIf=\"type == 'inline'; else elseTemplate\">\n  <ax-form-group size=\"{{ size }}\">\n    <ax-text-box\n      [value]=\"fileName\"\n      readonly=\"true\"\n      [disabled]=\"disabled\"\n    ></ax-text-box>\n    <ax-button\n      type=\"blank light\"\n      icon=\"far fa-times\"\n      (click)=\"remove()\"\n      *ngIf=\"fileName\"\n      [tabIndex]=\"-1\"\n    >\n    </ax-button>\n    <ax-button\n      type=\"primary blank\"\n      icon=\"far fa-upload\"\n      (click)=\"open()\"\n      [disabled]=\"disabled\"\n      [tabIndex]=\"-1\"\n    >\n    </ax-button>\n  </ax-form-group>\n</ng-container>\n\n<ng-template #elseTemplate>\n  <div class=\"ax upload-file-box\" (click)=\"open()\" #dropRef></div>\n</ng-template>\n"]}
@@ -17141,12 +17141,13 @@ class AXUploadFileComponent extends AXBaseComponent {
17141
17141
  injectionService;
17142
17142
  rendrer;
17143
17143
  cdr;
17144
+ toastService;
17144
17145
  overlayDiv;
17145
17146
  contentType = 'image';
17146
17147
  dropRef;
17147
17148
  progressRef;
17148
17149
  label;
17149
- size = "md";
17150
+ size = 'md';
17150
17151
  fileInput;
17151
17152
  type = 'inline';
17152
17153
  template;
@@ -17158,45 +17159,60 @@ class AXUploadFileComponent extends AXBaseComponent {
17158
17159
  {
17159
17160
  type: 'image',
17160
17161
  accept: ['image/gif', 'image/jpeg', 'image/png'],
17162
+ message: 'عکس',
17161
17163
  },
17162
17164
  {
17163
17165
  type: 'audio',
17164
17166
  accept: ['audio/mp3'],
17167
+ message: 'audio',
17165
17168
  },
17166
17169
  {
17167
17170
  type: 'ebook',
17168
17171
  accept: ['application/pdf'],
17172
+ message: 'pdf',
17169
17173
  },
17170
17174
  {
17171
17175
  type: 'excel',
17172
- accept: ['application/vnd.ms-excel', 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'],
17176
+ accept: [
17177
+ 'application/vnd.ms-excel',
17178
+ 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet',
17179
+ 'application/vnd.ms-excel.sheet.macroEnabled.12',
17180
+ 'application/vnd.oasis.opendocument.spreadsheet',
17181
+ 'text/csv',
17182
+ ],
17183
+ message: 'اکسل',
17173
17184
  },
17174
17185
  {
17175
17186
  type: 'video',
17176
17187
  accept: ['video/*'],
17188
+ message: 'video',
17177
17189
  },
17178
17190
  {
17179
17191
  type: 'video/image',
17180
17192
  accept: ['image/gif', 'image/jpeg', 'image/png', 'video/*'],
17193
+ message: 'video/image',
17181
17194
  },
17182
17195
  {
17183
17196
  type: 'json',
17184
17197
  accept: ['application/json'],
17198
+ message: 'json',
17185
17199
  },
17186
17200
  {
17187
17201
  type: 'any',
17188
17202
  accept: ['*/*'],
17203
+ message: '',
17189
17204
  },
17190
17205
  ];
17191
17206
  files = [];
17192
17207
  focus() { }
17193
17208
  fileName = '';
17194
- constructor(el, injectionService, rendrer, cdr) {
17209
+ constructor(el, injectionService, rendrer, cdr, toastService) {
17195
17210
  super();
17196
17211
  this.el = el;
17197
17212
  this.injectionService = injectionService;
17198
17213
  this.rendrer = rendrer;
17199
17214
  this.cdr = cdr;
17215
+ this.toastService = toastService;
17200
17216
  }
17201
17217
  onDeleteClick(e) {
17202
17218
  e.stopPropagation();
@@ -17219,31 +17235,24 @@ class AXUploadFileComponent extends AXBaseComponent {
17219
17235
  if (this.dropRef != null) {
17220
17236
  }
17221
17237
  else {
17222
- this.dropRef = this.el.nativeElement;
17238
+ this.dropRef = this.el.nativeElement.querySelector('.upload-file-box');
17223
17239
  }
17224
17240
  //
17225
17241
  if (this.progressRef != null) {
17226
17242
  }
17227
17243
  else {
17228
- this.progressRef = this.el.nativeElement;
17244
+ this.progressRef =
17245
+ this.el.nativeElement.querySelector('.upload-file-box');
17229
17246
  }
17230
17247
  //
17231
17248
  if (this.type === 'hidden' || this.type === 'box') {
17232
- this.overlayDiv = this.rendrer.createElement('div');
17233
- this.overlayDiv.classList.add('overlay');
17234
- this.overlayDiv.innerHTML = `
17235
- <div class="icon-wrapper">
17236
- <i class="far fa-cloud-upload-alt fa-3x"></i>
17237
- <span>Drop File(s) Here</span>
17238
- </div>
17239
- `;
17249
+ this.handleShowEmptyFile();
17240
17250
  this.overlayDiv.addEventListener('drag', this.handleOverlayDragOver);
17241
17251
  this.overlayDiv.addEventListener('dragover', this.handleOverlayDragOver);
17242
17252
  this.overlayDiv.addEventListener('dragleave', this.handleOverlayDragOver);
17243
- this.rendrer.appendChild(this.dropRef, this.overlayDiv);
17244
17253
  }
17245
17254
  //
17246
- this.dropRef.classList.add('ax-upload-drop-over');
17255
+ // this.dropRef.classList.add('ax-upload-drop-over');
17247
17256
  this.dropRef.addEventListener('dragover', this.handleDragOver.bind(this));
17248
17257
  this.dropRef.addEventListener('dragleave', this.handleDragLeave.bind(this));
17249
17258
  this.dropRef.addEventListener('drop', this.handleDrop.bind(this));
@@ -17273,6 +17282,14 @@ class AXUploadFileComponent extends AXBaseComponent {
17273
17282
  }
17274
17283
  }
17275
17284
  addFile(file) {
17285
+ if (this.contentType &&
17286
+ this.contentType !== 'any' &&
17287
+ !this.fileTypes
17288
+ .find((x) => x.type === this.contentType)
17289
+ .accept.includes(file.type)) {
17290
+ this.toastService.info(`فایل بارگذاری باید از نوع ${this.fileTypes.find((x) => x.type === this.contentType).message} باشد`);
17291
+ return;
17292
+ }
17276
17293
  const progressDiv = this.rendrer.createElement('div');
17277
17294
  progressDiv.classList.add('ax-upload-progress-panel');
17278
17295
  const progressLabel = this.rendrer.createElement('small');
@@ -17285,7 +17302,7 @@ class AXUploadFileComponent extends AXBaseComponent {
17285
17302
  reader.addEventListener('load', (e) => {
17286
17303
  this.onLoad.emit({
17287
17304
  file,
17288
- data: e.target.result
17305
+ data: e.target.result,
17289
17306
  });
17290
17307
  //
17291
17308
  // Fake Upload
@@ -17302,13 +17319,41 @@ class AXUploadFileComponent extends AXBaseComponent {
17302
17319
  file,
17303
17320
  total: e.total,
17304
17321
  uploaded,
17305
- value: pv
17322
+ value: pv,
17306
17323
  });
17307
17324
  //
17308
17325
  if (com.progress >= 100) {
17309
17326
  clearInterval(intv);
17310
17327
  setTimeout(() => {
17311
17328
  this.rendrer.removeChild(this.progressRef, progressDiv);
17329
+ if (this.fileName) {
17330
+ this.rendrer.removeChild(this.dropRef, this.overlayDiv);
17331
+ this.overlayDiv = this.rendrer.createElement('div');
17332
+ this.overlayDiv.classList.add('overlay');
17333
+ this.overlayDiv.innerHTML = `
17334
+ <div
17335
+ style="
17336
+ display: flex;
17337
+ flex-direction: column;
17338
+ align-items: center;
17339
+ justify-content: center;
17340
+ gap: 8px;
17341
+ "
17342
+ >
17343
+ <i style="color: var(--ax-danger-color)" class="far fa-times fa-3x"></i>
17344
+ <span>${this.fileName}</span>
17345
+ </div>
17346
+
17347
+ `;
17348
+ const closeIcon = this.overlayDiv.querySelector('.far.fa-times');
17349
+ this.rendrer.listen(closeIcon, 'click', (e) => {
17350
+ this.remove();
17351
+ this.rendrer.removeChild(this.dropRef, this.overlayDiv);
17352
+ this.handleShowEmptyFile();
17353
+ e.stopPropagation();
17354
+ });
17355
+ this.rendrer.appendChild(this.dropRef, this.overlayDiv);
17356
+ }
17312
17357
  }, 1000);
17313
17358
  }
17314
17359
  }, 100);
@@ -17319,13 +17364,31 @@ class AXUploadFileComponent extends AXBaseComponent {
17319
17364
  get accessTypes() {
17320
17365
  return this.fileTypes.find((item) => item.type == this.contentType).accept;
17321
17366
  }
17322
- static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AXUploadFileComponent, deps: [{ token: i0.ElementRef }, { token: i1$2.AXRenderService }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
17323
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", 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)\" />\n\n<ng-container *ngIf=\"type == 'inline'; else elseTemplate\">\n <ax-form-group size=\"{{size}}\">\n <ax-text-box [value]=\"fileName\" readonly=\"true\" [disabled]=\"disabled\"></ax-text-box>\n <ax-button type=\"blank light\" icon=\"far fa-times\" (click)=\"remove()\" *ngIf=\"fileName\" [tabIndex]=\"-1\">\n </ax-button>\n <ax-button type=\"primary blank\" icon=\"far fa-upload\" (click)=\"open()\" [disabled]=\"disabled\" [tabIndex]=\"-1\">\n </ax-button>\n </ax-form-group>\n</ng-container>\n\n<ng-template #elseTemplate>\n <div class=\"ax upload-file-box\" (click)=\"open()\" #dropRef>\n </div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: AXButtonComponent, selector: "ax-button", inputs: ["type", "icon", "submitBehavior", "cancelBehavior", "block", "loading", "selected"] }, { kind: "component", type: AXTextBoxComponent, selector: "ax-text-box", inputs: ["mask", "showMask", "type", "maxLength", "maskGuid", "maskPlaceholder", "maskKeepCharPositions"] }, { kind: "component", type: AXFormGroupComponent, selector: "ax-form-group", inputs: ["size"] }], encapsulation: i0.ViewEncapsulation.None });
17367
+ handleShowEmptyFile() {
17368
+ this.overlayDiv = this.rendrer.createElement('div');
17369
+ this.overlayDiv.classList.add('overlay');
17370
+ this.overlayDiv.innerHTML = `
17371
+ <div style="
17372
+ display: flex;
17373
+ flex-direction: column;
17374
+ align-items: center;
17375
+ justify-content: center;
17376
+ gap: 8px;
17377
+ ">
17378
+ <i class="far fa-cloud-upload-alt fa-3x"></i>
17379
+ <span>${AXTranslator.get('common.upload')}</span>
17380
+ </div>
17381
+ `;
17382
+ this.rendrer.appendChild(this.dropRef, this.overlayDiv);
17383
+ this.dropRef.classList.add('ax-upload-drop-over');
17384
+ }
17385
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AXUploadFileComponent, deps: [{ token: i0.ElementRef }, { token: i1$2.AXRenderService }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }, { token: AXToastService }], target: i0.ɵɵFactoryTarget.Component });
17386
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", 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\n #fileInput\n type=\"file\"\n [accept]=\"accessTypes.join(',')\"\n style=\"display: none\"\n (change)=\"onFileChange($event)\"\n/>\n\n<ng-container *ngIf=\"type == 'inline'; else elseTemplate\">\n <ax-form-group size=\"{{ size }}\">\n <ax-text-box\n [value]=\"fileName\"\n readonly=\"true\"\n [disabled]=\"disabled\"\n ></ax-text-box>\n <ax-button\n type=\"blank light\"\n icon=\"far fa-times\"\n (click)=\"remove()\"\n *ngIf=\"fileName\"\n [tabIndex]=\"-1\"\n >\n </ax-button>\n <ax-button\n type=\"primary blank\"\n icon=\"far fa-upload\"\n (click)=\"open()\"\n [disabled]=\"disabled\"\n [tabIndex]=\"-1\"\n >\n </ax-button>\n </ax-form-group>\n</ng-container>\n\n<ng-template #elseTemplate>\n <div class=\"ax upload-file-box\" (click)=\"open()\" #dropRef></div>\n</ng-template>\n", dependencies: [{ kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: AXButtonComponent, selector: "ax-button", inputs: ["type", "icon", "submitBehavior", "cancelBehavior", "block", "loading", "selected"] }, { kind: "component", type: AXTextBoxComponent, selector: "ax-text-box", inputs: ["mask", "showMask", "type", "maxLength", "maskGuid", "maskPlaceholder", "maskKeepCharPositions"] }, { kind: "component", type: AXFormGroupComponent, selector: "ax-form-group", inputs: ["size"] }], encapsulation: i0.ViewEncapsulation.None });
17324
17387
  }
17325
17388
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AXUploadFileComponent, decorators: [{
17326
17389
  type: Component,
17327
- 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)\" />\n\n<ng-container *ngIf=\"type == 'inline'; else elseTemplate\">\n <ax-form-group size=\"{{size}}\">\n <ax-text-box [value]=\"fileName\" readonly=\"true\" [disabled]=\"disabled\"></ax-text-box>\n <ax-button type=\"blank light\" icon=\"far fa-times\" (click)=\"remove()\" *ngIf=\"fileName\" [tabIndex]=\"-1\">\n </ax-button>\n <ax-button type=\"primary blank\" icon=\"far fa-upload\" (click)=\"open()\" [disabled]=\"disabled\" [tabIndex]=\"-1\">\n </ax-button>\n </ax-form-group>\n</ng-container>\n\n<ng-template #elseTemplate>\n <div class=\"ax upload-file-box\" (click)=\"open()\" #dropRef>\n </div>\n</ng-template>\n" }]
17328
- }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1$2.AXRenderService }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { contentType: [{
17390
+ args: [{ selector: 'ax-upload-file', encapsulation: ViewEncapsulation.None, host: { style: 'display: block; width:100%; position: relative' }, template: "<input\n #fileInput\n type=\"file\"\n [accept]=\"accessTypes.join(',')\"\n style=\"display: none\"\n (change)=\"onFileChange($event)\"\n/>\n\n<ng-container *ngIf=\"type == 'inline'; else elseTemplate\">\n <ax-form-group size=\"{{ size }}\">\n <ax-text-box\n [value]=\"fileName\"\n readonly=\"true\"\n [disabled]=\"disabled\"\n ></ax-text-box>\n <ax-button\n type=\"blank light\"\n icon=\"far fa-times\"\n (click)=\"remove()\"\n *ngIf=\"fileName\"\n [tabIndex]=\"-1\"\n >\n </ax-button>\n <ax-button\n type=\"primary blank\"\n icon=\"far fa-upload\"\n (click)=\"open()\"\n [disabled]=\"disabled\"\n [tabIndex]=\"-1\"\n >\n </ax-button>\n </ax-form-group>\n</ng-container>\n\n<ng-template #elseTemplate>\n <div class=\"ax upload-file-box\" (click)=\"open()\" #dropRef></div>\n</ng-template>\n" }]
17391
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1$2.AXRenderService }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: AXToastService }]; }, propDecorators: { contentType: [{
17329
17392
  type: Input
17330
17393
  }], dropRef: [{
17331
17394
  type: Input