com.phloxui
Version:
PhloxUI Ng2+ Framework
497 lines (496 loc) • 34.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, ElementRef, EventEmitter, Output, Input } from '@angular/core';
import { AbstractDataView } from './AbstractDataView';
import { PhloxDataChartModel } from '.././model/models';
import { Option } from '../../decorator/decorators';
import { BEFORE_CHART_SELECT_EVENT, CHART_SELECT_EVENT, CHART_ERROR, CHART_READY } from '../../share/CustomEventType';
import { EventUtils } from '../../share/shares';
var /** @type {?} */ TYPE_NAME = "phxChart";
var PhloxChart = /** @class */ (function (_super) {
tslib_1.__extends(PhloxChart, _super);
function PhloxChart(elementRef) {
var _this = _super.call(this, elementRef) || this;
_this.chartReadyEvent = new EventEmitter(); // before event is not require
_this.chartErrorEvent = new EventEmitter(); // before event is not require
_this.beforeChartSelectEvent = new EventEmitter();
_this.chartSelectEvent = new EventEmitter();
_this.beforeChartMouseOverEvent = new EventEmitter();
_this.chartMouseOverEvent = new EventEmitter();
_this.beforeChartMouseOutEvent = new EventEmitter();
_this.chartMouseOutEvent = new EventEmitter();
return _this;
}
/**
* @return {?}
*/
PhloxChart.prototype.ngOnInit = /**
* @return {?}
*/
function () {
_super.prototype.ngOnInit.call(this);
if (this.chartType !== undefined && this.chartType !== null &&
this.dataTable !== undefined && this.dataTable !== null &&
this.cols !== undefined && this.cols !== null &&
this.rows !== undefined && this.rows !== null) {
this.model = new PhloxDataChartModel(this.chartType, this.dataTable, this.formatters, this.options, this.title, this.subtitle, this.width, this.height, this.cols, this.rows);
}
};
/**
* @return {?}
*/
PhloxChart.prototype.isSelfDataDirty = /**
* @return {?}
*/
function () {
return false;
};
/**
* @param {?} data
* @return {?}
*/
PhloxChart.prototype.selfSaveData = /**
* @param {?} data
* @return {?}
*/
function (data) {
};
/**
* @return {?}
*/
PhloxChart.prototype.selfResetData = /**
* @return {?}
*/
function () {
};
/**
* @return {?}
*/
PhloxChart.prototype.doPreload = /**
* @return {?}
*/
function () { return new Promise(function (resolve, reject) { resolve(null); }); };
/**
* @return {?}
*/
PhloxChart.prototype.doLoaded = /**
* @return {?}
*/
function () {
};
/**
* @param {?} dataTable
* @return {?}
*/
PhloxChart.prototype.reloadData = /**
* @param {?} dataTable
* @return {?}
*/
function (dataTable) {
this.model.dataTable = dataTable;
this.model = JSON.parse(JSON.stringify(this.model));
};
/**
* @param {?} event
* @param {?=} fireEvent
* @return {?}
*/
PhloxChart.prototype.onChartSelectEvent = /**
* @param {?} event
* @param {?=} fireEvent
* @return {?}
*/
function (event, fireEvent) {
var _this = this;
if (fireEvent === null || fireEvent === undefined) {
fireEvent = true;
}
EventUtils.handleBrowserEvent(this, 'beforeChartSelectEvent', event, fireEvent, function ($event) {
// doEvent
}, function ($event) {
// emitBeforeEvent
// emitBeforeEvent
_this.emitBeforeChartSelectEvent($event);
}, function ($event, result) {
// emitAfterEvent
// emitAfterEvent
_this.emitChartSelectEvent($event);
}, function ($event) {
// doPrevented
});
};
/**
* @param {?} $event
* @return {?}
*/
PhloxChart.prototype.emitBeforeChartSelectEvent = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
var /** @type {?} */ eventData = null;
// emit event
var /** @type {?} */ data = eventData;
var /** @type {?} */ ev = EventUtils.newCustomEvent(BEFORE_CHART_SELECT_EVENT, this, data, $event);
if (this.beforeChartSelectEvent !== null && this.beforeChartSelectEvent !== undefined) {
this.beforeChartSelectEvent.emit(ev);
}
};
/**
* @param {?} $event
* @return {?}
*/
PhloxChart.prototype.emitChartSelectEvent = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
var /** @type {?} */ eventData = $event;
// emit event
var /** @type {?} */ data = eventData;
var /** @type {?} */ ev = EventUtils.newCustomEvent(CHART_SELECT_EVENT, this, data, $event);
if (this.chartSelectEvent !== null && this.chartSelectEvent !== undefined) {
this.chartSelectEvent.emit(ev);
}
};
/**
* @param {?} $event
* @return {?}
*/
PhloxChart.prototype.emitChartReadyEvent = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
var /** @type {?} */ eventData = null;
// emit event
var /** @type {?} */ data = eventData;
var /** @type {?} */ ev = EventUtils.newCustomEvent(CHART_READY, this, data, event);
if (this.chartReadyEvent !== null && this.chartReadyEvent !== undefined) {
this.chartReadyEvent.emit(ev);
}
};
/**
* @param {?} $event
* @return {?}
*/
PhloxChart.prototype.emitChartErrorEvent = /**
* @param {?} $event
* @return {?}
*/
function ($event) {
var /** @type {?} */ eventData = null;
// emit event
var /** @type {?} */ data = eventData;
var /** @type {?} */ ev = EventUtils.newCustomEvent(CHART_ERROR, this, data, event);
if (this.chartErrorEvent !== null && this.chartErrorEvent !== undefined) {
this.chartErrorEvent.emit(ev);
}
};
/**
* @param {?} event
* @param {?=} fireEvent
* @return {?}
*/
PhloxChart.prototype.onChartReadyEvent = /**
* @param {?} event
* @param {?=} fireEvent
* @return {?}
*/
function (event, fireEvent) {
if (fireEvent === null || fireEvent === undefined) {
fireEvent = true;
}
this.emitChartReadyEvent(event);
};
/**
* @param {?} event
* @param {?=} fireEvent
* @return {?}
*/
PhloxChart.prototype.onChartErrorEvent = /**
* @param {?} event
* @param {?=} fireEvent
* @return {?}
*/
function (event, fireEvent) {
if (fireEvent === null || fireEvent === undefined) {
fireEvent = true;
}
this.emitChartErrorEvent(event);
};
/**
* @return {?}
*/
PhloxChart.prototype.getchartReadyEvent = /**
* @return {?}
*/
function () {
return this.chartReadyEvent;
};
/**
* @return {?}
*/
PhloxChart.prototype.getchartErrorEvent = /**
* @return {?}
*/
function () {
return this.chartErrorEvent;
};
/**
* @return {?}
*/
PhloxChart.prototype.getchartSelectEvent = /**
* @return {?}
*/
function () {
return this.chartSelectEvent;
};
/**
* @return {?}
*/
PhloxChart.prototype.getchartMouseOverEvent = /**
* @return {?}
*/
function () {
return this.chartMouseOverEvent;
};
/**
* @return {?}
*/
PhloxChart.prototype.getchartMouseOutEvent = /**
* @return {?}
*/
function () {
return this.chartMouseOutEvent;
};
/**
* @param {?} options
* @return {?}
*/
PhloxChart.prototype.setOptions = /**
* @param {?} options
* @return {?}
*/
function (options) {
this.model.options = options;
this.reloadData(this.model.dataTable);
};
/**
* @param {?} chartType
* @return {?}
*/
PhloxChart.prototype.setChartType = /**
* @param {?} chartType
* @return {?}
*/
function (chartType) {
this.model.chartType = chartType;
this.reloadData(this.model.dataTable);
};
/**
* @param {?} title
* @return {?}
*/
PhloxChart.prototype.setTitle = /**
* @param {?} title
* @return {?}
*/
function (title) {
this.model.title = title;
this.reloadData(this.model.dataTable);
};
/**
* @param {?} subtitle
* @return {?}
*/
PhloxChart.prototype.setSubtitle = /**
* @param {?} subtitle
* @return {?}
*/
function (subtitle) {
this.model.subtitle = subtitle;
this.reloadData(this.model.dataTable);
};
/**
* @return {?}
*/
PhloxChart.prototype.getModel = /**
* @return {?}
*/
function () {
return this.model;
};
/**
* @param {?} model
* @return {?}
*/
PhloxChart.prototype.setModel = /**
* @param {?} model
* @return {?}
*/
function (model) {
this.model = model;
};
PhloxChart.TYPE_NAME = TYPE_NAME;
PhloxChart.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: "<div class=\"phxChart\">\n <google-chart [data]=\"getModel()\" (chartReady)=\"onChartReadyEvent($event)\" (chartError)=\"onChartErrorEvent($event)\" (chartSelect)=\"onChartSelectEvent($event)\"></google-chart>\n</div> "
},] },
];
/** @nocollapse */
PhloxChart.ctorParameters = function () { return [
{ type: ElementRef, },
]; };
PhloxChart.propDecorators = {
"chartReadyEvent": [{ type: Output, args: ['phxChartReady',] },],
"chartErrorEvent": [{ type: Output, args: ['phxChartError',] },],
"beforeChartSelectEvent": [{ type: Output, args: ['phxBeforeChartSelect',] },],
"chartSelectEvent": [{ type: Output, args: ['phxChartSelect',] },],
"beforeChartMouseOverEvent": [{ type: Output, args: ['phxBeforeChartMouseOver',] },],
"chartMouseOverEvent": [{ type: Output, args: ['phxChartMouseOver',] },],
"beforeChartMouseOutEvent": [{ type: Output, args: ['phxBeforeChartMouseOut',] },],
"chartMouseOutEvent": [{ type: Output, args: ['phxChartMouseOut',] },],
"dataTable": [{ type: Input },],
"chartType": [{ type: Input },],
"formatters": [{ type: Input },],
"title": [{ type: Input },],
"subtitle": [{ type: Input },],
"options": [{ type: Input },],
"width": [{ type: Input },],
"height": [{ type: Input },],
"cols": [{ type: Input },],
"rows": [{ type: Input },],
};
tslib_1.__decorate([
Option('chartReady'),
tslib_1.__metadata("design:type", EventEmitter)
], PhloxChart.prototype, "chartReadyEvent", void 0);
tslib_1.__decorate([
Option('chartError'),
tslib_1.__metadata("design:type", EventEmitter)
], PhloxChart.prototype, "chartErrorEvent", void 0);
tslib_1.__decorate([
Option('beforeChartSelect'),
tslib_1.__metadata("design:type", EventEmitter)
], PhloxChart.prototype, "beforeChartSelectEvent", void 0);
tslib_1.__decorate([
Option('chartSelect'),
tslib_1.__metadata("design:type", EventEmitter)
], PhloxChart.prototype, "chartSelectEvent", void 0);
tslib_1.__decorate([
Option('beforeChartMouseOver'),
tslib_1.__metadata("design:type", EventEmitter)
], PhloxChart.prototype, "beforeChartMouseOverEvent", void 0);
tslib_1.__decorate([
Option('chartMouseOver'),
tslib_1.__metadata("design:type", EventEmitter)
], PhloxChart.prototype, "chartMouseOverEvent", void 0);
tslib_1.__decorate([
Option('beforeChartMouseOut'),
tslib_1.__metadata("design:type", EventEmitter)
], PhloxChart.prototype, "beforeChartMouseOutEvent", void 0);
tslib_1.__decorate([
Option('chartMouseOut'),
tslib_1.__metadata("design:type", EventEmitter)
], PhloxChart.prototype, "chartMouseOutEvent", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Array)
], PhloxChart.prototype, "dataTable", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], PhloxChart.prototype, "chartType", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Array)
], PhloxChart.prototype, "formatters", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], PhloxChart.prototype, "title", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], PhloxChart.prototype, "subtitle", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Object)
], PhloxChart.prototype, "options", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], PhloxChart.prototype, "width", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], PhloxChart.prototype, "height", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Array)
], PhloxChart.prototype, "cols", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Array)
], PhloxChart.prototype, "rows", void 0);
return PhloxChart;
}(AbstractDataView));
export { PhloxChart };
function PhloxChart_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
PhloxChart.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
PhloxChart.ctorParameters;
/** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
PhloxChart.propDecorators;
/** @type {?} */
PhloxChart.TYPE_NAME;
/** @type {?} */
PhloxChart.prototype.chartReadyEvent;
/** @type {?} */
PhloxChart.prototype.chartErrorEvent;
/** @type {?} */
PhloxChart.prototype.beforeChartSelectEvent;
/** @type {?} */
PhloxChart.prototype.chartSelectEvent;
/** @type {?} */
PhloxChart.prototype.beforeChartMouseOverEvent;
/** @type {?} */
PhloxChart.prototype.chartMouseOverEvent;
/** @type {?} */
PhloxChart.prototype.beforeChartMouseOutEvent;
/** @type {?} */
PhloxChart.prototype.chartMouseOutEvent;
/** @type {?} */
PhloxChart.prototype.dataTable;
/** @type {?} */
PhloxChart.prototype.chartType;
/** @type {?} */
PhloxChart.prototype.formatters;
/** @type {?} */
PhloxChart.prototype.title;
/** @type {?} */
PhloxChart.prototype.subtitle;
/** @type {?} */
PhloxChart.prototype.options;
/** @type {?} */
PhloxChart.prototype.width;
/** @type {?} */
PhloxChart.prototype.height;
/** @type {?} */
PhloxChart.prototype.cols;
/** @type {?} */
PhloxChart.prototype.rows;
/** @type {?} */
PhloxChart.prototype.model;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"PhloxChart.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/dataview/PhloxChart.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, EventEmitter, Output, ViewChild, Input } from '@angular/core';\r\nimport { AbstractDataView } from './AbstractDataView';\r\nimport { IHasModel } from '../IHasModel';\r\nimport { PhloxDataChartModel } from '.././model/models';\r\nimport { Option } from '../../decorator/decorators';\r\nimport { GoogleChartComponent } from 'ng2-google-charts';\r\nimport { BEFORE_CHART_MOUSE_OVER_EVENT, CHART_MOUSE_OVER_EVENT, BEFORE_CHART_MOUSE_OUT_EVENT, CHART_MOUSE_OUT_EVENT, BEFORE_CHART_SELECT_EVENT, CHART_SELECT_EVENT, CHART_ERROR, CHART_READY } from '../../share/CustomEventType';\r\nimport { EventUtils } from '../../share/shares';\r\n\r\nconst TYPE_NAME: string = \"phxChart\";\r\n\r\n@Component({\r\n  moduleId: module.id,\r\n  selector: TYPE_NAME,\r\n  template: `<div class=\"phxChart\">\r\n    <google-chart [data]=\"getModel()\" (chartReady)=\"onChartReadyEvent($event)\" (chartError)=\"onChartErrorEvent($event)\" (chartSelect)=\"onChartSelectEvent($event)\"></google-chart>\r\n</div> `\r\n})\r\n\r\nexport class PhloxChart extends AbstractDataView implements IHasModel, OnInit {\r\n\r\n  public static readonly TYPE_NAME: string = TYPE_NAME;\r\n\r\n  @Option('chartReady')\r\n  @Output('phxChartReady')\r\n  protected chartReadyEvent: EventEmitter<any>;\r\n  @Option('chartError')\r\n  @Output('phxChartError')\r\n  protected chartErrorEvent: EventEmitter<any>;\r\n  @Option('beforeChartSelect')\r\n  @Output('phxBeforeChartSelect')\r\n  protected beforeChartSelectEvent: EventEmitter<any>;\r\n  @Option('chartSelect')\r\n  @Output('phxChartSelect')\r\n  protected chartSelectEvent: EventEmitter<any>;\r\n  @Option('beforeChartMouseOver')\r\n  @Output('phxBeforeChartMouseOver')\r\n  protected beforeChartMouseOverEvent: EventEmitter<any>;\r\n  @Option('chartMouseOver')\r\n  @Output('phxChartMouseOver')\r\n  protected chartMouseOverEvent: EventEmitter<any>;\r\n  @Option('beforeChartMouseOut')\r\n  @Output('phxBeforeChartMouseOut')\r\n  protected beforeChartMouseOutEvent: EventEmitter<any>;\r\n  @Option('chartMouseOut')\r\n  @Output('phxChartMouseOut')\r\n  protected chartMouseOutEvent: EventEmitter<any>;\r\n\r\n  @Input()\r\n  @Option()\r\n  protected dataTable: any[];\r\n  @Input()\r\n  @Option()\r\n  protected chartType: string;\r\n  @Input()\r\n  @Option()\r\n  protected formatters: any[];\r\n  @Input()\r\n  @Option()\r\n  protected title : string;\r\n  @Input()\r\n  @Option()\r\n  protected subtitle: string;\r\n  @Input()\r\n  @Option()\r\n  protected options: any;\r\n  @Input()\r\n  @Option()\r\n  protected width: string;\r\n  @Input()\r\n  @Option()\r\n  protected height: string;\r\n  @Input()\r\n  @Option()\r\n  protected cols: any[];\r\n  @Input()\r\n  @Option()\r\n  protected rows: any[];\r\n\r\n  //   protected chartWrapper: ChartWrapper;\r\n  protected model: PhloxDataChartModel;\r\n\r\n\r\n  constructor(elementRef: ElementRef) {\r\n    super(elementRef);\r\n\r\n    this.chartReadyEvent = new EventEmitter(); // before event is not require\r\n    this.chartErrorEvent = new EventEmitter(); // before event is not require\r\n    this.beforeChartSelectEvent = new EventEmitter();\r\n    this.chartSelectEvent = new EventEmitter();\r\n    this.beforeChartMouseOverEvent = new EventEmitter();\r\n    this.chartMouseOverEvent = new EventEmitter();\r\n    this.beforeChartMouseOutEvent = new EventEmitter();\r\n    this.chartMouseOutEvent = new EventEmitter();\r\n\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    super.ngOnInit();\r\n\r\n    if(this.chartType !== undefined && this.chartType !== null &&\r\n      this.dataTable !== undefined && this.dataTable !== null &&\r\n      this.cols !== undefined && this.cols !== null &&\r\n      this.rows !== undefined && this.rows !== null  ) {\r\n        this.model = new PhloxDataChartModel(\r\n          this.chartType,\r\n          this.dataTable,\r\n          this.formatters,\r\n          this.options,\r\n          this.title,\r\n          this.subtitle,\r\n          this.width,\r\n          this.height,\r\n          this.cols,\r\n          this.rows\r\n        );\r\n      }\r\n  }\r\n\r\n  public isSelfDataDirty(): boolean {\r\n    return false;\r\n  }\r\n\r\n  public selfSaveData(data: any): void {\r\n\r\n  }\r\n\r\n  public selfResetData(): void {\r\n\r\n  }\r\n\r\n  public doPreload(): Promise<any> {     return new Promise((resolve, reject) => {       resolve(null);     });   }  public doLoaded(): void {\r\n\r\n  }\r\n\r\n  public reloadData(dataTable: any[]): void {\r\n    this.model.dataTable = dataTable;\r\n    this.model = JSON.parse(JSON.stringify(this.model));\r\n  }\r\n\r\n  public onChartSelectEvent(event: any, fireEvent?: boolean) {\r\n    if (fireEvent === null || fireEvent === undefined) {\r\n      fireEvent = true;\r\n    }\r\n\r\n    EventUtils.handleBrowserEvent(this, 'beforeChartSelectEvent', event, fireEvent, ($event: Event) => {\r\n      // doEvent\r\n    }, ($event: Event) => {\r\n      // emitBeforeEvent\r\n      this.emitBeforeChartSelectEvent($event);\r\n    }, ($event: Event, result: any) => {\r\n      // emitAfterEvent\r\n      this.emitChartSelectEvent($event);\r\n    }, ($event: Event) => {\r\n      // doPrevented\r\n    });\r\n  }\r\n\r\n  protected emitBeforeChartSelectEvent($event: Event) {\r\n    let eventData: any = null\r\n\r\n    // emit event\r\n    let data: any = eventData;\r\n    let ev = EventUtils.newCustomEvent(BEFORE_CHART_SELECT_EVENT, this, data, $event);\r\n\r\n    if (this.beforeChartSelectEvent !== null && this.beforeChartSelectEvent !== undefined) {\r\n      this.beforeChartSelectEvent.emit(ev);\r\n    }\r\n  }\r\n\r\n  protected emitChartSelectEvent($event: Event) {\r\n    let eventData: any = $event\r\n\r\n    // emit event\r\n    let data: any = eventData;\r\n    let ev = EventUtils.newCustomEvent(CHART_SELECT_EVENT, this, data, $event);\r\n\r\n    if (this.chartSelectEvent !== null && this.chartSelectEvent !== undefined) {\r\n      this.chartSelectEvent.emit(ev);\r\n    }\r\n  }\r\n\r\n  protected emitChartReadyEvent($event: Event) {\r\n    let eventData: any = null\r\n\r\n    // emit event\r\n    let data: any = eventData;\r\n    let ev = EventUtils.newCustomEvent(CHART_READY, this, data, event);\r\n\r\n    if (this.chartReadyEvent !== null && this.chartReadyEvent !== undefined) {\r\n      this.chartReadyEvent.emit(ev);\r\n    }\r\n  }\r\n\r\n  protected emitChartErrorEvent($event: Event) {\r\n    let eventData: any = null\r\n\r\n    // emit event\r\n    let data: any = eventData;\r\n    let ev = EventUtils.newCustomEvent(CHART_ERROR, this, data, event);\r\n\r\n    if (this.chartErrorEvent !== null && this.chartErrorEvent !== undefined) {\r\n      this.chartErrorEvent.emit(ev);\r\n    }\r\n  }\r\n\r\n  public onChartReadyEvent(event: any, fireEvent?: boolean) {\r\n    if (fireEvent === null || fireEvent === undefined) {\r\n      fireEvent = true;\r\n    }\r\n\r\n    this.emitChartReadyEvent(event);\r\n  }\r\n\r\n  public onChartErrorEvent(event: any, fireEvent?: boolean) {\r\n    if (fireEvent === null || fireEvent === undefined) {\r\n      fireEvent = true;\r\n    }\r\n\r\n    this.emitChartErrorEvent(event);\r\n  }\r\n\r\n  public getchartReadyEvent(): EventEmitter<any> {\r\n    return this.chartReadyEvent;\r\n  }\r\n\r\n  public getchartErrorEvent(): EventEmitter<any> {\r\n    return this.chartErrorEvent;\r\n  }\r\n\r\n  public getchartSelectEvent(): EventEmitter<any> {\r\n    return this.chartSelectEvent;\r\n  }\r\n\r\n  public getchartMouseOverEvent(): EventEmitter<any> {\r\n    return this.chartMouseOverEvent;\r\n  }\r\n\r\n  public getchartMouseOutEvent(): EventEmitter<any> {\r\n    return this.chartMouseOutEvent;\r\n  }\r\n\r\n  public setOptions(options: any): void {\r\n    this.model.options = options;\r\n    this.reloadData(this.model.dataTable);\r\n  }\r\n\r\n  public setChartType(chartType: string): void {\r\n    this.model.chartType = chartType;\r\n    this.reloadData(this.model.dataTable);\r\n  }\r\n\r\n  public setTitle(title: string): void {\r\n    this.model.title = title;\r\n    this.reloadData(this.model.dataTable);\r\n  }\r\n\r\n  public setSubtitle(subtitle: string): void {\r\n    this.model.subtitle = subtitle;\r\n    this.reloadData(this.model.dataTable);\r\n  }\r\n\r\n  public getModel(): PhloxDataChartModel {\r\n    return this.model;\r\n  }\r\n\r\n  public setModel(model: PhloxDataChartModel): void {\r\n    this.model = model;\r\n  }\r\n}\r\n"]}