@smartbit4all/ng-client 4.2.140 → 4.2.142

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.
@@ -61,7 +61,7 @@ export class SmartfileuploaderComponent {
61
61
  else if (validFiles.length) {
62
62
  this.files = [validFiles[0]];
63
63
  }
64
- if (this.autoUpload) {
64
+ if (this.autoUpload && this.errors.length == 0) {
65
65
  this.uploadFile();
66
66
  }
67
67
  }
@@ -187,4 +187,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
187
187
  }], autoUpload: [{
188
188
  type: Input
189
189
  }] } });
190
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smartfileuploader.component.js","sourceRoot":"","sources":["../../../../../../projects/smart-ng-client/src/lib/smart-form/smartfileuploader/smartfileuploader.component.ts","../../../../../../projects/smart-ng-client/src/lib/smart-form/smartfileuploader/smartfileuploader.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, OnInit, ViewChild } from '@angular/core';\r\nimport { MatSnackBar } from '@angular/material/snack-bar';\r\nimport { SmartFileUploaderI18n } from './smartfileuploader.model';\r\nimport {\r\n  IconPosition,\r\n  UiActionButtonType,\r\n  UiActionDescriptor,\r\n} from '../../view-context/api/model/models';\r\n\r\n@Component({\r\n  selector: 'smartfileuploader',\r\n  templateUrl: './smartfileuploader.component.html',\r\n  styleUrls: ['./smartfileuploader.component.css'],\r\n})\r\nexport class SmartfileuploaderComponent implements OnInit {\r\n  @ViewChild('fileInput') fileInput!: ElementRef<HTMLInputElement>;\r\n\r\n  files: File[] = [];\r\n  @Input() uploadCallback!: (files: File[]) => void;\r\n  @Input() fileFormats?: string[] = [];\r\n  @Input() maxSizeMb?: number = 25;\r\n  @Input() i18n?: SmartFileUploaderI18n;\r\n  @Input() useIconButton: boolean = true;\r\n  @Input() isMultiple?: boolean = true;\r\n  @Input() autoUpload?: boolean = false;\r\n\r\n  isDragOver = false;\r\n  errors: string[] = [];\r\n\r\n  constructor(private _snackBar: MatSnackBar) {}\r\n\r\n  ngOnInit(): void {\r\n    const defaultI18n = {\r\n      addFile: 'dokumentum hozzáadása',\r\n      browseOrDrag: 'tallózás vagy behúzás',\r\n      maxSize: `max. ${this.maxSizeMb} MB`,\r\n      formats: 'PDF, docx, xls formátum',\r\n      upload: 'Feltöltés',\r\n    };\r\n\r\n    this.i18n = { ...defaultI18n, ...this.i18n };\r\n  }\r\n\r\n  private processFiles(fileList: File[]): void {\r\n    this.errors = [];\r\n    var validFiles: File[] = [];\r\n\r\n    fileList.forEach((file: File) => {\r\n      let hasError = false;\r\n\r\n      if (this.fileFormats?.length) {\r\n        var ext = file.name.split('.').pop()?.toLowerCase();\r\n\r\n        var trimmedFormats = (this.fileFormats || [])\r\n          .flatMap((f) => f.split(','))\r\n          .map((f) => f.replace('.', '').trim().toLowerCase());\r\n        var isAllowed = trimmedFormats.includes(ext!);\r\n\r\n        if (!isAllowed) {\r\n          this.errors.push(`\"${file.name}\" - nem támogatott formátum`);\r\n          hasError = true;\r\n        }\r\n      }\r\n\r\n      if (file.size > this.maxSizeMb! * 1_000_000) {\r\n        this.errors.push(`\"${file.name}\" - túl nagy fájl (max ${this.maxSizeMb} MB)`);\r\n        hasError = true;\r\n      }\r\n\r\n      if (!hasError) {\r\n        validFiles.push(file);\r\n      }\r\n    });\r\n\r\n    if (this.isMultiple) {\r\n      this.files = [...this.files, ...validFiles];\r\n    } else if (validFiles.length) {\r\n      this.files = [validFiles[0]];\r\n    }\r\n    if (this.autoUpload) {\r\n      this.uploadFile();\r\n    }\r\n  }\r\n\r\n  getFile(event: any): void {\r\n    if (event.target.files && event.target.files.length) {\r\n      var fileList = Array.from(event.target.files) as File[];\r\n      this.processFiles(fileList);\r\n      this.fileInput.nativeElement.value = '';\r\n    }\r\n  }\r\n\r\n  onDrop(event: DragEvent): void {\r\n    event.preventDefault();\r\n    this.isDragOver = false;\r\n\r\n    if (!event.dataTransfer?.files) return;\r\n    const fileList = Array.from(event.dataTransfer.files);\r\n    this.processFiles(fileList);\r\n  }\r\n\r\n  onDragOver(event: DragEvent): void {\r\n    event.preventDefault();\r\n    this.isDragOver = true;\r\n  }\r\n\r\n  onDragLeave(event: DragEvent): void {\r\n    event.preventDefault();\r\n\r\n    const related = event.relatedTarget as HTMLElement | null;\r\n    let stopDrag = false;\r\n\r\n    if (!related) {\r\n      stopDrag = true;\r\n    } else {\r\n      const parentDrop = related.closest('.container');\r\n      if (related !== event.currentTarget && !parentDrop) {\r\n        stopDrag = true;\r\n      }\r\n    }\r\n\r\n    if (stopDrag) {\r\n      this.isDragOver = false;\r\n    }\r\n  }\r\n\r\n  remove(index: number): void {\r\n    this.files.splice(index, 1);\r\n  }\r\n\r\n  uploadFile(): void {\r\n    this.uploadCallback(this.files);\r\n  }\r\n\r\n  formatSize(bytes: number): string {\r\n    if (bytes === 0) return '0 B';\r\n    const k = 1024;\r\n    const sizes = ['B', 'KB', 'MB', 'GB', 'TB'];\r\n    const i = Math.floor(Math.log(bytes) / Math.log(k));\r\n    const value = parseFloat((bytes / Math.pow(k, i)).toFixed(1));\r\n    return `${value} ${sizes[i]}`;\r\n  }\r\n\r\n  previewUrls = new Map<File, string>();\r\n\r\n  filePreviewUrl(file: File): string | null {\r\n    if (!file || !file.type.startsWith('image/')) {\r\n      return null;\r\n    }\r\n\r\n    if (this.previewUrls.has(file)) {\r\n      return this.previewUrls.get(file)!;\r\n    }\r\n\r\n    const url = URL.createObjectURL(file);\r\n    this.previewUrls.set(file, url);\r\n    return url;\r\n  }\r\n\r\n  downloadFile(file: File): void {\r\n    const url = URL.createObjectURL(file);\r\n    const a = document.createElement('a');\r\n    a.href = url;\r\n    a.download = file.name;\r\n    a.click();\r\n    URL.revokeObjectURL(url);\r\n  }\r\n\r\n  get uploadButton(): UiActionDescriptor {\r\n    return {\r\n      title: this.i18n!.upload ?? '',\r\n      color: 'primary',\r\n      type: UiActionButtonType.RAISED,\r\n      icon: 'upload',\r\n      iconPosition: IconPosition.PRE,\r\n    };\r\n  }\r\n\r\n  get downloadButton(): UiActionDescriptor {\r\n    return {\r\n      title: '',\r\n      color: 'primary',\r\n      type: UiActionButtonType.ICON,\r\n      icon: 'download',\r\n      iconPosition: IconPosition.PRE,\r\n    };\r\n  }\r\n\r\n  get removeButton(): UiActionDescriptor {\r\n    return {\r\n      title: '',\r\n      color: 'primary',\r\n      type: UiActionButtonType.ICON,\r\n      icon: 'close',\r\n      iconColor: 'red',\r\n      iconPosition: IconPosition.PRE,\r\n    };\r\n  }\r\n}\r\n","<div\r\n  class=\"container\"\r\n  (dragover)=\"onDragOver($event)\"\r\n  (dragleave)=\"onDragLeave($event)\"\r\n  (drop)=\"onDrop($event)\"\r\n  [class.dragover]=\"isDragOver\"\r\n>\r\n  <div class=\"fileContainer\" (click)=\"fileInput.click()\">\r\n    <input\r\n      #fileInput\r\n      id=\"addFile\"\r\n      placeholder=\"fileInput\"\r\n      type=\"file\"\r\n      (change)=\"getFile($event)\"\r\n      class=\"file\"\r\n      accept=\"{{ fileFormats?.join(', ') }}\"\r\n      [size]=\"maxSizeMb\"\r\n      [multiple]=\"isMultiple\"\r\n      style=\"display: none\"\r\n    />\r\n    <div class=\"fileUploadContentContainer\">\r\n      <div class=\"icon\">\r\n        <mat-label *ngIf=\"useIconButton\" class=\"addFileButton\">\r\n          <mat-icon color=\"primary\" class=\"addCircle\">add_circle</mat-icon>\r\n        </mat-label>\r\n        <button *ngIf=\"!useIconButton\" mat-raised-button color=\"primary\" class=\"addFileButton\">\r\n          {{ i18n!.addFile }}\r\n        </button>\r\n      </div>\r\n      <div class=\"labels\">\r\n        <mat-label *ngIf=\"useIconButton\" class=\"label primary title\">\r\n          {{ i18n!.addFile }}\r\n        </mat-label>\r\n        <mat-label class=\"label secondary\"> {{ i18n!.browseOrDrag }} </mat-label>\r\n        <mat-label class=\"subLabel primary\"> {{ i18n!.maxSize }} </mat-label>\r\n        <mat-label class=\"subLabel primary\"> {{ i18n!.formats }} </mat-label>\r\n      </div>\r\n      <div class=\"uploadButton\" *ngIf=\"files.length\">\r\n        <ui-action-button (actionClick)=\"uploadFile()\" [descriptor]=\"uploadButton\">\r\n        </ui-action-button>\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n  <div *ngIf=\"errors.length\" class=\"errorMessage\">\r\n    <smart-icon [icon]=\"'error'\" [color]=\"'warn'\"></smart-icon>\r\n    <div class=\"errors\">\r\n      <span *ngFor=\"let error of errors\">{{ error }}</span>\r\n    </div>\r\n  </div>\r\n\r\n  <div *ngIf=\"files.length\" class=\"uploadedFilesContainer\">\r\n    <div *ngFor=\"let file of files; let i = index\" class=\"uploadedFile\">\r\n      <ng-container *ngIf=\"filePreviewUrl(file); else fileIcon\">\r\n        <img [src]=\"filePreviewUrl(file)\" [alt]=\"file.name\" width=\"50\" height=\"50\" />\r\n      </ng-container>\r\n      <ng-template #fileIcon>\r\n        <smart-icon [icon]=\"'insert_drive_file'\"></smart-icon>\r\n      </ng-template>\r\n\r\n      <div class=\"fileData\">\r\n        <div class=\"fileDataContainer\">\r\n          <span class=\"fileName\">{{ file.name }}</span>\r\n          <span class=\"fileSize\">{{ formatSize(file.size) }}</span>\r\n        </div>\r\n      </div>\r\n\r\n      <div class=\"fileActions\">\r\n        <ui-action-button (actionClick)=\"downloadFile(file)\" [descriptor]=\"downloadButton\">\r\n        </ui-action-button>\r\n\r\n        <ui-action-button class=\"removeIcon\" (actionClick)=\"remove(i)\" [descriptor]=\"removeButton\">\r\n        </ui-action-button>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
190
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"smartfileuploader.component.js","sourceRoot":"","sources":["../../../../../../projects/smart-ng-client/src/lib/smart-form/smartfileuploader/smartfileuploader.component.ts","../../../../../../projects/smart-ng-client/src/lib/smart-form/smartfileuploader/smartfileuploader.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, Input, OnInit, ViewChild } from '@angular/core';\r\nimport { MatSnackBar } from '@angular/material/snack-bar';\r\nimport { SmartFileUploaderI18n } from './smartfileuploader.model';\r\nimport {\r\n  IconPosition,\r\n  UiActionButtonType,\r\n  UiActionDescriptor,\r\n} from '../../view-context/api/model/models';\r\n\r\n@Component({\r\n  selector: 'smartfileuploader',\r\n  templateUrl: './smartfileuploader.component.html',\r\n  styleUrls: ['./smartfileuploader.component.css'],\r\n})\r\nexport class SmartfileuploaderComponent implements OnInit {\r\n  @ViewChild('fileInput') fileInput!: ElementRef<HTMLInputElement>;\r\n\r\n  files: File[] = [];\r\n  @Input() uploadCallback!: (files: File[]) => void;\r\n  @Input() fileFormats?: string[] = [];\r\n  @Input() maxSizeMb?: number = 25;\r\n  @Input() i18n?: SmartFileUploaderI18n;\r\n  @Input() useIconButton: boolean = true;\r\n  @Input() isMultiple?: boolean = true;\r\n  @Input() autoUpload?: boolean = false;\r\n\r\n  isDragOver = false;\r\n  errors: string[] = [];\r\n\r\n  constructor(private _snackBar: MatSnackBar) {}\r\n\r\n  ngOnInit(): void {\r\n    const defaultI18n = {\r\n      addFile: 'dokumentum hozzáadása',\r\n      browseOrDrag: 'tallózás vagy behúzás',\r\n      maxSize: `max. ${this.maxSizeMb} MB`,\r\n      formats: 'PDF, docx, xls formátum',\r\n      upload: 'Feltöltés',\r\n    };\r\n\r\n    this.i18n = { ...defaultI18n, ...this.i18n };\r\n  }\r\n\r\n  private processFiles(fileList: File[]): void {\r\n    this.errors = [];\r\n    var validFiles: File[] = [];\r\n\r\n    fileList.forEach((file: File) => {\r\n      let hasError = false;\r\n\r\n      if (this.fileFormats?.length) {\r\n        var ext = file.name.split('.').pop()?.toLowerCase();\r\n\r\n        var trimmedFormats = (this.fileFormats || [])\r\n          .flatMap((f) => f.split(','))\r\n          .map((f) => f.replace('.', '').trim().toLowerCase());\r\n        var isAllowed = trimmedFormats.includes(ext!);\r\n\r\n        if (!isAllowed) {\r\n          this.errors.push(`\"${file.name}\" - nem támogatott formátum`);\r\n          hasError = true;\r\n        }\r\n      }\r\n\r\n      if (file.size > this.maxSizeMb! * 1_000_000) {\r\n        this.errors.push(`\"${file.name}\" - túl nagy fájl (max ${this.maxSizeMb} MB)`);\r\n        hasError = true;\r\n      }\r\n\r\n      if (!hasError) {\r\n        validFiles.push(file);\r\n      }\r\n    });\r\n\r\n    if (this.isMultiple) {\r\n      this.files = [...this.files, ...validFiles];\r\n    } else if (validFiles.length) {\r\n      this.files = [validFiles[0]];\r\n    }\r\n    if (this.autoUpload && this.errors.length == 0) {\r\n      this.uploadFile();\r\n    }\r\n  }\r\n\r\n  getFile(event: any): void {\r\n    if (event.target.files && event.target.files.length) {\r\n      var fileList = Array.from(event.target.files) as File[];\r\n      this.processFiles(fileList);\r\n      this.fileInput.nativeElement.value = '';\r\n    }\r\n  }\r\n\r\n  onDrop(event: DragEvent): void {\r\n    event.preventDefault();\r\n    this.isDragOver = false;\r\n\r\n    if (!event.dataTransfer?.files) return;\r\n    const fileList = Array.from(event.dataTransfer.files);\r\n    this.processFiles(fileList);\r\n  }\r\n\r\n  onDragOver(event: DragEvent): void {\r\n    event.preventDefault();\r\n    this.isDragOver = true;\r\n  }\r\n\r\n  onDragLeave(event: DragEvent): void {\r\n    event.preventDefault();\r\n\r\n    const related = event.relatedTarget as HTMLElement | null;\r\n    let stopDrag = false;\r\n\r\n    if (!related) {\r\n      stopDrag = true;\r\n    } else {\r\n      const parentDrop = related.closest('.container');\r\n      if (related !== event.currentTarget && !parentDrop) {\r\n        stopDrag = true;\r\n      }\r\n    }\r\n\r\n    if (stopDrag) {\r\n      this.isDragOver = false;\r\n    }\r\n  }\r\n\r\n  remove(index: number): void {\r\n    this.files.splice(index, 1);\r\n  }\r\n\r\n  uploadFile(): void {\r\n    this.uploadCallback(this.files);\r\n  }\r\n\r\n  formatSize(bytes: number): string {\r\n    if (bytes === 0) return '0 B';\r\n    const k = 1024;\r\n    const sizes = ['B', 'KB', 'MB', 'GB', 'TB'];\r\n    const i = Math.floor(Math.log(bytes) / Math.log(k));\r\n    const value = parseFloat((bytes / Math.pow(k, i)).toFixed(1));\r\n    return `${value} ${sizes[i]}`;\r\n  }\r\n\r\n  previewUrls = new Map<File, string>();\r\n\r\n  filePreviewUrl(file: File): string | null {\r\n    if (!file || !file.type.startsWith('image/')) {\r\n      return null;\r\n    }\r\n\r\n    if (this.previewUrls.has(file)) {\r\n      return this.previewUrls.get(file)!;\r\n    }\r\n\r\n    const url = URL.createObjectURL(file);\r\n    this.previewUrls.set(file, url);\r\n    return url;\r\n  }\r\n\r\n  downloadFile(file: File): void {\r\n    const url = URL.createObjectURL(file);\r\n    const a = document.createElement('a');\r\n    a.href = url;\r\n    a.download = file.name;\r\n    a.click();\r\n    URL.revokeObjectURL(url);\r\n  }\r\n\r\n  get uploadButton(): UiActionDescriptor {\r\n    return {\r\n      title: this.i18n!.upload ?? '',\r\n      color: 'primary',\r\n      type: UiActionButtonType.RAISED,\r\n      icon: 'upload',\r\n      iconPosition: IconPosition.PRE,\r\n    };\r\n  }\r\n\r\n  get downloadButton(): UiActionDescriptor {\r\n    return {\r\n      title: '',\r\n      color: 'primary',\r\n      type: UiActionButtonType.ICON,\r\n      icon: 'download',\r\n      iconPosition: IconPosition.PRE,\r\n    };\r\n  }\r\n\r\n  get removeButton(): UiActionDescriptor {\r\n    return {\r\n      title: '',\r\n      color: 'primary',\r\n      type: UiActionButtonType.ICON,\r\n      icon: 'close',\r\n      iconColor: 'red',\r\n      iconPosition: IconPosition.PRE,\r\n    };\r\n  }\r\n}\r\n","<div\r\n  class=\"container\"\r\n  (dragover)=\"onDragOver($event)\"\r\n  (dragleave)=\"onDragLeave($event)\"\r\n  (drop)=\"onDrop($event)\"\r\n  [class.dragover]=\"isDragOver\"\r\n>\r\n  <div class=\"fileContainer\" (click)=\"fileInput.click()\">\r\n    <input\r\n      #fileInput\r\n      id=\"addFile\"\r\n      placeholder=\"fileInput\"\r\n      type=\"file\"\r\n      (change)=\"getFile($event)\"\r\n      class=\"file\"\r\n      accept=\"{{ fileFormats?.join(', ') }}\"\r\n      [size]=\"maxSizeMb\"\r\n      [multiple]=\"isMultiple\"\r\n      style=\"display: none\"\r\n    />\r\n    <div class=\"fileUploadContentContainer\">\r\n      <div class=\"icon\">\r\n        <mat-label *ngIf=\"useIconButton\" class=\"addFileButton\">\r\n          <mat-icon color=\"primary\" class=\"addCircle\">add_circle</mat-icon>\r\n        </mat-label>\r\n        <button *ngIf=\"!useIconButton\" mat-raised-button color=\"primary\" class=\"addFileButton\">\r\n          {{ i18n!.addFile }}\r\n        </button>\r\n      </div>\r\n      <div class=\"labels\">\r\n        <mat-label *ngIf=\"useIconButton\" class=\"label primary title\">\r\n          {{ i18n!.addFile }}\r\n        </mat-label>\r\n        <mat-label class=\"label secondary\"> {{ i18n!.browseOrDrag }} </mat-label>\r\n        <mat-label class=\"subLabel primary\"> {{ i18n!.maxSize }} </mat-label>\r\n        <mat-label class=\"subLabel primary\"> {{ i18n!.formats }} </mat-label>\r\n      </div>\r\n      <div class=\"uploadButton\" *ngIf=\"files.length\">\r\n        <ui-action-button (actionClick)=\"uploadFile()\" [descriptor]=\"uploadButton\">\r\n        </ui-action-button>\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n  <div *ngIf=\"errors.length\" class=\"errorMessage\">\r\n    <smart-icon [icon]=\"'error'\" [color]=\"'warn'\"></smart-icon>\r\n    <div class=\"errors\">\r\n      <span *ngFor=\"let error of errors\">{{ error }}</span>\r\n    </div>\r\n  </div>\r\n\r\n  <div *ngIf=\"files.length\" class=\"uploadedFilesContainer\">\r\n    <div *ngFor=\"let file of files; let i = index\" class=\"uploadedFile\">\r\n      <ng-container *ngIf=\"filePreviewUrl(file); else fileIcon\">\r\n        <img [src]=\"filePreviewUrl(file)\" [alt]=\"file.name\" width=\"50\" height=\"50\" />\r\n      </ng-container>\r\n      <ng-template #fileIcon>\r\n        <smart-icon [icon]=\"'insert_drive_file'\"></smart-icon>\r\n      </ng-template>\r\n\r\n      <div class=\"fileData\">\r\n        <div class=\"fileDataContainer\">\r\n          <span class=\"fileName\">{{ file.name }}</span>\r\n          <span class=\"fileSize\">{{ formatSize(file.size) }}</span>\r\n        </div>\r\n      </div>\r\n\r\n      <div class=\"fileActions\">\r\n        <ui-action-button (actionClick)=\"downloadFile(file)\" [descriptor]=\"downloadButton\">\r\n        </ui-action-button>\r\n\r\n        <ui-action-button class=\"removeIcon\" (actionClick)=\"remove(i)\" [descriptor]=\"removeButton\">\r\n        </ui-action-button>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}