@firestitch/file
Advanced tools
Comparing version 12.17.1 to 12.17.2
@@ -54,2 +54,3 @@ import { ChangeDetectorRef, EventEmitter, OnDestroy, OnInit, QueryList, TemplateRef } from '@angular/core'; | ||
get previewPercent(): RegExpMatchArray; | ||
clear(): void; | ||
writeValue(file: any): void; | ||
@@ -56,0 +57,0 @@ selectFilePreview(fsFiles: FsFile[]): void; |
@@ -109,2 +109,6 @@ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, ContentChildren, EventEmitter, Inject, Input, Optional, Output, QueryList, TemplateRef, ViewChild, forwardRef, } from '@angular/core'; | ||
} | ||
clear() { | ||
this.file = null; | ||
this._cdRef.markForCheck(); | ||
} | ||
writeValue(file) { | ||
@@ -238,2 +242,2 @@ this.file = file; | ||
}] } }); | ||
//# 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  public onTouch: any = () => { };\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 === void 0) {\n        this.allowDownload = this._moduleConfig.allowDownload;\n      }\n\n      if (this.allowRemove === void 0) {\n        this.allowRemove = this._moduleConfig.allowRemove;\n      }\n    }\n  }\n\n  public validate(control: AbstractControl): Promise<ValidationErrors | null> | null {\n    if (this.file?.typeImage && (this.minWidth || this.minHeight)) {\n      // if(this.file.imageWidth < this.minWidth) {\n      //   return { minWidth: `Minimum width ${this.minWidth}px` };\n      // }\n\n      // if(this.file.imageHeight < this.minHeight) {\n      //   return { minWidth: `Minimum height ${this.minHeight}px` };\n      // }\n    }\n\n    return null;\n  }\n\n  public get previewPercent() {\n    return String(this._previewWidth).match(/%/);\n  }\n\n  public writeValue(file): void {\n    this.file = file;\n    this._cdRef.markForCheck();\n  }\n\n  public 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":"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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  public onTouch: any = () => { };\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 === void 0) {\n        this.allowDownload = this._moduleConfig.allowDownload;\n      }\n\n      if (this.allowRemove === void 0) {\n        this.allowRemove = this._moduleConfig.allowRemove;\n      }\n    }\n  }\n\n  public validate(control: AbstractControl): Promise<ValidationErrors | null> | null {\n    if (this.file?.typeImage && (this.minWidth || this.minHeight)) {\n      // if(this.file.imageWidth < this.minWidth) {\n      //   return { minWidth: `Minimum width ${this.minWidth}px` };\n      // }\n\n      // if(this.file.imageHeight < this.minHeight) {\n      //   return { minWidth: `Minimum height ${this.minHeight}px` };\n      // }\n    }\n\n    return null;\n  }\n\n  public get previewPercent() {\n    return String(this._previewWidth).match(/%/);\n  }\n\n  public 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"]} |
{ | ||
"name": "@firestitch/file", | ||
"version": "12.17.1", | ||
"version": "12.17.2", | ||
"repository": { | ||
@@ -5,0 +5,0 @@ "type": "git", |
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is too big to display
Sorry, the diff of this file is not supported yet
791818
6477