@acorex/components 16.0.20 → 16.0.22

Sign up to get free protection for your applications and to get access to all the features.
@@ -131,9 +131,11 @@ export class AXUploadFileComponent extends AXBaseComponent {
131
131
  }
132
132
  //
133
133
  // this.dropRef.classList.add('ax-upload-drop-over');
134
- this.dropRef.addEventListener('dragover', this.handleDragOver.bind(this));
135
- this.dropRef.addEventListener('dragleave', this.handleDragLeave.bind(this));
136
- this.dropRef.addEventListener('drop', this.handleDrop.bind(this));
134
+ if (this.dropRef) {
135
+ this.dropRef.addEventListener('dragover', this.handleDragOver.bind(this));
136
+ this.dropRef.addEventListener('dragleave', this.handleDragLeave.bind(this));
137
+ this.dropRef.addEventListener('drop', this.handleDrop.bind(this));
138
+ }
137
139
  }
138
140
  handleOverlayDragOver(e) {
139
141
  e.preventDefault();
@@ -173,7 +175,9 @@ export class AXUploadFileComponent extends AXBaseComponent {
173
175
  const progressLabel = this.rendrer.createElement('small');
174
176
  progressLabel.innerText = file.name;
175
177
  this.fileName = file.name;
176
- this.rendrer.appendChild(this.progressRef, progressDiv);
178
+ if (this.type === 'box') {
179
+ this.rendrer.appendChild(this.progressRef, progressDiv);
180
+ }
177
181
  const com = this.injectionService.appendComponent(AXProgressBarComponent, { progress: 0 }, progressDiv).instance;
178
182
  this.rendrer.appendChild(progressDiv, progressLabel);
179
183
  const reader = new FileReader();
@@ -292,4 +296,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
292
296
  }], onRemove: [{
293
297
  type: Output
294
298
  }] } });
295
- //# 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' = 'any';\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\n    if (this.type === 'box') {\n      this.rendrer.removeChild(this.dropRef, this.overlayDiv);\n      this.handleShowEmptyFile();\n    }\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"]}
299
+ //# 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' = 'any';\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\n    if (this.type === 'box') {\n      this.rendrer.removeChild(this.dropRef, this.overlayDiv);\n      this.handleShowEmptyFile();\n    }\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    if (this.dropRef) {\n      this.dropRef.addEventListener('dragover', this.handleDragOver.bind(this));\n      this.dropRef.addEventListener(\n        'dragleave',\n        this.handleDragLeave.bind(this)\n      );\n      this.dropRef.addEventListener('drop', this.handleDrop.bind(this));\n    }\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    if (this.type === 'box') {\n      this.rendrer.appendChild(this.progressRef, progressDiv);\n    }\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"]}
@@ -973,21 +973,43 @@ class AXCalendarBoxComponent {
973
973
  jalali: {
974
974
  locale: AXConfig.get('dateTime.jalali.locale') || 'fa',
975
975
  dir: 'rtl',
976
- number: 1
976
+ number: 1,
977
977
  },
978
978
  gregorian: {
979
979
  locale: AXConfig.get('dateTime.gregorian.locale') || 'en',
980
980
  dir: 'ltr',
981
- number: 0
982
- }
981
+ number: 0,
982
+ },
983
983
  };
984
984
  numRotate;
985
985
  size = 'md';
986
986
  type;
987
987
  locale;
988
988
  dir;
989
- min;
990
- max;
989
+ _min;
990
+ set min(v) {
991
+ if (v) {
992
+ this._min = v;
993
+ this.focusedValue = this.today;
994
+ this.viewRange = this.today.month.range;
995
+ this.navigate(0);
996
+ }
997
+ }
998
+ get min() {
999
+ return this._min;
1000
+ }
1001
+ _max;
1002
+ set max(v) {
1003
+ if (v) {
1004
+ this._max = v;
1005
+ this.focusedValue = this.today;
1006
+ this.viewRange = this.today.month.range;
1007
+ this.navigate(0);
1008
+ }
1009
+ }
1010
+ get max() {
1011
+ return this._max;
1012
+ }
991
1013
  selectableHoliday = true;
992
1014
  dayStyle = [];
993
1015
  dayMinMaxResoan = '';
@@ -1028,7 +1050,7 @@ class AXCalendarBoxComponent {
1028
1050
  vv = AXDateTime.convert(v);
1029
1051
  }
1030
1052
  let unValidDate = false;
