aril 0.1.36 → 0.1.38
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/ui/charts/src/highCharts/bar/bar-chart.component.mjs +38 -25
- package/esm2022/ui/charts/src/highCharts/column/column-chart.component.mjs +68 -36
- package/esm2022/ui/charts/src/highCharts/pie/pie-chart.component.mjs +76 -30
- package/fesm2022/aril-ui-charts.mjs +177 -86
- package/fesm2022/aril-ui-charts.mjs.map +1 -1
- package/package.json +152 -150
- package/ui/charts/src/highCharts/bar/bar-chart.component.d.ts +5 -3
- package/ui/charts/src/highCharts/column/column-chart.component.d.ts +10 -6
- package/ui/charts/src/highCharts/pie/pie-chart.component.d.ts +10 -5
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { ChangeDetectionStrategy, Component, input } from '@angular/core';
|
|
2
2
|
import * as Highcharts from 'highcharts';
|
|
3
3
|
import { HighchartsChartModule } from 'highcharts-angular';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
@@ -18,42 +18,55 @@ export class BarHighChartComponent {
|
|
|
18
18
|
this.categoriesTitle = input('');
|
|
19
19
|
this.valuesTitle = input('');
|
|
20
20
|
this.seriesName = input();
|
|
21
|
+
this.width = input('460');
|
|
22
|
+
this.height = input('380');
|
|
21
23
|
this.Highcharts = Highcharts;
|
|
22
24
|
this.chartOptions = {}; // Highcharts.Options
|
|
23
25
|
}
|
|
24
26
|
setChartOptions() {
|
|
25
27
|
this.chartOptions = {
|
|
26
28
|
chart: {
|
|
27
|
-
type: 'bar'
|
|
29
|
+
type: 'bar',
|
|
30
|
+
height: this.height(),
|
|
31
|
+
width: this.width()
|
|
28
32
|
},
|
|
29
33
|
title: {
|
|
30
|
-
text: this.title()
|
|
34
|
+
text: this.title()
|
|
31
35
|
},
|
|
32
36
|
xAxis: {
|
|
33
|
-
categories: this.data().map(item => item.name),
|
|
37
|
+
categories: this.data().map((item) => item.name),
|
|
34
38
|
title: {
|
|
35
|
-
text: this.categoriesTitle()
|
|
36
|
-
}
|
|
39
|
+
text: this.categoriesTitle()
|
|
40
|
+
}
|
|
37
41
|
},
|
|
38
42
|
yAxis: {
|
|
39
43
|
min: 0,
|
|
40
44
|
title: {
|
|
41
|
-
text: this.valuesTitle()
|
|
42
|
-
}
|
|
45
|
+
text: this.valuesTitle()
|
|
46
|
+
}
|
|
43
47
|
},
|
|
44
48
|
tooltip: {
|
|
45
|
-
|
|
49
|
+
formatter: function () {
|
|
50
|
+
return `
|
|
51
|
+
<strong>${this.point.category}</strong><br>
|
|
52
|
+
Değer: <b>${this.point.y.toLocaleString('tr-TR', {
|
|
53
|
+
minimumFractionDigits: 2,
|
|
54
|
+
maximumFractionDigits: 2
|
|
55
|
+
})}</b>
|
|
56
|
+
`;
|
|
57
|
+
},
|
|
58
|
+
useHTML: true
|
|
46
59
|
},
|
|
47
60
|
series: [
|
|
48
61
|
{
|
|
49
62
|
name: this.seriesName(),
|
|
50
|
-
data: this.data().map(item => item.y)
|
|
63
|
+
data: this.data().map((item) => item.y)
|
|
51
64
|
}
|
|
52
65
|
],
|
|
53
66
|
legend: { enabled: this.seriesName() ? true : false },
|
|
54
67
|
credits: {
|
|
55
|
-
enabled: false
|
|
56
|
-
}
|
|
68
|
+
enabled: false
|
|
69
|
+
}
|
|
57
70
|
};
|
|
58
71
|
}
|
|
59
72
|
ngOnChanges(changes) {
|
|
@@ -62,26 +75,26 @@ export class BarHighChartComponent {
|
|
|
62
75
|
}
|
|
63
76
|
}
|
|
64
77
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: BarHighChartComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
65
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.1.2", type: BarHighChartComponent, isStandalone: true, selector: "aril-bar-highchart", inputs: { data: { classPropertyName: "data", publicName: "data", isSignal: true, isRequired: true, transformFunction: null }, title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: false, transformFunction: null }, categoriesTitle: { classPropertyName: "categoriesTitle", publicName: "categoriesTitle", isSignal: true, isRequired: false, transformFunction: null }, valuesTitle: { classPropertyName: "valuesTitle", publicName: "valuesTitle", isSignal: true, isRequired: false, transformFunction: null }, seriesName: { classPropertyName: "seriesName", publicName: "seriesName", isSignal: true, isRequired: false, transformFunction: null } }, usesOnChanges: true, ngImport: i0, template: `
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
78
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.1.2", type: BarHighChartComponent, isStandalone: true, selector: "aril-bar-highchart", inputs: { data: { classPropertyName: "data", publicName: "data", isSignal: true, isRequired: true, transformFunction: null }, title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: false, transformFunction: null }, categoriesTitle: { classPropertyName: "categoriesTitle", publicName: "categoriesTitle", isSignal: true, isRequired: false, transformFunction: null }, valuesTitle: { classPropertyName: "valuesTitle", publicName: "valuesTitle", isSignal: true, isRequired: false, transformFunction: null }, seriesName: { classPropertyName: "seriesName", publicName: "seriesName", isSignal: true, isRequired: false, transformFunction: null }, width: { classPropertyName: "width", publicName: "width", isSignal: true, isRequired: false, transformFunction: null }, height: { classPropertyName: "height", publicName: "height", isSignal: true, isRequired: false, transformFunction: null } }, usesOnChanges: true, ngImport: i0, template: ` <highcharts-chart
|
|
79
|
+
style="width: 100%; display: block"
|
|
80
|
+
[Highcharts]="Highcharts"
|
|
81
|
+
[options]="chartOptions"
|
|
82
|
+
[oneToOne]="true">
|
|
83
|
+
</highcharts-chart>`, isInline: true, dependencies: [{ kind: "ngmodule", type: HighchartsChartModule }, { kind: "component", type: i1.HighchartsChartComponent, selector: "highcharts-chart", inputs: ["Highcharts", "constructorType", "callbackFunction", "oneToOne", "runOutsideAngular", "options", "update"], outputs: ["updateChange", "chartInstance"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
71
84
|
}
|
|
72
85
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: BarHighChartComponent, decorators: [{
|
|
73
86
|
type: Component,
|
|
74
87
|
args: [{
|
|
75
88
|
standalone: true,
|
|
76
89
|
selector: 'aril-bar-highchart',
|
|
77
|
-
template: `
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
90
|
+
template: ` <highcharts-chart
|
|
91
|
+
style="width: 100%; display: block"
|
|
92
|
+
[Highcharts]="Highcharts"
|
|
93
|
+
[options]="chartOptions"
|
|
94
|
+
[oneToOne]="true">
|
|
95
|
+
</highcharts-chart>`,
|
|
83
96
|
imports: [HighchartsChartModule],
|
|
84
97
|
changeDetection: ChangeDetectionStrategy.OnPush
|
|
85
98
|
}]
|
|
86
99
|
}] });
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFyLWNoYXJ0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FyaWwvdWkvY2hhcnRzL3NyYy9oaWdoQ2hhcnRzL2Jhci9iYXItY2hhcnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxTQUFTLEVBQTRCLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVwRyxPQUFPLEtBQUssVUFBVSxNQUFNLFlBQVksQ0FBQztBQUN6QyxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQzs7O0FBVTNELGVBQWU7QUFDZixXQUFXO0FBQ1gsbUNBQW1DO0FBQ25DLG1DQUFtQztBQUNuQyxtQ0FBbUM7QUFDbkMsbUNBQW1DO0FBQ25DLG1DQUFtQztBQUNuQyxJQUFJO0FBZUosTUFBTSxPQUFPLHFCQUFxQjtJQWJsQztRQWNDLFNBQUksR0FBRyxLQUFLLENBQUMsUUFBUSxFQUFlLENBQUM7UUFDckMsVUFBSyxHQUFHLEtBQUssQ0FBUyxFQUFFLENBQUMsQ0FBQztRQUMxQixvQkFBZSxHQUFHLEtBQUssQ0FBUyxFQUFFLENBQUMsQ0FBQztRQUNwQyxnQkFBVyxHQUFHLEtBQUssQ0FBUyxFQUFFLENBQUMsQ0FBQztRQUNoQyxlQUFVLEdBQUcsS0FBSyxFQUFVLENBQUM7UUFDN0IsVUFBSyxHQUFHLEtBQUssQ0FBUyxLQUFLLENBQUMsQ0FBQztRQUM3QixXQUFNLEdBQUcsS0FBSyxDQUFTLEtBQUssQ0FBQyxDQUFDO1FBRTlCLGVBQVUsR0FBc0IsVUFBVSxDQUFDO1FBQzNDLGlCQUFZLEdBQVEsRUFBRSxDQUFDLENBQUMscUJBQXFCO0tBc0Q3QztJQXBEQSxlQUFlO1FBQ2QsSUFBSSxDQUFDLFlBQVksR0FBRztZQUNuQixLQUFLLEVBQUU7Z0JBQ04sSUFBSSxFQUFFLEtBQUs7Z0JBQ1gsTUFBTSxFQUFFLElBQUksQ0FBQyxNQUFNLEVBQUU7Z0JBQ3JCLEtBQUssRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFO2FBQ25CO1lBQ0QsS0FBSyxFQUFFO2dCQUNOLElBQUksRUFBRSxJQUFJLENBQUMsS0FBSyxFQUFFO2FBQ2xCO1lBQ0QsS0FBSyxFQUFFO2dCQUNOLFVBQVUsRUFBRSxJQUFJLENBQUMsSUFBSSxFQUFFLENBQUMsR0FBRyxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDO2dCQUNoRCxLQUFLLEVBQUU7b0JBQ04sSUFBSSxFQUFFLElBQUksQ0FBQyxlQUFlLEVBQUU7aUJBQzVCO2FBQ0Q7WUFDRCxLQUFLLEVBQUU7Z0JBQ04sR0FBRyxFQUFFLENBQUM7Z0JBQ04sS0FBSyxFQUFFO29CQUNOLElBQUksRUFBRSxJQUFJLENBQUMsV0FBVyxFQUFFO2lCQUN4QjthQUNEO1lBQ0QsT0FBTyxFQUFFO2dCQUNSLFNBQVMsRUFBRTtvQkFDVixPQUFPO2dCQUNJLElBQUksQ0FBQyxLQUFLLENBQUMsUUFBUTtrQkFDakIsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsY0FBYyxDQUFDLE9BQU8sRUFBRTt3QkFDaEQscUJBQXFCLEVBQUUsQ0FBQzt3QkFDeEIscUJBQXFCLEVBQUUsQ0FBQztxQkFDeEIsQ0FBQztNQUNGLENBQUM7Z0JBQ0gsQ0FBQztnQkFDRCxPQUFPLEVBQUUsSUFBSTthQUNiO1lBQ0QsTUFBTSxFQUFFO2dCQUNQO29CQUNDLElBQUksRUFBRSxJQUFJLENBQUMsVUFBVSxFQUFFO29CQUN2QixJQUFJLEVBQUUsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztpQkFDdkM7YUFDRDtZQUNELE1BQU0sRUFBRSxFQUFFLE9BQU8sRUFBRSxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxFQUFFO1lBQ3JELE9BQU8sRUFBRTtnQkFDUixPQUFPLEVBQUUsS0FBSzthQUNkO1NBQ0QsQ0FBQztJQUNILENBQUM7SUFFRCxXQUFXLENBQUMsT0FBc0I7UUFDakMsSUFBSSxPQUFPLENBQUMsTUFBTSxDQUFDLElBQUksT0FBTyxDQUFDLE9BQU8sQ0FBQyxFQUFFLENBQUM7WUFDekMsSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQ3hCLENBQUM7SUFDRixDQUFDOzhHQS9EVyxxQkFBcUI7a0dBQXJCLHFCQUFxQixxL0JBVnZCOzs7OztxQkFLVSwyREFFVixxQkFBcUI7OzJGQUduQixxQkFBcUI7a0JBYmpDLFNBQVM7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSxvQkFBb0I7b0JBQzlCLFFBQVEsRUFBRTs7Ozs7cUJBS1U7b0JBRXBCLE9BQU8sRUFBRSxDQUFDLHFCQUFxQixDQUFDO29CQUNoQyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDL0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBPbkNoYW5nZXMsIFNpbXBsZUNoYW5nZXMsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5pbXBvcnQgKiBhcyBIaWdoY2hhcnRzIGZyb20gJ2hpZ2hjaGFydHMnO1xyXG5pbXBvcnQgeyBIaWdoY2hhcnRzQ2hhcnRNb2R1bGUgfSBmcm9tICdoaWdoY2hhcnRzLWFuZ3VsYXInO1xyXG5cclxuaW50ZXJmYWNlIGRhdGFJdGVtcyB7XHJcblx0bmFtZTogc3RyaW5nO1xyXG5cdHk6IGFueTtcclxuXHRjb2xvcj86IHN0cmluZztcclxuXHR0b29sdGlwPzogc3RyaW5nO1xyXG5cdHNlbGVjdGVkPzogYm9vbGVhbjtcclxufVxyXG5cclxuLy8gRXhhbXBsZSBEYXRhXHJcbi8vIGRhdGEgPSBbXHJcbi8vIFx0eyBuYW1lOiAnS2F0ZWdvcmkgQScsIHk6IDIwMCB9LFxyXG4vLyBcdHsgbmFtZTogJ0thdGVnb3JpIEInLCB5OiAxMDAgfSxcclxuLy8gXHR7IG5hbWU6ICdLYXRlZ29yaSBDJywgeTogNTAwIH0sXHJcbi8vIFx0eyBuYW1lOiAnS2F0ZWdvcmkgRCcsIHk6IDI1MCB9LFxyXG4vLyBcdHsgbmFtZTogJ0thdGVnb3JpIEUnLCB5OiA0MDAgfSxcclxuLy8gXVxyXG5cclxuQENvbXBvbmVudCh7XHJcblx0c3RhbmRhbG9uZTogdHJ1ZSxcclxuXHRzZWxlY3RvcjogJ2FyaWwtYmFyLWhpZ2hjaGFydCcsXHJcblx0dGVtcGxhdGU6IGAgPGhpZ2hjaGFydHMtY2hhcnRcclxuXHRcdHN0eWxlPVwid2lkdGg6IDEwMCU7IGRpc3BsYXk6IGJsb2NrXCJcclxuXHRcdFtIaWdoY2hhcnRzXT1cIkhpZ2hjaGFydHNcIlxyXG5cdFx0W29wdGlvbnNdPVwiY2hhcnRPcHRpb25zXCJcclxuXHRcdFtvbmVUb09uZV09XCJ0cnVlXCI+XHJcblx0PC9oaWdoY2hhcnRzLWNoYXJ0PmAsXHJcblxyXG5cdGltcG9ydHM6IFtIaWdoY2hhcnRzQ2hhcnRNb2R1bGVdLFxyXG5cdGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBCYXJIaWdoQ2hhcnRDb21wb25lbnQgaW1wbGVtZW50cyBPbkNoYW5nZXMge1xyXG5cdGRhdGEgPSBpbnB1dC5yZXF1aXJlZDxkYXRhSXRlbXNbXT4oKTtcclxuXHR0aXRsZSA9IGlucHV0PHN0cmluZz4oJycpO1xyXG5cdGNhdGVnb3JpZXNUaXRsZSA9IGlucHV0PHN0cmluZz4oJycpO1xyXG5cdHZhbHVlc1RpdGxlID0gaW5wdXQ8c3RyaW5nPignJyk7XHJcblx0c2VyaWVzTmFtZSA9IGlucHV0PHN0cmluZz4oKTtcclxuXHR3aWR0aCA9IGlucHV0PHN0cmluZz4oJzQ2MCcpO1xyXG5cdGhlaWdodCA9IGlucHV0PHN0cmluZz4oJzM4MCcpO1xyXG5cclxuXHRIaWdoY2hhcnRzOiB0eXBlb2YgSGlnaGNoYXJ0cyA9IEhpZ2hjaGFydHM7XHJcblx0Y2hhcnRPcHRpb25zOiBhbnkgPSB7fTsgLy8gSGlnaGNoYXJ0cy5PcHRpb25zXHJcblxyXG5cdHNldENoYXJ0T3B0aW9ucygpIHtcclxuXHRcdHRoaXMuY2hhcnRPcHRpb25zID0ge1xyXG5cdFx0XHRjaGFydDoge1xyXG5cdFx0XHRcdHR5cGU6ICdiYXInLFxyXG5cdFx0XHRcdGhlaWdodDogdGhpcy5oZWlnaHQoKSxcclxuXHRcdFx0XHR3aWR0aDogdGhpcy53aWR0aCgpXHJcblx0XHRcdH0sXHJcblx0XHRcdHRpdGxlOiB7XHJcblx0XHRcdFx0dGV4dDogdGhpcy50aXRsZSgpXHJcblx0XHRcdH0sXHJcblx0XHRcdHhBeGlzOiB7XHJcblx0XHRcdFx0Y2F0ZWdvcmllczogdGhpcy5kYXRhKCkubWFwKChpdGVtKSA9PiBpdGVtLm5hbWUpLFxyXG5cdFx0XHRcdHRpdGxlOiB7XHJcblx0XHRcdFx0XHR0ZXh0OiB0aGlzLmNhdGVnb3JpZXNUaXRsZSgpXHJcblx0XHRcdFx0fVxyXG5cdFx0XHR9LFxyXG5cdFx0XHR5QXhpczoge1xyXG5cdFx0XHRcdG1pbjogMCxcclxuXHRcdFx0XHR0aXRsZToge1xyXG5cdFx0XHRcdFx0dGV4dDogdGhpcy52YWx1ZXNUaXRsZSgpXHJcblx0XHRcdFx0fVxyXG5cdFx0XHR9LFxyXG5cdFx0XHR0b29sdGlwOiB7XHJcblx0XHRcdFx0Zm9ybWF0dGVyOiBmdW5jdGlvbiAodGhpczogYW55KSB7XHJcblx0XHRcdFx0XHRyZXR1cm4gYFxyXG5cdFx0XHRcdFx0XHQ8c3Ryb25nPiR7dGhpcy5wb2ludC5jYXRlZ29yeX08L3N0cm9uZz48YnI+XHJcblx0XHRcdFx0XHRcdERlxJ9lcjogPGI+JHt0aGlzLnBvaW50LnkudG9Mb2NhbGVTdHJpbmcoJ3RyLVRSJywge1xyXG5cdFx0XHRcdFx0XHRcdG1pbmltdW1GcmFjdGlvbkRpZ2l0czogMixcclxuXHRcdFx0XHRcdFx0XHRtYXhpbXVtRnJhY3Rpb25EaWdpdHM6IDJcclxuXHRcdFx0XHRcdFx0fSl9PC9iPlxyXG5cdFx0XHRcdFx0YDtcclxuXHRcdFx0XHR9LFxyXG5cdFx0XHRcdHVzZUhUTUw6IHRydWVcclxuXHRcdFx0fSxcclxuXHRcdFx0c2VyaWVzOiBbXHJcblx0XHRcdFx0e1xyXG5cdFx0XHRcdFx0bmFtZTogdGhpcy5zZXJpZXNOYW1lKCksXHJcblx0XHRcdFx0XHRkYXRhOiB0aGlzLmRhdGEoKS5tYXAoKGl0ZW0pID0+IGl0ZW0ueSlcclxuXHRcdFx0XHR9XHJcblx0XHRcdF0sXHJcblx0XHRcdGxlZ2VuZDogeyBlbmFibGVkOiB0aGlzLnNlcmllc05hbWUoKSA/IHRydWUgOiBmYWxzZSB9LFxyXG5cdFx0XHRjcmVkaXRzOiB7XHJcblx0XHRcdFx0ZW5hYmxlZDogZmFsc2VcclxuXHRcdFx0fVxyXG5cdFx0fTtcclxuXHR9XHJcblxyXG5cdG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpOiB2b2lkIHtcclxuXHRcdGlmIChjaGFuZ2VzWydkYXRhJ10gfHwgY2hhbmdlc1sndGl0bGUnXSkge1xyXG5cdFx0XHR0aGlzLnNldENoYXJ0T3B0aW9ucygpO1xyXG5cdFx0fVxyXG5cdH1cclxufVxyXG4iXX0=
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component,
|
|
1
|
+
import { Component, effect, input } from '@angular/core';
|
|
2
2
|
import * as Highcharts from 'highcharts';
|
|
3
3
|
import { HighchartsChartModule } from 'highcharts-angular';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
@@ -18,68 +18,100 @@ export class ColumnHighChartComponent {
|
|
|
18
18
|
this.categoriesTitle = input('');
|
|
19
19
|
this.valuesTitle = input('');
|
|
20
20
|
this.seriesName = input();
|
|
21
|
+
this.dateFormat = input();
|
|
22
|
+
this.width = input('460');
|
|
23
|
+
this.height = input('380');
|
|
24
|
+
this.series = input([]);
|
|
21
25
|
this.Highcharts = Highcharts;
|
|
22
26
|
this.chartOptions = {}; // Highcharts.Options
|
|
27
|
+
effect(() => {
|
|
28
|
+
if (this.data()) {
|
|
29
|
+
this.setChartOptions();
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
}
|
|
33
|
+
formatDate(name) {
|
|
34
|
+
const date = new Date(`${name.toString().slice(0, 4)}-${name.toString().slice(4, 6)}-${name.toString().slice(6, 8)}T` +
|
|
35
|
+
`${name.toString().slice(8, 10)}:${name.toString().slice(10, 12)}:${name.toString().slice(12, 14)}Z`);
|
|
36
|
+
switch (this.dateFormat()) {
|
|
37
|
+
case 'date':
|
|
38
|
+
return new Intl.DateTimeFormat('tr-TR', { day: '2-digit', month: 'long', year: 'numeric' }).format(date);
|
|
39
|
+
case 'month':
|
|
40
|
+
return new Intl.DateTimeFormat('tr-TR', { month: 'long', year: 'numeric' }).format(date).replace(' ', '/');
|
|
41
|
+
case 'year':
|
|
42
|
+
return new Intl.DateTimeFormat('tr-TR', { year: 'numeric' }).format(date);
|
|
43
|
+
}
|
|
23
44
|
}
|
|
24
45
|
setChartOptions() {
|
|
25
46
|
this.chartOptions = {
|
|
26
47
|
chart: {
|
|
27
|
-
type: 'column'
|
|
48
|
+
type: 'column',
|
|
49
|
+
width: this.width(),
|
|
50
|
+
height: this.height()
|
|
28
51
|
},
|
|
29
52
|
title: {
|
|
30
|
-
text: this.title()
|
|
53
|
+
text: this.title()
|
|
31
54
|
},
|
|
32
55
|
xAxis: {
|
|
33
|
-
categories: this.
|
|
56
|
+
categories: this.dateFormat() ?
|
|
57
|
+
this.data().map((item) => this.formatDate(item.name))
|
|
58
|
+
: this.data().map((item) => item.name),
|
|
34
59
|
title: {
|
|
35
|
-
text: this.categoriesTitle()
|
|
36
|
-
}
|
|
60
|
+
text: this.categoriesTitle()
|
|
61
|
+
}
|
|
37
62
|
},
|
|
38
63
|
yAxis: {
|
|
39
64
|
min: 0,
|
|
40
65
|
title: {
|
|
41
|
-
text: this.valuesTitle()
|
|
42
|
-
}
|
|
66
|
+
text: this.valuesTitle()
|
|
67
|
+
}
|
|
43
68
|
},
|
|
44
69
|
tooltip: {
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
70
|
+
formatter: function () {
|
|
71
|
+
return `
|
|
72
|
+
<strong>${this.point.category}</strong><br>
|
|
73
|
+
Değer: <b>${this.point.y.toLocaleString('tr-TR', {
|
|
74
|
+
minimumFractionDigits: 2,
|
|
75
|
+
maximumFractionDigits: 2
|
|
76
|
+
})}</b>
|
|
77
|
+
`;
|
|
51
78
|
},
|
|
52
|
-
|
|
79
|
+
useHTML: true
|
|
80
|
+
},
|
|
81
|
+
series: this.series().length ?
|
|
82
|
+
this.series()
|
|
83
|
+
: [
|
|
84
|
+
{
|
|
85
|
+
name: this.seriesName(),
|
|
86
|
+
data: this.data().map((item) => item.y)
|
|
87
|
+
}
|
|
88
|
+
],
|
|
53
89
|
legend: { enabled: this.seriesName() ? true : false },
|
|
54
90
|
credits: {
|
|
55
|
-
enabled: false
|
|
56
|
-
}
|
|
91
|
+
enabled: false
|
|
92
|
+
}
|
|
57
93
|
};
|
|
58
94
|
}
|
|
59
|
-
ngOnChanges(changes) {
|
|
60
|
-
if (changes['data'] || changes['title']) {
|
|
61
|
-
this.setChartOptions();
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
95
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: ColumnHighChartComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
65
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.1.2", type: ColumnHighChartComponent, isStandalone: true, selector: "aril-column-highchart", inputs: { data: { classPropertyName: "data", publicName: "data", isSignal: true, isRequired: true, transformFunction: null }, title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: false, transformFunction: null }, categoriesTitle: { classPropertyName: "categoriesTitle", publicName: "categoriesTitle", isSignal: true, isRequired: false, transformFunction: null }, valuesTitle: { classPropertyName: "valuesTitle", publicName: "valuesTitle", isSignal: true, isRequired: false, transformFunction: null }, seriesName: { classPropertyName: "seriesName", publicName: "seriesName", isSignal: true, isRequired: false, transformFunction: null } },
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
96
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.1.2", type: ColumnHighChartComponent, isStandalone: true, selector: "aril-column-highchart", inputs: { data: { classPropertyName: "data", publicName: "data", isSignal: true, isRequired: true, transformFunction: null }, title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: false, transformFunction: null }, categoriesTitle: { classPropertyName: "categoriesTitle", publicName: "categoriesTitle", isSignal: true, isRequired: false, transformFunction: null }, valuesTitle: { classPropertyName: "valuesTitle", publicName: "valuesTitle", isSignal: true, isRequired: false, transformFunction: null }, seriesName: { classPropertyName: "seriesName", publicName: "seriesName", isSignal: true, isRequired: false, transformFunction: null }, dateFormat: { classPropertyName: "dateFormat", publicName: "dateFormat", isSignal: true, isRequired: false, transformFunction: null }, width: { classPropertyName: "width", publicName: "width", isSignal: true, isRequired: false, transformFunction: null }, height: { classPropertyName: "height", publicName: "height", isSignal: true, isRequired: false, transformFunction: null }, series: { classPropertyName: "series", publicName: "series", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: ` <highcharts-chart
|
|
97
|
+
style="width: 100%; display: block"
|
|
98
|
+
[Highcharts]="Highcharts"
|
|
99
|
+
[oneToOne]="true"
|
|
100
|
+
[options]="chartOptions">
|
|
101
|
+
</highcharts-chart>`, isInline: true, dependencies: [{ kind: "ngmodule", type: HighchartsChartModule }, { kind: "component", type: i1.HighchartsChartComponent, selector: "highcharts-chart", inputs: ["Highcharts", "constructorType", "callbackFunction", "oneToOne", "runOutsideAngular", "options", "update"], outputs: ["updateChange", "chartInstance"] }] }); }
|
|
70
102
|
}
|
|
71
103
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: ColumnHighChartComponent, decorators: [{
|
|
72
104
|
type: Component,
|
|
73
105
|
args: [{
|
|
74
106
|
standalone: true,
|
|
75
107
|
selector: 'aril-column-highchart',
|
|
76
|
-
template: `
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
108
|
+
template: ` <highcharts-chart
|
|
109
|
+
style="width: 100%; display: block"
|
|
110
|
+
[Highcharts]="Highcharts"
|
|
111
|
+
[oneToOne]="true"
|
|
112
|
+
[options]="chartOptions">
|
|
113
|
+
</highcharts-chart>`,
|
|
114
|
+
imports: [HighchartsChartModule]
|
|
83
115
|
}]
|
|
84
|
-
}] });
|
|
85
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
116
|
+
}], ctorParameters: () => [] });
|
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-chart.component.js","sourceRoot":"","sources":["../../../../../../../projects/aril/ui/charts/src/highCharts/column/column-chart.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, effect, input } from '@angular/core';\r\n\r\nimport * as Highcharts from 'highcharts';\r\nimport { HighchartsChartModule } from 'highcharts-angular';\r\n\r\ninterface dataItems {\r\n\tname: any;\r\n\ty: any;\r\n\tcolor?: string;\r\n\ttooltip?: string;\r\n\tselected?: boolean;\r\n}\r\n\r\n// Example Data\r\n// data = [\r\n// \t{ name: 'Kategori A', y: 200 },\r\n// \t{ name: 'Kategori B', y: 100 },\r\n// \t{ name: 'Kategori C', y: 500 },\r\n// \t{ name: 'Kategori D', y: 250 },\r\n// \t{ name: 'Kategori E', y: 400 },\r\n// ]\r\n\r\n@Component({\r\n\tstandalone: true,\r\n\tselector: 'aril-column-highchart',\r\n\ttemplate: ` <highcharts-chart\r\n\t\tstyle=\"width: 100%; display: block\"\r\n\t\t[Highcharts]=\"Highcharts\"\r\n\t\t[oneToOne]=\"true\"\r\n\t\t[options]=\"chartOptions\">\r\n\t</highcharts-chart>`,\r\n\r\n\timports: [HighchartsChartModule]\r\n})\r\nexport class ColumnHighChartComponent {\r\n\tconstructor() {\r\n\t\teffect(() => {\r\n\t\t\tif (this.data()) {\r\n\t\t\t\tthis.setChartOptions();\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\tdata = input.required<dataItems[]>();\r\n\ttitle = input<string>('');\r\n\tcategoriesTitle = input<string>('');\r\n\tvaluesTitle = input<string>('');\r\n\tseriesName = input<string>();\r\n\tdateFormat = input<string>();\r\n\twidth = input<string>('460');\r\n\theight = input<string>('380');\r\n\tseries = input<any>([]);\r\n\r\n\tHighcharts: typeof Highcharts = Highcharts;\r\n\tchartOptions: any = {}; // Highcharts.Options\r\n\r\n\tformatDate(name: any): any {\r\n\t\tconst date = new Date(\r\n\t\t\t`${name.toString().slice(0, 4)}-${name.toString().slice(4, 6)}-${name.toString().slice(6, 8)}T` +\r\n\t\t\t\t`${name.toString().slice(8, 10)}:${name.toString().slice(10, 12)}:${name.toString().slice(12, 14)}Z`\r\n\t\t);\r\n\r\n\t\tswitch (this.dateFormat()) {\r\n\t\t\tcase 'date':\r\n\t\t\t\treturn new Intl.DateTimeFormat('tr-TR', { day: '2-digit', month: 'long', year: 'numeric' }).format(date);\r\n\t\t\tcase 'month':\r\n\t\t\t\treturn new Intl.DateTimeFormat('tr-TR', { month: 'long', year: 'numeric' }).format(date).replace(' ', '/');\r\n\t\t\tcase 'year':\r\n\t\t\t\treturn new Intl.DateTimeFormat('tr-TR', { year: 'numeric' }).format(date);\r\n\t\t}\r\n\t}\r\n\r\n\tsetChartOptions() {\r\n\t\tthis.chartOptions = {\r\n\t\t\tchart: {\r\n\t\t\t\ttype: 'column',\r\n\t\t\t\twidth: this.width(),\r\n\t\t\t\theight: this.height()\r\n\t\t\t},\r\n\t\t\ttitle: {\r\n\t\t\t\ttext: this.title()\r\n\t\t\t},\r\n\t\t\txAxis: {\r\n\t\t\t\tcategories:\r\n\t\t\t\t\tthis.dateFormat() ?\r\n\t\t\t\t\t\tthis.data().map((item) => this.formatDate(item.name))\r\n\t\t\t\t\t:\tthis.data().map((item) => item.name),\r\n\t\t\t\ttitle: {\r\n\t\t\t\t\ttext: this.categoriesTitle()\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\tyAxis: {\r\n\t\t\t\tmin: 0,\r\n\t\t\t\ttitle: {\r\n\t\t\t\t\ttext: this.valuesTitle()\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\ttooltip: {\r\n\t\t\t\tformatter: function (this: any) {\r\n\t\t\t\t\treturn `\r\n\t\t\t\t\t\t<strong>${this.point.category}</strong><br>\r\n\t\t\t\t\t\tDeğer: <b>${this.point.y.toLocaleString('tr-TR', {\r\n\t\t\t\t\t\t\tminimumFractionDigits: 2,\r\n\t\t\t\t\t\t\tmaximumFractionDigits: 2\r\n\t\t\t\t\t\t})}</b>\r\n\t\t\t\t\t`;\r\n\t\t\t\t},\r\n\t\t\t\tuseHTML: true\r\n\t\t\t},\r\n\t\t\tseries:\r\n\t\t\t\tthis.series().length ?\r\n\t\t\t\t\tthis.series()\r\n\t\t\t\t:\t[\r\n\t\t\t\t\t\t{\r\n\t\t\t\t\t\t\tname: this.seriesName(),\r\n\t\t\t\t\t\t\tdata: this.data().map((item) => item.y)\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t],\r\n\t\t\tlegend: { enabled: this.seriesName() ? true : false },\r\n\t\t\tcredits: {\r\n\t\t\t\tenabled: false\r\n\t\t\t}\r\n\t\t};\r\n\t}\r\n}\r\n"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component,
|
|
1
|
+
import { Component, EventEmitter, Output, effect, input } from '@angular/core';
|
|
2
2
|
import * as Highcharts from 'highcharts';
|
|
3
3
|
import { HighchartsChartModule } from 'highcharts-angular';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
@@ -16,22 +16,33 @@ export class PieHighChartComponent {
|
|
|
16
16
|
this.data = input.required();
|
|
17
17
|
this.title = input('');
|
|
18
18
|
this.size = input('70%');
|
|
19
|
+
this.width = input('460');
|
|
20
|
+
this.height = input('380');
|
|
21
|
+
this.showLegend = input(false);
|
|
22
|
+
this.dataLabelsFormat = input('<span style="font-size: 1.2em"><b>{point.name}:</b> <span style="opacity: 0.6">' +
|
|
23
|
+
'{point.percentage:.1f}%</span><br>');
|
|
24
|
+
this.selected = new EventEmitter();
|
|
19
25
|
this.Highcharts = Highcharts;
|
|
20
|
-
this.chartOptions = {};
|
|
26
|
+
this.chartOptions = {};
|
|
27
|
+
effect(() => {
|
|
28
|
+
if (this.data()) {
|
|
29
|
+
this.setChartOptions();
|
|
30
|
+
}
|
|
31
|
+
});
|
|
21
32
|
}
|
|
22
33
|
setChartOptions() {
|
|
23
34
|
this.chartOptions = {
|
|
24
35
|
chart: {
|
|
25
|
-
|
|
26
|
-
plotBorderWidth: null,
|
|
36
|
+
type: 'pie',
|
|
27
37
|
plotShadow: false,
|
|
28
|
-
|
|
38
|
+
width: this.width(),
|
|
39
|
+
height: this.height()
|
|
29
40
|
},
|
|
30
41
|
title: {
|
|
31
|
-
text: this.title()
|
|
42
|
+
text: this.title()
|
|
32
43
|
},
|
|
33
44
|
tooltip: {
|
|
34
|
-
pointFormat: '<b>{point.percentage:.1f}%</b>'
|
|
45
|
+
pointFormat: '<b>{point.percentage:.1f}%</b>'
|
|
35
46
|
},
|
|
36
47
|
accessibility: {
|
|
37
48
|
point: {
|
|
@@ -40,52 +51,87 @@ export class PieHighChartComponent {
|
|
|
40
51
|
},
|
|
41
52
|
plotOptions: {
|
|
42
53
|
pie: {
|
|
43
|
-
size:
|
|
54
|
+
size: this.size(),
|
|
44
55
|
allowPointSelect: true,
|
|
45
56
|
cursor: 'pointer',
|
|
57
|
+
showInLegend: this.showLegend(),
|
|
46
58
|
dataLabels: {
|
|
59
|
+
formatter: function () {
|
|
60
|
+
const percentage = this.point.percentage.toFixed(1);
|
|
61
|
+
const value = this.point.y.toLocaleString('tr-TR', {
|
|
62
|
+
minimumFractionDigits: 2,
|
|
63
|
+
maximumFractionDigits: 2
|
|
64
|
+
});
|
|
65
|
+
return `
|
|
66
|
+
<span style="font-size: 1.2em"><b>${this.point.name}:</b></span>
|
|
67
|
+
<span style="opacity: 0.6">${percentage}%</span>
|
|
68
|
+
<br>
|
|
69
|
+
<span style="font-weight: bold;">${value} TL</span>`;
|
|
70
|
+
},
|
|
47
71
|
enabled: true,
|
|
48
|
-
|
|
49
|
-
'
|
|
50
|
-
|
|
72
|
+
style: {
|
|
73
|
+
fontWeight: 'normal'
|
|
74
|
+
}
|
|
75
|
+
},
|
|
76
|
+
events: {
|
|
77
|
+
click: (event) => {
|
|
78
|
+
this.selected.emit(event.point.options);
|
|
79
|
+
}
|
|
51
80
|
}
|
|
52
81
|
}
|
|
53
82
|
},
|
|
54
83
|
series: [
|
|
55
84
|
{
|
|
85
|
+
type: 'pie',
|
|
56
86
|
name: 'Data',
|
|
57
|
-
data: this.data()
|
|
58
|
-
}
|
|
87
|
+
data: this.data()
|
|
88
|
+
}
|
|
59
89
|
],
|
|
60
90
|
credits: {
|
|
61
|
-
enabled: false
|
|
91
|
+
enabled: false
|
|
62
92
|
},
|
|
93
|
+
responsive: {
|
|
94
|
+
rules: [
|
|
95
|
+
{
|
|
96
|
+
condition: {
|
|
97
|
+
maxWidth: 500
|
|
98
|
+
},
|
|
99
|
+
chartOptions: {
|
|
100
|
+
legend: {
|
|
101
|
+
layout: 'vertical',
|
|
102
|
+
align: 'right',
|
|
103
|
+
verticalAlign: 'middle'
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
]
|
|
108
|
+
}
|
|
63
109
|
};
|
|
64
110
|
}
|
|
65
|
-
ngOnChanges(changes) {
|
|
66
|
-
if (changes['data'] || changes['title']) {
|
|
67
|
-
this.setChartOptions();
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
111
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: PieHighChartComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
71
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.1.2", type: PieHighChartComponent, isStandalone: true, selector: "aril-pie-highchart", inputs: { data: { classPropertyName: "data", publicName: "data", isSignal: true, isRequired: true, transformFunction: null }, title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null } },
|
|
72
|
-
|
|
73
|
-
|
|
112
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.1.2", type: PieHighChartComponent, isStandalone: true, selector: "aril-pie-highchart", inputs: { data: { classPropertyName: "data", publicName: "data", isSignal: true, isRequired: true, transformFunction: null }, title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, width: { classPropertyName: "width", publicName: "width", isSignal: true, isRequired: false, transformFunction: null }, height: { classPropertyName: "height", publicName: "height", isSignal: true, isRequired: false, transformFunction: null }, showLegend: { classPropertyName: "showLegend", publicName: "showLegend", isSignal: true, isRequired: false, transformFunction: null }, dataLabelsFormat: { classPropertyName: "dataLabelsFormat", publicName: "dataLabelsFormat", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { selected: "selected" }, ngImport: i0, template: ` <highcharts-chart
|
|
113
|
+
style="width: 100%; display: block"
|
|
114
|
+
[Highcharts]="Highcharts"
|
|
115
|
+
[oneToOne]="true"
|
|
116
|
+
[runOutsideAngular]="true"
|
|
74
117
|
[options]="chartOptions">
|
|
75
|
-
</highcharts-chart>`, isInline: true, dependencies: [{ kind: "ngmodule", type: HighchartsChartModule }, { kind: "component", type: i1.HighchartsChartComponent, selector: "highcharts-chart", inputs: ["Highcharts", "constructorType", "callbackFunction", "oneToOne", "runOutsideAngular", "options", "update"], outputs: ["updateChange", "chartInstance"] }]
|
|
118
|
+
</highcharts-chart>`, isInline: true, dependencies: [{ kind: "ngmodule", type: HighchartsChartModule }, { kind: "component", type: i1.HighchartsChartComponent, selector: "highcharts-chart", inputs: ["Highcharts", "constructorType", "callbackFunction", "oneToOne", "runOutsideAngular", "options", "update"], outputs: ["updateChange", "chartInstance"] }] }); }
|
|
76
119
|
}
|
|
77
120
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: PieHighChartComponent, decorators: [{
|
|
78
121
|
type: Component,
|
|
79
122
|
args: [{
|
|
80
123
|
standalone: true,
|
|
81
124
|
selector: 'aril-pie-highchart',
|
|
82
|
-
template: `
|
|
83
|
-
|
|
84
|
-
|
|
125
|
+
template: ` <highcharts-chart
|
|
126
|
+
style="width: 100%; display: block"
|
|
127
|
+
[Highcharts]="Highcharts"
|
|
128
|
+
[oneToOne]="true"
|
|
129
|
+
[runOutsideAngular]="true"
|
|
85
130
|
[options]="chartOptions">
|
|
86
131
|
</highcharts-chart>`,
|
|
87
|
-
imports: [HighchartsChartModule]
|
|
88
|
-
changeDetection: ChangeDetectionStrategy.OnPush
|
|
132
|
+
imports: [HighchartsChartModule]
|
|
89
133
|
}]
|
|
90
|
-
}]
|
|
91
|
-
|
|
134
|
+
}], ctorParameters: () => [], propDecorators: { selected: [{
|
|
135
|
+
type: Output
|
|
136
|
+
}] } });
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pie-chart.component.js","sourceRoot":"","sources":["../../../../../../../projects/aril/ui/charts/src/highCharts/pie/pie-chart.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Output, effect, input } from '@angular/core';\r\n\r\nimport * as Highcharts from 'highcharts';\r\nimport { HighchartsChartModule } from 'highcharts-angular';\r\n\r\ninterface dataItems {\r\n\tname: string;\r\n\ty: number;\r\n\tcolor?: string;\r\n\ttooltip?: string;\r\n\tselected?: boolean;\r\n}\r\n\r\n// Example Data\r\n// data = [\r\n// \t{ name: 'Kategori A', y: 200 },\r\n// \t{ name: 'Kategori B', y: 100 },\r\n// \t{ name: 'Kategori C', y: 500 },\r\n// \t{ name: 'Kategori D', y: 250 },\r\n// \t{ name: 'Kategori E', y: 400 },\r\n// ]\r\n\r\n@Component({\r\n\tstandalone: true,\r\n\tselector: 'aril-pie-highchart',\r\n\ttemplate: ` <highcharts-chart\r\n\t\tstyle=\"width: 100%; display: block\"\r\n\t\t[Highcharts]=\"Highcharts\"\r\n\t\t[oneToOne]=\"true\"\r\n\t\t[runOutsideAngular]=\"true\"\r\n\t\t[options]=\"chartOptions\">\r\n\t</highcharts-chart>`,\r\n\r\n\timports: [HighchartsChartModule]\r\n})\r\nexport class PieHighChartComponent {\r\n\tconstructor() {\r\n\t\teffect(() => {\r\n\t\t\tif (this.data()) {\r\n\t\t\t\tthis.setChartOptions();\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\tdata = input.required<dataItems[]>();\r\n\ttitle = input<string>('');\r\n\tsize = input<string>('70%');\r\n\twidth = input<string>('460');\r\n\theight = input<string>('380');\r\n\tshowLegend = input<boolean>(false);\r\n\tdataLabelsFormat = input<string>(\r\n\t\t'<span style=\"font-size: 1.2em\"><b>{point.name}:</b> <span style=\"opacity: 0.6\">' +\r\n\t\t\t'{point.percentage:.1f}%</span><br>'\r\n\t);\r\n\r\n\t@Output() selected: EventEmitter<unknown> = new EventEmitter();\r\n\r\n\tHighcharts: typeof Highcharts = Highcharts;\r\n\tchartOptions: Highcharts.Options = {};\r\n\r\n\tsetChartOptions() {\r\n\t\tthis.chartOptions = {\r\n\t\t\tchart: {\r\n\t\t\t\ttype: 'pie',\r\n\t\t\t\tplotShadow: false,\r\n\t\t\t\twidth: this.width(),\r\n\t\t\t\theight: this.height()\r\n\t\t\t},\r\n\t\t\ttitle: {\r\n\t\t\t\ttext: this.title()\r\n\t\t\t},\r\n\t\t\ttooltip: {\r\n\t\t\t\tpointFormat: '<b>{point.percentage:.1f}%</b>'\r\n\t\t\t},\r\n\t\t\taccessibility: {\r\n\t\t\t\tpoint: {\r\n\t\t\t\t\tvalueSuffix: '%'\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\tplotOptions: {\r\n\t\t\t\tpie: {\r\n\t\t\t\t\tsize: this.size(),\r\n\t\t\t\t\tallowPointSelect: true,\r\n\t\t\t\t\tcursor: 'pointer',\r\n\t\t\t\t\tshowInLegend: this.showLegend(),\r\n\t\t\t\t\tdataLabels: {\r\n\t\t\t\t\t\tformatter: function (this: any) {\r\n\t\t\t\t\t\t\tconst percentage = this.point.percentage.toFixed(1);\r\n\t\t\t\t\t\t\tconst value = this.point.y.toLocaleString('tr-TR', {\r\n\t\t\t\t\t\t\t\tminimumFractionDigits: 2,\r\n\t\t\t\t\t\t\t\tmaximumFractionDigits: 2\r\n\t\t\t\t\t\t\t});\r\n\t\t\t\t\t\t\treturn `\r\n\t\t\t\t\t\t\t\t<span style=\"font-size: 1.2em\"><b>${this.point.name}:</b></span>\r\n\t\t\t\t\t\t\t\t<span style=\"opacity: 0.6\">${percentage}%</span>\r\n\t\t\t\t\t\t\t\t<br>\r\n\t\t\t\t\t\t\t\t<span style=\"font-weight: bold;\">${value} TL</span>`;\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tenabled: true,\r\n\t\t\t\t\t\tstyle: {\r\n\t\t\t\t\t\t\tfontWeight: 'normal'\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t},\r\n\t\t\t\t\tevents: {\r\n\t\t\t\t\t\tclick: (event: any) => {\r\n\t\t\t\t\t\t\tthis.selected.emit(event.point.options);\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t},\r\n\t\t\tseries: [\r\n\t\t\t\t{\r\n\t\t\t\t\ttype: 'pie',\r\n\t\t\t\t\tname: 'Data',\r\n\t\t\t\t\tdata: this.data()\r\n\t\t\t\t}\r\n\t\t\t],\r\n\t\t\tcredits: {\r\n\t\t\t\tenabled: false\r\n\t\t\t},\r\n\t\t\tresponsive: {\r\n\t\t\t\trules: [\r\n\t\t\t\t\t{\r\n\t\t\t\t\t\tcondition: {\r\n\t\t\t\t\t\t\tmaxWidth: 500\r\n\t\t\t\t\t\t},\r\n\t\t\t\t\t\tchartOptions: {\r\n\t\t\t\t\t\t\tlegend: {\r\n\t\t\t\t\t\t\t\tlayout: 'vertical',\r\n\t\t\t\t\t\t\t\talign: 'right',\r\n\t\t\t\t\t\t\t\tverticalAlign: 'middle'\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t]\r\n\t\t\t}\r\n\t\t};\r\n\t}\r\n}\r\n"]}
|