UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

369 lines (368 loc) 22.3 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { EventEmitter } from '@angular/core'; import { AbstractInputDataView } from "./AbstractInputDataView"; import { Option } from '../../../decorator/Option.decorator'; import { EventUtils } from '../../../share/utils/EventUtils'; import { BEFORE_SELECT_EVENT, SELECT_EVENT } from '../../../share/CustomEventType'; /** * @abstract */ var AbstracFileSelector = /** @class */ (function (_super) { tslib_1.__extends(AbstracFileSelector, _super); function AbstracFileSelector(elementRef, needFocusService) { var _this = _super.call(this, elementRef, needFocusService) || this; _this.beforeSelectEvent = new EventEmitter(); _this.selectEvent = new EventEmitter(); _this.allowMultipleSelect = false; _this.files = []; _this.acceptStatus = true; _this.alertMessage = null; return _this; } /** * @return {?} */ AbstracFileSelector.prototype.ngOnInit = /** * @return {?} */ function () { _super.prototype.ngOnInit.call(this); // recall setData to do some function this.setData(this.data); }; /** * @param {?=} $event * @return {?} */ AbstracFileSelector.prototype.emitBeforeSelectEvent = /** * @param {?=} $event * @return {?} */ function ($event) { var /** @type {?} */ data = null; var /** @type {?} */ ev = EventUtils.newCustomEvent(BEFORE_SELECT_EVENT, this, data, $event); this.beforeSelectEvent.emit(ev); }; /** * @param {?=} $event * @return {?} */ AbstracFileSelector.prototype.emitSelectEvent = /** * @param {?=} $event * @return {?} */ function ($event) { var /** @type {?} */ data = null; var /** @type {?} */ ev = EventUtils.newCustomEvent(SELECT_EVENT, this, data, $event); this.selectEvent.emit(ev); }; /** * @param {?} files * @return {?} */ AbstracFileSelector.prototype.isAccept = /** * @param {?} files * @return {?} */ function (files) { try { for (var files_1 = tslib_1.__values(files), files_1_1 = files_1.next(); !files_1_1.done; files_1_1 = files_1.next()) { var file = files_1_1.value; if (this.fileTypes.indexOf(file.type) === -1) { this.alertMessage = "Error: Allow only file type '" + JSON.stringify(this.fileTypes) + "'"; this.acceptStatus = false; return false; } if (file.size > this.maxFilesize) { this.alertMessage = "Error: The maximun size for file upload is " + this.maxFilesize + " KB"; this.acceptStatus = false; return false; } } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (files_1_1 && !files_1_1.done && (_a = files_1.return)) _a.call(files_1); } finally { if (e_1) throw e_1.error; } } this.acceptStatus = true; this.alertMessage = "Done! Upload more?"; return true; var e_1, _a; }; /** * @return {?} */ AbstracFileSelector.prototype.setDefaultState = /** * @return {?} */ function () { this.alertMessage = null; this.acceptStatus = true; }; /** * @return {?} */ AbstracFileSelector.prototype.isAcceptStatus = /** * @return {?} */ function () { return this.acceptStatus; }; /** * @return {?} */ AbstracFileSelector.prototype.getAlertMessage = /** * @return {?} */ function () { return this.alertMessage; }; /** * @return {?} */ AbstracFileSelector.prototype.getFiles = /** * @return {?} */ function () { return this.files; }; /** * @return {?} */ AbstracFileSelector.prototype.getFile = /** * @return {?} */ function () { if (this.files !== undefined && this.files !== null && this.files.length > 0) { return this.files[0]; } return; }; /** * @return {?} */ AbstracFileSelector.prototype.getFilesCount = /** * @return {?} */ function () { return this.files.length; }; /** * @return {?} */ AbstracFileSelector.prototype.clear = /** * @return {?} */ function () { this.files = []; }; /** * @param {?} index * @return {?} */ AbstracFileSelector.prototype.removeFile = /** * @param {?} index * @return {?} */ function (index) { this.files.splice(index, 1); }; /** * @param {?} files * @param {?=} $event * @param {?=} fireEvent * @return {?} */ AbstracFileSelector.prototype.addFiles = /** * @param {?} files * @param {?=} $event * @param {?=} fireEvent * @return {?} */ function (files, $event, fireEvent) { var _this = this; if (fireEvent === null || fireEvent === undefined) { fireEvent = true; } EventUtils.handleBrowserEvent(this, 'beforeSelectEvent', $event, fireEvent, function ($event) { // doEvent if (_this.allowMultipleSelect) { try { for (var files_2 = tslib_1.__values(files), files_2_1 = files_2.next(); !files_2_1.done; files_2_1 = files_2.next()) { var file = files_2_1.value; _this.files.push(file); } } catch (e_2_1) { e_2 = { error: e_2_1 }; } finally { try { if (files_2_1 && !files_2_1.done && (_a = files_2.return)) _a.call(files_2); } finally { if (e_2) throw e_2.error; } } } else { _this.files[0] = files[0]; } var e_2, _a; }, function ($event) { // emitBeforeEvent // emitBeforeEvent _this.emitBeforeSelectEvent($event); }, function ($event, result) { // emitAfterEvent // emitAfterEvent _this.emitSelectEvent($event); }, function ($event) { // doPrevented }); }; /** * @return {?} */ AbstracFileSelector.prototype.getBeforeSelectEvent = /** * @return {?} */ function () { return this.beforeSelectEvent; }; /** * @param {?} event * @return {?} */ AbstracFileSelector.prototype.setBeforeSelectEvent = /** * @param {?} event * @return {?} */ function (event) { this.beforeSelectEvent = event; }; /** * @return {?} */ AbstracFileSelector.prototype.getSelectEvent = /** * @return {?} */ function () { return this.selectEvent; }; /** * @param {?} event * @return {?} */ AbstracFileSelector.prototype.setSelectEvent = /** * @param {?} event * @return {?} */ function (event) { this.selectEvent = event; }; /** * @return {?} */ AbstracFileSelector.prototype.getAllowMultipleSelect = /** * @return {?} */ function () { return this.allowMultipleSelect; }; /** * @param {?} allowMultipleSelect * @return {?} */ AbstracFileSelector.prototype.setAllowMultipleSelect = /** * @param {?} allowMultipleSelect * @return {?} */ function (allowMultipleSelect) { this.allowMultipleSelect = allowMultipleSelect; }; /** * @return {?} */ AbstracFileSelector.prototype.getMaxFilesize = /** * @return {?} */ function () { return this.maxFilesize; }; /** * @param {?} maxFilesize * @return {?} */ AbstracFileSelector.prototype.setMaxFilesize = /** * @param {?} maxFilesize * @return {?} */ function (maxFilesize) { this.maxFilesize = maxFilesize; }; /** * @return {?} */ AbstracFileSelector.prototype.getFileTypes = /** * @return {?} */ function () { return this.fileTypes; }; /** * @param {?} fileTypes * @return {?} */ AbstracFileSelector.prototype.setFileTypes = /** * @param {?} fileTypes * @return {?} */ function (fileTypes) { this.fileTypes = fileTypes; }; tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Number) ], AbstracFileSelector.prototype, "maxFilesize", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Boolean) ], AbstracFileSelector.prototype, "allowMultipleSelect", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", Array) ], AbstracFileSelector.prototype, "fileTypes", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", EventEmitter) ], AbstracFileSelector.prototype, "beforeSelectEvent", void 0); tslib_1.__decorate([ Option(), tslib_1.__metadata("design:type", EventEmitter) ], AbstracFileSelector.prototype, "selectEvent", void 0); return AbstracFileSelector; }(AbstractInputDataView)); export { AbstracFileSelector }; function AbstracFileSelector_tsickle_Closure_declarations() { /** @type {?} */ AbstracFileSelector.prototype.maxFilesize; /** @type {?} */ AbstracFileSelector.prototype.allowMultipleSelect; /** @type {?} */ AbstracFileSelector.prototype.fileTypes; /** @type {?} */ AbstracFileSelector.prototype.beforeSelectEvent; /** @type {?} */ AbstracFileSelector.prototype.selectEvent; /** @type {?} */ AbstracFileSelector.prototype.acceptStatus; /** @type {?} */ AbstracFileSelector.prototype.alertMessage; /** @type {?} */ AbstracFileSelector.prototype.files; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AbstracFileSelector.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/dataview/input/AbstracFileSelector.ts"],"names":[],"mappings":"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","sourcesContent":["import { OnInit, EventEmitter, ElementRef } from '@angular/core';\nimport { AbstractInputDataView } from \"./AbstractInputDataView\";\nimport { NeedFocusService } from \"../../../service/NeedFocusService.service\";\nimport { Option } from '../../../decorator/Option.decorator';\nimport { EventUtils } from '../../../share/utils/EventUtils';\nimport { BEFORE_SELECT_EVENT, SELECT_EVENT } from '../../../share/CustomEventType';\n\nexport abstract class AbstracFileSelector extends AbstractInputDataView implements OnInit {\n\n  @Option()\n  protected maxFilesize: number;\n  @Option()\n  protected allowMultipleSelect: boolean;\n  @Option()\n  protected fileTypes: string[];\n  @Option()\n  protected beforeSelectEvent: EventEmitter<any>;\n  @Option()\n  protected selectEvent: EventEmitter<any>;\n  private acceptStatus: boolean;\n  private alertMessage: string;\n  private files: File[];\n\n  constructor(elementRef: ElementRef, needFocusService: NeedFocusService) {\n    super(elementRef, needFocusService);\n\n    this.beforeSelectEvent = new EventEmitter();\n    this.selectEvent = new EventEmitter();\n    this.allowMultipleSelect = false;\n    this.files = [];\n    this.acceptStatus = true;\n    this.alertMessage = null;\n  }\n\n  public ngOnInit(): void {\n    super.ngOnInit();\n\n    // recall setData to do some function\n    this.setData(this.data);\n  }\n\n  private emitBeforeSelectEvent($event?: Event): void {\n    let data: any = null;\n    let ev = EventUtils.newCustomEvent(BEFORE_SELECT_EVENT, this, data, $event);\n\n    this.beforeSelectEvent.emit(ev);\n  }\n\n  private emitSelectEvent($event?: Event): void {\n    let data: any = null;\n    let ev = EventUtils.newCustomEvent(SELECT_EVENT, this, data, $event);\n\n    this.selectEvent.emit(ev);\n  }\n\n  protected isAccept(files: any[]): boolean {\n    for (let file of files) {\n      if (this.fileTypes.indexOf(file.type) === -1) {\n        this.alertMessage = \"Error: Allow only file type '\" + JSON.stringify(this.fileTypes) + \"'\";\n        this.acceptStatus = false;\n        return false;\n      }\n      if (file.size > this.maxFilesize) {\n        this.alertMessage = \"Error: The maximun size for file upload is \" + this.maxFilesize + \" KB\";\n        this.acceptStatus = false;\n        return false\n      }\n    }\n    this.acceptStatus = true;\n    this.alertMessage = \"Done! Upload more?\";\n    return true;\n  }\n\n  protected setDefaultState(): void {\n    this.alertMessage = null;\n    this.acceptStatus = true;\n  }\n\n  public isAcceptStatus(): boolean {\n    return this.acceptStatus;\n  }\n\n  public getAlertMessage(): string {\n    return this.alertMessage;\n  }\n\n  public getFiles(): File[] {\n    return this.files;\n  }\n\n  public getFile(): File {\n    if (this.files !== undefined && this.files !== null && this.files.length > 0) {\n      return this.files[0];\n    }\n    return;\n  }\n\n  public getFilesCount(): number {\n    return this.files.length;\n  }\n\n  public clear(): void {\n    this.files = [];\n  }\n\n  public removeFile(index: number): void {\n    this.files.splice(index, 1);\n  }\n\n  public addFiles(files: File[], $event?: Event, fireEvent?: boolean): void {\n    if (fireEvent === null || fireEvent === undefined) {\n      fireEvent = true;\n    }\n\n    EventUtils.handleBrowserEvent(this, 'beforeSelectEvent', $event, fireEvent, ($event: Event) => {\n      // doEvent\n      if (this.allowMultipleSelect) {\n        for (let file of files) {\n          this.files.push(file);\n        }\n      } else {\n        this.files[0] = files[0];\n      }\n    }, ($event: Event) => {\n      // emitBeforeEvent\n      this.emitBeforeSelectEvent($event);\n    }, ($event: Event, result: any) => {\n      // emitAfterEvent\n      this.emitSelectEvent($event);\n    }, ($event: Event) => {\n      // doPrevented\n    });\n  }\n\n  public getBeforeSelectEvent(): EventEmitter<any> {\n    return this.beforeSelectEvent;\n  }\n\n  public setBeforeSelectEvent(event: EventEmitter<any>): void {\n    this.beforeSelectEvent = event;\n  }\n\n  public getSelectEvent(): EventEmitter<any> {\n    return this.selectEvent;\n  }\n\n  public setSelectEvent(event: EventEmitter<any>): void {\n    this.selectEvent = event;\n  }\n\n  public getAllowMultipleSelect(): boolean {\n    return this.allowMultipleSelect;\n  }\n\n  public setAllowMultipleSelect(allowMultipleSelect: boolean): void {\n    this.allowMultipleSelect = allowMultipleSelect;\n  }\n\n  public getMaxFilesize(): number {\n    return this.maxFilesize;\n  }\n\n  public setMaxFilesize(maxFilesize: number): void {\n    this.maxFilesize = maxFilesize;\n  }\n\n  public getFileTypes(): string[] {\n    return this.fileTypes;\n  }\n\n  public setFileTypes(fileTypes: string[]): void {\n    this.fileTypes = fileTypes;\n  }\n}\n"]}