UNPKG

@asi-ngtools/lib

Version:

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

333 lines (332 loc) 22.3 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; 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'; var AsiFileChooserComponent = /** @class */ (function (_super) { tslib_1.__extends(AsiFileChooserComponent, _super); function AsiFileChooserComponent(fileService, renderer, elementRef) { var _this = _super.call(this) || this; _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 _this; } /** * @return {?} */ AsiFileChooserComponent.prototype.ngOnInit = /** * @return {?} */ function () { var _this = this; this.renderer.addClass(this.elementRef.nativeElement, 'label-' + this.labelPosition); if (this.fileSrc != null) { this.fileService.getFileAsBlob(this.fileSrc).subscribe(function (blob) { /** @type {?} */ var fileName = _this.fileName || _this.fileSrc.split('/').pop(); /** @type {?} */ var file = new Blob([blob], { type: blob.type }); file.name = fileName; _this.value = file; }); } }; /** * @return {?} */ AsiFileChooserComponent.prototype.ngOnChanges = /** * @return {?} */ function () { var _this = this; if (nh.isArray(this.accept)) { (/** @type {?} */ (this.accept)).forEach(function (accept) { _this.acceptAttribute += accept.extension + ', ' + accept.mimeType + ','; }); } else if (this.accept != null) { /** @type {?} */ var aAccept = (/** @type {?} */ (this.accept)); this.acceptAttribute = aAccept.extension + ', ' + aAccept.mimeType; } }; /** * @return {?} */ AsiFileChooserComponent.prototype.openFileInput = /** * @return {?} */ function () { this.fileInput.nativeElement.value = null; this.fileInput.nativeElement.click(); }; /** * @return {?} */ AsiFileChooserComponent.prototype.getFileUrl = /** * @return {?} */ function () { return this.fileService.getFileUrl(this.value); }; /** * @return {?} */ AsiFileChooserComponent.prototype.clean = /** * @return {?} */ function () { this.value = null; }; /** * @return {?} */ AsiFileChooserComponent.prototype.handleDragEnter = /** * @return {?} */ function () { this.dragging = true; }; /** * @return {?} */ AsiFileChooserComponent.prototype.handleDragLeave = /** * @return {?} */ function () { this.dragging = false; }; /** * @param {?} e * @return {?} */ AsiFileChooserComponent.prototype.handleDrop = /** * @param {?} e * @return {?} */ function (e) { e.preventDefault(); this.dragging = false; this.handleInputChange(e); }; /** * @return {?} */ AsiFileChooserComponent.prototype.handleFileLoad = /** * @return {?} */ function () { this.fileLoaded = true; }; /** * @param {?} event * @return {?} */ AsiFileChooserComponent.prototype.handleInputChange = /** * @param {?} event * @return {?} */ function (event) { /** @type {?} */ var 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 {?} */ AsiFileChooserComponent.prototype.downloadForIE = /** * @return {?} */ function () { if (navigator.msSaveBlob) { navigator.msSaveBlob(this.value, this.value.name); } }; /** * @param {?} mimeType * @return {?} */ AsiFileChooserComponent.prototype.isValideMimeType = /** * @param {?} mimeType * @return {?} */ function (mimeType) { if (!this.accept) { return true; } if (nh.isArray(this.accept)) { /** @type {?} */ var accepts = /** @type {?} */ (this.accept); try { for (var accepts_1 = tslib_1.__values(accepts), accepts_1_1 = accepts_1.next(); !accepts_1_1.done; accepts_1_1 = accepts_1.next()) { var accept = accepts_1_1.value; if (accept.mimeType === mimeType) { return true; } } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (accepts_1_1 && !accepts_1_1.done && (_a = accepts_1.return)) _a.call(accepts_1); } finally { if (e_1) throw e_1.error; } } } else { /** @type {?} */ var aAccept = (/** @type {?} */ (this.accept)); return aAccept.mimeType === mimeType; } return false; var e_1, _a; }; 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=\"fas fa-trash-alt\" size=\"lg\"></asi-fa-icon>\n </div>\n</div>\n", providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(function () { return AsiFileChooserComponent; }), multi: true } ] }] } ]; /** @nocollapse */ AsiFileChooserComponent.ctorParameters = function () { return [ { 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',] }] }; return AsiFileChooserComponent; }(DefaultControlValueAccessor)); export { AsiFileChooserComponent }; 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"]}