UNPKG

@lxlib/chart

Version:

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

231 lines 15.8 kB
/** * @fileoverview added by tsickle * Generated from: mini-bar.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 { InputNumber } from '@lxlib/util'; /** * @record */ export function G2MiniBarData() { } if (false) { /** @type {?} */ G2MiniBarData.prototype.x; /** @type {?} */ G2MiniBarData.prototype.y; /* Skipping unhandled member: [key: string]: any;*/ } var G2MiniBarComponent = /** @class */ (function () { // #endregion function G2MiniBarComponent(el, ngZone) { this.el = el; this.ngZone = ngZone; // #region fields this.delay = 0; this.color = '#1890FF'; this.height = 0; this.borderWidth = 5; this.padding = [8, 8, 8, 8]; this.data = []; this.yTooltipSuffix = ''; this.tooltipType = 'default'; } /** * @private * @return {?} */ G2MiniBarComponent.prototype.install = /** * @private * @return {?} */ function () { var _a = this, el = _a.el, height = _a.height, padding = _a.padding, yTooltipSuffix = _a.yTooltipSuffix, tooltipType = _a.tooltipType; /** @type {?} */ var chart = (this.chart = new Chart({ container: el.nativeElement, autoFit: true, height: height, padding: padding, })); chart.scale({ x: { type: 'cat', }, y: { min: 0, }, }); chart.legend(false); chart.axis(false); /** @type {?} */ var tooltipOption = { showTitle: false, showMarkers: true, showCrosshairs: false, 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 .interval() .position('x*y') .tooltip('x*y', (/** * @param {?} x * @param {?} y * @return {?} */ function (x, y) { return ({ name: x, value: y + yTooltipSuffix }); })); chart.render(); this.attachChart(); }; /** * @private * @return {?} */ G2MiniBarComponent.prototype.attachChart = /** * @private * @return {?} */ function () { var _a = this, chart = _a.chart, height = _a.height, padding = _a.padding, data = _a.data, color = _a.color, borderWidth = _a.borderWidth; if (!chart || !data || data.length <= 0) return; chart.geometries[0].size(borderWidth).color(color); chart.height = height; chart.padding = padding; chart.changeData(data); }; /** * @return {?} */ G2MiniBarComponent.prototype.ngOnInit = /** * @return {?} */ function () { var _this = this; this.ngZone.runOutsideAngular((/** * @return {?} */ function () { return setTimeout((/** * @return {?} */ function () { return _this.install(); }), _this.delay); })); }; /** * @return {?} */ G2MiniBarComponent.prototype.ngOnChanges = /** * @return {?} */ function () { var _this = this; this.ngZone.runOutsideAngular((/** * @return {?} */ function () { return _this.attachChart(); })); }; /** * @return {?} */ G2MiniBarComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { var _this = this; if (this.chart) { this.ngZone.runOutsideAngular((/** * @return {?} */ function () { return _this.chart.destroy(); })); } }; G2MiniBarComponent.decorators = [ { type: Component, args: [{ selector: 'g2-mini-bar', exportAs: 'g2MiniBar', template: "", host: { '[style.height.px]': 'height', }, preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None }] } ]; /** @nocollapse */ G2MiniBarComponent.ctorParameters = function () { return [ { type: ElementRef }, { type: NgZone } ]; }; G2MiniBarComponent.propDecorators = { delay: [{ type: Input }], color: [{ type: Input }], height: [{ type: Input }], borderWidth: [{ type: Input }], padding: [{ type: Input }], data: [{ type: Input }], yTooltipSuffix: [{ type: Input }], tooltipType: [{ type: Input }] }; __decorate([ InputNumber(), __metadata("design:type", Object) ], G2MiniBarComponent.prototype, "delay", void 0); __decorate([ InputNumber(), __metadata("design:type", Object) ], G2MiniBarComponent.prototype, "height", void 0); __decorate([ InputNumber(), __metadata("design:type", Object) ], G2MiniBarComponent.prototype, "borderWidth", void 0); return G2MiniBarComponent; }()); export { G2MiniBarComponent }; if (false) { /** * @type {?} * @private */ G2MiniBarComponent.prototype.chart; /** @type {?} */ G2MiniBarComponent.prototype.delay; /** @type {?} */ G2MiniBarComponent.prototype.color; /** @type {?} */ G2MiniBarComponent.prototype.height; /** @type {?} */ G2MiniBarComponent.prototype.borderWidth; /** @type {?} */ G2MiniBarComponent.prototype.padding; /** @type {?} */ G2MiniBarComponent.prototype.data; /** @type {?} */ G2MiniBarComponent.prototype.yTooltipSuffix; /** @type {?} */ G2MiniBarComponent.prototype.tooltipType; /** * @type {?} * @private */ G2MiniBarComponent.prototype.el; /** * @type {?} * @private */ G2MiniBarComponent.prototype.ngZone; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mini-bar.component.js","sourceRoot":"ng://@lxlib/chart/mini-bar/","sources":["mini-bar.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  ViewEncapsulation,\n} from '@angular/core';\nimport { Chart } from '@antv/g2';\nimport { TooltipOption } from '@antv/g2/lib/interface';\nimport { InputNumber } from '@lxlib/util';\nimport { NzSafeAny } from 'ng-zorro-antd/core/types';\n\nexport interface G2MiniBarData {\n  x: any;\n  y: any;\n  [key: string]: any;\n}\n\n@Component({\n  selector: 'g2-mini-bar',\n  exportAs: 'g2MiniBar',\n  template: ``,\n  host: {\n    '[style.height.px]': 'height',\n  },\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class G2MiniBarComponent implements OnInit, OnChanges, OnDestroy {\n  private chart: Chart;\n\n  // #region fields\n\n  @Input() @InputNumber() delay = 0;\n  @Input() color = '#1890FF';\n  @Input() @InputNumber() height = 0;\n  @Input() @InputNumber() borderWidth = 5;\n  @Input() padding: number | number[] | 'auto' = [8, 8, 8, 8];\n  @Input() data: G2MiniBarData[] = [];\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, height, padding, yTooltipSuffix, tooltipType } = this;\n    const chart = (this.chart = new Chart({\n      container: el.nativeElement,\n      autoFit: true,\n      height,\n      padding,\n    }));\n    chart.scale({\n      x: {\n        type: 'cat',\n      },\n      y: {\n        min: 0,\n      },\n    });\n    chart.legend(false);\n    chart.axis(false);\n    const tooltipOption: TooltipOption = {\n      showTitle: false,\n      showMarkers: true,\n      showCrosshairs: false,\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    chart\n      .interval()\n      .position('x*y')\n      .tooltip('x*y', (x: NzSafeAny, y: NzSafeAny) => ({ name: x, value: y + yTooltipSuffix }));\n\n    chart.render();\n\n    this.attachChart();\n  }\n\n  private attachChart() {\n    const { chart, height, padding, data, color, borderWidth } = this;\n    if (!chart || !data || data.length <= 0) return;\n    chart.geometries[0].size(borderWidth).color(color);\n    chart.height = height;\n    chart.padding = padding;\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"]}