UNPKG

@lxlib/chart

Version:

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

242 lines 16 kB
/** * @fileoverview added by tsickle * Generated from: single-bar.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { __assign, __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'; var G2SingleBarComponent = /** @class */ (function () { // #endregion function G2SingleBarComponent(el, ngZone) { this.el = el; this.ngZone = ngZone; // #region fields this.delay = 0; this.plusColor = '#40a9ff'; this.minusColor = '#ff4d4f'; this.height = 60; this.barSize = 30; this.min = 0; this.max = 100; this.value = 0; this.line = false; this.padding = 0; this.textStyle = { fontSize: 12, color: '#595959' }; } /** * @private * @return {?} */ G2SingleBarComponent.prototype.install = /** * @private * @return {?} */ function () { var _a = this, el = _a.el, height = _a.height, padding = _a.padding, textStyle = _a.textStyle, line = _a.line, format = _a.format; /** @type {?} */ var chart = (this.chart = new Chart({ container: el.nativeElement, autoFit: true, height: height, padding: padding, })); chart.legend(false); chart.axis(false); chart.tooltip(false); chart.coordinate().transpose(); chart .interval() .position('1*value') .label('value', (/** * @return {?} */ function () { return ({ formatter: format, style: __assign({}, textStyle), }); })); if (line) { chart.annotation().line({ start: ['50%', '0%'], end: ['50%', '100%'], style: { stroke: '#e8e8e8', lineDash: [0, 0], }, }); } chart.render(); this.attachChart(); }; /** * @private * @return {?} */ G2SingleBarComponent.prototype.attachChart = /** * @private * @return {?} */ function () { var _a = this, chart = _a.chart, height = _a.height, padding = _a.padding, value = _a.value, min = _a.min, max = _a.max, plusColor = _a.plusColor, minusColor = _a.minusColor, barSize = _a.barSize; if (!chart) return; chart.scale({ value: { max: max, min: min } }); chart.height = height; chart.padding = padding; chart.geometries[0].color('value', (/** * @param {?} val * @return {?} */ function (val) { return (val > 0 ? plusColor : minusColor); })).size(barSize); chart.changeData([{ value: value }]); }; /** * @return {?} */ G2SingleBarComponent.prototype.ngOnInit = /** * @return {?} */ function () { var _this = this; this.ngZone.runOutsideAngular((/** * @return {?} */ function () { return setTimeout((/** * @return {?} */ function () { return _this.install(); }), _this.delay); })); }; /** * @return {?} */ G2SingleBarComponent.prototype.ngOnChanges = /** * @return {?} */ function () { var _this = this; this.ngZone.runOutsideAngular((/** * @return {?} */ function () { return _this.attachChart(); })); }; /** * @return {?} */ G2SingleBarComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { var _this = this; if (this.chart) { this.ngZone.runOutsideAngular((/** * @return {?} */ function () { return _this.chart.destroy(); })); } }; G2SingleBarComponent.decorators = [ { type: Component, args: [{ selector: 'g2-single-bar', exportAs: 'g2SingleBar', template: "", host: { '[style.height.px]': 'height', }, preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None }] } ]; /** @nocollapse */ G2SingleBarComponent.ctorParameters = function () { return [ { type: ElementRef }, { type: NgZone } ]; }; G2SingleBarComponent.propDecorators = { delay: [{ type: Input }], plusColor: [{ type: Input }], minusColor: [{ type: Input }], height: [{ type: Input }], barSize: [{ type: Input }], min: [{ type: Input }], max: [{ type: Input }], value: [{ type: Input }], line: [{ type: Input }], format: [{ type: Input }], padding: [{ type: Input }], textStyle: [{ type: Input }] }; __decorate([ InputNumber(), __metadata("design:type", Object) ], G2SingleBarComponent.prototype, "delay", void 0); __decorate([ InputNumber(), __metadata("design:type", Object) ], G2SingleBarComponent.prototype, "height", void 0); __decorate([ InputNumber(), __metadata("design:type", Object) ], G2SingleBarComponent.prototype, "barSize", void 0); __decorate([ InputNumber(), __metadata("design:type", Object) ], G2SingleBarComponent.prototype, "min", void 0); __decorate([ InputNumber(), __metadata("design:type", Object) ], G2SingleBarComponent.prototype, "max", void 0); __decorate([ InputNumber(), __metadata("design:type", Object) ], G2SingleBarComponent.prototype, "value", void 0); __decorate([ InputBoolean(), __metadata("design:type", Object) ], G2SingleBarComponent.prototype, "line", void 0); return G2SingleBarComponent; }()); export { G2SingleBarComponent }; if (false) { /** * @type {?} * @private */ G2SingleBarComponent.prototype.chart; /** @type {?} */ G2SingleBarComponent.prototype.delay; /** @type {?} */ G2SingleBarComponent.prototype.plusColor; /** @type {?} */ G2SingleBarComponent.prototype.minusColor; /** @type {?} */ G2SingleBarComponent.prototype.height; /** @type {?} */ G2SingleBarComponent.prototype.barSize; /** @type {?} */ G2SingleBarComponent.prototype.min; /** @type {?} */ G2SingleBarComponent.prototype.max; /** @type {?} */ G2SingleBarComponent.prototype.value; /** @type {?} */ G2SingleBarComponent.prototype.line; /** @type {?} */ G2SingleBarComponent.prototype.format; /** @type {?} */ G2SingleBarComponent.prototype.padding; /** @type {?} */ G2SingleBarComponent.prototype.textStyle; /** * @type {?} * @private */ G2SingleBarComponent.prototype.el; /** * @type {?} * @private */ G2SingleBarComponent.prototype.ngZone; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"single-bar.component.js","sourceRoot":"ng://@lxlib/chart/single-bar/","sources":["single-bar.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;AACjC,OAAO,EAAE,YAAY,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAExD;IA6BE,aAAa;IAEb,8BAAoB,EAAc,EAAU,MAAc;QAAtC,OAAE,GAAF,EAAE,CAAY;QAAU,WAAM,GAAN,MAAM,CAAQ;;QAflC,UAAK,GAAG,CAAC,CAAC;QACzB,cAAS,GAAG,SAAS,CAAC;QACtB,eAAU,GAAG,SAAS,CAAC;QACR,WAAM,GAAG,EAAE,CAAC;QACZ,YAAO,GAAG,EAAE,CAAC;QACb,QAAG,GAAG,CAAC,CAAC;QACR,QAAG,GAAG,GAAG,CAAC;QACV,UAAK,GAAG,CAAC,CAAC;QACT,SAAI,GAAG,KAAK,CAAC;QAE7B,YAAO,GAA+B,CAAC,CAAC;QACxC,cAAS,GAAQ,EAAE,QAAQ,EAAE,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC;IAIA,CAAC;;;;;IAEtD,sCAAO;;;;IAAf;QACQ,IAAA,SAAuD,EAArD,UAAE,EAAE,kBAAM,EAAE,oBAAO,EAAE,wBAAS,EAAE,cAAI,EAAE,kBAAe;;YACvD,KAAK,GAAG,CAAC,IAAI,CAAC,KAAK,GAAG,IAAI,KAAK,CAAC;YACpC,SAAS,EAAE,EAAE,CAAC,aAAa;YAC3B,OAAO,EAAE,IAAI;YACb,MAAM,QAAA;YACN,OAAO,SAAA;SACR,CAAC,CAAC;QACH,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACpB,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAClB,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACrB,KAAK,CAAC,UAAU,EAAE,CAAC,SAAS,EAAE,CAAC;QAC/B,KAAK;aACF,QAAQ,EAAE;aACV,QAAQ,CAAC,SAAS,CAAC;aACnB,KAAK,CAAC,OAAO;;;QAAE,cAAM,OAAA,CAAC;YACrB,SAAS,EAAE,MAAM;YACjB,KAAK,eACA,SAAS,CACb;SACF,CAAC,EALoB,CAKpB,EAAC,CAAC;QAEN,IAAI,IAAI,EAAE;YACR,KAAK,CAAC,UAAU,EAAE,CAAC,IAAI,CAAC;gBACtB,KAAK,EAAE,CAAC,KAAK,EAAE,IAAI,CAAC;gBACpB,GAAG,EAAE,CAAC,KAAK,EAAE,MAAM,CAAC;gBACpB,KAAK,EAAE;oBACL,MAAM,EAAE,SAAS;oBACjB,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;iBACjB;aACF,CAAC,CAAC;SACJ;QAED,KAAK,CAAC,MAAM,EAAE,CAAC;QAEf,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;;;;;IAEO,0CAAW;;;;IAAnB;QACQ,IAAA,SAAkF,EAAhF,gBAAK,EAAE,kBAAM,EAAE,oBAAO,EAAE,gBAAK,EAAE,YAAG,EAAE,YAAG,EAAE,wBAAS,EAAE,0BAAU,EAAE,oBAAgB;QACxF,IAAI,CAAC,KAAK;YAAE,OAAO;QACnB,KAAK,CAAC,KAAK,CAAC,EAAE,KAAK,EAAE,EAAE,GAAG,KAAA,EAAE,GAAG,KAAA,EAAE,EAAE,CAAC,CAAC;QACrC,KAAK,CAAC,MAAM,GAAG,MAAM,CAAC;QACtB,KAAK,CAAC,OAAO,GAAG,OAAO,CAAC;QACxB,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO;;;;QAAE,UAAC,GAAW,IAAK,OAAA,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,CAAC,EAAlC,CAAkC,EAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACtG,KAAK,CAAC,UAAU,CAAC,CAAC,EAAE,KAAK,OAAA,EAAE,CAAC,CAAC,CAAC;IAChC,CAAC;;;;IAED,uCAAQ;;;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,0CAAW;;;IAAX;QAAA,iBAEC;QADC,IAAI,CAAC,MAAM,CAAC,iBAAiB;;;QAAC,cAAM,OAAA,KAAI,CAAC,WAAW,EAAE,EAAlB,CAAkB,EAAC,CAAC;IAC1D,CAAC;;;;IAED,0CAAW;;;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;;gBA7FF,SAAS,SAAC;oBACT,QAAQ,EAAE,eAAe;oBACzB,QAAQ,EAAE,aAAa;oBACvB,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;;;;gBArBC,UAAU;gBAEV,MAAM;;;wBAyBL,KAAK;4BACL,KAAK;6BACL,KAAK;yBACL,KAAK;0BACL,KAAK;sBACL,KAAK;sBACL,KAAK;wBACL,KAAK;uBACL,KAAK;yBACL,KAAK;0BACL,KAAK;4BACL,KAAK;;IAXkB;QAAd,WAAW,EAAE;;uDAAW;IAGV;QAAd,WAAW,EAAE;;wDAAa;IACZ;QAAd,WAAW,EAAE;;yDAAc;IACb;QAAd,WAAW,EAAE;;qDAAS;IACR;QAAd,WAAW,EAAE;;qDAAW;IACV;QAAd,WAAW,EAAE;;uDAAW;IACT;QAAf,YAAY,EAAE;;sDAAc;IAsExC,2BAAC;CAAA,AA9FD,IA8FC;SAnFY,oBAAoB;;;;;;IAC/B,qCAAqB;;IAIrB,qCAAkC;;IAClC,yCAA+B;;IAC/B,0CAAgC;;IAChC,sCAAoC;;IACpC,uCAAqC;;IACrC,mCAAgC;;IAChC,mCAAkC;;IAClC,qCAAkC;;IAClC,oCAAsC;;IACtC,sCAAoE;;IACpE,uCAAiD;;IACjD,yCAA6D;;;;;IAIjD,kCAAsB;;;;;IAAE,sCAAsB","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 { InputBoolean, InputNumber } from '@lxlib/util';\n\n@Component({\n  selector: 'g2-single-bar',\n  exportAs: 'g2SingleBar',\n  template: ``,\n  host: {\n    '[style.height.px]': 'height',\n  },\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class G2SingleBarComponent implements OnInit, OnChanges, OnDestroy {\n  private chart: Chart;\n\n  // #region fields\n\n  @Input() @InputNumber() delay = 0;\n  @Input() plusColor = '#40a9ff';\n  @Input() minusColor = '#ff4d4f';\n  @Input() @InputNumber() height = 60;\n  @Input() @InputNumber() barSize = 30;\n  @Input() @InputNumber() min = 0;\n  @Input() @InputNumber() max = 100;\n  @Input() @InputNumber() value = 0;\n  @Input() @InputBoolean() line = false;\n  @Input() format: (value: number, item: {}, index: number) => string;\n  @Input() padding: number | number[] | 'auto' = 0;\n  @Input() textStyle: any = { fontSize: 12, color: '#595959' };\n\n  // #endregion\n\n  constructor(private el: ElementRef, private ngZone: NgZone) {}\n\n  private install() {\n    const { el, height, padding, textStyle, line, format } = this;\n    const chart = (this.chart = new Chart({\n      container: el.nativeElement,\n      autoFit: true,\n      height,\n      padding,\n    }));\n    chart.legend(false);\n    chart.axis(false);\n    chart.tooltip(false);\n    chart.coordinate().transpose();\n    chart\n      .interval()\n      .position('1*value')\n      .label('value', () => ({\n        formatter: format,\n        style: {\n          ...textStyle,\n        },\n      }));\n\n    if (line) {\n      chart.annotation().line({\n        start: ['50%', '0%'],\n        end: ['50%', '100%'],\n        style: {\n          stroke: '#e8e8e8',\n          lineDash: [0, 0],\n        },\n      });\n    }\n\n    chart.render();\n\n    this.attachChart();\n  }\n\n  private attachChart() {\n    const { chart, height, padding, value, min, max, plusColor, minusColor, barSize } = this;\n    if (!chart) return;\n    chart.scale({ value: { max, min } });\n    chart.height = height;\n    chart.padding = padding;\n    chart.geometries[0].color('value', (val: number) => (val > 0 ? plusColor : minusColor)).size(barSize);\n    chart.changeData([{ value }]);\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"]}