UNPKG

angular-advance-chart

Version:

Angular Advance Chart provides chart solution for Angular.Currently supports Bar, Pie and Donut chart

116 lines 15 kB
import { __decorate } from "tslib"; import { Component, EventEmitter, Input, Output, ViewChildren } from '@angular/core'; let DonutChartComponent = class DonutChartComponent { constructor() { this.selectedItem = new EventEmitter(); this.chartOptions = { showLegend: true, legendTitle: 'Total', }; this.view = { height: 200, width: 200, radius: 80, donutSize: 20 }; this.totalSum = 0; this.processedData = []; this.legendData = []; this.chartView = []; } ngOnInit() { if (this.chartData) { this.view['donutSize'] = this.view['donutSize'] ? this.view['donutSize'] : 20; this.chartView.push(this.view.height + 'px'); this.chartView.push(this.view.width + 'px'); // Get total number of records this.totalSum = this.chartData.reduce(function (a, b) { return a + b.value; }, 0); //generate Data for list let prevAngle = 0; this.chartData.map((x, index) => { let legend = { name: x.name, value: x.value, color: x.color }; this.legendData.push(legend); let percentage = this.getPercentage(x.value, this.totalSum); if (percentage > 0) { let circlePercentage = percentage / 10 * 36; let pieData = { color: x.color, a1: prevAngle, a2: prevAngle + circlePercentage, name: x.name }; prevAngle = prevAngle + circlePercentage; this.processedData.push(pieData); } }); } } getPercentage(partialValue, totalValue) { return (100 * partialValue) / totalValue; } ngAfterViewInit() { //create svg if (this.processedData.length > 0) { this.span.map((item, index) => { item.nativeElement.setAttribute('d', this.describeArc(this.view.height / 2, this.view.width / 2, this.view.radius, this.processedData[index].a1, this.processedData[index].a2 == 360 ? 359.99 : this.processedData[index].a2)); item.nativeElement.setAttribute('stroke', this.processedData[index].color); }); } } polarToCartesian(centerX, centerY, radius, angleInDegrees) { let angleInRadians = (angleInDegrees - 90) * Math.PI / 180.0; return { x: centerX + (radius * Math.cos(angleInRadians)), y: centerY + (radius * Math.sin(angleInRadians)) }; } describeArc(x, y, radius, startAngle, endAngle) { let start = this.polarToCartesian(x, y, radius, endAngle); let end = this.polarToCartesian(x, y, radius, startAngle); let largeArcFlag = endAngle - startAngle <= 180 ? "0" : "1"; let d = [ "M", start.x, start.y, "A", radius, radius, 0, largeArcFlag, 0, end.x, end.y ].join(" "); return d; } getItemClicked(item) { let selected = { name: item.name, value: item.value }; this.selectedItem.emit(selected); } show(status) { } }; __decorate([ Input() ], DonutChartComponent.prototype, "chartData", void 0); __decorate([ Output() ], DonutChartComponent.prototype, "selectedItem", void 0); __decorate([ ViewChildren('el') ], DonutChartComponent.prototype, "span", void 0); __decorate([ Input() ], DonutChartComponent.prototype, "chartOptions", void 0); __decorate([ Input() ], DonutChartComponent.prototype, "view", void 0); DonutChartComponent = __decorate([ Component({ selector: 'ngx-donut-chart', template: "<div class=\"chart-view ngx-donut\">\n <svg class=\"chart-wrapper\" [ngStyle]=\"{'height': chartView[0],'width': chartView[1]}\">\n <path width=\"100%\" height=\"100%\" #el fill=\"none\" [attr.stroke-width]=\"this.view.donutSize\" *ngFor=\"let item of processedData; let i=index\"\n (click)=\"getItemClicked(item)\" chartTooltip tooltip={{item.name}}/>\n\n </svg>\n <div class=\"legend\" *ngIf=\"chartOptions.showLegend\">\n <h4>{{chartOptions.legendTitle +' : '+ totalSum}}</h4>\n <div class=\"legend-item\" *ngFor=\"let item of legendData; let i=index\" >\n <div class=\"legend-item-colour\" [ngStyle]=\"{'background': item.color}\"></div><span class=\"legend-item-name\" >{{item.name}}</span><span class=\"legend-item-value\" >{{item.value}}</span>\n </div>\n </div>\n</div>", styles: ["path:hover{cursor:pointer}"] }) ], DonutChartComponent); export { DonutChartComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"donut-chart.component.js","sourceRoot":"ng://angular-advance-chart/","sources":["lib/_component/donut-chart/donut-chart.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnInit, Output, QueryList, ViewChildren } from '@angular/core';\nimport { ChartData, ChartOption } from '../../_model/chartData';\nimport { DonutChartView } from '../../_model/donutChartOptions';\n\n\n@Component({\n  selector: 'ngx-donut-chart',\n  templateUrl: './donut-chart.component.html',\n  styleUrls: ['./donut-chart.component.scss']\n})\nexport class DonutChartComponent implements OnInit {\n\n  @Input() chartData: ChartData[];\n  @Output() selectedItem = new EventEmitter<any>();\n  @ViewChildren('el') span: QueryList<ElementRef>;\n  @Input() chartOptions: ChartOption = {\n    showLegend: true,\n    legendTitle: 'Total',\n  }\n  @Input() view: DonutChartView = {\n    height: 200,\n    width: 200,\n    radius: 80,\n    donutSize: 20\n  }\n  totalSum = 0;\n  processedData = [];\n  legendData = [];\n  chartView = [];\n  constructor() { }\n\n  ngOnInit(): void {\n    if (this.chartData) {\n      this.view['donutSize'] = this.view['donutSize'] ? this.view['donutSize'] : 20;\n      this.chartView.push(this.view.height + 'px')\n      this.chartView.push(this.view.width + 'px')\n\n      // Get total number of records\n      this.totalSum = this.chartData.reduce(function (a, b) {\n        return a + b.value;\n      }, 0);\n\n      //generate Data for list\n      let prevAngle = 0\n      this.chartData.map((x, index) => {\n        let legend = {\n          name: x.name,\n          value: x.value,\n          color: x.color\n        }\n\n        this.legendData.push(legend)\n        let percentage = this.getPercentage(x.value, this.totalSum);\n        if (percentage > 0) {\n          let circlePercentage = percentage / 10 * 36;\n          let pieData = {\n            color: x.color,\n            a1: prevAngle,\n            a2: prevAngle + circlePercentage,\n            name: x.name\n          }\n          prevAngle = prevAngle + circlePercentage\n          this.processedData.push(pieData);\n        }\n      });\n    }\n  }\n\n\n  getPercentage(partialValue, totalValue): number {\n    return (100 * partialValue) / totalValue;\n  }\n\n  ngAfterViewInit(): void {\n\n    //create svg\n    if (this.processedData.length > 0) {\n      this.span.map((item: ElementRef, index) => {\n        item.nativeElement.setAttribute('d', this.describeArc(this.view.height / 2, this.view.width / 2, this.view.radius, this.processedData[index].a1, this.processedData[index].a2 == 360 ? 359.99 : this.processedData[index].a2));\n        item.nativeElement.setAttribute('stroke', this.processedData[index].color);\n      });\n    }\n\n  }\n\n\n  polarToCartesian(centerX, centerY, radius, angleInDegrees) {\n    let angleInRadians = (angleInDegrees - 90) * Math.PI / 180.0;\n\n    return {\n      x: centerX + (radius * Math.cos(angleInRadians)),\n      y: centerY + (radius * Math.sin(angleInRadians))\n    };\n  }\n\n  describeArc(x, y, radius, startAngle, endAngle) {\n    let start = this.polarToCartesian(x, y, radius, endAngle);\n    let end = this.polarToCartesian(x, y, radius, startAngle);\n    let largeArcFlag = endAngle - startAngle <= 180 ? \"0\" : \"1\";\n\n    let d = [\n      \"M\", start.x, start.y,\n      \"A\", radius, radius, 0, largeArcFlag, 0, end.x, end.y\n    ].join(\" \");\n\n    return d;\n  }\n\n  getItemClicked(item) {\n    let selected = {\n      name: item.name,\n      value: item.value\n    }\n    this.selectedItem.emit(selected);\n  }\n\n  show(status) {\n  }\n}\n"]}