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