@lxlib/chart
Version:
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 9.1.1.
321 lines • 22.8 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: timeline.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { __assign, __decorate, __metadata, __read, __spread } from "tslib";
import { ChangeDetectionStrategy, Component, ElementRef, Input, NgZone, ViewChild, ViewEncapsulation, } from '@angular/core';
import DataSet from '@antv/data-set';
import { Chart } from '@antv/g2';
import { InputBoolean, InputNumber } from '@lxlib/util';
var G2TimelineData = /** @class */ (function () {
function G2TimelineData() {
}
return G2TimelineData;
}());
export { G2TimelineData };
if (false) {
/**
* 非 `Date` 格式,自动使用 `new Date` 转换,因此,支持时间格式字符串、数字型时间戳
* @type {?}
*/
G2TimelineData.prototype.x;
/**
* 指标1数据
* @type {?}
*/
G2TimelineData.prototype.y1;
/**
* 指标2数据
* @type {?}
*/
G2TimelineData.prototype.y2;
/* Skipping unhandled member: [key: string]: any;*/
}
var G2TimelineComponent = /** @class */ (function () {
// #endregion
function G2TimelineComponent(ngZone) {
this.ngZone = ngZone;
// #region fields
this.delay = 0;
this.data = [];
this.colorMap = { y1: '#1890FF', y2: '#2FC25B' };
this.mask = 'HH:mm';
this.position = 'top';
this.height = 450;
this.padding = [60, 20, 64, 40];
this.borderWidth = 2;
this.slider = true;
}
/**
* @return {?}
*/
G2TimelineComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
function () { return setTimeout((/**
* @return {?}
*/
function () { return _this.install(); }), _this.delay); }));
};
/**
* @private
* @return {?}
*/
G2TimelineComponent.prototype.install = /**
* @private
* @return {?}
*/
function () {
var _a = this, node = _a.node, height = _a.height, padding = _a.padding, mask = _a.mask, slider = _a.slider;
/** @type {?} */
var chart = (this.chart = new Chart({
container: node.nativeElement,
autoFit: true,
height: height,
padding: padding,
}));
chart.axis('x', { title: null });
chart.axis('y1', { title: null });
chart.axis('y2', false);
chart.line().position('x*y1');
chart.line().position('x*y2');
/** @type {?} */
var sliderPadding = __assign(__assign({}, []), padding);
sliderPadding[0] = 0;
if (slider) {
chart.option('slider', {
height: 26,
start: 0.1,
end: 0.8,
trendCfg: {
isArea: false,
},
mask: mask,
});
}
this.attachChart();
};
/**
* @private
* @return {?}
*/
G2TimelineComponent.prototype.attachChart = /**
* @private
* @return {?}
*/
function () {
var _a = this, chart = _a.chart, height = _a.height, padding = _a.padding, data = _a.data, mask = _a.mask, titleMap = _a.titleMap, position = _a.position, colorMap = _a.colorMap, borderWidth = _a.borderWidth;
if (!chart || !data || data.length <= 0)
return;
chart.legend({
position: position,
custom: true,
// clickable: false,
items: [
{ name: titleMap.y1, value: titleMap.y1, marker: { style: { fill: colorMap.y1 } } },
{ name: titleMap.y1, value: titleMap.y2, marker: { style: { fill: colorMap.y2 } } },
],
});
// border
chart.geometries.forEach((/**
* @param {?} v
* @param {?} idx
* @return {?}
*/
function (v, idx) {
v.color(((/** @type {?} */ (colorMap)))["y" + (idx + 1)]).size(borderWidth);
}));
chart.height = height;
chart.padding = padding;
data
.filter((/**
* @param {?} v
* @return {?}
*/
function (v) { return !(v.x instanceof Number); }))
.forEach((/**
* @param {?} v
* @return {?}
*/
function (v) {
v.x = +new Date(v.x);
}));
data.sort((/**
* @param {?} a
* @param {?} b
* @return {?}
*/
function (a, b) { return +a.x - +b.x; }));
/** @type {?} */
var max = Math.max(__spread(data).sort((/**
* @param {?} a
* @param {?} b
* @return {?}
*/
function (a, b) { return b.y1 - a.y1; }))[0].y1, __spread(data).sort((/**
* @param {?} a
* @param {?} b
* @return {?}
*/
function (a, b) { return b.y2 - a.y2; }))[0].y2);
/** @type {?} */
var ds = new DataSet({
state: {
start: data[0].x,
end: data[data.length - 1].x,
},
});
/** @type {?} */
var dv = ds.createView('origin').source(data);
dv.transform({
type: 'filter',
callback: (/**
* @param {?} val
* @return {?}
*/
function (val) {
/** @type {?} */
var time = +val.x;
return time >= ds.state.start && time <= ds.state.end;
}),
});
chart.scale({
x: {
type: 'timeCat',
mask: mask,
range: [0, 1],
},
y1: {
alias: titleMap.y1,
max: max,
min: 0,
},
y2: {
alias: titleMap.y2,
max: max,
min: 0,
},
});
chart.changeData(dv.rows);
};
/**
* @return {?}
*/
G2TimelineComponent.prototype.ngOnChanges = /**
* @return {?}
*/
function () {
var _this = this;
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
function () { return _this.attachChart(); }));
};
/**
* @return {?}
*/
G2TimelineComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
var _this = this;
if (this.chart) {
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
function () { return _this.chart.destroy(); }));
}
};
G2TimelineComponent.decorators = [
{ type: Component, args: [{
selector: 'g2-timeline',
exportAs: 'g2Timeline',
template: "<ng-container *nzStringTemplateOutlet=\"title\">\n <h4>{{title}}</h4>\n</ng-container>\n<div #container></div>\n",
preserveWhitespaces: false,
changeDetection: ChangeDetectionStrategy.OnPush,
encapsulation: ViewEncapsulation.None
}] }
];
/** @nocollapse */
G2TimelineComponent.ctorParameters = function () { return [
{ type: NgZone }
]; };
G2TimelineComponent.propDecorators = {
node: [{ type: ViewChild, args: ['container', { static: false },] }],
delay: [{ type: Input }],
title: [{ type: Input }],
data: [{ type: Input }],
titleMap: [{ type: Input }],
colorMap: [{ type: Input }],
mask: [{ type: Input }],
position: [{ type: Input }],
height: [{ type: Input }],
padding: [{ type: Input }],
borderWidth: [{ type: Input }],
slider: [{ type: Input }]
};
__decorate([
InputNumber(),
__metadata("design:type", Object)
], G2TimelineComponent.prototype, "delay", void 0);
__decorate([
InputNumber(),
__metadata("design:type", Object)
], G2TimelineComponent.prototype, "height", void 0);
__decorate([
InputNumber(),
__metadata("design:type", Object)
], G2TimelineComponent.prototype, "borderWidth", void 0);
__decorate([
InputBoolean(),
__metadata("design:type", Object)
], G2TimelineComponent.prototype, "slider", void 0);
return G2TimelineComponent;
}());
export { G2TimelineComponent };
if (false) {
/**
* @type {?}
* @private
*/
G2TimelineComponent.prototype.node;
/**
* @type {?}
* @private
*/
G2TimelineComponent.prototype.chart;
/** @type {?} */
G2TimelineComponent.prototype.delay;
/** @type {?} */
G2TimelineComponent.prototype.title;
/** @type {?} */
G2TimelineComponent.prototype.data;
/** @type {?} */
G2TimelineComponent.prototype.titleMap;
/** @type {?} */
G2TimelineComponent.prototype.colorMap;
/** @type {?} */
G2TimelineComponent.prototype.mask;
/** @type {?} */
G2TimelineComponent.prototype.position;
/** @type {?} */
G2TimelineComponent.prototype.height;
/** @type {?} */
G2TimelineComponent.prototype.padding;
/** @type {?} */
G2TimelineComponent.prototype.borderWidth;
/** @type {?} */
G2TimelineComponent.prototype.slider;
/**
* @type {?}
* @private
*/
G2TimelineComponent.prototype.ngZone;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timeline.component.js","sourceRoot":"ng://@lxlib/chart/timeline/","sources":["timeline.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\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 DataSet from '@antv/data-set';\nimport { Chart } from '@antv/g2';\nimport { InputBoolean, InputNumber } from '@lxlib/util';\nimport { NzSafeAny } from 'ng-zorro-antd/core/types';\n\nexport class G2TimelineData {\n  /** 非 `Date` 格式，自动使用 `new Date` 转换，因此，支持时间格式字符串、数字型时间戳 */\n  x: Date | string | number;\n  /** 指标1数据 */\n  y1: number;\n  /** 指标2数据 */\n  y2: number;\n  [key: string]: any;\n}\n\n@Component({\n  selector: 'g2-timeline',\n  exportAs: 'g2Timeline',\n  templateUrl: './timeline.component.html',\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class G2TimelineComponent implements OnInit, OnDestroy, OnChanges {\n  @ViewChild('container', { static: false }) private node: ElementRef;\n  private chart: Chart;\n\n  // #region fields\n\n  @Input() @InputNumber() delay = 0;\n  @Input() title: string | TemplateRef<void>;\n  @Input() data: G2TimelineData[] = [];\n  @Input() titleMap: { y1: string; y2: string };\n  @Input() colorMap: { y1: string; y2: string } = { y1: '#1890FF', y2: '#2FC25B' };\n  @Input() mask: string = 'HH:mm';\n  @Input() position: 'top' | 'right' | 'bottom' | 'left' = 'top';\n  @Input() @InputNumber() height = 450;\n  @Input() padding: number[] = [60, 20, 64, 40];\n  @Input() @InputNumber() borderWidth = 2;\n  @Input() @InputBoolean() slider = true;\n\n  // #endregion\n\n  constructor(private ngZone: NgZone) {}\n\n  ngOnInit(): void {\n    this.ngZone.runOutsideAngular(() => setTimeout(() => this.install(), this.delay));\n  }\n\n  private install() {\n    const { node, height, padding, mask, slider } = this;\n    const chart = (this.chart = new Chart({\n      container: node.nativeElement,\n      autoFit: true,\n      height,\n      padding,\n    }));\n    chart.axis('x', { title: null });\n    chart.axis('y1', { title: null });\n    chart.axis('y2', false);\n\n    chart.line().position('x*y1');\n    chart.line().position('x*y2');\n\n    const sliderPadding = { ...[], ...padding };\n    sliderPadding[0] = 0;\n    if (slider) {\n      chart.option('slider', {\n        height: 26,\n        start: 0.1,\n        end: 0.8,\n        trendCfg: {\n          isArea: false,\n        },\n        mask,\n      });\n    }\n\n    this.attachChart();\n  }\n\n  private attachChart() {\n    const { chart, height, padding, data, mask, titleMap, position, colorMap, borderWidth } = this;\n    if (!chart || !data || data.length <= 0) return;\n\n    chart.legend({\n      position,\n      custom: true,\n      // clickable: false,\n      items: [\n        { name: titleMap.y1, value: titleMap.y1, marker: { style: { fill: colorMap.y1 } } },\n        { name: titleMap.y1, value: titleMap.y2, marker: { style: { fill: colorMap.y2 } } },\n      ],\n    });\n\n    // border\n    chart.geometries.forEach((v, idx: number) => {\n      v.color((colorMap as NzSafeAny)[`y${idx + 1}`]).size(borderWidth);\n    });\n    chart.height = height;\n    chart.padding = padding;\n\n    data\n      .filter(v => !(v.x instanceof Number))\n      .forEach(v => {\n        v.x = +new Date(v.x);\n      });\n    data.sort((a, b) => +a.x - +b.x);\n    const max = Math.max([...data].sort((a, b) => b.y1 - a.y1)[0].y1, [...data].sort((a, b) => b.y2 - a.y2)[0].y2);\n    const ds = new DataSet({\n      state: {\n        start: data[0].x,\n        end: data[data.length - 1].x,\n      },\n    });\n    const dv = ds.createView('origin').source(data);\n    dv.transform({\n      type: 'filter',\n      callback: (val: G2TimelineData) => {\n        const time = +val.x;\n        return time >= ds.state.start && time <= ds.state.end;\n      },\n    });\n    chart.scale({\n      x: {\n        type: 'timeCat',\n        mask,\n        range: [0, 1],\n      },\n      y1: {\n        alias: titleMap.y1,\n        max,\n        min: 0,\n      },\n      y2: {\n        alias: titleMap.y2,\n        max,\n        min: 0,\n      },\n    });\n    chart.changeData(dv.rows);\n  }\n\n  ngOnChanges(): void {\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"]}