angular-advance-chart
Version:
Angular Advance Chart provides chart solution for Angular.Currently supports Bar, Pie and Donut chart
144 lines • 18.3 kB
JavaScript
import { __decorate } from "tslib";
import { Component, EventEmitter, Input, Output, } from '@angular/core';
var BarChartComponent = /** @class */ (function () {
function BarChartComponent() {
this.selectedItem = new EventEmitter();
this.chartData = [];
this.chartOptions = {
roundedCorners: false,
isHorizontal: false,
showLegend: true,
legendTitle: 'Total',
};
this.view = {
height: 200,
width: 200
};
this.lines = [];
this.totalSum = 0;
this.isHorizontal = true;
this.barLineType = 'round';
this.chartView = [];
this.scale = 100;
}
BarChartComponent.prototype.ngOnInit = function () {
var _this = this;
this.chartView.push(this.view.height + 'px');
this.chartView.push(this.view.width + 'px');
this.barLineType = this.chartOptions['roundedCorners'] ? 'round' : 'butt';
this.isHorizontal = this.chartOptions['isHorizontal'] ? true : false;
this.scale = this.isHorizontal ? this.view.width : this.view.height;
this.getTotalSum(this.chartData);
var value = Math.max.apply(Math, this.chartData.map(function (o) {
return o.value;
}));
if (value > this.scale) {
var normalizedValue_1 = value / this.scale;
this.chartData.map(function (y, index) {
_this.chartData[index]['normalized'] = Number(y.value) / normalizedValue_1;
});
}
else {
var normalizedValue_2 = this.scale / value;
this.chartData.map(function (y, index) {
_this.chartData[index]['normalized'] = Number(y.value) * normalizedValue_2;
});
}
this.lines = this.isHorizontal ? this.calculateHorizontalBarLines(this.chartData) : this.calculateVerticalBarLines(this.chartData);
};
BarChartComponent.prototype.ngAfterViewInit = function () { };
BarChartComponent.prototype.getItemClicked = function (line) {
var selectedbar = {
name: line.name,
value: line.value
};
this.selectedItem.emit(JSON.stringify(selectedbar));
};
BarChartComponent.prototype.calculateHorizontalBarLines = function (graphData) {
var _this = this;
var barLines = [];
graphData.map(function (x, index) {
var background = {
x1: 10,
y1: index * 20 + 20,
y2: index * 20 + 20,
x2: _this.view.width,
color: '#EBEBEB',
name: x.name,
value: x.value
};
barLines.push(background);
if (x.value > 0) {
var line = {
x1: 10,
y1: index * 20 + 20,
y2: index * 20 + 20,
x2: x.normalized < 10 ? _this.barLineType == 'butt' ? 11 : 10 : x.normalized,
color: x.color,
name: x.name,
value: x.value
};
barLines.push(line);
}
});
return barLines;
};
BarChartComponent.prototype.calculateVerticalBarLines = function (graphData) {
var _this = this;
var barLines = [];
graphData.map(function (x, index) {
var background = {
x1: index * 20 + 20,
y1: 10,
x2: index * 20 + 20,
y2: _this.scale,
color: '#EBEBEB',
name: x.name,
value: x.value
};
barLines.push(background);
if (x.value > 0) {
var line = {
x1: index * 20 + 20,
y1: (_this.scale + 10) - x.normalized > _this.scale ? _this.barLineType == 'butt' ? (_this.scale - 1) : _this.scale : (_this.scale + 10) - x.normalized,
x2: index * 20 + 20,
y2: _this.scale,
color: x.color,
name: x.name,
value: x.value
};
barLines.push(line);
}
});
console.log(barLines);
return barLines;
};
BarChartComponent.prototype.getTotalSum = function (chartData) {
// Get total number of records
this.totalSum = chartData.reduce(function (a, b) {
return a + parseInt(b.value);
}, 0);
};
__decorate([
Output()
], BarChartComponent.prototype, "selectedItem", void 0);
__decorate([
Input()
], BarChartComponent.prototype, "chartData", void 0);
__decorate([
Input()
], BarChartComponent.prototype, "chartOptions", void 0);
__decorate([
Input()
], BarChartComponent.prototype, "view", void 0);
BarChartComponent = __decorate([
Component({
selector: 'ngx-bar-chart',
template: "<div class=\"chart-view ngx-bar\">\n <div class=\"chart-wrapper\" [ngStyle]=\"{'height': chartView[0],'width': chartView[1]}\">\n <svg id=\"lines\" [attr.viewBox]=\"'0 0 '+ (isHorizontal ? scale+40 : (lines[lines.length-1].x1 + 20))+' ' + (isHorizontal ? (lines[lines.length-1].y2 + 20) : (scale+20))\">\n <g>\n <line *ngFor=\"let line of lines\" stroke-width=\"10\" class=\"line\" [attr.x1]=\"line.x1\" [attr.y1]=\"line.y1 \"\n [attr.x2]=\"line.x2\" [attr.y2]=\"line.y2\" [attr.stroke]=\"line.color\" \u00A0\u00A0\u00A0\u00A0\u00A0\u00A0\u00A0 [attr.stroke-linecap]=\"barLineType\"\n [attr.title]=\"line.name\" (click)=\"getItemClicked(line)\" chartTooltip tooltip={{line.name}} />\n </g>\n </svg>\n </div>\n <div class=\"legend\" *ngIf=\"chartOptions.showLegend\">\n <h4>{{chartOptions.legendTitle +' : '+ totalSum}}</h4>\n <div class=\"legend-item\" *ngFor=\"let item of chartData; let i=index\">\n <div class=\"legend-item-colour\" [ngStyle]=\"{'background': item.color}\"></div><span\n class=\"legend-item-name\">{{item.name}}</span><span class=\"legend-item-value\">{{item.value}}</span>\n </div>\n </div>\n\n</div>",
styles: [".line{cursor:pointer}"]
})
], BarChartComponent);
return BarChartComponent;
}());
export { BarChartComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bar-chart.component.js","sourceRoot":"ng://angular-advance-chart/","sources":["lib/_component/bar-chart/bar-chart.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit, Component, ElementRef, EventEmitter, Input, OnInit, Output, ViewChild,\n} from '@angular/core';\nimport { BarChartOption } from '../../_model/barChartOptions';\nimport { ChartData, ChartView } from '../../_model/chartData';\n\n\n@Component({\n  selector: 'ngx-bar-chart',\n  templateUrl: './bar-chart.component.html',\n  styleUrls: ['./bar-chart.component.scss']\n})\nexport class BarChartComponent implements OnInit, AfterViewInit {\n  @Output() selectedItem = new EventEmitter<string>();\n  @Input() chartData: ChartData[] = [];\n  @Input() chartOptions: BarChartOption = {\n    roundedCorners: false,\n    isHorizontal: false,\n    showLegend: true,\n    legendTitle: 'Total',\n  };\n  @Input() view: ChartView = {\n    height: 200,\n    width: 200\n  };\n  lines = [];\n  totalSum = 0;\n  isHorizontal = true;\n  barLineType = 'round'\n  chartView = [];\n  scale = 100;\n  constructor() { }\n\n  ngOnInit(): void {\n\n    this.chartView.push(this.view.height + 'px')\n    this.chartView.push(this.view.width + 'px')\n\n    this.barLineType = this.chartOptions['roundedCorners'] ? 'round' : 'butt'\n    this.isHorizontal = this.chartOptions['isHorizontal'] ? true : false;\n    this.scale = this.isHorizontal ? this.view.width : this.view.height;\n\n    \n\n    this.getTotalSum(this.chartData);\n    let value = Math.max.apply(\n      Math,\n      this.chartData.map(function (o) {\n        return o.value;\n      })\n    );\n    if (value > this.scale) {\n      let normalizedValue = value / this.scale;\n      this.chartData.map((y, index) => {\n        this.chartData[index]['normalized'] = Number(y.value) / normalizedValue;\n      });\n    } else {\n      let normalizedValue = this.scale / value;\n      this.chartData.map((y, index) => {\n        this.chartData[index]['normalized'] = Number(y.value) * normalizedValue;\n      });\n    }\n\n    this.lines = this.isHorizontal ? this.calculateHorizontalBarLines(this.chartData) : this.calculateVerticalBarLines(this.chartData);\n  }\n\n  ngAfterViewInit(): void { }\n\n  getItemClicked(line) {\n    let selectedbar = {\n      name: line.name,\n      value: line.value\n    }\n    this.selectedItem.emit(JSON.stringify(selectedbar));\n  }\n\n  calculateHorizontalBarLines(graphData) {\n    let barLines = [];\n    graphData.map((x, index) => {\n      let background = {\n        x1: 10,\n        y1: index * 20 + 20,\n        y2: index * 20 + 20,\n        x2: this.view.width,\n        color: '#EBEBEB',\n        name: x.name,\n        value: x.value\n      };\n      barLines.push(background)\n\n      if (x.value > 0) {\n        let line = {\n          x1: 10,\n          y1: index * 20 + 20,\n          y2: index * 20 + 20,\n          x2: x.normalized < 10 ? this.barLineType == 'butt' ? 11 : 10 : x.normalized,\n          color: x.color,\n          name: x.name,\n          value: x.value\n        };\n        barLines.push(line);\n      }\n\n    });\n    return barLines;\n  }\n\n\n  calculateVerticalBarLines(graphData) {\n    let barLines = [];\n\n    graphData.map((x, index) => {\n      let background = {\n        x1: index * 20 + 20,\n        y1: 10,\n        x2: index * 20 + 20,\n        y2: this.scale,\n        color: '#EBEBEB',\n        name: x.name,\n        value: x.value\n      };\n      barLines.push(background)\n\n      if (x.value > 0) {\n        let line = {\n          x1: index * 20 + 20,\n          y1: (this.scale+10) - x.normalized > this.scale ? this.barLineType == 'butt' ? (this.scale-1) : this.scale : (this.scale+10) - x.normalized,\n          x2: index * 20 + 20,\n          y2: this.scale,\n          color: x.color,\n          name: x.name,\n          value: x.value\n        };\n        barLines.push(line);\n\n      }\n\n    });\n    console.log(barLines)\n    return barLines;\n  }\n\n\n\n  getTotalSum(chartData) {\n    // Get total number of records\n    this.totalSum = chartData.reduce(function (a, b) {\n      return a + parseInt(b.value);\n    }, 0);\n  }\n}"]}