aril 0.1.10 → 0.1.12
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/theme/layout/app/topbar/app.topbar.component.mjs +1 -1
- package/esm2022/ui/badge/src/badge.component.mjs +5 -4
- package/esm2022/ui/charts/aril-ui-charts.mjs +5 -0
- package/esm2022/ui/charts/index.mjs +4 -0
- package/esm2022/ui/charts/src/column/column-chart.component.mjs +124 -0
- package/esm2022/ui/charts/src/line/line-chart.component.mjs +164 -0
- package/esm2022/ui/charts/src/pie/pie-chart.component.mjs +116 -0
- package/esm2022/ui/charts/src/theme/theme.mjs +54 -0
- package/esm2022/ui/detailed-overlay-panel/aril-ui-detailed-overlay-panel.mjs +5 -0
- package/esm2022/ui/detailed-overlay-panel/index.mjs +2 -0
- package/esm2022/ui/detailed-overlay-panel/src/detailed-overlay-panel.component.mjs +62 -0
- package/esm2022/ui/lib/src/input/input-error-message.pipe.mjs +8 -5
- package/esm2022/ui/multiSelect/aril-ui-multiSelect.mjs +5 -0
- package/esm2022/ui/multiSelect/index.mjs +2 -0
- package/esm2022/ui/multiSelect/src/multi-select.component.mjs +30 -0
- package/esm2022/ui/table/src/table.component.mjs +3 -3
- package/esm2022/ui/value/src/value.component.mjs +26 -6
- package/fesm2022/aril-theme-layout.mjs +1 -1
- package/fesm2022/aril-theme-layout.mjs.map +1 -1
- package/fesm2022/aril-ui-badge.mjs +4 -3
- package/fesm2022/aril-ui-badge.mjs.map +1 -1
- package/fesm2022/aril-ui-charts.mjs +448 -0
- package/fesm2022/aril-ui-charts.mjs.map +1 -0
- package/fesm2022/aril-ui-detailed-overlay-panel.mjs +69 -0
- package/fesm2022/aril-ui-detailed-overlay-panel.mjs.map +1 -0
- package/fesm2022/aril-ui-lib.mjs +10 -7
- package/fesm2022/aril-ui-lib.mjs.map +1 -1
- package/fesm2022/aril-ui-multiSelect.mjs +37 -0
- package/fesm2022/aril-ui-multiSelect.mjs.map +1 -0
- package/fesm2022/aril-ui-table.mjs +2 -2
- package/fesm2022/aril-ui-table.mjs.map +1 -1
- package/fesm2022/aril-ui-value.mjs +25 -5
- package/fesm2022/aril-ui-value.mjs.map +1 -1
- package/package.json +81 -63
- package/ui/badge/src/badge.component.d.ts +2 -1
- package/ui/charts/index.d.ts +3 -0
- package/ui/charts/src/column/column-chart.component.d.ts +25 -0
- package/ui/charts/src/line/line-chart.component.d.ts +26 -0
- package/ui/charts/src/pie/pie-chart.component.d.ts +24 -0
- package/ui/charts/src/theme/theme.d.ts +5 -0
- package/ui/detailed-overlay-panel/index.d.ts +1 -0
- package/ui/detailed-overlay-panel/src/detailed-overlay-panel.component.d.ts +24 -0
- package/ui/lib/src/input/input-error-message.pipe.d.ts +3 -0
- package/ui/multiSelect/index.d.ts +1 -0
- package/ui/multiSelect/src/multi-select.component.d.ts +17 -0
- package/ui/value/src/value.component.d.ts +7 -1
|
@@ -66,7 +66,7 @@ export class AppTopbarComponent {
|
|
|
66
66
|
this.layoutService.showConfigSidebar();
|
|
67
67
|
}
|
|
68
68
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: AppTopbarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
69
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: AppTopbarComponent, isStandalone: true, selector: "app-topbar", viewQueries: [{ propertyName: "menuButton", first: true, predicate: ["menubutton"], descendants: true }], ngImport: i0, template: "<div class=\"layout-topbar\">\r\n\t<div class=\"topbar-start\">\r\n\t\t<button #menubutton type=\"button\" class=\"topbar-menubutton p-link p-trigger\" (click)=\"onMenuButtonClick()\">\r\n\t\t\t<i class=\"pi pi-bars\"></i>\r\n\t\t</button>\r\n\t\t<img [src]=\"filePath()\" class=\"mr-3\" alt=\"yeap\" />\r\n\t</div>\r\n\r\n\t<div class=\"topbar-search\" style=\"width: 50rem\">\r\n\t\t<span class=\"p-input-icon-left\" style=\"width: 100%\">\r\n\t\t\t<i class=\"pi pi-search\"></i>\r\n\t\t\t<input\r\n\t\t\t\ttype=\"text\"\r\n\t\t\t\tpInputText\r\n\t\t\t\tvariant=\"filled\"\r\n\t\t\t\tplaceholder=\"Genel Arama\"\r\n\t\t\t\tstyle=\"background: #EFF3F8;border: none; height: 42px;\"\r\n\t\t\t\tclass=\"p-inputtext p-component p-element sm:w-full\" />\r\n\t\t</span>\r\n\t</div>\r\n\r\n\t<div class=\"topbar-end mr-2\">\r\n\t\t<ul class=\"topbar-menu\">\r\n\t\t\t<li>\r\n\t\t\t\t<p-button icon=\"pi pi-sitemap\" severity=\"secondary\" [text]=\"true\" [rounded]=\"true\" />\r\n\t\t\t</li>\r\n\t\t\t<li>\r\n\t\t\t\t<p-button icon=\"pi pi-history\" severity=\"secondary\" [text]=\"true\" [rounded]=\"true\" />\r\n\t\t\t</li>\r\n\t\t\t<li>\r\n\t\t\t\t<p-button icon=\"pi pi-heart\" severity=\"secondary\" [text]=\"true\" [rounded]=\"true\" />\r\n\t\t\t</li>\r\n\t\t\t<li>\r\n\t\t\t\t<p-button severity=\"secondary\" [text]=\"true\" [rounded]=\"true\" (click)=\"onProfileButtonClick()\">\r\n\t\t\t\t\t{{ username[0] | uppercase }}\r\n\t\t\t\t</p-button>\r\n\t\t\t</li>\r\n\t\t\t<li>\r\n\t\t\t\t<p-divider layout=\"vertical\" styleClass=\"h-1rem border-500 m-0\" />\r\n\t\t\t</li>\r\n\t\t\t<li>\r\n\t\t\t\t<i class=\"pi pi-bell\" severity=\"info\" pBadge [value]=\"0\"></i>\r\n\t\t\t</li>\r\n\t\t</ul>\r\n\t</div>\r\n</div>\r\n\r\n<app-breadcrumb class=\"topbar-breadcrumb\"></app-breadcrumb>\r\n", dependencies: [{ kind: "ngmodule", type: ButtonModule }, { kind: "component", type: i1.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "style", "styleClass", "badgeClass", "ariaLabel", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "component", type: AppBreadcrumbComponent, selector: "app-breadcrumb" }, { kind: "pipe", type: UpperCasePipe, name: "uppercase" }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: DividerModule }, { kind: "component", type: i2.Divider, selector: "p-divider", inputs: ["style", "styleClass", "layout", "type", "align"] }, { kind: "ngmodule", type: BadgeModule }, { kind: "directive", type: i3.BadgeDirective, selector: "[pBadge]", inputs: ["badgeDisabled", "badgeSize", "size", "severity", "value"] }] }); }
|
|
69
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: AppTopbarComponent, isStandalone: true, selector: "app-topbar", viewQueries: [{ propertyName: "menuButton", first: true, predicate: ["menubutton"], descendants: true }], ngImport: i0, template: "<div class=\"layout-topbar\">\r\n\t<div class=\"topbar-start\">\r\n\t\t<button #menubutton type=\"button\" class=\"topbar-menubutton p-link p-trigger\" (click)=\"onMenuButtonClick()\">\r\n\t\t\t<i class=\"pi pi-bars\"></i>\r\n\t\t</button>\r\n\t\t<img [src]=\"filePath()\" class=\"mr-3\" alt=\"yeap\" />\r\n\t</div>\r\n\r\n\t<div class=\"topbar-search\" style=\"width: 50rem\">\r\n\t\t<span class=\"p-input-icon-left\" style=\"width: 100%\">\r\n\t\t\t<i class=\"pi pi-search\"></i>\r\n\t\t\t<input\r\n\t\t\t\ttype=\"text\"\r\n\t\t\t\tpInputText\r\n\t\t\t\tvariant=\"filled\"\r\n\t\t\t\tplaceholder=\"Genel Arama\"\r\n\t\t\t\tstyle=\"background: #EFF3F8;border: none; height: 42px;\"\r\n\t\t\t\tclass=\"p-inputtext p-component p-element sm:w-full\" />\r\n\t\t</span>\r\n\t</div>\r\n\r\n\t<div class=\"topbar-end mr-2\">\r\n\t\t<ul class=\"topbar-menu\">\r\n\t\t\t<li>\r\n\t\t\t\t<p-button icon=\"pi pi-sitemap\" severity=\"secondary\" [text]=\"true\" [rounded]=\"true\" />\r\n\t\t\t</li>\r\n\t\t\t<li>\r\n\t\t\t\t<p-button icon=\"pi pi-history\" severity=\"secondary\" [text]=\"true\" [rounded]=\"true\" />\r\n\t\t\t</li>\r\n\t\t\t<li>\r\n\t\t\t\t<p-button icon=\"pi pi-heart\" severity=\"secondary\" [text]=\"true\" [rounded]=\"true\" />\r\n\t\t\t</li>\r\n\t\t\t<li>\r\n\t\t\t\t<p-button severity=\"secondary\" [text]=\"true\" [rounded]=\"true\" (click)=\"onProfileButtonClick()\">\r\n\t\t\t\t\t{{ username[0] | uppercase }}\r\n\t\t\t\t</p-button>\r\n\t\t\t</li>\r\n\t\t\t<li>\r\n\t\t\t\t<p-divider layout=\"vertical\" styleClass=\"h-1rem border-500 m-0\" />\r\n\t\t\t</li>\r\n\t\t\t<li>\r\n\t\t\t\t<i class=\"pi pi-bell\" severity=\"info\" pBadge [value]=\"0\"></i>\r\n\t\t\t</li>\r\n\t\t</ul>\r\n\t</div>\r\n</div>\r\n\r\n<app-breadcrumb class=\"topbar-breadcrumb\"></app-breadcrumb>\r\n", dependencies: [{ kind: "ngmodule", type: ButtonModule }, { kind: "component", type: i1.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "style", "styleClass", "badgeClass", "ariaLabel", "autofocus"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "component", type: AppBreadcrumbComponent, selector: "app-breadcrumb" }, { kind: "pipe", type: UpperCasePipe, name: "uppercase" }, { kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: DividerModule }, { kind: "component", type: i2.Divider, selector: "p-divider", inputs: ["style", "styleClass", "layout", "type", "align"] }, { kind: "ngmodule", type: BadgeModule }, { kind: "directive", type: i3.BadgeDirective, selector: "[pBadge]", inputs: ["badgeDisabled", "badgeSize", "size", "severity", "value", "badgeStyle", "badgeStyleClass"] }] }); }
|
|
70
70
|
}
|
|
71
71
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: AppTopbarComponent, decorators: [{
|
|
72
72
|
type: Component,
|
|
@@ -6,14 +6,15 @@ export class BadgeComponent {
|
|
|
6
6
|
constructor() {
|
|
7
7
|
this.icon = input();
|
|
8
8
|
this.value = input();
|
|
9
|
-
this.severity = input
|
|
9
|
+
this.severity = input();
|
|
10
10
|
this.rounded = input();
|
|
11
|
+
this.background = input();
|
|
11
12
|
}
|
|
12
13
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: BadgeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
13
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.1.2", type: BadgeComponent, isStandalone: true, selector: "aril-badge", inputs: { icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: false, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, severity: { classPropertyName: "severity", publicName: "severity", isSignal: true, isRequired:
|
|
14
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.1.2", type: BadgeComponent, isStandalone: true, selector: "aril-badge", inputs: { icon: { classPropertyName: "icon", publicName: "icon", isSignal: true, isRequired: false, transformFunction: null }, value: { classPropertyName: "value", publicName: "value", isSignal: true, isRequired: false, transformFunction: null }, severity: { classPropertyName: "severity", publicName: "severity", isSignal: true, isRequired: false, transformFunction: null }, rounded: { classPropertyName: "rounded", publicName: "rounded", isSignal: true, isRequired: false, transformFunction: null }, background: { classPropertyName: "background", publicName: "background", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: "<p-tag\r\n [icon]=\"icon()\"\r\n [value]=\"value()\"\r\n [severity]=\"severity()\"\r\n [rounded]=\"rounded()\"\r\n [style]=\"{ backgroundColor: background(), textAlign: 'center', fontSize: '0.9rem' }\">\r\n <ng-content></ng-content>\r\n</p-tag>", dependencies: [{ kind: "ngmodule", type: TagModule }, { kind: "component", type: i1.Tag, selector: "p-tag", inputs: ["style", "styleClass", "severity", "value", "icon", "rounded"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
14
15
|
}
|
|
15
16
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: BadgeComponent, decorators: [{
|
|
16
17
|
type: Component,
|
|
17
|
-
args: [{ standalone: true, selector: 'aril-badge', imports: [TagModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<p-tag
|
|
18
|
+
args: [{ standalone: true, selector: 'aril-badge', imports: [TagModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<p-tag\r\n [icon]=\"icon()\"\r\n [value]=\"value()\"\r\n [severity]=\"severity()\"\r\n [rounded]=\"rounded()\"\r\n [style]=\"{ backgroundColor: background(), textAlign: 'center', fontSize: '0.9rem' }\">\r\n <ng-content></ng-content>\r\n</p-tag>" }]
|
|
18
19
|
}] });
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFkZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYXJpbC91aS9iYWRnZS9zcmMvYmFkZ2UuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYXJpbC91aS9iYWRnZS9zcmMvYmFkZ2UuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFMUUsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGFBQWEsQ0FBQzs7O0FBV3hDLE1BQU0sT0FBTyxjQUFjO0lBUDNCO1FBUUMsU0FBSSxHQUFHLEtBQUssRUFBVSxDQUFDO1FBQ3ZCLFVBQUssR0FBRyxLQUFLLEVBQVUsQ0FBQztRQUN4QixhQUFRLEdBQUcsS0FBSyxFQUFZLENBQUM7UUFDN0IsWUFBTyxHQUFHLEtBQUssRUFBVyxDQUFDO1FBQzNCLGVBQVUsR0FBRyxLQUFLLEVBQVUsQ0FBQztLQUM3Qjs4R0FOWSxjQUFjO2tHQUFkLGNBQWMscXNCQ2IzQiw0UEFPUSwyQ0RHRyxTQUFTOzsyRkFHUCxjQUFjO2tCQVAxQixTQUFTO2lDQUNHLElBQUksWUFDTixZQUFZLFdBRWIsQ0FBQyxTQUFTLENBQUMsbUJBQ0gsdUJBQXVCLENBQUMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIGlucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5pbXBvcnQgeyBUYWdNb2R1bGUgfSBmcm9tICdwcmltZW5nL3RhZyc7XHJcblxyXG50eXBlIFNldmVyaXR5ID0gJ3N1Y2Nlc3MnIHwgJ3NlY29uZGFyeScgfCAnaW5mbycgfCAnd2FybmluZycgfCAnZGFuZ2VyJyB8ICdjb250cmFzdCcgfCB1bmRlZmluZWQ7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuXHRzdGFuZGFsb25lOiB0cnVlLFxyXG5cdHNlbGVjdG9yOiAnYXJpbC1iYWRnZScsXHJcblx0dGVtcGxhdGVVcmw6ICcuL2JhZGdlLmNvbXBvbmVudC5odG1sJyxcclxuXHRpbXBvcnRzOiBbVGFnTW9kdWxlXSxcclxuXHRjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQmFkZ2VDb21wb25lbnQge1xyXG5cdGljb24gPSBpbnB1dDxzdHJpbmc+KCk7XHJcblx0dmFsdWUgPSBpbnB1dDxzdHJpbmc+KCk7XHJcblx0c2V2ZXJpdHkgPSBpbnB1dDxTZXZlcml0eT4oKTtcclxuXHRyb3VuZGVkID0gaW5wdXQ8Ym9vbGVhbj4oKTtcclxuXHRiYWNrZ3JvdW5kID0gaW5wdXQ8c3RyaW5nPigpO1xyXG59XHJcbiIsIjxwLXRhZ1xyXG4gIFtpY29uXT1cImljb24oKVwiXHJcbiAgW3ZhbHVlXT1cInZhbHVlKClcIlxyXG4gIFtzZXZlcml0eV09XCJzZXZlcml0eSgpXCJcclxuICBbcm91bmRlZF09XCJyb3VuZGVkKClcIlxyXG4gIFtzdHlsZV09XCJ7IGJhY2tncm91bmRDb2xvcjogYmFja2dyb3VuZCgpLCB0ZXh0QWxpZ246ICdjZW50ZXInLCBmb250U2l6ZTogJzAuOXJlbScgfVwiPlxyXG4gIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cclxuPC9wLXRhZz4iXX0=
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './index';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJpbC11aS1jaGFydHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9hcmlsL3VpL2NoYXJ0cy9hcmlsLXVpLWNoYXJ0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
export * from './src/pie/pie-chart.component';
|
|
2
|
+
export * from './src/column/column-chart.component';
|
|
3
|
+
export * from './src/line/line-chart.component';
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9hcmlsL3VpL2NoYXJ0cy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyxpQ0FBaUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc3JjL3BpZS9waWUtY2hhcnQuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9zcmMvY29sdW1uL2NvbHVtbi1jaGFydC5jb21wb25lbnQnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NyYy9saW5lL2xpbmUtY2hhcnQuY29tcG9uZW50JztcclxuIl19
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
import { NgClass } from '@angular/common';
|
|
2
|
+
import { isPlatformBrowser } from '@angular/common';
|
|
3
|
+
import { ChangeDetectionStrategy, Component, Inject, PLATFORM_ID, input } from '@angular/core';
|
|
4
|
+
import * as am5 from '@amcharts/amcharts5';
|
|
5
|
+
import am5themes_Animated from '@amcharts/amcharts5/themes/Animated';
|
|
6
|
+
import * as am5xy from '@amcharts/amcharts5/xy';
|
|
7
|
+
import { ChartThemes } from '../theme/theme';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
// EXAMPLE CHART DATA
|
|
10
|
+
// testChartData = [
|
|
11
|
+
// {
|
|
12
|
+
// label: "col1",
|
|
13
|
+
// value: 100000
|
|
14
|
+
// },
|
|
15
|
+
// {
|
|
16
|
+
// label: "col2",
|
|
17
|
+
// value: 160000
|
|
18
|
+
// },
|
|
19
|
+
// {
|
|
20
|
+
// label: "col3",
|
|
21
|
+
// value: 80000
|
|
22
|
+
// }
|
|
23
|
+
// ];
|
|
24
|
+
export class ColumnChartComponent {
|
|
25
|
+
constructor(platformId, zone) {
|
|
26
|
+
this.platformId = platformId;
|
|
27
|
+
this.zone = zone;
|
|
28
|
+
this.data = input.required();
|
|
29
|
+
this.chartId = input.required(); // must be given unique names for all charts. Its because angular and am5 rendering methods needs unique id to draw different canvas
|
|
30
|
+
this.appName = input('yeap');
|
|
31
|
+
this.chartHeight = input(100);
|
|
32
|
+
this.chartColorSet = [];
|
|
33
|
+
}
|
|
34
|
+
browserOnly(f) {
|
|
35
|
+
if (isPlatformBrowser(this.platformId)) {
|
|
36
|
+
this.zone.runOutsideAngular(() => {
|
|
37
|
+
f();
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
ngAfterViewInit() {
|
|
42
|
+
// Chart code goes in here
|
|
43
|
+
this.browserOnly(() => {
|
|
44
|
+
switch (this.appName()) {
|
|
45
|
+
case 'yeap':
|
|
46
|
+
this.chartColorSet = ChartThemes.getYeapAppColors();
|
|
47
|
+
break;
|
|
48
|
+
case 'thor':
|
|
49
|
+
this.chartColorSet = ChartThemes.getThorAppColors();
|
|
50
|
+
break;
|
|
51
|
+
case 'lena':
|
|
52
|
+
this.chartColorSet = ChartThemes.getLenaAppColors();
|
|
53
|
+
break;
|
|
54
|
+
case 'billing':
|
|
55
|
+
this.chartColorSet = ChartThemes.getThorAppColors();
|
|
56
|
+
break;
|
|
57
|
+
default:
|
|
58
|
+
this.chartColorSet = ChartThemes.getYeapAppColors();
|
|
59
|
+
break;
|
|
60
|
+
}
|
|
61
|
+
const root = am5.Root.new(this.chartId());
|
|
62
|
+
root._logo?.dispose();
|
|
63
|
+
root.setThemes([am5themes_Animated.new(root)]);
|
|
64
|
+
const chart = root.container.children.push(am5xy.XYChart.new(root, {
|
|
65
|
+
panY: false,
|
|
66
|
+
layout: root.verticalLayout
|
|
67
|
+
}));
|
|
68
|
+
const yAxis = chart.yAxes.push(am5xy.ValueAxis.new(root, {
|
|
69
|
+
renderer: am5xy.AxisRendererY.new(root, {})
|
|
70
|
+
}));
|
|
71
|
+
const xAxis = chart.xAxes.push(am5xy.CategoryAxis.new(root, {
|
|
72
|
+
renderer: am5xy.AxisRendererX.new(root, {}),
|
|
73
|
+
categoryField: 'label'
|
|
74
|
+
}));
|
|
75
|
+
xAxis.data.setAll(this.data());
|
|
76
|
+
const series = chart.series.push(am5xy.ColumnSeries.new(root, {
|
|
77
|
+
xAxis: xAxis,
|
|
78
|
+
yAxis: yAxis,
|
|
79
|
+
valueYField: 'value',
|
|
80
|
+
categoryXField: 'label',
|
|
81
|
+
stacked: true
|
|
82
|
+
}));
|
|
83
|
+
series.data.setAll(this.data());
|
|
84
|
+
xAxis.data.setAll(this.data());
|
|
85
|
+
series.columns.template.setAll({
|
|
86
|
+
stroke: am5.color(0xffffff),
|
|
87
|
+
strokeWidth: 2
|
|
88
|
+
});
|
|
89
|
+
series.columns.template.adapters.add('fill', (fill, target) => {
|
|
90
|
+
const dataContext = target.dataItem?.dataContext;
|
|
91
|
+
if (dataContext) {
|
|
92
|
+
const index = this.data().findIndex((item) => item.label === dataContext.label);
|
|
93
|
+
return am5.color(this.chartColorSet[index % this.chartColorSet.length]); // Sıralı renk seçimi
|
|
94
|
+
}
|
|
95
|
+
return fill;
|
|
96
|
+
});
|
|
97
|
+
});
|
|
98
|
+
}
|
|
99
|
+
ngOnDestroy() {
|
|
100
|
+
// Clean up chart when the component is removed
|
|
101
|
+
this.browserOnly(() => {
|
|
102
|
+
if (this.root) {
|
|
103
|
+
this.root.dispose();
|
|
104
|
+
}
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: ColumnChartComponent, deps: [{ token: PLATFORM_ID }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
108
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.1.2", type: ColumnChartComponent, isStandalone: true, selector: "aril-column-chart", inputs: { data: { classPropertyName: "data", publicName: "data", isSignal: true, isRequired: true, transformFunction: null }, chartId: { classPropertyName: "chartId", publicName: "chartId", isSignal: true, isRequired: true, transformFunction: null }, appName: { classPropertyName: "appName", publicName: "appName", isSignal: true, isRequired: false, transformFunction: null }, chartHeight: { classPropertyName: "chartHeight", publicName: "chartHeight", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `<div style="width: 100%; height:{{ chartHeight() }}px;" id="{{ chartId() }}"></div>`, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
109
|
+
}
|
|
110
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: ColumnChartComponent, decorators: [{
|
|
111
|
+
type: Component,
|
|
112
|
+
args: [{
|
|
113
|
+
standalone: true,
|
|
114
|
+
selector: 'aril-column-chart',
|
|
115
|
+
// templateUrl: './column-chart.component.html',
|
|
116
|
+
template: `<div style="width: 100%; height:{{ chartHeight() }}px;" id="{{ chartId() }}"></div>`,
|
|
117
|
+
imports: [NgClass],
|
|
118
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
119
|
+
}]
|
|
120
|
+
}], ctorParameters: () => [{ type: Object, decorators: [{
|
|
121
|
+
type: Inject,
|
|
122
|
+
args: [PLATFORM_ID]
|
|
123
|
+
}] }, { type: i0.NgZone }] });
|
|
124
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"column-chart.component.js","sourceRoot":"","sources":["../../../../../../projects/aril/ui/charts/src/column/column-chart.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgClass } from '@angular/common';\r\nimport { isPlatformBrowser } from '@angular/common';\r\nimport { ChangeDetectionStrategy, Component, Inject, NgZone, PLATFORM_ID, input } from '@angular/core';\r\n\r\nimport * as am5 from '@amcharts/amcharts5';\r\nimport am5themes_Animated from '@amcharts/amcharts5/themes/Animated';\r\nimport * as am5xy from '@amcharts/amcharts5/xy';\r\n\r\nimport { ChartThemes } from '../theme/theme';\r\n\r\ninterface dataItems {\r\n\tlabel: string; // this field can use as category\r\n\tvalue: number;\r\n\tvalue2?: number;\r\n}\r\n\r\ntype appNames = 'thor' | 'lena' | 'billing' | 'yeap';\r\n\r\n// EXAMPLE CHART DATA\r\n// testChartData = [\r\n// \t{\r\n// \t\tlabel: \"col1\",\r\n// \t\tvalue: 100000\r\n// \t},\r\n// \t{\r\n// \t\tlabel: \"col2\",\r\n// \t\tvalue: 160000\r\n// \t},\r\n// \t{\r\n// \t\tlabel: \"col3\",\r\n// \t\tvalue: 80000\r\n// \t}\r\n// ];\r\n\r\n@Component({\r\n\tstandalone: true,\r\n\tselector: 'aril-column-chart',\r\n\t// templateUrl: './column-chart.component.html',\r\n\ttemplate: `<div style=\"width: 100%; height:{{ chartHeight() }}px;\" id=\"{{ chartId() }}\"></div>`,\r\n\timports: [NgClass],\r\n\tchangeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class ColumnChartComponent {\r\n\tprivate root!: am5.Root;\r\n\r\n\tconstructor(@Inject(PLATFORM_ID) private platformId: Object, private zone: NgZone) {}\r\n\r\n\tdata = input.required<dataItems[]>();\r\n\tchartId = input.required<string>(); // must be given unique names for all charts. Its because angular and am5 rendering methods needs unique id to draw different canvas\r\n\tappName = input<appNames>('yeap');\r\n\tchartHeight = input<number>(100);\r\n\tchartColorSet: string[] = [];\r\n\r\n\tbrowserOnly(f: () => void) {\r\n\t\tif (isPlatformBrowser(this.platformId)) {\r\n\t\t\tthis.zone.runOutsideAngular(() => {\r\n\t\t\t\tf();\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n\r\n\tngAfterViewInit() {\r\n\t\t// Chart code goes in here\r\n\t\tthis.browserOnly(() => {\r\n\t\t\tswitch (this.appName()) {\r\n\t\t\t\tcase 'yeap':\r\n\t\t\t\t\tthis.chartColorSet = ChartThemes.getYeapAppColors();\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase 'thor':\r\n\t\t\t\t\tthis.chartColorSet = ChartThemes.getThorAppColors();\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase 'lena':\r\n\t\t\t\t\tthis.chartColorSet = ChartThemes.getLenaAppColors();\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase 'billing':\r\n\t\t\t\t\tthis.chartColorSet = ChartThemes.getThorAppColors();\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tdefault:\r\n\t\t\t\t\tthis.chartColorSet = ChartThemes.getYeapAppColors();\r\n\t\t\t\t\tbreak;\r\n\t\t\t}\r\n\t\t\tconst root = am5.Root.new(this.chartId());\r\n\t\t\troot._logo?.dispose();\r\n\t\t\troot.setThemes([am5themes_Animated.new(root)]);\r\n\r\n\t\t\tconst chart = root.container.children.push(\r\n\t\t\t\tam5xy.XYChart.new(root, {\r\n\t\t\t\t\tpanY: false,\r\n\t\t\t\t\tlayout: root.verticalLayout\r\n\t\t\t\t})\r\n\t\t\t);\r\n\r\n\t\t\tconst yAxis = chart.yAxes.push(\r\n\t\t\t\tam5xy.ValueAxis.new(root, {\r\n\t\t\t\t\trenderer: am5xy.AxisRendererY.new(root, {})\r\n\t\t\t\t})\r\n\t\t\t);\r\n\r\n\t\t\tconst xAxis = chart.xAxes.push(\r\n\t\t\t\tam5xy.CategoryAxis.new(root, {\r\n\t\t\t\t\trenderer: am5xy.AxisRendererX.new(root, {}),\r\n\t\t\t\t\tcategoryField: 'label'\r\n\t\t\t\t})\r\n\t\t\t);\r\n\t\t\txAxis.data.setAll(this.data());\r\n\r\n\t\t\tconst series = chart.series.push(\r\n\t\t\t\tam5xy.ColumnSeries.new(root, {\r\n\t\t\t\t\txAxis: xAxis,\r\n\t\t\t\t\tyAxis: yAxis,\r\n\t\t\t\t\tvalueYField: 'value',\r\n\t\t\t\t\tcategoryXField: 'label',\r\n\t\t\t\t\tstacked: true\r\n\t\t\t\t})\r\n\t\t\t);\r\n\r\n\t\t\tseries.data.setAll(this.data());\r\n\t\t\txAxis.data.setAll(this.data());\r\n\r\n\t\t\tseries.columns.template.setAll({\r\n\t\t\t\tstroke: am5.color(0xffffff),\r\n\t\t\t\tstrokeWidth: 2\r\n\t\t\t});\r\n\r\n\t\t\tseries.columns.template.adapters.add('fill', (fill, target) => {\r\n\t\t\t\tconst dataContext: any = target.dataItem?.dataContext;\r\n\t\t\t\tif (dataContext) {\r\n\t\t\t\t\tconst index = this.data().findIndex((item) => item.label === dataContext.label);\r\n\t\t\t\t\treturn am5.color(this.chartColorSet[index % this.chartColorSet.length]); // Sıralı renk seçimi\r\n\t\t\t\t}\r\n\t\t\t\treturn fill;\r\n\t\t\t});\r\n\t\t});\r\n\t}\r\n\r\n\tngOnDestroy() {\r\n\t\t// Clean up chart when the component is removed\r\n\t\tthis.browserOnly(() => {\r\n\t\t\tif (this.root) {\r\n\t\t\t\tthis.root.dispose();\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n}\r\n"]}
|
|
@@ -0,0 +1,164 @@
|
|
|
1
|
+
import { NgClass } from '@angular/common';
|
|
2
|
+
import { isPlatformBrowser } from '@angular/common';
|
|
3
|
+
import { ChangeDetectionStrategy, Component, Inject, PLATFORM_ID, input } from '@angular/core';
|
|
4
|
+
import * as am5 from '@amcharts/amcharts5';
|
|
5
|
+
import am5themes_Animated from '@amcharts/amcharts5/themes/Animated';
|
|
6
|
+
import * as am5xy from '@amcharts/amcharts5/xy';
|
|
7
|
+
import { ChartThemes } from '../theme/theme';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
// EXAMPLE CHART DATA
|
|
10
|
+
// https://www.amcharts.com/docs/v5/charts/xy-chart/axes/date-axis/
|
|
11
|
+
// testChartData = [
|
|
12
|
+
// {
|
|
13
|
+
// date: 1732628383422,
|
|
14
|
+
// value: 100000
|
|
15
|
+
// },
|
|
16
|
+
// {
|
|
17
|
+
// date: 1732638383422,
|
|
18
|
+
// value: 160000
|
|
19
|
+
// },
|
|
20
|
+
// {
|
|
21
|
+
// date: 1732658383422,
|
|
22
|
+
// value: 80000
|
|
23
|
+
// }
|
|
24
|
+
// ];
|
|
25
|
+
export class LineChartComponent {
|
|
26
|
+
constructor(platformId, zone) {
|
|
27
|
+
this.platformId = platformId;
|
|
28
|
+
this.zone = zone;
|
|
29
|
+
this.data = input.required();
|
|
30
|
+
this.chartId = input.required(); // must be given unique names for all charts. Its because angular and am5 rendering methods needs unique id to draw different canvas
|
|
31
|
+
this.appName = input('yeap');
|
|
32
|
+
this.timeUnit = input('day');
|
|
33
|
+
this.chartHeight = input(100);
|
|
34
|
+
this.chartColorSet = [];
|
|
35
|
+
}
|
|
36
|
+
browserOnly(f) {
|
|
37
|
+
if (isPlatformBrowser(this.platformId)) {
|
|
38
|
+
this.zone.runOutsideAngular(() => {
|
|
39
|
+
f();
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
ngAfterViewInit() {
|
|
44
|
+
// Chart code goes in here
|
|
45
|
+
this.browserOnly(() => {
|
|
46
|
+
switch (this.appName()) {
|
|
47
|
+
case 'yeap':
|
|
48
|
+
this.chartColorSet = ChartThemes.getYeapAppColors();
|
|
49
|
+
break;
|
|
50
|
+
case 'thor':
|
|
51
|
+
this.chartColorSet = ChartThemes.getThorAppColors();
|
|
52
|
+
break;
|
|
53
|
+
case 'lena':
|
|
54
|
+
this.chartColorSet = ChartThemes.getLenaAppColors();
|
|
55
|
+
break;
|
|
56
|
+
case 'billing':
|
|
57
|
+
this.chartColorSet = ChartThemes.getThorAppColors();
|
|
58
|
+
break;
|
|
59
|
+
default:
|
|
60
|
+
this.chartColorSet = ChartThemes.getYeapAppColors();
|
|
61
|
+
break;
|
|
62
|
+
}
|
|
63
|
+
const root = am5.Root.new('lineChart');
|
|
64
|
+
root._logo?.dispose();
|
|
65
|
+
root.setThemes([am5themes_Animated.new(root)]);
|
|
66
|
+
const chart = root.container.children.push(am5xy.XYChart.new(root, {
|
|
67
|
+
panX: false,
|
|
68
|
+
panY: false,
|
|
69
|
+
wheelX: 'panX',
|
|
70
|
+
wheelY: 'zoomX',
|
|
71
|
+
paddingLeft: 0
|
|
72
|
+
}));
|
|
73
|
+
const cursor = chart.set('cursor', am5xy.XYCursor.new(root, {
|
|
74
|
+
behavior: 'zoomX'
|
|
75
|
+
}));
|
|
76
|
+
cursor.lineY.set('visible', false);
|
|
77
|
+
const xAxis = chart.xAxes.push(am5xy.DateAxis.new(root, {
|
|
78
|
+
maxDeviation: 0,
|
|
79
|
+
baseInterval: {
|
|
80
|
+
timeUnit: this.timeUnit(),
|
|
81
|
+
count: 1
|
|
82
|
+
},
|
|
83
|
+
markUnitChange: false,
|
|
84
|
+
gridIntervals: [
|
|
85
|
+
{ timeUnit: 'day', count: 1 },
|
|
86
|
+
{ timeUnit: 'month', count: 1 },
|
|
87
|
+
{ timeUnit: 'year', count: 1 }
|
|
88
|
+
],
|
|
89
|
+
tooltipDateFormat: 'dd-MM-yyyy',
|
|
90
|
+
renderer: am5xy.AxisRendererX.new(root, {
|
|
91
|
+
minorGridEnabled: true,
|
|
92
|
+
minGridDistance: 200,
|
|
93
|
+
minorLabelsEnabled: true
|
|
94
|
+
}),
|
|
95
|
+
tooltip: am5.Tooltip.new(root, {})
|
|
96
|
+
}));
|
|
97
|
+
xAxis.set('minorDateFormats', {
|
|
98
|
+
day: 'dd',
|
|
99
|
+
month: 'MM',
|
|
100
|
+
year: 'yyyy'
|
|
101
|
+
});
|
|
102
|
+
xAxis.get('dateFormats')['day'] = 'dd/MM/yyyy';
|
|
103
|
+
const yAxis = chart.yAxes.push(am5xy.ValueAxis.new(root, {
|
|
104
|
+
renderer: am5xy.AxisRendererY.new(root, {})
|
|
105
|
+
}));
|
|
106
|
+
const series = chart.series.push(am5xy.LineSeries.new(root, {
|
|
107
|
+
name: 'Series',
|
|
108
|
+
xAxis: xAxis,
|
|
109
|
+
yAxis: yAxis,
|
|
110
|
+
valueYField: 'value',
|
|
111
|
+
valueXField: 'date',
|
|
112
|
+
stroke: am5.color(this.chartColorSet[0]),
|
|
113
|
+
tooltip: am5.Tooltip.new(root, {
|
|
114
|
+
labelText: '{valueY}'
|
|
115
|
+
})
|
|
116
|
+
}));
|
|
117
|
+
series.bullets.push(function () {
|
|
118
|
+
const bulletCircle = am5.Circle.new(root, {
|
|
119
|
+
radius: 5,
|
|
120
|
+
fill: series.get('fill')
|
|
121
|
+
});
|
|
122
|
+
return am5.Bullet.new(root, {
|
|
123
|
+
sprite: bulletCircle
|
|
124
|
+
});
|
|
125
|
+
});
|
|
126
|
+
chart.set('scrollbarX', am5.Scrollbar.new(root, {
|
|
127
|
+
orientation: 'horizontal'
|
|
128
|
+
}));
|
|
129
|
+
series.set('fill', am5.color(this.chartColorSet[0])); // set Series color to red
|
|
130
|
+
// series.fills.template.setAll({
|
|
131
|
+
// fillOpacity: 0.5,
|
|
132
|
+
// visible: true
|
|
133
|
+
// color
|
|
134
|
+
// });
|
|
135
|
+
series.data.setAll(this.data());
|
|
136
|
+
series.appear(1000);
|
|
137
|
+
chart.appear(1000, 100);
|
|
138
|
+
});
|
|
139
|
+
}
|
|
140
|
+
ngOnDestroy() {
|
|
141
|
+
// Clean up chart when the component is removed
|
|
142
|
+
this.browserOnly(() => {
|
|
143
|
+
if (this.root) {
|
|
144
|
+
this.root.dispose();
|
|
145
|
+
}
|
|
146
|
+
});
|
|
147
|
+
}
|
|
148
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: LineChartComponent, deps: [{ token: PLATFORM_ID }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
149
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.1.2", type: LineChartComponent, isStandalone: true, selector: "aril-line-chart", inputs: { data: { classPropertyName: "data", publicName: "data", isSignal: true, isRequired: true, transformFunction: null }, chartId: { classPropertyName: "chartId", publicName: "chartId", isSignal: true, isRequired: true, transformFunction: null }, appName: { classPropertyName: "appName", publicName: "appName", isSignal: true, isRequired: false, transformFunction: null }, timeUnit: { classPropertyName: "timeUnit", publicName: "timeUnit", isSignal: true, isRequired: false, transformFunction: null }, chartHeight: { classPropertyName: "chartHeight", publicName: "chartHeight", isSignal: true, isRequired: false, transformFunction: null } }, ngImport: i0, template: `<div style="width: 100%; height:{{ chartHeight() }}px;" id="{{ chartId() }}"></div>`, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
150
|
+
}
|
|
151
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: LineChartComponent, decorators: [{
|
|
152
|
+
type: Component,
|
|
153
|
+
args: [{
|
|
154
|
+
standalone: true,
|
|
155
|
+
selector: 'aril-line-chart',
|
|
156
|
+
template: `<div style="width: 100%; height:{{ chartHeight() }}px;" id="{{ chartId() }}"></div>`,
|
|
157
|
+
imports: [NgClass],
|
|
158
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
159
|
+
}]
|
|
160
|
+
}], ctorParameters: () => [{ type: Object, decorators: [{
|
|
161
|
+
type: Inject,
|
|
162
|
+
args: [PLATFORM_ID]
|
|
163
|
+
}] }, { type: i0.NgZone }] });
|
|
164
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"line-chart.component.js","sourceRoot":"","sources":["../../../../../../projects/aril/ui/charts/src/line/line-chart.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { NgClass } from '@angular/common';\r\nimport { isPlatformBrowser } from '@angular/common';\r\nimport { ChangeDetectionStrategy, Component, Inject, NgZone, PLATFORM_ID, input } from '@angular/core';\r\n\r\nimport * as am5 from '@amcharts/amcharts5';\r\nimport am5themes_Animated from '@amcharts/amcharts5/themes/Animated';\r\nimport * as am5xy from '@amcharts/amcharts5/xy';\r\n\r\nimport { ChartThemes } from '../theme/theme';\r\n\r\ninterface dataItems {\r\n\tdate: number; // this field can use as category\r\n\tvalue: number;\r\n}\r\n\r\ntype appNames = 'thor' | 'lena' | 'billing' | 'yeap';\r\ntype timeUnit = 'day' | 'month' | 'year' | 'week' | 'hour' | 'minute' | 'second';\r\n\r\n// EXAMPLE CHART DATA\r\n// https://www.amcharts.com/docs/v5/charts/xy-chart/axes/date-axis/\r\n// testChartData = [\r\n// \t{\r\n// \t\tdate: 1732628383422,\r\n// \t\tvalue: 100000\r\n// \t},\r\n// \t{\r\n// \t\tdate: 1732638383422,\r\n// \t\tvalue: 160000\r\n// \t},\r\n// \t{\r\n// \t\tdate: 1732658383422,\r\n// \t\tvalue: 80000\r\n// \t}\r\n// ];\r\n\r\n@Component({\r\n\tstandalone: true,\r\n\tselector: 'aril-line-chart',\r\n\ttemplate: `<div style=\"width: 100%; height:{{ chartHeight() }}px;\" id=\"{{ chartId() }}\"></div>`,\r\n\timports: [NgClass],\r\n\tchangeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class LineChartComponent {\r\n\tprivate root!: am5.Root;\r\n\r\n\tconstructor(@Inject(PLATFORM_ID) private platformId: Object, private zone: NgZone) {}\r\n\r\n\tdata = input.required<dataItems[]>();\r\n\tchartId = input.required<string>(); // must be given unique names for all charts. Its because angular and am5 rendering methods needs unique id to draw different canvas\r\n\tappName = input<appNames>('yeap');\r\n\ttimeUnit = input<timeUnit>('day');\r\n\tchartHeight = input<number>(100);\r\n\tchartColorSet: string[] = [];\r\n\r\n\tbrowserOnly(f: () => void) {\r\n\t\tif (isPlatformBrowser(this.platformId)) {\r\n\t\t\tthis.zone.runOutsideAngular(() => {\r\n\t\t\t\tf();\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n\r\n\tngAfterViewInit() {\r\n\t\t// Chart code goes in here\r\n\t\tthis.browserOnly(() => {\r\n\t\t\tswitch (this.appName()) {\r\n\t\t\t\tcase 'yeap':\r\n\t\t\t\t\tthis.chartColorSet = ChartThemes.getYeapAppColors();\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase 'thor':\r\n\t\t\t\t\tthis.chartColorSet = ChartThemes.getThorAppColors();\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase 'lena':\r\n\t\t\t\t\tthis.chartColorSet = ChartThemes.getLenaAppColors();\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase 'billing':\r\n\t\t\t\t\tthis.chartColorSet = ChartThemes.getThorAppColors();\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tdefault:\r\n\t\t\t\t\tthis.chartColorSet = ChartThemes.getYeapAppColors();\r\n\t\t\t\t\tbreak;\r\n\t\t\t}\r\n\t\t\tconst root = am5.Root.new('lineChart');\r\n\t\t\troot._logo?.dispose();\r\n\t\t\troot.setThemes([am5themes_Animated.new(root)]);\r\n\r\n\t\t\tconst chart = root.container.children.push(\r\n\t\t\t\tam5xy.XYChart.new(root, {\r\n\t\t\t\t\tpanX: false,\r\n\t\t\t\t\tpanY: false,\r\n\t\t\t\t\twheelX: 'panX',\r\n\t\t\t\t\twheelY: 'zoomX',\r\n\t\t\t\t\tpaddingLeft: 0\r\n\t\t\t\t})\r\n\t\t\t);\r\n\r\n\t\t\tconst cursor = chart.set(\r\n\t\t\t\t'cursor',\r\n\t\t\t\tam5xy.XYCursor.new(root, {\r\n\t\t\t\t\tbehavior: 'zoomX'\r\n\t\t\t\t})\r\n\t\t\t);\r\n\t\t\tcursor.lineY.set('visible', false);\r\n\r\n\t\t\tconst xAxis = chart.xAxes.push(\r\n\t\t\t\tam5xy.DateAxis.new(root, {\r\n\t\t\t\t\tmaxDeviation: 0,\r\n\t\t\t\t\tbaseInterval: {\r\n\t\t\t\t\t\ttimeUnit: this.timeUnit(),\r\n\t\t\t\t\t\tcount: 1\r\n\t\t\t\t\t},\r\n\t\t\t\t\tmarkUnitChange: false,\r\n\t\t\t\t\tgridIntervals: [\r\n\t\t\t\t\t\t{ timeUnit: 'day', count: 1 },\r\n\t\t\t\t\t\t{ timeUnit: 'month', count: 1 },\r\n\t\t\t\t\t\t{ timeUnit: 'year', count: 1 }\r\n\t\t\t\t\t],\r\n\t\t\t\t\ttooltipDateFormat: 'dd-MM-yyyy',\r\n\t\t\t\t\trenderer: am5xy.AxisRendererX.new(root, {\r\n\t\t\t\t\t\tminorGridEnabled: true,\r\n\t\t\t\t\t\tminGridDistance: 200,\r\n\t\t\t\t\t\tminorLabelsEnabled: true\r\n\t\t\t\t\t}),\r\n\t\t\t\t\ttooltip: am5.Tooltip.new(root, {})\r\n\t\t\t\t})\r\n\t\t\t);\r\n\r\n\t\t\txAxis.set('minorDateFormats', {\r\n\t\t\t\tday: 'dd',\r\n\t\t\t\tmonth: 'MM',\r\n\t\t\t\tyear: 'yyyy'\r\n\t\t\t});\r\n\r\n\t\t\txAxis.get('dateFormats')!['day'] = 'dd/MM/yyyy';\r\n\r\n\t\t\tconst yAxis = chart.yAxes.push(\r\n\t\t\t\tam5xy.ValueAxis.new(root, {\r\n\t\t\t\t\trenderer: am5xy.AxisRendererY.new(root, {})\r\n\t\t\t\t})\r\n\t\t\t);\r\n\r\n\t\t\tconst series = chart.series.push(\r\n\t\t\t\tam5xy.LineSeries.new(root, {\r\n\t\t\t\t\tname: 'Series',\r\n\t\t\t\t\txAxis: xAxis,\r\n\t\t\t\t\tyAxis: yAxis,\r\n\t\t\t\t\tvalueYField: 'value',\r\n\t\t\t\t\tvalueXField: 'date',\r\n\t\t\t\t\tstroke: am5.color(this.chartColorSet[0]),\r\n\t\t\t\t\ttooltip: am5.Tooltip.new(root, {\r\n\t\t\t\t\t\tlabelText: '{valueY}'\r\n\t\t\t\t\t})\r\n\t\t\t\t})\r\n\t\t\t);\r\n\r\n\t\t\tseries.bullets.push(function () {\r\n\t\t\t\tconst bulletCircle = am5.Circle.new(root, {\r\n\t\t\t\t\tradius: 5,\r\n\t\t\t\t\tfill: series.get('fill')\r\n\t\t\t\t});\r\n\t\t\t\treturn am5.Bullet.new(root, {\r\n\t\t\t\t\tsprite: bulletCircle\r\n\t\t\t\t});\r\n\t\t\t});\r\n\r\n\t\t\tchart.set(\r\n\t\t\t\t'scrollbarX',\r\n\t\t\t\tam5.Scrollbar.new(root, {\r\n\t\t\t\t\torientation: 'horizontal'\r\n\t\t\t\t})\r\n\t\t\t);\r\n\r\n\t\t\tseries.set('fill', am5.color(this.chartColorSet[0])); // set Series color to red\r\n\t\t\t// series.fills.template.setAll({\r\n\t\t\t// \tfillOpacity: 0.5,\r\n\t\t\t// \tvisible: true\r\n\t\t\t// \tcolor\r\n\t\t\t// });\r\n\r\n\t\t\tseries.data.setAll(this.data());\r\n\t\t\tseries.appear(1000);\r\n\t\t\tchart.appear(1000, 100);\r\n\t\t});\r\n\t}\r\n\r\n\tngOnDestroy() {\r\n\t\t// Clean up chart when the component is removed\r\n\t\tthis.browserOnly(() => {\r\n\t\t\tif (this.root) {\r\n\t\t\t\tthis.root.dispose();\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n}\r\n"]}
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
import { NgClass } from '@angular/common';
|
|
2
|
+
import { isPlatformBrowser } from '@angular/common';
|
|
3
|
+
import { ChangeDetectionStrategy, Component, Inject, PLATFORM_ID, input } from '@angular/core';
|
|
4
|
+
import * as am5 from '@amcharts/amcharts5';
|
|
5
|
+
import * as am5percent from '@amcharts/amcharts5/percent';
|
|
6
|
+
import am5themes_Animated from '@amcharts/amcharts5/themes/Animated';
|
|
7
|
+
import { ChartThemes } from '../theme/theme';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
// EXAMPLE CHART DATA
|
|
10
|
+
// testChartData = [
|
|
11
|
+
// {
|
|
12
|
+
// label: "part1",
|
|
13
|
+
// value: 100000
|
|
14
|
+
// },
|
|
15
|
+
// {
|
|
16
|
+
// label: "part1",
|
|
17
|
+
// value: 160000
|
|
18
|
+
// },
|
|
19
|
+
// {
|
|
20
|
+
// label: "part1",
|
|
21
|
+
// value: 80000
|
|
22
|
+
// }
|
|
23
|
+
// ];
|
|
24
|
+
export class PieChartComponent {
|
|
25
|
+
constructor(platformId, zone) {
|
|
26
|
+
this.platformId = platformId;
|
|
27
|
+
this.zone = zone;
|
|
28
|
+
this.data = input.required();
|
|
29
|
+
this.chartId = input.required(); // must be given unique names for all charts. Its because angular and am5 rendering methods needs unique id to draw different canvas
|
|
30
|
+
this.appName = input('yeap');
|
|
31
|
+
this.chartColorSet = [];
|
|
32
|
+
this.chartHeight = input.required();
|
|
33
|
+
}
|
|
34
|
+
browserOnly(f) {
|
|
35
|
+
if (isPlatformBrowser(this.platformId)) {
|
|
36
|
+
this.zone.runOutsideAngular(() => {
|
|
37
|
+
f();
|
|
38
|
+
});
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
ngAfterViewInit() {
|
|
42
|
+
// Chart code goes in here
|
|
43
|
+
this.browserOnly(() => {
|
|
44
|
+
switch (this.appName()) {
|
|
45
|
+
case 'yeap':
|
|
46
|
+
this.chartColorSet = ChartThemes.getYeapAppColors();
|
|
47
|
+
break;
|
|
48
|
+
case 'thor':
|
|
49
|
+
this.chartColorSet = ChartThemes.getThorAppColors();
|
|
50
|
+
break;
|
|
51
|
+
case 'lena':
|
|
52
|
+
this.chartColorSet = ChartThemes.getLenaAppColors();
|
|
53
|
+
break;
|
|
54
|
+
case 'billing':
|
|
55
|
+
this.chartColorSet = ChartThemes.getThorAppColors();
|
|
56
|
+
break;
|
|
57
|
+
default:
|
|
58
|
+
this.chartColorSet = ChartThemes.getYeapAppColors();
|
|
59
|
+
break;
|
|
60
|
+
}
|
|
61
|
+
const root = am5.Root.new('pieChart');
|
|
62
|
+
root._logo?.dispose();
|
|
63
|
+
root.setThemes([am5themes_Animated.new(root)]);
|
|
64
|
+
const chart = root.container.children.push(am5percent.PieChart.new(root, {}));
|
|
65
|
+
const series = chart.series.push(am5percent.PieSeries.new(root, {
|
|
66
|
+
name: 'Series',
|
|
67
|
+
categoryField: 'label',
|
|
68
|
+
valueField: 'value',
|
|
69
|
+
fillField: 'color'
|
|
70
|
+
}));
|
|
71
|
+
series.slices.template.adapters.add('fill', (fill, target) => {
|
|
72
|
+
const dataContext = target.dataItem?.dataContext;
|
|
73
|
+
if (dataContext) {
|
|
74
|
+
const index = this.data().findIndex((item) => item.label === dataContext.label);
|
|
75
|
+
return am5.color(this.chartColorSet[index % this.chartColorSet.length]); // Sıralı renk seçimi
|
|
76
|
+
}
|
|
77
|
+
return fill;
|
|
78
|
+
});
|
|
79
|
+
series.slices.template.setAll({
|
|
80
|
+
stroke: am5.color(0xffffff),
|
|
81
|
+
strokeWidth: 2
|
|
82
|
+
});
|
|
83
|
+
series.data.setAll(this.data());
|
|
84
|
+
const legend = chart.children.push(am5.Legend.new(root, {
|
|
85
|
+
centerX: am5.percent(50),
|
|
86
|
+
x: am5.percent(50),
|
|
87
|
+
layout: root.horizontalLayout
|
|
88
|
+
}));
|
|
89
|
+
legend.data.setAll(series.dataItems);
|
|
90
|
+
});
|
|
91
|
+
}
|
|
92
|
+
ngOnDestroy() {
|
|
93
|
+
// Clean up chart when the component is removed
|
|
94
|
+
this.browserOnly(() => {
|
|
95
|
+
if (this.root) {
|
|
96
|
+
this.root.dispose();
|
|
97
|
+
}
|
|
98
|
+
});
|
|
99
|
+
}
|
|
100
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: PieChartComponent, deps: [{ token: PLATFORM_ID }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
101
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "17.1.2", type: PieChartComponent, isStandalone: true, selector: "aril-pie-chart", inputs: { data: { classPropertyName: "data", publicName: "data", isSignal: true, isRequired: true, transformFunction: null }, chartId: { classPropertyName: "chartId", publicName: "chartId", isSignal: true, isRequired: true, transformFunction: null }, appName: { classPropertyName: "appName", publicName: "appName", isSignal: true, isRequired: false, transformFunction: null }, chartHeight: { classPropertyName: "chartHeight", publicName: "chartHeight", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: `<div style="width: 100%; height:{{ chartHeight() }}px;" id="{{ chartId() }}"></div>`, isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
102
|
+
}
|
|
103
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: PieChartComponent, decorators: [{
|
|
104
|
+
type: Component,
|
|
105
|
+
args: [{
|
|
106
|
+
standalone: true,
|
|
107
|
+
selector: 'aril-pie-chart',
|
|
108
|
+
template: `<div style="width: 100%; height:{{ chartHeight() }}px;" id="{{ chartId() }}"></div>`,
|
|
109
|
+
imports: [NgClass],
|
|
110
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
111
|
+
}]
|
|
112
|
+
}], ctorParameters: () => [{ type: Object, decorators: [{
|
|
113
|
+
type: Inject,
|
|
114
|
+
args: [PLATFORM_ID]
|
|
115
|
+
}] }, { type: i0.NgZone }] });
|
|
116
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pie-chart.component.js","sourceRoot":"","sources":["../../../../../../projects/aril/ui/charts/src/pie/pie-chart.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,iBAAiB,CAAC;AAC1C,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;AACpD,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,MAAM,EAAU,WAAW,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAEvG,OAAO,KAAK,GAAG,MAAM,qBAAqB,CAAC;AAC3C,OAAO,KAAK,UAAU,MAAM,6BAA6B,CAAC;AAC1D,OAAO,kBAAkB,MAAM,qCAAqC,CAAC;AAErE,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;;AAU7C,qBAAqB;AACrB,oBAAoB;AACpB,KAAK;AACL,oBAAoB;AACpB,kBAAkB;AAClB,MAAM;AACN,KAAK;AACL,oBAAoB;AACpB,kBAAkB;AAClB,MAAM;AACN,KAAK;AACL,oBAAoB;AACpB,iBAAiB;AACjB,KAAK;AACL,KAAK;AASL,MAAM,OAAO,iBAAiB;IAG7B,YAAyC,UAAkB,EAAU,IAAY;QAAxC,eAAU,GAAV,UAAU,CAAQ;QAAU,SAAI,GAAJ,IAAI,CAAQ;QAEjF,SAAI,GAAG,KAAK,CAAC,QAAQ,EAAe,CAAC;QACrC,YAAO,GAAG,KAAK,CAAC,QAAQ,EAAU,CAAC,CAAC,oIAAoI;QACxK,YAAO,GAAG,KAAK,CAAW,MAAM,CAAC,CAAC;QAClC,kBAAa,GAAa,EAAE,CAAC;QAC7B,gBAAW,GAAG,KAAK,CAAC,QAAQ,EAAU,CAAC;IAN6C,CAAC;IAQrF,WAAW,CAAC,CAAa;QACxB,IAAI,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;YACxC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE;gBAChC,CAAC,EAAE,CAAC;YACL,CAAC,CAAC,CAAC;QACJ,CAAC;IACF,CAAC;IAED,eAAe;QACd,0BAA0B;QAC1B,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE;YACrB,QAAQ,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC;gBACxB,KAAK,MAAM;oBACV,IAAI,CAAC,aAAa,GAAG,WAAW,CAAC,gBAAgB,EAAE,CAAC;oBACpD,MAAM;gBACP,KAAK,MAAM;oBACV,IAAI,CAAC,aAAa,GAAG,WAAW,CAAC,gBAAgB,EAAE,CAAC;oBACpD,MAAM;gBACP,KAAK,MAAM;oBACV,IAAI,CAAC,aAAa,GAAG,WAAW,CAAC,gBAAgB,EAAE,CAAC;oBACpD,MAAM;gBACP,KAAK,SAAS;oBACb,IAAI,CAAC,aAAa,GAAG,WAAW,CAAC,gBAAgB,EAAE,CAAC;oBACpD,MAAM;gBACP;oBACC,IAAI,CAAC,aAAa,GAAG,WAAW,CAAC,gBAAgB,EAAE,CAAC;oBACpD,MAAM;YACR,CAAC;YACD,MAAM,IAAI,GAAG,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;YACtC,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,CAAC;YACtB,IAAI,CAAC,SAAS,CAAC,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;YAE/C,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC;YAE9E,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,IAAI,CAC/B,UAAU,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,EAAE;gBAC9B,IAAI,EAAE,QAAQ;gBACd,aAAa,EAAE,OAAO;gBACtB,UAAU,EAAE,OAAO;gBACnB,SAAS,EAAE,OAAO;aAClB,CAAC,CACF,CAAC;YAEF,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,GAAG,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,MAAM,EAAE,EAAE;gBAC5D,MAAM,WAAW,GAAQ,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC;gBACtD,IAAI,WAAW,EAAE,CAAC;oBACjB,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,KAAK,WAAW,CAAC,KAAK,CAAC,CAAC;oBAChF,OAAO,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,qBAAqB;gBAC/F,CAAC;gBACD,OAAO,IAAI,CAAC;YACb,CAAC,CAAC,CAAC;YAEH,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC;gBAC7B,MAAM,EAAE,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC;gBAC3B,WAAW,EAAE,CAAC;aACd,CAAC,CAAC;YAEH,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;YAEhC,MAAM,MAAM,GAAG,KAAK,CAAC,QAAQ,CAAC,IAAI,CACjC,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,IAAI,EAAE;gBACpB,OAAO,EAAE,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC;gBACxB,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC;gBAClB,MAAM,EAAE,IAAI,CAAC,gBAAgB;aAC7B,CAAC,CACF,CAAC;YAEF,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QACtC,CAAC,CAAC,CAAC;IACJ,CAAC;IAED,WAAW;QACV,+CAA+C;QAC/C,IAAI,CAAC,WAAW,CAAC,GAAG,EAAE;YACrB,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;gBACf,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YACrB,CAAC;QACF,CAAC,CAAC,CAAC;IACJ,CAAC;8GAzFW,iBAAiB,kBAGT,WAAW;kGAHnB,iBAAiB,8kBAJnB,qFAAqF;;2FAInF,iBAAiB;kBAP7B,SAAS;mBAAC;oBACV,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,gBAAgB;oBAC1B,QAAQ,EAAE,qFAAqF;oBAC/F,OAAO,EAAE,CAAC,OAAO,CAAC;oBAClB,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAC/C;;0BAIa,MAAM;2BAAC,WAAW","sourcesContent":["import { NgClass } from '@angular/common';\r\nimport { isPlatformBrowser } from '@angular/common';\r\nimport { ChangeDetectionStrategy, Component, Inject, NgZone, PLATFORM_ID, input } from '@angular/core';\r\n\r\nimport * as am5 from '@amcharts/amcharts5';\r\nimport * as am5percent from '@amcharts/amcharts5/percent';\r\nimport am5themes_Animated from '@amcharts/amcharts5/themes/Animated';\r\n\r\nimport { ChartThemes } from '../theme/theme';\r\n\r\n// import * as am5color from \"@amcharts/amcharts5/color\";\r\ninterface dataItems {\r\n\tlabel: string; // this field can use as category\r\n\tvalue: number;\r\n}\r\n\r\ntype appNames = 'thor' | 'lena' | 'billing' | 'yeap';\r\n\r\n// EXAMPLE CHART DATA\r\n// testChartData = [\r\n// \t{\r\n// \t\tlabel: \"part1\",\r\n// \t\tvalue: 100000\r\n// \t},\r\n// \t{\r\n// \t\tlabel: \"part1\",\r\n// \t\tvalue: 160000\r\n// \t},\r\n// \t{\r\n// \t\tlabel: \"part1\",\r\n// \t\tvalue: 80000\r\n// \t}\r\n// ];\r\n\r\n@Component({\r\n\tstandalone: true,\r\n\tselector: 'aril-pie-chart',\r\n\ttemplate: `<div style=\"width: 100%; height:{{ chartHeight() }}px;\" id=\"{{ chartId() }}\"></div>`,\r\n\timports: [NgClass],\r\n\tchangeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class PieChartComponent {\r\n\tprivate root!: am5.Root;\r\n\r\n\tconstructor(@Inject(PLATFORM_ID) private platformId: Object, private zone: NgZone) {}\r\n\r\n\tdata = input.required<dataItems[]>();\r\n\tchartId = input.required<string>(); // must be given unique names for all charts. Its because angular and am5 rendering methods needs unique id to draw different canvas\r\n\tappName = input<appNames>('yeap');\r\n\tchartColorSet: string[] = [];\r\n\tchartHeight = input.required<number>();\r\n\r\n\tbrowserOnly(f: () => void) {\r\n\t\tif (isPlatformBrowser(this.platformId)) {\r\n\t\t\tthis.zone.runOutsideAngular(() => {\r\n\t\t\t\tf();\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n\r\n\tngAfterViewInit() {\r\n\t\t// Chart code goes in here\r\n\t\tthis.browserOnly(() => {\r\n\t\t\tswitch (this.appName()) {\r\n\t\t\t\tcase 'yeap':\r\n\t\t\t\t\tthis.chartColorSet = ChartThemes.getYeapAppColors();\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase 'thor':\r\n\t\t\t\t\tthis.chartColorSet = ChartThemes.getThorAppColors();\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase 'lena':\r\n\t\t\t\t\tthis.chartColorSet = ChartThemes.getLenaAppColors();\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tcase 'billing':\r\n\t\t\t\t\tthis.chartColorSet = ChartThemes.getThorAppColors();\r\n\t\t\t\t\tbreak;\r\n\t\t\t\tdefault:\r\n\t\t\t\t\tthis.chartColorSet = ChartThemes.getYeapAppColors();\r\n\t\t\t\t\tbreak;\r\n\t\t\t}\r\n\t\t\tconst root = am5.Root.new('pieChart');\r\n\t\t\troot._logo?.dispose();\r\n\t\t\troot.setThemes([am5themes_Animated.new(root)]);\r\n\r\n\t\t\tconst chart = root.container.children.push(am5percent.PieChart.new(root, {}));\r\n\r\n\t\t\tconst series = chart.series.push(\r\n\t\t\t\tam5percent.PieSeries.new(root, {\r\n\t\t\t\t\tname: 'Series',\r\n\t\t\t\t\tcategoryField: 'label',\r\n\t\t\t\t\tvalueField: 'value',\r\n\t\t\t\t\tfillField: 'color'\r\n\t\t\t\t})\r\n\t\t\t);\r\n\r\n\t\t\tseries.slices.template.adapters.add('fill', (fill, target) => {\r\n\t\t\t\tconst dataContext: any = target.dataItem?.dataContext;\r\n\t\t\t\tif (dataContext) {\r\n\t\t\t\t\tconst index = this.data().findIndex((item) => item.label === dataContext.label);\r\n\t\t\t\t\treturn am5.color(this.chartColorSet[index % this.chartColorSet.length]); // Sıralı renk seçimi\r\n\t\t\t\t}\r\n\t\t\t\treturn fill;\r\n\t\t\t});\r\n\r\n\t\t\tseries.slices.template.setAll({\r\n\t\t\t\tstroke: am5.color(0xffffff),\r\n\t\t\t\tstrokeWidth: 2\r\n\t\t\t});\r\n\r\n\t\t\tseries.data.setAll(this.data());\r\n\r\n\t\t\tconst legend = chart.children.push(\r\n\t\t\t\tam5.Legend.new(root, {\r\n\t\t\t\t\tcenterX: am5.percent(50),\r\n\t\t\t\t\tx: am5.percent(50),\r\n\t\t\t\t\tlayout: root.horizontalLayout\r\n\t\t\t\t})\r\n\t\t\t);\r\n\r\n\t\t\tlegend.data.setAll(series.dataItems);\r\n\t\t});\r\n\t}\r\n\r\n\tngOnDestroy() {\r\n\t\t// Clean up chart when the component is removed\r\n\t\tthis.browserOnly(() => {\r\n\t\t\tif (this.root) {\r\n\t\t\t\tthis.root.dispose();\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n}\r\n"]}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
export class ChartThemes {
|
|
2
|
+
static getThorAppColors() {
|
|
3
|
+
return [
|
|
4
|
+
'#e7625f',
|
|
5
|
+
'#c85250',
|
|
6
|
+
'#f7bec0',
|
|
7
|
+
'#e9eae0',
|
|
8
|
+
'#aa1945',
|
|
9
|
+
'#f1ced4',
|
|
10
|
+
'#391306',
|
|
11
|
+
'#821d30',
|
|
12
|
+
'#fb4570',
|
|
13
|
+
'#fb4570',
|
|
14
|
+
'#fb4570',
|
|
15
|
+
'#5f093d',
|
|
16
|
+
'#b21368',
|
|
17
|
+
'#d67ba8'
|
|
18
|
+
];
|
|
19
|
+
}
|
|
20
|
+
static getYeapAppColors() {
|
|
21
|
+
return [
|
|
22
|
+
'#525252',
|
|
23
|
+
'#9A9A9A',
|
|
24
|
+
'#767676',
|
|
25
|
+
'#828282',
|
|
26
|
+
'#BEBEBE',
|
|
27
|
+
'#8E8E8E',
|
|
28
|
+
'#6A6A6A',
|
|
29
|
+
'#A6A6A6',
|
|
30
|
+
'#5E5E5E',
|
|
31
|
+
'#B2B2B2',
|
|
32
|
+
'#CACACA'
|
|
33
|
+
];
|
|
34
|
+
}
|
|
35
|
+
static getLenaAppColors() {
|
|
36
|
+
return [
|
|
37
|
+
'#abea7c',
|
|
38
|
+
'#fede00',
|
|
39
|
+
'#c8df52',
|
|
40
|
+
'#0a7029',
|
|
41
|
+
'#dbe8d8',
|
|
42
|
+
'#65463e',
|
|
43
|
+
'#aad6a0',
|
|
44
|
+
'#013a20',
|
|
45
|
+
'#bacc81',
|
|
46
|
+
'#cdd193',
|
|
47
|
+
'#fad02c',
|
|
48
|
+
'#282120',
|
|
49
|
+
'#333652',
|
|
50
|
+
'#b2d7da'
|
|
51
|
+
];
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGhlbWUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hcmlsL3VpL2NoYXJ0cy9zcmMvdGhlbWUvdGhlbWUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFPLFdBQVc7SUFDdkIsTUFBTSxDQUFDLGdCQUFnQjtRQUN0QixPQUFPO1lBQ04sU0FBUztZQUNULFNBQVM7WUFDVCxTQUFTO1lBQ1QsU0FBUztZQUNULFNBQVM7WUFDVCxTQUFTO1lBQ1QsU0FBUztZQUNULFNBQVM7WUFDVCxTQUFTO1lBQ1QsU0FBUztZQUNULFNBQVM7WUFDVCxTQUFTO1lBQ1QsU0FBUztZQUNULFNBQVM7U0FDVCxDQUFDO0lBQ0gsQ0FBQztJQUVELE1BQU0sQ0FBQyxnQkFBZ0I7UUFDdEIsT0FBTztZQUNOLFNBQVM7WUFDVCxTQUFTO1lBQ1QsU0FBUztZQUNULFNBQVM7WUFDVCxTQUFTO1lBQ1QsU0FBUztZQUNULFNBQVM7WUFDVCxTQUFTO1lBQ1QsU0FBUztZQUNULFNBQVM7WUFDVCxTQUFTO1NBQ1QsQ0FBQztJQUNILENBQUM7SUFFRCxNQUFNLENBQUMsZ0JBQWdCO1FBQ3RCLE9BQU87WUFDTixTQUFTO1lBQ1QsU0FBUztZQUNULFNBQVM7WUFDVCxTQUFTO1lBQ1QsU0FBUztZQUNULFNBQVM7WUFDVCxTQUFTO1lBQ1QsU0FBUztZQUNULFNBQVM7WUFDVCxTQUFTO1lBQ1QsU0FBUztZQUNULFNBQVM7WUFDVCxTQUFTO1lBQ1QsU0FBUztTQUNULENBQUM7SUFDSCxDQUFDO0NBQ0QiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY2xhc3MgQ2hhcnRUaGVtZXMge1xyXG5cdHN0YXRpYyBnZXRUaG9yQXBwQ29sb3JzKCkge1xyXG5cdFx0cmV0dXJuIFtcclxuXHRcdFx0JyNlNzYyNWYnLFxyXG5cdFx0XHQnI2M4NTI1MCcsXHJcblx0XHRcdCcjZjdiZWMwJyxcclxuXHRcdFx0JyNlOWVhZTAnLFxyXG5cdFx0XHQnI2FhMTk0NScsXHJcblx0XHRcdCcjZjFjZWQ0JyxcclxuXHRcdFx0JyMzOTEzMDYnLFxyXG5cdFx0XHQnIzgyMWQzMCcsXHJcblx0XHRcdCcjZmI0NTcwJyxcclxuXHRcdFx0JyNmYjQ1NzAnLFxyXG5cdFx0XHQnI2ZiNDU3MCcsXHJcblx0XHRcdCcjNWYwOTNkJyxcclxuXHRcdFx0JyNiMjEzNjgnLFxyXG5cdFx0XHQnI2Q2N2JhOCdcclxuXHRcdF07XHJcblx0fVxyXG5cclxuXHRzdGF0aWMgZ2V0WWVhcEFwcENvbG9ycygpIHtcclxuXHRcdHJldHVybiBbXHJcblx0XHRcdCcjNTI1MjUyJyxcclxuXHRcdFx0JyM5QTlBOUEnLFxyXG5cdFx0XHQnIzc2NzY3NicsXHJcblx0XHRcdCcjODI4MjgyJyxcclxuXHRcdFx0JyNCRUJFQkUnLFxyXG5cdFx0XHQnIzhFOEU4RScsXHJcblx0XHRcdCcjNkE2QTZBJyxcclxuXHRcdFx0JyNBNkE2QTYnLFxyXG5cdFx0XHQnIzVFNUU1RScsXHJcblx0XHRcdCcjQjJCMkIyJyxcclxuXHRcdFx0JyNDQUNBQ0EnXHJcblx0XHRdO1xyXG5cdH1cclxuXHJcblx0c3RhdGljIGdldExlbmFBcHBDb2xvcnMoKSB7XHJcblx0XHRyZXR1cm4gW1xyXG5cdFx0XHQnI2FiZWE3YycsXHJcblx0XHRcdCcjZmVkZTAwJyxcclxuXHRcdFx0JyNjOGRmNTInLFxyXG5cdFx0XHQnIzBhNzAyOScsXHJcblx0XHRcdCcjZGJlOGQ4JyxcclxuXHRcdFx0JyM2NTQ2M2UnLFxyXG5cdFx0XHQnI2FhZDZhMCcsXHJcblx0XHRcdCcjMDEzYTIwJyxcclxuXHRcdFx0JyNiYWNjODEnLFxyXG5cdFx0XHQnI2NkZDE5MycsXHJcblx0XHRcdCcjZmFkMDJjJyxcclxuXHRcdFx0JyMyODIxMjAnLFxyXG5cdFx0XHQnIzMzMzY1MicsXHJcblx0XHRcdCcjYjJkN2RhJ1xyXG5cdFx0XTtcclxuXHR9XHJcbn1cclxuIl19
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Generated bundle index. Do not edit.
|
|
3
|
+
*/
|
|
4
|
+
export * from './index';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXJpbC11aS1kZXRhaWxlZC1vdmVybGF5LXBhbmVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvYXJpbC91aS9kZXRhaWxlZC1vdmVybGF5LXBhbmVsL2FyaWwtdWktZGV0YWlsZWQtb3ZlcmxheS1wYW5lbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export * from './src/detailed-overlay-panel.component';
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9hcmlsL3VpL2RldGFpbGVkLW92ZXJsYXktcGFuZWwvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx3Q0FBd0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc3JjL2RldGFpbGVkLW92ZXJsYXktcGFuZWwuY29tcG9uZW50JztcclxuIl19
|