@lxlib/chart
Version:
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 9.1.1.
308 lines • 21.3 kB
JavaScript
/**
* @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;*/
}
export class G2RadarComponent {
// #endregion
/**
* @param {?} cdr
* @param {?} ngZone
*/
constructor(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 {?}
*/
getHeight() {
return this.height - (this.hasLegend ? 80 : 22);
}
/**
* @private
* @return {?}
*/
install() {
const { node, padding } = this;
/** @type {?} */
const chart = (this.chart = new Chart({
container: node.nativeElement,
autoFit: true,
height: this.getHeight(),
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 {?}
*/
(name) => {
/** @type {?} */
const legendItem = this.legendData.find((/**
* @param {?} w
* @return {?}
*/
w => 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 {?}
*/
attachChart() {
const { chart, padding, data, colors, tickCount } = this;
if (!chart || !data || data.length <= 0)
return;
chart.height = this.getHeight();
chart.padding = padding;
chart.scale({
value: {
min: 0,
tickCount,
},
});
chart.geometries.forEach((/**
* @param {?} g
* @return {?}
*/
g => g.color('name', colors)));
chart.changeData(data);
this.ngZone.run((/**
* @return {?}
*/
() => this.genLegend()));
}
/**
* @private
* @return {?}
*/
genLegend() {
const { hasLegend, cdr, chart } = this;
if (!hasLegend)
return;
this.legendData = chart.geometries[0].dataArray.map((/**
* @param {?} item
* @return {?}
*/
item => {
/** @type {?} */
const origin = item[0]._origin;
/** @type {?} */
const result = {
name: origin.name,
color: item[0].color,
checked: true,
value: item.reduce((/**
* @param {?} p
* @param {?} n
* @return {?}
*/
(p, n) => p + n._origin.value), 0),
};
return result;
}));
cdr.detectChanges();
}
/**
* @param {?} i
* @return {?}
*/
_click(i) {
const { legendData, chart } = this;
legendData[i].checked = !legendData[i].checked;
chart.render();
}
/**
* @return {?}
*/
ngOnInit() {
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
() => setTimeout((/**
* @return {?}
*/
() => this.install()), this.delay)));
}
/**
* @return {?}
*/
ngOnChanges() {
this.legendData.forEach((/**
* @param {?} i
* @return {?}
*/
i => (i.checked = true)));
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
() => this.attachChart()));
}
/**
* @return {?}
*/
ngOnDestroy() {
if (this.chart) {
this.ngZone.runOutsideAngular((/**
* @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 = () => [
{ 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);
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"]}