@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
JavaScript
/**
* @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"]}