@lxlib/chart
Version:
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 9.1.1.
286 lines • 19.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: mini-area.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { __decorate, __metadata } from "tslib";
import { ChangeDetectionStrategy, Component, ElementRef, Input, NgZone, ViewEncapsulation, } from '@angular/core';
import { Chart } from '@antv/g2';
import { InputBoolean, InputNumber } from '@lxlib/util';
/**
* @record
*/
export function G2MiniAreaData() { }
if (false) {
/** @type {?} */
G2MiniAreaData.prototype.x;
/** @type {?} */
G2MiniAreaData.prototype.y;
/* Skipping unhandled member: [key: string]: any;*/
}
var G2MiniAreaComponent = /** @class */ (function () {
// #endregion
function G2MiniAreaComponent(el, ngZone) {
this.el = el;
this.ngZone = ngZone;
// #region fields
this.delay = 0;
this.color = 'rgba(24, 144, 255, 0.2)';
this.borderColor = '#1890FF';
this.borderWidth = 2;
this.height = 56;
this.fit = true;
this.line = false;
this.animate = true;
this.padding = [8, 8, 8, 8];
this.data = [];
this.yTooltipSuffix = '';
this.tooltipType = 'default';
}
/**
* @private
* @return {?}
*/
G2MiniAreaComponent.prototype.install = /**
* @private
* @return {?}
*/
function () {
var _a = this, el = _a.el, fit = _a.fit, height = _a.height, padding = _a.padding, xAxis = _a.xAxis, yAxis = _a.yAxis, yTooltipSuffix = _a.yTooltipSuffix, tooltipType = _a.tooltipType, line = _a.line;
/** @type {?} */
var chart = (this.chart = new Chart({
container: el.nativeElement,
autoFit: fit,
height: height,
padding: padding,
}));
if (!xAxis && !yAxis) {
chart.axis(false);
}
if (xAxis) {
chart.axis('x', xAxis);
}
else {
chart.axis('x', false);
}
if (yAxis) {
chart.axis('y', yAxis);
}
else {
chart.axis('y', false);
}
chart.legend(false);
/** @type {?} */
var tooltipOption = {
showTitle: false,
showMarkers: true,
enterable: true,
domStyles: {
'g2-tooltip': { padding: '0px' },
'g2-tooltip-title': { display: 'none' },
'g2-tooltip-list-item': { margin: '4px' },
},
};
if (tooltipType === 'mini') {
tooltipOption.position = 'top';
(/** @type {?} */ (tooltipOption.domStyles))['g2-tooltip'] = { padding: '0px', backgroundColor: 'transparent', boxShadow: 'none' };
tooltipOption.itemTpl = "<li>{value}</li>";
tooltipOption.offset = 0;
}
chart.tooltip(tooltipOption);
chart
.area()
.position('x*y')
.tooltip('x*y', (/**
* @param {?} x
* @param {?} y
* @return {?}
*/
function (x, y) { return ({ name: x, value: y + yTooltipSuffix }); }))
.shape('smooth');
if (line) {
chart.line().position('x*y').shape('smooth').tooltip(false);
}
chart.render();
this.attachChart();
};
/**
* @private
* @return {?}
*/
G2MiniAreaComponent.prototype.attachChart = /**
* @private
* @return {?}
*/
function () {
var _a = this, chart = _a.chart, line = _a.line, fit = _a.fit, height = _a.height, animate = _a.animate, padding = _a.padding, data = _a.data, color = _a.color, borderColor = _a.borderColor, borderWidth = _a.borderWidth;
if (!chart || !data || data.length <= 0) {
return;
}
/** @type {?} */
var geoms = chart.geometries;
geoms.forEach((/**
* @param {?} g
* @return {?}
*/
function (g) { return g.color(color); }));
if (line) {
geoms[1].color(borderColor).size(borderWidth);
}
chart.autoFit = fit;
chart.height = height;
chart.animate(animate);
chart.padding = padding;
chart.changeData(data);
};
/**
* @return {?}
*/
G2MiniAreaComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
function () { return setTimeout((/**
* @return {?}
*/
function () { return _this.install(); }), _this.delay); }));
};
/**
* @return {?}
*/
G2MiniAreaComponent.prototype.ngOnChanges = /**
* @return {?}
*/
function () {
var _this = this;
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
function () { return _this.attachChart(); }));
};
/**
* @return {?}
*/
G2MiniAreaComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
var _this = this;
if (this.chart) {
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
function () { return _this.chart.destroy(); }));
}
};
G2MiniAreaComponent.decorators = [
{ type: Component, args: [{
selector: 'g2-mini-area',
exportAs: 'g2MiniArea',
template: "",
host: {
'[style.height.px]': 'height',
},
preserveWhitespaces: false,
changeDetection: ChangeDetectionStrategy.OnPush,
encapsulation: ViewEncapsulation.None
}] }
];
/** @nocollapse */
G2MiniAreaComponent.ctorParameters = function () { return [
{ type: ElementRef },
{ type: NgZone }
]; };
G2MiniAreaComponent.propDecorators = {
delay: [{ type: Input }],
color: [{ type: Input }],
borderColor: [{ type: Input }],
borderWidth: [{ type: Input }],
height: [{ type: Input }],
fit: [{ type: Input }],
line: [{ type: Input }],
animate: [{ type: Input }],
xAxis: [{ type: Input }],
yAxis: [{ type: Input }],
padding: [{ type: Input }],
data: [{ type: Input }],
yTooltipSuffix: [{ type: Input }],
tooltipType: [{ type: Input }]
};
__decorate([
InputNumber(),
__metadata("design:type", Object)
], G2MiniAreaComponent.prototype, "delay", void 0);
__decorate([
InputNumber(),
__metadata("design:type", Object)
], G2MiniAreaComponent.prototype, "borderWidth", void 0);
__decorate([
InputNumber(),
__metadata("design:type", Object)
], G2MiniAreaComponent.prototype, "height", void 0);
__decorate([
InputBoolean(),
__metadata("design:type", Object)
], G2MiniAreaComponent.prototype, "fit", void 0);
__decorate([
InputBoolean(),
__metadata("design:type", Object)
], G2MiniAreaComponent.prototype, "line", void 0);
__decorate([
InputBoolean(),
__metadata("design:type", Object)
], G2MiniAreaComponent.prototype, "animate", void 0);
return G2MiniAreaComponent;
}());
export { G2MiniAreaComponent };
if (false) {
/**
* @type {?}
* @private
*/
G2MiniAreaComponent.prototype.chart;
/** @type {?} */
G2MiniAreaComponent.prototype.delay;
/** @type {?} */
G2MiniAreaComponent.prototype.color;
/** @type {?} */
G2MiniAreaComponent.prototype.borderColor;
/** @type {?} */
G2MiniAreaComponent.prototype.borderWidth;
/** @type {?} */
G2MiniAreaComponent.prototype.height;
/** @type {?} */
G2MiniAreaComponent.prototype.fit;
/** @type {?} */
G2MiniAreaComponent.prototype.line;
/** @type {?} */
G2MiniAreaComponent.prototype.animate;
/** @type {?} */
G2MiniAreaComponent.prototype.xAxis;
/** @type {?} */
G2MiniAreaComponent.prototype.yAxis;
/** @type {?} */
G2MiniAreaComponent.prototype.padding;
/** @type {?} */
G2MiniAreaComponent.prototype.data;
/** @type {?} */
G2MiniAreaComponent.prototype.yTooltipSuffix;
/** @type {?} */
G2MiniAreaComponent.prototype.tooltipType;
/**
* @type {?}
* @private
*/
G2MiniAreaComponent.prototype.el;
/**
* @type {?}
* @private
*/
G2MiniAreaComponent.prototype.ngZone;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mini-area.component.js","sourceRoot":"ng://@lxlib/chart/mini-area/","sources":["mini-area.component.ts"],"names":[],"mappings":";;;;;;AAAA,OAAO,EACL,uBAAuB,EACvB,SAAS,EACT,UAAU,EACV,KAAK,EACL,MAAM,EAIN,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,KAAK,EAAE,MAAM,UAAU,CAAC;AAEjC,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;;;;AAExD,oCAIC;;;IAHC,2BAAO;;IACP,2BAAO;;;AAIT;IA+BE,aAAa;IAEb,6BAAoB,EAAc,EAAU,MAAc;QAAtC,OAAE,GAAF,EAAE,CAAY;QAAU,WAAM,GAAN,MAAM,CAAQ;;QAjBlC,UAAK,GAAG,CAAC,CAAC;QACzB,UAAK,GAAG,yBAAyB,CAAC;QAClC,gBAAW,GAAG,SAAS,CAAC;QACT,gBAAW,GAAG,CAAC,CAAC;QAChB,WAAM,GAAG,EAAE,CAAC;QACX,QAAG,GAAG,IAAI,CAAC;QACX,SAAI,GAAG,KAAK,CAAC;QACb,YAAO,GAAG,IAAI,CAAC;QAG/B,YAAO,GAA+B,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACnD,SAAI,GAAqB,EAAE,CAAC;QAC5B,mBAAc,GAAG,EAAE,CAAC;QACpB,gBAAW,GAAuB,SAAS,CAAC;IAIQ,CAAC;;;;;IAEtD,qCAAO;;;;IAAf;QACQ,IAAA,SAAoF,EAAlF,UAAE,EAAE,YAAG,EAAE,kBAAM,EAAE,oBAAO,EAAE,gBAAK,EAAE,gBAAK,EAAE,kCAAc,EAAE,4BAAW,EAAE,cAAa;;YACpF,KAAK,GAAG,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,KAAK,CAAC;YACpC,SAAS,EAAE,EAAE,CAAC,aAAa;YAC3B,OAAO,EAAE,GAAG;YACZ,MAAM,QAAA;YACN,OAAO,SAAA;SACR,CAAC,CAAC;QAEH,IAAI,CAAC,KAAK,IAAI,CAAC,KAAK,EAAE;YACpB,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACnB;QAED,IAAI,KAAK,EAAE;YACT,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;SACxB;aAAM;YACL,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;SACxB;QAED,IAAI,KAAK,EAAE;YACT,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;SACxB;aAAM;YACL,KAAK,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;SACxB;QAED,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;;YACd,aAAa,GAAkB;YACnC,SAAS,EAAE,KAAK;YAChB,WAAW,EAAE,IAAI;YACjB,SAAS,EAAE,IAAI;YACf,SAAS,EAAE;gBACT,YAAY,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE;gBAChC,kBAAkB,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE;gBACvC,sBAAsB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;aAC1C;SACF;QACD,IAAI,WAAW,KAAK,MAAM,EAAE;YAC1B,aAAa,CAAC,QAAQ,GAAG,KAAK,CAAC;YAC/B,mBAAA,aAAa,CAAC,SAAS,EAAC,CAAC,YAAY,CAAC,GAAG,EAAE,OAAO,EAAE,KAAK,EAAE,eAAe,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,EAAE,CAAC;YAC/G,aAAa,CAAC,OAAO,GAAG,kBAAkB,CAAC;YAC3C,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC;SAC1B;QACD,KAAK,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QAE7B,KAAK;aACF,IAAI,EAAE;aACN,QAAQ,CAAC,KAAK,CAAC;aACf,OAAO,CAAC,KAAK;;;;;QAAE,UAAC,CAAC,EAAE,CAAC,IAAK,OAAA,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,GAAG,cAAc,EAAE,CAAC,EAAxC,CAAwC,EAAC;aAClE,KAAK,CAAC,QAAQ,CAAC,CAAC;QAEnB,IAAI,IAAI,EAAE;YACR,KAAK,CAAC,IAAI,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;SAC7D;QAED,KAAK,CAAC,MAAM,EAAE,CAAC;QAEf,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;;;;;IAEO,yCAAW;;;;IAAnB;QACQ,IAAA,SAA4F,EAA1F,gBAAK,EAAE,cAAI,EAAE,YAAG,EAAE,kBAAM,EAAE,oBAAO,EAAE,oBAAO,EAAE,cAAI,EAAE,gBAAK,EAAE,4BAAW,EAAE,4BAAoB;QAClG,IAAI,CAAC,KAAK,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC,EAAE;YACvC,OAAO;SACR;;YAEK,KAAK,GAAG,KAAK,CAAC,UAAU;QAC9B,KAAK,CAAC,OAAO;;;;QAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,EAAd,CAAc,EAAC,CAAC;QACnC,IAAI,IAAI,EAAE;YACR,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;SAC/C;QAED,KAAK,CAAC,OAAO,GAAG,GAAG,CAAC;QACpB,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;QACtB,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;QACvB,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;QAExB,KAAK,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;IACzB,CAAC;;;;IAED,sCAAQ;;;IAAR;QAAA,iBAEC;QADC,IAAI,CAAC,MAAM,CAAC,iBAAiB;;;QAAC,cAAM,OAAA,UAAU;;;QAAC,cAAM,OAAA,KAAI,CAAC,OAAO,EAAE,EAAd,CAAc,GAAE,KAAI,CAAC,KAAK,CAAC,EAA5C,CAA4C,EAAC,CAAC;IACpF,CAAC;;;;IAED,yCAAW;;;IAAX;QAAA,iBAEC;QADC,IAAI,CAAC,MAAM,CAAC,iBAAiB;;;QAAC,cAAM,OAAA,KAAI,CAAC,WAAW,EAAE,EAAlB,CAAkB,EAAC,CAAC;IAC1D,CAAC;;;;IAED,yCAAW;;;IAAX;QAAA,iBAIC;QAHC,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,IAAI,CAAC,MAAM,CAAC,iBAAiB;;;YAAC,cAAM,OAAA,KAAI,CAAC,KAAK,CAAC,OAAO,EAAE,EAApB,CAAoB,EAAC,CAAC;SAC3D;IACH,CAAC;;gBA9HF,SAAS,SAAC;oBACT,QAAQ,EAAE,cAAc;oBACxB,QAAQ,EAAE,YAAY;oBACtB,QAAQ,EAAE,EAAE;oBACZ,IAAI,EAAE;wBACJ,mBAAmB,EAAE,QAAQ;qBAC9B;oBACD,mBAAmB,EAAE,KAAK;oBAC1B,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;iBACtC;;;;gBA5BC,UAAU;gBAEV,MAAM;;;wBAgCL,KAAK;wBACL,KAAK;8BACL,KAAK;8BACL,KAAK;yBACL,KAAK;sBACL,KAAK;uBACL,KAAK;0BACL,KAAK;wBACL,KAAK;wBACL,KAAK;0BACL,KAAK;uBACL,KAAK;iCACL,KAAK;8BACL,KAAK;;IAbkB;QAAd,WAAW,EAAE;;sDAAW;IAGV;QAAd,WAAW,EAAE;;4DAAiB;IAChB;QAAd,WAAW,EAAE;;uDAAa;IACX;QAAf,YAAY,EAAE;;oDAAY;IACX;QAAf,YAAY,EAAE;;qDAAc;IACb;QAAf,YAAY,EAAE;;wDAAgB;IAwG1C,0BAAC;CAAA,AA/HD,IA+HC;SApHY,mBAAmB;;;;;;IAC9B,oCAAqB;;IAIrB,oCAAkC;;IAClC,oCAA2C;;IAC3C,0CAAiC;;IACjC,0CAAwC;;IACxC,qCAAoC;;IACpC,kCAAoC;;IACpC,mCAAsC;;IACtC,sCAAwC;;IACxC,oCAAoB;;IACpB,oCAAoB;;IACpB,sCAA4D;;IAC5D,mCAAqC;;IACrC,6CAA6B;;IAC7B,0CAAqD;;;;;IAIzC,iCAAsB;;;;;IAAE,qCAAsB","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  Input,\n  NgZone,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { Chart } from '@antv/g2';\nimport { TooltipOption } from '@antv/g2/lib/interface';\nimport { InputBoolean, InputNumber } from '@lxlib/util';\n\nexport interface G2MiniAreaData {\n  x: any;\n  y: any;\n  [key: string]: any;\n}\n\n@Component({\n  selector: 'g2-mini-area',\n  exportAs: 'g2MiniArea',\n  template: ``,\n  host: {\n    '[style.height.px]': 'height',\n  },\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class G2MiniAreaComponent implements OnInit, OnChanges, OnDestroy {\n  private chart: Chart;\n\n  // #region fields\n\n  @Input() @InputNumber() delay = 0;\n  @Input() color = 'rgba(24, 144, 255, 0.2)';\n  @Input() borderColor = '#1890FF';\n  @Input() @InputNumber() borderWidth = 2;\n  @Input() @InputNumber() height = 56;\n  @Input() @InputBoolean() fit = true;\n  @Input() @InputBoolean() line = false;\n  @Input() @InputBoolean() animate = true;\n  @Input() xAxis: any;\n  @Input() yAxis: any;\n  @Input() padding: number | number[] | 'auto' = [8, 8, 8, 8];\n  @Input() data: G2MiniAreaData[] = [];\n  @Input() yTooltipSuffix = '';\n  @Input() tooltipType: 'mini' | 'default' = 'default';\n\n  // #endregion\n\n  constructor(private el: ElementRef, private ngZone: NgZone) {}\n\n  private install() {\n    const { el, fit, height, padding, xAxis, yAxis, yTooltipSuffix, tooltipType, line } = this;\n    const chart = (this.chart = new Chart({\n      container: el.nativeElement,\n      autoFit: fit,\n      height,\n      padding,\n    }));\n\n    if (!xAxis && !yAxis) {\n      chart.axis(false);\n    }\n\n    if (xAxis) {\n      chart.axis('x', xAxis);\n    } else {\n      chart.axis('x', false);\n    }\n\n    if (yAxis) {\n      chart.axis('y', yAxis);\n    } else {\n      chart.axis('y', false);\n    }\n\n    chart.legend(false);\n    const tooltipOption: TooltipOption = {\n      showTitle: false,\n      showMarkers: true,\n      enterable: true,\n      domStyles: {\n        'g2-tooltip': { padding: '0px' },\n        'g2-tooltip-title': { display: 'none' },\n        'g2-tooltip-list-item': { margin: '4px' },\n      },\n    };\n    if (tooltipType === 'mini') {\n      tooltipOption.position = 'top';\n      tooltipOption.domStyles!['g2-tooltip'] = { padding: '0px', backgroundColor: 'transparent', boxShadow: 'none' };\n      tooltipOption.itemTpl = `<li>{value}</li>`;\n      tooltipOption.offset = 0;\n    }\n    chart.tooltip(tooltipOption);\n\n    chart\n      .area()\n      .position('x*y')\n      .tooltip('x*y', (x, y) => ({ name: x, value: y + yTooltipSuffix }))\n      .shape('smooth');\n\n    if (line) {\n      chart.line().position('x*y').shape('smooth').tooltip(false);\n    }\n\n    chart.render();\n\n    this.attachChart();\n  }\n\n  private attachChart() {\n    const { chart, line, fit, height, animate, padding, data, color, borderColor, borderWidth } = this;\n    if (!chart || !data || data.length <= 0) {\n      return;\n    }\n\n    const geoms = chart.geometries;\n    geoms.forEach(g => g.color(color));\n    if (line) {\n      geoms[1].color(borderColor).size(borderWidth);\n    }\n\n    chart.autoFit = fit;\n    chart.height = height;\n    chart.animate(animate);\n    chart.padding = padding;\n\n    chart.changeData(data);\n  }\n\n  ngOnInit() {\n    this.ngZone.runOutsideAngular(() => setTimeout(() => this.install(), this.delay));\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"]}