import { Directive, ElementRef, EventEmitter, Input, Output, HostListener, Inject, OnChanges } from '@angular/core'; import { Ng2UploaderService } from '../services/ng2-uploader'; import { INg2UploaderOptions, Ng2UploaderOptions, UploadedFile, UploadRejected } from '../classes'; @Directive({ selector: '[ngFileSelect]' }) export class NgFileSelectDirective implements OnChanges { @Input() options: Ng2UploaderOptions; @Input() events: EventEmitter; @Output() onUpload: EventEmitter = new EventEmitter(); @Output() onPreviewData: EventEmitter = new EventEmitter(); @Output() onUploadRejected: EventEmitter = new EventEmitter(); @Output() beforeUpload: EventEmitter = new EventEmitter(); files: any[] = []; constructor( @Inject(ElementRef) public el: ElementRef, @Inject(Ng2UploaderService) public uploader: Ng2UploaderService) { } ngOnChanges() { if (!this.options) { return; } this.uploader.setOptions(new Ng2UploaderOptions(this.options)); this.uploader._emitter.subscribe((data: any) => { this.onUpload.emit(data); if (data.done) { this.files = this.files.filter(f => f.name !== data.originalName); } }); this.uploader._previewEmitter.subscribe((data: any) => { this.onPreviewData.emit(data); }); this.uploader._beforeEmitter.subscribe((uploadingFile: UploadedFile) => { this.beforeUpload.emit(uploadingFile) }); if (this.events instanceof EventEmitter) { this.events.subscribe((data: string) => { if (data === 'startUpload') { this.uploader.uploadFilesInQueue(); } }); } } @HostListener('change') onChange(): void { this.files = this.el.nativeElement.files; if (!this.files) { console.log('return'); return; } if (this.options.filterExtensions && this.options.allowedExtensions) { this.files = this.files.filter(f => { if (this.options.allowedExtensions.indexOf(f.type) !== -1) { return true; } let ext: string = f.name.split('.').pop(); if (this.options.allowedExtensions.indexOf(ext) !== -1 ) { return true; } this.onUploadRejected.emit({file: f, reason: UploadRejected.EXTENSION_NOT_ALLOWED}); return false; }); } if (this.files.length) { this.uploader.addFilesToQueue(this.files); } } }