@firestitch/file
Advanced tools
Comparing version 12.4.0 to 12.4.1
@@ -21,3 +21,2 @@ import { Observable } from 'rxjs'; | ||
private generateTransformParams; | ||
private alertImageProcessingError; | ||
} |
@@ -30,3 +30,7 @@ import { FsFileConfig } from '../interfaces'; | ||
set name(name: string); | ||
updateImageInfo(): Promise<unknown>; | ||
get imageInfo(): Promise<{ | ||
width: number; | ||
height: number; | ||
exif: any; | ||
}>; | ||
toObject(): { | ||
@@ -33,0 +37,0 @@ name: string; |
@@ -59,5 +59,5 @@ import { __awaiter } from "tslib"; | ||
// Update FsFile info | ||
originFile.updateImageInfo() | ||
.then(result => { | ||
resolve(result); | ||
originFile.imageInfo | ||
.then(() => { | ||
resolve(originFile); | ||
}).catch((error) => { | ||
@@ -86,3 +86,3 @@ reject({ error, originFile }); | ||
try { | ||
yield fsFile.updateImageInfo(); | ||
yield fsFile.imageInfo; | ||
const params = this.generateTransformParams(fsFile, config); | ||
@@ -123,6 +123,3 @@ const resultFile = yield this.transformFile(fsFile, params, config); | ||
} | ||
alertImageProcessingError(file) { | ||
alert(`File ${file.name} can't be processed as image. File was rejected`); | ||
} | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-processor.js","sourceRoot":"","sources":["../../../../src/app/classes/file-processor.ts"],"names":[],"mappings":"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","sourcesContent":["import * as FileAPI from 'fileapi';\nimport * as EXIF from '@firestitch/exif-js';\n\nimport { from, Observable, of } from 'rxjs';\nimport { switchMap } from 'rxjs/operators';\nimport { toInteger } from 'lodash-es';\n\n\nimport { ProcessConfig, FsFile } from '../models';\nimport { ScaleExifImage, createBlob } from '../helpers';\nimport { FsFileConfig } from '../interfaces';\n\n\nexport class FileProcessor {\n\n  constructor() {}\n\n  /**\n   * Process uploaded files\n   * @param files\n   * @param config\n   */\n  public process(files, config: FsFileConfig): Observable<any> {\n    let multiple = true;\n    const processConfig = new ProcessConfig(config);\n\n    if (!Array.isArray(files)) {\n      files = [files];\n      multiple = false;\n    }\n\n    const processedFiles = [];\n    files.forEach((file: FsFile) => {\n\n      if (file.file && file.imageProcess && processConfig.shouldProcess) {\n        const resFilePromise = new Promise((resolve, reject) => {\n          this.applyTransforms(file, resolve, reject, processConfig);\n        });\n        processedFiles.push(resFilePromise);\n      } else {\n        processedFiles.push(file);\n      }\n    });\n\n    return from(Promise.all(processedFiles))\n    .pipe(\n      switchMap((resultFiles) => {\n        if (!multiple && resultFiles[0]) { return of(resultFiles[0]) }\n        return of(resultFiles);\n      })\n    );\n  }\n\n  private async transformFile(originFile: FsFile, transformConfig: any, processConfig: ProcessConfig) {\n    return new Promise((resolve, reject) => {\n      // Transform image by options and rotate if needed\n      FileAPI.Image.transform(\n        originFile.file,\n        [transformConfig],\n        true, // AutoRotate\n        (err, images) => {\n          // Process transformed files\n          if (!err && images[0]) {\n            originFile.exifInfo\n            .then((exifInfo) => {\n              let canvasImage;\n              canvasImage = ScaleExifImage(images[0], exifInfo.Orientation);\n\n              // Convert to blob for create File object\n              canvasImage.toBlob((blob) => {\n                // Save as file to FsFile\n                originFile.file = createBlob([blob], originFile.file.name, originFile.type);\n\n                // Update FsFile info\n                originFile.updateImageInfo()\n                  .then(result => {\n                    resolve(result);\n                  }).catch((error) => {\n                    reject({ error, originFile });\n                  });\n              }, transformConfig.type, canvasImage.quality);\n            }, reject);\n\n          } else {\n            reject(err);\n          }\n        });\n    });\n  }\n\n  /**\n   * Process image file\n   * @param file\n   * @param resolve\n   * @param reject\n   * @param config\n   */\n  private async applyTransforms(fsFile: FsFile, resolve, reject, config: ProcessConfig) {\n    try {\n      await fsFile.updateImageInfo();\n\n      const params = this.generateTransformParams(fsFile, config);\n      const resultFile: any = await this.transformFile(fsFile, params, config);\n      const codes = [];\n      const errors = [];\n\n      if (config.minHeight && fsFile.imageHeight < toInteger(config.minHeight)) {\n        codes.push('minHeight');\n        errors.push(`Height must be at least ${config.minHeight}px.`);\n      }\n\n      if (config.minWidth && fsFile.imageWidth < toInteger(config.minWidth)) {\n        codes.push('minWidth');\n        errors.push(`Width must be at least ${config.minWidth}px.`);\n      }\n\n      if (codes.length) {\n        throw { codes: codes, error: errors.join(' ') };\n      }\n\n      resolve(resultFile);\n\n    } catch (err) {\n      reject(err);\n    }\n  }\n\n  private generateTransformParams(file, config: ProcessConfig) {\n    const transformParams: any = {};\n\n    // Type for result image\n    transformParams.type = (config.format) ? 'image/' + config.format : file.type;\n\n    // Resize\n    transformParams.maxWidth = config.width;\n    transformParams.maxHeight = config.height;\n\n    // Quality for result image\n    if (config.quality !== void 0) {\n      transformParams.quality = config.quality || 1;\n    }\n\n    return transformParams;\n  }\n\n  private alertImageProcessingError(file) {\n    alert(`File ${file.name} can't be processed as image. File was rejected`);\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-processor.js","sourceRoot":"","sources":["../../../../src/app/classes/file-processor.ts"],"names":[],"mappings":"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","sourcesContent":["import * as FileAPI from 'fileapi';\nimport * as EXIF from '@firestitch/exif-js';\n\nimport { from, Observable, of } from 'rxjs';\nimport { switchMap } from 'rxjs/operators';\nimport { toInteger } from 'lodash-es';\n\n\nimport { ProcessConfig, FsFile } from '../models';\nimport { ScaleExifImage, createBlob } from '../helpers';\nimport { FsFileConfig } from '../interfaces';\n\n\nexport class FileProcessor {\n\n  constructor() {}\n\n  /**\n   * Process uploaded files\n   * @param files\n   * @param config\n   */\n  public process(files, config: FsFileConfig): Observable<any> {\n    let multiple = true;\n    const processConfig = new ProcessConfig(config);\n\n    if (!Array.isArray(files)) {\n      files = [files];\n      multiple = false;\n    }\n\n    const processedFiles = [];\n    files.forEach((file: FsFile) => {\n\n      if (file.file && file.imageProcess && processConfig.shouldProcess) {\n        const resFilePromise = new Promise((resolve, reject) => {\n          this.applyTransforms(file, resolve, reject, processConfig);\n        });\n\n        processedFiles.push(resFilePromise);\n      } else {\n        processedFiles.push(file);\n      }\n    });\n\n    return from(Promise.all(processedFiles))\n    .pipe(\n      switchMap((resultFiles) => {\n        if (!multiple && resultFiles[0]) { return of(resultFiles[0]) }\n        return of(resultFiles);\n      })\n    );\n  }\n\n  private async transformFile(originFile: FsFile, transformConfig: any, processConfig: ProcessConfig): Promise<FsFile> {\n    return new Promise((resolve, reject) => {\n      // Transform image by options and rotate if needed\n      FileAPI.Image.transform(\n        originFile.file,\n        [transformConfig],\n        true, // AutoRotate\n        (err, images) => {\n          // Process transformed files\n          if (!err && images[0]) {\n            originFile.exifInfo\n            .then((exifInfo) => {\n              let canvasImage;\n              canvasImage = ScaleExifImage(images[0], exifInfo.Orientation);\n\n              // Convert to blob for create File object\n              canvasImage.toBlob((blob) => {\n                // Save as file to FsFile\n                originFile.file = createBlob([blob], originFile.file.name, originFile.type);\n\n                // Update FsFile info\n                originFile.imageInfo\n                  .then(() => {\n                    resolve(originFile);\n                  }).catch((error) => {\n                    reject({ error, originFile });\n                  });\n              }, transformConfig.type, canvasImage.quality);\n            }, reject);\n\n          } else {\n            reject(err);\n          }\n        });\n    });\n  }\n\n  /**\n   * Process image file\n   * @param file\n   * @param resolve\n   * @param reject\n   * @param config\n   */\n  private async applyTransforms(fsFile: FsFile, resolve, reject, config: ProcessConfig) {\n    try {\n      await fsFile.imageInfo;\n\n      const params = this.generateTransformParams(fsFile, config);\n      const resultFile: any = await this.transformFile(fsFile, params, config);\n      const codes = [];\n      const errors = [];\n\n      if (config.minHeight && fsFile.imageHeight < toInteger(config.minHeight)) {\n        codes.push('minHeight');\n        errors.push(`Height must be at least ${config.minHeight}px.`);\n      }\n\n      if (config.minWidth && fsFile.imageWidth < toInteger(config.minWidth)) {\n        codes.push('minWidth');\n        errors.push(`Width must be at least ${config.minWidth}px.`);\n      }\n\n      if (codes.length) {\n        throw { codes: codes, error: errors.join(' ') };\n      }\n\n      resolve(resultFile);\n\n    } catch (err) {\n      reject(err);\n    }\n  }\n\n  private generateTransformParams(file, config: ProcessConfig) {\n    const transformParams: any = {};\n\n    // Type for result image\n    transformParams.type = (config.format) ? 'image/' + config.format : file.type;\n\n    // Resize\n    transformParams.maxWidth = config.width;\n    transformParams.maxHeight = config.height;\n\n    // Quality for result image\n    if (config.quality !== void 0) {\n      transformParams.quality = config.quality || 1;\n    }\n\n    return transformParams;\n  }\n}\n"]} |
@@ -121,3 +121,3 @@ import { EventEmitter, Component, Input, Output, ViewChild, Inject, Optional, NgZone, ChangeDetectionStrategy, forwardRef, ChangeDetectorRef, QueryList, ContentChildren } from '@angular/core'; | ||
.pipe(switchMap(() => { | ||
return this.minWidth || this.minHeight ? from(fsFile.updateImageInfo()) : of(true); | ||
return this.minWidth || this.minHeight ? from(fsFile.imageInfo) : of(true); | ||
}), takeUntil(this._destroy$)) | ||
@@ -238,2 +238,2 @@ .subscribe(() => { | ||
}] } }); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fs-file-picker.component.js","sourceRoot":"","sources":["../../../../../src/app/components/fs-file-picker/fs-file-picker.component.ts","../../../../../src/app/components/fs-file-picker/fs-file-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  EventEmitter,\n  Component,\n  Input,\n  Output,\n  ViewChild,\n  Inject,\n  Optional,\n  OnInit,\n  NgZone,\n  ChangeDetectionStrategy,\n  forwardRef,\n  ChangeDetectorRef,\n  QueryList,\n  ContentChildren,\n  TemplateRef,\n  OnDestroy\n} from '@angular/core';\nimport { AbstractControl, AsyncValidator, ControlValueAccessor, NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors, Validator } from '@angular/forms';\n\nimport { FsFileLabelDirective } from '../../directives/fs-file-label.directive';\nimport { FsFileDragBaseComponent } from '../fs-file-drag-base/fs-file-drag-base';\nimport { InputProcessor } from '../../classes';\nimport { FsFile } from '../../models/fs-file';\nimport { CordovaService } from '../../services/cordova.service';\nimport { FS_FILE_MODULE_CONFIG } from '../../fs-file.providers';\nimport { from, Observable, of, Subject } from 'rxjs';\nimport { map, switchMap, takeUntil } from 'rxjs/operators';\n\n\n@Component({\n  selector: 'fs-file-picker',\n  templateUrl: 'fs-file-picker.component.html',\n  styleUrls: ['fs-file-picker.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => FsFilePickerComponent),\n    multi: true,\n  },\n  {\n    provide: NG_VALIDATORS, \n    useExisting: FsFilePickerComponent,\n    multi: true\n  }\n  ],  \n})\nexport class FsFilePickerComponent extends FsFileDragBaseComponent implements OnInit, ControlValueAccessor, AsyncValidator, OnDestroy {\n\n  @ViewChild('fileInput') \n  public fileInput: any;\n\n  @ContentChildren(FsFileLabelDirective)\n  public labels: QueryList<TemplateRef<any>>;\n\n  @Input() public minWidth = 0;\n  @Input() public minHeight = 0;\n  @Input() public imageWidth;\n  @Input() public imageHeight;\n  @Input() public imageQuality;\n  @Input() public label;\n  @Input() public showFilename = true;\n  @Input() public allowDownload = false;\n  @Input() public allowReupload = true;\n  @Input() public allowRemove = false;\n\n  @Input('url') set url(url) {\n    this.file = url ? new FsFile(url) : null;\n  }\n\n  @Input('file') set file(file) {\n    if(file) {\n      if(file instanceof FsFile) {\n        this._file = file;\n          \n      } else {\n        this._file = new FsFile(file);\n      }\n    } else {\n      this._file = null;\n    }\n  }\n\n  @Input()\n  public set accept(value) {\n    this.inputProcessor.accept = value;\n  }\n\n  public get accept() {\n    return this.inputProcessor.accept || '*';\n  }\n  \n  public get file() {\n    return this._file;\n  }\n\n  @Input()\n  public set disabled(value) {\n    this._disabled = value;\n  }\n\n  public get disabled() {\n    return this._disabled;\n  }\n  \n  @Input()\n  public set previewWidth(value: string | number) {\n    this._previewWidth = Number.isInteger(value) ? `${value}px` : value?.toString() || '';\n  }\n\n  public get previewWidth() {\n    return this._previewWidth;\n  }\n  \n  @Input()\n  public set previewHeight(value: string | number) {\n    this._previewHeight = Number.isInteger(value) ? `${value}px` : value?.toString() || '';\n  }\n\n  public get previewHeight() {\n    return this._previewHeight;\n  }\n\n  @Output() public select = new EventEmitter<any>();\n  @Output() public remove = new EventEmitter();\n  @Output() public download = new EventEmitter<FsFile>();\n\n  public onChange: any = () => {};\n  public onTouch: any = () => {};\n  public registerOnChange(fn): void { this.onChange = fn; }\n  public registerOnTouched(fn): void { this.onTouch = fn; }\n  public inputProcessor = null;\n  public instruction = 'Drag & Drop your file or use the button below';\n  public _file: FsFile;\n\n  private _destroy$ = new Subject();\n  private _disabled: boolean;  \n  private _previewWidth = '150px';\n  private _previewHeight = '150px';\n\n  public constructor(\n    @Optional() @Inject(FS_FILE_MODULE_CONFIG) private _moduleConfig,\n    private _cordovaService: CordovaService,\n    private _ngZone: NgZone,\n    private _cdRef: ChangeDetectorRef,\n  ) {\n    super();\n    this.inputProcessor = new InputProcessor(_cordovaService, _ngZone);\n  }\n\n  public ngOnInit() {\n    if (this._moduleConfig) {\n      if (this.allowDownload === void 0) {\n        this.allowDownload = this._moduleConfig.allowDownload\n      }\n\n      if (this.allowRemove === void 0) {\n        this.allowRemove = this._moduleConfig.allowRemove\n      }\n    }\n  }\n\n  public validate(control: AbstractControl): Promise<ValidationErrors | null> |  null { \n    if(this.file?.typeImage && (this.minWidth || this.minHeight)) {\n      // if(this.file.imageWidth < this.minWidth) {\n      //   return { minWidth: `Minimum width ${this.minWidth}px` };\n      // }\n\n      // if(this.file.imageHeight < this.minHeight) {\n      //   return { minWidth: `Minimum height ${this.minHeight}px` };\n      // }      \n    }\n\n    return null;\n  } \n\n  public get previewPercent() {\n    return String(this._previewWidth).match(/%/);\n  }\n\n  public writeValue(file): void {\n    this.file = file;\n    this._cdRef.markForCheck();\n  }\n\n  public selectFile(fsFile: FsFile) {\n    of(true)    \n    .pipe(\n      switchMap(() => {\n        return this.minWidth || this.minHeight ? from(fsFile.updateImageInfo()) : of(true);\n      }),\n      takeUntil(this._destroy$),\n    )\n    .subscribe(() => {\n      this.file = fsFile;\n      this.select.emit(fsFile);\n      this.onChange(fsFile);\n    });\n  }\n\n  public removeFile() {\n    this.file = void 0;\n    this.remove.emit(this.file);\n    this.onChange(null);\n  }\n\n  public actionClick(event: { event: PointerEvent }) {\n    event.event.stopPropagation();\n  }\n\n  public downloadClicked(event: { event: PointerEvent }) {\n    event.event.stopPropagation();\n\n    if(this.download.observers.length) {\n      event.event.preventDefault();\n      this.download.emit(this.file);\n    }\n  }\n  \n  public ngOnDestroy(): void {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  private _isNumeric(value) {\n    return /^-?\\d+$/.test(value);\n  }\n\n}\n","<fs-label-field \n    class=\"fs-form-wrapper fs-label\"\n    [ngClass]=\"{ 'percent-preview': previewPercent }\">\n  <ng-container *ngIf=\"label; else labelContent\">\n    <fs-label>{{label}}</fs-label>\n  </ng-container>\n  <ng-template #labelContent>\n    <fs-label *ngIf=\"labels.length\">\n      <ng-content select=\"[fsFileLabel]\"></ng-content>\n    </fs-label>\n  </ng-template>\n  <fs-file\n      [accept]=\"accept\"\n      (select)=\"selectFile($event)\"\n      [imageWidth]=\"imageWidth\"\n      [imageHeight]=\"imageHeight\"\n      [imageQuality]=\"imageQuality\"\n      [disabled]=\"disabled\">\n    <div \n        class=\"wrap\"\n        [style.width]=\"previewWidth\"\n        [style.height]=\"previewHeight\">\n      <fs-file-preview\n          class=\"preview\"\n          *ngIf=\"file; else preview\"\n          (remove)=\"removeFile()\"\n          [file]=\"file\"\n          [showFilename]=\"showFilename\"\n          [previewHeight]=\"null\"\n          [previewWidth]=\"null\">\n        <ng-template\n            fs-file-preview-action\n            placement=\"top-right\"\n            action=\"remove\"\n            tooltip=\"Remove\"\n            *ngIf=\"allowRemove\" \n            (click)=\"actionClick($event)\">\n          <mat-icon>close</mat-icon>\n        </ng-template>\n        <ng-template\n            fs-file-preview-action\n            placement=\"bottom-right\"\n            tooltip=\"Reupload\"\n            *ngIf=\"allowReupload\">\n          <mat-icon>cloud_upload</mat-icon>\n        </ng-template>\n        <ng-template\n            fs-file-preview-action\n            placement=\"bottom-left\"\n            action=\"download\"\n            tooltip=\"Download\"\n            [hide]=\"!(allowDownload && ((download.observers.length && file) || file.url))\"\n            (click)=\"downloadClicked($event)\">\n          <a \n              [href]=\"file.url\" \n              target=\"_blank\" \n              tabindex=\"-1\" \n              class=\"download\">\n            <mat-icon>cloud_download</mat-icon>\n          </a>\n        </ng-template>\n      </fs-file-preview>\n\n      <ng-template #preview>\n        <div class=\"select\">\n          <mat-icon>cloud_upload</mat-icon>\n          <div class=\"instruction\">{{instruction}}</div>\n          <div class=\"mat-raised-button mat-primary\">Upload</div>\n        </div>\n      </ng-template>\n    </div>\n  </fs-file>\n  <fs-label-message class=\"fs-form-message\">\n    <span class=\"fs-form-hint\">\n      <ng-content select=\"[fsFileHint]\"></ng-content>\n      <ng-content select=\"[fsFileMessageLabel]\"></ng-content>\n    </span>\n  </fs-label-message>\n</fs-label-field>"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fs-file-picker.component.js","sourceRoot":"","sources":["../../../../../src/app/components/fs-file-picker/fs-file-picker.component.ts","../../../../../src/app/components/fs-file-picker/fs-file-picker.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,YAAY,EACZ,SAAS,EACT,KAAK,EACL,MAAM,EACN,SAAS,EACT,MAAM,EACN,QAAQ,EAER,MAAM,EACN,uBAAuB,EACvB,UAAU,EACV,iBAAiB,EACjB,SAAS,EACT,eAAe,EAGhB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAyD,aAAa,EAAE,iBAAiB,EAA+B,MAAM,gBAAgB,CAAC;AAEtJ,OAAO,EAAE,oBAAoB,EAAE,MAAM,0CAA0C,CAAC;AAChF,OAAO,EAAE,uBAAuB,EAAE,MAAM,wCAAwC,CAAC;AACjF,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AAC/C,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAC9C,OAAO,EAAE,cAAc,EAAE,MAAM,gCAAgC,CAAC;AAChE,OAAO,EAAE,qBAAqB,EAAE,MAAM,yBAAyB,CAAC;AAChE,OAAO,EAAE,IAAI,EAAc,EAAE,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AACrD,OAAO,EAAO,SAAS,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;;;;;;;;;AAqB3D,MAAM,OAAO,qBAAsB,SAAQ,uBAAuB;IA6FhE,YACqD,aAAa,EACxD,eAA+B,EAC/B,OAAe,EACf,MAAyB;QAEjC,KAAK,EAAE,CAAC;QAL2C,kBAAa,GAAb,aAAa,CAAA;QACxD,oBAAe,GAAf,eAAe,CAAgB;QAC/B,YAAO,GAAP,OAAO,CAAQ;QACf,WAAM,GAAN,MAAM,CAAmB;QAzFnB,aAAQ,GAAG,CAAC,CAAC;QACb,cAAS,GAAG,CAAC,CAAC;QAKd,iBAAY,GAAG,IAAI,CAAC;QACpB,kBAAa,GAAG,KAAK,CAAC;QACtB,kBAAa,GAAG,IAAI,CAAC;QACrB,gBAAW,GAAG,KAAK,CAAC;QA2DnB,WAAM,GAAG,IAAI,YAAY,EAAO,CAAC;QACjC,WAAM,GAAG,IAAI,YAAY,EAAE,CAAC;QAC5B,aAAQ,GAAG,IAAI,YAAY,EAAU,CAAC;QAEhD,aAAQ,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;QACzB,YAAO,GAAQ,GAAG,EAAE,GAAE,CAAC,CAAC;QAGxB,mBAAc,GAAG,IAAI,CAAC;QACtB,gBAAW,GAAG,+CAA+C,CAAC;QAG7D,cAAS,GAAG,IAAI,OAAO,EAAE,CAAC;QAE1B,kBAAa,GAAG,OAAO,CAAC;QACxB,mBAAc,GAAG,OAAO,CAAC;QAS/B,IAAI,CAAC,cAAc,GAAG,IAAI,cAAc,CAAC,eAAe,EAAE,OAAO,CAAC,CAAC;IACrE,CAAC;IAlFD,IAAkB,GAAG,CAAC,GAAG;QACvB,IAAI,CAAC,IAAI,GAAG,GAAG,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC3C,CAAC;IAED,IAAmB,IAAI,CAAC,IAAI;QAC1B,IAAG,IAAI,EAAE;YACP,IAAG,IAAI,YAAY,MAAM,EAAE;gBACzB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;aAEnB;iBAAM;gBACL,IAAI,CAAC,KAAK,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC;aAC/B;SACF;aAAM;YACL,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;SACnB;IACH,CAAC;IAED,IACW,MAAM,CAAC,KAAK;QACrB,IAAI,CAAC,cAAc,CAAC,MAAM,GAAG,KAAK,CAAC;IACrC,CAAC;IAED,IAAW,MAAM;QACf,OAAO,IAAI,CAAC,cAAc,CAAC,MAAM,IAAI,GAAG,CAAC;IAC3C,CAAC;IAED,IAAW,IAAI;QACb,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED,IACW,QAAQ,CAAC,KAAK;QACvB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IAED,IAAW,QAAQ;QACjB,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED,IACW,YAAY,CAAC,KAAsB;QAC5C,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,IAAI,CAAC,CAAC,CAAC,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,QAAQ,EAAE,KAAI,EAAE,CAAC;IACxF,CAAC;IAED,IAAW,YAAY;QACrB,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IAED,IACW,aAAa,CAAC,KAAsB;QAC7C,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,IAAI,CAAC,CAAC,CAAC,CAAA,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,QAAQ,EAAE,KAAI,EAAE,CAAC;IACzF,CAAC;IAED,IAAW,aAAa;QACtB,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IAQM,gBAAgB,CAAC,EAAE,IAAU,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC,CAAC,CAAC;IAClD,iBAAiB,CAAC,EAAE,IAAU,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC,CAAC,CAAC;IAoBlD,QAAQ;QACb,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,IAAI,CAAC,aAAa,KAAK,KAAK,CAAC,EAAE;gBACjC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAA;aACtD;YAED,IAAI,IAAI,CAAC,WAAW,KAAK,KAAK,CAAC,EAAE;gBAC/B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,WAAW,CAAA;aAClD;SACF;IACH,CAAC;IAEM,QAAQ,CAAC,OAAwB;;QACtC,IAAG,CAAA,MAAA,IAAI,CAAC,IAAI,0CAAE,SAAS,KAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,SAAS,CAAC,EAAE;YAC5D,6CAA6C;YAC7C,6DAA6D;YAC7D,IAAI;YAEJ,+CAA+C;YAC/C,+DAA+D;YAC/D,UAAU;SACX;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAW,cAAc;QACvB,OAAO,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;IAC/C,CAAC;IAEM,UAAU,CAAC,IAAI;QACpB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;IAC7B,CAAC;IAEM,UAAU,CAAC,MAAc;QAC9B,EAAE,CAAC,IAAI,CAAC;aACP,IAAI,CACH,SAAS,CAAC,GAAG,EAAE;YACb,OAAO,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC;QAC7E,CAAC,CAAC,EACF,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAC1B;aACA,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC;YACnB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACzB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QACxB,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,UAAU;QACf,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC,CAAC;QACnB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IACtB,CAAC;IAEM,WAAW,CAAC,KAA8B;QAC/C,KAAK,CAAC,KAAK,CAAC,eAAe,EAAE,CAAC;IAChC,CAAC;IAEM,eAAe,CAAC,KAA8B;QACnD,KAAK,CAAC,KAAK,CAAC,eAAe,EAAE,CAAC;QAE9B,IAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,MAAM,EAAE;YACjC,KAAK,CAAC,KAAK,CAAC,cAAc,EAAE,CAAC;YAC7B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAC/B;IACH,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;IAEO,UAAU,CAAC,KAAK;QACtB,OAAO,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;;mHAnLU,qBAAqB,kBA8FV,qBAAqB;uGA9FhC,qBAAqB,wgBAbrB;QACT;YACA,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC;YACpD,KAAK,EAAE,IAAI;SACZ;QACD;YACE,OAAO,EAAE,aAAa;YACtB,WAAW,EAAE,qBAAqB;YAClC,KAAK,EAAE,IAAI;SACZ;KACA,iDAOgB,oBAAoB,4JCrDvC,qnFA8EiB;4FD9BJ,qBAAqB;kBAlBjC,SAAS;mBAAC;oBACT,QAAQ,EAAE,gBAAgB;oBAC1B,WAAW,EAAE,+BAA+B;oBAC5C,SAAS,EAAE,CAAC,+BAA+B,CAAC;oBAC5C,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,SAAS,EAAE;wBACT;4BACA,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,sBAAsB,CAAC;4BACpD,KAAK,EAAE,IAAI;yBACZ;wBACD;4BACE,OAAO,EAAE,aAAa;4BACtB,WAAW,uBAAuB;4BAClC,KAAK,EAAE,IAAI;yBACZ;qBACA;iBACF;;0BA+FI,QAAQ;;0BAAI,MAAM;2BAAC,qBAAqB;8HA3FpC,SAAS;sBADf,SAAS;uBAAC,WAAW;gBAIf,MAAM;sBADZ,eAAe;uBAAC,oBAAoB;gBAGrB,QAAQ;sBAAvB,KAAK;gBACU,SAAS;sBAAxB,KAAK;gBACU,UAAU;sBAAzB,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBACU,YAAY;sBAA3B,KAAK;gBACU,KAAK;sBAApB,KAAK;gBACU,YAAY;sBAA3B,KAAK;gBACU,aAAa;sBAA5B,KAAK;gBACU,aAAa;sBAA5B,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBAEY,GAAG;sBAApB,KAAK;uBAAC,KAAK;gBAIO,IAAI;sBAAtB,KAAK;uBAAC,MAAM;gBAcF,MAAM;sBADhB,KAAK;gBAcK,QAAQ;sBADlB,KAAK;gBAUK,YAAY;sBADtB,KAAK;gBAUK,aAAa;sBADvB,KAAK;gBASW,MAAM;sBAAtB,MAAM;gBACU,MAAM;sBAAtB,MAAM;gBACU,QAAQ;sBAAxB,MAAM","sourcesContent":["import {\n  EventEmitter,\n  Component,\n  Input,\n  Output,\n  ViewChild,\n  Inject,\n  Optional,\n  OnInit,\n  NgZone,\n  ChangeDetectionStrategy,\n  forwardRef,\n  ChangeDetectorRef,\n  QueryList,\n  ContentChildren,\n  TemplateRef,\n  OnDestroy\n} from '@angular/core';\nimport { AbstractControl, AsyncValidator, ControlValueAccessor, NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors, Validator } from '@angular/forms';\n\nimport { FsFileLabelDirective } from '../../directives/fs-file-label.directive';\nimport { FsFileDragBaseComponent } from '../fs-file-drag-base/fs-file-drag-base';\nimport { InputProcessor } from '../../classes';\nimport { FsFile } from '../../models/fs-file';\nimport { CordovaService } from '../../services/cordova.service';\nimport { FS_FILE_MODULE_CONFIG } from '../../fs-file.providers';\nimport { from, Observable, of, Subject } from 'rxjs';\nimport { map, switchMap, takeUntil } from 'rxjs/operators';\n\n\n@Component({\n  selector: 'fs-file-picker',\n  templateUrl: 'fs-file-picker.component.html',\n  styleUrls: ['fs-file-picker.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => FsFilePickerComponent),\n    multi: true,\n  },\n  {\n    provide: NG_VALIDATORS, \n    useExisting: FsFilePickerComponent,\n    multi: true\n  }\n  ],  \n})\nexport class FsFilePickerComponent extends FsFileDragBaseComponent implements OnInit, ControlValueAccessor, AsyncValidator, OnDestroy {\n\n  @ViewChild('fileInput') \n  public fileInput: any;\n\n  @ContentChildren(FsFileLabelDirective)\n  public labels: QueryList<TemplateRef<any>>;\n\n  @Input() public minWidth = 0;\n  @Input() public minHeight = 0;\n  @Input() public imageWidth;\n  @Input() public imageHeight;\n  @Input() public imageQuality;\n  @Input() public label;\n  @Input() public showFilename = true;\n  @Input() public allowDownload = false;\n  @Input() public allowReupload = true;\n  @Input() public allowRemove = false;\n\n  @Input('url') set url(url) {\n    this.file = url ? new FsFile(url) : null;\n  }\n\n  @Input('file') set file(file) {\n    if(file) {\n      if(file instanceof FsFile) {\n        this._file = file;\n          \n      } else {\n        this._file = new FsFile(file);\n      }\n    } else {\n      this._file = null;\n    }\n  }\n\n  @Input()\n  public set accept(value) {\n    this.inputProcessor.accept = value;\n  }\n\n  public get accept() {\n    return this.inputProcessor.accept || '*';\n  }\n  \n  public get file() {\n    return this._file;\n  }\n\n  @Input()\n  public set disabled(value) {\n    this._disabled = value;\n  }\n\n  public get disabled() {\n    return this._disabled;\n  }\n  \n  @Input()\n  public set previewWidth(value: string | number) {\n    this._previewWidth = Number.isInteger(value) ? `${value}px` : value?.toString() || '';\n  }\n\n  public get previewWidth() {\n    return this._previewWidth;\n  }\n  \n  @Input()\n  public set previewHeight(value: string | number) {\n    this._previewHeight = Number.isInteger(value) ? `${value}px` : value?.toString() || '';\n  }\n\n  public get previewHeight() {\n    return this._previewHeight;\n  }\n\n  @Output() public select = new EventEmitter<any>();\n  @Output() public remove = new EventEmitter();\n  @Output() public download = new EventEmitter<FsFile>();\n\n  public onChange: any = () => {};\n  public onTouch: any = () => {};\n  public registerOnChange(fn): void { this.onChange = fn; }\n  public registerOnTouched(fn): void { this.onTouch = fn; }\n  public inputProcessor = null;\n  public instruction = 'Drag & Drop your file or use the button below';\n  public _file: FsFile;\n\n  private _destroy$ = new Subject();\n  private _disabled: boolean;  \n  private _previewWidth = '150px';\n  private _previewHeight = '150px';\n\n  public constructor(\n    @Optional() @Inject(FS_FILE_MODULE_CONFIG) private _moduleConfig,\n    private _cordovaService: CordovaService,\n    private _ngZone: NgZone,\n    private _cdRef: ChangeDetectorRef,\n  ) {\n    super();\n    this.inputProcessor = new InputProcessor(_cordovaService, _ngZone);\n  }\n\n  public ngOnInit() {\n    if (this._moduleConfig) {\n      if (this.allowDownload === void 0) {\n        this.allowDownload = this._moduleConfig.allowDownload\n      }\n\n      if (this.allowRemove === void 0) {\n        this.allowRemove = this._moduleConfig.allowRemove\n      }\n    }\n  }\n\n  public validate(control: AbstractControl): Promise<ValidationErrors | null> |  null { \n    if(this.file?.typeImage && (this.minWidth || this.minHeight)) {\n      // if(this.file.imageWidth < this.minWidth) {\n      //   return { minWidth: `Minimum width ${this.minWidth}px` };\n      // }\n\n      // if(this.file.imageHeight < this.minHeight) {\n      //   return { minWidth: `Minimum height ${this.minHeight}px` };\n      // }      \n    }\n\n    return null;\n  } \n\n  public get previewPercent() {\n    return String(this._previewWidth).match(/%/);\n  }\n\n  public writeValue(file): void {\n    this.file = file;\n    this._cdRef.markForCheck();\n  }\n\n  public selectFile(fsFile: FsFile) {\n    of(true)    \n    .pipe(\n      switchMap(() => {\n        return this.minWidth || this.minHeight ? from(fsFile.imageInfo) : of(true);\n      }),\n      takeUntil(this._destroy$),\n    )\n    .subscribe(() => {\n      this.file = fsFile;\n      this.select.emit(fsFile);\n      this.onChange(fsFile);\n    });\n  }\n\n  public removeFile() {\n    this.file = void 0;\n    this.remove.emit(this.file);\n    this.onChange(null);\n  }\n\n  public actionClick(event: { event: PointerEvent }) {\n    event.event.stopPropagation();\n  }\n\n  public downloadClicked(event: { event: PointerEvent }) {\n    event.event.stopPropagation();\n\n    if(this.download.observers.length) {\n      event.event.preventDefault();\n      this.download.emit(this.file);\n    }\n  }\n  \n  public ngOnDestroy(): void {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  private _isNumeric(value) {\n    return /^-?\\d+$/.test(value);\n  }\n\n}\n","<fs-label-field \n    class=\"fs-form-wrapper fs-label\"\n    [ngClass]=\"{ 'percent-preview': previewPercent }\">\n  <ng-container *ngIf=\"label; else labelContent\">\n    <fs-label>{{label}}</fs-label>\n  </ng-container>\n  <ng-template #labelContent>\n    <fs-label *ngIf=\"labels.length\">\n      <ng-content select=\"[fsFileLabel]\"></ng-content>\n    </fs-label>\n  </ng-template>\n  <fs-file\n      [accept]=\"accept\"\n      (select)=\"selectFile($event)\"\n      [imageWidth]=\"imageWidth\"\n      [imageHeight]=\"imageHeight\"\n      [imageQuality]=\"imageQuality\"\n      [disabled]=\"disabled\">\n    <div \n        class=\"wrap\"\n        [style.width]=\"previewWidth\"\n        [style.height]=\"previewHeight\">\n      <fs-file-preview\n          class=\"preview\"\n          *ngIf=\"file; else preview\"\n          (remove)=\"removeFile()\"\n          [file]=\"file\"\n          [showFilename]=\"showFilename\"\n          [previewHeight]=\"null\"\n          [previewWidth]=\"null\">\n        <ng-template\n            fs-file-preview-action\n            placement=\"top-right\"\n            action=\"remove\"\n            tooltip=\"Remove\"\n            *ngIf=\"allowRemove\" \n            (click)=\"actionClick($event)\">\n          <mat-icon>close</mat-icon>\n        </ng-template>\n        <ng-template\n            fs-file-preview-action\n            placement=\"bottom-right\"\n            tooltip=\"Reupload\"\n            *ngIf=\"allowReupload\">\n          <mat-icon>cloud_upload</mat-icon>\n        </ng-template>\n        <ng-template\n            fs-file-preview-action\n            placement=\"bottom-left\"\n            action=\"download\"\n            tooltip=\"Download\"\n            [hide]=\"!(allowDownload && ((download.observers.length && file) || file.url))\"\n            (click)=\"downloadClicked($event)\">\n          <a \n              [href]=\"file.url\" \n              target=\"_blank\" \n              tabindex=\"-1\" \n              class=\"download\">\n            <mat-icon>cloud_download</mat-icon>\n          </a>\n        </ng-template>\n      </fs-file-preview>\n\n      <ng-template #preview>\n        <div class=\"select\">\n          <mat-icon>cloud_upload</mat-icon>\n          <div class=\"instruction\">{{instruction}}</div>\n          <div class=\"mat-raised-button mat-primary\">Upload</div>\n        </div>\n      </ng-template>\n    </div>\n  </fs-file>\n  <fs-label-message class=\"fs-form-message\">\n    <span class=\"fs-form-hint\">\n      <ng-content select=\"[fsFileHint]\"></ng-content>\n      <ng-content select=\"[fsFileMessageLabel]\"></ng-content>\n    </span>\n  </fs-label-message>\n</fs-label-field>"]} |
@@ -31,5 +31,5 @@ import * as EXIF from '@firestitch/exif-js'; | ||
return new Promise((resolve, reject) => { | ||
this.updateImageInfo() | ||
.then(() => { | ||
resolve(this._imageWidth); | ||
this.imageInfo | ||
.then((data) => { | ||
resolve(data.exif); | ||
}, reject); | ||
@@ -40,5 +40,5 @@ }); | ||
return new Promise((resolve, reject) => { | ||
this.updateImageInfo() | ||
.then(() => { | ||
resolve(this._imageHeight); | ||
this.imageInfo | ||
.then((data) => { | ||
resolve(data.height); | ||
}, reject); | ||
@@ -49,5 +49,5 @@ }); | ||
return new Promise((resolve, reject) => { | ||
this.updateImageInfo() | ||
.then(() => { | ||
resolve(this._exifInfo); | ||
this.imageInfo | ||
.then((data) => { | ||
resolve(data.exif); | ||
}, reject); | ||
@@ -94,5 +94,9 @@ }); | ||
} | ||
updateImageInfo() { | ||
get imageInfo() { | ||
if (!this.typeImage || this._exifInfo) { | ||
return Promise.resolve(this); | ||
return Promise.resolve({ | ||
width: this._imageWidth, | ||
height: this._imageHeight, | ||
exif: this._exifInfo, | ||
}); | ||
} | ||
@@ -126,3 +130,7 @@ const exif = new Promise((resolve, reject) => { | ||
this._imageHeight = data[1].height; | ||
resolve(this); | ||
resolve({ | ||
width: this._imageWidth, | ||
height: this._imageHeight, | ||
exif: this._exifInfo, | ||
}); | ||
}, (err) => { | ||
@@ -148,2 +156,2 @@ reject(err); | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fs-file.js","sourceRoot":"","sources":["../../../../src/app/models/fs-file.ts"],"names":[],"mappings":"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","sourcesContent":["import * as EXIF from '@firestitch/exif-js';\n\nimport * as FileAPI from 'fileapi';\n\nimport { FsFileConfig } from '../interfaces';\nimport { createBlob } from '../helpers';\n\n\nexport class FsFile {\n\n  public progress = false;\n  public rotate: number;\n  public extension: string;\n  public type: string;\n  public url = '';\n  public size: number;\n\n  private _file: any;\n  private _name: string;\n  private _fileOptions: FsFileConfig;\n  private _fileExists = false;\n  private _imageWidth: number;\n  private _imageHeight: number;\n  private _exifInfo: any;  \n\n  constructor(obj?: File|Blob|string, filename?: string) {\n    if (obj instanceof File || obj instanceof Blob) {\n      this.file = obj;\n    } else {\n      if(obj) {\n        const url = new URL(obj);\n        filename = filename || url.pathname.split('/').pop();\n        this.url = url.href;\n      }\n\n      let type = '';\n      if (filename) {\n        const match = filename.toLowerCase().match(/([^\\.]+)$/);\n        this.extension = match ? match[1] : '';\n\n        const mime = this.extension.match(/(jpe?g|png|gif|tiff?|bmp|svg)/) ? 'image' : 'application';\n        type = mime + '/' + this.extension;\n      }\n\n      this.file = createBlob([''], filename, type);\n    }\n\n    this._checkIfFileExists();\n  }\n\n  public get imageWidth(): Promise<number> {\n    return new Promise((resolve, reject) => {\n      this.updateImageInfo()\n      .then(() => {\n        resolve(this._imageWidth);\n      }, reject);\n    });\n  }\n\n  public get imageHeight(): Promise<number> {\n    return new Promise((resolve, reject) => {\n      this.updateImageInfo()\n        .then(() => {\n          resolve(this._imageHeight);\n        }, reject);\n    });\n  }\n\n  public get exifInfo(): Promise<any> {\n    return new Promise((resolve, reject) => {\n      this.updateImageInfo()\n        .then(() => {\n          resolve(this._exifInfo);\n        }, reject);\n    });\n  }\n\n  public get typeImage() {\n    return this.type.match(/^image/) !== null;\n  }\n\n  public get typeSvg() {\n    return this.type.match(/\\/svg/);\n  }\n\n  public get imageProcess() {\n    return this.typeImage && !this.typeSvg;\n  }\n\n  public get exists() {\n    return this._fileExists;\n  }\n\n  public get file() {\n    return this._file;\n  }\n\n  public get name() {\n    return this._name;\n  }\n\n  public set fileOptions(value) {\n    this._fileOptions = value;\n  }\n\n  public get fileOptions() {\n    return this._fileOptions;\n  }\n\n  public set file(value) {\n    this._file = value;\n    this.size = value.size;\n    this.name = value.name;\n    this.type = value.type;\n    this._checkIfFileExists();\n  }\n\n  public set name(name) {\n    this._name = name;\n    const parts = String(name).split('.');\n    if (parts.length > 1) {\n      this.extension = parts[parts.length - 1];\n    }\n  }\n\n  public updateImageInfo() {\n    if (!this.typeImage || this._exifInfo) {\n      return Promise.resolve(this);\n    }\n\n    const exif = new Promise((resolve, reject) => {\n      const fr = new FileReader();\n      fr.onload = () => {\n        var exif = EXIF.readFromBinaryFile(fr.result);\n        resolve(exif);\n      };\n\n      fr.onerror = () => {\n        reject(fr.error);\n      }\n\n      fr.readAsArrayBuffer(this.file);\n    });\n\n    const dims = new Promise((resolve, reject) => {\n      FileAPI.getInfo(this.file, (err, info) => {\n        if (!err) {\n          resolve(info);\n        } else {\n          reject(err);\n        }\n      });\n    });\n\n    return new Promise((resolve, reject) => {\n      Promise.all([exif, dims])\n      .then((data: any) => {\n        this._exifInfo = data[0] || {};\n        this._imageWidth = data[1].width;\n        this._imageHeight = data[1].height;\n        resolve(this);\n      },(err) => {\n        reject(err);\n      });\n    });\n  }\n\n  public toObject() {\n    return {\n      name: this._name,\n      type: this.type,\n      size: this.size,\n      progress: this.progress,\n      extension: this.extension,\n      imageWidth: this.imageWidth,\n      imageHeight: this.imageHeight\n    }\n  }\n\n  private _checkIfFileExists() {\n    this._fileExists = !!this.name || !!this.url\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fs-file.js","sourceRoot":"","sources":["../../../../src/app/models/fs-file.ts"],"names":[],"mappings":"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","sourcesContent":["import * as EXIF from '@firestitch/exif-js';\n\nimport * as FileAPI from 'fileapi';\n\nimport { FsFileConfig } from '../interfaces';\nimport { createBlob } from '../helpers';\n\n\nexport class FsFile {\n\n  public progress = false;\n  public rotate: number;\n  public extension: string;\n  public type: string;\n  public url = '';\n  public size: number;\n\n  private _file: any;\n  private _name: string;\n  private _fileOptions: FsFileConfig;\n  private _fileExists = false;\n  private _imageWidth: number;\n  private _imageHeight: number;\n  private _exifInfo: any;  \n\n  constructor(obj?: File|Blob|string, filename?: string) {\n    if (obj instanceof File || obj instanceof Blob) {\n      this.file = obj;\n    } else {\n      if(obj) {\n        const url = new URL(obj);\n        filename = filename || url.pathname.split('/').pop();\n        this.url = url.href;\n      }\n\n      let type = '';\n      if (filename) {\n        const match = filename.toLowerCase().match(/([^\\.]+)$/);\n        this.extension = match ? match[1] : '';\n\n        const mime = this.extension.match(/(jpe?g|png|gif|tiff?|bmp|svg)/) ? 'image' : 'application';\n        type = mime + '/' + this.extension;\n      }\n\n      this.file = createBlob([''], filename, type);\n    }\n\n    this._checkIfFileExists();\n  }\n\n  public get imageWidth(): Promise<number> {\n    return new Promise((resolve, reject) => {\n      this.imageInfo\n        .then((data) => {\n          resolve(data.exif);\n        }, reject);\n    });\n  }\n\n  public get imageHeight(): Promise<number> {\n    return new Promise((resolve, reject) => {\n      this.imageInfo\n        .then((data) => {\n          resolve(data.height);\n        }, reject);\n    });\n  }\n\n  public get exifInfo(): Promise<any> {\n    return new Promise((resolve, reject) => {\n      this.imageInfo\n        .then((data) => {\n          resolve(data.exif);\n        }, reject);\n    });\n  }\n\n  public get typeImage() {\n    return this.type.match(/^image/) !== null;\n  }\n\n  public get typeSvg() {\n    return this.type.match(/\\/svg/);\n  }\n\n  public get imageProcess() {\n    return this.typeImage && !this.typeSvg;\n  }\n\n  public get exists() {\n    return this._fileExists;\n  }\n\n  public get file() {\n    return this._file;\n  }\n\n  public get name() {\n    return this._name;\n  }\n\n  public set fileOptions(value) {\n    this._fileOptions = value;\n  }\n\n  public get fileOptions() {\n    return this._fileOptions;\n  }\n\n  public set file(value) {\n    this._file = value;\n    this.size = value.size;\n    this.name = value.name;\n    this.type = value.type;\n    this._checkIfFileExists();\n  }\n\n  public set name(name) {\n    this._name = name;\n    const parts = String(name).split('.');\n    if (parts.length > 1) {\n      this.extension = parts[parts.length - 1];\n    }\n  }\n\n  public get imageInfo(): Promise<{ width: number; height: number; exif: any }> {\n    if (!this.typeImage || this._exifInfo) {\n      return Promise.resolve({\n        width: this._imageWidth,\n        height: this._imageHeight,\n        exif: this._exifInfo,\n      });\n    }\n\n    const exif = new Promise((resolve, reject) => {\n      const fr = new FileReader();\n      fr.onload = () => {\n        var exif = EXIF.readFromBinaryFile(fr.result);\n        resolve(exif);\n      };\n\n      fr.onerror = () => {\n        reject(fr.error);\n      }\n\n      fr.readAsArrayBuffer(this.file);\n    });\n\n    const dims = new Promise((resolve, reject) => {\n      FileAPI.getInfo(this.file, (err, info) => {\n        if (!err) {\n          resolve(info);\n        } else {\n          reject(err);\n        }\n      });\n    });\n\n    return new Promise((resolve, reject) => {\n      Promise.all([exif, dims])\n      .then((data: any) => {\n        this._exifInfo = data[0] || {};\n        this._imageWidth = data[1].width;\n        this._imageHeight = data[1].height;\n\n        resolve({\n          width: this._imageWidth,\n          height: this._imageHeight,\n          exif: this._exifInfo,\n        });\n      },(err) => {\n        reject(err);\n      });\n    });\n  }\n\n  public toObject() {\n    return {\n      name: this._name,\n      type: this.type,\n      size: this.size,\n      progress: this.progress,\n      extension: this.extension,\n      imageWidth: this.imageWidth,\n      imageHeight: this.imageHeight\n    }\n  }\n\n  private _checkIfFileExists() {\n    this._fileExists = !!this.name || !!this.url\n  }\n}\n"]} |
{ | ||
"name": "@firestitch/file", | ||
"version": "12.4.0", | ||
"version": "12.4.1", | ||
"repository": { | ||
@@ -5,0 +5,0 @@ "type": "git", |
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
773829
7023