@firestitch/file
Advanced tools
Comparing version 12.17.4 to 12.18.0
@@ -8,5 +8,6 @@ import { Observable } from 'rxjs'; | ||
private _validate; | ||
private _transformHeic; | ||
private _transform; | ||
private _applyTransforms; | ||
private _transformImage; | ||
private _generateTransformConfig; | ||
} |
@@ -1,2 +0,2 @@ | ||
import { FsFileProcessConfig } from "../interfaces"; | ||
import { FsFileProcessConfig } from '../interfaces'; | ||
export declare class FileProcessConfig { | ||
@@ -10,2 +10,3 @@ private _maxWidth; | ||
private _orientate; | ||
private _heic; | ||
constructor(config?: FsFileProcessConfig); | ||
@@ -12,0 +13,0 @@ set maxWidth(value: number); |
@@ -17,2 +17,4 @@ import { FsApiFile } from '@firestitch/api'; | ||
constructor(obj?: File | Blob | string | FsApiFile, filename?: string); | ||
private _init; | ||
private _getExtensionMime; | ||
get imageWidth(): Promise<number>; | ||
@@ -27,4 +29,4 @@ get imageHeight(): Promise<number>; | ||
get file(): File; | ||
set file(value: File); | ||
get name(): string; | ||
set file(value: File); | ||
set name(name: string); | ||
@@ -31,0 +33,0 @@ get imageInfo(): Promise<{ |
@@ -27,2 +27,3 @@ import { ElementRef, EventEmitter } from '@angular/core'; | ||
* Initialize service for target element | ||
* | ||
* @param el | ||
@@ -38,2 +39,3 @@ */ | ||
* Check if file mimetype or extention is acceptable by @accept field | ||
* | ||
* @param targetType | ||
@@ -43,10 +45,11 @@ * @param targetExt | ||
*/ | ||
private checkAcceptableTypes; | ||
private _checkAcceptableTypes; | ||
/** | ||
* Parset and store acceptable types for feature filter | ||
* | ||
* @param types | ||
*/ | ||
private parseAcceptTypes; | ||
private _parseAcceptTypes; | ||
static ɵfac: i0.ɵɵFactoryDeclaration<InputProcessorService, [{ optional: true; }]>; | ||
static ɵprov: i0.ɵɵInjectableDeclaration<InputProcessorService>; | ||
} |
import { forkJoin, from, Observable, of, throwError } from 'rxjs'; | ||
import { catchError, switchMap } from 'rxjs/operators'; | ||
import { catchError, map, switchMap } from 'rxjs/operators'; | ||
import * as FileAPI from 'fileapi'; | ||
import heic2any from 'heic2any'; | ||
import { toInteger } from 'lodash-es'; | ||
import { FileProcessConfig } from '../models'; | ||
import { FileProcessConfig, FsFile } from '../models'; | ||
export class FileProcessor { | ||
processFile(fsFile, config) { | ||
const processConfig = config instanceof FileProcessConfig ? config : new FileProcessConfig(config); | ||
return (fsFile.imageProcess ? | ||
this._applyTransforms(fsFile, processConfig) : | ||
of(fsFile)) | ||
.pipe(switchMap((fsFile) => this._validate(fsFile, processConfig))); | ||
return this._transform(fsFile, processConfig) | ||
.pipe(switchMap((item) => this._validate(item, processConfig))); | ||
} | ||
@@ -21,3 +20,3 @@ processFiles(fsFiles, config) { | ||
})))) | ||
.pipe(switchMap((fsFiles) => { | ||
.pipe(switchMap((result) => { | ||
if (errors.length) { | ||
@@ -28,3 +27,3 @@ const error = errors | ||
...accum, | ||
item.error | ||
item.error, | ||
]; | ||
@@ -37,3 +36,3 @@ }, []) | ||
...accum, | ||
item.code | ||
item.code, | ||
]; | ||
@@ -44,3 +43,3 @@ }, []) | ||
} | ||
return of(fsFiles); | ||
return of(result); | ||
})); | ||
@@ -63,3 +62,22 @@ } | ||
} | ||
_transformHeic(fsFile) { | ||
if (fsFile.extension === 'heic' && fsFile.file instanceof Blob) { | ||
return from(heic2any({ blob: fsFile.file })) | ||
.pipe(map((blob) => { | ||
var _a; | ||
const ext = ((_a = blob.type) === null || _a === void 0 ? void 0 : _a.split('/')) || []; | ||
const name = fsFile.name.replace(/heic$/i, ext[1] || 'jpg'); | ||
return new FsFile(blob, name); | ||
})); | ||
} | ||
return of(fsFile); | ||
} | ||
_transform(fsFile, processConfig) { | ||
return this._transformHeic(fsFile) | ||
.pipe(switchMap((response) => this._transformImage(response, processConfig))); | ||
} | ||
_transformImage(fsFile, processConfig) { | ||
if (fsFile.imageProcess) { | ||
return of(fsFile); | ||
} | ||
if (!processConfig.orientate && | ||
@@ -83,3 +101,3 @@ !processConfig.maxWidth && | ||
const canvas = images[0]; | ||
const type = (processConfig.format) ? 'image/' + processConfig.format : fsFile.type; | ||
const type = (processConfig.format) ? `image/${processConfig.format}` : fsFile.type; | ||
canvas.toBlob((blob) => { | ||
@@ -98,5 +116,2 @@ fsFile.file = new File([blob], fsFile.file.name, { type: fsFile.type }); | ||
} | ||
_applyTransforms(fsFile, processConfig) { | ||
return this._transform(fsFile, processConfig); | ||
} | ||
_generateTransformConfig(file, config) { | ||
@@ -108,6 +123,6 @@ return { | ||
// Quality for result image | ||
quality: config.quality || 1 | ||
quality: config.quality || 1, | ||
}; | ||
} | ||
} | ||
//# 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 { forkJoin, from, Observable, of, throwError } from 'rxjs';\nimport { catchError, switchMap } from 'rxjs/operators';\n\nimport * as FileAPI from 'fileapi';\nimport { toInteger } from 'lodash-es';\n\nimport { FsFileProcessConfig } from '../interfaces';\nimport { FileProcessConfig, FsFile } from '../models';\n\n\nexport class FileProcessor {\n\n  public processFile(fsFile: FsFile, config: FileProcessConfig | FsFileProcessConfig): Observable<FsFile> {\n    const processConfig = config instanceof FileProcessConfig ? config : new FileProcessConfig(config);\n\n    return (\n      fsFile.imageProcess ?\n        this._applyTransforms(fsFile, processConfig) :\n        of(fsFile)\n    )\n      .pipe(\n        switchMap((fsFile) => this._validate(fsFile, processConfig))\n      );\n  }\n\n  public processFiles(fsFiles: FsFile[], config: FileProcessConfig | FsFileProcessConfig): Observable<FsFile[]> {\n    const errors = [];\n    return forkJoin(\n      fsFiles.map((fsFile) => this.processFile(fsFile, config)\n        .pipe(\n          catchError((error) => {\n            errors.push(error);\n            return of(null);\n          }),\n        )\n      )\n    )\n      .pipe(\n        switchMap((fsFiles) => {\n          if (errors.length) {\n            const error = errors\n              .reduce((accum, item) => {\n                return [\n                  ...accum,\n                  item.error\n                ];\n              }, [])\n              .join(', ');\n\n            const code = errors\n              .reduce((accum, item) => {\n                return [\n                  ...accum,\n                  item.code\n                ];\n              }, [])\n              .join(', ');\n\n            return throwError({ error, code, message: error });\n          }\n\n          return of(fsFiles);\n        })\n      );\n  }\n\n  private _validate(fsFile: FsFile, processConfig: FileProcessConfig): Observable<FsFile> {\n    if (processConfig.minHeight || processConfig.minWidth) {\n      return from(fsFile.imageInfo)\n        .pipe(\n          switchMap((data) => {\n            if (data.height < toInteger(processConfig.minHeight)) {\n              return throwError({ error: `Height must be at least ${processConfig.minHeight}px.`, code: 'minHeight' });\n            }\n\n            if (data.width < toInteger(processConfig.minWidth)) {\n              return throwError({ error: `Width must be at least ${processConfig.minWidth}px.`, code: 'minWidth' });\n            }\n\n            return of(fsFile);\n          }),\n        );\n    }\n\n    return of(fsFile);\n  }\n\n  private _transform(fsFile: FsFile, processConfig: FileProcessConfig): Observable<FsFile> {\n    if (\n      !processConfig.orientate &&\n      !processConfig.maxWidth &&\n      !processConfig.maxHeight &&\n      processConfig.quality === 1\n    ) {\n      return of(fsFile);\n    }\n\n    return from(fsFile.exifInfo)\n      .pipe(\n        switchMap((exifInfo: any) => {\n          if (!exifInfo?.Orientation) {\n            return of(fsFile);\n          }\n\n          return new Observable<FsFile>((observer) => {\n            const transformConfig = this._generateTransformConfig(fsFile, processConfig);\n\n            // Transform image by options and rotate if needed\n            FileAPI.Image.transform(\n              fsFile.file,\n              [transformConfig],\n              processConfig.orientate,\n              (err, images) => {\n                // Process transformed files\n                if (!err && images[0]) {\n                  const canvas: HTMLCanvasElement = images[0];\n                  const type = (processConfig.format) ? 'image/' + processConfig.format : fsFile.type;\n\n                  canvas.toBlob((blob) => {\n                    fsFile.file = new File([blob], fsFile.file.name, { type: fsFile.type });\n                    observer.next(fsFile);\n                    observer.complete();\n                  }, type, processConfig.quality);\n                } else {\n                  observer.error(err);\n                }\n              });\n          });\n        })\n      );\n  }\n\n  private _applyTransforms(fsFile: FsFile, processConfig: FileProcessConfig): Observable<FsFile> {\n    return this._transform(fsFile, processConfig);\n  }\n\n  private _generateTransformConfig(file, config: FileProcessConfig) {\n    return {\n      // Resize\n      maxWidth: config.maxWidth,\n      maxHeight: config.maxHeight,\n\n      // Quality for result image\n      quality: config.quality || 1\n    };\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 { forkJoin, from, Observable, of, throwError } from 'rxjs';\nimport { catchError, map, switchMap } from 'rxjs/operators';\n\nimport * as FileAPI from 'fileapi';\nimport heic2any from 'heic2any';\nimport { toInteger } from 'lodash-es';\n\nimport { FsFileProcessConfig } from '../interfaces';\nimport { FileProcessConfig, FsFile } from '../models';\n\n\nexport class FileProcessor {\n\n  public processFile(fsFile: FsFile, config: FileProcessConfig | FsFileProcessConfig): Observable<FsFile> {\n    const processConfig = config instanceof FileProcessConfig ? config : new FileProcessConfig(config);\n\n    return this._transform(fsFile, processConfig)\n      .pipe(\n        switchMap((item) => this._validate(item, processConfig)),\n      );\n  }\n\n  public processFiles(fsFiles: FsFile[], config: FileProcessConfig | FsFileProcessConfig): Observable<FsFile[]> {\n    const errors = [];\n\n    return forkJoin(\n      fsFiles.map((fsFile) => this.processFile(fsFile, config)\n        .pipe(\n          catchError((error) => {\n            errors.push(error);\n\n            return of(null);\n          }),\n        ),\n      ),\n    )\n      .pipe(\n        switchMap((result) => {\n          if (errors.length) {\n            const error = errors\n              .reduce((accum, item) => {\n                return [\n                  ...accum,\n                  item.error,\n                ];\n              }, [])\n              .join(', ');\n\n            const code = errors\n              .reduce((accum, item) => {\n                return [\n                  ...accum,\n                  item.code,\n                ];\n              }, [])\n              .join(', ');\n\n            return throwError({ error, code, message: error });\n          }\n\n          return of(result);\n        }),\n      );\n  }\n\n  private _validate(fsFile: FsFile, processConfig: FileProcessConfig): Observable<FsFile> {\n    if (processConfig.minHeight || processConfig.minWidth) {\n      return from(fsFile.imageInfo)\n        .pipe(\n          switchMap((data) => {\n            if (data.height < toInteger(processConfig.minHeight)) {\n              return throwError({ error: `Height must be at least ${processConfig.minHeight}px.`, code: 'minHeight' });\n            }\n\n            if (data.width < toInteger(processConfig.minWidth)) {\n              return throwError({ error: `Width must be at least ${processConfig.minWidth}px.`, code: 'minWidth' });\n            }\n\n            return of(fsFile);\n          }),\n        );\n    }\n\n    return of(fsFile);\n  }\n\n\n  private _transformHeic(fsFile: FsFile): Observable<FsFile> {\n    if(fsFile.extension === 'heic' && fsFile.file instanceof Blob) {\n      return from(heic2any({ blob: fsFile.file }))\n        .pipe(\n          map((blob: Blob) => {\n            const ext = blob.type?.split('/') || [];\n            const name = fsFile.name.replace(/heic$/i, ext[1] || 'jpg');\n\n            return new FsFile(blob, name);\n          }),\n        );\n    }\n\n    return of(fsFile);\n  }\n\n  private _transform(fsFile: FsFile, processConfig: FileProcessConfig): Observable<FsFile> {\n    return this._transformHeic(fsFile)\n      .pipe(\n        switchMap((response)=> this._transformImage(response, processConfig)),\n      );\n  }\n\n  private _transformImage(fsFile: FsFile, processConfig: FileProcessConfig): Observable<FsFile> {\n    if(fsFile.imageProcess) {\n      return of(fsFile);\n    }\n\n    if (\n      !processConfig.orientate &&\n      !processConfig.maxWidth &&\n      !processConfig.maxHeight &&\n      processConfig.quality === 1\n    ) {\n      return of(fsFile);\n    }\n\n    return from(fsFile.exifInfo)\n      .pipe(\n        switchMap((exifInfo: any) => {\n          if (!exifInfo?.Orientation) {\n            return of(fsFile);\n          }\n\n          return new Observable<FsFile>((observer) => {\n            const transformConfig = this._generateTransformConfig(fsFile, processConfig);\n\n            // Transform image by options and rotate if needed\n            FileAPI.Image.transform(\n              fsFile.file,\n              [transformConfig],\n              processConfig.orientate,\n              (err, images) => {\n                // Process transformed files\n                if (!err && images[0]) {\n                  const canvas: HTMLCanvasElement = images[0];\n                  const type = (processConfig.format) ? `image/${  processConfig.format}` : fsFile.type;\n\n                  canvas.toBlob((blob) => {\n                    fsFile.file = new File([blob], fsFile.file.name, { type: fsFile.type });\n                    observer.next(fsFile);\n                    observer.complete();\n                  }, type, processConfig.quality);\n                } else {\n                  observer.error(err);\n                }\n              });\n          });\n        }),\n      );\n  }\n\n  private _generateTransformConfig(file, config: FileProcessConfig) {\n    return {\n      // Resize\n      maxWidth: config.maxWidth,\n      maxHeight: config.maxHeight,\n\n      // Quality for result image\n      quality: config.quality || 1,\n    };\n  }\n}\n"]} |
@@ -245,2 +245,2 @@ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, ContentChildren, EventEmitter, Inject, Input, Optional, Output, QueryList, TemplateRef, ViewChild, forwardRef, } from '@angular/core'; | ||
}] } }); | ||
//# 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  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ContentChildren,\n  EventEmitter,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n  forwardRef,\n} from '@angular/core';\nimport {\n  AbstractControl, AsyncValidator, ControlValueAccessor,\n  NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors,\n} from '@angular/forms';\n\nimport { FsApiFile } from '@firestitch/api';\n\nimport { Subject } from 'rxjs';\n\nimport { FsFilePickerSelectDirective, FsFilePreviewActionDirective } from '../../directives';\nimport { FsFileLabelDirective } from '../../directives/fs-file-label.directive';\nimport { FS_FILE_MODULE_CONFIG } from '../../injectors/file-config.injector';\nimport { FsFile } from '../../models/fs-file';\nimport { FsFileDragBaseComponent } from '../fs-file-drag-base/fs-file-drag-base';\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\n  extends FsFileDragBaseComponent\n  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  @ContentChild(FsFilePickerSelectDirective, { read: TemplateRef })\n  public filePickerSelectTemplate: TemplateRef<any>;\n\n  @ContentChildren(FsFilePreviewActionDirective)\n  public previewActions: QueryList<FsFilePreviewActionDirective>;\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 multiple = false;\n  @Input() public allowRemove = false;\n\n  @Input('url') public set url(url) {\n    this.file = url ? new FsFile(url) : null;\n  }\n\n  @Input('file') public set file(file: FsFile | FsApiFile | string) {\n    if (file instanceof FsApiFile) {\n      this._file = new FsFile(file);\n    } else if (file instanceof FsFile) {\n      this._file = file;\n    } else if (file) {\n      this._file = new FsFile(file);\n    } else {\n      this._file = null;\n    }\n\n    this.previewFile = this._file;\n  }\n\n  public get file(): FsFile {\n    return this._file;\n  }\n\n  @Input()\n  public accept: string | string[];\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\n  public instruction = 'Drag & Drop your file or use the button below';\n  public previewFile: FsFile;\n\n  private _destroy$ = new Subject();\n  private _disabled: boolean;\n  private _previewWidth = '150px';\n  private _file: FsFile;\n  private _previewHeight = '150px';\n\n  constructor(\n    @Optional() @Inject(FS_FILE_MODULE_CONFIG) private _moduleConfig,\n    private _cdRef: ChangeDetectorRef,\n  ) {\n    super();\n  }\n\n  public onChange: any = () => {\n    //\n  };\n\n  public onTouch: any = () => {\n    //\n  };\n\n  public registerOnChange(fn): void {\n    this.onChange = fn;\n  }\n\n  public registerOnTouched(fn): void {\n    this.onTouch = fn;\n  }\n\n  public ngOnInit() {\n    if (this._moduleConfig) {\n      if (this.allowDownload === undefined) {\n        this.allowDownload = this._moduleConfig.allowDownload;\n      }\n\n      if (this.allowRemove === undefined) {\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 clear(): void {\n    this.file = null;\n    this._cdRef.markForCheck();\n  }\n\n  public writeValue(file): void {\n    this.file = file;\n    this._cdRef.markForCheck();\n  }\n\n  public selectFilePreview(fsFiles: FsFile[]) {\n    this.previewFile = fsFiles[0];\n  }\n\n  public selectFile(fsFile: FsFile) {\n    if (!this.multiple) {\n      this.file = fsFile;\n      this.onChange(fsFile);\n    }\n\n    this.select.emit(fsFile);\n  }\n\n  public removeFile() {\n    this.file = null;\n    this.previewFile = null;\n    this.remove.emit(this.file);\n    this.onChange(null);\n  }\n\n  public actionClick(event: { event: MouseEvent }) {\n    event.event.stopPropagation();\n  }\n\n  public downloadClicked(event: { event: MouseEvent }) {\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}\n","<fs-label-field\n    class=\"fs-form-wrapper\"\n    [ngClass]=\"{ 'percent-preview': previewPercent }\">\n  <ng-container *ngIf=\"label; else labelContent\">\n    <fs-label class=\"fs-form-label\">{{label}}</fs-label>\n  </ng-container>\n  <ng-template #labelContent>\n    <fs-label *ngIf=\"labels.length\" class=\"fs-form-label\">\n      <ng-content select=\"[fsFileLabel]\"></ng-content>\n    </fs-label>\n  </ng-template>\n  <fs-file\n      [accept]=\"accept\"\n      (select)=\"selectFile($event)\"\n      (selectPreviews)=\"selectFilePreview($event)\"\n      [imageWidth]=\"imageWidth\"\n      [imageHeight]=\"imageHeight\"\n      [imageQuality]=\"imageQuality\"\n      [disabled]=\"disabled\"\n      [multiple]=\"multiple\">\n    <div\n        class=\"wrap\"\n        [style.width]=\"previewWidth\"\n        [style.height]=\"previewHeight\">\n      <fs-file-preview\n          class=\"preview\"\n          *ngIf=\"previewFile; else preview\"\n          (remove)=\"removeFile()\"\n          [file]=\"previewFile\"\n          [previewActions]=\"previewActions.toArray()\"\n          [showFilename]=\"showFilename\"\n          [previewHeight]=\"null\"\n          [previewWidth]=\"null\">\n        <ng-template\n            *ngIf=\"allowRemove\"\n            fs-file-preview-action\n            placement=\"top-right\"\n            action=\"remove\"\n            tooltip=\"Remove\"\n            (click)=\"actionClick($event)\">\n          <mat-icon>close</mat-icon>\n        </ng-template>\n        <ng-template\n            *ngIf=\"allowReupload\"\n            fs-file-preview-action\n            action=\"reupload\"\n            placement=\"bottom-right\"\n            tooltip=\"Reupload\">\n          <mat-icon>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]=\"previewFile.url\"\n              target=\"_blank\"\n              tabindex=\"-1\"\n              class=\"download\">\n            <mat-icon>download</mat-icon>\n          </a>\n        </ng-template>\n      </fs-file-preview>\n\n      <ng-template #preview>\n        <ng-container *ngIf=\"filePickerSelectTemplate\">\n          <ng-container [ngTemplateOutlet]=\"filePickerSelectTemplate\"></ng-container>\n        </ng-container>\n        <ng-container *ngIf=\"!filePickerSelectTemplate\">\n          <div class=\"select\">\n            <mat-icon>upload</mat-icon>\n            <div class=\"instruction\">{{instruction}}</div>\n            <div class=\"mat-raised-button\">Upload</div>\n          </div>\n        </ng-container>\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>\n"]} | ||
//# 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,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,eAAe,EACf,YAAY,EACZ,MAAM,EACN,KAAK,EAGL,QAAQ,EACR,MAAM,EACN,SAAS,EACT,WAAW,EACX,SAAS,EACT,UAAU,GACX,MAAM,eAAe,CAAC;AACvB,OAAO,EAEL,aAAa,EAAE,iBAAiB,GACjC,MAAM,gBAAgB,CAAC;AAExB,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAE5C,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAE/B,OAAO,EAAE,2BAA2B,EAAE,4BAA4B,EAAE,MAAM,kBAAkB,CAAC;AAC7F,OAAO,EAAE,oBAAoB,EAAE,MAAM,0CAA0C,CAAC;AAChF,OAAO,EAAE,qBAAqB,EAAE,MAAM,sCAAsC,CAAC;AAC7E,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAC9C,OAAO,EAAE,uBAAuB,EAAE,MAAM,wCAAwC,CAAC;;;;;;;;AAqBjF,MAAM,OAAO,qBACX,SAAQ,uBAAuB;IA6F/B,YACqD,aAAa,EACxD,MAAyB;QAEjC,KAAK,EAAE,CAAC;QAH2C,kBAAa,GAAb,aAAa,CAAA;QACxD,WAAM,GAAN,MAAM,CAAmB;QAhFnB,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,aAAQ,GAAG,KAAK,CAAC;QACjB,gBAAW,GAAG,KAAK,CAAC;QAuDnB,WAAM,GAAG,IAAI,YAAY,EAAO,CAAC;QACjC,WAAM,GAAG,IAAI,YAAY,EAAE,CAAC;QAC5B,aAAQ,GAAG,IAAI,YAAY,EAAU,CAAC;QAEhD,gBAAW,GAAG,+CAA+C,CAAC;QAG7D,cAAS,GAAG,IAAI,OAAO,EAAE,CAAC;QAE1B,kBAAa,GAAG,OAAO,CAAC;QAExB,mBAAc,GAAG,OAAO,CAAC;QAS1B,aAAQ,GAAQ,GAAG,EAAE;YAC1B,EAAE;QACJ,CAAC,CAAC;QAEK,YAAO,GAAQ,GAAG,EAAE;YACzB,EAAE;QACJ,CAAC,CAAC;IARF,CAAC;IAvED,IAAyB,GAAG,CAAC,GAAG;QAC9B,IAAI,CAAC,IAAI,GAAG,GAAG,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC3C,CAAC;IAED,IAA0B,IAAI,CAAC,IAAiC;QAC9D,IAAI,IAAI,YAAY,SAAS,EAAE;YAC7B,IAAI,CAAC,KAAK,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC;SAC/B;aAAM,IAAI,IAAI,YAAY,MAAM,EAAE;YACjC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;SACnB;aAAM,IAAI,IAAI,EAAE;YACf,IAAI,CAAC,KAAK,GAAG,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC;SAC/B;aAAM;YACL,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;SACnB;QAED,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC;IAChC,CAAC;IAED,IAAW,IAAI;QACb,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAMD,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;IA8BM,gBAAgB,CAAC,EAAE;QACxB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAEM,iBAAiB,CAAC,EAAE;QACzB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;IACpB,CAAC;IAEM,QAAQ;QACb,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,IAAI,IAAI,CAAC,aAAa,KAAK,SAAS,EAAE;gBACpC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC;aACvD;YAED,IAAI,IAAI,CAAC,WAAW,KAAK,SAAS,EAAE;gBAClC,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC;aACnD;SACF;IACH,CAAC;IAEM,QAAQ,CAAC,OAAwB;;QACtC,IAAI,CAAA,MAAA,IAAI,CAAC,IAAI,0CAAE,SAAS,KAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,SAAS,CAAC,EAAE;YAC7D,6CAA6C;YAC7C,6DAA6D;YAC7D,IAAI;YAEJ,+CAA+C;YAC/C,+DAA+D;YAC/D,IAAI;SACL;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,KAAK;QACV,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;IAC7B,CAAC;IAEM,UAAU,CAAC,IAAI;QACpB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,MAAM,CAAC,YAAY,EAAE,CAAC;IAC7B,CAAC;IAEM,iBAAiB,CAAC,OAAiB;QACxC,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;IAChC,CAAC;IAEM,UAAU,CAAC,MAAc;QAC9B,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC;YACnB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;SACvB;QAED,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC3B,CAAC;IAEM,UAAU;QACf,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC5B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;IACtB,CAAC;IAEM,WAAW,CAAC,KAA4B;QAC7C,KAAK,CAAC,KAAK,CAAC,eAAe,EAAE,CAAC;IAChC,CAAC;IAEM,eAAe,CAAC,KAA4B;QACjD,KAAK,CAAC,KAAK,CAAC,eAAe,EAAE,CAAC;QAE9B,IAAI,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,MAAM,EAAE;YAClC,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;;mHAjMU,qBAAqB,kBA+FV,qBAAqB;uGA/FhC,qBAAqB,8hBAbrB;QACT;YACE,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;KACF,gFAYa,2BAA2B,2BAAU,WAAW,yCAH7C,oBAAoB,iDAMpB,4BAA4B,4JCjE/C,0kGAwFA;4FDpCa,qBAAqB;kBAlBjC,SAAS;mBAAC;oBACT,QAAQ,EAAE,gBAAgB;oBAC1B,WAAW,EAAE,iCAAiC;oBAC9C,SAAS,EAAE,CAAC,iCAAiC,CAAC;oBAC9C,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,SAAS,EAAE;wBACT;4BACE,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;qBACF;iBACF;;0BAgGI,QAAQ;;0BAAI,MAAM;2BAAC,qBAAqB;4EA1FpC,SAAS;sBADf,SAAS;uBAAC,WAAW;gBAIf,MAAM;sBADZ,eAAe;uBAAC,oBAAoB;gBAI9B,wBAAwB;sBAD9B,YAAY;uBAAC,2BAA2B,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE;gBAIzD,cAAc;sBADpB,eAAe;uBAAC,4BAA4B;gBAG7B,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,QAAQ;sBAAvB,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBAEmB,GAAG;sBAA3B,KAAK;uBAAC,KAAK;gBAIc,IAAI;sBAA7B,KAAK;uBAAC,MAAM;gBAmBN,MAAM;sBADZ,KAAK;gBAKK,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  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  ContentChildren,\n  EventEmitter,\n  Inject,\n  Input,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Output,\n  QueryList,\n  TemplateRef,\n  ViewChild,\n  forwardRef,\n} from '@angular/core';\nimport {\n  AbstractControl, AsyncValidator, ControlValueAccessor,\n  NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors,\n} from '@angular/forms';\n\nimport { FsApiFile } from '@firestitch/api';\n\nimport { Subject } from 'rxjs';\n\nimport { FsFilePickerSelectDirective, FsFilePreviewActionDirective } from '../../directives';\nimport { FsFileLabelDirective } from '../../directives/fs-file-label.directive';\nimport { FS_FILE_MODULE_CONFIG } from '../../injectors/file-config.injector';\nimport { FsFile } from '../../models/fs-file';\nimport { FsFileDragBaseComponent } from '../fs-file-drag-base/fs-file-drag-base';\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\n  extends FsFileDragBaseComponent\n  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  @ContentChild(FsFilePickerSelectDirective, { read: TemplateRef })\n  public filePickerSelectTemplate: TemplateRef<any>;\n\n  @ContentChildren(FsFilePreviewActionDirective)\n  public previewActions: QueryList<FsFilePreviewActionDirective>;\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 multiple = false;\n  @Input() public allowRemove = false;\n\n  @Input('url') public set url(url) {\n    this.file = url ? new FsFile(url) : null;\n  }\n\n  @Input('file') public set file(file: FsFile | FsApiFile | string) {\n    if (file instanceof FsApiFile) {\n      this._file = new FsFile(file);\n    } else if (file instanceof FsFile) {\n      this._file = file;\n    } else if (file) {\n      this._file = new FsFile(file);\n    } else {\n      this._file = null;\n    }\n\n    this.previewFile = this._file;\n  }\n\n  public get file(): FsFile {\n    return this._file;\n  }\n\n  @Input()\n  public accept: string | string[];\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 instruction = 'Drag & Drop your file or use the button below';\n  public previewFile: FsFile;\n\n  private _destroy$ = new Subject();\n  private _disabled: boolean;\n  private _previewWidth = '150px';\n  private _file: FsFile;\n  private _previewHeight = '150px';\n\n  constructor(\n    @Optional() @Inject(FS_FILE_MODULE_CONFIG) private _moduleConfig,\n    private _cdRef: ChangeDetectorRef,\n  ) {\n    super();\n  }\n\n  public onChange: any = () => {\n    //\n  };\n\n  public onTouch: any = () => {\n    //\n  };\n\n  public registerOnChange(fn): void {\n    this.onChange = fn;\n  }\n\n  public registerOnTouched(fn): void {\n    this.onTouch = fn;\n  }\n\n  public ngOnInit() {\n    if (this._moduleConfig) {\n      if (this.allowDownload === undefined) {\n        this.allowDownload = this._moduleConfig.allowDownload;\n      }\n\n      if (this.allowRemove === undefined) {\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 clear(): void {\n    this.file = null;\n    this._cdRef.markForCheck();\n  }\n\n  public writeValue(file): void {\n    this.file = file;\n    this._cdRef.markForCheck();\n  }\n\n  public selectFilePreview(fsFiles: FsFile[]) {\n    this.previewFile = fsFiles[0];\n  }\n\n  public selectFile(fsFile: FsFile) {\n    if (!this.multiple) {\n      this.file = fsFile;\n      this.onChange(fsFile);\n    }\n\n    this.select.emit(fsFile);\n  }\n\n  public removeFile() {\n    this.file = null;\n    this.previewFile = null;\n    this.remove.emit(this.file);\n    this.onChange(null);\n  }\n\n  public actionClick(event: { event: MouseEvent }) {\n    event.event.stopPropagation();\n  }\n\n  public downloadClicked(event: { event: MouseEvent }) {\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}\n","<fs-label-field\n    class=\"fs-form-wrapper\"\n    [ngClass]=\"{ 'percent-preview': previewPercent }\">\n  <ng-container *ngIf=\"label; else labelContent\">\n    <fs-label class=\"fs-form-label\">{{label}}</fs-label>\n  </ng-container>\n  <ng-template #labelContent>\n    <fs-label *ngIf=\"labels.length\" class=\"fs-form-label\">\n      <ng-content select=\"[fsFileLabel]\"></ng-content>\n    </fs-label>\n  </ng-template>\n  <fs-file\n      [accept]=\"accept\"\n      (select)=\"selectFile($event)\"\n      (selectPreviews)=\"selectFilePreview($event)\"\n      [imageWidth]=\"imageWidth\"\n      [imageHeight]=\"imageHeight\"\n      [imageQuality]=\"imageQuality\"\n      [disabled]=\"disabled\"\n      [multiple]=\"multiple\">\n    <div\n        class=\"wrap\"\n        [style.width]=\"previewWidth\"\n        [style.height]=\"previewHeight\">\n      <fs-file-preview\n          class=\"preview\"\n          *ngIf=\"previewFile; else preview\"\n          (remove)=\"removeFile()\"\n          [file]=\"previewFile\"\n          [previewActions]=\"previewActions.toArray()\"\n          [showFilename]=\"showFilename\"\n          [previewHeight]=\"null\"\n          [previewWidth]=\"null\">\n        <ng-template\n            *ngIf=\"allowRemove\"\n            fs-file-preview-action\n            placement=\"top-right\"\n            action=\"remove\"\n            tooltip=\"Remove\"\n            (click)=\"actionClick($event)\">\n          <mat-icon>close</mat-icon>\n        </ng-template>\n        <ng-template\n            *ngIf=\"allowReupload\"\n            fs-file-preview-action\n            action=\"reupload\"\n            placement=\"bottom-right\"\n            tooltip=\"Reupload\">\n          <mat-icon>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]=\"previewFile.url\"\n              target=\"_blank\"\n              tabindex=\"-1\"\n              class=\"download\">\n            <mat-icon>download</mat-icon>\n          </a>\n        </ng-template>\n      </fs-file-preview>\n\n      <ng-template #preview>\n        <ng-container *ngIf=\"filePickerSelectTemplate\">\n          <ng-container [ngTemplateOutlet]=\"filePickerSelectTemplate\"></ng-container>\n        </ng-container>\n        <ng-container *ngIf=\"!filePickerSelectTemplate\">\n          <div class=\"select\">\n            <mat-icon>upload</mat-icon>\n            <div class=\"instruction\">{{instruction}}</div>\n            <div class=\"mat-raised-button\">Upload</div>\n          </div>\n        </ng-container>\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>\n"]} |
@@ -84,3 +84,3 @@ import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Input, Output, QueryList, } from '@angular/core'; | ||
FsFilePreviewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FsFilePreviewComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); | ||
FsFilePreviewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: FsFilePreviewComponent, selector: "fs-file-preview", inputs: { previewActions: "previewActions", showFilename: "showFilename", previewWidth: "previewWidth", previewHeight: "previewHeight", file: "file", url: "url", index: "index", showActionOn: "showActionOn" }, outputs: { remove: "remove" }, queries: [{ propertyName: "childrenPreviewActions", predicate: FsFilePreviewActionDirective }], usesOnChanges: true, ngImport: i0, template: "<div\n [style.width.px]=\"previewWidth\"\n [style.height.px]=\"previewHeight\"\n class=\"preview-container\"\n [ngClass]=\"{ \n 'has-actions': (childrenPreviewActions.length !== 0 || previewActions.length !== 0), \n 'type-image': typeImage,\n 'loaded': loaded,\n 'show-action-always': showActionOn === 'always'\n }\">\n <!-- Image container -->\n <ng-container \n *ngIf=\"typeImage; else nonImage\">\n <ng-container *ngIf=\"(file | fsFileSrc | async) as src\">\n <img \n [src]=\"src\" \n (load)=\"previewLoaded()\">\n </ng-container>\n \n <ng-container *ngIf=\"!loaded\">\n <div class=\"loader\"></div>\n </ng-container>\n </ng-container>\n\n <!-- Non image container -->\n <ng-template #nonImage>\n <div class=\"file-details\">\n <div class=\"file-icon\">\n <div \n class=\"file-ext\"\n [style.fontSize]=\"extensionFontSize + 'px'\">\n {{file.extension}}\n </div>\n <mat-icon \n [style.width]=\"iconDim + 'px'\" \n [style.height]=\"iconDim + 'px'\"\n [style.fontSize]=\"iconDim + 'px'\">insert_drive_file</mat-icon>\n </div>\n <ng-container *ngIf=\"showFilename && file.name\">\n <a \n class=\"file-name\" \n [matTooltip]=\"file.name\">\n {{file.name}}\n </a>\n </ng-container>\n </div>\n </ng-template>\n\n <div class=\"actions\">\n <ng-container *ngFor=\"let previewAction of previewActions\">\n <ng-container \n [ngTemplateOutlet]=\"previewActionTmpl\" \n [ngTemplateOutletContext]=\"{ previewAction: previewAction }\">\n </ng-container>\n </ng-container>\n <ng-container *ngFor=\"let previewAction of childrenPreviewActions\">\n <ng-container \n [ngTemplateOutlet]=\"previewActionTmpl\" \n [ngTemplateOutletContext]=\"{ previewAction: previewAction }\">\n </ng-container>\n </ng-container>\n </div>\n\n <div class=\"spinner\">\n <mat-spinner *ngIf=\"file.progress\" [diameter]=\"30\"></mat-spinner>\n </div>\n <ng-content></ng-content>\n</div>\n\n<ng-template #previewActionTmpl let-previewAction=\"previewAction\">\n <ng-container *ngIf=\"!previewAction.hide\">\n <div\n class=\"action mat-mini-fab mat-primary\" \n [class]=\"previewAction.placement\"\n [matTooltip]=\"previewAction.tooltip\"\n (click)=\"callAction($event, previewAction)\">\n <span class=\"mat-button-wrapper\">\n <ng-template [ngTemplateOutlet]=\"previewAction.templateRef\"></ng-template>\n </span>\n </div>\n </ng-container>\n</ng-template>", styles: [":host{border:1px #efefef solid;display:inline-block;position:relative;vertical-align:top;overflow:hidden;border-radius:3px}:host .file-details{flex-direction:column;display:flex;padding:5px;min-width:0}:host .file-details .file-icon{position:relative;display:flex;justify-content:center}:host .file-details .file-ext{font-weight:bold;text-align:center;text-transform:uppercase;font-size:20px;position:absolute;width:100%;bottom:25%;color:#fff}:host .file-details mat-icon{color:#ccc}:host .file-details .file-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:5px;font-size:75%;text-align:center;width:100%;color:inherit;box-sizing:border-box}:host .preview-container.show-action-always .actions .action.top-left,:host .preview-container:hover .actions .action.top-left,:host .preview-container:focus .actions .action.top-left{top:8px;left:8px}:host .preview-container.show-action-always .actions .action.top-right,:host .preview-container:hover .actions .action.top-right,:host .preview-container:focus .actions .action.top-right{top:8px;right:8px}:host .preview-container.show-action-always .actions .action.bottom-left,:host .preview-container:hover .actions .action.bottom-left,:host .preview-container:focus .actions .action.bottom-left{bottom:8px;left:8px}:host .preview-container.show-action-always .actions .action.bottom-right,:host .preview-container:hover .actions .action.bottom-right,:host .preview-container:focus .actions .action.bottom-right{bottom:8px;right:8px}:host .preview-container{overflow:hidden;box-sizing:border-box;margin:auto;display:flex;align-items:center;flex-grow:1;height:100%;justify-content:center}:host .preview-container.type-image{background-image:linear-gradient(to right,rgba(255,255,255,.75),rgba(255,255,255,.75)),linear-gradient(to right,black 50%,white 50%),linear-gradient(to bottom,black 50%,white 50%);background-blend-mode:normal,difference,normal;background-size:20px 20px}:host .preview-container.type-image:not(.loaded){background:none}:host .preview-container.type-image:not(.loaded) .actions{display:none}:host .preview-container.loaded img{opacity:1}@media only screen and (max-width: 767.98px){:host .actions{display:block}}:host .actions .action.top-left{top:8px;left:8px}:host .actions .action.top-right{top:8px;right:8px}:host .actions .action.bottom-left{bottom:8px;left:8px}:host .actions .action.bottom-right{bottom:8px;right:8px}@media only screen and (min-width: 768px){:host .actions .action.top-left,:host .actions .action.top-right,:host .actions .action.bottom-left,:host .actions .action.bottom-right{transition:top .3s,bottom .3s,left .3s,right .3s}:host .actions .action.top-left{top:-50px;left:-50px}:host .actions .action.top-right{top:-50px;right:-50px}:host .actions .action.bottom-left{bottom:-50px;left:-50px}:host .actions .action.bottom-right{bottom:-50px;right:-50px}}:host .actions .action{position:absolute;cursor:pointer}:host .actions .action.hide{display:none}:host:hover .actions,:host:focus .actions{display:block}:host img{display:block;transform:translateZ(.1px);object-position:top;object-fit:cover;width:100%;height:100%}:host .mat-button-wrapper{padding:0;line-height:15px!important}:host .spinner{position:absolute;top:50%;left:50%;margin-left:-25%;margin-top:-25%}img{opacity:0}.loader{height:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);max-height:70px;aspect-ratio:1/1}.loader:after{content:\" \";display:block;width:100%;height:100%;border-radius:50%;border:6px solid #ccc;border-color:#ccc transparent #ccc transparent;animation:lds-dual-ring 1.2s linear infinite;box-sizing:border-box}@keyframes lds-dual-ring{0%{transform:rotate(0)}to{transform:rotate(360deg)}}\n"], components: [{ type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i2.MatSpinner, selector: "mat-spinner", inputs: ["color"] }], directives: [{ type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "async": i3.AsyncPipe, "fsFileSrc": i5.FsFileSrcPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush }); | ||
FsFilePreviewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: FsFilePreviewComponent, selector: "fs-file-preview", inputs: { previewActions: "previewActions", showFilename: "showFilename", previewWidth: "previewWidth", previewHeight: "previewHeight", file: "file", url: "url", index: "index", showActionOn: "showActionOn" }, outputs: { remove: "remove" }, queries: [{ propertyName: "childrenPreviewActions", predicate: FsFilePreviewActionDirective }], usesOnChanges: true, ngImport: i0, template: "<div\n [style.width.px]=\"previewWidth\"\n [style.height.px]=\"previewHeight\"\n class=\"preview-container\"\n [ngClass]=\"{ \n 'has-actions': (childrenPreviewActions.length !== 0 || previewActions.length !== 0), \n 'type-image': typeImage,\n 'loaded': loaded,\n 'show-action-always': showActionOn === 'always'\n }\">\n <!-- Image container -->\n <ng-container \n *ngIf=\"typeImage; else nonImage\">\n <ng-container *ngIf=\"(file | fsFileSrc | async) as src\">\n <img \n [src]=\"src\" \n (load)=\"previewLoaded()\"\n (error)=\"previewError()\">\n </ng-container>\n \n <ng-container *ngIf=\"!loaded\">\n <div class=\"loader\"></div>\n </ng-container>\n </ng-container>\n\n <!-- Non image container -->\n <ng-template #nonImage>\n <div class=\"file-details\">\n <div class=\"file-icon\">\n <div \n class=\"file-ext\"\n [style.fontSize]=\"extensionFontSize + 'px'\">\n {{file.extension}}\n </div>\n <mat-icon \n [style.width]=\"iconDim + 'px'\" \n [style.height]=\"iconDim + 'px'\"\n [style.fontSize]=\"iconDim + 'px'\">insert_drive_file</mat-icon>\n </div>\n <ng-container *ngIf=\"showFilename && file.name\">\n <a \n class=\"file-name\" \n [matTooltip]=\"file.name\">\n {{file.name}}\n </a>\n </ng-container>\n </div>\n </ng-template>\n\n <div class=\"actions\">\n <ng-container *ngFor=\"let previewAction of previewActions\">\n <ng-container \n [ngTemplateOutlet]=\"previewActionTmpl\" \n [ngTemplateOutletContext]=\"{ previewAction: previewAction }\">\n </ng-container>\n </ng-container>\n <ng-container *ngFor=\"let previewAction of childrenPreviewActions\">\n <ng-container \n [ngTemplateOutlet]=\"previewActionTmpl\" \n [ngTemplateOutletContext]=\"{ previewAction: previewAction }\">\n </ng-container>\n </ng-container>\n </div>\n\n <div class=\"spinner\">\n <mat-spinner *ngIf=\"file.progress\" [diameter]=\"30\"></mat-spinner>\n </div>\n <ng-content></ng-content>\n</div>\n\n<ng-template #previewActionTmpl let-previewAction=\"previewAction\">\n <ng-container *ngIf=\"!previewAction.hide\">\n <div\n class=\"action mat-mini-fab mat-primary\" \n [class]=\"previewAction.placement\"\n [matTooltip]=\"previewAction.tooltip\"\n (click)=\"callAction($event, previewAction)\">\n <span class=\"mat-button-wrapper\">\n <ng-template [ngTemplateOutlet]=\"previewAction.templateRef\"></ng-template>\n </span>\n </div>\n </ng-container>\n</ng-template>", styles: [":host{border:1px #efefef solid;display:inline-block;position:relative;vertical-align:top;overflow:hidden;border-radius:3px}:host .file-details{flex-direction:column;display:flex;padding:5px;min-width:0}:host .file-details .file-icon{position:relative;display:flex;justify-content:center}:host .file-details .file-ext{font-weight:bold;text-align:center;text-transform:uppercase;font-size:20px;position:absolute;width:100%;bottom:25%;color:#fff}:host .file-details mat-icon{color:#ccc}:host .file-details .file-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:5px;font-size:75%;text-align:center;width:100%;color:inherit;box-sizing:border-box}:host .preview-container.show-action-always .actions .action.top-left,:host .preview-container:hover .actions .action.top-left,:host .preview-container:focus .actions .action.top-left{top:8px;left:8px}:host .preview-container.show-action-always .actions .action.top-right,:host .preview-container:hover .actions .action.top-right,:host .preview-container:focus .actions .action.top-right{top:8px;right:8px}:host .preview-container.show-action-always .actions .action.bottom-left,:host .preview-container:hover .actions .action.bottom-left,:host .preview-container:focus .actions .action.bottom-left{bottom:8px;left:8px}:host .preview-container.show-action-always .actions .action.bottom-right,:host .preview-container:hover .actions .action.bottom-right,:host .preview-container:focus .actions .action.bottom-right{bottom:8px;right:8px}:host .preview-container{overflow:hidden;box-sizing:border-box;margin:auto;display:flex;align-items:center;flex-grow:1;height:100%;justify-content:center}:host .preview-container.type-image{background-image:linear-gradient(to right,rgba(255,255,255,.75),rgba(255,255,255,.75)),linear-gradient(to right,black 50%,white 50%),linear-gradient(to bottom,black 50%,white 50%);background-blend-mode:normal,difference,normal;background-size:20px 20px}:host .preview-container.type-image:not(.loaded){background:none}:host .preview-container.type-image:not(.loaded) .actions{display:none}:host .preview-container.loaded img{opacity:1}@media only screen and (max-width: 767.98px){:host .actions{display:block}}:host .actions .action.top-left{top:8px;left:8px}:host .actions .action.top-right{top:8px;right:8px}:host .actions .action.bottom-left{bottom:8px;left:8px}:host .actions .action.bottom-right{bottom:8px;right:8px}@media only screen and (min-width: 768px){:host .actions .action.top-left,:host .actions .action.top-right,:host .actions .action.bottom-left,:host .actions .action.bottom-right{transition:top .3s,bottom .3s,left .3s,right .3s}:host .actions .action.top-left{top:-50px;left:-50px}:host .actions .action.top-right{top:-50px;right:-50px}:host .actions .action.bottom-left{bottom:-50px;left:-50px}:host .actions .action.bottom-right{bottom:-50px;right:-50px}}:host .actions .action{position:absolute;cursor:pointer}:host .actions .action.hide{display:none}:host:hover .actions,:host:focus .actions{display:block}:host img{display:block;transform:translateZ(.1px);object-position:top;object-fit:cover;width:100%;height:100%}:host .mat-button-wrapper{padding:0;line-height:15px!important}:host .spinner{position:absolute;top:50%;left:50%;margin-left:-25%;margin-top:-25%}img{opacity:0}.loader{height:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);max-height:70px;aspect-ratio:1/1}.loader:after{content:\" \";display:block;width:100%;height:100%;border-radius:50%;border:6px solid #ccc;border-color:#ccc transparent #ccc transparent;animation:lds-dual-ring 1.2s linear infinite;box-sizing:border-box}@keyframes lds-dual-ring{0%{transform:rotate(0)}to{transform:rotate(360deg)}}\n"], components: [{ type: i1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i2.MatSpinner, selector: "mat-spinner", inputs: ["color"] }], directives: [{ type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], pipes: { "async": i3.AsyncPipe, "fsFileSrc": i5.FsFileSrcPipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FsFilePreviewComponent, decorators: [{ | ||
@@ -116,2 +116,2 @@ type: Component, | ||
}] } }); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fs-file-preview.component.js","sourceRoot":"","sources":["../../../../../src/app/components/fs-file-preview/fs-file-preview.component.ts","../../../../../src/app/components/fs-file-preview/fs-file-preview.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  QueryList,\n  SimpleChanges,\n} from '@angular/core';\n\nimport { isArray } from 'lodash-es';\n\nimport { FsFilePreviewActionDirective } from '../../directives';\nimport { FsFile } from '../../models';\n\n\n@Component({\n  selector: 'fs-file-preview',\n  templateUrl: './fs-file-preview.component.html',\n  styleUrls: ['./fs-file-preview.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class FsFilePreviewComponent implements AfterContentInit, OnInit, OnChanges {\n\n  @ContentChildren(FsFilePreviewActionDirective)\n  public childrenPreviewActions: QueryList<FsFilePreviewActionDirective>;\n\n  @Input() public previewActions: FsFilePreviewActionDirective[] = [];\n  @Input() public showFilename = true;\n  @Input() public previewWidth: number = 150;\n  @Input() public previewHeight: number = 150;\n  @Input() public file: FsFile;\n  @Input() public url: string;\n  @Input() public index: number;\n  @Input() public showActionOn: 'hover' | 'always' = 'hover';\n\n  @Output() public remove = new EventEmitter<{ event: MouseEvent; file: FsFile }>();\n\n  public loaded = false;\n  public iconDim = 100;\n  public extensionFontSize = 20;\n\n  public get typeImage(): boolean {\n    return this.file?.typeImage && this.file?.exists;\n  }\n\n  public ngOnInit(): void {\n    if (this.url) {\n      this.file = new FsFile(this.url);\n    }\n\n    this.previewHeight = this.previewHeight || 150;\n    this.previewWidth = this.previewWidth || 150;\n\n    const iconDim = this.previewWidth * .7;\n    if (iconDim < 100) {\n      this.iconDim = iconDim;\n      this.extensionFontSize = this.extensionFontSize * (iconDim / 100);\n    }\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes.file) {\n      this.loaded = false;\n    }\n  }\n\n  public ngAfterContentInit() {\n    this._cleanActions();\n  }\n\n  public previewLoaded() {\n    this.loaded = true;\n  }\n\n  public previewError() {\n    this.loaded = true;\n  }\n\n  public callAction($event: MouseEvent, previewAction: FsFilePreviewActionDirective) {\n    if (previewAction.click.observers.length) {\n      $event.stopImmediatePropagation();\n      $event.stopPropagation();\n\n      previewAction.click.emit({ event: $event, file: this.file, index: this.index });\n    }\n\n    if (previewAction.action === 'remove') {\n      this.remove.emit({ event: $event, file: this.file });\n    }\n  }\n\n  private _cleanActions() {\n    this.previewActions\n      .forEach((action) => {\n        if (action.forTypes) {\n          // save original type\n          const [originalFileType, originalContentType] = this.file.type.split('/');\n          const types: any = isArray(action.forTypes) ? action.forTypes : [action.forTypes];\n\n          // Looking for allowed type\n          for (let i = 0; i < types.length; i++) {\n            const [fileType, contentType] = types[i].split('/');\n            const allowed = fileType === originalFileType && (contentType === originalContentType || contentType === '*');\n\n            if (!allowed) {\n              action.hide = true;\n              break;\n            }\n          }\n        }\n      });\n  }\n}\n","<div\n    [style.width.px]=\"previewWidth\"\n    [style.height.px]=\"previewHeight\"\n    class=\"preview-container\"\n    [ngClass]=\"{ \n      'has-actions': (childrenPreviewActions.length !== 0 || previewActions.length !== 0),  \n      'type-image': typeImage,\n      'loaded': loaded,\n      'show-action-always': showActionOn === 'always'\n    }\">\n  <!-- Image container -->\n  <ng-container \n      *ngIf=\"typeImage; else nonImage\">\n    <ng-container *ngIf=\"(file | fsFileSrc | async) as src\">\n      <img \n        [src]=\"src\" \n        (load)=\"previewLoaded()\">\n    </ng-container>\n   \n    <ng-container *ngIf=\"!loaded\">\n      <div class=\"loader\"></div>\n    </ng-container>\n  </ng-container>\n\n  <!-- Non image container -->\n  <ng-template #nonImage>\n    <div class=\"file-details\">\n      <div class=\"file-icon\">\n        <div \n            class=\"file-ext\"\n            [style.fontSize]=\"extensionFontSize + 'px'\">\n          {{file.extension}}\n        </div>\n        <mat-icon \n          [style.width]=\"iconDim + 'px'\" \n          [style.height]=\"iconDim + 'px'\"\n          [style.fontSize]=\"iconDim + 'px'\">insert_drive_file</mat-icon>\n      </div>\n      <ng-container *ngIf=\"showFilename && file.name\">\n        <a \n            class=\"file-name\" \n            [matTooltip]=\"file.name\">\n          {{file.name}}\n        </a>\n      </ng-container>\n    </div>\n  </ng-template>\n\n  <div class=\"actions\">\n    <ng-container *ngFor=\"let previewAction of previewActions\">\n      <ng-container \n        [ngTemplateOutlet]=\"previewActionTmpl\" \n        [ngTemplateOutletContext]=\"{ previewAction: previewAction }\">\n      </ng-container>\n    </ng-container>\n    <ng-container *ngFor=\"let previewAction of childrenPreviewActions\">\n      <ng-container \n        [ngTemplateOutlet]=\"previewActionTmpl\" \n        [ngTemplateOutletContext]=\"{ previewAction: previewAction }\">\n      </ng-container>\n    </ng-container>\n  </div>\n\n  <div class=\"spinner\">\n    <mat-spinner *ngIf=\"file.progress\" [diameter]=\"30\"></mat-spinner>\n  </div>\n  <ng-content></ng-content>\n</div>\n\n<ng-template #previewActionTmpl let-previewAction=\"previewAction\">\n  <ng-container *ngIf=\"!previewAction.hide\">\n    <div\n        class=\"action mat-mini-fab mat-primary\"      \n        [class]=\"previewAction.placement\"\n        [matTooltip]=\"previewAction.tooltip\"\n        (click)=\"callAction($event, previewAction)\">\n      <span class=\"mat-button-wrapper\">\n        <ng-template [ngTemplateOutlet]=\"previewAction.templateRef\"></ng-template>\n      </span>\n    </div>\n  </ng-container>\n</ng-template>"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fs-file-preview.component.js","sourceRoot":"","sources":["../../../../../src/app/components/fs-file-preview/fs-file-preview.component.ts","../../../../../src/app/components/fs-file-preview/fs-file-preview.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChildren,\n  EventEmitter,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  QueryList,\n  SimpleChanges,\n} from '@angular/core';\n\nimport { isArray } from 'lodash-es';\n\nimport { FsFilePreviewActionDirective } from '../../directives';\nimport { FsFile } from '../../models';\n\n\n@Component({\n  selector: 'fs-file-preview',\n  templateUrl: './fs-file-preview.component.html',\n  styleUrls: ['./fs-file-preview.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class FsFilePreviewComponent implements AfterContentInit, OnInit, OnChanges {\n\n  @ContentChildren(FsFilePreviewActionDirective)\n  public childrenPreviewActions: QueryList<FsFilePreviewActionDirective>;\n\n  @Input() public previewActions: FsFilePreviewActionDirective[] = [];\n  @Input() public showFilename = true;\n  @Input() public previewWidth: number = 150;\n  @Input() public previewHeight: number = 150;\n  @Input() public file: FsFile;\n  @Input() public url: string;\n  @Input() public index: number;\n  @Input() public showActionOn: 'hover' | 'always' = 'hover';\n\n  @Output() public remove = new EventEmitter<{ event: MouseEvent; file: FsFile }>();\n\n  public loaded = false;\n  public iconDim = 100;\n  public extensionFontSize = 20;\n\n  public get typeImage(): boolean {\n    return this.file?.typeImage && this.file?.exists;\n  }\n\n  public ngOnInit(): void {\n    if (this.url) {\n      this.file = new FsFile(this.url);\n    }\n\n    this.previewHeight = this.previewHeight || 150;\n    this.previewWidth = this.previewWidth || 150;\n\n    const iconDim = this.previewWidth * .7;\n    if (iconDim < 100) {\n      this.iconDim = iconDim;\n      this.extensionFontSize = this.extensionFontSize * (iconDim / 100);\n    }\n  }\n\n  public ngOnChanges(changes: SimpleChanges): void {\n    if (changes.file) {\n      this.loaded = false;\n    }\n  }\n\n  public ngAfterContentInit() {\n    this._cleanActions();\n  }\n\n  public previewLoaded() {\n    this.loaded = true;\n  }\n\n  public previewError() {\n    this.loaded = true;\n  }\n\n  public callAction($event: MouseEvent, previewAction: FsFilePreviewActionDirective) {\n    if (previewAction.click.observers.length) {\n      $event.stopImmediatePropagation();\n      $event.stopPropagation();\n\n      previewAction.click.emit({ event: $event, file: this.file, index: this.index });\n    }\n\n    if (previewAction.action === 'remove') {\n      this.remove.emit({ event: $event, file: this.file });\n    }\n  }\n\n  private _cleanActions() {\n    this.previewActions\n      .forEach((action) => {\n        if (action.forTypes) {\n          // save original type\n          const [originalFileType, originalContentType] = this.file.type.split('/');\n          const types: any = isArray(action.forTypes) ? action.forTypes : [action.forTypes];\n\n          // Looking for allowed type\n          for (let i = 0; i < types.length; i++) {\n            const [fileType, contentType] = types[i].split('/');\n            const allowed = fileType === originalFileType && (contentType === originalContentType || contentType === '*');\n\n            if (!allowed) {\n              action.hide = true;\n              break;\n            }\n          }\n        }\n      });\n  }\n}\n","<div\n    [style.width.px]=\"previewWidth\"\n    [style.height.px]=\"previewHeight\"\n    class=\"preview-container\"\n    [ngClass]=\"{ \n      'has-actions': (childrenPreviewActions.length !== 0 || previewActions.length !== 0),  \n      'type-image': typeImage,\n      'loaded': loaded,\n      'show-action-always': showActionOn === 'always'\n    }\">\n  <!-- Image container -->\n  <ng-container \n      *ngIf=\"typeImage; else nonImage\">\n    <ng-container *ngIf=\"(file | fsFileSrc | async) as src\">\n      <img \n        [src]=\"src\" \n        (load)=\"previewLoaded()\"\n        (error)=\"previewError()\">\n    </ng-container>\n   \n    <ng-container *ngIf=\"!loaded\">\n      <div class=\"loader\"></div>\n    </ng-container>\n  </ng-container>\n\n  <!-- Non image container -->\n  <ng-template #nonImage>\n    <div class=\"file-details\">\n      <div class=\"file-icon\">\n        <div \n            class=\"file-ext\"\n            [style.fontSize]=\"extensionFontSize + 'px'\">\n          {{file.extension}}\n        </div>\n        <mat-icon \n          [style.width]=\"iconDim + 'px'\" \n          [style.height]=\"iconDim + 'px'\"\n          [style.fontSize]=\"iconDim + 'px'\">insert_drive_file</mat-icon>\n      </div>\n      <ng-container *ngIf=\"showFilename && file.name\">\n        <a \n            class=\"file-name\" \n            [matTooltip]=\"file.name\">\n          {{file.name}}\n        </a>\n      </ng-container>\n    </div>\n  </ng-template>\n\n  <div class=\"actions\">\n    <ng-container *ngFor=\"let previewAction of previewActions\">\n      <ng-container \n        [ngTemplateOutlet]=\"previewActionTmpl\" \n        [ngTemplateOutletContext]=\"{ previewAction: previewAction }\">\n      </ng-container>\n    </ng-container>\n    <ng-container *ngFor=\"let previewAction of childrenPreviewActions\">\n      <ng-container \n        [ngTemplateOutlet]=\"previewActionTmpl\" \n        [ngTemplateOutletContext]=\"{ previewAction: previewAction }\">\n      </ng-container>\n    </ng-container>\n  </div>\n\n  <div class=\"spinner\">\n    <mat-spinner *ngIf=\"file.progress\" [diameter]=\"30\"></mat-spinner>\n  </div>\n  <ng-content></ng-content>\n</div>\n\n<ng-template #previewActionTmpl let-previewAction=\"previewAction\">\n  <ng-container *ngIf=\"!previewAction.hide\">\n    <div\n        class=\"action mat-mini-fab mat-primary\"      \n        [class]=\"previewAction.placement\"\n        [matTooltip]=\"previewAction.tooltip\"\n        (click)=\"callAction($event, previewAction)\">\n      <span class=\"mat-button-wrapper\">\n        <ng-template [ngTemplateOutlet]=\"previewAction.templateRef\"></ng-template>\n      </span>\n    </div>\n  </ng-container>\n</ng-template>"]} |
@@ -6,2 +6,3 @@ export class FileProcessConfig { | ||
this._orientate = true; | ||
this._heic = false; | ||
this.maxWidth = config.maxWidth; | ||
@@ -15,3 +16,3 @@ this.maxHeight = config.maxHeight; | ||
set maxWidth(value) { | ||
if (value !== void 0) { | ||
if (value !== undefined) { | ||
this._maxWidth = +value; | ||
@@ -24,3 +25,3 @@ } | ||
set maxHeight(value) { | ||
if (value !== void 0) { | ||
if (value !== undefined) { | ||
this._maxHeight = +value; | ||
@@ -68,2 +69,2 @@ } | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1wcm9jZXNzLWNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9hcHAvbW9kZWxzL2ZpbGUtcHJvY2Vzcy1jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsTUFBTSxPQUFPLGlCQUFpQjtJQVU1QixZQUFZLFNBQThCLEVBQUU7O1FBTnBDLGFBQVEsR0FBVyxDQUFDLENBQUM7UUFJckIsZUFBVSxHQUFHLElBQUksQ0FBQztRQUd4QixJQUFJLENBQUMsUUFBUSxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUM7UUFDaEMsSUFBSSxDQUFDLFNBQVMsR0FBRyxNQUFNLENBQUMsU0FBUyxDQUFDO1FBQ2xDLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQztRQUM1QixJQUFJLENBQUMsU0FBUyxHQUFHLE1BQUEsTUFBTSxDQUFDLFNBQVMsbUNBQUksSUFBSSxDQUFDO1FBQzFDLElBQUksQ0FBQyxRQUFRLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQztRQUNoQyxJQUFJLENBQUMsU0FBUyxHQUFHLE1BQU0sQ0FBQyxTQUFTLENBQUM7SUFDcEMsQ0FBQztJQUVELElBQVcsUUFBUSxDQUFDLEtBQUs7UUFDdkIsSUFBSSxLQUFLLEtBQUssS0FBSyxDQUFDLEVBQUU7WUFDcEIsSUFBSSxDQUFDLFNBQVMsR0FBRyxDQUFDLEtBQUssQ0FBQztTQUN6QjtJQUNILENBQUM7SUFFRCxJQUFXLFFBQVE7UUFDakIsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQ3hCLENBQUM7SUFFRCxJQUFXLFNBQVMsQ0FBQyxLQUFLO1FBQ3hCLElBQUksS0FBSyxLQUFLLEtBQUssQ0FBQyxFQUFFO1lBQ3BCLElBQUksQ0FBQyxVQUFVLEdBQUcsQ0FBQyxLQUFLLENBQUM7U0FDMUI7SUFDSCxDQUFDO0lBRUQsSUFBVyxTQUFTO1FBQ2xCLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQztJQUN6QixDQUFDO0lBRUQsSUFBVyxPQUFPLENBQUMsS0FBVTtRQUMzQixNQUFNLEdBQUcsR0FBRyxVQUFVLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDOUIsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsRUFBRTtZQUNmLElBQUksQ0FBQyxRQUFRLEdBQUcsR0FBRyxDQUFDO1NBQ3JCO0lBQ0gsQ0FBQztJQUVELElBQVcsT0FBTztRQUNoQixPQUFPLElBQUksQ0FBQyxRQUFRLENBQUM7SUFDdkIsQ0FBQztJQUVELElBQVcsTUFBTSxDQUFDLEtBQW9CO1FBQ3BDLElBQUksQ0FBQyxLQUFLLEVBQUUsS0FBSyxDQUFDLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFO1lBQ3RDLElBQUksQ0FBQyxPQUFPLEdBQUcsS0FBSyxDQUFBO1NBQ3JCO0lBQ0gsQ0FBQztJQUVELElBQVcsTUFBTTtRQUNmLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUN0QixDQUFDO0lBRUQsSUFBVyxTQUFTO1FBQ2xCLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQztJQUN6QixDQUFDO0lBRUQsSUFBVyxTQUFTLENBQUMsS0FBSztRQUN4QixJQUFJLENBQUMsVUFBVSxHQUFHLEtBQUssQ0FBQztJQUMxQixDQUFDO0lBRUQsSUFBVyxRQUFRLENBQUMsS0FBSztRQUN2QixJQUFJLENBQUMsU0FBUyxHQUFHLEtBQUssQ0FBQztJQUN6QixDQUFDO0lBRUQsSUFBVyxRQUFRO1FBQ2pCLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQztJQUN4QixDQUFDO0lBRUQsSUFBVyxTQUFTLENBQUMsS0FBSztRQUN4QixJQUFJLENBQUMsVUFBVSxHQUFHLEtBQUssQ0FBQztJQUMxQixDQUFDO0lBRUQsSUFBVyxTQUFTO1FBQ2xCLE9BQU8sSUFBSSxDQUFDLFVBQVUsQ0FBQztJQUN6QixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBGc0ZpbGVQcm9jZXNzQ29uZmlnIH0gZnJvbSBcIi4uL2ludGVyZmFjZXNcIjtcblxuXG5leHBvcnQgY2xhc3MgRmlsZVByb2Nlc3NDb25maWcge1xuXG4gIHByaXZhdGUgX21heFdpZHRoOiBudW1iZXI7XG4gIHByaXZhdGUgX21heEhlaWdodDogbnVtYmVyO1xuICBwcml2YXRlIF9xdWFsaXR5OiBudW1iZXIgPSAxO1xuICBwcml2YXRlIF9mb3JtYXQ6ICdwbmcnIHwgJ2pwZyc7XG4gIHByaXZhdGUgX21pbldpZHRoOiBudW1iZXI7XG4gIHByaXZhdGUgX21pbkhlaWdodDogbnVtYmVyO1xuICBwcml2YXRlIF9vcmllbnRhdGUgPSB0cnVlO1xuXG4gIGNvbnN0cnVjdG9yKGNvbmZpZzogRnNGaWxlUHJvY2Vzc0NvbmZpZyA9IHt9KSB7XG4gICAgdGhpcy5tYXhXaWR0aCA9IGNvbmZpZy5tYXhXaWR0aDtcbiAgICB0aGlzLm1heEhlaWdodCA9IGNvbmZpZy5tYXhIZWlnaHQ7XG4gICAgdGhpcy5mb3JtYXQgPSBjb25maWcuZm9ybWF0O1xuICAgIHRoaXMub3JpZW50YXRlID0gY29uZmlnLm9yaWVudGF0ZSA/PyB0cnVlO1xuICAgIHRoaXMubWluV2lkdGggPSBjb25maWcubWluV2lkdGg7XG4gICAgdGhpcy5taW5IZWlnaHQgPSBjb25maWcubWluSGVpZ2h0O1xuICB9XG5cbiAgcHVibGljIHNldCBtYXhXaWR0aCh2YWx1ZSkge1xuICAgIGlmICh2YWx1ZSAhPT0gdm9pZCAwKSB7XG4gICAgICB0aGlzLl9tYXhXaWR0aCA9ICt2YWx1ZTtcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgZ2V0IG1heFdpZHRoKCkge1xuICAgIHJldHVybiB0aGlzLl9tYXhXaWR0aDtcbiAgfVxuXG4gIHB1YmxpYyBzZXQgbWF4SGVpZ2h0KHZhbHVlKSB7XG4gICAgaWYgKHZhbHVlICE9PSB2b2lkIDApIHtcbiAgICAgIHRoaXMuX21heEhlaWdodCA9ICt2YWx1ZTtcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgZ2V0IG1heEhlaWdodCgpIHtcbiAgICByZXR1cm4gdGhpcy5fbWF4SGVpZ2h0O1xuICB9XG5cbiAgcHVibGljIHNldCBxdWFsaXR5KHZhbHVlOiBhbnkpIHtcbiAgICBjb25zdCB2YWwgPSBwYXJzZUZsb2F0KHZhbHVlKTtcbiAgICBpZiAoIWlzTmFOKHZhbCkpIHtcbiAgICAgIHRoaXMuX3F1YWxpdHkgPSB2YWw7XG4gICAgfVxuICB9XG5cbiAgcHVibGljIGdldCBxdWFsaXR5KCkge1xuICAgIHJldHVybiB0aGlzLl9xdWFsaXR5O1xuICB9XG5cbiAgcHVibGljIHNldCBmb3JtYXQodmFsdWU6ICdqcGcnIHwgJ3BuZycpIHtcbiAgICBpZiAoWydqcGcnLCAncG5nJ10uaW5kZXhPZih2YWx1ZSkgPiAtMSkge1xuICAgICAgdGhpcy5fZm9ybWF0ID0gdmFsdWVcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgZ2V0IGZvcm1hdCgpIHtcbiAgICByZXR1cm4gdGhpcy5fZm9ybWF0O1xuICB9XG5cbiAgcHVibGljIGdldCBvcmllbnRhdGUoKSB7XG4gICAgcmV0dXJuIHRoaXMuX29yaWVudGF0ZTtcbiAgfVxuXG4gIHB1YmxpYyBzZXQgb3JpZW50YXRlKHZhbHVlKSB7XG4gICAgdGhpcy5fb3JpZW50YXRlID0gdmFsdWU7XG4gIH1cblxuICBwdWJsaWMgc2V0IG1pbldpZHRoKHZhbHVlKSB7XG4gICAgdGhpcy5fbWluV2lkdGggPSB2YWx1ZTtcbiAgfVxuXG4gIHB1YmxpYyBnZXQgbWluV2lkdGgoKSB7XG4gICAgcmV0dXJuIHRoaXMuX21pbldpZHRoO1xuICB9XG5cbiAgcHVibGljIHNldCBtaW5IZWlnaHQodmFsdWUpIHtcbiAgICB0aGlzLl9taW5IZWlnaHQgPSB2YWx1ZTtcbiAgfVxuXG4gIHB1YmxpYyBnZXQgbWluSGVpZ2h0KCkge1xuICAgIHJldHVybiB0aGlzLl9taW5IZWlnaHQ7XG4gIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZS1wcm9jZXNzLWNvbmZpZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9hcHAvbW9kZWxzL2ZpbGUtcHJvY2Vzcy1jb25maWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBR0EsTUFBTSxPQUFPLGlCQUFpQjtJQVc1QixZQUFZLFNBQThCLEVBQUU7O1FBUHBDLGFBQVEsR0FBVyxDQUFDLENBQUM7UUFJckIsZUFBVSxHQUFHLElBQUksQ0FBQztRQUNsQixVQUFLLEdBQUcsS0FBSyxDQUFDO1FBR3BCLElBQUksQ0FBQyxRQUFRLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQztRQUNoQyxJQUFJLENBQUMsU0FBUyxHQUFHLE1BQU0sQ0FBQyxTQUFTLENBQUM7UUFDbEMsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDO1FBQzVCLElBQUksQ0FBQyxTQUFTLEdBQUcsTUFBQSxNQUFNLENBQUMsU0FBUyxtQ0FBSSxJQUFJLENBQUM7UUFDMUMsSUFBSSxDQUFDLFFBQVEsR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDO1FBQ2hDLElBQUksQ0FBQyxTQUFTLEdBQUcsTUFBTSxDQUFDLFNBQVMsQ0FBQztJQUNwQyxDQUFDO0lBRUQsSUFBVyxRQUFRLENBQUMsS0FBSztRQUN2QixJQUFJLEtBQUssS0FBSyxTQUFTLEVBQUU7WUFDdkIsSUFBSSxDQUFDLFNBQVMsR0FBRyxDQUFDLEtBQUssQ0FBQztTQUN6QjtJQUNILENBQUM7SUFFRCxJQUFXLFFBQVE7UUFDakIsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQ3hCLENBQUM7SUFFRCxJQUFXLFNBQVMsQ0FBQyxLQUFLO1FBQ3hCLElBQUksS0FBSyxLQUFLLFNBQVMsRUFBRTtZQUN2QixJQUFJLENBQUMsVUFBVSxHQUFHLENBQUMsS0FBSyxDQUFDO1NBQzFCO0lBQ0gsQ0FBQztJQUVELElBQVcsU0FBUztRQUNsQixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUM7SUFDekIsQ0FBQztJQUVELElBQVcsT0FBTyxDQUFDLEtBQVU7UUFDM0IsTUFBTSxHQUFHLEdBQUcsVUFBVSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQzlCLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLEVBQUU7WUFDZixJQUFJLENBQUMsUUFBUSxHQUFHLEdBQUcsQ0FBQztTQUNyQjtJQUNILENBQUM7SUFFRCxJQUFXLE9BQU87UUFDaEIsT0FBTyxJQUFJLENBQUMsUUFBUSxDQUFDO0lBQ3ZCLENBQUM7SUFFRCxJQUFXLE1BQU0sQ0FBQyxLQUFvQjtRQUNwQyxJQUFJLENBQUMsS0FBSyxFQUFFLEtBQUssQ0FBQyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRTtZQUN0QyxJQUFJLENBQUMsT0FBTyxHQUFHLEtBQUssQ0FBQztTQUN0QjtJQUNILENBQUM7SUFFRCxJQUFXLE1BQU07UUFDZixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUM7SUFDdEIsQ0FBQztJQUVELElBQVcsU0FBUztRQUNsQixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUM7SUFDekIsQ0FBQztJQUVELElBQVcsU0FBUyxDQUFDLEtBQUs7UUFDeEIsSUFBSSxDQUFDLFVBQVUsR0FBRyxLQUFLLENBQUM7SUFDMUIsQ0FBQztJQUVELElBQVcsUUFBUSxDQUFDLEtBQUs7UUFDdkIsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUM7SUFDekIsQ0FBQztJQUVELElBQVcsUUFBUTtRQUNqQixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDeEIsQ0FBQztJQUVELElBQVcsU0FBUyxDQUFDLEtBQUs7UUFDeEIsSUFBSSxDQUFDLFVBQVUsR0FBRyxLQUFLLENBQUM7SUFDMUIsQ0FBQztJQUVELElBQVcsU0FBUztRQUNsQixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUM7SUFDekIsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRnNGaWxlUHJvY2Vzc0NvbmZpZyB9IGZyb20gJy4uL2ludGVyZmFjZXMnO1xuXG5cbmV4cG9ydCBjbGFzcyBGaWxlUHJvY2Vzc0NvbmZpZyB7XG5cbiAgcHJpdmF0ZSBfbWF4V2lkdGg6IG51bWJlcjtcbiAgcHJpdmF0ZSBfbWF4SGVpZ2h0OiBudW1iZXI7XG4gIHByaXZhdGUgX3F1YWxpdHk6IG51bWJlciA9IDE7XG4gIHByaXZhdGUgX2Zvcm1hdDogJ3BuZycgfCAnanBnJztcbiAgcHJpdmF0ZSBfbWluV2lkdGg6IG51bWJlcjtcbiAgcHJpdmF0ZSBfbWluSGVpZ2h0OiBudW1iZXI7XG4gIHByaXZhdGUgX29yaWVudGF0ZSA9IHRydWU7XG4gIHByaXZhdGUgX2hlaWMgPSBmYWxzZTtcblxuICBjb25zdHJ1Y3Rvcihjb25maWc6IEZzRmlsZVByb2Nlc3NDb25maWcgPSB7fSkge1xuICAgIHRoaXMubWF4V2lkdGggPSBjb25maWcubWF4V2lkdGg7XG4gICAgdGhpcy5tYXhIZWlnaHQgPSBjb25maWcubWF4SGVpZ2h0O1xuICAgIHRoaXMuZm9ybWF0ID0gY29uZmlnLmZvcm1hdDtcbiAgICB0aGlzLm9yaWVudGF0ZSA9IGNvbmZpZy5vcmllbnRhdGUgPz8gdHJ1ZTtcbiAgICB0aGlzLm1pbldpZHRoID0gY29uZmlnLm1pbldpZHRoO1xuICAgIHRoaXMubWluSGVpZ2h0ID0gY29uZmlnLm1pbkhlaWdodDtcbiAgfVxuXG4gIHB1YmxpYyBzZXQgbWF4V2lkdGgodmFsdWUpIHtcbiAgICBpZiAodmFsdWUgIT09IHVuZGVmaW5lZCkge1xuICAgICAgdGhpcy5fbWF4V2lkdGggPSArdmFsdWU7XG4gICAgfVxuICB9XG5cbiAgcHVibGljIGdldCBtYXhXaWR0aCgpIHtcbiAgICByZXR1cm4gdGhpcy5fbWF4V2lkdGg7XG4gIH1cblxuICBwdWJsaWMgc2V0IG1heEhlaWdodCh2YWx1ZSkge1xuICAgIGlmICh2YWx1ZSAhPT0gdW5kZWZpbmVkKSB7XG4gICAgICB0aGlzLl9tYXhIZWlnaHQgPSArdmFsdWU7XG4gICAgfVxuICB9XG5cbiAgcHVibGljIGdldCBtYXhIZWlnaHQoKSB7XG4gICAgcmV0dXJuIHRoaXMuX21heEhlaWdodDtcbiAgfVxuXG4gIHB1YmxpYyBzZXQgcXVhbGl0eSh2YWx1ZTogYW55KSB7XG4gICAgY29uc3QgdmFsID0gcGFyc2VGbG9hdCh2YWx1ZSk7XG4gICAgaWYgKCFpc05hTih2YWwpKSB7XG4gICAgICB0aGlzLl9xdWFsaXR5ID0gdmFsO1xuICAgIH1cbiAgfVxuXG4gIHB1YmxpYyBnZXQgcXVhbGl0eSgpIHtcbiAgICByZXR1cm4gdGhpcy5fcXVhbGl0eTtcbiAgfVxuXG4gIHB1YmxpYyBzZXQgZm9ybWF0KHZhbHVlOiAnanBnJyB8ICdwbmcnKSB7XG4gICAgaWYgKFsnanBnJywgJ3BuZyddLmluZGV4T2YodmFsdWUpID4gLTEpIHtcbiAgICAgIHRoaXMuX2Zvcm1hdCA9IHZhbHVlO1xuICAgIH1cbiAgfVxuXG4gIHB1YmxpYyBnZXQgZm9ybWF0KCkge1xuICAgIHJldHVybiB0aGlzLl9mb3JtYXQ7XG4gIH1cblxuICBwdWJsaWMgZ2V0IG9yaWVudGF0ZSgpIHtcbiAgICByZXR1cm4gdGhpcy5fb3JpZW50YXRlO1xuICB9XG5cbiAgcHVibGljIHNldCBvcmllbnRhdGUodmFsdWUpIHtcbiAgICB0aGlzLl9vcmllbnRhdGUgPSB2YWx1ZTtcbiAgfVxuXG4gIHB1YmxpYyBzZXQgbWluV2lkdGgodmFsdWUpIHtcbiAgICB0aGlzLl9taW5XaWR0aCA9IHZhbHVlO1xuICB9XG5cbiAgcHVibGljIGdldCBtaW5XaWR0aCgpIHtcbiAgICByZXR1cm4gdGhpcy5fbWluV2lkdGg7XG4gIH1cblxuICBwdWJsaWMgc2V0IG1pbkhlaWdodCh2YWx1ZSkge1xuICAgIHRoaXMuX21pbkhlaWdodCA9IHZhbHVlO1xuICB9XG5cbiAgcHVibGljIGdldCBtaW5IZWlnaHQoKSB7XG4gICAgcmV0dXJuIHRoaXMuX21pbkhlaWdodDtcbiAgfVxufVxuIl19 |
import { FsApiFile } from '@firestitch/api'; | ||
import * as EXIF from '@firestitch/exif-js'; | ||
import * as FileAPI from 'fileapi'; | ||
import { Observable, of } from 'rxjs'; | ||
import { catchError, map, switchMap, tap } from 'rxjs/operators'; | ||
import * as FileAPI from 'fileapi'; | ||
export class FsFile { | ||
@@ -11,36 +11,39 @@ constructor(obj, filename) { | ||
this._fileExists = false; | ||
this._init(obj, filename); | ||
this._checkIfFileExists(); | ||
} | ||
_init(obj, filename) { | ||
if (obj instanceof File) { | ||
this.file = obj; | ||
return this.file = obj; | ||
} | ||
else { | ||
let type; | ||
let fileBlob = []; | ||
if (obj instanceof Blob) { | ||
fileBlob = [obj]; | ||
if (obj.type) { | ||
type = obj.type; | ||
if (!filename) { | ||
filename = 'file.' + obj.type.split('/').pop(); | ||
} | ||
let type; | ||
let fileBlob = []; | ||
if (obj instanceof Blob) { | ||
fileBlob = [obj]; | ||
if (obj.type) { | ||
type = obj.type; | ||
if (!filename) { | ||
filename = `file.${obj.type.split('/').pop()}`; | ||
} | ||
} | ||
else if (typeof obj === 'string') { | ||
const url = new URL(obj); | ||
filename = filename || url.pathname.split('/').pop(); | ||
this.url = url.href; | ||
} | ||
else if (obj instanceof FsApiFile) { | ||
this._apiFile = obj; | ||
filename = filename || this._apiFile.name; | ||
} | ||
if (filename) { | ||
const match = filename.toLowerCase().match(/([^\.]+)$/); | ||
this.extension = match ? match[1] : ''; | ||
const mime = this.extension.match(/(jpe?g|png|gif|tiff?|bmp|svg)/) ? 'image' : 'application'; | ||
type = mime + '/' + this.extension; | ||
} | ||
this.file = new File(fileBlob, filename, { type }); | ||
} | ||
this._checkIfFileExists(); | ||
else if (typeof obj === 'string') { | ||
const url = new URL(obj); | ||
filename = filename || url.pathname.split('/').pop(); | ||
this.url = url.href; | ||
} | ||
else if (obj instanceof FsApiFile) { | ||
this._apiFile = obj; | ||
filename = filename || this._apiFile.name; | ||
} | ||
if (filename) { | ||
const match = filename.toLowerCase().match(/([^\.]+)$/); | ||
this.extension = match ? match[1] : ''; | ||
type = `${this._getExtensionMime()}/${this.extension}`; | ||
} | ||
this.file = new File(fileBlob, filename, { type }); | ||
} | ||
_getExtensionMime() { | ||
return this.extension.match(/(jpe?g|png|gif|tiff?|bmp|svg|heic)/) ? 'image' : 'application'; | ||
} | ||
get imageWidth() { | ||
@@ -88,5 +91,2 @@ return new Promise((resolve, reject) => { | ||
} | ||
get name() { | ||
return this._name; | ||
} | ||
set file(value) { | ||
@@ -99,2 +99,5 @@ this._file = value; | ||
} | ||
get name() { | ||
return this._name; | ||
} | ||
set name(name) { | ||
@@ -162,3 +165,3 @@ this._name = name; | ||
this.file; | ||
var link = document.createElement('a'); | ||
const link = document.createElement('a'); | ||
link.href = href; | ||
@@ -178,3 +181,3 @@ link.download = this.name; | ||
imageWidth: this.imageWidth, | ||
imageHeight: this.imageHeight | ||
imageHeight: this.imageHeight, | ||
}; | ||
@@ -186,2 +189,2 @@ } | ||
} | ||
//# 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 { FsApiFile } from '@firestitch/api';\nimport * as EXIF from '@firestitch/exif-js';\n\nimport * as FileAPI from 'fileapi';\nimport { from, Observable, of } from 'rxjs';\nimport { catchError, map, switchMap, tap } from 'rxjs/operators';\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 _fileExists = false;\n  private _imageWidth: number;\n  private _imageHeight: number;\n  private _exifInfo: any;  \n  private _apiFile: FsApiFile;\n\n  constructor(obj?: File|Blob|string|FsApiFile, filename?: string) {    \n    if (obj instanceof File) {\n      this.file = obj;\n    } else {\n      let type;\n      let fileBlob = [];\n\n      if (obj instanceof Blob) {\n        fileBlob = [obj];\n\n        if(obj.type) {\n          type = obj.type;\n\n          if(!filename) {\n            filename = 'file.' + obj.type.split('/').pop();\n          }\n        }\n\n      } else if(typeof obj === 'string') {\n        const url = new URL(obj);\n        filename = filename || url.pathname.split('/').pop();\n        this.url = url.href;\n      } else if (obj instanceof FsApiFile) {\n        this._apiFile = obj;\n        filename = filename || this._apiFile.name;\n      }\n\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 = new File(fileBlob, 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 apiFile(): FsApiFile {\n    return this._apiFile;\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 file(value: File) {\n    this._file = value;\n    this.size = value.size;\n    this.type = value.type;\n    this.name = value.name;\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 Observable<any>((observer) => {\n      const fr = new FileReader();\n      fr.onload = () => {\n        const exif = EXIF.readFromBinaryFile(fr.result);\n        if(exif) {\n          observer.next(exif);\n          observer.complete();\n        } else {\n          observer.error('Failed to read from binary file');\n        }\n      };\n\n      fr.onerror = () => {\n        observer.error(fr.error);\n      }\n\n      fr.readAsArrayBuffer(this.file);\n    });\n\n    const dims$ = new Observable<any>((observer) => {\n      FileAPI.getInfo(this.file, (err, info) => {\n        if (!err) {\n          observer.next(info);\n          observer.complete();\n        } else {\n          observer.error(err);        \n        }\n      });\n    });\n\n    return of(true)\n      .pipe(\n        switchMap(() => dims$\n          .pipe(\n            tap((dims) => {\n            this._imageWidth = dims.width;\n            this._imageHeight = dims.height;\n            }),\n\n            catchError(() => of(true)),\n          )\n        ),\n        switchMap(() => exif$\n          .pipe(\n            tap((exif) => {\n              this._exifInfo = exif || {};\n            }),\n            catchError(() => of(true)),\n          )\n        ),\n        map(() => ({\n          width: this._imageWidth,\n          height: this._imageHeight,\n          exif: this._exifInfo,\n        })),\n      )\n      .toPromise();\n  }\n\n  public download() {\n    const href = this.file instanceof File ?\n      URL.createObjectURL(this.file) :\n      this.file;\n\n    var link = document.createElement('a'); \n    link.href = href;\n    link.download = this.name;\n    document.body.appendChild(link); \n    link.click();\n    link.remove();\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.url || !!this.size || !!this.apiFile;\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 { FsApiFile } from '@firestitch/api';\nimport * as EXIF from '@firestitch/exif-js';\n\nimport { Observable, of } from 'rxjs';\nimport { catchError, map, switchMap, tap } from 'rxjs/operators';\n\nimport * as FileAPI from 'fileapi';\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 _fileExists = false;\n  private _imageWidth: number;\n  private _imageHeight: number;\n  private _exifInfo: any;\n  private _apiFile: FsApiFile;\n\n  constructor(obj?: File|Blob|string|FsApiFile, filename?: string) {\n    this._init(obj, filename);\n    this._checkIfFileExists();\n  }\n\n  private _init(obj?: File|Blob|string|FsApiFile, filename?: string) {\n    if (obj instanceof File) {\n      return this.file = obj;\n    }\n\n    let type;\n    let fileBlob = [];\n    if (obj instanceof Blob) {\n      fileBlob = [obj];\n\n      if(obj.type) {\n        type = obj.type;\n\n        if(!filename) {\n          filename = `file.${  obj.type.split('/').pop()}`;\n        }\n      }\n\n    } else if(typeof obj === 'string') {\n      const url = new URL(obj);\n      filename = filename || url.pathname.split('/').pop();\n      this.url = url.href;\n    } else if (obj instanceof FsApiFile) {\n      this._apiFile = obj;\n      filename = filename || this._apiFile.name;\n    }\n\n    if (filename) {\n      const match = filename.toLowerCase().match(/([^\\.]+)$/);\n      this.extension = match ? match[1] : '';\n      type = `${this._getExtensionMime()}/${this.extension}`;\n    }\n\n    this.file = new File(fileBlob, filename, { type });\n  }\n\n  private _getExtensionMime() {\n    return this.extension.match(/(jpe?g|png|gif|tiff?|bmp|svg|heic)/) ? 'image' : 'application';\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 apiFile(): FsApiFile {\n    return this._apiFile;\n  }\n\n  public get exists() {\n    return this._fileExists;\n  }\n\n  public get file() {\n    return this._file;\n  }\n\n  public set file(value: File) {\n    this._file = value;\n    this.size = value.size;\n    this.type = value.type;\n    this.name = value.name;\n    this._checkIfFileExists();\n  }\n\n  public get name() {\n    return this._name;\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 Observable<any>((observer) => {\n      const fr = new FileReader();\n      fr.onload = () => {\n        const exif = EXIF.readFromBinaryFile(fr.result);\n        if(exif) {\n          observer.next(exif);\n          observer.complete();\n        } else {\n          observer.error('Failed to read from binary file');\n        }\n      };\n\n      fr.onerror = () => {\n        observer.error(fr.error);\n      };\n\n      fr.readAsArrayBuffer(this.file);\n    });\n\n    const dims$ = new Observable<any>((observer) => {\n      FileAPI.getInfo(this.file, (err, info) => {\n        if (!err) {\n          observer.next(info);\n          observer.complete();\n        } else {\n          observer.error(err);\n        }\n      });\n    });\n\n    return of(true)\n      .pipe(\n        switchMap(() => dims$\n          .pipe(\n            tap((dims) => {\n              this._imageWidth = dims.width;\n              this._imageHeight = dims.height;\n            }),\n\n            catchError(() => of(true)),\n          ),\n        ),\n        switchMap(() => exif$\n          .pipe(\n            tap((exif) => {\n              this._exifInfo = exif || {};\n            }),\n            catchError(() => of(true)),\n          ),\n        ),\n        map(() => ({\n          width: this._imageWidth,\n          height: this._imageHeight,\n          exif: this._exifInfo,\n        })),\n      )\n      .toPromise();\n  }\n\n  public download() {\n    const href = this.file instanceof File ?\n      URL.createObjectURL(this.file) :\n      this.file;\n\n    const link = document.createElement('a');\n    link.href = href;\n    link.download = this.name;\n    document.body.appendChild(link);\n    link.click();\n    link.remove();\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.url || !!this.size || !!this.apiFile;\n  }\n}\n"]} |
@@ -30,3 +30,3 @@ import { EventEmitter, Inject, Injectable, Optional } from '@angular/core'; | ||
this._acceptableExts.clear(); | ||
this.parseAcceptTypes(value); | ||
this._parseAcceptTypes(value); | ||
this._accept = [ | ||
@@ -38,3 +38,3 @@ ...Array.from(this._acceptableTypes) | ||
...Array.from(values) | ||
.map((value) => `${key}/${value}`), | ||
.map((item) => `${key}/${item}`), | ||
]; | ||
@@ -50,2 +50,3 @@ }, []), | ||
* Initialize service for target element | ||
* | ||
* @param el | ||
@@ -97,3 +98,3 @@ */ | ||
...this._clickInterceptors || [], | ||
new ClickInterceptor() | ||
new ClickInterceptor(), | ||
]; | ||
@@ -122,4 +123,4 @@ const interceptorChain = interceptors.reduceRight((next, interceptor) => new FileClickHandler(next, interceptor), null); | ||
} | ||
ext = (ext + '').toLowerCase(); | ||
const acceptableFile = this.checkAcceptableTypes(file.type, ext); | ||
ext = (`${ext}`).toLowerCase(); | ||
const acceptableFile = this._checkAcceptableTypes(file.type, ext); | ||
if (!acceptableFile) { | ||
@@ -142,2 +143,3 @@ declinedFiles.push(file); | ||
* Check if file mimetype or extention is acceptable by @accept field | ||
* | ||
* @param targetType | ||
@@ -147,3 +149,3 @@ * @param targetExt | ||
*/ | ||
checkAcceptableTypes(targetType, targetExt) { | ||
_checkAcceptableTypes(targetType, targetExt) { | ||
targetType = targetType.trim(); | ||
@@ -159,5 +161,6 @@ const [type, ext] = targetType.split('/'); | ||
* Parset and store acceptable types for feature filter | ||
* | ||
* @param types | ||
*/ | ||
parseAcceptTypes(value) { | ||
_parseAcceptTypes(value) { | ||
let types = []; | ||
@@ -214,2 +217,2 @@ if (typeof value === 'string') { | ||
}] }]; } }); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-processor.service.js","sourceRoot":"","sources":["../../../../src/app/services/input-processor.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, EventEmitter, Inject, Injectable, Optional } from '@angular/core';\n\nimport { Subject } from 'rxjs';\n\nimport * as FileAPI from 'fileapi';\nimport { FileClickHandler, FileClickInterceptor } from '../classes';\nimport { ClickInterceptor } from '../classes/click-interceptor';\nimport { FS_FILE_CLICK_INTERCEPTOR } from '../injectors';\nimport { FsFile } from '../models';\n\n\n@Injectable()\nexport class InputProcessorService {\n\n  public containerEl: any;\n  public inputEl: HTMLInputElement;\n  public multiple = false;\n  public api: 'html5' | 'any' | 'cordova' = null;\n  public capture: 'camera' | 'library';\n  public disabled;\n  public allowClick = true;\n  public allowDrop = true;\n  public select = new EventEmitter<FsFile | FsFile[]>();\n  public clicked = new EventEmitter();\n\n  private _accept = '*';\n  private _acceptableTypes = new Map();\n  private _acceptableExts = new Set();\n  private _declinedFiles$ = new Subject<File[]>();\n\n  constructor(\n    @Optional() @Inject(FS_FILE_CLICK_INTERCEPTOR) private _clickInterceptors: FileClickInterceptor[],\n  ) { }\n\n  public get accept() {\n    return this._accept;\n  }\n\n  public set accept(value) {\n    value = value || '*';\n    this._acceptableTypes.clear();\n    this._acceptableExts.clear();\n    this.parseAcceptTypes(value);\n\n    this._accept = [\n      ...Array.from(this._acceptableTypes)\n        .reduce((accum, [key, values]) => {\n          return [\n            ...accum,\n            ...Array.from(values)\n              .map((value) => `${key}/${value}`),\n          ];\n        }, []),\n      ...Array.from(this._acceptableExts).values(),\n    ].join(',');\n  }\n\n  public get declinedFiles$() {\n    return this._declinedFiles$.asObservable();\n  }\n\n  /**\n   * Initialize service for target element\n   * @param el\n   */\n  public registerInput(el: ElementRef) {\n    if (!el) {\n      return\n    }\n\n    this.inputEl = el.nativeElement;\n\n    FileAPI.event.on(this.inputEl, 'change', (event) => {\n      if (!this.allowClick) {\n        return;\n      }\n\n      const files = FileAPI.getFiles(event);\n\n      if (files) {\n        this.selectFiles(files);\n      }\n\n      this.inputEl.value = null;\n    });\n  }\n\n  public registerDrop(el: ElementRef) {\n    if (!el) {\n      return\n    }\n\n    this.containerEl = el.nativeElement;\n    FileAPI.event.on(this.containerEl, 'drop', (event) => {\n\n      if (!this.allowDrop) {\n        return;\n      }\n\n      const files = FileAPI.getFiles(event);\n\n      if (files) {\n        this.selectFiles(files);\n      }\n\n      this.inputEl.value = null;\n\n    });\n  }\n\n  public registerLabel(el: ElementRef) {\n    if (!el) {\n      return\n    }\n\n    FileAPI.event.on(el.nativeElement, 'click', (event) => {\n      if (!this.allowClick) {\n        return;\n      }\n\n      if (!event.defaultPrevented) {\n        this.clicked.next(event);\n\n        const interceptors: FileClickInterceptor[] = [\n          ...this._clickInterceptors || [],\n          new ClickInterceptor()\n        ];\n\n        const interceptorChain: FileClickHandler = interceptors.reduceRight(\n          (next: FileClickHandler, interceptor: FileClickInterceptor) => new FileClickHandler(next, interceptor), null);\n\n        interceptorChain.handle(event, this)\n          .subscribe();\n      }\n    });\n  }\n\n  public isAcceptVideo() {\n    return this.accept.match(/video/i) || this.accept === '*';\n  }\n\n  public isAcceptImage() {\n    return this.accept.match(/image/i) || this.accept === '*';\n  }\n\n  public selectFiles(files: File[]) {\n    const declinedFiles = [];\n    const fsFiles = files\n      .map((file) => new FsFile(file))\n      .filter((file) => {\n        const nameParts = file.name.split('.');\n        let ext;\n        if (nameParts && Array.isArray(nameParts)) {\n          ext = nameParts[nameParts.length - 1];\n        }\n\n        ext = (ext + '').toLowerCase();\n        const acceptableFile = this.checkAcceptableTypes(file.type, ext);\n\n        if (!acceptableFile) {\n          declinedFiles.push(file);\n        }\n\n        return acceptableFile;\n      });\n\n    if (declinedFiles.length > 0) {\n      this._declinedFiles$.next(declinedFiles);\n    }\n\n    if (files.length === 1) {\n      this.select.emit(fsFiles[0]);\n    } else if (files.length > 0) {\n      this.select.emit(fsFiles);\n    }\n  }\n\n  /**\n   * Check if file mimetype or extention is acceptable by @accept field\n   * @param targetType\n   * @param targetExt\n   * @returns boolean\n   */\n  private checkAcceptableTypes(targetType, targetExt) {\n    targetType = targetType.trim();\n    const [type, ext] = targetType.split('/');\n    const acceptableType = this._acceptableTypes.get(type);\n\n    return this.accept === '*'\n      || this.accept === '*/*'\n      || (!!acceptableType && (acceptableType.has('*') || acceptableType.has(ext)))\n      || this._acceptableExts.has(`.${targetExt}`);\n  }\n\n  /**\n   * Parset and store acceptable types for feature filter\n   * @param types\n   */\n  private parseAcceptTypes(value) {\n    let types = [];\n    if (typeof value === 'string') {\n      types = value.split(/[,;]/);\n    }\n\n    if (!types.length) {\n      return;\n    }\n\n    types = types\n      .map((type) => type.trim());\n\n    types.forEach((part) => {\n      if (part === '*') {\n        this._acceptableExts.add('*');\n      } else if (part.indexOf('/') !== -1) {\n        const [type, ext] = part.split('/');\n        if (this._acceptableTypes.has(type)) {\n          const existedType = this._acceptableTypes.get(type);\n\n          if (!existedType.has(ext)) {\n            existedType.add(ext);\n          }\n        } else {\n          const extensions = new Set();\n          this._acceptableTypes.set(type, extensions);\n          extensions.add(ext);\n        }\n      } else if (part.indexOf('.') !== -1) {\n        part = part.replace(/^\\*/, '');\n        if (!this._acceptableExts.has(part)) {\n          this._acceptableExts.add(part);\n        }\n      } else if (part.match(/[a-z0-9]{3,4}/i)) {\n        if (!this._acceptableExts.has(part)) {\n          this._acceptableExts.add(`.${part}`);\n        }\n      }\n    })\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-processor.service.js","sourceRoot":"","sources":["../../../../src/app/services/input-processor.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, EventEmitter, Inject, Injectable, Optional } from '@angular/core';\n\nimport { Subject } from 'rxjs';\n\nimport * as FileAPI from 'fileapi';\n\nimport { FileClickHandler, FileClickInterceptor } from '../classes';\nimport { ClickInterceptor } from '../classes/click-interceptor';\nimport { FS_FILE_CLICK_INTERCEPTOR } from '../injectors';\nimport { FsFile } from '../models';\n\n\n@Injectable()\nexport class InputProcessorService {\n\n  public containerEl: any;\n  public inputEl: HTMLInputElement;\n  public multiple = false;\n  public api: 'html5' | 'any' | 'cordova' = null;\n  public capture: 'camera' | 'library';\n  public disabled;\n  public allowClick = true;\n  public allowDrop = true;\n  public select = new EventEmitter<FsFile | FsFile[]>();\n  public clicked = new EventEmitter();\n\n  private _accept = '*';\n  private _acceptableTypes = new Map();\n  private _acceptableExts = new Set();\n  private _declinedFiles$ = new Subject<File[]>();\n\n  constructor(\n    @Optional() @Inject(FS_FILE_CLICK_INTERCEPTOR) private _clickInterceptors: FileClickInterceptor[],\n  ) { }\n\n  public get accept() {\n    return this._accept;\n  }\n\n  public set accept(value) {\n    value = value || '*';\n    this._acceptableTypes.clear();\n    this._acceptableExts.clear();\n    this._parseAcceptTypes(value);\n\n    this._accept = [\n      ...Array.from(this._acceptableTypes)\n        .reduce((accum, [key, values]) => {\n          return [\n            ...accum,\n            ...Array.from(values)\n              .map((item) => `${key}/${item}`),\n          ];\n        }, []),\n      ...Array.from(this._acceptableExts).values(),\n    ].join(',');\n  }\n\n  public get declinedFiles$() {\n    return this._declinedFiles$.asObservable();\n  }\n\n  /**\n   * Initialize service for target element\n   *\n   * @param el\n   */\n  public registerInput(el: ElementRef) {\n    if (!el) {\n      return;\n    }\n\n    this.inputEl = el.nativeElement;\n\n    FileAPI.event.on(this.inputEl, 'change', (event) => {\n      if (!this.allowClick) {\n        return;\n      }\n\n      const files = FileAPI.getFiles(event);\n\n      if (files) {\n        this.selectFiles(files);\n      }\n\n      this.inputEl.value = null;\n    });\n  }\n\n  public registerDrop(el: ElementRef) {\n    if (!el) {\n      return;\n    }\n\n    this.containerEl = el.nativeElement;\n    FileAPI.event.on(this.containerEl, 'drop', (event) => {\n\n      if (!this.allowDrop) {\n        return;\n      }\n\n      const files = FileAPI.getFiles(event);\n\n      if (files) {\n        this.selectFiles(files);\n      }\n\n      this.inputEl.value = null;\n\n    });\n  }\n\n  public registerLabel(el: ElementRef) {\n    if (!el) {\n      return;\n    }\n\n    FileAPI.event.on(el.nativeElement, 'click', (event) => {\n      if (!this.allowClick) {\n        return;\n      }\n\n      if (!event.defaultPrevented) {\n        this.clicked.next(event);\n\n        const interceptors: FileClickInterceptor[] = [\n          ...this._clickInterceptors || [],\n          new ClickInterceptor(),\n        ];\n\n        const interceptorChain: FileClickHandler = interceptors.reduceRight(\n          (next: FileClickHandler, interceptor: FileClickInterceptor) => new FileClickHandler(next, interceptor), null);\n\n        interceptorChain.handle(event, this)\n          .subscribe();\n      }\n    });\n  }\n\n  public isAcceptVideo() {\n    return this.accept.match(/video/i) || this.accept === '*';\n  }\n\n  public isAcceptImage() {\n    return this.accept.match(/image/i) || this.accept === '*';\n  }\n\n  public selectFiles(files: File[]) {\n    const declinedFiles = [];\n    const fsFiles = files\n      .map((file) => new FsFile(file))\n      .filter((file) => {\n        const nameParts = file.name.split('.');\n        let ext;\n        if (nameParts && Array.isArray(nameParts)) {\n          ext = nameParts[nameParts.length - 1];\n        }\n\n        ext = (`${ext  }`).toLowerCase();\n        const acceptableFile = this._checkAcceptableTypes(file.type, ext);\n\n        if (!acceptableFile) {\n          declinedFiles.push(file);\n        }\n\n        return acceptableFile;\n      });\n\n    if (declinedFiles.length > 0) {\n      this._declinedFiles$.next(declinedFiles);\n    }\n\n    if (files.length === 1) {\n      this.select.emit(fsFiles[0]);\n    } else if (files.length > 0) {\n      this.select.emit(fsFiles);\n    }\n  }\n\n  /**\n   * Check if file mimetype or extention is acceptable by @accept field\n   *\n   * @param targetType\n   * @param targetExt\n   * @returns boolean\n   */\n  private _checkAcceptableTypes(targetType, targetExt) {\n    targetType = targetType.trim();\n    const [type, ext] = targetType.split('/');\n    const acceptableType = this._acceptableTypes.get(type);\n\n    return this.accept === '*'\n      || this.accept === '*/*'\n      || (!!acceptableType && (acceptableType.has('*') || acceptableType.has(ext)))\n      || this._acceptableExts.has(`.${targetExt}`);\n  }\n\n  /**\n   * Parset and store acceptable types for feature filter\n   *\n   * @param types\n   */\n  private _parseAcceptTypes(value) {\n    let types = [];\n    if (typeof value === 'string') {\n      types = value.split(/[,;]/);\n    }\n\n    if (!types.length) {\n      return;\n    }\n\n    types = types\n      .map((type) => type.trim());\n\n    types.forEach((part) => {\n      if (part === '*') {\n        this._acceptableExts.add('*');\n      } else if (part.indexOf('/') !== -1) {\n        const [type, ext] = part.split('/');\n        if (this._acceptableTypes.has(type)) {\n          const existedType = this._acceptableTypes.get(type);\n\n          if (!existedType.has(ext)) {\n            existedType.add(ext);\n          }\n        } else {\n          const extensions = new Set();\n          this._acceptableTypes.set(type, extensions);\n          extensions.add(ext);\n        }\n      } else if (part.indexOf('.') !== -1) {\n        part = part.replace(/^\\*/, '');\n        if (!this._acceptableExts.has(part)) {\n          this._acceptableExts.add(part);\n        }\n      } else if (part.match(/[a-z0-9]{3,4}/i)) {\n        if (!this._acceptableExts.has(part)) {\n          this._acceptableExts.add(`.${part}`);\n        }\n      }\n    });\n  }\n}\n"]} |
{ | ||
"name": "@firestitch/file", | ||
"version": "12.17.4", | ||
"version": "12.18.0", | ||
"repository": { | ||
@@ -25,2 +25,3 @@ "type": "git", | ||
"fileapi": "^2.1.1", | ||
"heic2any": "^0.0.4", | ||
"tslib": "^2.0.0" | ||
@@ -27,0 +28,0 @@ }, |
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
Long strings
Supply chain riskContains long string literals, which may be a sign of obfuscated or packed code.
Found 1 instance in 1 package
Long strings
Supply chain riskContains long string literals, which may be a sign of obfuscated or packed code.
Found 1 instance in 1 package
801961
6575
5
+ Addedheic2any@^0.0.4
+ Addedheic2any@0.0.4(transitive)