com.phloxui
Version:
PhloxUI Ng2+ Framework
369 lines (368 loc) • 22.3 kB
JavaScript
/**
* @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"]}