@lxlib/chart
Version:
This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 9.1.1.
308 lines • 19.8 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: 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, ViewChild, ViewEncapsulation, } from '@angular/core';
import { Chart } from '@antv/g2';
import { InputBoolean, InputNumber } from '@lxlib/util';
import { fromEvent } from 'rxjs';
import { debounceTime, filter } from 'rxjs/operators';
/** @type {?} */
var TITLE_HEIGHT = 41;
/**
* @record
*/
export function G2BarData() { }
if (false) {
/** @type {?} */
G2BarData.prototype.x;
/** @type {?} */
G2BarData.prototype.y;
/** @type {?|undefined} */
G2BarData.prototype.color;
/* Skipping unhandled member: [key: string]: any;*/
}
var G2BarComponent = /** @class */ (function () {
// #endregion
function G2BarComponent(ngZone) {
this.ngZone = ngZone;
// #region fields
this.delay = 0;
this.color = 'rgba(24, 144, 255, 0.85)';
this.height = 0;
this.padding = 'auto';
this.data = [];
this.autoLabel = true;
this.interaction = 'none';
}
/**
* @private
* @return {?}
*/
G2BarComponent.prototype.getHeight = /**
* @private
* @return {?}
*/
function () {
return this.title ? this.height - TITLE_HEIGHT : this.height;
};
/**
* @private
* @return {?}
*/
G2BarComponent.prototype.install = /**
* @private
* @return {?}
*/
function () {
var _this = this;
var _a = this, node = _a.node, padding = _a.padding, interaction = _a.interaction;
/** @type {?} */
var container = (/** @type {?} */ (node.nativeElement));
/** @type {?} */
var chart = (this.chart = new Chart({
container: container,
autoFit: true,
height: this.getHeight(),
padding: padding,
}));
this.updatelabel();
chart.axis('y', {
title: null,
line: null,
tickLine: null,
});
chart.scale({
x: {
type: 'cat',
},
y: {
min: 0,
},
});
chart.tooltip({
showTitle: false,
});
if (interaction !== 'none') {
chart.interaction(interaction);
}
chart.legend(false);
chart
.interval()
.position('x*y')
.color('x*y', (/**
* @param {?} x
* @param {?} y
* @return {?}
*/
function (x, y) {
/** @type {?} */
var colorItem = _this.data.find((/**
* @param {?} w
* @return {?}
*/
function (w) { return w.x === x && w.y === y; }));
return colorItem && colorItem.color ? colorItem.color : _this.color;
}))
.tooltip('x*y', (/**
* @param {?} x
* @param {?} y
* @return {?}
*/
function (x, y) { return ({ name: x, value: y }); }));
this.attachChart();
};
/**
* @private
* @return {?}
*/
G2BarComponent.prototype.attachChart = /**
* @private
* @return {?}
*/
function () {
var _a = this, chart = _a.chart, padding = _a.padding, data = _a.data;
if (!chart || !data || data.length <= 0)
return;
this.installResizeEvent();
/** @type {?} */
var height = this.getHeight();
if (chart.height !== height) {
chart.height = height;
}
chart.padding = padding;
chart.data(data);
chart.render();
};
/**
* @private
* @return {?}
*/
G2BarComponent.prototype.updatelabel = /**
* @private
* @return {?}
*/
function () {
var _a = this, node = _a.node, data = _a.data, chart = _a.chart;
/** @type {?} */
var canvasWidth = node.nativeElement.clientWidth;
/** @type {?} */
var minWidth = data.length * 30;
chart.axis('x', canvasWidth > minWidth).render();
};
/**
* @private
* @return {?}
*/
G2BarComponent.prototype.installResizeEvent = /**
* @private
* @return {?}
*/
function () {
var _this = this;
if (!this.autoLabel || this.resize$)
return;
this.resize$ = fromEvent(window, 'resize')
.pipe(filter((/**
* @return {?}
*/
function () { return !!_this.chart; })), debounceTime(200))
.subscribe((/**
* @return {?}
*/
function () { return _this.ngZone.runOutsideAngular((/**
* @return {?}
*/
function () { return _this.updatelabel(); })); }));
};
/**
* @return {?}
*/
G2BarComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
function () { return setTimeout((/**
* @return {?}
*/
function () { return _this.install(); }), _this.delay); }));
};
/**
* @return {?}
*/
G2BarComponent.prototype.ngOnChanges = /**
* @return {?}
*/
function () {
var _this = this;
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
function () { return _this.attachChart(); }));
};
/**
* @return {?}
*/
G2BarComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
var _this = this;
if (this.resize$) {
this.resize$.unsubscribe();
}
if (this.chart) {
this.ngZone.runOutsideAngular((/**
* @return {?}
*/
function () { return _this.chart.destroy(); }));
}
};
G2BarComponent.decorators = [
{ type: Component, args: [{
selector: 'g2-bar',
exportAs: 'g2Bar',
template: "<ng-container *nzStringTemplateOutlet=\"title\">\n <h4 style=\"margin-bottom:20px\">{{title}}</h4>\n</ng-container>\n<div #container></div>\n",
host: {
'[style.height.px]': 'height',
},
preserveWhitespaces: false,
changeDetection: ChangeDetectionStrategy.OnPush,
encapsulation: ViewEncapsulation.None
}] }
];
/** @nocollapse */
G2BarComponent.ctorParameters = function () { return [
{ type: NgZone }
]; };
G2BarComponent.propDecorators = {
node: [{ type: ViewChild, args: ['container', { static: true },] }],
delay: [{ type: Input }],
title: [{ type: Input }],
color: [{ type: Input }],
height: [{ type: Input }],
padding: [{ type: Input }],
data: [{ type: Input }],
autoLabel: [{ type: Input }],
interaction: [{ type: Input }]
};
__decorate([
InputNumber(),
__metadata("design:type", Object)
], G2BarComponent.prototype, "delay", void 0);
__decorate([
InputNumber(),
__metadata("design:type", Object)
], G2BarComponent.prototype, "height", void 0);
__decorate([
InputBoolean(),
__metadata("design:type", Object)
], G2BarComponent.prototype, "autoLabel", void 0);
return G2BarComponent;
}());
export { G2BarComponent };
if (false) {
/**
* @type {?}
* @private
*/
G2BarComponent.prototype.resize$;
/**
* @type {?}
* @private
*/
G2BarComponent.prototype.chart;
/**
* @type {?}
* @private
*/
G2BarComponent.prototype.node;
/** @type {?} */
G2BarComponent.prototype.delay;
/** @type {?} */
G2BarComponent.prototype.title;
/** @type {?} */
G2BarComponent.prototype.color;
/** @type {?} */
G2BarComponent.prototype.height;
/** @type {?} */
G2BarComponent.prototype.padding;
/** @type {?} */
G2BarComponent.prototype.data;
/** @type {?} */
G2BarComponent.prototype.autoLabel;
/** @type {?} */
G2BarComponent.prototype.interaction;
/**
* @type {?}
* @private
*/
G2BarComponent.prototype.ngZone;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bar.component.js","sourceRoot":"ng://@lxlib/chart/bar/","sources":["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  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { Chart } from '@antv/g2';\nimport { InteractionType } from '@lxlib/chart/core/types';\nimport { InputBoolean, InputNumber } from '@lxlib/util';\nimport { fromEvent, Subscription } from 'rxjs';\nimport { debounceTime, filter } from 'rxjs/operators';\n\nconst TITLE_HEIGHT = 41;\n\nexport interface G2BarData {\n  x: any;\n  y: any;\n  color?: string;\n  [key: string]: any;\n}\n\n@Component({\n  selector: 'g2-bar',\n  exportAs: 'g2Bar',\n  templateUrl: './bar.component.html',\n  host: {\n    '[style.height.px]': 'height',\n  },\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class G2BarComponent implements OnInit, OnChanges, OnDestroy {\n  private resize$: Subscription;\n  private chart: Chart;\n  @ViewChild('container', { static: true }) private node: ElementRef;\n\n  // #region fields\n\n  @Input() @InputNumber() delay = 0;\n  @Input() title: string | TemplateRef<void>;\n  @Input() color = 'rgba(24, 144, 255, 0.85)';\n  @Input() @InputNumber() height = 0;\n  @Input() padding: number | number[] | 'auto' = 'auto';\n  @Input() data: G2BarData[] = [];\n  @Input() @InputBoolean() autoLabel = true;\n  @Input() interaction: InteractionType = 'none';\n\n  // #endregion\n\n  constructor(private ngZone: NgZone) {}\n\n  private getHeight() {\n    return this.title ? this.height - TITLE_HEIGHT : this.height;\n  }\n\n  private install() {\n    const { node, padding, interaction } = this;\n\n    const container = node.nativeElement as HTMLElement;\n    const chart = (this.chart = new Chart({\n      container,\n      autoFit: true,\n      height: this.getHeight(),\n      padding,\n    }));\n    this.updatelabel();\n    chart.axis('y', {\n      title: null,\n      line: null,\n      tickLine: null,\n    });\n    chart.scale({\n      x: {\n        type: 'cat',\n      },\n      y: {\n        min: 0,\n      },\n    });\n    chart.tooltip({\n      showTitle: false,\n    });\n    if (interaction !== 'none') {\n      chart.interaction(interaction);\n    }\n    chart.legend(false);\n    chart\n      .interval()\n      .position('x*y')\n      .color('x*y', (x, y) => {\n        const colorItem = this.data.find(w => w.x === x && w.y === y);\n        return colorItem && colorItem.color ? colorItem.color : this.color;\n      })\n      .tooltip('x*y', (x, y) => ({ name: x, value: y }));\n\n    this.attachChart();\n  }\n\n  private attachChart() {\n    const { chart, padding, data } = this;\n    if (!chart || !data || data.length <= 0) return;\n    this.installResizeEvent();\n    const height = this.getHeight();\n    if (chart.height !== height) {\n      chart.height = height;\n    }\n    chart.padding = padding;\n\n    chart.data(data);\n    chart.render();\n  }\n\n  private updatelabel() {\n    const { node, data, chart } = this;\n    const canvasWidth = node.nativeElement.clientWidth;\n    const minWidth = data.length * 30;\n    chart.axis('x', canvasWidth > minWidth).render();\n  }\n\n  private installResizeEvent() {\n    if (!this.autoLabel || this.resize$) return;\n\n    this.resize$ = fromEvent(window, 'resize')\n      .pipe(\n        filter(() => !!this.chart),\n        debounceTime(200),\n      )\n      .subscribe(() => this.ngZone.runOutsideAngular(() => this.updatelabel()));\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.resize$) {\n      this.resize$.unsubscribe();\n    }\n    if (this.chart) {\n      this.ngZone.runOutsideAngular(() => this.chart.destroy());\n    }\n  }\n}\n"]}