gamma-app-controller 2.0.25 → 4.0.1
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/esm2020/lib/application-controller/application-content.service.mjs +36 -36
- package/esm2020/lib/application-controller/application-controller.module.mjs +6 -1
- package/esm2020/lib/application-controller/application-dataset-component/create-dataset/create-dataset.component.mjs +2 -2
- package/esm2020/lib/application-controller/application-menu-controller/application-create-menu/application-create-menu.component.mjs +10 -27
- package/esm2020/lib/application-controller/application-view-components/create-comp-view/create-comp-view.component.mjs +6 -3
- package/esm2020/lib/application-controller/page-controller/page-config/page-config.component.mjs +3 -3
- package/esm2020/lib/application-controller/support-components/dash-chart/dash-chart.component.mjs +32 -167
- package/esm2020/lib/application-controller/support-components/dash-table/dash-table.component.mjs +4 -3
- package/esm2020/lib/application-controller/support-components/geo-map/geo-map.component.mjs +12 -228
- package/esm2020/lib/application-controller/support-components/heat-map/heat-map.component.mjs +32 -3
- package/esm2020/lib/application-controller/support-components/single-card/single-card.component.mjs +24 -34
- package/esm2020/lib/shared/advanced-component/gamm-single-number-card/gamm-single-number-card.component.mjs +3 -4
- package/esm2020/lib/shared/advanced-component/gamma-advance-chart/gamma-advance-chart.component.mjs +39 -109
- package/esm2020/lib/shared/advanced-component/gamma-advance-operator-table/gamma-advance-operator-table.component.mjs +15 -2
- package/esm2020/lib/shared/advanced-component/gamma-geo-chart/gamma-geo-chart.component.mjs +7 -272
- package/esm2020/lib/shared/advanced-component/gamma-heatmap/gamma-heatmap.component.mjs +68 -16
- package/esm2020/lib/shared/advanced-component/google-geo-map/google-geo-map.component.mjs +439 -0
- package/esm2020/lib/shared/gamma-bread-crumbs/bread-crumbs.component.mjs +66 -58
- package/esm2020/lib/shared/permission-helper.mjs +4 -35
- package/esm2020/lib/shared/template-dataset-call-service.mjs +5 -1
- package/esm2020/lib/shared/user-access/user-access.component.mjs +5 -5
- package/esm2020/lib/template-module/KpiCreationModule/create-kpi-tree.component.mjs +275 -153
- package/esm2020/lib/template-module/KpiCreationModule/createKpi.service.mjs +6 -37
- package/esm2020/lib/template-module/KpiCreationModule/treeview/components/basic/basic.component.mjs +3 -3
- package/esm2020/lib/template-module/KpiCreationModule/treeview/components/collapsable/collapsable.component.mjs +15 -4
- package/esm2020/lib/template-module/KpiCreationModule/treeview/treeview.component.mjs +6 -4
- package/esm2020/lib/template-module/bookmarked-template/bookmarked-layout.service.mjs +8 -8
- package/esm2020/lib/template-module/cdrConfigModule/cdr-browser.service.mjs +2 -2
- package/esm2020/lib/template-module/defaulLandingComponent/landing-component.component.mjs +2 -1
- package/esm2020/lib/template-module/defaulLandingComponent/landing-component.service.mjs +8 -8
- package/esm2020/lib/template-module/defaulLandingMultiLayoutComponent/defaulLandingMultiLayout.service.mjs +8 -8
- package/esm2020/lib/template-module/kpiWithMultiLayout/kpi-multi-layout.service.mjs +8 -8
- package/esm2020/lib/template-module/kpiWithSingleLayout/kpi-single-layout.service.mjs +8 -16
- package/esm2020/lib/template-module/kpiWithSingleLayout/kpi-with-dataset.component.mjs +9 -12
- package/esm2020/public-api.mjs +3 -1
- package/fesm2015/gamma-app-controller.mjs +8857 -8951
- package/fesm2015/gamma-app-controller.mjs.map +1 -1
- package/fesm2020/gamma-app-controller.mjs +9471 -9578
- package/fesm2020/gamma-app-controller.mjs.map +1 -1
- package/lib/application-controller/application-content.service.d.ts +1 -1
- package/lib/application-controller/application-controller.module.d.ts +26 -25
- package/lib/application-controller/application-menu-controller/application-create-menu/application-create-menu.component.d.ts +0 -2
- package/lib/application-controller/support-components/dash-chart/dash-chart.component.d.ts +3 -18
- package/lib/application-controller/support-components/geo-map/geo-map.component.d.ts +2 -46
- package/lib/application-controller/support-components/heat-map/heat-map.component.d.ts +5 -0
- package/lib/application-controller/support-components/single-card/single-card.component.d.ts +2 -5
- package/lib/shared/advanced-component/gamm-single-number-card/gamm-single-number-card.component.d.ts +0 -1
- package/lib/shared/advanced-component/gamma-advance-chart/gamma-advance-chart.component.d.ts +1 -3
- package/lib/shared/advanced-component/gamma-advance-operator-table/gamma-advance-operator-table.component.d.ts +1 -0
- package/lib/shared/advanced-component/gamma-geo-chart/gamma-geo-chart.component.d.ts +0 -40
- package/lib/shared/advanced-component/gamma-heatmap/gamma-heatmap.component.d.ts +3 -1
- package/lib/shared/advanced-component/google-geo-map/google-geo-map.component.d.ts +62 -0
- package/lib/shared/gamma-bread-crumbs/bread-crumbs.component.d.ts +0 -2
- package/lib/shared/permission-helper.d.ts +0 -1
- package/lib/template-module/KpiCreationModule/create-kpi-tree.component.d.ts +15 -11
- package/lib/template-module/KpiCreationModule/createKpi.service.d.ts +0 -4
- package/lib/template-module/kpiWithSingleLayout/kpi-single-layout.service.d.ts +0 -1
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
|
@@ -45,7 +45,6 @@ export class GammaHeatChartComponent {
|
|
|
45
45
|
else {
|
|
46
46
|
this.isLoader = true;
|
|
47
47
|
this.page_config = value;
|
|
48
|
-
this.page_parms = value.titleParams;
|
|
49
48
|
if (value.kpiConfig.dataSource && value.kpiConfig.dataSource.length !== 0) {
|
|
50
49
|
this.heatmapChartConfig = value.kpiConfig.dataConfig;
|
|
51
50
|
this.colorArray = value.kpiConfig.dataConfig.color;
|
|
@@ -58,7 +57,7 @@ export class GammaHeatChartComponent {
|
|
|
58
57
|
setTimeout(() => {
|
|
59
58
|
this.dataSourseForTable = [];
|
|
60
59
|
this.tableDataConfig['columns'] = [];
|
|
61
|
-
this.isLoader =
|
|
60
|
+
this.isLoader = true;
|
|
62
61
|
}, 200);
|
|
63
62
|
}
|
|
64
63
|
}
|
|
@@ -107,7 +106,9 @@ export class GammaHeatChartComponent {
|
|
|
107
106
|
const allEntries = [];
|
|
108
107
|
const topArg = this.heatmapChartConfig.topArgument;
|
|
109
108
|
const leftArg = this.heatmapChartConfig.leftArgument;
|
|
110
|
-
const
|
|
109
|
+
const mapColumn = this.heatmapChartConfig.columns.filter(col => col.displayFor === 'map' && col.visible);
|
|
110
|
+
const tooltipColumns = this.heatmapChartConfig.columns.filter(col => col.displayFor === 'tooltip' && col.visible);
|
|
111
|
+
const valueField = mapColumn.length > 0 ? mapColumn[0].dataField : null;
|
|
111
112
|
data.forEach(entry => {
|
|
112
113
|
const formattedDate = (moment(entry[topArg]).format('YYYY-MM-DD')) ? moment(entry[topArg]).format('YYYY-MM-DD') : topArg;
|
|
113
114
|
uniqueDates.add(formattedDate);
|
|
@@ -135,7 +136,14 @@ export class GammaHeatChartComponent {
|
|
|
135
136
|
if (!dateMap[date]) {
|
|
136
137
|
dateMap[date] = [];
|
|
137
138
|
}
|
|
138
|
-
let toolTip =
|
|
139
|
+
let toolTip = '';
|
|
140
|
+
if (valueField) {
|
|
141
|
+
toolTip += `${this.commonService.convertString(valueField)} : ${item[valueField]}\n`;
|
|
142
|
+
}
|
|
143
|
+
tooltipColumns.forEach(col => {
|
|
144
|
+
const value = item[col.dataField];
|
|
145
|
+
toolTip += `${col.caption} : ${value}\n`;
|
|
146
|
+
});
|
|
139
147
|
dateMap[date].push({
|
|
140
148
|
[leftArg]: item[leftArg],
|
|
141
149
|
[valueField]: item[valueField],
|
|
@@ -162,7 +170,9 @@ export class GammaHeatChartComponent {
|
|
|
162
170
|
const dataSourceMap = {};
|
|
163
171
|
const topArg = this.heatmapChartConfig.topArgument;
|
|
164
172
|
const leftArg = this.heatmapChartConfig.leftArgument;
|
|
165
|
-
const
|
|
173
|
+
const mapColumn = this.heatmapChartConfig.columns.filter(col => col.displayFor === 'map' && col.visible);
|
|
174
|
+
const tooltipColumns = this.heatmapChartConfig.columns.filter(col => col.displayFor === 'tooltip' && col.visible);
|
|
175
|
+
const valueField = mapColumn.length > 0 ? mapColumn[0].dataField : null;
|
|
166
176
|
data.forEach(item => {
|
|
167
177
|
const rowKey = item[leftArg];
|
|
168
178
|
const columnKey = moment(item[topArg]).format('YYYY-MM-DD');
|
|
@@ -172,7 +182,14 @@ export class GammaHeatChartComponent {
|
|
|
172
182
|
dataset: []
|
|
173
183
|
};
|
|
174
184
|
}
|
|
175
|
-
let toolTip =
|
|
185
|
+
let toolTip = '';
|
|
186
|
+
if (valueField) {
|
|
187
|
+
toolTip += `${this.commonService.convertString(valueField)} : ${item[valueField]} | `;
|
|
188
|
+
}
|
|
189
|
+
tooltipColumns.forEach(col => {
|
|
190
|
+
const value = item[col.dataField];
|
|
191
|
+
toolTip += `${col.caption} : ${value} | `;
|
|
192
|
+
});
|
|
176
193
|
dataSourceMap[rowKey].dataset.push({
|
|
177
194
|
...item,
|
|
178
195
|
toolTip: toolTip,
|
|
@@ -298,26 +315,61 @@ export class GammaHeatChartComponent {
|
|
|
298
315
|
getObjectKeys(obj) {
|
|
299
316
|
return Object.keys(obj);
|
|
300
317
|
}
|
|
301
|
-
callServiceFunction(
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
318
|
+
callServiceFunction(data) {
|
|
319
|
+
const mapColumn = this.heatmapChartConfig.columns.find(col => col.displayFor === 'map' && col.visible);
|
|
320
|
+
const functionName = mapColumn ? mapColumn.enrichName : null;
|
|
321
|
+
const valueField = mapColumn ? mapColumn.dataField : null;
|
|
322
|
+
if (functionName != "") {
|
|
323
|
+
if (data[valueField] !== undefined) {
|
|
324
|
+
if (typeof this.commonService[functionName] === "function") {
|
|
325
|
+
return this.commonService[functionName](data[valueField]);
|
|
326
|
+
}
|
|
327
|
+
else {
|
|
328
|
+
console.error(`Function ${functionName} not found in CommonService`);
|
|
329
|
+
return null;
|
|
330
|
+
}
|
|
305
331
|
}
|
|
306
332
|
else {
|
|
307
|
-
|
|
308
|
-
return null;
|
|
333
|
+
return "No Data";
|
|
309
334
|
}
|
|
310
335
|
}
|
|
311
336
|
else {
|
|
312
|
-
return
|
|
337
|
+
return data[valueField];
|
|
338
|
+
}
|
|
339
|
+
}
|
|
340
|
+
onRowClick(data) {
|
|
341
|
+
const title_params = data[this.page_config.kpiConfig.dataConfig.commonConfig['dataField']];
|
|
342
|
+
let title = this.getParamsTitle(data);
|
|
343
|
+
let obj = {
|
|
344
|
+
data: data,
|
|
345
|
+
keyToPass: this.page_config.kpiConfig.keyToPass,
|
|
346
|
+
tableTitle: (this.page_parms) ? this.page_parms + title : title,
|
|
347
|
+
viewId: this.page_config.viewId,
|
|
348
|
+
drillDownType: "natural",
|
|
349
|
+
drilldownFrom: this.page_config.viewId,
|
|
350
|
+
drilldownTo: "",
|
|
351
|
+
};
|
|
352
|
+
this.oRowClick.emit(obj);
|
|
353
|
+
}
|
|
354
|
+
getParamsTitle(data) {
|
|
355
|
+
const config = this.page_config.kpiConfig.dataConfig.commonConfig;
|
|
356
|
+
const titleTemplate = config['title'];
|
|
357
|
+
const hasParams = /\$P\{.*?\}/.test(titleTemplate);
|
|
358
|
+
if (!hasParams) {
|
|
359
|
+
const title_params = data[config['dataField']];
|
|
360
|
+
return titleTemplate + (title_params ?? '');
|
|
313
361
|
}
|
|
362
|
+
let result = titleTemplate.replace(/\$P\{(.*?)\}/g, (_, key) => {
|
|
363
|
+
return data[key] ?? '';
|
|
364
|
+
});
|
|
365
|
+
return result;
|
|
314
366
|
}
|
|
315
367
|
}
|
|
316
368
|
GammaHeatChartComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: GammaHeatChartComponent, deps: [{ token: i1.CommonService }], target: i0.ɵɵFactoryTarget.Component });
|
|
317
|
-
GammaHeatChartComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: GammaHeatChartComponent, selector: "app-gamma-heatmap", inputs: { rightClickEnable: "rightClickEnable", chartDataSource: "chartDataSource" }, outputs: { getTableConfigOutPut: "getTableConfigOutPut", oRowClick: "oRowClick", onrightClickContextSelection: "onrightClickContextSelection" }, ngImport: i0, template: "<div class=\"mx-2 bg-gray-800\">\n <app-loader *ngIf=\"isLoader\"></app-loader>\n <ng-container *ngIf=\"!isLoader\">\n <ng-container *ngIf=\"heatmapChartConfig.chartFormat == 'simple'\">\n <div class=\"p-3 h-auto overflow-x-auto\">\n <div class=\"inline-block\">\n <div class=\"flex flex-nowrap justify-center\">\n <div class=\"flex-shrink-0 w-
|
|
369
|
+
GammaHeatChartComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: GammaHeatChartComponent, selector: "app-gamma-heatmap", inputs: { rightClickEnable: "rightClickEnable", chartDataSource: "chartDataSource" }, outputs: { getTableConfigOutPut: "getTableConfigOutPut", oRowClick: "oRowClick", onrightClickContextSelection: "onrightClickContextSelection" }, ngImport: i0, template: "<div class=\"mx-2 bg-gray-800\">\n <app-loader *ngIf=\"isLoader\"></app-loader>\n <ng-container *ngIf=\"!isLoader\">\n <ng-container *ngIf=\"heatmapChartConfig.chartFormat == 'simple'\">\n <div class=\"p-3 h-auto overflow-x-auto\">\n <div class=\"inline-block\">\n <div class=\"flex flex-nowrap justify-center\">\n <div class=\"flex-shrink-0 w-48 h-10 flex items-center justify-center\"></div>\n <div *ngFor=\"let item of heatChartDataSource.argumentValue\"\n class=\"flex-shrink-0 min-w-22 max-w-[20%] h-8 text-sm flex items-center justify-center\">\n {{item}}\n </div>\n </div>\n </div>\n <ng-container *ngFor=\"let item of heatChartDataSource.dataSet\">\n <div class=\"flex flex-row\">\n <div class=\"h-8 flex text-sm items-center min-w-48 justify-end px-2 inline\">\n {{ item.datasource }}\n </div>\n <div class=\"inline-block\">\n <div class=\"flex flex-nowrap justify-start\">\n <ng-container *ngFor=\"let box of item.dataset\">\n <div (click)=\"onRowClick(box)\" class=\"flex-shrink-0 min-w-22 max-w-[20%] h-8 border-2 text-sm cursor-pointer flex items-center justify-center text-gray-800\"\n [ngStyle]=\"{ 'background-color': box.color }\" [matTooltip]=\"box.toolTip\"\n matTooltipClass=\"custom-tooltip\">\n {{ callServiceFunction(box) }}\n </div>\n </ng-container>\n </div>\n </div>\n </div>\n </ng-container>\n </div>\n </ng-container>\n <ng-container *ngIf=\"heatmapChartConfig.chartFormat == 'topx'\">\n <div class=\"p-3 h-auto overflow-x-auto\">\n <div class=\"flex flex-row\">\n <ng-container *ngFor=\"let header of heatChartDataSource.argumentValue\">\n <div class=\"min-w-32 text-sm font-medium text-center mb-2\">\n {{ header }}\n </div>\n </ng-container>\n </div>\n\n <div *ngFor=\"let row of heatChartDataSource.dataSet\" class=\"flex flex-row\">\n <ng-container *ngFor=\"let cell of row\">\n <div *ngIf=\"cell.box\" (click)=\"onRowClick(cell.box)\"\n class=\"h-8 border-2 text-sm cursor-pointer flex items-center justify-center text-gray-800 min-w-32 cursor-pointer\"\n [ngStyle]=\"{ 'background-color': cell.box.color }\" [matTooltip]=\"cell.box.toolTip\"\n matTooltipClass=\"custom-tooltip\">\n {{ cell.box[heatmapChartConfig.leftArgument] }}\n ({{callServiceFunction(cell.box) }})\n </div>\n <div *ngIf=\"!cell.box\" class=\"h-8 min-w-32\"></div>\n </ng-container>\n </div>\n </div>\n </ng-container>\n </ng-container>\n</div>", dependencies: [{ 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: "directive", type: i3.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i4.LoaderComponent, selector: "app-loader" }] });
|
|
318
370
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: GammaHeatChartComponent, decorators: [{
|
|
319
371
|
type: Component,
|
|
320
|
-
args: [{ selector: 'app-gamma-heatmap', template: "<div class=\"mx-2 bg-gray-800\">\n <app-loader *ngIf=\"isLoader\"></app-loader>\n <ng-container *ngIf=\"!isLoader\">\n <ng-container *ngIf=\"heatmapChartConfig.chartFormat == 'simple'\">\n <div class=\"p-3 h-auto overflow-x-auto\">\n <div class=\"inline-block\">\n <div class=\"flex flex-nowrap justify-center\">\n <div class=\"flex-shrink-0 w-
|
|
372
|
+
args: [{ selector: 'app-gamma-heatmap', template: "<div class=\"mx-2 bg-gray-800\">\n <app-loader *ngIf=\"isLoader\"></app-loader>\n <ng-container *ngIf=\"!isLoader\">\n <ng-container *ngIf=\"heatmapChartConfig.chartFormat == 'simple'\">\n <div class=\"p-3 h-auto overflow-x-auto\">\n <div class=\"inline-block\">\n <div class=\"flex flex-nowrap justify-center\">\n <div class=\"flex-shrink-0 w-48 h-10 flex items-center justify-center\"></div>\n <div *ngFor=\"let item of heatChartDataSource.argumentValue\"\n class=\"flex-shrink-0 min-w-22 max-w-[20%] h-8 text-sm flex items-center justify-center\">\n {{item}}\n </div>\n </div>\n </div>\n <ng-container *ngFor=\"let item of heatChartDataSource.dataSet\">\n <div class=\"flex flex-row\">\n <div class=\"h-8 flex text-sm items-center min-w-48 justify-end px-2 inline\">\n {{ item.datasource }}\n </div>\n <div class=\"inline-block\">\n <div class=\"flex flex-nowrap justify-start\">\n <ng-container *ngFor=\"let box of item.dataset\">\n <div (click)=\"onRowClick(box)\" class=\"flex-shrink-0 min-w-22 max-w-[20%] h-8 border-2 text-sm cursor-pointer flex items-center justify-center text-gray-800\"\n [ngStyle]=\"{ 'background-color': box.color }\" [matTooltip]=\"box.toolTip\"\n matTooltipClass=\"custom-tooltip\">\n {{ callServiceFunction(box) }}\n </div>\n </ng-container>\n </div>\n </div>\n </div>\n </ng-container>\n </div>\n </ng-container>\n <ng-container *ngIf=\"heatmapChartConfig.chartFormat == 'topx'\">\n <div class=\"p-3 h-auto overflow-x-auto\">\n <div class=\"flex flex-row\">\n <ng-container *ngFor=\"let header of heatChartDataSource.argumentValue\">\n <div class=\"min-w-32 text-sm font-medium text-center mb-2\">\n {{ header }}\n </div>\n </ng-container>\n </div>\n\n <div *ngFor=\"let row of heatChartDataSource.dataSet\" class=\"flex flex-row\">\n <ng-container *ngFor=\"let cell of row\">\n <div *ngIf=\"cell.box\" (click)=\"onRowClick(cell.box)\"\n class=\"h-8 border-2 text-sm cursor-pointer flex items-center justify-center text-gray-800 min-w-32 cursor-pointer\"\n [ngStyle]=\"{ 'background-color': cell.box.color }\" [matTooltip]=\"cell.box.toolTip\"\n matTooltipClass=\"custom-tooltip\">\n {{ cell.box[heatmapChartConfig.leftArgument] }}\n ({{callServiceFunction(cell.box) }})\n </div>\n <div *ngIf=\"!cell.box\" class=\"h-8 min-w-32\"></div>\n </ng-container>\n </div>\n </div>\n </ng-container>\n </ng-container>\n</div>" }]
|
|
321
373
|
}], ctorParameters: function () { return [{ type: i1.CommonService }]; }, propDecorators: { getTableConfigOutPut: [{
|
|
322
374
|
type: Output
|
|
323
375
|
}], oRowClick: [{
|
|
@@ -330,4 +382,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
330
382
|
type: Input,
|
|
331
383
|
args: ['chartDataSource']
|
|
332
384
|
}] } });
|
|
333
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gamma-heatmap.component.js","sourceRoot":"","sources":["../../../../../../../projects/gamma-app-controller/src/lib/shared/advanced-component/gamma-heatmap/gamma-heatmap.component.ts","../../../../../../../projects/gamma-app-controller/src/lib/shared/advanced-component/gamma-heatmap/gamma-heatmap.component.html"],"names":[],"mappings":"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","sourcesContent":["\n\n\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport moment from '../../../application-controller/moment-helper';\nimport { CommonService } from '../../../application-controller/common';\n\n@Component({\n  selector: 'app-gamma-heatmap',\n  templateUrl: './gamma-heatmap.component.html',\n})\nexport class GammaHeatChartComponent implements OnInit {\n isJsonPreview: boolean\n  dataSourseForTable: any = [];\n  jsaonDatasource: any;\n  configColume: any;\n  isLoader: boolean = true;\n  tableDataConfig: any = {};\n  enrichNameList = [\"formatBytes\", \"formatBytsToKb\", \"formatBytsToGb\", \"reformatNumberWithThousandSeparatorV3\", \"formatBytesv2\"]\n  page_config: any;\n  page_parms: any;\n  page_selected_operator: any;\n  activeTab: string = 'basic';\n\n  tableHeight: any;\n\n\n  isAdvanceFilter: boolean = false;\n  isHeatMapClick: boolean = false;\n\n  heatChartDataSource: any = {};\n  chartDataForTooltip: any = {};\n\n\n\n  dataSourseForHeatMap: any = [];\n  selectedViewConfigs: any;\n\n  viewProperties: any = {\n    enableClickEvent: false,\n    enableRightClickEvent: true,\n    clickEventOptions: {\n      associatedViews: [],\n      eventType: \"\"\n    }\n  };\n  optionalDrilDownDataSource: any = [];\n  selectedTableViewType: any;\n\n  allConfiguredViews: any = [];\n  colorArray: any = [];\n  firstColor = \"rgba(45, 110, 18, 1)\";\n  secondColor = \"rgba(255, 204, 0, 1)\";\n  singleColor = \"rgba(255, 204, 0, 1)\";\n\n  heatmapChartConfig: any = {};\n  @Output() public getTableConfigOutPut: EventEmitter<any> = new EventEmitter();\n  @Output() public oRowClick: EventEmitter<any> = new EventEmitter();\n  @Output() public onrightClickContextSelection: EventEmitter<any> = new EventEmitter();\n  @Input() rightClickEnable: boolean = true;\n\n  @Input('chartDataSource')\n  set chartDataSource(value) {\n    if (value === undefined || value.length === 0) {\n      return;\n    } else {\n      this.isLoader = true;\n      this.page_config = value;\n      this.page_parms = value.titleParams;\n      if (value.kpiConfig.dataSource && value.kpiConfig.dataSource.length !== 0) {\n        this.heatmapChartConfig = value.kpiConfig.dataConfig;\n        this.colorArray = value.kpiConfig.dataConfig.color;\n        this.getHeatmapData(value.kpiConfig.dataSource);\n        setTimeout(() => {\n          this.isLoader = false;\n        }, 200);\n      } else {\n        setTimeout(() => {\n          this.dataSourseForTable = [];\n          this.tableDataConfig['columns'] = [];\n          this.isLoader = false;\n        }, 200);\n      }\n    }\n  }\n\n  constructor(public commonService: CommonService) { }\n\n  ngOnInit(): void {\n  }\n\n  getHeatmapData(heatMapData) {\n    this.heatChartDataSource = {};\n    this.isAdvanceFilter = false;\n    if (heatMapData && heatMapData.length !== 0) {\n      if (this.heatmapChartConfig.chartFormat == \"topx\") {\n        const { result, uniqueDates } = this.generateDateWiseColorCodedData(heatMapData);\n        // uniqueDates.sort();\n        this.heatChartDataSource.dataSet = this.getTransposedHeatmapData(result);\n        this.heatChartDataSource[\"argumentValue\"] = uniqueDates;\n      } else if ((this.heatmapChartConfig.chartFormat == \"simple\")) {\n        const { result, uniqueDates } = this.generateData(heatMapData);\n        // uniqueDates.sort();\n        this.heatChartDataSource[\"dataSet\"] = result;\n        this.heatChartDataSource[\"argumentValue\"] = uniqueDates;\n      }\n\n      this.isHeatMapClick = false;\n    } else {\n      this.isHeatMapClick = false;\n    }\n\n    // this.heatChartDataSource = {};\n    // this.isAdvanceFilter = false;\n\n    // if (heatMapData && heatMapData.length !== 0) {\n    //   const { result, uniqueDates } = this.generateData(heatMapData)\n    //   uniqueDates.sort();\n    //   this.heatChartDataSource[\"dataSet\"] = result;\n    //   this.heatChartDataSource[\"argumentValue\"] = uniqueDates;\n    //   this.isHeatMapClick = false;\n    // } else {\n    //   this.isHeatMapClick = false;\n    // }\n\n\n  }\n\n  getTransposedHeatmapData(dataSet: any[]): any[] {\n    const transposed: any[] = [];\n    const maxBoxes = Math.max(...dataSet.map(item => item.dataset.length));\n\n    for (let i = 0; i < maxBoxes; i++) {\n      const row: any[] = [];\n      for (let j = 0; j < dataSet.length; j++) {\n        const box = dataSet[j].dataset[i];\n        row.push({\n          box: box || null,\n          date: dataSet[j].record_date\n        });\n      }\n      transposed.push(row);\n    }\n\n    return transposed;\n  }\n\n  generateDateWiseColorCodedData(data: any[]) {\n    const result: any[] = [];\n    const uniqueDates = new Set();\n    const allEntries: any[] = [];\n\n    const topArg = this.heatmapChartConfig.topArgument;\n    const leftArg = this.heatmapChartConfig.leftArgument;\n    const valueField = this.heatmapChartConfig.columns[0].dataField;\n\n    data.forEach(entry => {\n      const formattedDate = (moment(entry[topArg]).format('YYYY-MM-DD')) ? moment(entry[topArg]).format('YYYY-MM-DD') : topArg;\n      uniqueDates.add(formattedDate);\n\n      entry.resultDataset.forEach(item => {\n        allEntries.push({\n          [topArg]: formattedDate,\n          [leftArg]: item[`${leftArg}`],\n          [valueField]: item[`${valueField}`]\n        });\n      });\n    });\n\n    let coloredData;\n    if (this.heatmapChartConfig.type === 'gradient') {\n      coloredData = this.getFormateDataByColorCodeForGradient(allEntries, valueField);\n    } else if (this.heatmapChartConfig.type === 'twoColor') {\n      coloredData = this.getFormateDataByColorCodeForWithTwoColor(allEntries, valueField);\n    } else {\n      coloredData = this.getFormateDataByColorCodeForWithSingleColor(allEntries, valueField);\n    }\n\n    const dateMap: { [date: string]: any[] } = {};\n\n    coloredData.forEach(item => {\n      const date: any = item[topArg];\n\n      if (!dateMap[date]) {\n        dateMap[date] = [];\n      }\n      let toolTip = `Record Date : ${item[topArg]} \\n${this.commonService.convertString(valueField)} : ${this.commonService.ThousandSeparatorWithTwoDecimals(item[valueField])}`\n      dateMap[date].push({\n        [leftArg]: item[leftArg],\n        [valueField]: item[valueField],\n        color: item.color,\n        toolTip: toolTip,\n        [topArg]: date,\n      });\n    });\n    \n    const sortedDates = Array.from(uniqueDates).sort((a, b) => moment(b).diff(moment(a)));\n\n    for (const date of sortedDates as string[]) {\n      result.push({\n        record_date: date,\n        dataset: dateMap[date] || []\n      });\n    }\n\n    return {\n      result,\n      uniqueDates: sortedDates\n    };\n  }\n\n  generateData(data) {\n    const result = [];\n    const uniqueDates = new Set();\n    const dataSourceMap = {};\n    const topArg = this.heatmapChartConfig.topArgument;\n    const leftArg = this.heatmapChartConfig.leftArgument;\n    const valueField = this.heatmapChartConfig.columns[0].dataField;\n\n    data.forEach(item => {\n      const rowKey = item[leftArg];\n      const columnKey = moment(item[topArg]).format('YYYY-MM-DD');\n\n      if (!dataSourceMap[rowKey]) {\n        dataSourceMap[rowKey] = {\n          datasource: rowKey,\n          dataset: []\n        };\n      }\n      let toolTip = `${this.commonService.convertString(leftArg)} : ${item[leftArg]} \\nRecord Date : ${columnKey} \\n${this.commonService.convertString(valueField)} : ${this.commonService.ThousandSeparatorWithTwoDecimals(item[valueField])}`\n\n      dataSourceMap[rowKey].dataset.push({\n        ...item,\n         toolTip: toolTip,\n        [topArg]: columnKey,\n\n      });\n\n      uniqueDates.add(columnKey);\n    });\n\n    const uniqueDatesArray = Array.from(uniqueDates);\n\n    for (const key in dataSourceMap) {\n      const dataset = dataSourceMap[key].dataset;\n      let formattedDataset;\n\n      if (this.heatmapChartConfig.type == \"gradient\") {\n        formattedDataset = this.getFormateDataByColorCodeForGradient(dataset, this.heatmapChartConfig.columns[0].dataField);\n      } else if (this.heatmapChartConfig.type == \"twoColor\") {\n        formattedDataset = this.getFormateDataByColorCodeForWithTwoColor(dataset, this.heatmapChartConfig.columns[0].dataField);\n      } else {\n        formattedDataset = this.getFormateDataByColorCodeForWithSingleColor(dataset, this.heatmapChartConfig.columns[0].dataField);\n\n      }\n\n      const dateToItemMap = {};\n      formattedDataset.forEach(item => {\n        dateToItemMap[item[topArg]] = item;\n      });\n\n      const completeDataset = uniqueDatesArray.map((date: any) => {\n        if (dateToItemMap[date]) {\n          return dateToItemMap[date];\n        } else {\n          return {\n            [topArg]: date,\n            avgSize: \"No Data\",\n            fileCount: 0,\n            fileSize: 0,\n            color: \"rgb(242, 118, 109)\"\n          };\n        }\n      });\n\n      result.push({\n        datasource: key,\n        dataset: completeDataset\n      });\n    }\n\n    return {\n      result: result,\n      uniqueDates: uniqueDatesArray\n    };\n  }\n\n\n\n  getFormateDataByColorCodeForGradient(filedata, column) {\n    filedata.forEach(item => {\n      item.avgSize = parseFloat(item[column]);\n    });\n\n    const maxAvgSize = Math.max(...filedata.map(item => item[column]));\n    const minAvgSize = Math.min(...filedata.map(item => item[column]));\n\n    const [minColorStr, maxColorStr] = this.colorArray || [\"rgba(45, 110, 18,1)\", \"rgba(255, 204, 0,1)\"];\n    const minColor = this.parseRGBA(minColorStr);\n    const maxColor = this.parseRGBA(maxColorStr);\n\n    filedata.forEach(item => {\n      item.color = this.calculateColor(item[column], minAvgSize, maxAvgSize, minColor, maxColor);\n    });\n\n    return filedata;\n  }\n  getFormateDataByColorCodeForWithTwoColor(filedata, column) {\n    filedata.forEach(item => {\n      item[column] = parseFloat(item[column]);\n    });\n\n    const [minColorStr, maxColorStr] = this.colorArray || [\"rgba(45, 110, 18,1)\", \"rgba(255, 204, 0,1)\"];\n    const minColor = this.parseRGBA(minColorStr);\n    const maxColor = this.parseRGBA(maxColorStr);\n\n    filedata.forEach(item => {\n      if (item[column] == 0) {\n        item.color = `rgb(${minColor.join(',')})`;\n      } else {\n        item.color = `rgb(${maxColor.join(',')})`;\n      }\n\n    });\n\n    return filedata;\n  }\n  getFormateDataByColorCodeForWithSingleColor(filedata, column) {\n    filedata.forEach(item => {\n      item[column] = parseFloat(item[column]);\n    });\n\n    const [singleColor] = this.colorArray || [\"rgba(255, 204, 0,1)\"];\n    const minColor = this.parseRGBA(singleColor);\n\n    filedata.forEach(item => {\n      item.color = `rgb(${minColor.join(',')})`;\n    });\n\n    return filedata;\n  }\n\n  parseRGBA(colorStr: string): number[] {\n    const values = colorStr.match(/[\\d.]+/g)?.map(Number) || [];\n    if (values.length === 3) values.push(1);\n    return [\n      values[0] ?? 0,\n      values[1] ?? 0,\n      values[2] ?? 0,\n      values[3] ?? 1\n    ];\n  }\n\n  calculateColor(avgSize, minAvgSize, maxAvgSize, minColor, maxColor) {\n    if (minAvgSize != maxAvgSize) {\n      let gradient = (avgSize - minAvgSize) / (maxAvgSize - minAvgSize);\n      let color = minColor.map((channel, index) => {\n        return Math.round(channel + gradient * (maxColor[index] - channel));\n      });\n      return `rgb(${color.join(',')})`;\n    } else {\n      return `rgb(${minColor.join(',')})`\n    }\n\n  }\n\n\n\n  transformColumns(mainobj: any): any[] {\n    return Object.keys(mainobj).map(key => {\n      return {\n        visible: true,\n        dataField: key,\n        caption: key\n      };\n    });\n  }\n\n\n\n  getObjectKeys(obj: any): string[] {\n    return Object.keys(obj);\n  }\n\n\n  callServiceFunction(functionName: string, value): any {\n\n    if (value !== undefined) {\n      if (typeof this.commonService[functionName] === \"function\") {\n        return this.commonService[functionName](value);\n      } else {\n        console.error(`Function ${functionName} not found in CommonService`);\n        return null;\n      }\n    } else {\n      return \"No Data\"\n    }\n\n  }\n\n\n}\n","<div class=\"mx-2 bg-gray-800\">\n    <app-loader *ngIf=\"isLoader\"></app-loader>\n    <ng-container *ngIf=\"!isLoader\">\n        <ng-container *ngIf=\"heatmapChartConfig.chartFormat == 'simple'\">\n            <div class=\"p-3 h-auto overflow-x-auto\">\n                <div class=\"inline-block\">\n                    <div class=\"flex flex-nowrap justify-center\">\n                        <div class=\"flex-shrink-0 w-22 max-w-[20%] h-10 flex items-center justify-center\"></div>\n                        <div *ngFor=\"let item of heatChartDataSource.argumentValue\"\n                            class=\"flex-shrink-0 min-w-22 max-w-[20%] h-8 text-sm flex items-center justify-center\">\n                            {{item}}\n                        </div>\n                    </div>\n                </div>\n                <ng-container *ngFor=\"let item of heatChartDataSource.dataSet\">\n                    <div class=\"flex flex-row\">\n                        <div class=\"h-8 flex text-sm items-center min-w-22 justify-end px-2 inline\">\n                            {{ item.datasource }}\n                        </div>\n                        <div class=\"inline-block\">\n                            <div class=\"flex flex-nowrap justify-start\">\n                                <ng-container *ngFor=\"let box of item.dataset\">\n                                    <div class=\"flex-shrink-0 min-w-22 max-w-[20%] h-8 border-2 text-sm cursor-pointer flex items-center justify-center text-gray-800\"\n                                        [ngStyle]=\"{ 'background-color': box.color }\" [matTooltip]=\"box.toolTip\"\n                                        matTooltipClass=\"custom-tooltip\">\n                                        {{ callServiceFunction(heatmapChartConfig.columns[0].enrichName,\n                                        box[heatmapChartConfig.columns[0].dataField]) }}\n                                    </div>\n                                </ng-container>\n                            </div>\n                        </div>\n                    </div>\n                </ng-container>\n            </div>\n        </ng-container>\n        <ng-container *ngIf=\"heatmapChartConfig.chartFormat == 'topx'\">\n            <div class=\"p-3 h-auto overflow-x-auto\">\n                <div class=\"flex flex-row\">\n                    <ng-container *ngFor=\"let header of heatChartDataSource.argumentValue\">\n                        <div class=\"min-w-32 text-sm font-medium text-center mb-2\">\n                            {{ header }}\n                        </div>\n                    </ng-container>\n                </div>\n\n                <div *ngFor=\"let row of heatChartDataSource.dataSet\" class=\"flex flex-row\">\n                    <ng-container *ngFor=\"let cell of row\">\n                        <div *ngIf=\"cell.box\"\n                            class=\"h-8 border-2 text-sm cursor-pointer flex items-center justify-center text-gray-800 min-w-32 cursor-pointer\"\n                            [ngStyle]=\"{ 'background-color': cell.box.color }\" [matTooltip]=\"cell.box.toolTip\"\n                            matTooltipClass=\"custom-tooltip\">\n                            {{ cell.box[heatmapChartConfig.leftArgument] }} ({{\n                            callServiceFunction(heatmapChartConfig.columns[0].enrichName,\n                            cell.box[heatmapChartConfig.columns[0].dataField]) }})\n                        </div>\n                        <div *ngIf=\"!cell.box\" class=\"h-8 min-w-32\"></div>\n                    </ng-container>\n                </div>\n            </div>\n        </ng-container>\n    </ng-container>\n</div>"]}
|
|
385
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gamma-heatmap.component.js","sourceRoot":"","sources":["../../../../../../../projects/gamma-app-controller/src/lib/shared/advanced-component/gamma-heatmap/gamma-heatmap.component.ts","../../../../../../../projects/gamma-app-controller/src/lib/shared/advanced-component/gamma-heatmap/gamma-heatmap.component.html"],"names":[],"mappings":"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","sourcesContent":["\n\n\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport moment from '../../../application-controller/moment-helper';\nimport { CommonService } from '../../../application-controller/common';\n\n@Component({\n  selector: 'app-gamma-heatmap',\n  templateUrl: './gamma-heatmap.component.html',\n})\nexport class GammaHeatChartComponent implements OnInit {\n  isJsonPreview: boolean\n  dataSourseForTable: any = [];\n  jsaonDatasource: any;\n  configColume: any;\n  isLoader: boolean = true;\n  tableDataConfig: any = {};\n  enrichNameList = [\"formatBytes\", \"formatBytsToKb\", \"formatBytsToGb\", \"reformatNumberWithThousandSeparatorV3\", \"formatBytesv2\"]\n  page_config: any;\n  page_parms: any;\n  page_selected_operator: any;\n  activeTab: string = 'basic';\n\n  tableHeight: any;\n\n\n  isAdvanceFilter: boolean = false;\n  isHeatMapClick: boolean = false;\n\n  heatChartDataSource: any = {};\n  chartDataForTooltip: any = {};\n\n\n\n  dataSourseForHeatMap: any = [];\n  selectedViewConfigs: any;\n\n  viewProperties: any = {\n    enableClickEvent: false,\n    enableRightClickEvent: true,\n    clickEventOptions: {\n      associatedViews: [],\n      eventType: \"\"\n    }\n  };\n  optionalDrilDownDataSource: any = [];\n  selectedTableViewType: any;\n\n  allConfiguredViews: any = [];\n  colorArray: any = [];\n  firstColor = \"rgba(45, 110, 18, 1)\";\n  secondColor = \"rgba(255, 204, 0, 1)\";\n  singleColor = \"rgba(255, 204, 0, 1)\";\n\n  heatmapChartConfig: any = {};\n  @Output() public getTableConfigOutPut: EventEmitter<any> = new EventEmitter();\n  @Output() public oRowClick: EventEmitter<any> = new EventEmitter();\n  @Output() public onrightClickContextSelection: EventEmitter<any> = new EventEmitter();\n  @Input() rightClickEnable: boolean = true;\n\n  @Input('chartDataSource')\n  set chartDataSource(value) {\n    \n    if (value === undefined || value.length === 0) {\n      return;\n    } else {\n      this.isLoader = true;\n      this.page_config = value;\n      if (value.kpiConfig.dataSource && value.kpiConfig.dataSource.length !== 0) {\n        this.heatmapChartConfig = value.kpiConfig.dataConfig;\n        this.colorArray = value.kpiConfig.dataConfig.color;\n        this.getHeatmapData(value.kpiConfig.dataSource);\n        setTimeout(() => {\n          this.isLoader = false;\n        }, 200);\n      } else {\n        setTimeout(() => {\n          this.dataSourseForTable = [];\n          this.tableDataConfig['columns'] = [];\n          this.isLoader = true;\n        }, 200);\n      }\n    }\n  }\n\n  constructor(public commonService: CommonService) { }\n\n  ngOnInit(): void {\n  }\n\n  getHeatmapData(heatMapData) {\n    this.heatChartDataSource = {};\n    this.isAdvanceFilter = false;\n    if (heatMapData && heatMapData.length !== 0) {\n      if (this.heatmapChartConfig.chartFormat == \"topx\") {\n        const { result, uniqueDates } = this.generateDateWiseColorCodedData(heatMapData);\n        // uniqueDates.sort();\n        this.heatChartDataSource.dataSet = this.getTransposedHeatmapData(result);\n        \n        this.heatChartDataSource[\"argumentValue\"] = uniqueDates;\n      } else if ((this.heatmapChartConfig.chartFormat == \"simple\")) {\n        const { result, uniqueDates } = this.generateData(heatMapData);\n        // uniqueDates.sort();\n        this.heatChartDataSource[\"dataSet\"] = result;\n        this.heatChartDataSource[\"argumentValue\"] = uniqueDates;\n      }\n\n      this.isHeatMapClick = false;\n    } else {\n      this.isHeatMapClick = false;\n    }\n\n    // this.heatChartDataSource = {};\n    // this.isAdvanceFilter = false;\n\n    // if (heatMapData && heatMapData.length !== 0) {\n    //   const { result, uniqueDates } = this.generateData(heatMapData)\n    //   uniqueDates.sort();\n    //   this.heatChartDataSource[\"dataSet\"] = result;\n    //   this.heatChartDataSource[\"argumentValue\"] = uniqueDates;\n    //   this.isHeatMapClick = false;\n    // } else {\n    //   this.isHeatMapClick = false;\n    // }\n\n\n  }\n\n  getTransposedHeatmapData(dataSet: any[]): any[] {\n    const transposed: any[] = [];\n    const maxBoxes = Math.max(...dataSet.map(item => item.dataset.length));\n\n    for (let i = 0; i < maxBoxes; i++) {\n      const row: any[] = [];\n      for (let j = 0; j < dataSet.length; j++) {\n        const box = dataSet[j].dataset[i];\n        row.push({\n          box: box || null,\n          date: dataSet[j].record_date\n        });\n      }\n      transposed.push(row);\n    }\n\n    return transposed;\n  }\n\n  generateDateWiseColorCodedData(data: any[]) {\n    const result: any[] = [];\n    const uniqueDates = new Set();\n    const allEntries: any[] = [];\n\n    const topArg = this.heatmapChartConfig.topArgument;\n    const leftArg = this.heatmapChartConfig.leftArgument;\n    const mapColumn = this.heatmapChartConfig.columns.filter(col => col.displayFor === 'map' && col.visible);\n    const tooltipColumns = this.heatmapChartConfig.columns.filter(col => col.displayFor === 'tooltip' && col.visible);\n\n    const valueField = mapColumn.length > 0 ? mapColumn[0].dataField : null;\n\n    data.forEach(entry => {\n      const formattedDate = (moment(entry[topArg]).format('YYYY-MM-DD')) ? moment(entry[topArg]).format('YYYY-MM-DD') : topArg;\n      uniqueDates.add(formattedDate);\n\n      entry.resultDataset.forEach(item => {\n        allEntries.push({\n          [topArg]: formattedDate,\n          [leftArg]: item[`${leftArg}`],\n          [valueField]: item[`${valueField}`]\n        });\n      });\n    });\n\n    let coloredData;\n    if (this.heatmapChartConfig.type === 'gradient') {\n      coloredData = this.getFormateDataByColorCodeForGradient(allEntries, valueField);\n    } else if (this.heatmapChartConfig.type === 'twoColor') {\n      coloredData = this.getFormateDataByColorCodeForWithTwoColor(allEntries, valueField);\n    } else {\n      coloredData = this.getFormateDataByColorCodeForWithSingleColor(allEntries, valueField);\n    }\n\n    const dateMap: { [date: string]: any[] } = {};\n\n    coloredData.forEach(item => {\n      const date: any = item[topArg];\n\n      if (!dateMap[date]) {\n        dateMap[date] = [];\n      }\n      let toolTip = '';\n\n      if (valueField) {\n        toolTip += `${this.commonService.convertString(valueField)} : ${item[valueField]}\\n`;\n      }\n      tooltipColumns.forEach(col => {\n        const value = item[col.dataField];\n\n        toolTip += `${col.caption} : ${value}\\n`;\n      });\n\n      dateMap[date].push({\n        [leftArg]: item[leftArg],\n        [valueField]: item[valueField],\n        color: item.color,\n        toolTip: toolTip,\n        [topArg]: date,\n      });\n    });\n\n    const sortedDates = Array.from(uniqueDates).sort((a, b) => moment(b).diff(moment(a)));\n\n    for (const date of sortedDates as string[]) {\n      result.push({\n        record_date: date,\n        dataset: dateMap[date] || []\n      });\n    }\n\n    return {\n      result,\n      uniqueDates: sortedDates\n    };\n  }\n\n  generateData(data) {\n    const result = [];\n    const uniqueDates = new Set();\n    const dataSourceMap = {};\n    const topArg = this.heatmapChartConfig.topArgument;\n    const leftArg = this.heatmapChartConfig.leftArgument;\n\n    const mapColumn = this.heatmapChartConfig.columns.filter(col => col.displayFor === 'map' && col.visible);\n    const tooltipColumns = this.heatmapChartConfig.columns.filter(col => col.displayFor === 'tooltip' && col.visible);\n\n    const valueField = mapColumn.length > 0 ? mapColumn[0].dataField : null;\n\n    data.forEach(item => {\n      const rowKey = item[leftArg];\n      const columnKey = moment(item[topArg]).format('YYYY-MM-DD');\n\n      if (!dataSourceMap[rowKey]) {\n        dataSourceMap[rowKey] = {\n          datasource: rowKey,\n          dataset: []\n        };\n      }\n\n      let toolTip = '';\n\n      if (valueField) {\n        toolTip += `${this.commonService.convertString(valueField)} : ${item[valueField]} | `;\n      }\n      tooltipColumns.forEach(col => {\n        const value = item[col.dataField];\n\n        toolTip += `${col.caption} : ${value} | `;\n      });\n\n      dataSourceMap[rowKey].dataset.push({\n        ...item,\n        toolTip: toolTip,\n        [topArg]: columnKey,\n\n      });\n\n      uniqueDates.add(columnKey);\n    });\n\n    const uniqueDatesArray = Array.from(uniqueDates);\n\n    for (const key in dataSourceMap) {\n      const dataset = dataSourceMap[key].dataset;\n      let formattedDataset;\n\n      if (this.heatmapChartConfig.type == \"gradient\") {\n        formattedDataset = this.getFormateDataByColorCodeForGradient(dataset, this.heatmapChartConfig.columns[0].dataField);\n      } else if (this.heatmapChartConfig.type == \"twoColor\") {\n        formattedDataset = this.getFormateDataByColorCodeForWithTwoColor(dataset, this.heatmapChartConfig.columns[0].dataField);\n      } else {\n        formattedDataset = this.getFormateDataByColorCodeForWithSingleColor(dataset, this.heatmapChartConfig.columns[0].dataField);\n\n      }\n\n      const dateToItemMap = {};\n      formattedDataset.forEach(item => {\n        dateToItemMap[item[topArg]] = item;\n      });\n\n      const completeDataset = uniqueDatesArray.map((date: any) => {\n        if (dateToItemMap[date]) {\n          return dateToItemMap[date];\n        } else {\n          return {\n            [topArg]: date,\n            avgSize: \"No Data\",\n            fileCount: 0,\n            fileSize: 0,\n            color: \"rgb(242, 118, 109)\"\n          };\n        }\n      });\n\n      result.push({\n        datasource: key,\n        dataset: completeDataset\n      });\n    }\n\n    return {\n      result: result,\n      uniqueDates: uniqueDatesArray\n    };\n  }\n\n\n\n  getFormateDataByColorCodeForGradient(filedata, column) {\n    filedata.forEach(item => {\n      item.avgSize = parseFloat(item[column]);\n    });\n\n    const maxAvgSize = Math.max(...filedata.map(item => item[column]));\n    const minAvgSize = Math.min(...filedata.map(item => item[column]));\n\n    const [minColorStr, maxColorStr] = this.colorArray || [\"rgba(45, 110, 18,1)\", \"rgba(255, 204, 0,1)\"];\n    const minColor = this.parseRGBA(minColorStr);\n    const maxColor = this.parseRGBA(maxColorStr);\n\n    filedata.forEach(item => {\n      item.color = this.calculateColor(item[column], minAvgSize, maxAvgSize, minColor, maxColor);\n    });\n\n    return filedata;\n  }\n  getFormateDataByColorCodeForWithTwoColor(filedata, column) {\n    filedata.forEach(item => {\n      item[column] = parseFloat(item[column]);\n    });\n\n    const [minColorStr, maxColorStr] = this.colorArray || [\"rgba(45, 110, 18,1)\", \"rgba(255, 204, 0,1)\"];\n    const minColor = this.parseRGBA(minColorStr);\n    const maxColor = this.parseRGBA(maxColorStr);\n\n    filedata.forEach(item => {\n      if (item[column] == 0) {\n        item.color = `rgb(${minColor.join(',')})`;\n      } else {\n        item.color = `rgb(${maxColor.join(',')})`;\n      }\n\n    });\n\n    return filedata;\n  }\n  getFormateDataByColorCodeForWithSingleColor(filedata, column) {\n    filedata.forEach(item => {\n      item[column] = parseFloat(item[column]);\n    });\n\n    const [singleColor] = this.colorArray || [\"rgba(255, 204, 0,1)\"];\n    const minColor = this.parseRGBA(singleColor);\n\n    filedata.forEach(item => {\n      item.color = `rgb(${minColor.join(',')})`;\n    });\n\n    return filedata;\n  }\n\n  parseRGBA(colorStr: string): number[] {\n    const values = colorStr.match(/[\\d.]+/g)?.map(Number) || [];\n    if (values.length === 3) values.push(1);\n    return [\n      values[0] ?? 0,\n      values[1] ?? 0,\n      values[2] ?? 0,\n      values[3] ?? 1\n    ];\n  }\n\n  calculateColor(avgSize, minAvgSize, maxAvgSize, minColor, maxColor) {\n    if (minAvgSize != maxAvgSize) {\n      let gradient = (avgSize - minAvgSize) / (maxAvgSize - minAvgSize);\n      let color = minColor.map((channel, index) => {\n        return Math.round(channel + gradient * (maxColor[index] - channel));\n      });\n      return `rgb(${color.join(',')})`;\n    } else {\n      return `rgb(${minColor.join(',')})`\n    }\n\n  }\n\n\n\n  transformColumns(mainobj: any): any[] {\n    return Object.keys(mainobj).map(key => {\n      return {\n        visible: true,\n        dataField: key,\n        caption: key\n      };\n    });\n  }\n\n\n\n  getObjectKeys(obj: any): string[] {\n    return Object.keys(obj);\n  }\n\n\n  callServiceFunction(data): any {\n    const mapColumn = this.heatmapChartConfig.columns.find(col => col.displayFor === 'map' && col.visible);\n    const functionName = mapColumn ? mapColumn.enrichName : null;\n    const valueField = mapColumn ? mapColumn.dataField : null;\n\n    if (functionName != \"\") {\n      if (data[valueField] !== undefined) {\n        if (typeof this.commonService[functionName] === \"function\") {\n          return this.commonService[functionName](data[valueField]);\n        } else {\n          console.error(`Function ${functionName} not found in CommonService`);\n          return null;\n        }\n      } else {\n        return \"No Data\"\n      }\n    } else {\n      return data[valueField];\n    }\n\n\n  }\n\n\n  onRowClick(data) {\n    const title_params = data[this.page_config.kpiConfig.dataConfig.commonConfig['dataField']]\n    let title = this.getParamsTitle(data);\n    let obj = {\n      data: data,\n      keyToPass: this.page_config.kpiConfig.keyToPass,\n      tableTitle: (this.page_parms) ? this.page_parms + title : title,\n      viewId: this.page_config.viewId,\n      drillDownType: \"natural\",\n      drilldownFrom: this.page_config.viewId,\n      drilldownTo: \"\",\n    }\n    this.oRowClick.emit(obj);\n  }\n\n  getParamsTitle(data) {\n    \n    const config = this.page_config.kpiConfig.dataConfig.commonConfig;\n    const titleTemplate = config['title'];\n\n    // 🔎 Check if template contains $P{...}\n    const hasParams = /\\$P\\{.*?\\}/.test(titleTemplate);\n\n    // 🟢 CASE 1: No $P{} → use old logic\n    if (!hasParams) {\n      const title_params = data[config['dataField']];\n      return titleTemplate + (title_params ?? '');\n    }\n\n    // 🔵 CASE 2: Has $P{} → replace dynamically\n    let result = titleTemplate.replace(/\\$P\\{(.*?)\\}/g, (_, key) => {\n      return data[key] ?? '';\n    });\n\n    return result;\n  }\n\n\n}\n","<div class=\"mx-2 bg-gray-800\">\n    <app-loader *ngIf=\"isLoader\"></app-loader>\n    <ng-container *ngIf=\"!isLoader\">\n        <ng-container *ngIf=\"heatmapChartConfig.chartFormat == 'simple'\">\n            <div class=\"p-3 h-auto overflow-x-auto\">\n                <div class=\"inline-block\">\n                    <div class=\"flex flex-nowrap justify-center\">\n                        <div class=\"flex-shrink-0 w-48 h-10 flex items-center justify-center\"></div>\n                        <div *ngFor=\"let item of heatChartDataSource.argumentValue\"\n                            class=\"flex-shrink-0 min-w-22 max-w-[20%] h-8 text-sm flex items-center justify-center\">\n                            {{item}}\n                        </div>\n                    </div>\n                </div>\n                <ng-container *ngFor=\"let item of heatChartDataSource.dataSet\">\n                    <div class=\"flex flex-row\">\n                        <div class=\"h-8 flex text-sm items-center min-w-48 justify-end px-2 inline\">\n                            {{ item.datasource }}\n                        </div>\n                        <div class=\"inline-block\">\n                            <div class=\"flex flex-nowrap justify-start\">\n                                <ng-container *ngFor=\"let box of item.dataset\">\n                                    <div (click)=\"onRowClick(box)\" class=\"flex-shrink-0 min-w-22 max-w-[20%] h-8 border-2 text-sm cursor-pointer flex items-center justify-center text-gray-800\"\n                                        [ngStyle]=\"{ 'background-color': box.color }\" [matTooltip]=\"box.toolTip\"\n                                        matTooltipClass=\"custom-tooltip\">\n                                        {{ callServiceFunction(box) }}\n                                    </div>\n                                </ng-container>\n                            </div>\n                        </div>\n                    </div>\n                </ng-container>\n            </div>\n        </ng-container>\n        <ng-container *ngIf=\"heatmapChartConfig.chartFormat == 'topx'\">\n            <div class=\"p-3 h-auto overflow-x-auto\">\n                <div class=\"flex flex-row\">\n                    <ng-container *ngFor=\"let header of heatChartDataSource.argumentValue\">\n                        <div class=\"min-w-32 text-sm font-medium text-center mb-2\">\n                            {{ header }}\n                        </div>\n                    </ng-container>\n                </div>\n\n                <div *ngFor=\"let row of heatChartDataSource.dataSet\" class=\"flex flex-row\">\n                    <ng-container *ngFor=\"let cell of row\">\n                        <div *ngIf=\"cell.box\" (click)=\"onRowClick(cell.box)\"\n                            class=\"h-8 border-2 text-sm cursor-pointer flex items-center justify-center text-gray-800 min-w-32 cursor-pointer\"\n                            [ngStyle]=\"{ 'background-color': cell.box.color }\" [matTooltip]=\"cell.box.toolTip\"\n                            matTooltipClass=\"custom-tooltip\">\n                            {{ cell.box[heatmapChartConfig.leftArgument] }}\n                             ({{callServiceFunction(cell.box) }})\n                        </div>\n                        <div *ngIf=\"!cell.box\" class=\"h-8 min-w-32\"></div>\n                    </ng-container>\n                </div>\n            </div>\n        </ng-container>\n    </ng-container>\n</div>"]}
|