1031
- if (this.max || this.min) {
1053
+ if (this._max || this._min) {
1032
1054
  unValidDate = this.isInMInMaxRange(vv);
1033
1055
  }
1034
1056
  if (!unValidDate) {
@@ -1040,7 +1062,7 @@ class AXCalendarBoxComponent {
1040
1062
  this.onValueChanged.emit({
1041
1063
  component: this,
1042
1064
  value: this._value?.date,
1043
- htmlElement: this.ref.nativeElement
1065
+ htmlElement: this.ref.nativeElement,
1044
1066
  });
1045
1067
  }
1046
1068
  if (v == undefined) {
@@ -1052,7 +1074,7 @@ class AXCalendarBoxComponent {
1052
1074
  this.onClick.emit({
1053
1075
  component: this,
1054
1076
  value: this._value?.date,
1055
- htmlElement: this.ref.nativeElement
1077
+ htmlElement: this.ref.nativeElement,
1056
1078
  });
1057
1079
  }
1058
1080
  }
@@ -1088,8 +1110,10 @@ class AXCalendarBoxComponent {
1088
1110
  return this.dayStyle.find((c) => c.date.split('T')[0] == date.toISOString().split('T')[0]).text;
1089
1111
  }
1090
1112
  else {
1091
- if ((this.min && this.max && date.compaireNew(new AXDateTime(this.min, this.type), 'YMD', this.type) === -1) ||
1092
- date.compaireNew(new AXDateTime(this.max, this.type), 'YMD', this.type) === 1) {
1113
+ if ((this._min &&
1114
+ this._max &&
1115
+ date.compaireNew(new AXDateTime(this._min, this.type), 'YMD', this.type) === -1) ||
1116
+ date.compaireNew(new AXDateTime(this._max, this.type), 'YMD', this.type) === 1) {
1093
1117
  return this.dayMinMaxResoan;
1094
1118
  }
1095
1119
  else {
@@ -1143,7 +1167,7 @@ class AXCalendarBoxComponent {
1143
1167
  AXTranslator.get(`${path}.wed`, this.locale),
1144
1168
  AXTranslator.get(`${path}.thu`, this.locale),
1145
1169
  AXTranslator.get(`${path}.fri`, this.locale),
1146
- AXTranslator.get(`${path}.sat`, this.locale)
1170
+ AXTranslator.get(`${path}.sat`, this.locale),
1147
1171
  ];
1148
1172
  }
1149
1173
  getTodayName() {
@@ -1157,7 +1181,11 @@ class AXCalendarBoxComponent {
1157
1181
  }
1158
1182
  rotate(array, n) {
1159
1183
  const len = array.length;
1160
- return !(n % len) ? array : n > 0 ? array.map((e, i, a) => a[(i + n) % len]) : array.map((e, i, a) => a[(len - ((len - i - n) % len)) % len]);
1184
+ return !(n % len)
1185
+ ? array
1186
+ : n > 0
1187
+ ? array.map((e, i, a) => a[(i + n) % len])
1188
+ : array.map((e, i, a) => a[(len - ((len - i - n) % len)) % len]);
1161
1189
  }
1162
1190
  navigate(value) {
1163
1191
  let start;
@@ -1168,7 +1196,10 @@ class AXCalendarBoxComponent {
1168
1196
  fd = value.startOf('month');
1169
1197
  }
1170
1198
  else {
1171
- fd = this.viewRange.startTime.add('day', 15).add('month', value).startOf('month');
1199
+ fd = this.viewRange.startTime
1200
+ .add('day', 15)
1201
+ .add('month', value)
1202
+ .startOf('month');
1172
1203
  }
1173
1204
  start = fd.firstDayOfWeek;
1174
1205
  end = fd.endOf('month').endDayOfWeek;
@@ -1191,7 +1222,10 @@ class AXCalendarBoxComponent {
1191
1222
  fd = value.startOf('year');
1192
1223
  }
1193
1224
  else {
1194
- fd = this.viewRange.startTime.add('day', 15).add('year', value).startOf('year');
1225
+ fd = this.viewRange.startTime
1226
+ .add('day', 15)
1227
+ .add('year', value)
1228
+ .startOf('year');
1195
1229
  }
1196
1230
  start = fd;
1197
1231
  end = fd.endOf('year');
@@ -1221,7 +1255,8 @@ class AXCalendarBoxComponent {
1221
1255
  //
1222
1256
  if (this.view === 'day') {
1223
1257
  this.matrix = this.matrixify(this.applyStyle(this.viewRange.enumurate('day', this.type)), 7);
1224
- if (this.matrix.length > 0 && this.matrix[0].find((c) => c.nextMonth === false) === undefined) {
1258
+ if (this.matrix.length > 0 &&
1259
+ this.matrix[0].find((c) => c.nextMonth === false) === undefined) {
1225
1260
  this.matrix.splice(0, 1);
1226
1261
  }
1227
1262
  if (this.matrix[this.matrix.length - 1].find((c) => c.nextMonth === false) === undefined) {
@@ -1241,12 +1276,17 @@ class AXCalendarBoxComponent {
1241
1276
  dates.forEach((d, i, j) => {
1242
1277
  const item = {};
1243
1278
  item.date = d;
1244
- item.selected = d.compaireNew(new AXDateTime(this.value, this.type), this.getViewCompaire(this.view), this.type) === 0;
1245
- item.focused = d.compaireNew(this.focusedValue, this.getViewCompaire(this.view), this.type) === 0;
1246
- item.today = this.today && d.compaireNew(this.today, this.getViewCompaire(this.view), this.type) === 0;
1279
+ item.selected =
1280
+ d.compaireNew(new AXDateTime(this.value, this.type), this.getViewCompaire(this.view), this.type) === 0;
1281
+ item.focused =
1282
+ d.compaireNew(this.focusedValue, this.getViewCompaire(this.view), this.type) === 0;
1283
+ item.today =
1284
+ this.today &&
1285
+ d.compaireNew(this.today, this.getViewCompaire(this.view), this.type) === 0;
1247
1286
  if (this.view === 'day') {
1248
1287
  // item.nextMonth = d.compaireNew(this.viewRange.startTime.add('day', 10), 'YM') !== 0;
1249
- item.nextMonth = d.compaireNew(this.viewRange.startTime.add('day', 10), 'YM', this.type) !== 0;
1288
+ item.nextMonth =
1289
+ d.compaireNew(this.viewRange.startTime.add('day', 10), 'YM', this.type) !== 0;
1250
1290
  item.unselect = this.isInMInMaxRange(d);
1251
1291
  this.holidays.forEach((h) => {
1252
1292
  const comp = d.compaireNew(new AXDateTime(h.date, this.type), 'YMD', this.type);
@@ -1298,16 +1338,18 @@ class AXCalendarBoxComponent {
1298
1338
  isInMInMaxRange(d) {
1299
1339
  let r = false;
1300
1340
  if (d !== undefined) {
1301
- if (this.min && !this.max) {
1302
- r = d.compaireNew(new AXDateTime(this.min, this.type), this.getViewCompaire(this.view), this.type) === -1;
1341
+ if (this._min && !this._max) {
1342
+ r =
1343
+ d.compaireNew(new AXDateTime(this._min, this.type), this.getViewCompaire(this.view), this.type) === -1;
1303
1344
  }
1304
- if (this.max && !this.min) {
1305
- r = d.compaireNew(new AXDateTime(this.max, this.type), this.getViewCompaire(this.view), this.type) === 1;
1345
+ if (this._max && !this._min) {
1346
+ r =
1347
+ d.compaireNew(new AXDateTime(this._max, this.type), this.getViewCompaire(this.view), this.type) === 1;
1306
1348
  }
1307
- if (this.min && this.max) {
1349
+ if (this._min && this._max) {
1308
1350
  r =
1309
- d.compaireNew(new AXDateTime(this.min, this.type), this.getViewCompaire(this.view), this.type) === -1 ||
1310
- d.compaireNew(new AXDateTime(this.max, this.type), this.getViewCompaire(this.view), this.type) === 1;
1351
+ d.compaireNew(new AXDateTime(this._min, this.type), this.getViewCompaire(this.view), this.type) === -1 ||
1352
+ d.compaireNew(new AXDateTime(this._max, this.type), this.getViewCompaire(this.view), this.type) === 1;
1311
1353
  }
1312
1354
  }
1313
1355
  return r;
@@ -1318,7 +1360,9 @@ class AXCalendarBoxComponent {
1318
1360
  }
1319
1361
  else {
1320
1362
  this.view = 'day';
1321
- this.setFocus(new AXDateTime(this.value, this.type).set('year', date.year).set('month', date.monthOfYear));
1363
+ this.setFocus(new AXDateTime(this.value, this.type)
1364
+ .set('year', date.year)
1365
+ .set('month', date.monthOfYear));
1322
1366
  }
1323
1367
  event.stopPropagation();
1324
1368
  }
@@ -1651,6 +1695,11 @@ class AXTooltipDirective {
1651
1695
  this.hide();
1652
1696
  }
1653
1697
  }
1698
+ onMouseClick() {
1699
+ if (this.tooltip && this.tooltipTitle) {
1700
+ this.hide();
1701
+ }
1702
+ }
1654
1703
  show() {
1655
1704
  this.create();
1656
1705
  this.setPosition();
@@ -1686,7 +1735,10 @@ class AXTooltipDirective {
1686
1735
  setPosition() {
1687
1736
  const hostPos = this.el.nativeElement.getBoundingClientRect();
1688
1737
  const tooltipPos = this.tooltip.getBoundingClientRect();
1689
- const scrollPos = window.pageYOffset || document.documentElement.scrollTop || document.body.scrollTop || 0;
1738
+ const scrollPos = window.pageYOffset ||
1739
+ document.documentElement.scrollTop ||
1740
+ document.body.scrollTop ||
1741
+ 0;
1690
1742
  let top;
1691
1743
  let left;
1692
1744
  if (this.placement === 'top') {
@@ -1709,12 +1761,12 @@ class AXTooltipDirective {
1709
1761
  this.renderer.setStyle(this.tooltip, 'left', `${left}px`);
1710
1762
  }
1711
1763
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AXTooltipDirective, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive });
1712
- static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: AXTooltipDirective, selector: "[axTooltip]", inputs: { tooltipTitle: ["tooltip", "tooltipTitle"], placement: "placement", delay: "delay" }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()" } }, ngImport: i0 });
1764
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: AXTooltipDirective, selector: "[axTooltip]", inputs: { tooltipTitle: ["tooltip", "tooltipTitle"], placement: "placement", delay: "delay" }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()", "click": "onMouseClick()" } }, ngImport: i0 });
1713
1765
  }
1714
1766
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AXTooltipDirective, decorators: [{
1715
1767
  type: Directive,
1716
1768
  args: [{
1717
- selector: '[axTooltip]'
1769
+ selector: '[axTooltip]',
1718
1770
  }]
1719
1771
  }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }]; }, propDecorators: { tooltipTitle: [{
1720
1772
  type: Input,
@@ -1729,6 +1781,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
1729
1781
  }], onMouseLeave: [{
1730
1782
  type: HostListener,
1731
1783
  args: ['mouseleave']
1784
+ }], onMouseClick: [{
1785
+ type: HostListener,
1786
+ args: ['click']
1732
1787
  }] } });
1733
1788
 
1734
1789
  class AXMenuItemClickEvent extends AXEvent {
@@ -13189,7 +13244,7 @@ class AXSelectBoxPropertyEditorComponent extends AXProperyEditorComponent {
13189
13244
  selectionMode = 'single';
13190
13245
  selectionDataMode = 'value';
13191
13246
  allowSearch = true;
13192
- allowNull = false;
13247
+ allowNull = true;
13193
13248
  disabled = false;
13194
13249
  items = [];
13195
13250
  remoteOperation = false;
@@ -17261,9 +17316,11 @@ class AXUploadFileComponent extends AXBaseComponent {
17261
17316
  }
17262
17317
  //
17263
17318
  // this.dropRef.classList.add('ax-upload-drop-over');
17264
- this.dropRef.addEventListener('dragover', this.handleDragOver.bind(this));
17265
- this.dropRef.addEventListener('dragleave', this.handleDragLeave.bind(this));
17266
- this.dropRef.addEventListener('drop', this.handleDrop.bind(this));
17319
+ if (this.dropRef) {
17320
+ this.dropRef.addEventListener('dragover', this.handleDragOver.bind(this));
17321
+ this.dropRef.addEventListener('dragleave', this.handleDragLeave.bind(this));
17322
+ this.dropRef.addEventListener('drop', this.handleDrop.bind(this));
17323
+ }
17267
17324
  }
17268
17325
  handleOverlayDragOver(e) {
17269
17326
  e.preventDefault();
@@ -17303,7 +17360,9 @@ class AXUploadFileComponent extends AXBaseComponent {
17303
17360
  const progressLabel = this.rendrer.createElement('small');
17304
17361
  progressLabel.innerText = file.name;
17305
17362
  this.fileName = file.name;
17306
- this.rendrer.appendChild(this.progressRef, progressDiv);
17363
+ if (this.type === 'box') {
17364
+ this.rendrer.appendChild(this.progressRef, progressDiv);
17365
+ }
17307
17366
  const com = this.injectionService.appendComponent(AXProgressBarComponent, { progress: 0 }, progressDiv).instance;
17308
17367
  this.rendrer.appendChild(progressDiv, progressLabel);
17309
17368
  const reader = new FileReader();