@firestitch/file
Advanced tools
Comparing version 12.11.3 to 12.12.0
export * from './file-processor'; | ||
export * from './input-processor'; | ||
export * from './file-click-handler'; | ||
export * from './file-click-interceptor'; |
@@ -1,10 +0,6 @@ | ||
import { ChangeDetectorRef, EventEmitter, NgZone, TemplateRef } from '@angular/core'; | ||
import { ChangeDetectorRef, EventEmitter, TemplateRef } from '@angular/core'; | ||
import { MatDialog } from '@angular/material/dialog'; | ||
import { InputProcessor } from '../../classes/input-processor'; | ||
import { FsFile } from '../../models/fs-file'; | ||
import { CordovaService } from '../../services/cordova.service'; | ||
import * as i0 from "@angular/core"; | ||
export declare class FsFileImagePickerComponent { | ||
private _cordovaService; | ||
private _ngZone; | ||
private _dialog; | ||
@@ -28,7 +24,6 @@ private _cdRef; | ||
selectUrl: EventEmitter<any>; | ||
inputProcessor: InputProcessor; | ||
_file: FsFile; | ||
preview: string; | ||
private _previousFile; | ||
constructor(_cordovaService: CordovaService, _ngZone: NgZone, _dialog: MatDialog, _cdRef: ChangeDetectorRef); | ||
constructor(_dialog: MatDialog, _cdRef: ChangeDetectorRef); | ||
get file(): FsFile; | ||
@@ -35,0 +30,0 @@ selectFile(file: any): void; |
@@ -1,6 +0,5 @@ | ||
import { EventEmitter, OnInit, NgZone, ChangeDetectorRef, QueryList, TemplateRef, OnDestroy } from '@angular/core'; | ||
import { EventEmitter, OnInit, ChangeDetectorRef, QueryList, TemplateRef, OnDestroy } from '@angular/core'; | ||
import { AbstractControl, AsyncValidator, ControlValueAccessor, ValidationErrors } from '@angular/forms'; | ||
import { FsFileDragBaseComponent } from '../fs-file-drag-base/fs-file-drag-base'; | ||
import { FsFile } from '../../models/fs-file'; | ||
import { CordovaService } from '../../services/cordova.service'; | ||
import { FsApiFile } from '@firestitch/api'; | ||
@@ -10,4 +9,2 @@ import * as i0 from "@angular/core"; | ||
private _moduleConfig; | ||
private _cordovaService; | ||
private _ngZone; | ||
private _cdRef; | ||
@@ -52,3 +49,3 @@ fileInput: any; | ||
private _previewHeight; | ||
constructor(_moduleConfig: any, _cordovaService: CordovaService, _ngZone: NgZone, _cdRef: ChangeDetectorRef); | ||
constructor(_moduleConfig: any, _cdRef: ChangeDetectorRef); | ||
ngOnInit(): void; | ||
@@ -68,4 +65,4 @@ validate(control: AbstractControl): Promise<ValidationErrors | null> | null; | ||
private _isNumeric; | ||
static ɵfac: i0.ɵɵFactoryDeclaration<FsFilePickerComponent, [{ optional: true; }, null, null, null]>; | ||
static ɵfac: i0.ɵɵFactoryDeclaration<FsFilePickerComponent, [{ optional: true; }, null]>; | ||
static ɵcmp: i0.ɵɵComponentDeclaration<FsFilePickerComponent, "fs-file-picker", never, { "minWidth": "minWidth"; "minHeight": "minHeight"; "imageWidth": "imageWidth"; "imageHeight": "imageHeight"; "imageQuality": "imageQuality"; "label": "label"; "showFilename": "showFilename"; "allowDownload": "allowDownload"; "allowReupload": "allowReupload"; "multiple": "multiple"; "allowRemove": "allowRemove"; "url": "url"; "file": "file"; "accept": "accept"; "disabled": "disabled"; "previewWidth": "previewWidth"; "previewHeight": "previewHeight"; }, { "select": "select"; "remove": "remove"; "download": "download"; }, ["filePickerSelectTemplate", "labels"], ["[fsFileLabel]", "[fsFileHint]", "[fsFileMessageLabel]"]>; | ||
} |
import { ElementRef, EventEmitter, NgZone, OnDestroy, OnInit } from '@angular/core'; | ||
import { FsMessage } from '@firestitch/message'; | ||
import { FsFileDragBaseComponent } from '../fs-file-drag-base/fs-file-drag-base'; | ||
import { CordovaService } from '../../services/cordova.service'; | ||
import { InputProcessor } from '../../classes'; | ||
import { InputProcessorService } from '../../services'; | ||
import * as i0 from "@angular/core"; | ||
export declare class FsFileComponent extends FsFileDragBaseComponent implements OnInit, OnDestroy { | ||
el: ElementRef; | ||
inputProcessor: InputProcessorService; | ||
moduleConfig: any; | ||
private _message; | ||
inputProcessor: InputProcessor; | ||
private _destroy$; | ||
@@ -42,3 +41,3 @@ private processConfig; | ||
fileLabel: any; | ||
constructor(cordovaService: CordovaService, el: ElementRef, ngZone: NgZone, moduleConfig: any, _message: FsMessage); | ||
constructor(el: ElementRef, inputProcessor: InputProcessorService, ngZone: NgZone, moduleConfig: any, _message: FsMessage); | ||
ngOnInit(): void; | ||
@@ -45,0 +44,0 @@ ngOnDestroy(): void; |
export * from './file-processor'; | ||
export * from './input-processor'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYXBwL2NsYXNzZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9maWxlLXByb2Nlc3Nvcic7XG5leHBvcnQgKiBmcm9tICcuL2lucHV0LXByb2Nlc3Nvcic7XG4iXX0= | ||
export * from './file-click-handler'; | ||
export * from './file-click-interceptor'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYXBwL2NsYXNzZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsMEJBQTBCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2ZpbGUtcHJvY2Vzc29yJztcbmV4cG9ydCAqIGZyb20gJy4vZmlsZS1jbGljay1oYW5kbGVyJztcbmV4cG9ydCAqIGZyb20gJy4vZmlsZS1jbGljay1pbnRlcmNlcHRvcic7XG4iXX0= |
@@ -1,21 +0,16 @@ | ||
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, EventEmitter, Input, NgZone, Output, TemplateRef } from '@angular/core'; | ||
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, EventEmitter, Input, Output, TemplateRef } from '@angular/core'; | ||
import { MatDialog } from '@angular/material/dialog'; | ||
import { FsFileHintDirective, FsFileLabelDirective } from '../../directives'; | ||
import { InputProcessor } from '../../classes/input-processor'; | ||
import { FsFile } from '../../models/fs-file'; | ||
import { CordovaService } from '../../services/cordova.service'; | ||
import { FsFileImagePickerDialogComponent } from './fs-file-image-picker-dialog/fs-file-image-picker-dialog.component'; | ||
import * as i0 from "@angular/core"; | ||
import * as i1 from "../../services/cordova.service"; | ||
import * as i2 from "@angular/material/dialog"; | ||
import * as i3 from "@firestitch/label"; | ||
import * as i4 from "../fs-file/fs-file.component"; | ||
import * as i5 from "@angular/material/icon"; | ||
import * as i6 from "@angular/material/button"; | ||
import * as i7 from "@angular/common"; | ||
import * as i8 from "../../pipes/preview-pipe"; | ||
import * as i1 from "@angular/material/dialog"; | ||
import * as i2 from "@firestitch/label"; | ||
import * as i3 from "../fs-file/fs-file.component"; | ||
import * as i4 from "@angular/material/icon"; | ||
import * as i5 from "@angular/material/button"; | ||
import * as i6 from "@angular/common"; | ||
import * as i7 from "../../pipes/preview-pipe"; | ||
export class FsFileImagePickerComponent { | ||
constructor(_cordovaService, _ngZone, _dialog, _cdRef) { | ||
this._cordovaService = _cordovaService; | ||
this._ngZone = _ngZone; | ||
constructor(_dialog, _cdRef) { | ||
this._dialog = _dialog; | ||
@@ -33,4 +28,2 @@ this._cdRef = _cdRef; | ||
this.selectUrl = new EventEmitter(); | ||
this.inputProcessor = null; | ||
this.inputProcessor = new InputProcessor(this._cordovaService, this._ngZone); | ||
} | ||
@@ -73,4 +66,4 @@ set url(url) { | ||
} | ||
FsFileImagePickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FsFileImagePickerComponent, deps: [{ token: i1.CordovaService }, { token: i0.NgZone }, { token: i2.MatDialog }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); | ||
FsFileImagePickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: FsFileImagePickerComponent, selector: "fs-file-image-picker", inputs: { imageQuality: "imageQuality", borderRadius: "borderRadius", imageWidth: "imageWidth", imageHeight: "imageHeight", previewDiameter: "previewDiameter", previewFit: "previewFit", label: "label", minWidth: "minWidth", minHeight: "minHeight", disabled: "disabled", url: "url" }, outputs: { select: "select", error: "error", selectUrl: "selectUrl" }, queries: [{ propertyName: "labelTemplate", first: true, predicate: FsFileLabelDirective, descendants: true, read: TemplateRef }, { propertyName: "hintTemplate", first: true, predicate: FsFileHintDirective, descendants: true, read: TemplateRef }], ngImport: i0, template: "\n\n<ng-container *ngIf=\"labelTemplate || hintTemplate || label; else preview\">\n <fs-label-field class=\"fs-image-label\">\n <fs-label *ngIf=\"labelTemplate || label\">\n {{ label }}\n <ng-container *ngTemplateOutlet=\"labelTemplate\"></ng-container>\n </fs-label>\n <ng-container *ngTemplateOutlet=\"preview\"></ng-container>\n <fs-label-message class=\"fs-form-message\">\n <span class=\"fs-form-hint\">\n <ng-container *ngTemplateOutlet=\"hintTemplate\"></ng-container>\n </span>\n </fs-label-message>\n </fs-label-field>\n</ng-container>\n\n<ng-template #preview>\n <div \n class=\"wrap\" \n [ngClass]=\"{ \n disabled: disabled, \n exists: file?.exists && file.typeImage \n }\">\n <fs-file\n *ngIf=\"!disabled; else filePreview\"\n (select)=\"selectFile($event)\"\n (error)=\"error.emit($event)\"\n (clicked)=\"clicked($event)\"\n [minHeight]=\"minHeight\"\n [minWidth]=\"minWidth\"\n [imageWidth]=\"imageWidth\"\n [imageHeight]=\"imageHeight\"\n [imageQuality]=\"imageQuality\"\n [disabled]=\"disabled\"\n accept=\"image/*\"\n [multiple]=\"false\">\n <ng-container *ngTemplateOutlet=\"filePreview\"></ng-container>\n </fs-file>\n </div>\n\n <ng-template #filePreview>\n <div \n class=\"image-preview\"\n [style.borderRadius]=\"borderRadius\"\n [style.height]=\"previewDiameter + 'px'\"\n [style.width]=\"previewDiameter + 'px'\">\n <ng-container \n *ngIf=\"file?.exists && file.typeImage; else noImage\">\n <img \n [style.borderRadius]=\"borderRadius\"\n [src]=\"file | previewImage | async\">\n </ng-container>\n <ng-template #noImage>\n <div class=\"no-image\">\n <mat-icon\n [style.transform]=\"'scale(' + ((previewDiameter / 50) * 100) + '%)'\">\n image\n </mat-icon>\n </div>\n </ng-template>\n <div \n [style.transform]=\"'rotate(46deg) translate(' + (previewDiameter - 1) + 'px) rotate(-46deg)'\"\n class=\"upload-icon\">\n <button \n mat-mini-fab\n type=\"button\"\n [style.margin]=\"(previewDiameter < 100 ? (1 - (previewDiameter / 100)) * -10 : 1) + 'px'\"\n [style.transform]=\"'scale(' + (previewDiameter < 100 ? (previewDiameter / 100) : 1) + ')'\">\n <mat-icon>\n photo_camera\n </mat-icon>\n </button>\n </div>\n </div>\n </ng-template>\n</ng-template>\n", styles: [".fs-image-label{min-height:1px}.wrap{display:inline-flex}.wrap:not(.disabled){cursor:pointer}.wrap.disabled .upload-icon{display:none}.image-preview{position:relative;border:1px solid transparent;display:flex;align-items:center;justify-content:center}.image-preview .upload-icon{position:absolute;display:block;top:11%;left:11%;margin:-13px}.image-preview .upload-icon mat-icon{color:#e9e9e9}.image-preview .no-image{display:flex}.image-preview .no-image mat-icon{color:#ececec}.image-preview img{display:block;object-fit:cover;width:100%;height:100%}\n"], components: [{ type: i3.FsLabelFieldComponent, selector: "fs-label-field", inputs: ["bottomMargin", "topMargin", "labelMargin"] }, { type: i3.FsLabelComponent, selector: "fs-label" }, { type: i3.FsLabelMessageComponent, selector: "fs-label-message" }, { type: i4.FsFileComponent, selector: "fs-file", inputs: ["minHeight", "minWidth", "orientate", "multiple", "capture", "allowClick", "allowDrop", "accept", "disabled", "imageWidth", "imageHeight", "imageQuality"], outputs: ["select", "error", "clicked", "declined"] }, { type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i6.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], directives: [{ type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i7.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], pipes: { "async": i7.AsyncPipe, "previewImage": i8.PreviewImagePipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush }); | ||
FsFileImagePickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FsFileImagePickerComponent, deps: [{ token: i1.MatDialog }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); | ||
FsFileImagePickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: FsFileImagePickerComponent, selector: "fs-file-image-picker", inputs: { imageQuality: "imageQuality", borderRadius: "borderRadius", imageWidth: "imageWidth", imageHeight: "imageHeight", previewDiameter: "previewDiameter", previewFit: "previewFit", label: "label", minWidth: "minWidth", minHeight: "minHeight", disabled: "disabled", url: "url" }, outputs: { select: "select", error: "error", selectUrl: "selectUrl" }, queries: [{ propertyName: "labelTemplate", first: true, predicate: FsFileLabelDirective, descendants: true, read: TemplateRef }, { propertyName: "hintTemplate", first: true, predicate: FsFileHintDirective, descendants: true, read: TemplateRef }], ngImport: i0, template: "\n\n<ng-container *ngIf=\"labelTemplate || hintTemplate || label; else preview\">\n <fs-label-field class=\"fs-image-label\">\n <fs-label *ngIf=\"labelTemplate || label\">\n {{ label }}\n <ng-container *ngTemplateOutlet=\"labelTemplate\"></ng-container>\n </fs-label>\n <ng-container *ngTemplateOutlet=\"preview\"></ng-container>\n <fs-label-message class=\"fs-form-message\">\n <span class=\"fs-form-hint\">\n <ng-container *ngTemplateOutlet=\"hintTemplate\"></ng-container>\n </span>\n </fs-label-message>\n </fs-label-field>\n</ng-container>\n\n<ng-template #preview>\n <div \n class=\"wrap\" \n [ngClass]=\"{ \n disabled: disabled, \n exists: file?.exists && file.typeImage \n }\">\n <fs-file\n *ngIf=\"!disabled; else filePreview\"\n (select)=\"selectFile($event)\"\n (error)=\"error.emit($event)\"\n (clicked)=\"clicked($event)\"\n [minHeight]=\"minHeight\"\n [minWidth]=\"minWidth\"\n [imageWidth]=\"imageWidth\"\n [imageHeight]=\"imageHeight\"\n [imageQuality]=\"imageQuality\"\n [disabled]=\"disabled\"\n accept=\"image/*\"\n [multiple]=\"false\">\n <ng-container *ngTemplateOutlet=\"filePreview\"></ng-container>\n </fs-file>\n </div>\n\n <ng-template #filePreview>\n <div \n class=\"image-preview\"\n [style.borderRadius]=\"borderRadius\"\n [style.height]=\"previewDiameter + 'px'\"\n [style.width]=\"previewDiameter + 'px'\">\n <ng-container \n *ngIf=\"file?.exists && file.typeImage; else noImage\">\n <img \n [style.borderRadius]=\"borderRadius\"\n [src]=\"file | previewImage | async\">\n </ng-container>\n <ng-template #noImage>\n <div class=\"no-image\">\n <mat-icon\n [style.transform]=\"'scale(' + ((previewDiameter / 50) * 100) + '%)'\">\n image\n </mat-icon>\n </div>\n </ng-template>\n <div \n [style.transform]=\"'rotate(46deg) translate(' + (previewDiameter - 1) + 'px) rotate(-46deg)'\"\n class=\"upload-icon\">\n <button \n mat-mini-fab\n type=\"button\"\n [style.margin]=\"(previewDiameter < 100 ? (1 - (previewDiameter / 100)) * -10 : 1) + 'px'\"\n [style.transform]=\"'scale(' + (previewDiameter < 100 ? (previewDiameter / 100) : 1) + ')'\">\n <mat-icon>\n photo_camera\n </mat-icon>\n </button>\n </div>\n </div>\n </ng-template>\n</ng-template>\n", styles: [".fs-image-label{min-height:1px}.wrap{display:inline-flex}.wrap:not(.disabled){cursor:pointer}.wrap.disabled .upload-icon{display:none}.image-preview{position:relative;border:1px solid transparent;display:flex;align-items:center;justify-content:center}.image-preview .upload-icon{position:absolute;display:block;top:11%;left:11%;margin:-13px}.image-preview .upload-icon mat-icon{color:#e9e9e9}.image-preview .no-image{display:flex}.image-preview .no-image mat-icon{color:#ececec}.image-preview img{display:block;object-fit:cover;width:100%;height:100%}\n"], components: [{ type: i2.FsLabelFieldComponent, selector: "fs-label-field", inputs: ["bottomMargin", "topMargin", "labelMargin"] }, { type: i2.FsLabelComponent, selector: "fs-label" }, { type: i2.FsLabelMessageComponent, selector: "fs-label-message" }, { type: i3.FsFileComponent, selector: "fs-file", inputs: ["minHeight", "minWidth", "orientate", "multiple", "capture", "allowClick", "allowDrop", "accept", "disabled", "imageWidth", "imageHeight", "imageQuality"], outputs: ["select", "error", "clicked", "declined"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i5.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }], pipes: { "async": i6.AsyncPipe, "previewImage": i7.PreviewImagePipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FsFileImagePickerComponent, decorators: [{ | ||
@@ -84,3 +77,3 @@ type: Component, | ||
}] | ||
}], ctorParameters: function () { return [{ type: i1.CordovaService }, { type: i0.NgZone }, { type: i2.MatDialog }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { labelTemplate: [{ | ||
}], ctorParameters: function () { return [{ type: i1.MatDialog }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { labelTemplate: [{ | ||
type: ContentChild, | ||
@@ -121,2 +114,2 @@ args: [FsFileLabelDirective, { read: TemplateRef }] | ||
}] } }); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fs-file-image-picker.component.js","sourceRoot":"","sources":["../../../../../src/app/components/fs-file-image-picker/fs-file-image-picker.component.ts","../../../../../src/app/components/fs-file-image-picker/fs-file-image-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  EventEmitter,\n  Input,\n  NgZone,\n  Output,\n  TemplateRef\n} from '@angular/core';\n\nimport { MatDialog } from '@angular/material/dialog';\nimport { FsFileHintDirective, FsFileLabelDirective } from '../../directives';\n\nimport { InputProcessor } from '../../classes/input-processor';\nimport { FsFile } from '../../models/fs-file';\nimport { CordovaService } from '../../services/cordova.service';\nimport { FsFileImagePickerDialogComponent } from './fs-file-image-picker-dialog/fs-file-image-picker-dialog.component';\n\n\n@Component({\n  selector: 'fs-file-image-picker',\n  templateUrl: './fs-file-image-picker.component.html',\n  styleUrls: ['./fs-file-image-picker.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class FsFileImagePickerComponent {\n\n  @ContentChild(FsFileLabelDirective, { read: TemplateRef })\n  public labelTemplate: TemplateRef<any>;\n\n  @ContentChild(FsFileHintDirective, { read: TemplateRef })\n  public hintTemplate: TemplateRef<any>;\n\n  @Input() public imageQuality: number;\n  @Input() public borderRadius = '100%';\n  @Input() public imageWidth;\n  @Input() public imageHeight;\n  @Input() public previewDiameter = 80;\n  @Input() public previewFit = 'cover';\n  @Input() public label = '';\n  @Input() public minWidth = 0;\n  @Input() public minHeight = 0;\n  @Input() public disabled = false;\n\n  @Input('url') set url(url) {\n    this._previousFile = this._file;\n    this._file = url ? new FsFile(url) : null;\n  }\n\n  @Output() public select = new EventEmitter<any>();\n  @Output() public error = new EventEmitter<any>();\n  @Output() public selectUrl = new EventEmitter<any>();\n\n  public inputProcessor: InputProcessor = null;\n  public _file: FsFile;\n  public preview: string;\n\n  private _previousFile: FsFile;\n\n  constructor(\n    private _cordovaService: CordovaService,\n    private _ngZone: NgZone,\n    private _dialog: MatDialog,\n    private _cdRef: ChangeDetectorRef,\n  ) {\n    this.inputProcessor = new InputProcessor(this._cordovaService, this._ngZone);\n  }\n\n  public get file(): FsFile {\n    return this._file;\n  }\n\n  public selectFile(file): void {\n    this._previousFile = this._file;\n    this._file = file;\n    setTimeout(() => {\n      this.select.emit(file);\n    });    \n  }\n\n  public cancel(): void {\n    this._file = this._previousFile;\n    this._previousFile = null;\n    this._cdRef.markForCheck();\n  }\n\n  public clicked(event: KeyboardEvent): void {\n    if (this.disabled) {\n      return;\n    }\n\n    if (event.shiftKey) {\n      event.preventDefault();\n\n      this._dialog.open(FsFileImagePickerDialogComponent, {\n        data: {\n          file: this._file,\n          selectUrl: this.selectUrl\n        },\n        width: '500px',\n        autoFocus: false\n      });\n    }\n  }\n\n}\n","\n\n<ng-container *ngIf=\"labelTemplate || hintTemplate || label; else preview\">\n  <fs-label-field class=\"fs-image-label\">\n    <fs-label *ngIf=\"labelTemplate || label\">\n      {{ label }}\n      <ng-container *ngTemplateOutlet=\"labelTemplate\"></ng-container>\n    </fs-label>\n    <ng-container *ngTemplateOutlet=\"preview\"></ng-container>\n    <fs-label-message class=\"fs-form-message\">\n      <span class=\"fs-form-hint\">\n        <ng-container *ngTemplateOutlet=\"hintTemplate\"></ng-container>\n      </span>\n    </fs-label-message>\n  </fs-label-field>\n</ng-container>\n\n<ng-template #preview>\n  <div \n    class=\"wrap\" \n    [ngClass]=\"{ \n      disabled: disabled, \n      exists: file?.exists && file.typeImage \n    }\">\n    <fs-file\n        *ngIf=\"!disabled; else filePreview\"\n        (select)=\"selectFile($event)\"\n        (error)=\"error.emit($event)\"\n        (clicked)=\"clicked($event)\"\n        [minHeight]=\"minHeight\"\n        [minWidth]=\"minWidth\"\n        [imageWidth]=\"imageWidth\"\n        [imageHeight]=\"imageHeight\"\n        [imageQuality]=\"imageQuality\"\n        [disabled]=\"disabled\"\n        accept=\"image/*\"\n        [multiple]=\"false\">\n      <ng-container *ngTemplateOutlet=\"filePreview\"></ng-container>\n    </fs-file>\n  </div>\n\n  <ng-template #filePreview>\n    <div \n        class=\"image-preview\"\n        [style.borderRadius]=\"borderRadius\"\n        [style.height]=\"previewDiameter + 'px'\"\n        [style.width]=\"previewDiameter + 'px'\">\n      <ng-container \n        *ngIf=\"file?.exists && file.typeImage; else noImage\">\n        <img \n          [style.borderRadius]=\"borderRadius\"\n          [src]=\"file | previewImage | async\">\n      </ng-container>\n      <ng-template #noImage>\n        <div class=\"no-image\">\n          <mat-icon\n              [style.transform]=\"'scale(' + ((previewDiameter / 50) * 100) + '%)'\">\n            image\n          </mat-icon>\n        </div>\n      </ng-template>\n      <div \n          [style.transform]=\"'rotate(46deg) translate(' + (previewDiameter - 1) + 'px) rotate(-46deg)'\"\n          class=\"upload-icon\">\n        <button \n            mat-mini-fab\n            type=\"button\"\n            [style.margin]=\"(previewDiameter < 100 ? (1 - (previewDiameter / 100)) * -10 : 1) + 'px'\"\n            [style.transform]=\"'scale(' + (previewDiameter < 100 ? (previewDiameter / 100) : 1) + ')'\">\n          <mat-icon>\n              photo_camera\n          </mat-icon>\n        </button>\n      </div>\n    </div>\n  </ng-template>\n</ng-template>\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fs-file-image-picker.component.js","sourceRoot":"","sources":["../../../../../src/app/components/fs-file-image-picker/fs-file-image-picker.component.ts","../../../../../src/app/components/fs-file-image-picker/fs-file-image-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChild,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef\n} from '@angular/core';\n\nimport { MatDialog } from '@angular/material/dialog';\nimport { FsFileHintDirective, FsFileLabelDirective } from '../../directives';\n\nimport { FsFile } from '../../models/fs-file';\nimport { FsFileImagePickerDialogComponent } from './fs-file-image-picker-dialog/fs-file-image-picker-dialog.component';\n\n\n@Component({\n  selector: 'fs-file-image-picker',\n  templateUrl: './fs-file-image-picker.component.html',\n  styleUrls: ['./fs-file-image-picker.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class FsFileImagePickerComponent {\n\n  @ContentChild(FsFileLabelDirective, { read: TemplateRef })\n  public labelTemplate: TemplateRef<any>;\n\n  @ContentChild(FsFileHintDirective, { read: TemplateRef })\n  public hintTemplate: TemplateRef<any>;\n\n  @Input() public imageQuality: number;\n  @Input() public borderRadius = '100%';\n  @Input() public imageWidth;\n  @Input() public imageHeight;\n  @Input() public previewDiameter = 80;\n  @Input() public previewFit = 'cover';\n  @Input() public label = '';\n  @Input() public minWidth = 0;\n  @Input() public minHeight = 0;\n  @Input() public disabled = false;\n\n  @Input('url') set url(url) {\n    this._previousFile = this._file;\n    this._file = url ? new FsFile(url) : null;\n  }\n\n  @Output() public select = new EventEmitter<any>();\n  @Output() public error = new EventEmitter<any>();\n  @Output() public selectUrl = new EventEmitter<any>();\n\n  public _file: FsFile;\n  public preview: string;\n\n  private _previousFile: FsFile;\n\n  constructor(\n    private _dialog: MatDialog,\n    private _cdRef: ChangeDetectorRef,\n  ) {}\n\n  public get file(): FsFile {\n    return this._file;\n  }\n\n  public selectFile(file): void {\n    this._previousFile = this._file;\n    this._file = file;\n    setTimeout(() => {\n      this.select.emit(file);\n    });    \n  }\n\n  public cancel(): void {\n    this._file = this._previousFile;\n    this._previousFile = null;\n    this._cdRef.markForCheck();\n  }\n\n  public clicked(event: KeyboardEvent): void {\n    if (this.disabled) {\n      return;\n    }\n\n    if (event.shiftKey) {\n      event.preventDefault();\n\n      this._dialog.open(FsFileImagePickerDialogComponent, {\n        data: {\n          file: this._file,\n          selectUrl: this.selectUrl\n        },\n        width: '500px',\n        autoFocus: false\n      });\n    }\n  }\n\n}\n","\n\n<ng-container *ngIf=\"labelTemplate || hintTemplate || label; else preview\">\n  <fs-label-field class=\"fs-image-label\">\n    <fs-label *ngIf=\"labelTemplate || label\">\n      {{ label }}\n      <ng-container *ngTemplateOutlet=\"labelTemplate\"></ng-container>\n    </fs-label>\n    <ng-container *ngTemplateOutlet=\"preview\"></ng-container>\n    <fs-label-message class=\"fs-form-message\">\n      <span class=\"fs-form-hint\">\n        <ng-container *ngTemplateOutlet=\"hintTemplate\"></ng-container>\n      </span>\n    </fs-label-message>\n  </fs-label-field>\n</ng-container>\n\n<ng-template #preview>\n  <div \n    class=\"wrap\" \n    [ngClass]=\"{ \n      disabled: disabled, \n      exists: file?.exists && file.typeImage \n    }\">\n    <fs-file\n        *ngIf=\"!disabled; else filePreview\"\n        (select)=\"selectFile($event)\"\n        (error)=\"error.emit($event)\"\n        (clicked)=\"clicked($event)\"\n        [minHeight]=\"minHeight\"\n        [minWidth]=\"minWidth\"\n        [imageWidth]=\"imageWidth\"\n        [imageHeight]=\"imageHeight\"\n        [imageQuality]=\"imageQuality\"\n        [disabled]=\"disabled\"\n        accept=\"image/*\"\n        [multiple]=\"false\">\n      <ng-container *ngTemplateOutlet=\"filePreview\"></ng-container>\n    </fs-file>\n  </div>\n\n  <ng-template #filePreview>\n    <div \n        class=\"image-preview\"\n        [style.borderRadius]=\"borderRadius\"\n        [style.height]=\"previewDiameter + 'px'\"\n        [style.width]=\"previewDiameter + 'px'\">\n      <ng-container \n        *ngIf=\"file?.exists && file.typeImage; else noImage\">\n        <img \n          [style.borderRadius]=\"borderRadius\"\n          [src]=\"file | previewImage | async\">\n      </ng-container>\n      <ng-template #noImage>\n        <div class=\"no-image\">\n          <mat-icon\n              [style.transform]=\"'scale(' + ((previewDiameter / 50) * 100) + '%)'\">\n            image\n          </mat-icon>\n        </div>\n      </ng-template>\n      <div \n          [style.transform]=\"'rotate(46deg) translate(' + (previewDiameter - 1) + 'px) rotate(-46deg)'\"\n          class=\"upload-icon\">\n        <button \n            mat-mini-fab\n            type=\"button\"\n            [style.margin]=\"(previewDiameter < 100 ? (1 - (previewDiameter / 100)) * -10 : 1) + 'px'\"\n            [style.transform]=\"'scale(' + (previewDiameter < 100 ? (previewDiameter / 100) : 1) + ')'\">\n          <mat-icon>\n              photo_camera\n          </mat-icon>\n        </button>\n      </div>\n    </div>\n  </ng-template>\n</ng-template>\n"]} |
@@ -1,2 +0,2 @@ | ||
import { EventEmitter, Component, Input, Output, ViewChild, Inject, Optional, NgZone, ChangeDetectionStrategy, forwardRef, ChangeDetectorRef, QueryList, ContentChildren, TemplateRef, ContentChild } from '@angular/core'; | ||
import { EventEmitter, Component, Input, Output, ViewChild, Inject, Optional, ChangeDetectionStrategy, forwardRef, ChangeDetectorRef, QueryList, ContentChildren, TemplateRef, ContentChild } from '@angular/core'; | ||
import { NG_VALIDATORS, NG_VALUE_ACCESSOR } from '@angular/forms'; | ||
@@ -6,22 +6,17 @@ import { Subject } from 'rxjs'; | ||
import { FsFileDragBaseComponent } from '../fs-file-drag-base/fs-file-drag-base'; | ||
import { InputProcessor } from '../../classes'; | ||
import { FsFile } from '../../models/fs-file'; | ||
import { CordovaService } from '../../services/cordova.service'; | ||
import { FS_FILE_MODULE_CONFIG } from '../../fs-file.providers'; | ||
import { FS_FILE_MODULE_CONFIG } from '../../injectors/file-config.injector'; | ||
import { FsFilePickerSelectDirective } from '../../directives'; | ||
import { FsApiFile } from '@firestitch/api'; | ||
import * as i0 from "@angular/core"; | ||
import * as i1 from "../../services/cordova.service"; | ||
import * as i2 from "@firestitch/label"; | ||
import * as i3 from "../fs-file/fs-file.component"; | ||
import * as i4 from "../fs-file-preview/fs-file-preview.component"; | ||
import * as i5 from "@angular/material/icon"; | ||
import * as i6 from "@angular/common"; | ||
import * as i7 from "../../directives/fs-file-preview-action.directive"; | ||
import * as i1 from "@firestitch/label"; | ||
import * as i2 from "../fs-file/fs-file.component"; | ||
import * as i3 from "../fs-file-preview/fs-file-preview.component"; | ||
import * as i4 from "@angular/material/icon"; | ||
import * as i5 from "@angular/common"; | ||
import * as i6 from "../../directives/fs-file-preview-action.directive"; | ||
export class FsFilePickerComponent extends FsFileDragBaseComponent { | ||
constructor(_moduleConfig, _cordovaService, _ngZone, _cdRef) { | ||
constructor(_moduleConfig, _cdRef) { | ||
super(); | ||
this._moduleConfig = _moduleConfig; | ||
this._cordovaService = _cordovaService; | ||
this._ngZone = _ngZone; | ||
this._cdRef = _cdRef; | ||
@@ -45,3 +40,2 @@ this.minWidth = 0; | ||
this._previewHeight = '150px'; | ||
this.inputProcessor = new InputProcessor(_cordovaService, _ngZone); | ||
} | ||
@@ -147,3 +141,3 @@ set url(url) { | ||
} | ||
FsFilePickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FsFilePickerComponent, deps: [{ token: FS_FILE_MODULE_CONFIG, optional: true }, { token: i1.CordovaService }, { token: i0.NgZone }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); | ||
FsFilePickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FsFilePickerComponent, deps: [{ token: FS_FILE_MODULE_CONFIG, optional: true }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); | ||
FsFilePickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: FsFilePickerComponent, selector: "fs-file-picker", inputs: { minWidth: "minWidth", minHeight: "minHeight", imageWidth: "imageWidth", imageHeight: "imageHeight", imageQuality: "imageQuality", label: "label", showFilename: "showFilename", allowDownload: "allowDownload", allowReupload: "allowReupload", multiple: "multiple", allowRemove: "allowRemove", url: "url", file: "file", accept: "accept", disabled: "disabled", previewWidth: "previewWidth", previewHeight: "previewHeight" }, outputs: { select: "select", remove: "remove", download: "download" }, providers: [ | ||
@@ -160,3 +154,3 @@ { | ||
} | ||
], queries: [{ propertyName: "filePickerSelectTemplate", first: true, predicate: FsFilePickerSelectDirective, descendants: true, read: TemplateRef }, { propertyName: "labels", predicate: FsFileLabelDirective }], viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<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 [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=\"file; else preview\"\n (remove)=\"removeFile()\"\n [file]=\"file\"\n [showFilename]=\"showFilename\"\n [previewHeight]=\"null\"\n [previewWidth]=\"null\">\n <ng-template\n fs-file-preview-action\n placement=\"top-right\"\n action=\"remove\"\n tooltip=\"Remove\"\n *ngIf=\"allowRemove\"\n (click)=\"actionClick($event)\">\n <mat-icon>close</mat-icon>\n </ng-template>\n <ng-template\n fs-file-preview-action\n placement=\"bottom-right\"\n tooltip=\"Reupload\"\n *ngIf=\"allowReupload\">\n <mat-icon>upload</mat-icon>\n </ng-template>\n <ng-template\n fs-file-preview-action\n placement=\"bottom-left\"\n action=\"download\"\n tooltip=\"Download\"\n [hide]=\"!(allowDownload && ((download.observers.length && file) || file.url))\"\n (click)=\"downloadClicked($event)\">\n <a\n [href]=\"file.url\"\n target=\"_blank\"\n tabindex=\"-1\"\n class=\"download\">\n <mat-icon>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", styles: [":host .wrap{border:1px #efefef solid;border-radius:3px}:host .wrap:after{border-width:3px;border-style:dashed;border-radius:3px}:host.dragover .wrap{border-color:transparent}:host.dragover .wrap:after{content:\"\";position:absolute;top:0;right:0;bottom:0;left:0}:host.dragover .wrap .select{border:none}:host.dragover .select button{display:none}:host.dragover .select .mat-icon{color:#07a8e6}:host ::ng-deep .percent-preview fs-file .file-label,:host ::ng-deep .percent-preview fs-file-preview{display:block}:host ::ng-deep fs-file .file-label{position:relative}:host ::ng-deep fs-file-preview{border:none;height:100%;width:100%}:host ::ng-deep fs-file-preview .preview-container{order:none;display:flex;justify-content:center;align-items:center;flex-grow:1;height:100%}:host .download{color:inherit}:host .select{text-align:center;width:100%;height:100%;vertical-align:middle;padding:0 10px;justify-content:center;flex-direction:column;box-sizing:border-box;display:flex;align-items:center}:host .select mat-icon{transform:scale(1.8);color:#ddd}:host .instruction{font-size:75%;padding:12px 0;line-height:normal}\n"], components: [{ type: i2.FsLabelFieldComponent, selector: "fs-label-field", inputs: ["bottomMargin", "topMargin", "labelMargin"] }, { type: i2.FsLabelComponent, selector: "fs-label" }, { type: i3.FsFileComponent, selector: "fs-file", inputs: ["minHeight", "minWidth", "orientate", "multiple", "capture", "allowClick", "allowDrop", "accept", "disabled", "imageWidth", "imageHeight", "imageQuality"], outputs: ["select", "error", "clicked", "declined"] }, { type: i4.FsFilePreviewComponent, selector: "fs-file-preview", inputs: ["showFilename", "previewWidth", "previewHeight", "file", "url", "index", "setActions", "setActionsTemplate"], outputs: ["remove"] }, { type: i5.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i2.FsLabelMessageComponent, selector: "fs-label-message" }], directives: [{ type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i7.FsFilePreviewActionDirective, selector: "[fs-file-preview-action]", inputs: ["placement", "tooltip", "action", "hide", "for-types"], outputs: ["click"] }, { type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); | ||
], queries: [{ propertyName: "filePickerSelectTemplate", first: true, predicate: FsFilePickerSelectDirective, descendants: true, read: TemplateRef }, { propertyName: "labels", predicate: FsFileLabelDirective }], viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<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 [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=\"file; else preview\"\n (remove)=\"removeFile()\"\n [file]=\"file\"\n [showFilename]=\"showFilename\"\n [previewHeight]=\"null\"\n [previewWidth]=\"null\">\n <ng-template\n fs-file-preview-action\n placement=\"top-right\"\n action=\"remove\"\n tooltip=\"Remove\"\n *ngIf=\"allowRemove\"\n (click)=\"actionClick($event)\">\n <mat-icon>close</mat-icon>\n </ng-template>\n <ng-template\n fs-file-preview-action\n placement=\"bottom-right\"\n tooltip=\"Reupload\"\n *ngIf=\"allowReupload\">\n <mat-icon>upload</mat-icon>\n </ng-template>\n <ng-template\n fs-file-preview-action\n placement=\"bottom-left\"\n action=\"download\"\n tooltip=\"Download\"\n [hide]=\"!(allowDownload && ((download.observers.length && file) || file.url))\"\n (click)=\"downloadClicked($event)\">\n <a\n [href]=\"file.url\"\n target=\"_blank\"\n tabindex=\"-1\"\n class=\"download\">\n <mat-icon>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", styles: [":host .wrap{border:1px #efefef solid;border-radius:3px}:host .wrap:after{border-width:3px;border-style:dashed;border-radius:3px}:host.dragover .wrap{border-color:transparent}:host.dragover .wrap:after{content:\"\";position:absolute;top:0;right:0;bottom:0;left:0}:host.dragover .wrap .select{border:none}:host.dragover .select button{display:none}:host.dragover .select .mat-icon{color:#07a8e6}:host ::ng-deep .percent-preview fs-file .file-label,:host ::ng-deep .percent-preview fs-file-preview{display:block}:host ::ng-deep fs-file .file-label{position:relative}:host ::ng-deep fs-file-preview{border:none;height:100%;width:100%}:host .download{color:inherit}:host .select{text-align:center;width:100%;height:100%;vertical-align:middle;padding:0 10px;justify-content:center;flex-direction:column;box-sizing:border-box;display:flex;align-items:center}:host .select mat-icon{transform:scale(1.8);color:#ddd}:host .instruction{font-size:75%;padding:12px 0;line-height:normal}\n"], components: [{ type: i1.FsLabelFieldComponent, selector: "fs-label-field", inputs: ["bottomMargin", "topMargin", "labelMargin"] }, { type: i1.FsLabelComponent, selector: "fs-label" }, { type: i2.FsFileComponent, selector: "fs-file", inputs: ["minHeight", "minWidth", "orientate", "multiple", "capture", "allowClick", "allowDrop", "accept", "disabled", "imageWidth", "imageHeight", "imageQuality"], outputs: ["select", "error", "clicked", "declined"] }, { type: i3.FsFilePreviewComponent, selector: "fs-file-preview", inputs: ["showFilename", "previewWidth", "previewHeight", "file", "url", "index", "setActions", "setActionsTemplate"], outputs: ["remove"] }, { type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { type: i1.FsLabelMessageComponent, selector: "fs-label-message" }], directives: [{ type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.FsFilePreviewActionDirective, selector: "[fs-file-preview-action]", inputs: ["placement", "tooltip", "action", "hide", "for-types"], outputs: ["click"] }, { type: i5.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FsFilePickerComponent, decorators: [{ | ||
@@ -187,3 +181,3 @@ type: Component, | ||
args: [FS_FILE_MODULE_CONFIG] | ||
}] }, { type: i1.CordovaService }, { type: i0.NgZone }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { fileInput: [{ | ||
}] }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { fileInput: [{ | ||
type: ViewChild, | ||
@@ -240,2 +234,2 @@ args: ['fileInput'] | ||
}] } }); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fs-file-picker.component.js","sourceRoot":"","sources":["../../../../../src/app/components/fs-file-picker/fs-file-picker.component.ts","../../../../../src/app/components/fs-file-picker/fs-file-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  EventEmitter,\n  Component,\n  Input,\n  Output,\n  ViewChild,\n  Inject,\n  Optional,\n  OnInit,\n  NgZone,\n  ChangeDetectionStrategy,\n  forwardRef,\n  ChangeDetectorRef,\n  QueryList,\n  ContentChildren,\n  TemplateRef,\n  OnDestroy,\n  ContentChild\n} from '@angular/core';\nimport { AbstractControl, AsyncValidator, ControlValueAccessor, NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors } from '@angular/forms';\n\nimport { from, of, Subject } from 'rxjs';\nimport { switchMap, takeUntil } from 'rxjs/operators';\n\nimport { FsFileLabelDirective } from '../../directives/fs-file-label.directive';\nimport { FsFileDragBaseComponent } from '../fs-file-drag-base/fs-file-drag-base';\nimport { InputProcessor } from '../../classes';\nimport { FsFile } from '../../models/fs-file';\nimport { CordovaService } from '../../services/cordova.service';\nimport { FS_FILE_MODULE_CONFIG } from '../../fs-file.providers';\nimport { FsFilePickerSelectDirective } from '../../directives';\nimport { FsApiFile } from '@firestitch/api';\n\n\n@Component({\n  selector: 'fs-file-picker',\n  templateUrl: 'fs-file-picker.component.html',\n  styleUrls: ['fs-file-picker.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => FsFilePickerComponent),\n    multi: true,\n  },\n  {\n    provide: NG_VALIDATORS, \n    useExisting: FsFilePickerComponent,\n    multi: true\n  }\n  ],  \n})\nexport class FsFilePickerComponent extends FsFileDragBaseComponent implements OnInit, ControlValueAccessor, AsyncValidator, OnDestroy {\n\n  @ViewChild('fileInput') \n  public fileInput: any;\n\n  @ContentChildren(FsFileLabelDirective)\n  public labels: QueryList<TemplateRef<any>>;\n\n  @ContentChild(FsFilePickerSelectDirective, { read: TemplateRef })\n  public filePickerSelectTemplate: TemplateRef<any>;\n\n  @Input() public minWidth = 0;\n  @Input() public minHeight = 0;\n  @Input() public imageWidth;\n  @Input() public imageHeight;\n  @Input() public imageQuality;\n  @Input() public label;\n  @Input() public showFilename = true;\n  @Input() public allowDownload = false;\n  @Input() public allowReupload = true;\n  @Input() public multiple = false;\n  @Input() public allowRemove = false;\n\n  @Input('url') set url(url) {\n    this.file = url ? new FsFile(url) : null;\n  }\n\n  @Input('file') set file(file: 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\n  @Input()\n  public accept: string | string[];\n  \n  public get file(): FsFile {\n    return this._file;\n  }\n\n  @Input()\n  public set disabled(value) {\n    this._disabled = value;\n  }\n\n  public get disabled() {\n    return this._disabled;\n  }\n  \n  @Input()\n  public set previewWidth(value: string | number) {\n    this._previewWidth = Number.isInteger(value) ? `${value}px` : value?.toString() || '';\n  }\n\n  public get previewWidth() {\n    return this._previewWidth;\n  }\n  \n  @Input()\n  public set previewHeight(value: string | number) {\n    this._previewHeight = Number.isInteger(value) ? `${value}px` : value?.toString() || '';\n  }\n\n  public get previewHeight() {\n    return this._previewHeight;\n  }\n\n  @Output() public select = new EventEmitter<any>();\n  @Output() public remove = new EventEmitter();\n  @Output() public download = new EventEmitter<FsFile>();\n\n  public onChange: any = () => {};\n  public onTouch: any = () => {};\n  public registerOnChange(fn): void { this.onChange = fn; }\n  public registerOnTouched(fn): void { this.onTouch = fn; }\n  public inputProcessor = null;\n  public instruction = 'Drag & Drop your file or use the button below';\n  public _file: FsFile;\n\n  private _destroy$ = new Subject();\n  private _disabled: boolean;  \n  private _previewWidth = '150px';\n  private _previewHeight = '150px';\n\n  public constructor(\n    @Optional() @Inject(FS_FILE_MODULE_CONFIG) private _moduleConfig,\n    private _cordovaService: CordovaService,\n    private _ngZone: NgZone,\n    private _cdRef: ChangeDetectorRef,\n  ) {\n    super();\n    this.inputProcessor = new InputProcessor(_cordovaService, _ngZone);\n  }\n\n  public ngOnInit() {\n    if (this._moduleConfig) {\n      if (this.allowDownload === void 0) {\n        this.allowDownload = this._moduleConfig.allowDownload\n      }\n\n      if (this.allowRemove === void 0) {\n        this.allowRemove = this._moduleConfig.allowRemove\n      }\n    }\n  }\n\n  public validate(control: AbstractControl): Promise<ValidationErrors | null> |  null { \n    if(this.file?.typeImage && (this.minWidth || this.minHeight)) {\n      // if(this.file.imageWidth < this.minWidth) {\n      //   return { minWidth: `Minimum width ${this.minWidth}px` };\n      // }\n\n      // if(this.file.imageHeight < this.minHeight) {\n      //   return { minWidth: `Minimum height ${this.minHeight}px` };\n      // }      \n    }\n\n    return null;\n  } \n\n  public get previewPercent() {\n    return String(this._previewWidth).match(/%/);\n  }\n\n  public writeValue(file): void {\n    this.file = file;\n    this._cdRef.markForCheck();\n  }\n\n  public selectFile(fsFile: FsFile) {\n    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 = void 0;\n    this.remove.emit(this.file);\n    this.onChange(null);\n  }\n\n  public actionClick(event: { event: PointerEvent }) {\n    event.event.stopPropagation();\n  }\n\n  public downloadClicked(event: { event: PointerEvent }) {\n    event.event.stopPropagation();\n\n    if(this.download.observers.length) {\n      event.event.preventDefault();\n      this.download.emit(this.file);\n    }\n  }\n  \n  public ngOnDestroy(): void {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  private _isNumeric(value) {\n    return /^-?\\d+$/.test(value);\n  }\n\n}\n","<fs-label-field\n    class=\"fs-form-wrapper\"\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      [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=\"file; else preview\"\n          (remove)=\"removeFile()\"\n          [file]=\"file\"\n          [showFilename]=\"showFilename\"\n          [previewHeight]=\"null\"\n          [previewWidth]=\"null\">\n        <ng-template\n            fs-file-preview-action\n            placement=\"top-right\"\n            action=\"remove\"\n            tooltip=\"Remove\"\n            *ngIf=\"allowRemove\"\n            (click)=\"actionClick($event)\">\n          <mat-icon>close</mat-icon>\n        </ng-template>\n        <ng-template\n            fs-file-preview-action\n            placement=\"bottom-right\"\n            tooltip=\"Reupload\"\n            *ngIf=\"allowReupload\">\n          <mat-icon>upload</mat-icon>\n        </ng-template>\n        <ng-template\n            fs-file-preview-action\n            placement=\"bottom-left\"\n            action=\"download\"\n            tooltip=\"Download\"\n            [hide]=\"!(allowDownload && ((download.observers.length && file) || file.url))\"\n            (click)=\"downloadClicked($event)\">\n          <a\n              [href]=\"file.url\"\n              target=\"_blank\"\n              tabindex=\"-1\"\n              class=\"download\">\n            <mat-icon>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  EventEmitter,\n  Component,\n  Input,\n  Output,\n  ViewChild,\n  Inject,\n  Optional,\n  OnInit,\n  NgZone,\n  ChangeDetectionStrategy,\n  forwardRef,\n  ChangeDetectorRef,\n  QueryList,\n  ContentChildren,\n  TemplateRef,\n  OnDestroy,\n  ContentChild\n} from '@angular/core';\nimport { AbstractControl, AsyncValidator, ControlValueAccessor, NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors } from '@angular/forms';\n\nimport { Subject } from 'rxjs';\n\nimport { FsFileLabelDirective } from '../../directives/fs-file-label.directive';\nimport { FsFileDragBaseComponent } from '../fs-file-drag-base/fs-file-drag-base';\nimport { FsFile } from '../../models/fs-file';\nimport { FS_FILE_MODULE_CONFIG } from '../../injectors/file-config.injector';\nimport { FsFilePickerSelectDirective } from '../../directives';\nimport { FsApiFile } from '@firestitch/api';\n\n\n@Component({\n  selector: 'fs-file-picker',\n  templateUrl: 'fs-file-picker.component.html',\n  styleUrls: ['fs-file-picker.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => FsFilePickerComponent),\n    multi: true,\n  },\n  {\n    provide: NG_VALIDATORS, \n    useExisting: FsFilePickerComponent,\n    multi: true\n  }\n  ],  \n})\nexport class FsFilePickerComponent extends FsFileDragBaseComponent implements OnInit, ControlValueAccessor, AsyncValidator, OnDestroy {\n\n  @ViewChild('fileInput') \n  public fileInput: any;\n\n  @ContentChildren(FsFileLabelDirective)\n  public labels: QueryList<TemplateRef<any>>;\n\n  @ContentChild(FsFilePickerSelectDirective, { read: TemplateRef })\n  public filePickerSelectTemplate: TemplateRef<any>;\n\n  @Input() public minWidth = 0;\n  @Input() public minHeight = 0;\n  @Input() public imageWidth;\n  @Input() public imageHeight;\n  @Input() public imageQuality;\n  @Input() public label;\n  @Input() public showFilename = true;\n  @Input() public allowDownload = false;\n  @Input() public allowReupload = true;\n  @Input() public multiple = false;\n  @Input() public allowRemove = false;\n\n  @Input('url') set url(url) {\n    this.file = url ? new FsFile(url) : null;\n  }\n\n  @Input('file') set file(file: 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\n  @Input()\n  public accept: string | string[];\n  \n  public get file(): FsFile {\n    return this._file;\n  }\n\n  @Input()\n  public set disabled(value) {\n    this._disabled = value;\n  }\n\n  public get disabled() {\n    return this._disabled;\n  }\n  \n  @Input()\n  public set previewWidth(value: string | number) {\n    this._previewWidth = Number.isInteger(value) ? `${value}px` : value?.toString() || '';\n  }\n\n  public get previewWidth() {\n    return this._previewWidth;\n  }\n  \n  @Input()\n  public set previewHeight(value: string | number) {\n    this._previewHeight = Number.isInteger(value) ? `${value}px` : value?.toString() || '';\n  }\n\n  public get previewHeight() {\n    return this._previewHeight;\n  }\n\n  @Output() public select = new EventEmitter<any>();\n  @Output() public remove = new EventEmitter();\n  @Output() public download = new EventEmitter<FsFile>();\n\n  public onChange: any = () => {};\n  public onTouch: any = () => {};\n  public registerOnChange(fn): void { this.onChange = fn; }\n  public registerOnTouched(fn): void { this.onTouch = fn; }\n  public inputProcessor = null;\n  public instruction = 'Drag & Drop your file or use the button below';\n  public _file: FsFile;\n\n  private _destroy$ = new Subject();\n  private _disabled: boolean;  \n  private _previewWidth = '150px';\n  private _previewHeight = '150px';\n\n  public constructor(\n    @Optional() @Inject(FS_FILE_MODULE_CONFIG) private _moduleConfig,\n    private _cdRef: ChangeDetectorRef,\n  ) {\n    super();\n  }\n\n  public ngOnInit() {\n    if (this._moduleConfig) {\n      if (this.allowDownload === void 0) {\n        this.allowDownload = this._moduleConfig.allowDownload\n      }\n\n      if (this.allowRemove === void 0) {\n        this.allowRemove = this._moduleConfig.allowRemove\n      }\n    }\n  }\n\n  public validate(control: AbstractControl): Promise<ValidationErrors | null> |  null { \n    if(this.file?.typeImage && (this.minWidth || this.minHeight)) {\n      // if(this.file.imageWidth < this.minWidth) {\n      //   return { minWidth: `Minimum width ${this.minWidth}px` };\n      // }\n\n      // if(this.file.imageHeight < this.minHeight) {\n      //   return { minWidth: `Minimum height ${this.minHeight}px` };\n      // }      \n    }\n\n    return null;\n  } \n\n  public get previewPercent() {\n    return String(this._previewWidth).match(/%/);\n  }\n\n  public writeValue(file): void {\n    this.file = file;\n    this._cdRef.markForCheck();\n  }\n\n  public selectFile(fsFile: FsFile) {\n    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 = void 0;\n    this.remove.emit(this.file);\n    this.onChange(null);\n  }\n\n  public actionClick(event: { event: PointerEvent }) {\n    event.event.stopPropagation();\n  }\n\n  public downloadClicked(event: { event: PointerEvent }) {\n    event.event.stopPropagation();\n\n    if(this.download.observers.length) {\n      event.event.preventDefault();\n      this.download.emit(this.file);\n    }\n  }\n  \n  public ngOnDestroy(): void {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  private _isNumeric(value) {\n    return /^-?\\d+$/.test(value);\n  }\n\n}\n","<fs-label-field\n    class=\"fs-form-wrapper\"\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      [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=\"file; else preview\"\n          (remove)=\"removeFile()\"\n          [file]=\"file\"\n          [showFilename]=\"showFilename\"\n          [previewHeight]=\"null\"\n          [previewWidth]=\"null\">\n        <ng-template\n            fs-file-preview-action\n            placement=\"top-right\"\n            action=\"remove\"\n            tooltip=\"Remove\"\n            *ngIf=\"allowRemove\"\n            (click)=\"actionClick($event)\">\n          <mat-icon>close</mat-icon>\n        </ng-template>\n        <ng-template\n            fs-file-preview-action\n            placement=\"bottom-right\"\n            tooltip=\"Reupload\"\n            *ngIf=\"allowReupload\">\n          <mat-icon>upload</mat-icon>\n        </ng-template>\n        <ng-template\n            fs-file-preview-action\n            placement=\"bottom-left\"\n            action=\"download\"\n            tooltip=\"Download\"\n            [hide]=\"!(allowDownload && ((download.observers.length && file) || file.url))\"\n            (click)=\"downloadClicked($event)\">\n          <a\n              [href]=\"file.url\"\n              target=\"_blank\"\n              tabindex=\"-1\"\n              class=\"download\">\n            <mat-icon>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"]} |
@@ -65,3 +65,3 @@ import { EventEmitter, Component, Input, Output, ChangeDetectionStrategy, } from '@angular/core'; | ||
FsFilePreviewComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FsFilePreviewComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); | ||
FsFilePreviewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: FsFilePreviewComponent, selector: "fs-file-preview", inputs: { showFilename: "showFilename", previewWidth: "previewWidth", previewHeight: "previewHeight", file: "file", url: "url", index: "index", setActions: "setActions", setActionsTemplate: "setActionsTemplate" }, outputs: { remove: "remove" }, usesInheritance: true, ngImport: i0, template: "<div\n [style.width.px]=\"previewWidth\"\n [style.height.px]=\"previewHeight\"\n class=\"preview-container\"\n [ngClass]=\"{ \n 'has-actions': !!actions.length, \n 'type-image': file.typeImage && file.exists\n }\">\n\n <!-- Image container -->\n <ng-container \n *ngIf=\"file?.exists && file.typeImage; else nonImage\">\n <img \n [src]=\"file | previewImage | async\" \n [ngClass]=\"{ loaded: this.loaded }\"\n (load)=\"previewLoaded()\">\n </ng-container>\n\n <!-- Non image container -->\n <ng-template #nonImage>\n <div class=\"file-details\">\n <div class=\"file-icon\">\n <div class=\"file-ext\">{{file.extension}}</div>\n <mat-icon>insert_drive_file</mat-icon>\n </div>\n <div class=\"file-name\" [matTooltip]=\"file.name\" *ngIf=\"showFilename && file.name\">{{file.name}}</div>\n </div>\n </ng-template>\n\n <div class=\"actions\">\n <ng-container *ngFor=\"let action of actionTemplates; let index = index\">\n <div\n class=\"action mat-mini-fab mat-primary\"\n *ngIf=\"!action.hide\"\n [ngClass]=\"{ hide: action.hide }\"\n [class]=\"action.placement\"\n [matTooltip]=\"action.tooltip\"\n (click)=\"callAction($event, action, index)\">\n <span class=\"mat-button-wrapper\">\n <ng-template [ngTemplateOutlet]=\"actionTemplateRefs[index]\"></ng-template>\n </span>\n </div>\n </ng-container>\n </div>\n\n <div class=\"spinner\">\n <mat-spinner *ngIf=\"file.progress\" [diameter]=\"30\"></mat-spinner>\n </div>\n\n <ng-content></ng-content>\n</div>", 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;align-items:center;padding:5px}:host .file-details .file-icon{position:relative}:host .file-details .file-ext{font-weight:bold;text-align:center;text-transform:uppercase;font-size:20px;position:absolute;width:100%;bottom:28px;color:#fff}:host .file-details mat-icon{font-size:90px;width:90px;height:90px;color:#ccc}:host .file-details .file-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 5px;font-size:75%;text-align:center;width:100%}:host .preview-container{overflow:hidden;box-sizing:border-box;margin:auto}:host .actions{position:absolute;width:100%;height:100%;top:0;left:0}:host .actions .action{position:absolute;cursor:pointer}:host .actions .action.hide{display:none}: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:hover .actions,:host:focus .actions{display:block}:host img{display:block;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}img.loaded{opacity:1}\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, "previewImage": i5.PreviewImagePipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush }); | ||
FsFilePreviewComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: FsFilePreviewComponent, selector: "fs-file-preview", inputs: { showFilename: "showFilename", previewWidth: "previewWidth", previewHeight: "previewHeight", file: "file", url: "url", index: "index", setActions: "setActions", setActionsTemplate: "setActionsTemplate" }, outputs: { remove: "remove" }, usesInheritance: true, ngImport: i0, template: "<div\n [style.width.px]=\"previewWidth\"\n [style.height.px]=\"previewHeight\"\n class=\"preview-container\"\n [ngClass]=\"{ \n 'has-actions': !!actions.length, \n 'type-image': file.typeImage && file.exists\n }\">\n\n <!-- Image container -->\n <ng-container \n *ngIf=\"file?.exists && file.typeImage; else nonImage\">\n <img \n [src]=\"file | previewImage | async\" \n [ngClass]=\"{ loaded: this.loaded }\"\n (load)=\"previewLoaded()\">\n </ng-container>\n\n <!-- Non image container -->\n <ng-template #nonImage>\n <div class=\"file-details\">\n <div class=\"file-icon\">\n <div class=\"file-ext\">{{file.extension}}</div>\n <mat-icon>insert_drive_file</mat-icon>\n </div>\n <div class=\"file-name\" [matTooltip]=\"file.name\" *ngIf=\"showFilename && file.name\">{{file.name}}</div>\n </div>\n </ng-template>\n\n <div class=\"actions\">\n <ng-container *ngFor=\"let action of actionTemplates; let index = index\">\n <div\n class=\"action mat-mini-fab mat-primary\"\n *ngIf=\"!action.hide\"\n [ngClass]=\"{ hide: action.hide }\"\n [class]=\"action.placement\"\n [matTooltip]=\"action.tooltip\"\n (click)=\"callAction($event, action, index)\">\n <span class=\"mat-button-wrapper\">\n <ng-template [ngTemplateOutlet]=\"actionTemplateRefs[index]\"></ng-template>\n </span>\n </div>\n </ng-container>\n </div>\n\n <div class=\"spinner\">\n <mat-spinner *ngIf=\"file.progress\" [diameter]=\"30\"></mat-spinner>\n </div>\n\n <ng-content></ng-content>\n</div>", 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;align-items:center;padding:5px}:host .file-details .file-icon{position:relative}:host .file-details .file-ext{font-weight:bold;text-align:center;text-transform:uppercase;font-size:20px;position:absolute;width:100%;bottom:28px;color:#fff}:host .file-details mat-icon{font-size:90px;width:90px;height:90px;color:#ccc}:host .file-details .file-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding:0 5px;font-size:75%;text-align:center;width:100%}:host .preview-container{overflow:hidden;box-sizing:border-box;margin:auto;display:flex;justify-content:center;align-items:center;flex-grow:1;height:100%}: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 .actions{position:absolute;width:100%;height:100%;top:0;left:0}: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;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}img.loaded{opacity:1}\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, "previewImage": i5.PreviewImagePipe }, changeDetection: i0.ChangeDetectionStrategy.OnPush }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FsFilePreviewComponent, decorators: [{ | ||
@@ -68,0 +68,0 @@ type: Component, |
@@ -6,8 +6,8 @@ import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Inject, Input, NgZone, Optional, Output, ViewChild } from '@angular/core'; | ||
import { FsFileDragBaseComponent } from '../fs-file-drag-base/fs-file-drag-base'; | ||
import { CordovaService } from '../../services/cordova.service'; | ||
import { FileProcessor, InputProcessor } from '../../classes'; | ||
import { FS_FILE_MODULE_CONFIG } from '../../fs-file.providers'; | ||
import { FileProcessor } from '../../classes'; | ||
import { FS_FILE_MODULE_CONFIG } from '../../injectors'; | ||
import { FileProcessConfig } from '../../models'; | ||
import { InputProcessorService } from '../../services'; | ||
import * as i0 from "@angular/core"; | ||
import * as i1 from "../../services/cordova.service"; | ||
import * as i1 from "../../services"; | ||
import * as i2 from "@firestitch/message"; | ||
@@ -17,8 +17,8 @@ import * as i3 from "../fs-file-dragover-message/fs-file-dragover-message.component"; | ||
export class FsFileComponent extends FsFileDragBaseComponent { | ||
constructor(cordovaService, el, ngZone, moduleConfig, _message) { | ||
constructor(el, inputProcessor, ngZone, moduleConfig, _message) { | ||
super(); | ||
this.el = el; | ||
this.inputProcessor = inputProcessor; | ||
this.moduleConfig = moduleConfig; | ||
this._message = _message; | ||
this.inputProcessor = null; | ||
this._destroy$ = new Subject(); | ||
@@ -30,3 +30,2 @@ this.processConfig = new FileProcessConfig(); | ||
this.declined = new EventEmitter(); | ||
this.inputProcessor = new InputProcessor(cordovaService, ngZone); | ||
this.initSelect(); | ||
@@ -144,4 +143,4 @@ } | ||
} | ||
FsFileComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FsFileComponent, deps: [{ token: i1.CordovaService }, { token: i0.ElementRef }, { token: i0.NgZone }, { token: FS_FILE_MODULE_CONFIG, optional: true }, { token: i2.FsMessage }], target: i0.ɵɵFactoryTarget.Component }); | ||
FsFileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: FsFileComponent, selector: "fs-file", inputs: { minHeight: "minHeight", minWidth: "minWidth", orientate: "orientate", multiple: "multiple", capture: "capture", allowClick: "allowClick", allowDrop: "allowDrop", accept: "accept", disabled: "disabled", imageWidth: "imageWidth", imageHeight: "imageHeight", imageQuality: "imageQuality" }, outputs: { select: "select", error: "error", clicked: "clicked", declined: "declined" }, viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true, static: true }, { propertyName: "fileLabel", first: true, predicate: ["fileLabel"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"file-label\" #fileLabel>\n <ng-content></ng-content>\n</div>\n<input\n type=\"file\"\n [hidden]=\"true\"\n [disabled]=\"inputProcessor.disabled\"\n [multiple]=\"inputProcessor.multiple\"\n [attr.accept]=\"inputProcessor.accept\"\n [attr.capture]=\"inputProcessor.capture\"\n #fileInput>\n\n<fs-file-dragover-message *ngIf=\"moduleConfig.dragoverMessage\"></fs-file-dragover-message>\n", styles: [":host label{cursor:pointer}.file-label{display:inline-block}\n"], components: [{ type: i3.FsFileDragoverMessageComponent, selector: "fs-file-dragover-message" }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); | ||
FsFileComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FsFileComponent, deps: [{ token: i0.ElementRef }, { token: i1.InputProcessorService }, { token: i0.NgZone }, { token: FS_FILE_MODULE_CONFIG, optional: true }, { token: i2.FsMessage }], target: i0.ɵɵFactoryTarget.Component }); | ||
FsFileComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: FsFileComponent, selector: "fs-file", inputs: { minHeight: "minHeight", minWidth: "minWidth", orientate: "orientate", multiple: "multiple", capture: "capture", allowClick: "allowClick", allowDrop: "allowDrop", accept: "accept", disabled: "disabled", imageWidth: "imageWidth", imageHeight: "imageHeight", imageQuality: "imageQuality" }, outputs: { select: "select", error: "error", clicked: "clicked", declined: "declined" }, providers: [InputProcessorService], viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true, static: true }, { propertyName: "fileLabel", first: true, predicate: ["fileLabel"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"file-label\" #fileLabel>\n <ng-content></ng-content>\n</div>\n<input\n type=\"file\"\n [hidden]=\"true\"\n [disabled]=\"inputProcessor.disabled\"\n [multiple]=\"inputProcessor.multiple\"\n [attr.accept]=\"inputProcessor.accept\"\n [attr.capture]=\"inputProcessor.capture\"\n #fileInput>\n\n<fs-file-dragover-message *ngIf=\"moduleConfig.dragoverMessage\"></fs-file-dragover-message>\n", styles: [":host label{cursor:pointer}.file-label{display:inline-block}\n"], components: [{ type: i3.FsFileDragoverMessageComponent, selector: "fs-file-dragover-message" }], directives: [{ type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); | ||
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FsFileComponent, decorators: [{ | ||
@@ -154,4 +153,5 @@ type: Component, | ||
changeDetection: ChangeDetectionStrategy.OnPush, | ||
providers: [InputProcessorService], | ||
}] | ||
}], ctorParameters: function () { return [{ type: i1.CordovaService }, { type: i0.ElementRef }, { type: i0.NgZone }, { type: undefined, decorators: [{ | ||
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.InputProcessorService }, { type: i0.NgZone }, { type: undefined, decorators: [{ | ||
type: Optional | ||
@@ -200,2 +200,2 @@ }, { | ||
}] } }); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fs-file.component.js","sourceRoot":"","sources":["../../../../../src/app/components/fs-file/fs-file.component.ts","../../../../../src/app/components/fs-file/fs-file.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy, OnInit,\n  Optional,\n  Output,\n  ViewChild\n} from '@angular/core';\n\nimport { FsMessage, MessageMode } from '@firestitch/message';\n\nimport { map, switchMap, takeUntil } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\n\nimport { FsFileDragBaseComponent } from '../fs-file-drag-base/fs-file-drag-base';\nimport { CordovaService } from '../../services/cordova.service';\nimport { FileProcessor, InputProcessor } from '../../classes';\nimport { FS_FILE_MODULE_CONFIG } from '../../fs-file.providers';\nimport { FileProcessConfig } from '../../models';\n\n\n@Component({\n  selector: 'fs-file',\n  templateUrl: './fs-file.component.html',\n  styleUrls: ['./fs-file.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class FsFileComponent extends FsFileDragBaseComponent implements OnInit, OnDestroy {\n\n  public inputProcessor: InputProcessor = null;\n\n  private _destroy$ = new Subject();\n  private processConfig = new FileProcessConfig();\n\n  @Input()\n  public set minHeight(value) {\n    this.processConfig.minHeight = value;\n  }\n\n  @Input()\n  public set minWidth(value) {\n    this.processConfig.minWidth = value;\n  }\n\n  @Input()\n  public set orientate(value) {\n    this.processConfig.orientate = value;\n  }\n\n  @Input()\n  public set multiple(value) {\n    // TODO This should be a helper function in @firestitch/common\n    if (typeof(value) === 'boolean') {\n      this.inputProcessor.multiple = value;\n    } else {\n      this.inputProcessor.multiple = value === 'true';\n    }\n  }\n\n  public get multiple() {\n    return this.inputProcessor.multiple;\n  }\n\n  public get api() {\n    return this.inputProcessor.api;\n  }\n\n  @Input()\n  public set capture(value) {\n    this.inputProcessor.capture = value;\n  }\n\n  @Input()\n  public set allowClick(value) {\n    this.inputProcessor.allowClick = value;\n  }\n\n  @Input()\n  public set allowDrop(value) {\n    this.inputProcessor.allowDrop = value;\n  }\n\n  public get capture() {\n    return this.inputProcessor.capture;\n  }\n\n  /**\n   * Accept Examples\n   * \n   * image/*,audio/*,video/*,image/jpg,.pdf\n   */\n  @Input()\n  public set accept(value: string | string[]) {\n    this.inputProcessor.accept = Array.isArray(value) ? value.join(',') : value;\n  }\n\n  public get accept() {\n    return this.inputProcessor.accept;\n  }\n\n  @Input()\n  public set disabled(value) {\n    this.inputProcessor.disabled = value;\n  }\n\n  public get disabled() {\n    return this.inputProcessor.disabled;\n  }\n\n  @Input()\n  public set imageWidth(value) {\n    this.processConfig.maxWidth = +value;\n  }\n\n  @Input()\n  public set imageHeight(value) {\n    this.processConfig.maxHeight = +value;\n  }\n\n  @Input()\n  public set imageQuality(value) {\n    this.processConfig.quality = value;\n  }\n\n  @Output() public select = new EventEmitter();\n  @Output() public error = new EventEmitter();\n  @Output() public clicked = new EventEmitter();\n  @Output() public declined = new EventEmitter<File[]>();\n\n  @ViewChild('fileInput', { static: true })\n  public fileInput: any;\n\n  @ViewChild('fileLabel', { static: true })\n  public fileLabel: any;\n\n  constructor(\n    cordovaService: CordovaService,\n    public el: ElementRef,\n    ngZone: NgZone,\n    @Optional()\n    @Inject(FS_FILE_MODULE_CONFIG)\n    public moduleConfig,\n    private _message: FsMessage,\n  ) {\n    super();\n    this.inputProcessor = new InputProcessor(cordovaService, ngZone);\n    this.initSelect();\n  }\n\n  public ngOnInit() {\n    this.inputProcessor.registerInput(this.fileInput);\n    this.inputProcessor.registerLabel(this.fileLabel);\n    this.inputProcessor.registerDrop(this.el);\n    this.listenDeclinedFiles();\n  }\n\n  public ngOnDestroy() {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  private initSelect() {\n    const fileProcessor = new FileProcessor();\n\n    this.inputProcessor.clicked\n    .pipe(\n      takeUntil(this._destroy$),\n    )\n    .subscribe((event: KeyboardEvent) => {\n      this.clicked.next(event);\n    });\n\n    this.inputProcessor.select\n    .pipe(\n      switchMap((files) => {\n        if (!Array.isArray(files)) {\n            files = [files];\n        }\n\n        return fileProcessor.processFiles(files, this.processConfig);\n      }),\n      map((fsFiles) => {\n        return this.inputProcessor.multiple ? fsFiles : fsFiles[0]; \n      }),\n      takeUntil(this._destroy$),\n    )\n    .subscribe((e) => {\n      this.select.emit(e);\n    },\n    (e) => {\n      this.error.emit(e);\n      this.initSelect();\n    })\n  }\n\n  private listenDeclinedFiles(): void {\n    this.inputProcessor\n      .declinedFiles$\n      .pipe(\n        takeUntil(this._destroy$),\n      )\n      .subscribe((files) => {\n        this.declined.next(files);\n\n        files.forEach((file) => {\n          this._message.error(\n            `Upload file type is not supported for ${file.name}`,\n            {\n              mode: MessageMode.Toast,\n              positionClass: 'toast-bottom-right',\n            }\n          )\n        })\n      })\n  }\n}\n","<div class=\"file-label\" #fileLabel>\n  <ng-content></ng-content>\n</div>\n<input\n  type=\"file\"\n  [hidden]=\"true\"\n  [disabled]=\"inputProcessor.disabled\"\n  [multiple]=\"inputProcessor.multiple\"\n  [attr.accept]=\"inputProcessor.accept\"\n  [attr.capture]=\"inputProcessor.capture\"\n  #fileInput>\n\n<fs-file-dragover-message *ngIf=\"moduleConfig.dragoverMessage\"></fs-file-dragover-message>\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fs-file.component.js","sourceRoot":"","sources":["../../../../../src/app/components/fs-file/fs-file.component.ts","../../../../../src/app/components/fs-file/fs-file.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  Input,\n  NgZone,\n  OnDestroy, OnInit,\n  Optional,\n  Output,\n  ViewChild\n} from '@angular/core';\n\nimport { FsMessage, MessageMode } from '@firestitch/message';\n\nimport { map, switchMap, takeUntil } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\n\nimport { FsFileDragBaseComponent } from '../fs-file-drag-base/fs-file-drag-base';\nimport { FileProcessor } from '../../classes';\nimport { FS_FILE_MODULE_CONFIG } from '../../injectors';\nimport { FileProcessConfig } from '../../models';\nimport { InputProcessorService } from '../../services';\n\n\n@Component({\n  selector: 'fs-file',\n  templateUrl: './fs-file.component.html',\n  styleUrls: ['./fs-file.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [InputProcessorService],\n})\nexport class FsFileComponent extends FsFileDragBaseComponent implements OnInit, OnDestroy {\n\n  private _destroy$ = new Subject();\n  private processConfig = new FileProcessConfig();\n\n  @Input()\n  public set minHeight(value) {\n    this.processConfig.minHeight = value;\n  }\n\n  @Input()\n  public set minWidth(value) {\n    this.processConfig.minWidth = value;\n  }\n\n  @Input()\n  public set orientate(value) {\n    this.processConfig.orientate = value;\n  }\n\n  @Input()\n  public set multiple(value) {\n    // TODO This should be a helper function in @firestitch/common\n    if (typeof(value) === 'boolean') {\n      this.inputProcessor.multiple = value;\n    } else {\n      this.inputProcessor.multiple = value === 'true';\n    }\n  }\n\n  public get multiple() {\n    return this.inputProcessor.multiple;\n  }\n\n  public get api() {\n    return this.inputProcessor.api;\n  }\n\n  @Input()\n  public set capture(value) {\n    this.inputProcessor.capture = value;\n  }\n\n  @Input()\n  public set allowClick(value) {\n    this.inputProcessor.allowClick = value;\n  }\n\n  @Input()\n  public set allowDrop(value) {\n    this.inputProcessor.allowDrop = value;\n  }\n\n  public get capture() {\n    return this.inputProcessor.capture;\n  }\n\n  /**\n   * Accept Examples\n   * \n   * image/*,audio/*,video/*,image/jpg,.pdf\n   */\n  @Input()\n  public set accept(value: string | string[]) {\n    this.inputProcessor.accept = Array.isArray(value) ? value.join(',') : value;\n  }\n\n  public get accept() {\n    return this.inputProcessor.accept;\n  }\n\n  @Input()\n  public set disabled(value) {\n    this.inputProcessor.disabled = value;\n  }\n\n  public get disabled() {\n    return this.inputProcessor.disabled;\n  }\n\n  @Input()\n  public set imageWidth(value) {\n    this.processConfig.maxWidth = +value;\n  }\n\n  @Input()\n  public set imageHeight(value) {\n    this.processConfig.maxHeight = +value;\n  }\n\n  @Input()\n  public set imageQuality(value) {\n    this.processConfig.quality = value;\n  }\n\n  @Output() public select = new EventEmitter();\n  @Output() public error = new EventEmitter();\n  @Output() public clicked = new EventEmitter();\n  @Output() public declined = new EventEmitter<File[]>();\n\n  @ViewChild('fileInput', { static: true })\n  public fileInput: any;\n\n  @ViewChild('fileLabel', { static: true })\n  public fileLabel: any;\n\n  constructor(\n    public el: ElementRef,\n    public inputProcessor: InputProcessorService,\n    ngZone: NgZone,\n    @Optional()\n    @Inject(FS_FILE_MODULE_CONFIG)\n    public moduleConfig,\n    private _message: FsMessage,\n  ) {\n    super();\n    this.initSelect();\n  }\n\n  public ngOnInit() {\n    this.inputProcessor.registerInput(this.fileInput);\n    this.inputProcessor.registerLabel(this.fileLabel);\n    this.inputProcessor.registerDrop(this.el);\n    this.listenDeclinedFiles();\n  }\n\n  public ngOnDestroy() {\n    this._destroy$.next();\n    this._destroy$.complete();\n  }\n\n  private initSelect() {\n    const fileProcessor = new FileProcessor();\n\n    this.inputProcessor.clicked\n    .pipe(\n      takeUntil(this._destroy$),\n    )\n    .subscribe((event: KeyboardEvent) => {\n      this.clicked.next(event);\n    });\n\n    this.inputProcessor.select\n    .pipe(\n      switchMap((files) => {\n        if (!Array.isArray(files)) {\n          files = [files];\n        }\n\n        return fileProcessor.processFiles(files, this.processConfig);\n      }),\n      map((fsFiles) => {\n        return this.inputProcessor.multiple ? fsFiles : fsFiles[0]; \n      }),\n      takeUntil(this._destroy$),\n    )\n    .subscribe((e) => {\n      this.select.emit(e);\n    },\n    (e) => {\n      this.error.emit(e);\n      this.initSelect();\n    })\n  }\n\n  private listenDeclinedFiles(): void {\n    this.inputProcessor\n      .declinedFiles$\n      .pipe(\n        takeUntil(this._destroy$),\n      )\n      .subscribe((files) => {\n        this.declined.next(files);\n\n        files.forEach((file) => {\n          this._message.error(\n            `Upload file type is not supported for ${file.name}`,\n            {\n              mode: MessageMode.Toast,\n              positionClass: 'toast-bottom-right',\n            }\n          )\n        })\n      })\n  }\n}\n","<div class=\"file-label\" #fileLabel>\n  <ng-content></ng-content>\n</div>\n<input\n  type=\"file\"\n  [hidden]=\"true\"\n  [disabled]=\"inputProcessor.disabled\"\n  [multiple]=\"inputProcessor.multiple\"\n  [attr.accept]=\"inputProcessor.accept\"\n  [attr.capture]=\"inputProcessor.capture\"\n  #fileInput>\n\n<fs-file-dragover-message *ngIf=\"moduleConfig.dragoverMessage\"></fs-file-dragover-message>\n"]} |
@@ -23,4 +23,3 @@ import { NgModule } from '@angular/core'; | ||
import { FsFilePreviewActionDirective } from './directives/fs-file-preview-action.directive'; | ||
import { CordovaService } from './services/cordova.service'; | ||
import { FS_FILE_MODULE_CONFIG } from './fs-file.providers'; | ||
import { FS_FILE_MODULE_CONFIG } from './injectors'; | ||
import { FsLabelModule } from '@firestitch/label'; | ||
@@ -84,5 +83,3 @@ import { FsPromptModule } from '@firestitch/prompt'; | ||
FsFilePickerSelectDirective] }); | ||
FsFileModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FsFileModule, providers: [ | ||
CordovaService | ||
], imports: [[ | ||
FsFileModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: FsFileModule, imports: [[ | ||
FormsModule, | ||
@@ -145,7 +142,4 @@ CommonModule, | ||
], | ||
providers: [ | ||
CordovaService | ||
], | ||
}] | ||
}] }); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fs-file.module.js","sourceRoot":"","sources":["../../../src/app/fs-file.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule, ModuleWithProviders } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatDialogModule } from '@angular/material/dialog';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\nimport { MatTooltipModule } from '@angular/material/tooltip';\n\nimport { FsFileComponent } from './components/fs-file/fs-file.component';\nimport { FsFilePreviewsComponent } from './components/fs-file-previews/fs-file-previews.component';\nimport { FsFilePreviewComponent, } from './components/fs-file-preview/fs-file-preview.component';\nimport { FsFilePickerComponent, } from './components/fs-file-picker/fs-file-picker.component';\nimport { FsFilePreviewsBaseComponent, } from './components/fs-file-preview-base/fs-file-preview-base';\nimport { FsFileDragBaseComponent, } from './components/fs-file-drag-base/fs-file-drag-base';\nimport { FsFileImagePickerComponent } from './components/fs-file-image-picker/fs-file-image-picker.component';\nimport { FsFileImagePickerDialogComponent } from './components/fs-file-image-picker/fs-file-image-picker-dialog/fs-file-image-picker-dialog.component';\nimport { FsFileBouncingIconComponent } from './components/fs-file-bouncing-icon/fs-file-bouncing-icon.component';\nimport { FsFileDragoverMessageComponent } from './components/fs-file-dragover-message/fs-file-dragover-message.component';\n\nimport { FsFileHintDirective } from './directives/fs-file-hint.directive';\nimport { FsFileLabelDirective } from './directives/fs-file-label.directive';\nimport { FsFilePreviewActionDirective } from './directives/fs-file-preview-action.directive';\n\nimport { CordovaService } from './services/cordova.service';\nimport { FS_FILE_MODULE_CONFIG } from './fs-file.providers';\nimport { FsFileModuleConfig } from './interfaces/module-config.interface';\n\nimport { FsLabelModule } from '@firestitch/label';\nimport { FsPromptModule } from '@firestitch/prompt';\nimport { FormsModule } from '@angular/forms';\nimport { FilePreviewMapFilePipe, PreviewImagePipe } from './pipes';\nimport { FsFilePickerSelectDirective } from './directives';\n\n\n@NgModule({\n  imports: [\n    FormsModule,\n    CommonModule,\n\n    MatIconModule,\n    MatTooltipModule,\n    MatProgressSpinnerModule,\n    MatButtonModule,\n    MatDialogModule,\n    MatFormFieldModule,\n    MatInputModule,\n\n    FsLabelModule,\n    FsPromptModule,\n  ],\n  exports: [\n    FsFileComponent,\n    FsFilePreviewsComponent,\n    FsFilePreviewComponent,\n    FsFilePreviewActionDirective,\n    FsFilePickerComponent,\n    FsFileImagePickerComponent,\n    FsFileHintDirective,\n    FsFileLabelDirective,\n    FsFilePickerSelectDirective,\n  ],\n  declarations: [\n    FsFileComponent,\n    FsFilePreviewsComponent,\n    FsFilePreviewComponent,\n    FsFilePreviewActionDirective,\n    FsFileDragBaseComponent,\n    FsFilePreviewsBaseComponent,\n    FsFilePickerComponent,\n    FsFileImagePickerComponent,\n    FsFileBouncingIconComponent,\n    FsFileDragoverMessageComponent,\n    FsFileImagePickerDialogComponent,\n    FsFileHintDirective,\n    FsFileLabelDirective,\n    PreviewImagePipe,\n    FilePreviewMapFilePipe,\n    FsFilePickerSelectDirective,\n  ],\n  providers: [\n    CordovaService\n  ],\n})\nexport class FsFileModule {\n  static forRoot(config: FsFileModuleConfig = null): ModuleWithProviders<FsFileModule> {\n    return {\n      ngModule: FsFileModule,\n      providers: [\n        {\n          provide: FS_FILE_MODULE_CONFIG,\n          useValue: config || {\n            allowDownload: true,\n            allowRemove: true,\n            dragoverMessage: true\n          }\n        }\n      ]\n    };\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"fs-file.module.js","sourceRoot":"","sources":["../../../src/app/fs-file.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgModule, ModuleWithProviders } from '@angular/core';\nimport { CommonModule } from '@angular/common';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatDialogModule } from '@angular/material/dialog';\nimport { MatFormFieldModule } from '@angular/material/form-field';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatInputModule } from '@angular/material/input';\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\nimport { MatTooltipModule } from '@angular/material/tooltip';\n\nimport { FsFileComponent } from './components/fs-file/fs-file.component';\nimport { FsFilePreviewsComponent } from './components/fs-file-previews/fs-file-previews.component';\nimport { FsFilePreviewComponent, } from './components/fs-file-preview/fs-file-preview.component';\nimport { FsFilePickerComponent, } from './components/fs-file-picker/fs-file-picker.component';\nimport { FsFilePreviewsBaseComponent, } from './components/fs-file-preview-base/fs-file-preview-base';\nimport { FsFileDragBaseComponent, } from './components/fs-file-drag-base/fs-file-drag-base';\nimport { FsFileImagePickerComponent } from './components/fs-file-image-picker/fs-file-image-picker.component';\nimport { FsFileImagePickerDialogComponent } from './components/fs-file-image-picker/fs-file-image-picker-dialog/fs-file-image-picker-dialog.component';\nimport { FsFileBouncingIconComponent } from './components/fs-file-bouncing-icon/fs-file-bouncing-icon.component';\nimport { FsFileDragoverMessageComponent } from './components/fs-file-dragover-message/fs-file-dragover-message.component';\n\nimport { FsFileHintDirective } from './directives/fs-file-hint.directive';\nimport { FsFileLabelDirective } from './directives/fs-file-label.directive';\nimport { FsFilePreviewActionDirective } from './directives/fs-file-preview-action.directive';\n\nimport { FS_FILE_MODULE_CONFIG } from './injectors';\nimport { FsFileModuleConfig } from './interfaces/module-config.interface';\n\nimport { FsLabelModule } from '@firestitch/label';\nimport { FsPromptModule } from '@firestitch/prompt';\nimport { FormsModule } from '@angular/forms';\nimport { FilePreviewMapFilePipe, PreviewImagePipe } from './pipes';\nimport { FsFilePickerSelectDirective } from './directives';\n\n\n@NgModule({\n  imports: [\n    FormsModule,\n    CommonModule,\n\n    MatIconModule,\n    MatTooltipModule,\n    MatProgressSpinnerModule,\n    MatButtonModule,\n    MatDialogModule,\n    MatFormFieldModule,\n    MatInputModule,\n\n    FsLabelModule,\n    FsPromptModule,\n  ],\n  exports: [\n    FsFileComponent,\n    FsFilePreviewsComponent,\n    FsFilePreviewComponent,\n    FsFilePreviewActionDirective,\n    FsFilePickerComponent,\n    FsFileImagePickerComponent,\n    FsFileHintDirective,\n    FsFileLabelDirective,\n    FsFilePickerSelectDirective,\n  ],\n  declarations: [\n    FsFileComponent,\n    FsFilePreviewsComponent,\n    FsFilePreviewComponent,\n    FsFilePreviewActionDirective,\n    FsFileDragBaseComponent,\n    FsFilePreviewsBaseComponent,\n    FsFilePickerComponent,\n    FsFileImagePickerComponent,\n    FsFileBouncingIconComponent,\n    FsFileDragoverMessageComponent,\n    FsFileImagePickerDialogComponent,\n    FsFileHintDirective,\n    FsFileLabelDirective,\n    PreviewImagePipe,\n    FilePreviewMapFilePipe,\n    FsFilePickerSelectDirective,\n  ],\n})\nexport class FsFileModule {\n  static forRoot(config: FsFileModuleConfig = null): ModuleWithProviders<FsFileModule> {\n    return {\n      ngModule: FsFileModule,\n      providers: [\n        {\n          provide: FS_FILE_MODULE_CONFIG,\n          useValue: config || {\n            allowDownload: true,\n            allowRemove: true,\n            dragoverMessage: true\n          }\n        }\n      ]\n    };\n  }\n}\n"]} |
@@ -5,3 +5,2 @@ /* | ||
export { FsFileModule } from './app/fs-file.module'; | ||
export { CordovaService } from './app/services/cordova.service'; | ||
export { FsFile } from './app/models/fs-file'; | ||
@@ -20,3 +19,4 @@ export { getCordovaCamera, getCordovaCapture, getCordovaResolveLocalFileSystemURL, hasCordovaCameraSupport, hasCordovaCaptureSupport, isImageType, ScaleExifImage } from './app/helpers'; | ||
export { FsFilePickerSelectDirective } from './app/directives'; | ||
export { FileProcessor } from './app/classes'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNoRSxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDOUMsT0FBTyxFQUNMLGdCQUFnQixFQUNoQixpQkFBaUIsRUFDakIsbUNBQW1DLEVBQ25DLHVCQUF1QixFQUN2Qix3QkFBd0IsRUFDeEIsV0FBVyxFQUNYLGNBQWMsRUFDZixNQUFNLGVBQWUsQ0FBQztBQUV2QixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFDN0UsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sOERBQThELENBQUM7QUFDdkcsT0FBTyxFQUFFLHNCQUFzQixHQUFHLE1BQU0sNERBQTRELENBQUM7QUFDckcsT0FBTyxFQUFFLHFCQUFxQixHQUFHLE1BQU0sMERBQTBELENBQUM7QUFDbEcsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sc0VBQXNFLENBQUM7QUFDbEgsT0FBTyxFQUFFLDJCQUEyQixHQUFHLE1BQU0sNERBQTRELENBQUM7QUFDMUcsT0FBTyxFQUFFLHVCQUF1QixHQUFHLE1BQU0sc0RBQXNELENBQUM7QUFDaEcsT0FBTyxFQUFFLDRCQUE0QixFQUFFLE1BQU0sbURBQW1ELENBQUM7QUFDakcsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0seUNBQXlDLENBQUM7QUFDOUUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sMENBQTBDLENBQUM7QUFFaEYsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFHL0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGVBQWUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgZnMtbWVudVxuICovXG5cbmV4cG9ydCB7IEZzRmlsZU1vZHVsZSB9IGZyb20gJy4vYXBwL2ZzLWZpbGUubW9kdWxlJztcbmV4cG9ydCB7IENvcmRvdmFTZXJ2aWNlIH0gZnJvbSAnLi9hcHAvc2VydmljZXMvY29yZG92YS5zZXJ2aWNlJztcbmV4cG9ydCB7IEZzRmlsZSB9IGZyb20gJy4vYXBwL21vZGVscy9mcy1maWxlJztcbmV4cG9ydCB7XG4gIGdldENvcmRvdmFDYW1lcmEsXG4gIGdldENvcmRvdmFDYXB0dXJlLFxuICBnZXRDb3Jkb3ZhUmVzb2x2ZUxvY2FsRmlsZVN5c3RlbVVSTCxcbiAgaGFzQ29yZG92YUNhbWVyYVN1cHBvcnQsXG4gIGhhc0NvcmRvdmFDYXB0dXJlU3VwcG9ydCxcbiAgaXNJbWFnZVR5cGUsXG4gIFNjYWxlRXhpZkltYWdlXG59IGZyb20gJy4vYXBwL2hlbHBlcnMnO1xuXG5leHBvcnQgeyBGc0ZpbGVDb21wb25lbnQgfSBmcm9tICcuL2FwcC9jb21wb25lbnRzL2ZzLWZpbGUvZnMtZmlsZS5jb21wb25lbnQnO1xuZXhwb3J0IHsgRnNGaWxlUHJldmlld3NDb21wb25lbnQgfSBmcm9tICcuL2FwcC9jb21wb25lbnRzL2ZzLWZpbGUtcHJldmlld3MvZnMtZmlsZS1wcmV2aWV3cy5jb21wb25lbnQnO1xuZXhwb3J0IHsgRnNGaWxlUHJldmlld0NvbXBvbmVudCwgfSBmcm9tICcuL2FwcC9jb21wb25lbnRzL2ZzLWZpbGUtcHJldmlldy9mcy1maWxlLXByZXZpZXcuY29tcG9uZW50JztcbmV4cG9ydCB7IEZzRmlsZVBpY2tlckNvbXBvbmVudCwgfSBmcm9tICcuL2FwcC9jb21wb25lbnRzL2ZzLWZpbGUtcGlja2VyL2ZzLWZpbGUtcGlja2VyLmNvbXBvbmVudCc7XG5leHBvcnQgeyBGc0ZpbGVJbWFnZVBpY2tlckNvbXBvbmVudCB9IGZyb20gJy4vYXBwL2NvbXBvbmVudHMvZnMtZmlsZS1pbWFnZS1waWNrZXIvZnMtZmlsZS1pbWFnZS1waWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCB7IEZzRmlsZVByZXZpZXdzQmFzZUNvbXBvbmVudCwgfSBmcm9tICcuL2FwcC9jb21wb25lbnRzL2ZzLWZpbGUtcHJldmlldy1iYXNlL2ZzLWZpbGUtcHJldmlldy1iYXNlJztcbmV4cG9ydCB7IEZzRmlsZURyYWdCYXNlQ29tcG9uZW50LCB9IGZyb20gJy4vYXBwL2NvbXBvbmVudHMvZnMtZmlsZS1kcmFnLWJhc2UvZnMtZmlsZS1kcmFnLWJhc2UnO1xuZXhwb3J0IHsgRnNGaWxlUHJldmlld0FjdGlvbkRpcmVjdGl2ZSB9IGZyb20gJy4vYXBwL2RpcmVjdGl2ZXMvZnMtZmlsZS1wcmV2aWV3LWFjdGlvbi5kaXJlY3RpdmUnO1xuZXhwb3J0IHsgRnNGaWxlSGludERpcmVjdGl2ZSB9IGZyb20gJy4vYXBwL2RpcmVjdGl2ZXMvZnMtZmlsZS1oaW50LmRpcmVjdGl2ZSc7XG5leHBvcnQgeyBGc0ZpbGVMYWJlbERpcmVjdGl2ZSB9IGZyb20gJy4vYXBwL2RpcmVjdGl2ZXMvZnMtZmlsZS1sYWJlbC5kaXJlY3RpdmUnO1xuXG5leHBvcnQgeyBGc0ZpbGVQaWNrZXJTZWxlY3REaXJlY3RpdmUgfSBmcm9tICcuL2FwcC9kaXJlY3RpdmVzJztcblxuZXhwb3J0IHsgRnNGaWxlUHJvY2Vzc0NvbmZpZyB9IGZyb20gJy4vYXBwL2ludGVyZmFjZXMnO1xuZXhwb3J0IHsgRmlsZVByb2Nlc3NvciB9IGZyb20gJy4vYXBwL2NsYXNzZXMnO1xuIl19 | ||
export { FS_FILE_CLICK_INTERCEPTOR } from './app/injectors'; | ||
export { FileProcessor, FileClickInterceptor, FileClickHandler } from './app/classes'; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUM5QyxPQUFPLEVBQ0wsZ0JBQWdCLEVBQ2hCLGlCQUFpQixFQUNqQixtQ0FBbUMsRUFDbkMsdUJBQXVCLEVBQ3ZCLHdCQUF3QixFQUN4QixXQUFXLEVBQ1gsY0FBYyxFQUNmLE1BQU0sZUFBZSxDQUFDO0FBRXZCLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw0Q0FBNEMsQ0FBQztBQUM3RSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw4REFBOEQsQ0FBQztBQUN2RyxPQUFPLEVBQUUsc0JBQXNCLEdBQUcsTUFBTSw0REFBNEQsQ0FBQztBQUNyRyxPQUFPLEVBQUUscUJBQXFCLEdBQUcsTUFBTSwwREFBMEQsQ0FBQztBQUNsRyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxzRUFBc0UsQ0FBQztBQUNsSCxPQUFPLEVBQUUsMkJBQTJCLEdBQUcsTUFBTSw0REFBNEQsQ0FBQztBQUMxRyxPQUFPLEVBQUUsdUJBQXVCLEdBQUcsTUFBTSxzREFBc0QsQ0FBQztBQUNoRyxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxtREFBbUQsQ0FBQztBQUNqRyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUM5RSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSwwQ0FBMEMsQ0FBQztBQUVoRixPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUcvRCxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUM1RCxPQUFPLEVBQUUsYUFBYSxFQUFFLG9CQUFvQixFQUFFLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBmcy1tZW51XG4gKi9cblxuZXhwb3J0IHsgRnNGaWxlTW9kdWxlIH0gZnJvbSAnLi9hcHAvZnMtZmlsZS5tb2R1bGUnO1xuZXhwb3J0IHsgRnNGaWxlIH0gZnJvbSAnLi9hcHAvbW9kZWxzL2ZzLWZpbGUnO1xuZXhwb3J0IHtcbiAgZ2V0Q29yZG92YUNhbWVyYSxcbiAgZ2V0Q29yZG92YUNhcHR1cmUsXG4gIGdldENvcmRvdmFSZXNvbHZlTG9jYWxGaWxlU3lzdGVtVVJMLFxuICBoYXNDb3Jkb3ZhQ2FtZXJhU3VwcG9ydCxcbiAgaGFzQ29yZG92YUNhcHR1cmVTdXBwb3J0LFxuICBpc0ltYWdlVHlwZSxcbiAgU2NhbGVFeGlmSW1hZ2Vcbn0gZnJvbSAnLi9hcHAvaGVscGVycyc7XG5cbmV4cG9ydCB7IEZzRmlsZUNvbXBvbmVudCB9IGZyb20gJy4vYXBwL2NvbXBvbmVudHMvZnMtZmlsZS9mcy1maWxlLmNvbXBvbmVudCc7XG5leHBvcnQgeyBGc0ZpbGVQcmV2aWV3c0NvbXBvbmVudCB9IGZyb20gJy4vYXBwL2NvbXBvbmVudHMvZnMtZmlsZS1wcmV2aWV3cy9mcy1maWxlLXByZXZpZXdzLmNvbXBvbmVudCc7XG5leHBvcnQgeyBGc0ZpbGVQcmV2aWV3Q29tcG9uZW50LCB9IGZyb20gJy4vYXBwL2NvbXBvbmVudHMvZnMtZmlsZS1wcmV2aWV3L2ZzLWZpbGUtcHJldmlldy5jb21wb25lbnQnO1xuZXhwb3J0IHsgRnNGaWxlUGlja2VyQ29tcG9uZW50LCB9IGZyb20gJy4vYXBwL2NvbXBvbmVudHMvZnMtZmlsZS1waWNrZXIvZnMtZmlsZS1waWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCB7IEZzRmlsZUltYWdlUGlja2VyQ29tcG9uZW50IH0gZnJvbSAnLi9hcHAvY29tcG9uZW50cy9mcy1maWxlLWltYWdlLXBpY2tlci9mcy1maWxlLWltYWdlLXBpY2tlci5jb21wb25lbnQnO1xuZXhwb3J0IHsgRnNGaWxlUHJldmlld3NCYXNlQ29tcG9uZW50LCB9IGZyb20gJy4vYXBwL2NvbXBvbmVudHMvZnMtZmlsZS1wcmV2aWV3LWJhc2UvZnMtZmlsZS1wcmV2aWV3LWJhc2UnO1xuZXhwb3J0IHsgRnNGaWxlRHJhZ0Jhc2VDb21wb25lbnQsIH0gZnJvbSAnLi9hcHAvY29tcG9uZW50cy9mcy1maWxlLWRyYWctYmFzZS9mcy1maWxlLWRyYWctYmFzZSc7XG5leHBvcnQgeyBGc0ZpbGVQcmV2aWV3QWN0aW9uRGlyZWN0aXZlIH0gZnJvbSAnLi9hcHAvZGlyZWN0aXZlcy9mcy1maWxlLXByZXZpZXctYWN0aW9uLmRpcmVjdGl2ZSc7XG5leHBvcnQgeyBGc0ZpbGVIaW50RGlyZWN0aXZlIH0gZnJvbSAnLi9hcHAvZGlyZWN0aXZlcy9mcy1maWxlLWhpbnQuZGlyZWN0aXZlJztcbmV4cG9ydCB7IEZzRmlsZUxhYmVsRGlyZWN0aXZlIH0gZnJvbSAnLi9hcHAvZGlyZWN0aXZlcy9mcy1maWxlLWxhYmVsLmRpcmVjdGl2ZSc7XG5cbmV4cG9ydCB7IEZzRmlsZVBpY2tlclNlbGVjdERpcmVjdGl2ZSB9IGZyb20gJy4vYXBwL2RpcmVjdGl2ZXMnO1xuXG5leHBvcnQgeyBGc0ZpbGVQcm9jZXNzQ29uZmlnIH0gZnJvbSAnLi9hcHAvaW50ZXJmYWNlcyc7XG5leHBvcnQgeyBGU19GSUxFX0NMSUNLX0lOVEVSQ0VQVE9SIH0gZnJvbSAnLi9hcHAvaW5qZWN0b3JzJztcbmV4cG9ydCB7IEZpbGVQcm9jZXNzb3IsIEZpbGVDbGlja0ludGVyY2VwdG9yLCBGaWxlQ2xpY2tIYW5kbGVyIH0gZnJvbSAnLi9hcHAvY2xhc3Nlcyc7XG4iXX0= |
{ | ||
"name": "@firestitch/file", | ||
"version": "12.11.3", | ||
"version": "12.12.0", | ||
"repository": { | ||
@@ -5,0 +5,0 @@ "type": "git", |
export { FsFileModule } from './app/fs-file.module'; | ||
export { CordovaService } from './app/services/cordova.service'; | ||
export { FsFile } from './app/models/fs-file'; | ||
@@ -17,2 +16,3 @@ export { getCordovaCamera, getCordovaCapture, getCordovaResolveLocalFileSystemURL, hasCordovaCameraSupport, hasCordovaCaptureSupport, isImageType, ScaleExifImage } from './app/helpers'; | ||
export { FsFileProcessConfig } from './app/interfaces'; | ||
export { FileProcessor } from './app/classes'; | ||
export { FS_FILE_CLICK_INTERCEPTOR } from './app/injectors'; | ||
export { FileProcessor, FileClickInterceptor, FileClickHandler } from './app/classes'; |
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
98
12
795242
6575