ng-prime-tools 1.0.63 → 1.0.64
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/lib/models/text-style.model.mjs +1 -1
- package/esm2022/lib/pt-metric-card/pt-metric-card.component.mjs +59 -39
- package/fesm2022/ng-prime-tools.mjs +58 -38
- package/fesm2022/ng-prime-tools.mjs.map +1 -1
- package/lib/models/text-style.model.d.ts +1 -0
- package/lib/models/text-style.model.d.ts.map +1 -1
- package/lib/pt-group/pt-group.component.d.ts +1 -1
- package/lib/pt-metric-card/pt-metric-card.component.d.ts +17 -9
- package/lib/pt-metric-card/pt-metric-card.component.d.ts.map +1 -1
- package/package.json +1 -1
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC1zdHlsZS5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvbW9kZWxzL3RleHQtc3R5bGUubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgVGV4dFN0eWxlIHtcbiAgdGV4dDogc3RyaW5nO1xuICBjb2xvcj86IHN0cmluZztcbiAgZm9udFNpemU/OiBzdHJpbmc7XG4gIGZvbnRXZWlnaHQ/
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGV4dC1zdHlsZS5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25nLXByaW1lLXRvb2xzL3NyYy9saWIvbW9kZWxzL3RleHQtc3R5bGUubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgVGV4dFN0eWxlIHtcbiAgdGV4dDogc3RyaW5nO1xuICBjb2xvcj86IHN0cmluZztcbiAgZm9udFNpemU/OiBzdHJpbmc7XG4gIGZvbnRXZWlnaHQ/OiBzdHJpbmc7XG4gIHBvc2l0aW9uPzogJ2xlZnQnIHwgJ2NlbnRlcicgfCAncmlnaHQnO1xufVxuIl19
|
|
@@ -14,19 +14,20 @@ export class PTMetricCardComponent {
|
|
|
14
14
|
static { this.DEFAULT_ADDITIONAL_INFO_SIZE = '14px'; }
|
|
15
15
|
static { this.DEFAULT_BACKGROUND_COLOR = '#fff'; }
|
|
16
16
|
isIconObject() {
|
|
17
|
-
return typeof this.cardData.icon === 'object';
|
|
17
|
+
return (typeof this.cardData.icon === 'object' && this.cardData.icon !== null);
|
|
18
18
|
}
|
|
19
19
|
isTitleObject() {
|
|
20
|
-
return typeof this.cardData.title === 'object';
|
|
20
|
+
return (typeof this.cardData.title === 'object' && this.cardData.title !== null);
|
|
21
21
|
}
|
|
22
22
|
isValueObject() {
|
|
23
|
-
return typeof this.cardData.value === 'object';
|
|
23
|
+
return (typeof this.cardData.value === 'object' && this.cardData.value !== null);
|
|
24
24
|
}
|
|
25
25
|
isLabelObject(label) {
|
|
26
|
-
return typeof label === 'object';
|
|
26
|
+
return typeof label === 'object' && label !== null;
|
|
27
27
|
}
|
|
28
28
|
isAdditionalInfoObject() {
|
|
29
|
-
return typeof this.cardData.additionalInfo === 'object'
|
|
29
|
+
return (typeof this.cardData.additionalInfo === 'object' &&
|
|
30
|
+
this.cardData.additionalInfo !== null);
|
|
30
31
|
}
|
|
31
32
|
getIconText() {
|
|
32
33
|
return this.isIconObject()
|
|
@@ -36,35 +37,34 @@ export class PTMetricCardComponent {
|
|
|
36
37
|
getTitleText() {
|
|
37
38
|
return this.isTitleObject()
|
|
38
39
|
? this.cardData.title.text
|
|
39
|
-
: this.cardData.title;
|
|
40
|
+
: this.cardData.title || '';
|
|
40
41
|
}
|
|
41
42
|
getValueText() {
|
|
42
43
|
return this.isValueObject()
|
|
43
44
|
? this.cardData.value.text
|
|
44
|
-
: this.cardData.value;
|
|
45
|
+
: this.cardData.value || '';
|
|
45
46
|
}
|
|
46
47
|
getLabelText() {
|
|
47
48
|
const label = this.cardData.value?.label;
|
|
48
49
|
return this.isLabelObject(label)
|
|
49
50
|
? label.text
|
|
50
|
-
: label;
|
|
51
|
+
: label || '';
|
|
51
52
|
}
|
|
52
53
|
getAdditionalInfoText() {
|
|
53
54
|
return this.isAdditionalInfoObject()
|
|
54
55
|
? this.cardData.additionalInfo.text
|
|
55
|
-
: this.cardData.additionalInfo;
|
|
56
|
+
: this.cardData.additionalInfo || '';
|
|
56
57
|
}
|
|
57
58
|
getIconStyles() {
|
|
58
59
|
if (this.isIconObject()) {
|
|
59
60
|
const icon = this.cardData.icon;
|
|
60
|
-
const shape = icon.shape || 'circular';
|
|
61
|
-
// Determine border radius based on shape
|
|
61
|
+
const shape = icon.shape || 'circular';
|
|
62
62
|
const borderRadius = shape === 'circular' ? '50%' : '8px';
|
|
63
63
|
return {
|
|
64
64
|
color: icon.color || PTMetricCardComponent.DEFAULT_ICON_COLOR,
|
|
65
65
|
fontSize: icon.fontSize || PTMetricCardComponent.DEFAULT_ICON_SIZE,
|
|
66
|
-
|
|
67
|
-
|
|
66
|
+
backgroundColor: icon.backgroundColor || 'transparent',
|
|
67
|
+
borderRadius,
|
|
68
68
|
padding: '6px',
|
|
69
69
|
display: 'inline-block',
|
|
70
70
|
};
|
|
@@ -85,19 +85,43 @@ export class PTMetricCardComponent {
|
|
|
85
85
|
getValueStyles() {
|
|
86
86
|
if (this.isValueObject()) {
|
|
87
87
|
const value = this.cardData.value;
|
|
88
|
+
const position = value.position || 'left';
|
|
88
89
|
return {
|
|
89
90
|
color: value.color || PTMetricCardComponent.DEFAULT_VALUE_COLOR,
|
|
90
91
|
fontSize: value.fontSize || PTMetricCardComponent.DEFAULT_VALUE_SIZE,
|
|
91
92
|
fontWeight: value.fontWeight || 'bold',
|
|
93
|
+
textAlign: position,
|
|
94
|
+
width: '100%',
|
|
95
|
+
display: 'flex',
|
|
96
|
+
justifyContent: position === 'center'
|
|
97
|
+
? 'center'
|
|
98
|
+
: position === 'right'
|
|
99
|
+
? 'flex-end'
|
|
100
|
+
: 'flex-start',
|
|
101
|
+
alignItems: 'center',
|
|
92
102
|
};
|
|
93
103
|
}
|
|
94
|
-
|
|
104
|
+
return {
|
|
105
|
+
color: PTMetricCardComponent.DEFAULT_VALUE_COLOR,
|
|
106
|
+
fontSize: PTMetricCardComponent.DEFAULT_VALUE_SIZE,
|
|
107
|
+
fontWeight: 'bold',
|
|
108
|
+
textAlign: 'left',
|
|
109
|
+
width: '100%',
|
|
110
|
+
display: 'flex',
|
|
111
|
+
justifyContent: 'flex-start',
|
|
112
|
+
alignItems: 'center',
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
getValueTextStyles() {
|
|
116
|
+
if (this.isValueObject()) {
|
|
117
|
+
const value = this.cardData.value;
|
|
95
118
|
return {
|
|
96
|
-
|
|
97
|
-
fontSize: PTMetricCardComponent.DEFAULT_VALUE_SIZE,
|
|
98
|
-
fontWeight: 'bold',
|
|
119
|
+
textAlign: value.position || 'left',
|
|
99
120
|
};
|
|
100
121
|
}
|
|
122
|
+
return {
|
|
123
|
+
textAlign: 'left',
|
|
124
|
+
};
|
|
101
125
|
}
|
|
102
126
|
getLabelStyles(position) {
|
|
103
127
|
const label = this.cardData.value?.label;
|
|
@@ -111,13 +135,11 @@ export class PTMetricCardComponent {
|
|
|
111
135
|
fontWeight: label.fontWeight || 'normal',
|
|
112
136
|
};
|
|
113
137
|
}
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
};
|
|
120
|
-
}
|
|
138
|
+
return {
|
|
139
|
+
color: PTMetricCardComponent.DEFAULT_LABEL_COLOR,
|
|
140
|
+
fontSize: PTMetricCardComponent.DEFAULT_LABEL_SIZE,
|
|
141
|
+
fontWeight: 'normal',
|
|
142
|
+
};
|
|
121
143
|
}
|
|
122
144
|
getAdditionalInfoStyles() {
|
|
123
145
|
if (this.isAdditionalInfoObject()) {
|
|
@@ -130,13 +152,11 @@ export class PTMetricCardComponent {
|
|
|
130
152
|
fontWeight: additionalInfo.fontWeight || 'normal',
|
|
131
153
|
};
|
|
132
154
|
}
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
};
|
|
139
|
-
}
|
|
155
|
+
return {
|
|
156
|
+
color: PTMetricCardComponent.DEFAULT_ADDITIONAL_INFO_COLOR,
|
|
157
|
+
fontSize: PTMetricCardComponent.DEFAULT_ADDITIONAL_INFO_SIZE,
|
|
158
|
+
fontWeight: 'normal',
|
|
159
|
+
};
|
|
140
160
|
}
|
|
141
161
|
isLabelOnLeft() {
|
|
142
162
|
const label = this.cardData.value?.label;
|
|
@@ -148,27 +168,27 @@ export class PTMetricCardComponent {
|
|
|
148
168
|
}
|
|
149
169
|
getMetricCardContainerStyle() {
|
|
150
170
|
return {
|
|
151
|
-
|
|
152
|
-
|
|
171
|
+
minWidth: this.cardData.size?.minWidth || '100%',
|
|
172
|
+
maxWidth: this.cardData.size?.maxWidth || 'calc(25% - 16px)',
|
|
153
173
|
width: this.cardData.size?.fixedWidth || 'auto',
|
|
154
174
|
};
|
|
155
175
|
}
|
|
156
176
|
getMetricCardStyle() {
|
|
157
177
|
return {
|
|
158
|
-
|
|
178
|
+
backgroundColor: this.cardData.appearance?.backgroundColor ||
|
|
159
179
|
PTMetricCardComponent.DEFAULT_BACKGROUND_COLOR,
|
|
160
|
-
|
|
161
|
-
|
|
180
|
+
minWidth: this.cardData.size?.minWidth || '100%',
|
|
181
|
+
maxWidth: this.cardData.size?.maxWidth || 'calc(25% - 16px)',
|
|
162
182
|
width: this.cardData.size?.fixedWidth || 'auto',
|
|
163
183
|
};
|
|
164
184
|
}
|
|
165
185
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTMetricCardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
166
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTMetricCardComponent, selector: "pt-metric-card", inputs: { cardData: "cardData" }, ngImport: i0, template: "<div class=\"metric-card-container\" [ngStyle]=\"getMetricCardContainerStyle()\">\n <div\n *ngIf=\"cardData.verticalLine?.show\"\n class=\"vertical-line\"\n [ngStyle]=\"{\n 'background-color': cardData.verticalLine?.color || '#5a67d8'
|
|
186
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTMetricCardComponent, selector: "pt-metric-card", inputs: { cardData: "cardData" }, ngImport: i0, template: "<div class=\"metric-card-container\" [ngStyle]=\"getMetricCardContainerStyle()\">\n <div\n *ngIf=\"cardData.verticalLine?.show\"\n class=\"vertical-line\"\n [ngStyle]=\"{\n 'background-color': cardData.verticalLine?.color || '#5a67d8',\n }\"\n ></div>\n\n <div class=\"metric-card\" [ngStyle]=\"getMetricCardStyle()\">\n <div class=\"metric-card-header\">\n <i\n *ngIf=\"isIconObject()\"\n [ngClass]=\"getIconText()\"\n [ngStyle]=\"getIconStyles()\"\n ></i>\n <i *ngIf=\"!isIconObject()\" [ngClass]=\"cardData.icon\"></i>\n\n <span\n *ngIf=\"isTitleObject()\"\n class=\"metric-card-header-text\"\n [ngStyle]=\"getTitleStyles()\"\n >\n {{ getTitleText() }}\n </span>\n <span *ngIf=\"!isTitleObject()\" class=\"metric-card-header-text\">\n {{ cardData.title }}\n </span>\n </div>\n\n <div class=\"metric-card-content\">\n <div class=\"metric-value\" [ngStyle]=\"getValueStyles()\">\n <span\n *ngIf=\"isLabelOnLeft()\"\n class=\"value-label\"\n [ngStyle]=\"getLabelStyles('left')\"\n >\n {{ getLabelText() }}\n </span>\n\n <span class=\"metric-value-text\" [ngStyle]=\"getValueTextStyles()\">\n {{ getValueText() }}\n </span>\n\n <span\n *ngIf=\"isLabelOnRight()\"\n class=\"value-label\"\n [ngStyle]=\"getLabelStyles('right')\"\n >\n {{ getLabelText() }}\n </span>\n </div>\n\n <div\n *ngIf=\"cardData.divider?.show\"\n class=\"metric-divider\"\n [ngStyle]=\"{ backgroundColor: cardData.divider?.color || '#e2e8f0' }\"\n ></div>\n\n <div\n *ngIf=\"isAdditionalInfoObject()\"\n class=\"metric-additional-info\"\n [ngStyle]=\"getAdditionalInfoStyles()\"\n >\n {{ getAdditionalInfoText() }}\n </div>\n <div\n *ngIf=\"!isAdditionalInfoObject()\"\n class=\"metric-additional-info\"\n [ngStyle]=\"getAdditionalInfoStyles()\"\n >\n {{ cardData.additionalInfo }}\n </div>\n </div>\n </div>\n</div>\n", styles: [".metric-card-container{display:flex;align-items:stretch;box-sizing:border-box}.vertical-line{width:4px;border-radius:8px 0 0 8px;margin-right:-4px;z-index:2}.metric-card{background-color:#fff;border-radius:5px;box-shadow:0 1px 3px #0000001a;padding:16px;display:flex;flex-direction:column;box-sizing:border-box;margin-left:0;width:100%}.metric-card-header{display:flex;align-items:center;margin-bottom:16px}.metric-card-header i.icon-text{margin-right:8px}.metric-card-header-text{margin-left:6px}.metric-card-content{display:flex;flex-direction:column;justify-content:space-between;width:100%;flex:1}.metric-value{width:100%;display:flex;align-items:center;gap:6px;box-sizing:border-box}.metric-value-text{display:inline-block;width:100%;line-height:1.2}.metric-number{font-weight:700}.metric-label,.value-label{margin-left:8px;white-space:nowrap}.metric-divider{width:100%;height:1px;margin:16px 0}.metric-additional-info{margin-top:8px}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
|
|
167
187
|
}
|
|
168
188
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTMetricCardComponent, decorators: [{
|
|
169
189
|
type: Component,
|
|
170
|
-
args: [{ selector: 'pt-metric-card', template: "<div class=\"metric-card-container\" [ngStyle]=\"getMetricCardContainerStyle()\">\n <div\n *ngIf=\"cardData.verticalLine?.show\"\n class=\"vertical-line\"\n [ngStyle]=\"{\n 'background-color': cardData.verticalLine?.color || '#5a67d8'
|
|
190
|
+
args: [{ selector: 'pt-metric-card', template: "<div class=\"metric-card-container\" [ngStyle]=\"getMetricCardContainerStyle()\">\n <div\n *ngIf=\"cardData.verticalLine?.show\"\n class=\"vertical-line\"\n [ngStyle]=\"{\n 'background-color': cardData.verticalLine?.color || '#5a67d8',\n }\"\n ></div>\n\n <div class=\"metric-card\" [ngStyle]=\"getMetricCardStyle()\">\n <div class=\"metric-card-header\">\n <i\n *ngIf=\"isIconObject()\"\n [ngClass]=\"getIconText()\"\n [ngStyle]=\"getIconStyles()\"\n ></i>\n <i *ngIf=\"!isIconObject()\" [ngClass]=\"cardData.icon\"></i>\n\n <span\n *ngIf=\"isTitleObject()\"\n class=\"metric-card-header-text\"\n [ngStyle]=\"getTitleStyles()\"\n >\n {{ getTitleText() }}\n </span>\n <span *ngIf=\"!isTitleObject()\" class=\"metric-card-header-text\">\n {{ cardData.title }}\n </span>\n </div>\n\n <div class=\"metric-card-content\">\n <div class=\"metric-value\" [ngStyle]=\"getValueStyles()\">\n <span\n *ngIf=\"isLabelOnLeft()\"\n class=\"value-label\"\n [ngStyle]=\"getLabelStyles('left')\"\n >\n {{ getLabelText() }}\n </span>\n\n <span class=\"metric-value-text\" [ngStyle]=\"getValueTextStyles()\">\n {{ getValueText() }}\n </span>\n\n <span\n *ngIf=\"isLabelOnRight()\"\n class=\"value-label\"\n [ngStyle]=\"getLabelStyles('right')\"\n >\n {{ getLabelText() }}\n </span>\n </div>\n\n <div\n *ngIf=\"cardData.divider?.show\"\n class=\"metric-divider\"\n [ngStyle]=\"{ backgroundColor: cardData.divider?.color || '#e2e8f0' }\"\n ></div>\n\n <div\n *ngIf=\"isAdditionalInfoObject()\"\n class=\"metric-additional-info\"\n [ngStyle]=\"getAdditionalInfoStyles()\"\n >\n {{ getAdditionalInfoText() }}\n </div>\n <div\n *ngIf=\"!isAdditionalInfoObject()\"\n class=\"metric-additional-info\"\n [ngStyle]=\"getAdditionalInfoStyles()\"\n >\n {{ cardData.additionalInfo }}\n </div>\n </div>\n </div>\n</div>\n", styles: [".metric-card-container{display:flex;align-items:stretch;box-sizing:border-box}.vertical-line{width:4px;border-radius:8px 0 0 8px;margin-right:-4px;z-index:2}.metric-card{background-color:#fff;border-radius:5px;box-shadow:0 1px 3px #0000001a;padding:16px;display:flex;flex-direction:column;box-sizing:border-box;margin-left:0;width:100%}.metric-card-header{display:flex;align-items:center;margin-bottom:16px}.metric-card-header i.icon-text{margin-right:8px}.metric-card-header-text{margin-left:6px}.metric-card-content{display:flex;flex-direction:column;justify-content:space-between;width:100%;flex:1}.metric-value{width:100%;display:flex;align-items:center;gap:6px;box-sizing:border-box}.metric-value-text{display:inline-block;width:100%;line-height:1.2}.metric-number{font-weight:700}.metric-label,.value-label{margin-left:8px;white-space:nowrap}.metric-divider{width:100%;height:1px;margin:16px 0}.metric-additional-info{margin-top:8px}\n"] }]
|
|
171
191
|
}], propDecorators: { cardData: [{
|
|
172
192
|
type: Input
|
|
173
193
|
}] } });
|
|
174
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pt-metric-card.component.js","sourceRoot":"","sources":["../../../../../projects/ng-prime-tools/src/lib/pt-metric-card/pt-metric-card.component.ts","../../../../../projects/ng-prime-tools/src/lib/pt-metric-card/pt-metric-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from '@angular/core';\nimport {\n  LabelSetting,\n  MetricCardData,\n  ValueSetting,\n  IconStyle,\n  TextStyle,\n} from '../models';\n\n@Component({\n  selector: 'pt-metric-card',\n  templateUrl: './pt-metric-card.component.html',\n  styleUrls: ['./pt-metric-card.component.css'],\n})\nexport class PTMetricCardComponent {\n  private static readonly DEFAULT_ICON_COLOR = '#5a67d8';\n  private static readonly DEFAULT_ICON_SIZE = '24px';\n  private static readonly DEFAULT_TITLE_COLOR = '#5a67d8';\n  private static readonly DEFAULT_TITLE_SIZE = '16px';\n  private static readonly DEFAULT_VALUE_COLOR = '#2d3748';\n  private static readonly DEFAULT_VALUE_SIZE = '32px';\n  private static readonly DEFAULT_LABEL_COLOR = '#718096';\n  private static readonly DEFAULT_LABEL_SIZE = '14px';\n  private static readonly DEFAULT_ADDITIONAL_INFO_COLOR = 'gray';\n  private static readonly DEFAULT_ADDITIONAL_INFO_SIZE = '14px';\n  private static readonly DEFAULT_BACKGROUND_COLOR = '#fff';\n\n  @Input() cardData!: MetricCardData;\n\n  isIconObject(): boolean {\n    return typeof this.cardData.icon === 'object';\n  }\n\n  isTitleObject(): boolean {\n    return typeof this.cardData.title === 'object';\n  }\n\n  isValueObject(): boolean {\n    return typeof this.cardData.value === 'object';\n  }\n\n  isLabelObject(label: LabelSetting | string | undefined): boolean {\n    return typeof label === 'object';\n  }\n\n  isAdditionalInfoObject(): boolean {\n    return typeof this.cardData.additionalInfo === 'object';\n  }\n\n  getIconText(): string {\n    return this.isIconObject()\n      ? (this.cardData.icon as IconStyle).code\n      : (this.cardData.icon as string);\n  }\n\n  getTitleText(): string {\n    return this.isTitleObject()\n      ? (this.cardData.title as TextStyle).text\n      : (this.cardData.title as string);\n  }\n\n  getValueText(): string {\n    return this.isValueObject()\n      ? (this.cardData.value as ValueSetting).text\n      : (this.cardData.value as string);\n  }\n\n  getLabelText(): string {\n    const label = (this.cardData.value as ValueSetting)?.label;\n    return this.isLabelObject(label)\n      ? (label as LabelSetting).text\n      : (label as string);\n  }\n\n  getAdditionalInfoText(): string {\n    return this.isAdditionalInfoObject()\n      ? (this.cardData.additionalInfo as TextStyle).text\n      : (this.cardData.additionalInfo as string);\n  }\n\n  getIconStyles() {\n    if (this.isIconObject()) {\n      const icon = this.cardData.icon as IconStyle;\n      const shape = icon.shape || 'circular'; // Default to 'circular' if not specified\n\n      // Determine border radius based on shape\n      const borderRadius = shape === 'circular' ? '50%' : '8px';\n\n      return {\n        color: icon.color || PTMetricCardComponent.DEFAULT_ICON_COLOR,\n        fontSize: icon.fontSize || PTMetricCardComponent.DEFAULT_ICON_SIZE,\n        'background-color': icon.backgroundColor || 'transparent',\n        'border-radius': borderRadius,\n        padding: '6px',\n        display: 'inline-block',\n      };\n    }\n    return {};\n  }\n\n  getTitleStyles() {\n    if (this.isTitleObject()) {\n      const title = this.cardData.title as TextStyle;\n      return {\n        color: title.color || PTMetricCardComponent.DEFAULT_TITLE_COLOR,\n        fontSize: title.fontSize || PTMetricCardComponent.DEFAULT_TITLE_SIZE,\n        fontWeight: title.fontWeight || 'normal',\n      };\n    }\n    return {};\n  }\n\n  getValueStyles() {\n    if (this.isValueObject()) {\n      const value = this.cardData.value as ValueSetting;\n      return {\n        color: value.color || PTMetricCardComponent.DEFAULT_VALUE_COLOR,\n        fontSize: value.fontSize || PTMetricCardComponent.DEFAULT_VALUE_SIZE,\n        fontWeight: value.fontWeight || 'bold',\n      };\n    } else {\n      return {\n        color: PTMetricCardComponent.DEFAULT_VALUE_COLOR,\n        fontSize: PTMetricCardComponent.DEFAULT_VALUE_SIZE,\n        fontWeight: 'bold',\n      };\n    }\n  }\n\n  getLabelStyles(position: 'left' | 'right') {\n    const label = (this.cardData.value as ValueSetting)?.label;\n    if (\n      this.isLabelObject(label) &&\n      (label as LabelSetting).position === position\n    ) {\n      return {\n        color:\n          (label as LabelSetting).color ||\n          PTMetricCardComponent.DEFAULT_LABEL_COLOR,\n        fontSize:\n          (label as LabelSetting).fontSize ||\n          PTMetricCardComponent.DEFAULT_LABEL_SIZE,\n        fontWeight: (label as LabelSetting).fontWeight || 'normal',\n      };\n    } else {\n      return {\n        color: PTMetricCardComponent.DEFAULT_LABEL_COLOR,\n        fontSize: PTMetricCardComponent.DEFAULT_LABEL_SIZE,\n        fontWeight: 'normal',\n      };\n    }\n  }\n\n  getAdditionalInfoStyles() {\n    if (this.isAdditionalInfoObject()) {\n      const additionalInfo = this.cardData.additionalInfo as TextStyle;\n      return {\n        color:\n          additionalInfo.color ||\n          PTMetricCardComponent.DEFAULT_ADDITIONAL_INFO_COLOR,\n        fontSize:\n          additionalInfo.fontSize ||\n          PTMetricCardComponent.DEFAULT_ADDITIONAL_INFO_SIZE,\n        fontWeight: additionalInfo.fontWeight || 'normal',\n      };\n    } else {\n      return {\n        color: PTMetricCardComponent.DEFAULT_ADDITIONAL_INFO_COLOR,\n        fontSize: PTMetricCardComponent.DEFAULT_ADDITIONAL_INFO_SIZE,\n        fontWeight: 'normal',\n      };\n    }\n  }\n\n  isLabelOnLeft(): boolean {\n    const label = (this.cardData.value as ValueSetting)?.label;\n    return (\n      this.isLabelObject(label) && (label as LabelSetting).position === 'left'\n    );\n  }\n\n  isLabelOnRight(): boolean {\n    const label = (this.cardData.value as ValueSetting)?.label;\n    return (\n      this.isLabelObject(label) && (label as LabelSetting).position === 'right'\n    );\n  }\n\n  getMetricCardContainerStyle() {\n    return {\n      'min-width': this.cardData.size?.minWidth || '100%',\n      'max-width': this.cardData.size?.maxWidth || 'calc(25% - 16px)',\n      width: this.cardData.size?.fixedWidth || 'auto',\n    };\n  }\n\n  getMetricCardStyle() {\n    return {\n      'background-color':\n        this.cardData.appearance?.backgroundColor ||\n        PTMetricCardComponent.DEFAULT_BACKGROUND_COLOR,\n      'min-width': this.cardData.size?.minWidth || '100%',\n      'max-width': this.cardData.size?.maxWidth || 'calc(25% - 16px)',\n      width: this.cardData.size?.fixedWidth || 'auto',\n    };\n  }\n}\n","<div class=\"metric-card-container\" [ngStyle]=\"getMetricCardContainerStyle()\">\n  <div\n    *ngIf=\"cardData.verticalLine?.show\"\n    class=\"vertical-line\"\n    [ngStyle]=\"{\n      'background-color': cardData.verticalLine?.color || '#5a67d8'\n    }\"\n  ></div>\n\n  <div class=\"metric-card\" [ngStyle]=\"getMetricCardStyle()\">\n    <div class=\"metric-card-header\">\n      <i\n        *ngIf=\"isIconObject()\"\n        [ngClass]=\"getIconText()\"\n        [ngStyle]=\"getIconStyles()\"\n      ></i>\n      <i *ngIf=\"!isIconObject()\" [ngClass]=\"cardData.icon\"></i>\n\n      <span\n        *ngIf=\"isTitleObject()\"\n        class=\"metric-card-header-text\"\n        [ngStyle]=\"getTitleStyles()\"\n      >\n        {{ getTitleText() }}\n      </span>\n      <span *ngIf=\"!isTitleObject()\" class=\"metric-card-header-text\">\n        {{ cardData.title }}\n      </span>\n    </div>\n\n    <div class=\"metric-card-content\">\n      <div class=\"metric-value\" [ngStyle]=\"getValueStyles()\">\n        <span\n          *ngIf=\"isLabelOnLeft()\"\n          class=\"value-label\"\n          [ngStyle]=\"getLabelStyles('left')\"\n        >\n          {{ getLabelText() }}\n        </span>\n\n        <span [ngStyle]=\"getValueStyles()\">{{ getValueText() }}</span>\n\n        <span\n          *ngIf=\"isLabelOnRight()\"\n          class=\"value-label\"\n          [ngStyle]=\"getLabelStyles('right')\"\n        >\n          {{ getLabelText() }}\n        </span>\n      </div>\n\n      <div\n        *ngIf=\"cardData.divider?.show\"\n        class=\"metric-divider\"\n        [ngStyle]=\"{ backgroundColor: cardData.divider?.color || '#e2e8f0' }\"\n      ></div>\n\n      <div\n        *ngIf=\"isAdditionalInfoObject()\"\n        class=\"metric-additional-info\"\n        [ngStyle]=\"getAdditionalInfoStyles()\"\n      >\n        {{ getAdditionalInfoText() }}\n      </div>\n      <div\n        *ngIf=\"!isAdditionalInfoObject()\"\n        class=\"metric-additional-info\"\n        [ngStyle]=\"getAdditionalInfoStyles()\"\n      >\n        {{ cardData.additionalInfo }}\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
194
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pt-metric-card.component.js","sourceRoot":"","sources":["../../../../../projects/ng-prime-tools/src/lib/pt-metric-card/pt-metric-card.component.ts","../../../../../projects/ng-prime-tools/src/lib/pt-metric-card/pt-metric-card.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from '@angular/core';\nimport {\n  LabelSetting,\n  MetricCardData,\n  ValueSetting,\n  IconStyle,\n  TextStyle,\n} from '../models';\n\n@Component({\n  selector: 'pt-metric-card',\n  templateUrl: './pt-metric-card.component.html',\n  styleUrls: ['./pt-metric-card.component.css'],\n})\nexport class PTMetricCardComponent {\n  private static readonly DEFAULT_ICON_COLOR = '#5a67d8';\n  private static readonly DEFAULT_ICON_SIZE = '24px';\n  private static readonly DEFAULT_TITLE_COLOR = '#5a67d8';\n  private static readonly DEFAULT_TITLE_SIZE = '16px';\n  private static readonly DEFAULT_VALUE_COLOR = '#2d3748';\n  private static readonly DEFAULT_VALUE_SIZE = '32px';\n  private static readonly DEFAULT_LABEL_COLOR = '#718096';\n  private static readonly DEFAULT_LABEL_SIZE = '14px';\n  private static readonly DEFAULT_ADDITIONAL_INFO_COLOR = 'gray';\n  private static readonly DEFAULT_ADDITIONAL_INFO_SIZE = '14px';\n  private static readonly DEFAULT_BACKGROUND_COLOR = '#fff';\n\n  @Input() cardData!: MetricCardData;\n\n  isIconObject(): boolean {\n    return (\n      typeof this.cardData.icon === 'object' && this.cardData.icon !== null\n    );\n  }\n\n  isTitleObject(): boolean {\n    return (\n      typeof this.cardData.title === 'object' && this.cardData.title !== null\n    );\n  }\n\n  isValueObject(): boolean {\n    return (\n      typeof this.cardData.value === 'object' && this.cardData.value !== null\n    );\n  }\n\n  isLabelObject(label: LabelSetting | string | undefined): boolean {\n    return typeof label === 'object' && label !== null;\n  }\n\n  isAdditionalInfoObject(): boolean {\n    return (\n      typeof this.cardData.additionalInfo === 'object' &&\n      this.cardData.additionalInfo !== null\n    );\n  }\n\n  getIconText(): string {\n    return this.isIconObject()\n      ? (this.cardData.icon as IconStyle).code\n      : (this.cardData.icon as string);\n  }\n\n  getTitleText(): string {\n    return this.isTitleObject()\n      ? (this.cardData.title as TextStyle).text\n      : (this.cardData.title as string) || '';\n  }\n\n  getValueText(): string {\n    return this.isValueObject()\n      ? (this.cardData.value as ValueSetting).text\n      : (this.cardData.value as string) || '';\n  }\n\n  getLabelText(): string {\n    const label = (this.cardData.value as ValueSetting)?.label;\n    return this.isLabelObject(label)\n      ? (label as LabelSetting).text\n      : (label as string) || '';\n  }\n\n  getAdditionalInfoText(): string {\n    return this.isAdditionalInfoObject()\n      ? (this.cardData.additionalInfo as TextStyle).text\n      : (this.cardData.additionalInfo as string) || '';\n  }\n\n  getIconStyles() {\n    if (this.isIconObject()) {\n      const icon = this.cardData.icon as IconStyle;\n      const shape = icon.shape || 'circular';\n      const borderRadius = shape === 'circular' ? '50%' : '8px';\n\n      return {\n        color: icon.color || PTMetricCardComponent.DEFAULT_ICON_COLOR,\n        fontSize: icon.fontSize || PTMetricCardComponent.DEFAULT_ICON_SIZE,\n        backgroundColor: icon.backgroundColor || 'transparent',\n        borderRadius,\n        padding: '6px',\n        display: 'inline-block',\n      };\n    }\n\n    return {};\n  }\n\n  getTitleStyles() {\n    if (this.isTitleObject()) {\n      const title = this.cardData.title as TextStyle;\n\n      return {\n        color: title.color || PTMetricCardComponent.DEFAULT_TITLE_COLOR,\n        fontSize: title.fontSize || PTMetricCardComponent.DEFAULT_TITLE_SIZE,\n        fontWeight: title.fontWeight || 'normal',\n      };\n    }\n\n    return {};\n  }\n\n  getValueStyles() {\n    if (this.isValueObject()) {\n      const value = this.cardData.value as ValueSetting;\n      const position = value.position || 'left';\n\n      return {\n        color: value.color || PTMetricCardComponent.DEFAULT_VALUE_COLOR,\n        fontSize: value.fontSize || PTMetricCardComponent.DEFAULT_VALUE_SIZE,\n        fontWeight: value.fontWeight || 'bold',\n        textAlign: position,\n        width: '100%',\n        display: 'flex',\n        justifyContent:\n          position === 'center'\n            ? 'center'\n            : position === 'right'\n              ? 'flex-end'\n              : 'flex-start',\n        alignItems: 'center',\n      };\n    }\n\n    return {\n      color: PTMetricCardComponent.DEFAULT_VALUE_COLOR,\n      fontSize: PTMetricCardComponent.DEFAULT_VALUE_SIZE,\n      fontWeight: 'bold',\n      textAlign: 'left',\n      width: '100%',\n      display: 'flex',\n      justifyContent: 'flex-start',\n      alignItems: 'center',\n    };\n  }\n\n  getValueTextStyles() {\n    if (this.isValueObject()) {\n      const value = this.cardData.value as ValueSetting;\n\n      return {\n        textAlign: value.position || 'left',\n      };\n    }\n\n    return {\n      textAlign: 'left',\n    };\n  }\n\n  getLabelStyles(position: 'left' | 'right') {\n    const label = (this.cardData.value as ValueSetting)?.label;\n\n    if (\n      this.isLabelObject(label) &&\n      (label as LabelSetting).position === position\n    ) {\n      return {\n        color:\n          (label as LabelSetting).color ||\n          PTMetricCardComponent.DEFAULT_LABEL_COLOR,\n        fontSize:\n          (label as LabelSetting).fontSize ||\n          PTMetricCardComponent.DEFAULT_LABEL_SIZE,\n        fontWeight: (label as LabelSetting).fontWeight || 'normal',\n      };\n    }\n\n    return {\n      color: PTMetricCardComponent.DEFAULT_LABEL_COLOR,\n      fontSize: PTMetricCardComponent.DEFAULT_LABEL_SIZE,\n      fontWeight: 'normal',\n    };\n  }\n\n  getAdditionalInfoStyles() {\n    if (this.isAdditionalInfoObject()) {\n      const additionalInfo = this.cardData.additionalInfo as TextStyle;\n\n      return {\n        color:\n          additionalInfo.color ||\n          PTMetricCardComponent.DEFAULT_ADDITIONAL_INFO_COLOR,\n        fontSize:\n          additionalInfo.fontSize ||\n          PTMetricCardComponent.DEFAULT_ADDITIONAL_INFO_SIZE,\n        fontWeight: additionalInfo.fontWeight || 'normal',\n      };\n    }\n\n    return {\n      color: PTMetricCardComponent.DEFAULT_ADDITIONAL_INFO_COLOR,\n      fontSize: PTMetricCardComponent.DEFAULT_ADDITIONAL_INFO_SIZE,\n      fontWeight: 'normal',\n    };\n  }\n\n  isLabelOnLeft(): boolean {\n    const label = (this.cardData.value as ValueSetting)?.label;\n\n    return (\n      this.isLabelObject(label) && (label as LabelSetting).position === 'left'\n    );\n  }\n\n  isLabelOnRight(): boolean {\n    const label = (this.cardData.value as ValueSetting)?.label;\n\n    return (\n      this.isLabelObject(label) && (label as LabelSetting).position === 'right'\n    );\n  }\n\n  getMetricCardContainerStyle() {\n    return {\n      minWidth: this.cardData.size?.minWidth || '100%',\n      maxWidth: this.cardData.size?.maxWidth || 'calc(25% - 16px)',\n      width: this.cardData.size?.fixedWidth || 'auto',\n    };\n  }\n\n  getMetricCardStyle() {\n    return {\n      backgroundColor:\n        this.cardData.appearance?.backgroundColor ||\n        PTMetricCardComponent.DEFAULT_BACKGROUND_COLOR,\n      minWidth: this.cardData.size?.minWidth || '100%',\n      maxWidth: this.cardData.size?.maxWidth || 'calc(25% - 16px)',\n      width: this.cardData.size?.fixedWidth || 'auto',\n    };\n  }\n}\n","<div class=\"metric-card-container\" [ngStyle]=\"getMetricCardContainerStyle()\">\n  <div\n    *ngIf=\"cardData.verticalLine?.show\"\n    class=\"vertical-line\"\n    [ngStyle]=\"{\n      'background-color': cardData.verticalLine?.color || '#5a67d8',\n    }\"\n  ></div>\n\n  <div class=\"metric-card\" [ngStyle]=\"getMetricCardStyle()\">\n    <div class=\"metric-card-header\">\n      <i\n        *ngIf=\"isIconObject()\"\n        [ngClass]=\"getIconText()\"\n        [ngStyle]=\"getIconStyles()\"\n      ></i>\n      <i *ngIf=\"!isIconObject()\" [ngClass]=\"cardData.icon\"></i>\n\n      <span\n        *ngIf=\"isTitleObject()\"\n        class=\"metric-card-header-text\"\n        [ngStyle]=\"getTitleStyles()\"\n      >\n        {{ getTitleText() }}\n      </span>\n      <span *ngIf=\"!isTitleObject()\" class=\"metric-card-header-text\">\n        {{ cardData.title }}\n      </span>\n    </div>\n\n    <div class=\"metric-card-content\">\n      <div class=\"metric-value\" [ngStyle]=\"getValueStyles()\">\n        <span\n          *ngIf=\"isLabelOnLeft()\"\n          class=\"value-label\"\n          [ngStyle]=\"getLabelStyles('left')\"\n        >\n          {{ getLabelText() }}\n        </span>\n\n        <span class=\"metric-value-text\" [ngStyle]=\"getValueTextStyles()\">\n          {{ getValueText() }}\n        </span>\n\n        <span\n          *ngIf=\"isLabelOnRight()\"\n          class=\"value-label\"\n          [ngStyle]=\"getLabelStyles('right')\"\n        >\n          {{ getLabelText() }}\n        </span>\n      </div>\n\n      <div\n        *ngIf=\"cardData.divider?.show\"\n        class=\"metric-divider\"\n        [ngStyle]=\"{ backgroundColor: cardData.divider?.color || '#e2e8f0' }\"\n      ></div>\n\n      <div\n        *ngIf=\"isAdditionalInfoObject()\"\n        class=\"metric-additional-info\"\n        [ngStyle]=\"getAdditionalInfoStyles()\"\n      >\n        {{ getAdditionalInfoText() }}\n      </div>\n      <div\n        *ngIf=\"!isAdditionalInfoObject()\"\n        class=\"metric-additional-info\"\n        [ngStyle]=\"getAdditionalInfoStyles()\"\n      >\n        {{ cardData.additionalInfo }}\n      </div>\n    </div>\n  </div>\n</div>\n"]}
|
|
@@ -2808,19 +2808,20 @@ class PTMetricCardComponent {
|
|
|
2808
2808
|
static { this.DEFAULT_ADDITIONAL_INFO_SIZE = '14px'; }
|
|
2809
2809
|
static { this.DEFAULT_BACKGROUND_COLOR = '#fff'; }
|
|
2810
2810
|
isIconObject() {
|
|
2811
|
-
return typeof this.cardData.icon === 'object';
|
|
2811
|
+
return (typeof this.cardData.icon === 'object' && this.cardData.icon !== null);
|
|
2812
2812
|
}
|
|
2813
2813
|
isTitleObject() {
|
|
2814
|
-
return typeof this.cardData.title === 'object';
|
|
2814
|
+
return (typeof this.cardData.title === 'object' && this.cardData.title !== null);
|
|
2815
2815
|
}
|
|
2816
2816
|
isValueObject() {
|
|
2817
|
-
return typeof this.cardData.value === 'object';
|
|
2817
|
+
return (typeof this.cardData.value === 'object' && this.cardData.value !== null);
|
|
2818
2818
|
}
|
|
2819
2819
|
isLabelObject(label) {
|
|
2820
|
-
return typeof label === 'object';
|
|
2820
|
+
return typeof label === 'object' && label !== null;
|
|
2821
2821
|
}
|
|
2822
2822
|
isAdditionalInfoObject() {
|
|
2823
|
-
return typeof this.cardData.additionalInfo === 'object'
|
|
2823
|
+
return (typeof this.cardData.additionalInfo === 'object' &&
|
|
2824
|
+
this.cardData.additionalInfo !== null);
|
|
2824
2825
|
}
|
|
2825
2826
|
getIconText() {
|
|
2826
2827
|
return this.isIconObject()
|
|
@@ -2830,35 +2831,34 @@ class PTMetricCardComponent {
|
|
|
2830
2831
|
getTitleText() {
|
|
2831
2832
|
return this.isTitleObject()
|
|
2832
2833
|
? this.cardData.title.text
|
|
2833
|
-
: this.cardData.title;
|
|
2834
|
+
: this.cardData.title || '';
|
|
2834
2835
|
}
|
|
2835
2836
|
getValueText() {
|
|
2836
2837
|
return this.isValueObject()
|
|
2837
2838
|
? this.cardData.value.text
|
|
2838
|
-
: this.cardData.value;
|
|
2839
|
+
: this.cardData.value || '';
|
|
2839
2840
|
}
|
|
2840
2841
|
getLabelText() {
|
|
2841
2842
|
const label = this.cardData.value?.label;
|
|
2842
2843
|
return this.isLabelObject(label)
|
|
2843
2844
|
? label.text
|
|
2844
|
-
: label;
|
|
2845
|
+
: label || '';
|
|
2845
2846
|
}
|
|
2846
2847
|
getAdditionalInfoText() {
|
|
2847
2848
|
return this.isAdditionalInfoObject()
|
|
2848
2849
|
? this.cardData.additionalInfo.text
|
|
2849
|
-
: this.cardData.additionalInfo;
|
|
2850
|
+
: this.cardData.additionalInfo || '';
|
|
2850
2851
|
}
|
|
2851
2852
|
getIconStyles() {
|
|
2852
2853
|
if (this.isIconObject()) {
|
|
2853
2854
|
const icon = this.cardData.icon;
|
|
2854
|
-
const shape = icon.shape || 'circular';
|
|
2855
|
-
// Determine border radius based on shape
|
|
2855
|
+
const shape = icon.shape || 'circular';
|
|
2856
2856
|
const borderRadius = shape === 'circular' ? '50%' : '8px';
|
|
2857
2857
|
return {
|
|
2858
2858
|
color: icon.color || PTMetricCardComponent.DEFAULT_ICON_COLOR,
|
|
2859
2859
|
fontSize: icon.fontSize || PTMetricCardComponent.DEFAULT_ICON_SIZE,
|
|
2860
|
-
|
|
2861
|
-
|
|
2860
|
+
backgroundColor: icon.backgroundColor || 'transparent',
|
|
2861
|
+
borderRadius,
|
|
2862
2862
|
padding: '6px',
|
|
2863
2863
|
display: 'inline-block',
|
|
2864
2864
|
};
|
|
@@ -2879,19 +2879,43 @@ class PTMetricCardComponent {
|
|
|
2879
2879
|
getValueStyles() {
|
|
2880
2880
|
if (this.isValueObject()) {
|
|
2881
2881
|
const value = this.cardData.value;
|
|
2882
|
+
const position = value.position || 'left';
|
|
2882
2883
|
return {
|
|
2883
2884
|
color: value.color || PTMetricCardComponent.DEFAULT_VALUE_COLOR,
|
|
2884
2885
|
fontSize: value.fontSize || PTMetricCardComponent.DEFAULT_VALUE_SIZE,
|
|
2885
2886
|
fontWeight: value.fontWeight || 'bold',
|
|
2887
|
+
textAlign: position,
|
|
2888
|
+
width: '100%',
|
|
2889
|
+
display: 'flex',
|
|
2890
|
+
justifyContent: position === 'center'
|
|
2891
|
+
? 'center'
|
|
2892
|
+
: position === 'right'
|
|
2893
|
+
? 'flex-end'
|
|
2894
|
+
: 'flex-start',
|
|
2895
|
+
alignItems: 'center',
|
|
2886
2896
|
};
|
|
2887
2897
|
}
|
|
2888
|
-
|
|
2898
|
+
return {
|
|
2899
|
+
color: PTMetricCardComponent.DEFAULT_VALUE_COLOR,
|
|
2900
|
+
fontSize: PTMetricCardComponent.DEFAULT_VALUE_SIZE,
|
|
2901
|
+
fontWeight: 'bold',
|
|
2902
|
+
textAlign: 'left',
|
|
2903
|
+
width: '100%',
|
|
2904
|
+
display: 'flex',
|
|
2905
|
+
justifyContent: 'flex-start',
|
|
2906
|
+
alignItems: 'center',
|
|
2907
|
+
};
|
|
2908
|
+
}
|
|
2909
|
+
getValueTextStyles() {
|
|
2910
|
+
if (this.isValueObject()) {
|
|
2911
|
+
const value = this.cardData.value;
|
|
2889
2912
|
return {
|
|
2890
|
-
|
|
2891
|
-
fontSize: PTMetricCardComponent.DEFAULT_VALUE_SIZE,
|
|
2892
|
-
fontWeight: 'bold',
|
|
2913
|
+
textAlign: value.position || 'left',
|
|
2893
2914
|
};
|
|
2894
2915
|
}
|
|
2916
|
+
return {
|
|
2917
|
+
textAlign: 'left',
|
|
2918
|
+
};
|
|
2895
2919
|
}
|
|
2896
2920
|
getLabelStyles(position) {
|
|
2897
2921
|
const label = this.cardData.value?.label;
|
|
@@ -2905,13 +2929,11 @@ class PTMetricCardComponent {
|
|
|
2905
2929
|
fontWeight: label.fontWeight || 'normal',
|
|
2906
2930
|
};
|
|
2907
2931
|
}
|
|
2908
|
-
|
|
2909
|
-
|
|
2910
|
-
|
|
2911
|
-
|
|
2912
|
-
|
|
2913
|
-
};
|
|
2914
|
-
}
|
|
2932
|
+
return {
|
|
2933
|
+
color: PTMetricCardComponent.DEFAULT_LABEL_COLOR,
|
|
2934
|
+
fontSize: PTMetricCardComponent.DEFAULT_LABEL_SIZE,
|
|
2935
|
+
fontWeight: 'normal',
|
|
2936
|
+
};
|
|
2915
2937
|
}
|
|
2916
2938
|
getAdditionalInfoStyles() {
|
|
2917
2939
|
if (this.isAdditionalInfoObject()) {
|
|
@@ -2924,13 +2946,11 @@ class PTMetricCardComponent {
|
|
|
2924
2946
|
fontWeight: additionalInfo.fontWeight || 'normal',
|
|
2925
2947
|
};
|
|
2926
2948
|
}
|
|
2927
|
-
|
|
2928
|
-
|
|
2929
|
-
|
|
2930
|
-
|
|
2931
|
-
|
|
2932
|
-
};
|
|
2933
|
-
}
|
|
2949
|
+
return {
|
|
2950
|
+
color: PTMetricCardComponent.DEFAULT_ADDITIONAL_INFO_COLOR,
|
|
2951
|
+
fontSize: PTMetricCardComponent.DEFAULT_ADDITIONAL_INFO_SIZE,
|
|
2952
|
+
fontWeight: 'normal',
|
|
2953
|
+
};
|
|
2934
2954
|
}
|
|
2935
2955
|
isLabelOnLeft() {
|
|
2936
2956
|
const label = this.cardData.value?.label;
|
|
@@ -2942,26 +2962,26 @@ class PTMetricCardComponent {
|
|
|
2942
2962
|
}
|
|
2943
2963
|
getMetricCardContainerStyle() {
|
|
2944
2964
|
return {
|
|
2945
|
-
|
|
2946
|
-
|
|
2965
|
+
minWidth: this.cardData.size?.minWidth || '100%',
|
|
2966
|
+
maxWidth: this.cardData.size?.maxWidth || 'calc(25% - 16px)',
|
|
2947
2967
|
width: this.cardData.size?.fixedWidth || 'auto',
|
|
2948
2968
|
};
|
|
2949
2969
|
}
|
|
2950
2970
|
getMetricCardStyle() {
|
|
2951
2971
|
return {
|
|
2952
|
-
|
|
2972
|
+
backgroundColor: this.cardData.appearance?.backgroundColor ||
|
|
2953
2973
|
PTMetricCardComponent.DEFAULT_BACKGROUND_COLOR,
|
|
2954
|
-
|
|
2955
|
-
|
|
2974
|
+
minWidth: this.cardData.size?.minWidth || '100%',
|
|
2975
|
+
maxWidth: this.cardData.size?.maxWidth || 'calc(25% - 16px)',
|
|
2956
2976
|
width: this.cardData.size?.fixedWidth || 'auto',
|
|
2957
2977
|
};
|
|
2958
2978
|
}
|
|
2959
2979
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTMetricCardComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
2960
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTMetricCardComponent, selector: "pt-metric-card", inputs: { cardData: "cardData" }, ngImport: i0, template: "<div class=\"metric-card-container\" [ngStyle]=\"getMetricCardContainerStyle()\">\n <div\n *ngIf=\"cardData.verticalLine?.show\"\n class=\"vertical-line\"\n [ngStyle]=\"{\n 'background-color': cardData.verticalLine?.color || '#5a67d8'
|
|
2980
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: PTMetricCardComponent, selector: "pt-metric-card", inputs: { cardData: "cardData" }, ngImport: i0, template: "<div class=\"metric-card-container\" [ngStyle]=\"getMetricCardContainerStyle()\">\n <div\n *ngIf=\"cardData.verticalLine?.show\"\n class=\"vertical-line\"\n [ngStyle]=\"{\n 'background-color': cardData.verticalLine?.color || '#5a67d8',\n }\"\n ></div>\n\n <div class=\"metric-card\" [ngStyle]=\"getMetricCardStyle()\">\n <div class=\"metric-card-header\">\n <i\n *ngIf=\"isIconObject()\"\n [ngClass]=\"getIconText()\"\n [ngStyle]=\"getIconStyles()\"\n ></i>\n <i *ngIf=\"!isIconObject()\" [ngClass]=\"cardData.icon\"></i>\n\n <span\n *ngIf=\"isTitleObject()\"\n class=\"metric-card-header-text\"\n [ngStyle]=\"getTitleStyles()\"\n >\n {{ getTitleText() }}\n </span>\n <span *ngIf=\"!isTitleObject()\" class=\"metric-card-header-text\">\n {{ cardData.title }}\n </span>\n </div>\n\n <div class=\"metric-card-content\">\n <div class=\"metric-value\" [ngStyle]=\"getValueStyles()\">\n <span\n *ngIf=\"isLabelOnLeft()\"\n class=\"value-label\"\n [ngStyle]=\"getLabelStyles('left')\"\n >\n {{ getLabelText() }}\n </span>\n\n <span class=\"metric-value-text\" [ngStyle]=\"getValueTextStyles()\">\n {{ getValueText() }}\n </span>\n\n <span\n *ngIf=\"isLabelOnRight()\"\n class=\"value-label\"\n [ngStyle]=\"getLabelStyles('right')\"\n >\n {{ getLabelText() }}\n </span>\n </div>\n\n <div\n *ngIf=\"cardData.divider?.show\"\n class=\"metric-divider\"\n [ngStyle]=\"{ backgroundColor: cardData.divider?.color || '#e2e8f0' }\"\n ></div>\n\n <div\n *ngIf=\"isAdditionalInfoObject()\"\n class=\"metric-additional-info\"\n [ngStyle]=\"getAdditionalInfoStyles()\"\n >\n {{ getAdditionalInfoText() }}\n </div>\n <div\n *ngIf=\"!isAdditionalInfoObject()\"\n class=\"metric-additional-info\"\n [ngStyle]=\"getAdditionalInfoStyles()\"\n >\n {{ cardData.additionalInfo }}\n </div>\n </div>\n </div>\n</div>\n", styles: [".metric-card-container{display:flex;align-items:stretch;box-sizing:border-box}.vertical-line{width:4px;border-radius:8px 0 0 8px;margin-right:-4px;z-index:2}.metric-card{background-color:#fff;border-radius:5px;box-shadow:0 1px 3px #0000001a;padding:16px;display:flex;flex-direction:column;box-sizing:border-box;margin-left:0;width:100%}.metric-card-header{display:flex;align-items:center;margin-bottom:16px}.metric-card-header i.icon-text{margin-right:8px}.metric-card-header-text{margin-left:6px}.metric-card-content{display:flex;flex-direction:column;justify-content:space-between;width:100%;flex:1}.metric-value{width:100%;display:flex;align-items:center;gap:6px;box-sizing:border-box}.metric-value-text{display:inline-block;width:100%;line-height:1.2}.metric-number{font-weight:700}.metric-label,.value-label{margin-left:8px;white-space:nowrap}.metric-divider{width:100%;height:1px;margin:16px 0}.metric-additional-info{margin-top:8px}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
|
|
2961
2981
|
}
|
|
2962
2982
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: PTMetricCardComponent, decorators: [{
|
|
2963
2983
|
type: Component,
|
|
2964
|
-
args: [{ selector: 'pt-metric-card', template: "<div class=\"metric-card-container\" [ngStyle]=\"getMetricCardContainerStyle()\">\n <div\n *ngIf=\"cardData.verticalLine?.show\"\n class=\"vertical-line\"\n [ngStyle]=\"{\n 'background-color': cardData.verticalLine?.color || '#5a67d8'
|
|
2984
|
+
args: [{ selector: 'pt-metric-card', template: "<div class=\"metric-card-container\" [ngStyle]=\"getMetricCardContainerStyle()\">\n <div\n *ngIf=\"cardData.verticalLine?.show\"\n class=\"vertical-line\"\n [ngStyle]=\"{\n 'background-color': cardData.verticalLine?.color || '#5a67d8',\n }\"\n ></div>\n\n <div class=\"metric-card\" [ngStyle]=\"getMetricCardStyle()\">\n <div class=\"metric-card-header\">\n <i\n *ngIf=\"isIconObject()\"\n [ngClass]=\"getIconText()\"\n [ngStyle]=\"getIconStyles()\"\n ></i>\n <i *ngIf=\"!isIconObject()\" [ngClass]=\"cardData.icon\"></i>\n\n <span\n *ngIf=\"isTitleObject()\"\n class=\"metric-card-header-text\"\n [ngStyle]=\"getTitleStyles()\"\n >\n {{ getTitleText() }}\n </span>\n <span *ngIf=\"!isTitleObject()\" class=\"metric-card-header-text\">\n {{ cardData.title }}\n </span>\n </div>\n\n <div class=\"metric-card-content\">\n <div class=\"metric-value\" [ngStyle]=\"getValueStyles()\">\n <span\n *ngIf=\"isLabelOnLeft()\"\n class=\"value-label\"\n [ngStyle]=\"getLabelStyles('left')\"\n >\n {{ getLabelText() }}\n </span>\n\n <span class=\"metric-value-text\" [ngStyle]=\"getValueTextStyles()\">\n {{ getValueText() }}\n </span>\n\n <span\n *ngIf=\"isLabelOnRight()\"\n class=\"value-label\"\n [ngStyle]=\"getLabelStyles('right')\"\n >\n {{ getLabelText() }}\n </span>\n </div>\n\n <div\n *ngIf=\"cardData.divider?.show\"\n class=\"metric-divider\"\n [ngStyle]=\"{ backgroundColor: cardData.divider?.color || '#e2e8f0' }\"\n ></div>\n\n <div\n *ngIf=\"isAdditionalInfoObject()\"\n class=\"metric-additional-info\"\n [ngStyle]=\"getAdditionalInfoStyles()\"\n >\n {{ getAdditionalInfoText() }}\n </div>\n <div\n *ngIf=\"!isAdditionalInfoObject()\"\n class=\"metric-additional-info\"\n [ngStyle]=\"getAdditionalInfoStyles()\"\n >\n {{ cardData.additionalInfo }}\n </div>\n </div>\n </div>\n</div>\n", styles: [".metric-card-container{display:flex;align-items:stretch;box-sizing:border-box}.vertical-line{width:4px;border-radius:8px 0 0 8px;margin-right:-4px;z-index:2}.metric-card{background-color:#fff;border-radius:5px;box-shadow:0 1px 3px #0000001a;padding:16px;display:flex;flex-direction:column;box-sizing:border-box;margin-left:0;width:100%}.metric-card-header{display:flex;align-items:center;margin-bottom:16px}.metric-card-header i.icon-text{margin-right:8px}.metric-card-header-text{margin-left:6px}.metric-card-content{display:flex;flex-direction:column;justify-content:space-between;width:100%;flex:1}.metric-value{width:100%;display:flex;align-items:center;gap:6px;box-sizing:border-box}.metric-value-text{display:inline-block;width:100%;line-height:1.2}.metric-number{font-weight:700}.metric-label,.value-label{margin-left:8px;white-space:nowrap}.metric-divider{width:100%;height:1px;margin:16px 0}.metric-additional-info{margin-top:8px}\n"] }]
|
|
2965
2985
|
}], propDecorators: { cardData: [{
|
|
2966
2986
|
type: Input
|
|
2967
2987
|
}] } });
|