UNPKG

@lxlib/chart

Version:

This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 9.1.1.

340 lines 23 kB
/** * @fileoverview added by tsickle * Generated from: radar.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { __decorate, __metadata } from "tslib"; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, Input, NgZone, ViewChild, ViewEncapsulation, } from '@angular/core'; import { Chart } from '@antv/g2'; import { InputBoolean, InputNumber } from '@lxlib/util'; /** * @record */ export function G2RadarData() { } if (false) { /** @type {?} */ G2RadarData.prototype.name; /** @type {?} */ G2RadarData.prototype.label; /** @type {?} */ G2RadarData.prototype.value; /* Skipping unhandled member: [key: string]: any;*/ } var G2RadarComponent = /** @class */ (function () { // #endregion function G2RadarComponent(cdr, ngZone) { this.cdr = cdr; this.ngZone = ngZone; this.legendData = []; // #region fields this.delay = 0; this.height = 0; this.padding = [44, 30, 16, 30]; this.hasLegend = true; this.tickCount = 4; this.data = []; this.colors = ['#1890FF', '#FACC14', '#2FC25B', '#8543E0', '#F04864', '#13C2C2', '#fa8c16', '#a0d911']; } /** * @private * @return {?} */ G2RadarComponent.prototype.getHeight = /** * @private * @return {?} */ function () { return this.height - (this.hasLegend ? 80 : 22); }; /** * @private * @return {?} */ G2RadarComponent.prototype.install = /** * @private * @return {?} */ function () { var _this = this; var _a = this, node = _a.node, padding = _a.padding; /** @type {?} */ var chart = (this.chart = new Chart({ container: node.nativeElement, autoFit: true, height: this.getHeight(), padding: padding, })); chart.coordinate('polar'); chart.legend(false); chart.axis('label', { line: null, label: { offset: 8, style: { fill: 'rgba(0, 0, 0, .65)', }, }, grid: { line: { style: { stroke: '#e9e9e9', lineWidth: 1, lineDash: [0, 0], }, }, }, }); chart.axis('value', { grid: { line: { type: 'polygon', style: { stroke: '#e9e9e9', lineWidth: 1, lineDash: [0, 0], }, }, }, label: { style: { fill: 'rgba(0, 0, 0, .65)', }, }, }); chart.filter('name', (/** * @param {?} name * @return {?} */ function (name) { /** @type {?} */ var legendItem = _this.legendData.find((/** * @param {?} w * @return {?} */ function (w) { return w.name === name; })); return legendItem ? legendItem.checked !== false : true; })); chart.line().position('label*value'); chart.point().position('label*value').shape('circle').size(3); chart.render(); this.attachChart(); }; /** * @private * @return {?} */ G2RadarComponent.prototype.attachChart = /** * @private * @return {?} */ function () { var _this = this; var _a = this, chart = _a.chart, padding = _a.padding, data = _a.data, colors = _a.colors, tickCount = _a.tickCount; if (!chart || !data || data.length <= 0) return; chart.height = this.getHeight(); chart.padding = padding; chart.scale({ value: { min: 0, tickCount: tickCount, }, }); chart.geometries.forEach((/** * @param {?} g * @return {?} */ function (g) { return g.color('name', colors); })); chart.changeData(data); this.ngZone.run((/** * @return {?} */ function () { return _this.genLegend(); })); }; /** * @private * @return {?} */ G2RadarComponent.prototype.genLegend = /** * @private * @return {?} */ function () { var _a = this, hasLegend = _a.hasLegend, cdr = _a.cdr, chart = _a.chart; if (!hasLegend) return; this.legendData = chart.geometries[0].dataArray.map((/** * @param {?} item * @return {?} */ function (item) { /** @type {?} */ var origin = item[0]._origin; /** @type {?} */ var result = { name: origin.name, color: item[0].color, checked: true, value: item.reduce((/** * @param {?} p * @param {?} n * @return {?} */ function (p, n) { return p + n._origin.value; }), 0), }; return result; })); cdr.detectChanges(); }; /** * @param {?} i * @return {?} */ G2RadarComponent.prototype._click = /** * @param {?} i * @return {?} */ function (i) { var _a = this, legendData = _a.legendData, chart = _a.chart; legendData[i].checked = !legendData[i].checked; chart.render(); }; /** * @return {?} */ G2RadarComponent.prototype.ngOnInit = /** * @return {?} */ function () { var _this = this; this.ngZone.runOutsideAngular((/** * @return {?} */ function () { return setTimeout((/** * @return {?} */ function () { return _this.install(); }), _this.delay); })); }; /** * @return {?} */ G2RadarComponent.prototype.ngOnChanges = /** * @return {?} */ function () { var _this = this; this.legendData.forEach((/** * @param {?} i * @return {?} */ function (i) { return (i.checked = true); })); this.ngZone.runOutsideAngular((/** * @return {?} */ function () { return _this.attachChart(); })); }; /** * @return {?} */ G2RadarComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { var _this = this; if (this.chart) { this.ngZone.runOutsideAngular((/** * @return {?} */ function () { return _this.chart.destroy(); })); } }; G2RadarComponent.decorators = [ { type: Component, args: [{ selector: 'g2-radar', exportAs: 'g2Radar', template: "<ng-container *nzStringTemplateOutlet=\"title\">\n <h4>{{title}}</h4>\n</ng-container>\n<div #container></div>\n<div nz-row\n class=\"g2-radar__legend\"\n *ngIf=\"hasLegend\">\n <div nz-col\n [nzSpan]=\"24 / legendData.length\"\n *ngFor=\"let i of legendData; let idx = index\"\n (click)=\"_click(idx)\"\n class=\"g2-radar__legend-item\">\n <i class=\"g2-radar__legend-dot\"\n [ngStyle]=\"{'background-color': !i.checked ? '#aaa' : i.color}\"></i>\n {{i.name}}\n <h6 class=\"g2-radar__legend-title\">{{i.value}}</h6>\n </div>\n</div>\n", host: { '[style.height.px]': 'height', '[class.g2-radar]': 'true', }, preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None }] } ]; /** @nocollapse */ G2RadarComponent.ctorParameters = function () { return [ { type: ChangeDetectorRef }, { type: NgZone } ]; }; G2RadarComponent.propDecorators = { node: [{ type: ViewChild, args: ['container', { static: true },] }], delay: [{ type: Input }], title: [{ type: Input }], height: [{ type: Input }], padding: [{ type: Input }], hasLegend: [{ type: Input }], tickCount: [{ type: Input }], data: [{ type: Input }], colors: [{ type: Input }] }; __decorate([ InputNumber(), __metadata("design:type", Object) ], G2RadarComponent.prototype, "delay", void 0); __decorate([ InputNumber(), __metadata("design:type", Object) ], G2RadarComponent.prototype, "height", void 0); __decorate([ InputBoolean(), __metadata("design:type", Object) ], G2RadarComponent.prototype, "hasLegend", void 0); __decorate([ InputNumber(), __metadata("design:type", Object) ], G2RadarComponent.prototype, "tickCount", void 0); return G2RadarComponent; }()); export { G2RadarComponent }; if (false) { /** * @type {?} * @private */ G2RadarComponent.prototype.node; /** * @type {?} * @private */ G2RadarComponent.prototype.chart; /** @type {?} */ G2RadarComponent.prototype.legendData; /** @type {?} */ G2RadarComponent.prototype.delay; /** @type {?} */ G2RadarComponent.prototype.title; /** @type {?} */ G2RadarComponent.prototype.height; /** @type {?} */ G2RadarComponent.prototype.padding; /** @type {?} */ G2RadarComponent.prototype.hasLegend; /** @type {?} */ G2RadarComponent.prototype.tickCount; /** @type {?} */ G2RadarComponent.prototype.data; /** @type {?} */ G2RadarComponent.prototype.colors; /** * @type {?} * @private */ G2RadarComponent.prototype.cdr; /** * @type {?} * @private */ G2RadarComponent.prototype.ngZone; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radar.component.js","sourceRoot":"ng://@lxlib/chart/radar/","sources":["radar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { Chart } from '@antv/g2';\nimport { InputBoolean, InputNumber } from '@lxlib/util';\n\nexport interface G2RadarData {\n  name: string;\n  label: string;\n  value: number;\n  [key: string]: any;\n}\n\n@Component({\n  selector: 'g2-radar',\n  exportAs: 'g2Radar',\n  templateUrl: './radar.component.html',\n  host: {\n    '[style.height.px]': 'height',\n    '[class.g2-radar]': 'true',\n  },\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class G2RadarComponent implements OnInit, OnDestroy, OnChanges {\n  @ViewChild('container', { static: true }) private node: ElementRef;\n  private chart: Chart;\n  legendData: any[] = [];\n\n  // #region fields\n\n  @Input() @InputNumber() delay = 0;\n  @Input() title: string | TemplateRef<void>;\n  @Input() @InputNumber() height = 0;\n  @Input() padding: number | number[] | 'auto' = [44, 30, 16, 30];\n  @Input() @InputBoolean() hasLegend = true;\n  @Input() @InputNumber() tickCount = 4;\n  @Input() data: G2RadarData[] = [];\n  @Input() colors = ['#1890FF', '#FACC14', '#2FC25B', '#8543E0', '#F04864', '#13C2C2', '#fa8c16', '#a0d911'];\n\n  // #endregion\n\n  constructor(private cdr: ChangeDetectorRef, private ngZone: NgZone) {}\n\n  private getHeight() {\n    return this.height - (this.hasLegend ? 80 : 22);\n  }\n\n  private install() {\n    const { node, padding } = this;\n\n    const chart = (this.chart = new Chart({\n      container: node.nativeElement,\n      autoFit: true,\n      height: this.getHeight(),\n      padding,\n    }));\n\n    chart.coordinate('polar');\n    chart.legend(false);\n    chart.axis('label', {\n      line: null,\n      label: {\n        offset: 8,\n        style: {\n          fill: 'rgba(0, 0, 0, .65)',\n        },\n      },\n      grid: {\n        line: {\n          style: {\n            stroke: '#e9e9e9',\n            lineWidth: 1,\n            lineDash: [0, 0],\n          },\n        },\n      },\n    });\n    chart.axis('value', {\n      grid: {\n        line: {\n          type: 'polygon',\n          style: {\n            stroke: '#e9e9e9',\n            lineWidth: 1,\n            lineDash: [0, 0],\n          },\n        },\n      },\n      label: {\n        style: {\n          fill: 'rgba(0, 0, 0, .65)',\n        },\n      },\n    });\n    chart.filter('name', (name: string) => {\n      const legendItem = this.legendData.find(w => w.name === name);\n      return legendItem ? legendItem.checked !== false : true;\n    });\n\n    chart.line().position('label*value');\n\n    chart.point().position('label*value').shape('circle').size(3);\n\n    chart.render();\n\n    this.attachChart();\n  }\n\n  private attachChart() {\n    const { chart, padding, data, colors, tickCount } = this;\n    if (!chart || !data || data.length <= 0) return;\n\n    chart.height = this.getHeight();\n    chart.padding = padding;\n    chart.scale({\n      value: {\n        min: 0,\n        tickCount,\n      },\n    });\n\n    chart.geometries.forEach(g => g.color('name', colors));\n    chart.changeData(data);\n\n    this.ngZone.run(() => this.genLegend());\n  }\n\n  private genLegend() {\n    const { hasLegend, cdr, chart } = this;\n    if (!hasLegend) return;\n\n    this.legendData = chart.geometries[0].dataArray.map(item => {\n      const origin = item[0]._origin;\n      const result = {\n        name: origin.name,\n        color: item[0].color,\n        checked: true,\n        value: item.reduce((p, n) => p + n._origin.value, 0),\n      };\n\n      return result;\n    });\n\n    cdr.detectChanges();\n  }\n\n  _click(i: number) {\n    const { legendData, chart } = this;\n    legendData[i].checked = !legendData[i].checked;\n    chart.render();\n  }\n\n  ngOnInit(): void {\n    this.ngZone.runOutsideAngular(() => setTimeout(() => this.install(), this.delay));\n  }\n\n  ngOnChanges(): void {\n    this.legendData.forEach(i => (i.checked = true));\n    this.ngZone.runOutsideAngular(() => this.attachChart());\n  }\n\n  ngOnDestroy(): void {\n    if (this.chart) {\n      this.ngZone.runOutsideAngular(() => this.chart.destroy());\n    }\n  }\n}\n"]}