com.phloxui
Version:
PhloxUI Ng2+ Framework
403 lines (402 loc) • 31.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';
const /** @type {?} */ TYPE_NAME = "phxChart";
export class PhloxChart extends AbstractDataView {
/**
* @param {?} elementRef
*/
constructor(elementRef) {
super(elementRef);
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 {?}
*/
ngOnInit() {
super.ngOnInit();
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 {?}
*/
isSelfDataDirty() {
return false;
}
/**
* @param {?} data
* @return {?}
*/
selfSaveData(data) {
}
/**
* @return {?}
*/
selfResetData() {
}
/**
* @return {?}
*/
doPreload() { return new Promise((resolve, reject) => { resolve(null); }); }
/**
* @return {?}
*/
doLoaded() {
}
/**
* @param {?} dataTable
* @return {?}
*/
reloadData(dataTable) {
this.model.dataTable = dataTable;
this.model = JSON.parse(JSON.stringify(this.model));
}
/**
* @param {?} event
* @param {?=} fireEvent
* @return {?}
*/
onChartSelectEvent(event, fireEvent) {
if (fireEvent === null || fireEvent === undefined) {
fireEvent = true;
}
EventUtils.handleBrowserEvent(this, 'beforeChartSelectEvent', event, fireEvent, ($event) => {
// doEvent
}, ($event) => {
// emitBeforeEvent
this.emitBeforeChartSelectEvent($event);
}, ($event, result) => {
// emitAfterEvent
this.emitChartSelectEvent($event);
}, ($event) => {
// doPrevented
});
}
/**
* @param {?} $event
* @return {?}
*/
emitBeforeChartSelectEvent($event) {
let /** @type {?} */ eventData = null;
// emit event
let /** @type {?} */ data = eventData;
let /** @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 {?}
*/
emitChartSelectEvent($event) {
let /** @type {?} */ eventData = $event;
// emit event
let /** @type {?} */ data = eventData;
let /** @type {?} */ ev = EventUtils.newCustomEvent(CHART_SELECT_EVENT, this, data, $event);
if (this.chartSelectEvent !== null && this.chartSelectEvent !== undefined) {
this.chartSelectEvent.emit(ev);
}
}
/**
* @param {?} $event
* @return {?}
*/
emitChartReadyEvent($event) {
let /** @type {?} */ eventData = null;
// emit event
let /** @type {?} */ data = eventData;
let /** @type {?} */ ev = EventUtils.newCustomEvent(CHART_READY, this, data, event);
if (this.chartReadyEvent !== null && this.chartReadyEvent !== undefined) {
this.chartReadyEvent.emit(ev);
}
}
/**
* @param {?} $event
* @return {?}
*/
emitChartErrorEvent($event) {
let /** @type {?} */ eventData = null;
// emit event
let /** @type {?} */ data = eventData;
let /** @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 {?}
*/
onChartReadyEvent(event, fireEvent) {
if (fireEvent === null || fireEvent === undefined) {
fireEvent = true;
}
this.emitChartReadyEvent(event);
}
/**
* @param {?} event
* @param {?=} fireEvent
* @return {?}
*/
onChartErrorEvent(event, fireEvent) {
if (fireEvent === null || fireEvent === undefined) {
fireEvent = true;
}
this.emitChartErrorEvent(event);
}
/**
* @return {?}
*/
getchartReadyEvent() {
return this.chartReadyEvent;
}
/**
* @return {?}
*/
getchartErrorEvent() {
return this.chartErrorEvent;
}
/**
* @return {?}
*/
getchartSelectEvent() {
return this.chartSelectEvent;
}
/**
* @return {?}
*/
getchartMouseOverEvent() {
return this.chartMouseOverEvent;
}
/**
* @return {?}
*/
getchartMouseOutEvent() {
return this.chartMouseOutEvent;
}
/**
* @param {?} options
* @return {?}
*/
setOptions(options) {
this.model.options = options;
this.reloadData(this.model.dataTable);
}
/**
* @param {?} chartType
* @return {?}
*/
setChartType(chartType) {
this.model.chartType = chartType;
this.reloadData(this.model.dataTable);
}
/**
* @param {?} title
* @return {?}
*/
setTitle(title) {
this.model.title = title;
this.reloadData(this.model.dataTable);
}
/**
* @param {?} subtitle
* @return {?}
*/
setSubtitle(subtitle) {
this.model.subtitle = subtitle;
this.reloadData(this.model.dataTable);
}
/**
* @return {?}
*/
getModel() {
return this.model;
}
/**
* @param {?} model
* @return {?}
*/
setModel(model) {
this.model = model;
}
}
PhloxChart.TYPE_NAME = TYPE_NAME;
PhloxChart.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: `<div class="phxChart">
<google-chart [data]="getModel()" (chartReady)="onChartReadyEvent($event)" (chartError)="onChartErrorEvent($event)" (chartSelect)="onChartSelectEvent($event)"></google-chart>
</div> `
},] },
];
/** @nocollapse */
PhloxChart.ctorParameters = () => [
{ 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);
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"]}