UNPKG

@asi-ngtools/lib

Version:

This project is a little components library, simple to use, which will help you to simplify your project.

281 lines (280 loc) 20.1 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { DefaultControlValueAccessor } from './../common/default-control-value-accessor'; import { Component, Input, EventEmitter, Output, forwardRef, ViewChild, ElementRef, Renderer2 } from '@angular/core'; import { AsiFileService } from './../../services/asi-file.service'; import * as nh from '../../native-helper'; export class AsiFileChooserComponent extends DefaultControlValueAccessor { /** * @param {?} fileService * @param {?} renderer * @param {?} elementRef */ constructor(fileService, renderer, elementRef) { super(); this.fileService = fileService; this.renderer = renderer; this.elementRef = elementRef; /** * Label position */ this.labelPosition = 'top'; /** * Preload filechooser with an url */ this.fileSrc = null; /** * Allow you to force the name of the file */ this.fileName = null; /** * By default we dont block the file is the user select a wrong type */ this.blockImport = false; /** * Icon to display */ this.icon = 'fa fa-paperclip'; /** * Event emitted when an error occured with the selected file */ this.onError = new EventEmitter(); this.acceptAttribute = ''; this.dragging = false; this.loaded = false; this.fileLoaded = false; } /** * @return {?} */ ngOnInit() { this.renderer.addClass(this.elementRef.nativeElement, 'label-' + this.labelPosition); if (this.fileSrc != null) { this.fileService.getFileAsBlob(this.fileSrc).subscribe(blob => { /** @type {?} */ const fileName = this.fileName || this.fileSrc.split('/').pop(); /** @type {?} */ const file = new Blob([blob], { type: blob.type }); file.name = fileName; this.value = file; }); } } /** * @return {?} */ ngOnChanges() { if (nh.isArray(this.accept)) { (/** @type {?} */ (this.accept)).forEach((accept) => { this.acceptAttribute += accept.extension + ', ' + accept.mimeType + ','; }); } else if (this.accept != null) { /** @type {?} */ const aAccept = (/** @type {?} */ (this.accept)); this.acceptAttribute = aAccept.extension + ', ' + aAccept.mimeType; } } /** * @return {?} */ openFileInput() { this.fileInput.nativeElement.value = null; this.fileInput.nativeElement.click(); } /** * @return {?} */ getFileUrl() { return this.fileService.getFileUrl(this.value); } /** * @return {?} */ clean() { this.value = null; } /** * @return {?} */ handleDragEnter() { this.dragging = true; } /** * @return {?} */ handleDragLeave() { this.dragging = false; } /** * @param {?} e * @return {?} */ handleDrop(e) { e.preventDefault(); this.dragging = false; this.handleInputChange(e); } /** * @return {?} */ handleFileLoad() { this.fileLoaded = true; } /** * @param {?} event * @return {?} */ handleInputChange(event) { /** @type {?} */ const file = event.dataTransfer ? event.dataTransfer.files[0] : event.target.files[0]; if (this.blockImport && !this.isValideMimeType(file.type)) { this.onError.emit({ error: 'FORMAT', file: file }); return; } this.loaded = false; this.value = file; } /** * @return {?} */ downloadForIE() { if (navigator.msSaveBlob) { navigator.msSaveBlob(this.value, this.value.name); } } /** * @param {?} mimeType * @return {?} */ isValideMimeType(mimeType) { if (!this.accept) { return true; } if (nh.isArray(this.accept)) { /** @type {?} */ const accepts = /** @type {?} */ (this.accept); for (let accept of accepts) { if (accept.mimeType === mimeType) { return true; } } } else { /** @type {?} */ const aAccept = (/** @type {?} */ (this.accept)); return aAccept.mimeType === mimeType; } return false; } } AsiFileChooserComponent.decorators = [ { type: Component, args: [{ selector: 'asi-file-chooser', host: { 'class': 'asi-component asi-file-chooser' }, template: "<label class=\"input-label\" *ngIf=\"label != null\">{{label | translate}}</label>\n<div class=\"asi-file-chooser-container\">\n <label ondragover=\"return false;\" [class.loaded]=\"loaded\" (dragenter)=\"handleDragEnter()\" (dragleave)=\"handleDragLeave()\"\n (drop)=\"handleDrop($event)\">\n <asi-button size=\"small\" class=\"asi-focus-error\" (click)=\"openFileInput()\">\n <asi-fa-icon [icon]=\"icon\" size=\"2x\"></asi-fa-icon>\n </asi-button>\n <input #fileInput type=\"file\" [attr.id]=\"id\" [attr.name]=\"name\" [disabled]=\"disabled\" name=\"file\" [accept]=\"acceptAttribute\" (change)=\"handleInputChange($event)\" />\n </label>\n <div class=\"file-link\" *ngIf=\"value != null\">\n <a [title]=\"value.name\" (click)=\"downloadForIE()\" [innerHTML]=\"value.name\" [download]=\"value.name\" [href]=\"getFileUrl()\" target=\"_empty\"></a>\n <asi-fa-icon (onClick)=\"clean()\" icon=\"fa fa-trash-o\" size=\"lg\"></asi-fa-icon>\n </div>\n</div>\n", providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => AsiFileChooserComponent), multi: true } ] }] } ]; /** @nocollapse */ AsiFileChooserComponent.ctorParameters = () => [ { type: AsiFileService }, { type: Renderer2 }, { type: ElementRef } ]; AsiFileChooserComponent.propDecorators = { id: [{ type: Input }], name: [{ type: Input }], label: [{ type: Input }], labelPosition: [{ type: Input }], fileSrc: [{ type: Input }], fileName: [{ type: Input }], accept: [{ type: Input }], blockImport: [{ type: Input }], icon: [{ type: Input }], onError: [{ type: Output }], fileInput: [{ type: ViewChild, args: ['fileInput',] }] }; if (false) { /** * html id * @type {?} */ AsiFileChooserComponent.prototype.id; /** * html name * @type {?} */ AsiFileChooserComponent.prototype.name; /** * Label to display (is translated) * @type {?} */ AsiFileChooserComponent.prototype.label; /** * Label position * @type {?} */ AsiFileChooserComponent.prototype.labelPosition; /** * Preload filechooser with an url * @type {?} */ AsiFileChooserComponent.prototype.fileSrc; /** * Allow you to force the name of the file * @type {?} */ AsiFileChooserComponent.prototype.fileName; /** * Liste of mimetype : "application/pdf" used to display a correct selection view * @type {?} */ AsiFileChooserComponent.prototype.accept; /** * By default we dont block the file is the user select a wrong type * @type {?} */ AsiFileChooserComponent.prototype.blockImport; /** * Icon to display * @type {?} */ AsiFileChooserComponent.prototype.icon; /** * Event emitted when an error occured with the selected file * @type {?} */ AsiFileChooserComponent.prototype.onError; /** @type {?} */ AsiFileChooserComponent.prototype.acceptAttribute; /** @type {?} */ AsiFileChooserComponent.prototype.fileInput; /** @type {?} */ AsiFileChooserComponent.prototype.dragging; /** @type {?} */ AsiFileChooserComponent.prototype.loaded; /** @type {?} */ AsiFileChooserComponent.prototype.fileLoaded; /** @type {?} */ AsiFileChooserComponent.prototype.file; /** @type {?} */ AsiFileChooserComponent.prototype.fileService; /** @type {?} */ AsiFileChooserComponent.prototype.renderer; /** @type {?} */ AsiFileChooserComponent.prototype.elementRef; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asi-file-chooser.component.js","sourceRoot":"ng://@asi-ngtools/lib/","sources":["lib/components/asi-file-chooser/asi-file-chooser.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AsiMimeType } from './asi-file-chooser-constants';\nimport { SafeResourceUrl } from '@angular/platform-browser';\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { DefaultControlValueAccessor } from './../common/default-control-value-accessor';\nimport {\n  Component, Input, EventEmitter, Output, forwardRef,\n  OnChanges, ViewChild, OnInit, ElementRef, Renderer2\n} from '@angular/core';\nimport { AsiFileService } from './../../services/asi-file.service';\n\nimport * as nh from '../../native-helper';\n\n@Component({\n  selector: 'asi-file-chooser',\n  host: { 'class': 'asi-component asi-file-chooser' },\n  templateUrl: './asi-file-chooser.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => AsiFileChooserComponent),\n      multi: true\n    }\n  ]\n})\nexport class AsiFileChooserComponent extends DefaultControlValueAccessor implements OnChanges, OnInit {\n\n  /** html id */\n  @Input() id: string;\n  /** html name */\n  @Input() name: string;\n   /** Label to display (is translated) */\n  @Input() label: string;\n  /** Label position */\n  @Input() labelPosition: 'top' | 'left' | 'right' | 'bottom' | 'bottom-center' | 'top-center' = 'top';\n  /** Preload filechooser with an url */\n  @Input() fileSrc: string = null;\n  /** Allow you to force the name of the file */\n  @Input() fileName: string = null;\n  /** Liste of mimetype : \"application/pdf\" used to display a correct selection view */\n  @Input() accept: Array<AsiMimeType> | AsiMimeType;\n  /** By default we dont block the file is the user select a wrong type */\n  @Input() blockImport = false;\n  /** Icon to display */\n  @Input() icon = 'fa fa-paperclip';\n\n  /** Event emitted when an error occured with the selected file */\n  @Output() onError = new EventEmitter<any>();\n\n  acceptAttribute = '';\n\n  @ViewChild('fileInput') fileInput: any;\n\n  dragging = false;\n  loaded = false;\n  fileLoaded = false;\n\n  file: File;\n\n  constructor(private fileService: AsiFileService,\n    private renderer: Renderer2,\n    private elementRef: ElementRef) {\n    super();\n  }\n\n  ngOnInit() {\n    this.renderer.addClass(this.elementRef.nativeElement, 'label-' + this.labelPosition);\n    if (this.fileSrc != null) {\n      this.fileService.getFileAsBlob(this.fileSrc).subscribe(blob => {\n        const fileName = this.fileName || this.fileSrc.split('/').pop();\n        const file: any = new Blob([blob], { type: blob.type });\n        file.name = fileName;\n        this.value = file;\n      });\n    }\n  }\n\n  ngOnChanges() {\n    if (nh.isArray(this.accept)) {\n      (<Array<AsiMimeType>>this.accept).forEach((accept) => {\n        this.acceptAttribute += accept.extension + ', ' + accept.mimeType + ',';\n      });\n    } else if (this.accept != null) {\n      const aAccept: AsiMimeType = (<AsiMimeType>this.accept);\n      this.acceptAttribute = aAccept.extension + ', ' + aAccept.mimeType;\n    }\n  }\n\n  openFileInput() {\n    this.fileInput.nativeElement.value = null;\n    this.fileInput.nativeElement.click();\n  }\n\n  getFileUrl(): SafeResourceUrl {\n    return this.fileService.getFileUrl(this.value);\n  }\n\n  clean(): void {\n    this.value = null;\n  }\n\n  handleDragEnter() {\n    this.dragging = true;\n  }\n\n  handleDragLeave() {\n    this.dragging = false;\n  }\n\n  handleDrop(e: Event) {\n    e.preventDefault();\n    this.dragging = false;\n    this.handleInputChange(e);\n  }\n\n  handleFileLoad() {\n    this.fileLoaded = true;\n  }\n\n  handleInputChange(event: any) {\n    const file = event.dataTransfer ? event.dataTransfer.files[0] : event.target.files[0];\n\n    if (this.blockImport && !this.isValideMimeType(file.type)) {\n      this.onError.emit({\n        error: 'FORMAT',\n        file: file\n      });\n      return;\n    }\n    this.loaded = false;\n    this.value = file;\n  }\n\n  downloadForIE() {\n    if (navigator.msSaveBlob) {\n      navigator.msSaveBlob(this.value, this.value.name);\n    }\n  }\n\n  private isValideMimeType(mimeType: string): boolean {\n    if (!this.accept) {\n      return true;\n    }\n    if (nh.isArray(this.accept)) {\n      const accepts = <Array<AsiMimeType>>this.accept;\n      for (let accept of accepts) {\n        if (accept.mimeType === mimeType) {\n          return true;\n        }\n      }\n    } else {\n      const aAccept: AsiMimeType = (<AsiMimeType>this.accept);\n      return aAccept.mimeType === mimeType\n    }\n    return false;\n  }\n}\n"]}