UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

403 lines (402 loc) 31.9 kB
/** * @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"]}