UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

335 lines (334 loc) 26.3 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import * as tslib_1 from "tslib"; import { AbstractInputDataView } from './AbstractInputDataView'; import { Option } from '../../../decorator/Option.decorator'; /** * @abstract */ var AbstractHasFormatterInputDataView = /** @class */ (function (_super) { tslib_1.__extends(AbstractHasFormatterInputDataView, _super); function AbstractHasFormatterInputDataView(elementRef, formatterFactory, needFocusService) { var _this = _super.call(this, elementRef, needFocusService) || this; _this.formatterFactory = formatterFactory; _this._formatterInited = false; return _this; } /** * @param {?} formatter * @param {?} data * @return {?} */ AbstractHasFormatterInputDataView.resolveFormattedData = /** * @param {?} formatter * @param {?} data * @return {?} */ function (formatter, data) { if (formatter !== null && typeof formatter !== 'undefined') { return formatter.format(data); } return data; }; /** * @param {?} formatter * @param {?} formattedData * @return {?} */ AbstractHasFormatterInputDataView.parseFormattedData = /** * @param {?} formatter * @param {?} formattedData * @return {?} */ function (formatter, formattedData) { if (formatter !== null && typeof formatter !== 'undefined') { return formatter.parse(formattedData); } return formattedData; }; Object.defineProperty(AbstractHasFormatterInputDataView.prototype, "formattedData", { get: /** * @return {?} */ function () { if (!this.formatterUsePropertyValue && this._formatterInited) { return this.getFormattedData(); } else { return this._formattedData; } }, set: /** * @param {?} formattedData * @return {?} */ function (formattedData) { this.setFormattedData(formattedData); }, enumerable: true, configurable: true }); /** * @return {?} */ AbstractHasFormatterInputDataView.prototype.ngOnInit = /** * @return {?} */ function () { _super.prototype.ngOnInit.call(this); // Initialize formatter. if (this.formatter !== null && this.formatter !== undefined) { // Call setFormatter() method to initialize. this.setFormatter(this.formatter); } else if (this.formatterName !== null && this.formatterName !== undefined) { // Call setFormatterName() method to initialize. this.setFormatterName(this.formatterName); } else { this.formatter = null; this.formatterName = null; } this._formatterInited = true; }; // Override to auto parse "any" object value to "string" data type. /** * @param {?} typeOfData * @param {?} inputVal * @return {?} */ AbstractHasFormatterInputDataView.prototype._castValueToData = /** * @param {?} typeOfData * @param {?} inputVal * @return {?} */ function (typeOfData, inputVal) { var /** @type {?} */ type = typeOfData; if (inputVal === null || inputVal === undefined) { // Return default behavior from super. return _super.prototype._castValueToData.call(this, typeOfData, inputVal); } if (type === null || type === undefined || type.toLowerCase() === AbstractInputDataView.TYPE_AUTO) { // Auto resolve "typeOfData" of inputVal. type = typeof inputVal; } if (type === 'string' && typeof inputVal !== 'string') { // If inputVal is not string but data type is string, try to parse it to string using formatter. if (this.formatter !== null && this.formatter !== undefined) { return this.formatter.format(inputVal); } } // Return default behavior from super. return _super.prototype._castValueToData.call(this, typeOfData, inputVal); }; /** * @param {?} data * @return {?} */ AbstractHasFormatterInputDataView.prototype.setData = /** * @param {?} data * @return {?} */ function (data) { _super.prototype.setData.call(this, data); this._formattedData = this.getFormattedData(); }; /** * @param {?} inputVal * @param {?=} $event * @param {?=} fireEvent * @return {?} */ AbstractHasFormatterInputDataView.prototype.setInputValue = /** * @param {?} inputVal * @param {?=} $event * @param {?=} fireEvent * @return {?} */ function (inputVal, $event, fireEvent) { _super.prototype.setInputValue.call(this, inputVal, $event, fireEvent); this._formattedData = this.getFormattedData(); }; /** * @return {?} */ AbstractHasFormatterInputDataView.prototype.isFormatterUsePropertyValue = /** * @return {?} */ function () { return this.formatterUsePropertyValue; }; /** * @return {?} */ AbstractHasFormatterInputDataView.prototype.getFormatterName = /** * @return {?} */ function () { return this.formatterName; }; /** * @param {?} formatterName * @return {?} */ AbstractHasFormatterInputDataView.prototype.setFormatterName = /** * @param {?} formatterName * @return {?} */ function (formatterName) { this.formatterName = formatterName; var /** @type {?} */ formatter = null; if (this.formatterFactory !== null && typeof this.formatterFactory !== 'undefined') { formatter = this.formatterFactory.createFormatter(formatterName); } this.formatter = formatter; this.setFormatterOptions(this.formatterOptions); }; /** * @return {?} */ AbstractHasFormatterInputDataView.prototype.getFormatterOptions = /** * @return {?} */ function () { return this.formatterOptions; }; /** * @param {?} options * @return {?} */ AbstractHasFormatterInputDataView.prototype.setFormatterOptions = /** * @param {?} options * @return {?} */ function (options) { this.formatterOptions = options; if (this.formatter !== null && typeof this.formatter !== 'undefined') { var /** @type {?} */ f = this.formatter; if (typeof f.setOptions === 'function') { f.setOptions(this.formatterOptions); } } this._formattedData = this.getFormattedData(); }; /** * @return {?} */ AbstractHasFormatterInputDataView.prototype.getFormatter = /** * @return {?} */ function () { return this.formatter; }; /** * @param {?} formatter * @return {?} */ AbstractHasFormatterInputDataView.prototype.setFormatter = /** * @param {?} formatter * @return {?} */ function (formatter) { this.formatter = formatter; if (this.formatter !== null && typeof this.formatter !== 'undefined') { this.formatterName = this.formatter.getName(); } else { this.formatterName = null; } this.setFormatterOptions(this.formatterOptions); }; /** * @param {?} options * @return {?} */ AbstractHasFormatterInputDataView.prototype.setOptions = /** * @param {?} options * @return {?} */ function (options) { _super.prototype.setOptions.call(this, options); if (this.formatter !== null && typeof this.formatter !== 'undefined') { this.setFormatter(this.formatter); } else if (this.formatterName !== null && typeof this.formatterName !== 'undefined') { this.setFormatterName(this.formatterName); } else { this.formatter = null; this.formatterName = null; } }; /** * @return {?} */ AbstractHasFormatterInputDataView.prototype.getFormattedData = /** * @return {?} */ function () { return AbstractHasFormatterInputDataView.resolveFormattedData(this.formatter, this.getInputValue()); }; /** * @param {?} formattedData * @param {?=} $event * @param {?=} fireEvent * @return {?} */ AbstractHasFormatterInputDataView.prototype.setFormattedData = /** * @param {?} formattedData * @param {?=} $event * @param {?=} fireEvent * @return {?} */ function (formattedData, $event, fireEvent) { this._formattedData = formattedData; var /** @type {?} */ parsed = AbstractHasFormatterInputDataView.parseFormattedData(this.formatter, formattedData); this.setInputValue(parsed, $event, fireEvent); }; /** * @return {?} */ AbstractHasFormatterInputDataView.prototype.refreshFormattedData = /** * @return {?} */ function () { this._formattedData = this.getFormattedData(); }; tslib_1.__decorate([ Option('formatter.name'), tslib_1.__metadata("design:type", String) ], AbstractHasFormatterInputDataView.prototype, "formatterName", void 0); tslib_1.__decorate([ Option('formatter.options'), tslib_1.__metadata("design:type", Object) ], AbstractHasFormatterInputDataView.prototype, "formatterOptions", void 0); tslib_1.__decorate([ Option('formatter.instance'), tslib_1.__metadata("design:type", Object) ], AbstractHasFormatterInputDataView.prototype, "formatter", void 0); tslib_1.__decorate([ Option('formatter.usePropertyValue'), tslib_1.__metadata("design:type", Boolean) ], AbstractHasFormatterInputDataView.prototype, "formatterUsePropertyValue", void 0); return AbstractHasFormatterInputDataView; }(AbstractInputDataView)); export { AbstractHasFormatterInputDataView }; function AbstractHasFormatterInputDataView_tsickle_Closure_declarations() { /** @type {?} */ AbstractHasFormatterInputDataView.prototype._formattedData; /** @type {?} */ AbstractHasFormatterInputDataView.prototype.formatterName; /** @type {?} */ AbstractHasFormatterInputDataView.prototype.formatterOptions; /** @type {?} */ AbstractHasFormatterInputDataView.prototype.formatter; /** @type {?} */ AbstractHasFormatterInputDataView.prototype.formatterUsePropertyValue; /** @type {?} */ AbstractHasFormatterInputDataView.prototype.formatterFactory; /** @type {?} */ AbstractHasFormatterInputDataView.prototype._formatterInited; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AbstractHasFormatterInputDataView.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/dataview/input/AbstractHasFormatterInputDataView.ts"],"names":[],"mappings":"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","sourcesContent":["import { OnInit, ElementRef } from '@angular/core';\nimport { AbstractInputDataView } from './AbstractInputDataView';\nimport { IHasFormatter } from '../../IHasFormatter';\nimport { IFormatter } from '../../../share/formatter/IFormatter';\nimport { Option } from '../../../decorator/Option.decorator';\nimport { FormatterFactory } from '../../../service/FormatterFactory.service';\nimport { NeedFocusService } from '../../../service/NeedFocusService.service';\n\nexport abstract class AbstractHasFormatterInputDataView extends AbstractInputDataView implements OnInit, IHasFormatter {\n\n  public static resolveFormattedData(formatter: IFormatter, data: any): any {\n    if (formatter !== null && typeof formatter !== 'undefined') {\n      return formatter.format(data);\n    }\n\n    return data;\n  }\n\n  public static parseFormattedData(formatter: IFormatter, formattedData: any): any {\n    if (formatter !== null && typeof formatter !== 'undefined') {\n      return formatter.parse(formattedData);\n    }\n\n    return formattedData;\n  }\n\n  public _formattedData: any;\n\n  @Option('formatter.name')\n  protected formatterName: string;\n  @Option('formatter.options')\n  protected formatterOptions: any;\n  @Option('formatter.instance')\n  protected formatter: IFormatter;\n  @Option('formatter.usePropertyValue')\n  protected formatterUsePropertyValue: boolean;\n\n  protected formatterFactory: FormatterFactory;\n  protected _formatterInited: boolean;\n\n  // Use this property accessor method to bind with html template.\n  public get formattedData(): any {\n    if (!this.formatterUsePropertyValue && this._formatterInited) {\n      return this.getFormattedData();\n    } else {\n      return this._formattedData;\n    }\n  }\n\n  public set formattedData(formattedData: any) {\n    this.setFormattedData(formattedData);\n  }\n\n  constructor(elementRef: ElementRef, formatterFactory: FormatterFactory, needFocusService: NeedFocusService) {\n    super(elementRef, needFocusService);\n\n    this.formatterFactory = formatterFactory;\n    this._formatterInited = false;\n  }\n\n  public ngOnInit(): void {\n    super.ngOnInit();\n\n    // Initialize formatter.\n    if (this.formatter !== null && this.formatter !== undefined) {\n      // Call setFormatter() method to initialize.\n      this.setFormatter(this.formatter);\n    } else if (this.formatterName !== null && this.formatterName !== undefined) {\n      // Call setFormatterName() method to initialize.\n      this.setFormatterName(this.formatterName);\n    } else {\n      this.formatter = null;\n      this.formatterName = null;\n    }\n    this._formatterInited = true;\n  }\n\n  // Override to auto parse \"any\" object value to \"string\" data type.\n  protected _castValueToData(typeOfData: string, inputVal: any): any {\n    let type: string = typeOfData;\n\n    if (inputVal === null || inputVal === undefined) {\n      // Return default behavior from super.\n      return super._castValueToData(typeOfData, inputVal);\n    }\n    if (type === null || type === undefined || type.toLowerCase() === AbstractInputDataView.TYPE_AUTO) {\n      // Auto resolve \"typeOfData\" of inputVal.\n      type = typeof inputVal;\n    }\n\n    if (type === 'string' && typeof inputVal !== 'string') {\n      // If inputVal is not string but data type is string, try to parse it to string using formatter.\n      if (this.formatter !== null && this.formatter !== undefined) {\n        return this.formatter.format(inputVal);\n      }\n    }\n\n    // Return default behavior from super.\n    return super._castValueToData(typeOfData, inputVal);\n  }\n\n  // Override setData() to auto resolve \"this._formattedData\".\n  public setData(data: any): void {\n    super.setData(data);\n\n    this._formattedData = this.getFormattedData();\n  }\n\n  // Override setInputValue() to auto resolve \"this._formattedData\".\n  public setInputValue(inputVal: any, $event?: Event, fireEvent?: boolean): void {\n    super.setInputValue(inputVal, $event, fireEvent);\n\n    this._formattedData = this.getFormattedData();\n  }\n\n  public isFormatterUsePropertyValue(): boolean {\n    return this.formatterUsePropertyValue;\n  }\n\n  public getFormatterName(): string {\n    return this.formatterName;\n  }\n\n  public setFormatterName(formatterName: string): void {\n    this.formatterName = formatterName;\n\n    let formatter: any = null;\n    if (this.formatterFactory !== null && typeof this.formatterFactory !== 'undefined') {\n      formatter = this.formatterFactory.createFormatter(formatterName);\n    }\n    this.formatter = formatter;\n\n    this.setFormatterOptions(this.formatterOptions);\n  }\n\n  public getFormatterOptions(): any {\n    return this.formatterOptions;\n  }\n\n  public setFormatterOptions(options: any): void {\n    this.formatterOptions = options;\n\n    if (this.formatter !== null && typeof this.formatter !== 'undefined') {\n      let f: any = this.formatter;\n      if (typeof f.setOptions === 'function') {\n        f.setOptions(this.formatterOptions);\n      }\n    }\n\n    this._formattedData = this.getFormattedData();\n  }\n\n  public getFormatter(): IFormatter {\n    return this.formatter;\n  }\n\n  public setFormatter(formatter: IFormatter): void {\n    this.formatter = formatter;\n\n    if (this.formatter !== null && typeof this.formatter !== 'undefined') {\n      this.formatterName = this.formatter.getName();\n    } else {\n      this.formatterName = null;\n    }\n\n    this.setFormatterOptions(this.formatterOptions);\n  }\n\n  public setOptions(options: any): void {\n    super.setOptions(options);\n\n    if (this.formatter !== null && typeof this.formatter !== 'undefined') {\n      this.setFormatter(this.formatter);\n    } else if (this.formatterName !== null && typeof this.formatterName !== 'undefined') {\n      this.setFormatterName(this.formatterName);\n    } else {\n      this.formatter = null;\n      this.formatterName = null;\n    }\n  }\n\n  public getFormattedData(): any {\n    return AbstractHasFormatterInputDataView.resolveFormattedData(this.formatter, this.getInputValue());\n  }\n\n  public setFormattedData(formattedData: any, $event?: Event, fireEvent?: boolean): void {\n    this._formattedData = formattedData;\n\n    let parsed: any = AbstractHasFormatterInputDataView.parseFormattedData(this.formatter, formattedData);\n\n    this.setInputValue(parsed, $event, fireEvent);\n  }\n\n  public refreshFormattedData(): void {\n    this._formattedData = this.getFormattedData();\n  }\n}\n"]}