ng-prime-tools 1.0.23 → 1.0.24
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/README.md +5 -0
- package/esm2022/lib/models/metric-indicateur-data.model.mjs +2 -0
- package/esm2022/lib/models/metric-panel-data.model.mjs +2 -0
- package/esm2022/lib/models/public-api.mjs +3 -1
- package/esm2022/lib/pt-group/index.mjs +2 -0
- package/esm2022/lib/pt-group/pt-group.component.mjs +39 -0
- package/esm2022/lib/pt-group/pt-group.module.mjs +19 -0
- package/esm2022/lib/pt-group/public-api.mjs +3 -0
- package/esm2022/lib/pt-metric-panel/index.mjs +2 -0
- package/esm2022/lib/pt-metric-panel/pt-metric-panel.component.mjs +93 -0
- package/esm2022/lib/pt-metric-panel/pt-metric-panel.module.mjs +19 -0
- package/esm2022/lib/pt-metric-panel/public-api.mjs +3 -0
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/ng-prime-tools.mjs +163 -10
- package/fesm2022/ng-prime-tools.mjs.map +1 -1
- package/lib/models/metric-indicateur-data.model.d.ts +9 -0
- package/lib/models/metric-indicateur-data.model.d.ts.map +1 -0
- package/lib/models/metric-panel-data.model.d.ts +7 -0
- package/lib/models/metric-panel-data.model.d.ts.map +1 -0
- package/lib/models/public-api.d.ts +2 -0
- package/lib/models/public-api.d.ts.map +1 -1
- package/lib/pt-group/index.d.ts +2 -0
- package/lib/pt-group/index.d.ts.map +1 -0
- package/lib/pt-group/pt-group.component.d.ts +12 -0
- package/lib/pt-group/pt-group.component.d.ts.map +1 -0
- package/lib/pt-group/pt-group.module.d.ts +10 -0
- package/lib/pt-group/pt-group.module.d.ts.map +1 -0
- package/lib/pt-group/public-api.d.ts +3 -0
- package/lib/pt-group/public-api.d.ts.map +1 -0
- package/lib/pt-metric-panel/index.d.ts +2 -0
- package/lib/pt-metric-panel/index.d.ts.map +1 -0
- package/lib/pt-metric-panel/pt-metric-panel.component.d.ts +55 -0
- package/lib/pt-metric-panel/pt-metric-panel.component.d.ts.map +1 -0
- package/lib/pt-metric-panel/pt-metric-panel.module.d.ts +10 -0
- package/lib/pt-metric-panel/pt-metric-panel.module.d.ts.map +1 -0
- package/lib/pt-metric-panel/public-api.d.ts +3 -0
- package/lib/pt-metric-panel/public-api.d.ts.map +1 -0
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
- package/public-api.d.ts.map +1 -1
package/README.md
CHANGED
@@ -636,6 +636,11 @@ export class FormBuilderTesterComponent implements OnInit {
|
|
636
636
|
|
637
637
|
## Changelog
|
638
638
|
|
639
|
+
### Version 1.0.24 - Release Date: 05/03/2025
|
640
|
+
|
641
|
+
- adding pt-group
|
642
|
+
- adding pt-metric-panel
|
643
|
+
|
639
644
|
### Version 1.0.23 - Release Date: 03/03/2025
|
640
645
|
|
641
646
|
- fix NUMBER type in advanced table
|
@@ -0,0 +1,2 @@
|
|
1
|
+
export {};
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWV0cmljLWluZGljYXRldXItZGF0YS5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvbW9kZWxzL21ldHJpYy1pbmRpY2F0ZXVyLWRhdGEubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEljb25TdHlsZSB9IGZyb20gJy4vaWNvbi1zdHlsZS5tb2RlbCc7XG5pbXBvcnQgeyBUaXRsZVN0eWxlIH0gZnJvbSAnLi90aXRsZS1zdHlsZS5tb2RlbCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgTWV0cmljSW5kaWNhdGV1ckRhdGEge1xuICBpY29uPzogSWNvblN0eWxlO1xuICB0aXRsZT86IHN0cmluZyB8IFRpdGxlU3R5bGU7XG4gIHZhbHVlOiBzdHJpbmcgfCBUaXRsZVN0eWxlO1xuICB1cmw/OiBzdHJpbmc7XG59XG4iXX0=
|
@@ -0,0 +1,2 @@
|
|
1
|
+
export {};
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWV0cmljLXBhbmVsLWRhdGEubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1wcmltZS10b29scy9zcmMvbGliL21vZGVscy9tZXRyaWMtcGFuZWwtZGF0YS5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWV0cmljSW5kaWNhdGV1ckRhdGEgfSBmcm9tICcuL21ldHJpYy1pbmRpY2F0ZXVyLWRhdGEubW9kZWwnO1xuaW1wb3J0IHsgVGl0bGVTdHlsZSB9IGZyb20gJy4vdGl0bGUtc3R5bGUubW9kZWwnO1xuXG5leHBvcnQgaW50ZXJmYWNlIE1ldHJpY1BhbmVsRGF0YSB7XG4gIHRpdGxlPzogc3RyaW5nIHwgVGl0bGVTdHlsZTtcbiAgaW5kaWNhdG9yczogTWV0cmljSW5kaWNhdGV1ckRhdGFbXTtcbn1cbiJdfQ==
|
@@ -17,6 +17,8 @@ export * from './form-text-area-field.model';
|
|
17
17
|
export * from './form-text-field.model';
|
18
18
|
// Metric data for dashboard
|
19
19
|
export * from './metric-card-data.model';
|
20
|
+
export * from './metric-panel-data.model';
|
21
|
+
export * from './metric-indicateur-data.model';
|
20
22
|
// Chart
|
21
23
|
export * from './chart-config.model';
|
22
24
|
export * from './axis-chart-config.model';
|
@@ -50,4 +52,4 @@ export * from './image-style.model';
|
|
50
52
|
export * from './badge.model';
|
51
53
|
export * from './pattern.model';
|
52
54
|
export * from './footer.model';
|
53
|
-
//# sourceMappingURL=data:application/json;base64,
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvbW9kZWxzL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsaUJBQWlCO0FBQ2pCLGNBQWMsc0JBQXNCLENBQUM7QUFFckMsd0JBQXdCO0FBQ3hCLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyx1QkFBdUIsQ0FBQztBQUV0Qyx1QkFBdUI7QUFDdkIsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLHlCQUF5QixDQUFDO0FBRXhDLDRCQUE0QjtBQUM1QixjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyxnQ0FBZ0MsQ0FBQztBQUUvQyxRQUFRO0FBQ1IsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMseUJBQXlCLENBQUM7QUFFeEMsT0FBTztBQUNQLGNBQWMscUJBQXFCLENBQUM7QUFFcEMsT0FBTztBQUNQLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsOEJBQThCLENBQUM7QUFFN0MsZ0JBQWdCO0FBQ2hCLGNBQWMsOEJBQThCLENBQUM7QUFFN0MsU0FBUztBQUNULGNBQWMsdUJBQXVCLENBQUM7QUFFdEMsY0FBYztBQUNkLGNBQWMsNEJBQTRCLENBQUM7QUFFM0MsUUFBUTtBQUNSLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyxlQUFlLENBQUM7QUFFOUIsU0FBUztBQUNULGNBQWMsZ0JBQWdCLENBQUM7QUFFL0IsU0FBUztBQUNULGNBQWMsZ0JBQWdCLENBQUM7QUFFL0IsVUFBVTtBQUNWLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLG9CQUFvQixDQUFDO0FBQ25DLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxpQkFBaUIsQ0FBQztBQUNoQyxjQUFjLGdCQUFnQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQWR2YW5jZWQgdGFibGVcbmV4cG9ydCAqIGZyb20gJy4vdGFibGUtY29sdW1uLm1vZGVsJztcblxuLy8gTXVsdGkgc2VhcmNoIGNyaXRlcmlhXG5leHBvcnQgKiBmcm9tICcuL3NlYXJjaC1jcml0ZXJpYS5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2ZpbHRlci1vcHRpb24ubW9kZWwnO1xuXG4vLyBGb3JtIGlucHV0cyBhbmQgYnRuc1xuZXhwb3J0ICogZnJvbSAnLi9mb3JtLWJ1dHRvbi5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2Zvcm0tZmllbGQubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9mb3JtLWZpZWxkLWdyb3VwLm1vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vZm9ybS1jaGVjay1maWVsZC5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2Zvcm0tZGF0ZS1maWVsZC5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2Zvcm0tZHJvcC1kb3duLWZpZWxkLm1vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vZm9ybS1tdWx0aS1zZWxlY3QubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9mb3JtLW51bWJlci1maWVsZC5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2Zvcm0tc3dpdGNoLWZpZWxkLm1vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vZm9ybS10ZXh0LWFyZWEtZmllbGQubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9mb3JtLXRleHQtZmllbGQubW9kZWwnO1xuXG4vLyBNZXRyaWMgZGF0YSBmb3IgZGFzaGJvYXJkXG5leHBvcnQgKiBmcm9tICcuL21ldHJpYy1jYXJkLWRhdGEubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9tZXRyaWMtcGFuZWwtZGF0YS5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL21ldHJpYy1pbmRpY2F0ZXVyLWRhdGEubW9kZWwnO1xuXG4vLyBDaGFydFxuZXhwb3J0ICogZnJvbSAnLi9jaGFydC1jb25maWcubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9heGlzLWNoYXJ0LWNvbmZpZy5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2F4aXMtY2hhcnQtZGF0YS5tb2RlbCc7XG5cbi8vIENhcmRcbmV4cG9ydCAqIGZyb20gJy4vY2FyZC1jb25maWcubW9kZWwnO1xuXG4vLyBNZW51XG5leHBvcnQgKiBmcm9tICcuL21lbnUubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9tZW51LWl0ZW0ubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9tZW51LWNvbmZpZy5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL25hdi1iYXItbWVudS1jb25maWcubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9zaWRlLW1lbnUtYmFyLWNvbmZpZy5tb2RlbCc7XG5cbi8vIFBhZ2UgU2tlbGV0b25cbmV4cG9ydCAqIGZyb20gJy4vcGFnZS1za2VsZXRvbi1jb25maWcubW9kZWwnO1xuXG4vLyBGb290ZXJcbmV4cG9ydCAqIGZyb20gJy4vZm9vdGVyLWNvbmZpZy5tb2RlbCc7XG5cbi8vIEJyZWFkIENydW1iXG5leHBvcnQgKiBmcm9tICcuL2JyZWFkLWNydW1iLWNvbmZpZy5tb2RlbCc7XG5cbi8vIGxvZ2luXG5leHBvcnQgKiBmcm9tICcuL2xvZ2luLXBhZ2UtY29uZmlnLm1vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vbG9naW4tbW9kZWwnO1xuXG4vLyBCdXR0b25cbmV4cG9ydCAqIGZyb20gJy4vYnV0dG9uLm1vZGVsJztcblxuLy8gRGlhbG9nXG5leHBvcnQgKiBmcm9tICcuL2RpYWxvZy5tb2RlbCc7XG5cbi8vIEdlbmVyaWNcbmV4cG9ydCAqIGZyb20gJy4vaWNvbi1zdHlsZS5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL3RpdGxlLXN0eWxlLm1vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vdGV4dC1zdHlsZS5tb2RlbCc7XG5leHBvcnQgKiBmcm9tICcuL2ltYWdlLXN0eWxlLm1vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vYmFkZ2UubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9wYXR0ZXJuLm1vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vZm9vdGVyLm1vZGVsJztcbiJdfQ==
|
@@ -0,0 +1,2 @@
|
|
1
|
+
export * from './public-api';
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1wcmltZS10b29scy9zcmMvbGliL3B0LWdyb3VwL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsY0FBYyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
|
@@ -0,0 +1,39 @@
|
|
1
|
+
import { Component, Input, HostBinding } from '@angular/core';
|
2
|
+
import * as i0 from "@angular/core";
|
3
|
+
export class PTGroupComponent {
|
4
|
+
constructor() {
|
5
|
+
this.gap = '16px';
|
6
|
+
this.justify = 'flex-start';
|
7
|
+
this.display = 'flex';
|
8
|
+
this.flexWrap = 'wrap';
|
9
|
+
}
|
10
|
+
get gapSize() {
|
11
|
+
return this.gap;
|
12
|
+
}
|
13
|
+
get justifyContent() {
|
14
|
+
return this.justify;
|
15
|
+
}
|
16
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTGroupComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
17
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTGroupComponent, selector: "pt-group", inputs: { gap: "gap", justify: "justify" }, host: { properties: { "style.display": "this.display", "style.flexWrap": "this.flexWrap", "style.gap": "this.gapSize", "style.justifyContent": "this.justifyContent" } }, ngImport: i0, template: "<ng-content></ng-content>\n", styles: [":host{width:100%;display:flex;flex-wrap:wrap;gap:var(--gap, 16px);justify-content:var(--justify, flex-start)}\n"] }); }
|
18
|
+
}
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTGroupComponent, decorators: [{
|
20
|
+
type: Component,
|
21
|
+
args: [{ selector: 'pt-group', template: "<ng-content></ng-content>\n", styles: [":host{width:100%;display:flex;flex-wrap:wrap;gap:var(--gap, 16px);justify-content:var(--justify, flex-start)}\n"] }]
|
22
|
+
}], propDecorators: { gap: [{
|
23
|
+
type: Input
|
24
|
+
}], justify: [{
|
25
|
+
type: Input
|
26
|
+
}], display: [{
|
27
|
+
type: HostBinding,
|
28
|
+
args: ['style.display']
|
29
|
+
}], flexWrap: [{
|
30
|
+
type: HostBinding,
|
31
|
+
args: ['style.flexWrap']
|
32
|
+
}], gapSize: [{
|
33
|
+
type: HostBinding,
|
34
|
+
args: ['style.gap']
|
35
|
+
}], justifyContent: [{
|
36
|
+
type: HostBinding,
|
37
|
+
args: ['style.justifyContent']
|
38
|
+
}] } });
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHQtZ3JvdXAuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctcHJpbWUtdG9vbHMvc3JjL2xpYi9wdC1ncm91cC9wdC1ncm91cC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1wcmltZS10b29scy9zcmMvbGliL3B0LWdyb3VwL3B0LWdyb3VwLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLFdBQVcsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFPOUQsTUFBTSxPQUFPLGdCQUFnQjtJQUw3QjtRQU1XLFFBQUcsR0FBVyxNQUFNLENBQUM7UUFDckIsWUFBTyxHQUtLLFlBQVksQ0FBQztRQUVKLFlBQU8sR0FBRyxNQUFNLENBQUM7UUFDaEIsYUFBUSxHQUFHLE1BQU0sQ0FBQztLQU9sRDtJQU5DLElBQThCLE9BQU87UUFDbkMsT0FBTyxJQUFJLENBQUMsR0FBRyxDQUFDO0lBQ2xCLENBQUM7SUFDRCxJQUF5QyxjQUFjO1FBQ3JELE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQztJQUN0QixDQUFDOytHQWhCVSxnQkFBZ0I7bUdBQWhCLGdCQUFnQixzUUNQN0IsNkJBQ0E7OzRGRE1hLGdCQUFnQjtrQkFMNUIsU0FBUzsrQkFDRSxVQUFVOzhCQUtYLEdBQUc7c0JBQVgsS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUs7Z0JBT3dCLE9BQU87c0JBQXBDLFdBQVc7dUJBQUMsZUFBZTtnQkFDRyxRQUFRO3NCQUF0QyxXQUFXO3VCQUFDLGdCQUFnQjtnQkFDQyxPQUFPO3NCQUFwQyxXQUFXO3VCQUFDLFdBQVc7Z0JBR2lCLGNBQWM7c0JBQXRELFdBQVc7dUJBQUMsc0JBQXNCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgSG9zdEJpbmRpbmcgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncHQtZ3JvdXAnLFxuICB0ZW1wbGF0ZVVybDogJy4vcHQtZ3JvdXAuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9wdC1ncm91cC5jb21wb25lbnQuY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIFBUR3JvdXBDb21wb25lbnQge1xuICBASW5wdXQoKSBnYXA6IHN0cmluZyA9ICcxNnB4JztcbiAgQElucHV0KCkganVzdGlmeTpcbiAgICB8ICdmbGV4LXN0YXJ0J1xuICAgIHwgJ2NlbnRlcidcbiAgICB8ICdmbGV4LWVuZCdcbiAgICB8ICdzcGFjZS1iZXR3ZWVuJ1xuICAgIHwgJ3NwYWNlLWFyb3VuZCcgPSAnZmxleC1zdGFydCc7XG5cbiAgQEhvc3RCaW5kaW5nKCdzdHlsZS5kaXNwbGF5JykgZGlzcGxheSA9ICdmbGV4JztcbiAgQEhvc3RCaW5kaW5nKCdzdHlsZS5mbGV4V3JhcCcpIGZsZXhXcmFwID0gJ3dyYXAnO1xuICBASG9zdEJpbmRpbmcoJ3N0eWxlLmdhcCcpIGdldCBnYXBTaXplKCkge1xuICAgIHJldHVybiB0aGlzLmdhcDtcbiAgfVxuICBASG9zdEJpbmRpbmcoJ3N0eWxlLmp1c3RpZnlDb250ZW50JykgZ2V0IGp1c3RpZnlDb250ZW50KCkge1xuICAgIHJldHVybiB0aGlzLmp1c3RpZnk7XG4gIH1cbn1cbiIsIjxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiJdfQ==
|
@@ -0,0 +1,19 @@
|
|
1
|
+
import { NgModule } from '@angular/core';
|
2
|
+
import { CommonModule } from '@angular/common';
|
3
|
+
import { PTCardModule } from '../pt-card';
|
4
|
+
import { PTGroupComponent } from './pt-group.component';
|
5
|
+
import * as i0 from "@angular/core";
|
6
|
+
export class PTGroupModule {
|
7
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTGroupModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
8
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.11", ngImport: i0, type: PTGroupModule, declarations: [PTGroupComponent], imports: [CommonModule, PTCardModule], exports: [PTGroupComponent] }); }
|
9
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTGroupModule, imports: [CommonModule, PTCardModule] }); }
|
10
|
+
}
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTGroupModule, decorators: [{
|
12
|
+
type: NgModule,
|
13
|
+
args: [{
|
14
|
+
declarations: [PTGroupComponent],
|
15
|
+
imports: [CommonModule, PTCardModule],
|
16
|
+
exports: [PTGroupComponent],
|
17
|
+
}]
|
18
|
+
}] });
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHQtZ3JvdXAubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmctcHJpbWUtdG9vbHMvc3JjL2xpYi9wdC1ncm91cC9wdC1ncm91cC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLFlBQVksQ0FBQztBQUMxQyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQzs7QUFPeEQsTUFBTSxPQUFPLGFBQWE7K0dBQWIsYUFBYTtnSEFBYixhQUFhLGlCQUpULGdCQUFnQixhQUNyQixZQUFZLEVBQUUsWUFBWSxhQUMxQixnQkFBZ0I7Z0hBRWYsYUFBYSxZQUhkLFlBQVksRUFBRSxZQUFZOzs0RkFHekIsYUFBYTtrQkFMekIsUUFBUTttQkFBQztvQkFDUixZQUFZLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQztvQkFDaEMsT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLFlBQVksQ0FBQztvQkFDckMsT0FBTyxFQUFFLENBQUMsZ0JBQWdCLENBQUM7aUJBQzVCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBQVENhcmRNb2R1bGUgfSBmcm9tICcuLi9wdC1jYXJkJztcbmltcG9ydCB7IFBUR3JvdXBDb21wb25lbnQgfSBmcm9tICcuL3B0LWdyb3VwLmNvbXBvbmVudCc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1BUR3JvdXBDb21wb25lbnRdLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBQVENhcmRNb2R1bGVdLFxuICBleHBvcnRzOiBbUFRHcm91cENvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIFBUR3JvdXBNb2R1bGUge31cbiJdfQ==
|
@@ -0,0 +1,3 @@
|
|
1
|
+
export * from './pt-group.component';
|
2
|
+
export * from './pt-group.module';
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvcHQtZ3JvdXAvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsbUJBQW1CLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3B0LWdyb3VwLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL3B0LWdyb3VwLm1vZHVsZSc7XG4iXX0=
|
@@ -0,0 +1,2 @@
|
|
1
|
+
export * from './public-api';
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZy1wcmltZS10b29scy9zcmMvbGliL3B0LW1ldHJpYy1wYW5lbC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vcHVibGljLWFwaSc7XG4iXX0=
|
@@ -0,0 +1,93 @@
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
2
|
+
import * as i0 from "@angular/core";
|
3
|
+
import * as i1 from "@angular/router";
|
4
|
+
import * as i2 from "@angular/common";
|
5
|
+
import * as i3 from "../pt-card/pt-card.component";
|
6
|
+
export class PTMetricPanelComponent {
|
7
|
+
constructor(router) {
|
8
|
+
this.router = router;
|
9
|
+
this.cardConfig = this.getDefaultCardConfig();
|
10
|
+
}
|
11
|
+
ngOnInit() { }
|
12
|
+
getDefaultCardConfig() {
|
13
|
+
return {
|
14
|
+
backgroundColor: '#fff',
|
15
|
+
borderColor: '#ddd',
|
16
|
+
borderWidth: '1px',
|
17
|
+
padding: '20px',
|
18
|
+
margin: '10px 0',
|
19
|
+
borderRadius: '8px',
|
20
|
+
boxShadow: '0 4px 6px rgba(0, 0, 0, 0.1)',
|
21
|
+
};
|
22
|
+
}
|
23
|
+
getTitleText() {
|
24
|
+
return typeof this.panelData.title === 'object'
|
25
|
+
? this.panelData.title.text
|
26
|
+
: this.panelData.title || '';
|
27
|
+
}
|
28
|
+
getTitleStyles() {
|
29
|
+
if (typeof this.panelData.title === 'object') {
|
30
|
+
return {
|
31
|
+
color: this.panelData.title.color || '#333',
|
32
|
+
fontSize: this.panelData.title.fontSize || '1.5rem',
|
33
|
+
textAlign: this.panelData.title.position || 'left',
|
34
|
+
};
|
35
|
+
}
|
36
|
+
return {};
|
37
|
+
}
|
38
|
+
getIconClass(icon) {
|
39
|
+
return icon ? icon : '';
|
40
|
+
}
|
41
|
+
getIconStyles(icon) {
|
42
|
+
if (typeof icon === 'object') {
|
43
|
+
return {
|
44
|
+
color: icon.color || '#333',
|
45
|
+
fontSize: icon.fontSize || '1.2rem',
|
46
|
+
backgroundColor: icon.backgroundColor || 'transparent',
|
47
|
+
borderRadius: icon.shape === 'circular' ? '50%' : '8px',
|
48
|
+
padding: '6px',
|
49
|
+
display: 'inline-block',
|
50
|
+
};
|
51
|
+
}
|
52
|
+
return {};
|
53
|
+
}
|
54
|
+
getValueStyles(value) {
|
55
|
+
if (typeof value === 'object' && 'text' in value) {
|
56
|
+
return {
|
57
|
+
color: value.color || '#2d3748',
|
58
|
+
fontSize: value.fontSize || '1rem',
|
59
|
+
fontWeight: value.fontWeight || 'bold',
|
60
|
+
};
|
61
|
+
}
|
62
|
+
return {};
|
63
|
+
}
|
64
|
+
isTitleObject() {
|
65
|
+
return typeof this.panelData.title === 'object';
|
66
|
+
}
|
67
|
+
getTitleIcon() {
|
68
|
+
if (this.isTitleObject()) {
|
69
|
+
const icon = this.panelData.title.icon;
|
70
|
+
return typeof icon === 'string' ? icon : icon?.code;
|
71
|
+
}
|
72
|
+
return undefined;
|
73
|
+
}
|
74
|
+
isTitleStyle(value) {
|
75
|
+
return typeof value === 'object' && value !== null && 'text' in value;
|
76
|
+
}
|
77
|
+
handleClick(url) {
|
78
|
+
if (url) {
|
79
|
+
this.router.navigate([url]);
|
80
|
+
}
|
81
|
+
}
|
82
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTMetricPanelComponent, deps: [{ token: i1.Router }], target: i0.ɵɵFactoryTarget.Component }); }
|
83
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTMetricPanelComponent, selector: "pt-metric-panel", inputs: { panelData: "panelData", cardConfig: "cardConfig" }, ngImport: i0, template: "<pt-card [config]=\"cardConfig\">\n <!-- Panel Title -->\n <div class=\"panel-header\" [ngStyle]=\"getTitleStyles()\">\n <i\n *ngIf=\"getTitleIcon()\"\n [ngClass]=\"getIconClass(getTitleIcon())\"\n [ngStyle]=\"getIconStyles(getTitleIcon())\"\n ></i>\n <span>{{ getTitleText() }}</span>\n </div>\n\n <hr />\n\n <!-- Metric Indicators -->\n <div class=\"metric-list\">\n <div\n *ngFor=\"let item of panelData.indicators\"\n class=\"metric-item\"\n [ngStyle]=\"{ cursor: item?.url ? 'pointer' : 'default' }\"\n (click)=\"handleClick(item?.url)\"\n [attr.title]=\"item?.url ? 'Go to ' + item.url : ''\"\n >\n <i\n *ngIf=\"item.icon\"\n [ngClass]=\"getIconClass(item.icon.code)\"\n [ngStyle]=\"getIconStyles(item.icon)\"\n ></i>\n <span class=\"metric-title\">\n {{ isTitleStyle(item.title) ? item.title.text : item.title }}\n </span>\n\n <span class=\"metric-value\" [ngStyle]=\"getValueStyles(item.value)\">\n {{ isTitleStyle(item.value) ? item.value.text : item.value }}\n </span>\n </div>\n </div>\n</pt-card>\n", styles: [".panel-header{display:flex;align-items:center;font-size:1.3rem;font-weight:700;color:#333;gap:10px}hr{border:0;height:1px;background:#ddd;margin:10px 0}.metric-list{display:flex;flex-direction:column;gap:12px}.metric-item{display:flex;justify-content:space-between;align-items:center;padding:8px;border-radius:5px;background:#fff;transition:.3s ease-in-out}.metric-item:hover{background:#f1f1f1}.metric-title{flex-grow:1;font-size:1rem;color:#333}.metric-value{font-size:1rem;font-weight:700;color:#2d3748}.metric-item[ngStyle]{cursor:pointer}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3.PTCardComponent, selector: "pt-card", inputs: ["config"] }] }); }
|
84
|
+
}
|
85
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTMetricPanelComponent, decorators: [{
|
86
|
+
type: Component,
|
87
|
+
args: [{ selector: 'pt-metric-panel', template: "<pt-card [config]=\"cardConfig\">\n <!-- Panel Title -->\n <div class=\"panel-header\" [ngStyle]=\"getTitleStyles()\">\n <i\n *ngIf=\"getTitleIcon()\"\n [ngClass]=\"getIconClass(getTitleIcon())\"\n [ngStyle]=\"getIconStyles(getTitleIcon())\"\n ></i>\n <span>{{ getTitleText() }}</span>\n </div>\n\n <hr />\n\n <!-- Metric Indicators -->\n <div class=\"metric-list\">\n <div\n *ngFor=\"let item of panelData.indicators\"\n class=\"metric-item\"\n [ngStyle]=\"{ cursor: item?.url ? 'pointer' : 'default' }\"\n (click)=\"handleClick(item?.url)\"\n [attr.title]=\"item?.url ? 'Go to ' + item.url : ''\"\n >\n <i\n *ngIf=\"item.icon\"\n [ngClass]=\"getIconClass(item.icon.code)\"\n [ngStyle]=\"getIconStyles(item.icon)\"\n ></i>\n <span class=\"metric-title\">\n {{ isTitleStyle(item.title) ? item.title.text : item.title }}\n </span>\n\n <span class=\"metric-value\" [ngStyle]=\"getValueStyles(item.value)\">\n {{ isTitleStyle(item.value) ? item.value.text : item.value }}\n </span>\n </div>\n </div>\n</pt-card>\n", styles: [".panel-header{display:flex;align-items:center;font-size:1.3rem;font-weight:700;color:#333;gap:10px}hr{border:0;height:1px;background:#ddd;margin:10px 0}.metric-list{display:flex;flex-direction:column;gap:12px}.metric-item{display:flex;justify-content:space-between;align-items:center;padding:8px;border-radius:5px;background:#fff;transition:.3s ease-in-out}.metric-item:hover{background:#f1f1f1}.metric-title{flex-grow:1;font-size:1rem;color:#333}.metric-value{font-size:1rem;font-weight:700;color:#2d3748}.metric-item[ngStyle]{cursor:pointer}\n"] }]
|
88
|
+
}], ctorParameters: () => [{ type: i1.Router }], propDecorators: { panelData: [{
|
89
|
+
type: Input
|
90
|
+
}], cardConfig: [{
|
91
|
+
type: Input
|
92
|
+
}] } });
|
93
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pt-metric-panel.component.js","sourceRoot":"","sources":["../../../../../projects/ng-prime-tools/src/lib/pt-metric-panel/pt-metric-panel.component.ts","../../../../../projects/ng-prime-tools/src/lib/pt-metric-panel/pt-metric-panel.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;;;;;AAUzD,MAAM,OAAO,sBAAsB;IAIjC,YAAoB,MAAc;QAAd,WAAM,GAAN,MAAM,CAAQ;QAFzB,eAAU,GAAe,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAEzB,CAAC;IAEtC,QAAQ,KAAU,CAAC;IAEnB,oBAAoB;QAClB,OAAO;YACL,eAAe,EAAE,MAAM;YACvB,WAAW,EAAE,MAAM;YACnB,WAAW,EAAE,KAAK;YAClB,OAAO,EAAE,MAAM;YACf,MAAM,EAAE,QAAQ;YAChB,YAAY,EAAE,KAAK;YACnB,SAAS,EAAE,8BAA8B;SAC1C,CAAC;IACJ,CAAC;IAED,YAAY;QACV,OAAO,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,KAAK,QAAQ;YAC7C,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI;YAC3B,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,IAAI,EAAE,CAAC;IACjC,CAAC;IAED,cAAc;QACZ,IAAI,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,KAAK,QAAQ,EAAE,CAAC;YAC7C,OAAO;gBACL,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,KAAK,IAAI,MAAM;gBAC3C,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,QAAQ,IAAI,QAAQ;gBACnD,SAAS,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,QAAQ,IAAI,MAAM;aACnD,CAAC;QACJ,CAAC;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,YAAY,CAAC,IAAa;QACxB,OAAO,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;IAC1B,CAAC;IAED,aAAa,CAAC,IAAU;QACtB,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;YAC7B,OAAO;gBACL,KAAK,EAAE,IAAI,CAAC,KAAK,IAAI,MAAM;gBAC3B,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,QAAQ;gBACnC,eAAe,EAAE,IAAI,CAAC,eAAe,IAAI,aAAa;gBACtD,YAAY,EAAE,IAAI,CAAC,KAAK,KAAK,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK;gBACvD,OAAO,EAAE,KAAK;gBACd,OAAO,EAAE,cAAc;aACxB,CAAC;QACJ,CAAC;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,cAAc,CAAC,KAAU;QACvB,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,MAAM,IAAI,KAAK,EAAE,CAAC;YACjD,OAAO;gBACL,KAAK,EAAE,KAAK,CAAC,KAAK,IAAI,SAAS;gBAC/B,QAAQ,EAAE,KAAK,CAAC,QAAQ,IAAI,MAAM;gBAClC,UAAU,EAAE,KAAK,CAAC,UAAU,IAAI,MAAM;aACvC,CAAC;QACJ,CAAC;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;IAED,aAAa;QACX,OAAO,OAAO,IAAI,CAAC,SAAS,CAAC,KAAK,KAAK,QAAQ,CAAC;IAClD,CAAC;IAED,YAAY;QACV,IAAI,IAAI,CAAC,aAAa,EAAE,EAAE,CAAC;YACzB,MAAM,IAAI,GAAI,IAAI,CAAC,SAAS,CAAC,KAAoB,CAAC,IAAI,CAAC;YACvD,OAAO,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC;QACtD,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,YAAY,CAAC,KAAU;QACrB,OAAO,OAAO,KAAK,KAAK,QAAQ,IAAI,KAAK,KAAK,IAAI,IAAI,MAAM,IAAI,KAAK,CAAC;IACxE,CAAC;IAED,WAAW,CAAC,GAAY;QACtB,IAAI,GAAG,EAAE,CAAC;YACR,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC;+GAtFU,sBAAsB;mGAAtB,sBAAsB,qHCVnC,snCAqCA;;4FD3Ba,sBAAsB;kBALlC,SAAS;+BACE,iBAAiB;2EAKlB,SAAS;sBAAjB,KAAK;gBACG,UAAU;sBAAlB,KAAK","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { MetricPanelData } from '../models/metric-panel-data.model';\nimport { CardConfig, TitleStyle } from '../models';\nimport { Router } from '@angular/router';\n\n@Component({\n  selector: 'pt-metric-panel',\n  templateUrl: './pt-metric-panel.component.html',\n  styleUrls: ['./pt-metric-panel.component.css'],\n})\nexport class PTMetricPanelComponent implements OnInit {\n  @Input() panelData!: MetricPanelData;\n  @Input() cardConfig: CardConfig = this.getDefaultCardConfig();\n\n  constructor(private router: Router) {}\n\n  ngOnInit(): void {}\n\n  getDefaultCardConfig(): CardConfig {\n    return {\n      backgroundColor: '#fff',\n      borderColor: '#ddd',\n      borderWidth: '1px',\n      padding: '20px',\n      margin: '10px 0',\n      borderRadius: '8px',\n      boxShadow: '0 4px 6px rgba(0, 0, 0, 0.1)',\n    };\n  }\n\n  getTitleText(): string {\n    return typeof this.panelData.title === 'object'\n      ? this.panelData.title.text\n      : this.panelData.title || '';\n  }\n\n  getTitleStyles() {\n    if (typeof this.panelData.title === 'object') {\n      return {\n        color: this.panelData.title.color || '#333',\n        fontSize: this.panelData.title.fontSize || '1.5rem',\n        textAlign: this.panelData.title.position || 'left',\n      };\n    }\n    return {};\n  }\n\n  getIconClass(icon?: string): string {\n    return icon ? icon : '';\n  }\n\n  getIconStyles(icon?: any) {\n    if (typeof icon === 'object') {\n      return {\n        color: icon.color || '#333',\n        fontSize: icon.fontSize || '1.2rem',\n        backgroundColor: icon.backgroundColor || 'transparent',\n        borderRadius: icon.shape === 'circular' ? '50%' : '8px',\n        padding: '6px',\n        display: 'inline-block',\n      };\n    }\n    return {};\n  }\n\n  getValueStyles(value: any) {\n    if (typeof value === 'object' && 'text' in value) {\n      return {\n        color: value.color || '#2d3748',\n        fontSize: value.fontSize || '1rem',\n        fontWeight: value.fontWeight || 'bold',\n      };\n    }\n    return {};\n  }\n\n  isTitleObject(): boolean {\n    return typeof this.panelData.title === 'object';\n  }\n\n  getTitleIcon(): string | undefined {\n    if (this.isTitleObject()) {\n      const icon = (this.panelData.title as TitleStyle).icon;\n      return typeof icon === 'string' ? icon : icon?.code;\n    }\n    return undefined;\n  }\n\n  isTitleStyle(value: any): value is TitleStyle {\n    return typeof value === 'object' && value !== null && 'text' in value;\n  }\n\n  handleClick(url?: string) {\n    if (url) {\n      this.router.navigate([url]);\n    }\n  }\n}\n","<pt-card [config]=\"cardConfig\">\n  <!-- Panel Title -->\n  <div class=\"panel-header\" [ngStyle]=\"getTitleStyles()\">\n    <i\n      *ngIf=\"getTitleIcon()\"\n      [ngClass]=\"getIconClass(getTitleIcon())\"\n      [ngStyle]=\"getIconStyles(getTitleIcon())\"\n    ></i>\n    <span>{{ getTitleText() }}</span>\n  </div>\n\n  <hr />\n\n  <!-- Metric Indicators -->\n  <div class=\"metric-list\">\n    <div\n      *ngFor=\"let item of panelData.indicators\"\n      class=\"metric-item\"\n      [ngStyle]=\"{ cursor: item?.url ? 'pointer' : 'default' }\"\n      (click)=\"handleClick(item?.url)\"\n      [attr.title]=\"item?.url ? 'Go to ' + item.url : ''\"\n    >\n      <i\n        *ngIf=\"item.icon\"\n        [ngClass]=\"getIconClass(item.icon.code)\"\n        [ngStyle]=\"getIconStyles(item.icon)\"\n      ></i>\n      <span class=\"metric-title\">\n        {{ isTitleStyle(item.title) ? item.title.text : item.title }}\n      </span>\n\n      <span class=\"metric-value\" [ngStyle]=\"getValueStyles(item.value)\">\n        {{ isTitleStyle(item.value) ? item.value.text : item.value }}\n      </span>\n    </div>\n  </div>\n</pt-card>\n"]}
|
@@ -0,0 +1,19 @@
|
|
1
|
+
import { NgModule } from '@angular/core';
|
2
|
+
import { CommonModule } from '@angular/common';
|
3
|
+
import { PTMetricPanelComponent } from './pt-metric-panel.component';
|
4
|
+
import { PTCardModule } from '../pt-card';
|
5
|
+
import * as i0 from "@angular/core";
|
6
|
+
export class PTMetricPanelModule {
|
7
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTMetricPanelModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
8
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.11", ngImport: i0, type: PTMetricPanelModule, declarations: [PTMetricPanelComponent], imports: [CommonModule, PTCardModule], exports: [PTMetricPanelComponent] }); }
|
9
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTMetricPanelModule, imports: [CommonModule, PTCardModule] }); }
|
10
|
+
}
|
11
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTMetricPanelModule, decorators: [{
|
12
|
+
type: NgModule,
|
13
|
+
args: [{
|
14
|
+
declarations: [PTMetricPanelComponent],
|
15
|
+
imports: [CommonModule, PTCardModule],
|
16
|
+
exports: [PTMetricPanelComponent],
|
17
|
+
}]
|
18
|
+
}] });
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHQtbWV0cmljLXBhbmVsLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvcHQtbWV0cmljLXBhbmVsL3B0LW1ldHJpYy1wYW5lbC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDckUsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLFlBQVksQ0FBQzs7QUFPMUMsTUFBTSxPQUFPLG1CQUFtQjsrR0FBbkIsbUJBQW1CO2dIQUFuQixtQkFBbUIsaUJBSmYsc0JBQXNCLGFBQzNCLFlBQVksRUFBRSxZQUFZLGFBQzFCLHNCQUFzQjtnSEFFckIsbUJBQW1CLFlBSHBCLFlBQVksRUFBRSxZQUFZOzs0RkFHekIsbUJBQW1CO2tCQUwvQixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRSxDQUFDLHNCQUFzQixDQUFDO29CQUN0QyxPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsWUFBWSxDQUFDO29CQUNyQyxPQUFPLEVBQUUsQ0FBQyxzQkFBc0IsQ0FBQztpQkFDbEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IFBUTWV0cmljUGFuZWxDb21wb25lbnQgfSBmcm9tICcuL3B0LW1ldHJpYy1wYW5lbC5jb21wb25lbnQnO1xuaW1wb3J0IHsgUFRDYXJkTW9kdWxlIH0gZnJvbSAnLi4vcHQtY2FyZCc7XG5cbkBOZ01vZHVsZSh7XG4gIGRlY2xhcmF0aW9uczogW1BUTWV0cmljUGFuZWxDb21wb25lbnRdLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBQVENhcmRNb2R1bGVdLFxuICBleHBvcnRzOiBbUFRNZXRyaWNQYW5lbENvbXBvbmVudF0sXG59KVxuZXhwb3J0IGNsYXNzIFBUTWV0cmljUGFuZWxNb2R1bGUge31cbiJdfQ==
|
@@ -0,0 +1,3 @@
|
|
1
|
+
export * from './pt-metric-panel.component';
|
2
|
+
export * from './pt-metric-panel.module';
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvcHQtbWV0cmljLXBhbmVsL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLDBCQUEwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9wdC1tZXRyaWMtcGFuZWwuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vcHQtbWV0cmljLXBhbmVsLm1vZHVsZSc7XG4iXX0=
|
package/esm2022/public-api.mjs
CHANGED
@@ -12,6 +12,7 @@ export * from './lib/pt-switch-input';
|
|
12
12
|
export * from './lib/pt-text-area-input';
|
13
13
|
export * from './lib/pt-text-input';
|
14
14
|
// Dashboard
|
15
|
+
export * from './lib/pt-metric-panel';
|
15
16
|
export * from './lib/pt-metric-card';
|
16
17
|
export * from './lib/pt-metric-card-group';
|
17
18
|
// Chart
|
@@ -42,4 +43,5 @@ export * from './lib/pt-dialog';
|
|
42
43
|
export * from './lib/models';
|
43
44
|
export * from './lib/enums';
|
44
45
|
export * from './lib/types';
|
45
|
-
|
46
|
+
export * from './lib/pt-group';
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsNkJBQTZCLENBQUM7QUFFNUMsaUJBQWlCO0FBQ2pCLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyw2QkFBNkIsQ0FBQztBQUU1QyxTQUFTO0FBQ1QsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHFCQUFxQixDQUFDO0FBRXBDLFlBQVk7QUFDWixjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyw0QkFBNEIsQ0FBQztBQUUzQyxRQUFRO0FBQ1IsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLHFCQUFxQixDQUFDO0FBRXBDLFFBQVE7QUFDUixjQUFjLGVBQWUsQ0FBQztBQUU5QixPQUFPO0FBQ1AsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxxQkFBcUIsQ0FBQztBQUVwQyxTQUFTO0FBQ1QsY0FBYyx1QkFBdUIsQ0FBQztBQUV0QyxTQUFTO0FBQ1QsY0FBYyx3QkFBd0IsQ0FBQztBQUV2QyxnQkFBZ0I7QUFDaEIsY0FBYyx3QkFBd0IsQ0FBQztBQUV2QyxTQUFTO0FBQ1QsY0FBYyxpQkFBaUIsQ0FBQztBQUVoQyxjQUFjO0FBQ2QsY0FBYyxzQkFBc0IsQ0FBQztBQUVyQyxhQUFhO0FBQ2IsY0FBYyxxQkFBcUIsQ0FBQztBQUVwQyxTQUFTO0FBQ1QsY0FBYyxpQkFBaUIsQ0FBQztBQUVoQyxTQUFTO0FBQ1QsY0FBYyxpQkFBaUIsQ0FBQztBQUVoQyxVQUFVO0FBQ1YsY0FBYyxjQUFjLENBQUM7QUFDN0IsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxnQkFBZ0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL25nLXByaW1lLXRvb2xzLm1vZHVsZSc7XG5cbi8vIEFkdmFuY2VkIHRhYmxlXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1hZHZhbmNlZC1wcmltZS10YWJsZSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9tdWx0aS1zZWFyY2gtY3JpdGVyaWEnO1xuXG4vLyBJbnB1dHNcbmV4cG9ydCAqIGZyb20gJy4vbGliL3B0LWNoZWNrLWJveC1pbnB1dCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1kYXRlLWlucHV0JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3B0LWRyb3Bkb3duJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3B0LWZvcm0tYnVpbGRlcic7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1udW1iZXItaW5wdXQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtc3dpdGNoLWlucHV0JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3B0LXRleHQtYXJlYS1pbnB1dCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC10ZXh0LWlucHV0JztcblxuLy8gRGFzaGJvYXJkXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1tZXRyaWMtcGFuZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtbWV0cmljLWNhcmQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtbWV0cmljLWNhcmQtZ3JvdXAnO1xuXG4vLyBDaGFydFxuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtY2hhcnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtbGluZS1jaGFydCc7XG5cbi8vIENhcmRzXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1jYXJkJztcblxuLy8gTWVudVxuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtbWVudSc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1tZW51LWZhbmN5JztcblxuLy8gTmF2YmFyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1uYXYtYmFyLW1lbnUnO1xuXG4vLyBOYXZiYXJcbmV4cG9ydCAqIGZyb20gJy4vbGliL3B0LXNpZGUtYmFyLW1lbnUnO1xuXG4vLyBQYWdlIHNrZWxldG9uXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1wYWdlLXNrZWxldG9uJztcblxuLy8gZm9vdGVyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1mb290ZXInO1xuXG4vLyBicmVhZCBjcnVtYlxuZXhwb3J0ICogZnJvbSAnLi9saWIvcHQtYnJlYWQtY3J1bWInO1xuXG4vLyBsb2dpbiBwYWdlXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1sb2dpbi1wYWdlJztcblxuLy8gYnV0dG9uXG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1idXR0b24nO1xuXG4vLyBkaWFsb2dcbmV4cG9ydCAqIGZyb20gJy4vbGliL3B0LWRpYWxvZyc7XG5cbi8vIEdlbmVyaWNcbmV4cG9ydCAqIGZyb20gJy4vbGliL21vZGVscyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbnVtcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi90eXBlcyc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9wdC1ncm91cCc7XG4iXX0=
|