gamma-app-controller 1.2.17 → 1.2.18

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.
@@ -31,9 +31,9 @@ export class GammaAdvanceChartComponent {
31
31
  this.isFullScreen = false;
32
32
  this.onChartPointClick = new EventEmitter();
33
33
  this.customizeTooltip = (info) => ({
34
- html: `<table width=100% height=30 border=0 style=\'font-size: 13px\'>
35
- <tr><td style=\'text-align: left; color: white\'> ${this.commonService.convertToTitleCase(this.chartConfig.argumentField)} : ${info.argumentText} </td></tr>
36
- <tr><td style=\'text-align: left; color: white; padding-top: 5px\'> ${info.seriesName} :
34
+ html: `<table style = width=100% height=30 border=0 style=\'font-size: 13px\'>
35
+ <tr><td class="text-gray-800 dark:text-gray-200 " style=\'text-align: left\'> ${this.commonService.convertToTitleCase(this.chartConfig.argumentField)} : ${info.argumentText} </td></tr>
36
+ <tr><td class="text-gray-800 dark:text-gray-200 " style=\'text-align: left; padding-top: 5px\'> ${info.seriesName} :
37
37
  ${this.getValue(info.seriesName, info.value)} </td></tr>
38
38
  </table>`,
39
39
  });
@@ -409,4 +409,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
409
409
  type: Input,
410
410
  args: ['chartDataSource']
411
411
  }] } });
412
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gamma-advance-chart.component.js","sourceRoot":"","sources":["../../../../../../../projects/gamma-app-controller/src/lib/shared/advanced-component/gamma-advance-chart/gamma-advance-chart.component.ts","../../../../../../../projects/gamma-app-controller/src/lib/shared/advanced-component/gamma-advance-chart/gamma-advance-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["\nimport { AfterViewInit, ChangeDetectorRef, Component, ElementRef, EventEmitter, Inject, Input, OnInit, Output, Renderer2 } from '@angular/core';\nimport { ToastrService } from 'ngx-toastr';\nimport { kpicommonService } from '../../kpi-comon-service';\nimport moment from '../../../application-controller/moment-helper';\nimport { CommonService } from '../../../application-controller/common';\nimport { APP_ENVIRONMENT } from '../../../application-controller/environment';\n\n@Component({\n  selector: 'app-gamma-advance-chart',\n  templateUrl: './gamma-advance-chart.component.html',\n})\nexport class GammaAdvanceChartComponent implements OnInit {\n  chartConfig: any = {};\n   page_config: any = {};\n   isLoader: boolean = true;\n   @Input() componentId: any;\n   // @Input() caption: any;\n   @Input() kpi_name: any;\n   // @Input() chartDataSource:any;\n   caption: any;\n   isChartvisible: boolean;\n   creatChartDataSource = undefined;\n   finalChartDataSource: any = [];\n   chartHeight: any;\n \n   isFullScreen: boolean = false;\n \n   heatChartDataSource: any;\n   bubbleChartData: any;\n   constructor(\n     private commonService: CommonService,\n     private toastr: ToastrService,\n     private kpiService: kpicommonService,\n     private renderer: Renderer2, private el: ElementRef,\n     private cdr: ChangeDetectorRef,\n      @Inject(APP_ENVIRONMENT) private environment: any\n   ) {\n \n   }\n   page_parms: any;\n   // chart_attr.legend[0]\n   chartOrderBy: boolean;\n   chartDisplayDateFormat: any;\n   @Output() public onChartPointClick: EventEmitter<any> = new EventEmitter();\n \n   @Input('chartDataSource')\n   set chartDataSource(value) {\n     this.creatChartDataSource = value;\n     // console.log(value);\n     if (this.creatChartDataSource === undefined || this.creatChartDataSource.length === 0) {\n       this.isChartvisible = false;\n       return;\n     } else {\n \n       this.isLoader = true;\n       this.page_config = value;\n       this.page_parms = value.titleParams;\n       this.chartOrderBy = (value.kpiConfig.descendingOrder) ? value.kpiConfig.descendingOrder : false;\n       this.chartDisplayDateFormat = (value.kpiConfig.displayDateFormat) ? value.kpiConfig.displayDateFormat : \"MM-DD\";\n       if (value.kpiConfig.dataSource && value.kpiConfig.dataSource.length !== 0) {\n         this.chartConfig = value.kpiConfig.dataConfig;\n         if (value.kpiConfig.formate == \"daily\") {\n \n           const sortedData = value.kpiConfig.dataSource\n             .filter(record => record.recordDate)\n             .sort((a, b) => moment(b.recordDate).diff(moment(a.recordDate)));\n \n           const mostRecentRecord = sortedData[0];\n           const filteredObjects = sortedData.filter(data => data.recordDate === value.endDate);\n           if (this.chartConfig.chartType == 'funnel') {\n             this.finalChartDataSource = Object.keys(mostRecentRecord).filter(key => key !== 'recordDate').map(key => ({\n               argument: key,\n               value: Math.abs(parseInt(mostRecentRecord[key]))\n             }));\n             console.log(this.finalChartDataSource)\n           } else {\n \n             this.getDailyChart(filteredObjects, value.kpiConfig.dataConfig);\n \n           }\n \n           this.isLoader = false;\n         } else if (value.kpiConfig.formate == \"monthly\") {\n           if (value.kpiConfig.dataSource && value.kpiConfig.dataSource.length !== 0) {\n \n             if (this.chartConfig.chartType == 'bubble') {\n               this.bubbleChartData = value.kpiConfig.dataSource;\n               this.getBubbleChartData();\n             } else {\n               if (this.chartOrderBy) {\n                 let shortName = value.kpiConfig.dataConfig['argumentField'].toLowerCase();\n                 if (shortName.includes('date')) {\n                   value.kpiConfig.dataSource = value.kpiConfig.dataSource\n                     .filter(record => record[value.kpiConfig.dataConfig['argumentField']])\n                     .sort((a, b) => moment(b[value.kpiConfig.dataConfig['argumentField']]).diff(moment(a[value.kpiConfig.dataConfig['argumentField']])));\n \n                 }\n \n               }\n \n               this.getMonthlyChart(value.kpiConfig.dataSource, value.kpiConfig.dataConfig)\n               this.isChartvisible == true;\n             }\n \n           } else {\n             this.cdr.detectChanges();\n           }\n \n           this.isLoader = false;\n         } else if (value.kpiConfig.formate == \"hourly\") {\n           if (value.kpiConfig.dataSource && value.kpiConfig.dataSource.length !== 0) {\n             const sortedData = value.kpiConfig.dataSource\n               .filter(record => record.hour)\n               .sort((a, b) => moment(a.hour, 'hh').diff(moment(b.hour, 'hh')));\n             const mostRecentRecord = sortedData[0];\n             const filteredObjects = sortedData.filter(data => data.recordDate === mostRecentRecord.recordDate);\n \n             this.getHourChart(filteredObjects, value.kpiConfig.dataConfig)\n             this.isChartvisible == true;\n           } else {\n             this.cdr.detectChanges();\n           }\n \n           this.isLoader = false;\n         }\n \n       }\n       // else {\n       //   this.isLoader = false;\n       // }\n \n     }\n \n \n \n   }\n \n \n   ngOnInit(): void {\n \n   }\n \n   getHourChart(data, dataConfig) {\n     // const valueFields = dataConfig.chart_config.map(config => config.valueField);\n     if (data) {\n       data.forEach(val => {\n         if (val[dataConfig.argumentField].toString().length == 1) {\n           val[dataConfig.argumentField] = '0' + val[dataConfig.argumentField];\n         }\n         let label = val[dataConfig.argumentField].toString();\n         val[dataConfig.argumentField] = label\n       });\n       setTimeout(() => {\n         this.finalChartDataSource = data;\n       }, 500);\n     } else {\n       this.toastr.error(this.kpi_name + 'Chart Error');\n \n     }\n   }\n   getMonthlyChart(data, dataConfig) {\n     const valueFields = dataConfig.chart_config.map(config => config.valueField);\n     data.forEach((entry: any) => {\n       valueFields.forEach((field: any) => {\n         if (entry.hasOwnProperty(field)) {\n           if (typeof entry[field] === \"string\") {\n             entry[field] = Number(entry[field]);\n           }\n         }\n       });\n     });\n     if (data) {\n       let content = this.chartConfig.argumentField.toLowerCase();\n       if (content.includes('date')) {\n         const dataSource = data.map(obj => {\n           const newObj = { ...obj };\n           if (newObj.hasOwnProperty(this.chartConfig.argumentField)) {\n             newObj[this.chartConfig.argumentField] = moment(newObj[this.chartConfig.argumentField]).format(this.chartDisplayDateFormat);\n           }\n           return newObj;\n         });\n         this.finalChartDataSource = dataSource;\n       } else {\n         this.finalChartDataSource = data;\n       }\n     } else {\n       this.toastr.error(this.kpi_name + 'Chart Error');\n     }\n   }\n   getDailyChart(data, dataConfig) {\n     const valueFields = dataConfig.chart_config.map(config => config.valueField);\n     if (data) {\n       let content = this.chartConfig.argumentField.toLowerCase();\n       if (content.includes('date')) {\n         const dataSource = data.map(obj => {\n           const newObj = { ...obj };\n           if (newObj.hasOwnProperty(this.chartConfig.argumentField)) {\n             newObj[this.chartConfig.argumentField] = moment(newObj[this.chartConfig.argumentField]).format(this.chartDisplayDateFormat);\n           }\n           return newObj;\n         });\n         this.finalChartDataSource = dataSource;\n       } else {\n         this.finalChartDataSource = data;\n       }\n     } else {\n       this.toastr.error(this.kpi_name + ' Chart Error');\n     }\n   }\n \n \n   getReconDailyChart(data, dataConfig) {\n \n     this.finalChartDataSource = [];\n     const recon_key = dataConfig.reconKey;\n     const recon_column = dataConfig.reconColumns;\n     this.finalChartDataSource = this.getFinalData(data, recon_column);\n \n   }\n \n   getFinalData(mainData: any[], reconColumn: any[]): any[] {\n     mainData.forEach(data => {\n       reconColumn.forEach(column => {\n         const firstKeyValue = data[column.firstKey];\n         const secondKeyValue = data[column.secondKey];\n         const mouDiff = Math.abs(firstKeyValue - secondKeyValue);\n         data[column.finalKey] = mouDiff;\n       });\n     });\n \n     return mainData;\n   }\n \n   customizeTooltip = (info: any) => (\n     {\n \n       html: `<table width=100% height=30 border=0  style=\\'font-size: 13px\\'>\n     <tr><td style=\\'text-align: left; color: white\\'> ${this.commonService.convertToTitleCase(this.chartConfig.argumentField)} :  ${info.argumentText} </td></tr>\n     <tr><td style=\\'text-align: left; color: white; padding-top: 5px\\'> ${info.seriesName} :\n     ${this.getValue(info.seriesName, info.value)}  </td></tr>\n     </table>`,\n     });\n \n   // customizeTooltip(arg) {\n   //   return { text: `${arg.argumentText}<br>${arg.seriesName}: ${arg.valueText}B` };\n   // }\n \n   calculateTotal(pieChart) {\n     const totalValue = pieChart.getAllSeries()[0].getVisiblePoints().reduce((s, p) => s + p.originalValue, 0);\n     return this.formatNumber(totalValue);\n   }\n \n   formatNumber(value) {\n     if (value >= 1e9) {\n       return (value / 1e9).toFixed(2) + 'B';\n     } else if (value >= 1e6) {\n       return (value / 1e6).toFixed(2) + 'M';\n     } else if (value >= 1e3) {\n       return (value / 1e3).toFixed(2) + 'K';\n     } else {\n       return value.toFixed(2);\n     }\n   }\n \n   pointClickHandler(arg) {\n     arg.target.select();\n   }\n   getAllChartPointClick(event) {\n \n     let title = this.page_config.kpiConfig.commonConfig['title'];\n     let title_datafield = this.page_config.kpiConfig.commonConfig['dataField'];\n \n     const title_params = (title_datafield) ? event.target.data[title_datafield] : \"\";\n     let widget_title = (title) ? title + title_params : title_params;\n \n     if ('recordDate' in event.target.data) {\n       const recordDate = event.target.data.recordDate;\n       if (this.chartDisplayDateFormat == \"MM-DD\") {\n         const fullDate = moment(recordDate, \"MM-DD\")\n           .year(moment().year())\n           .format(this.environment.dataFormat);\n         event.target.data.recordDate = fullDate;\n       }\n \n     }\n \n     let obj = {\n       data: event.target.data,\n       keyToPass: this.page_config.kpiConfig.keyToPass,\n       tableTitle: (this.page_parms) ? this.page_parms + widget_title : widget_title,\n       viewId: this.page_config.viewId,\n       drillDownType: \"natural\",\n       drilldownFrom: this.page_config.viewId,\n       drilldownTo: \"\",\n     }\n     this.onChartPointClick.emit(obj);\n \n     console.log(\"onchart click\", obj);\n \n   }\n \n   getValue(contextKey, value) {\n \n     let context_data: any;\n     const sml_key = contextKey.toLowerCase();\n \n     if (typeof value === \"number\") {\n       if (sml_key === \"count\" || sml_key === \"hour\" || sml_key === \"denomination\" || sml_key.includes(\"count\")) {\n         context_data = this.commonService.reformatNumberWithThousandSeparatorV3(value, 0);\n       } else if (sml_key.includes('volume') || sml_key.includes('upload') || sml_key.includes('download')) {\n         if (sml_key == 'billablevolume') {\n           context_data = this.commonService.formatBytsToGb(value * 1024, 2)\n         } else {\n           context_data = this.commonService.formatBytsToGb(value * 1024, 2);\n         }\n       } else if (sml_key == \"uplink\" || sml_key == \"downlink\") {\n         context_data = this.commonService.formatBytsToGb(value, 2);\n       } else if (this.hasDecimal(value)) {\n         context_data = this.commonService.reformatNumberWithThousandSeparatorV3(value, 2);\n       } else if (!this.hasDecimal(value)) {\n         context_data = this.commonService.reformatNumberWithThousandSeparatorV3(value, 0);\n       } else {\n         context_data = this.commonService.reformatNumberWithThousandSeparatorV3(value, 2);\n       }\n     } else {\n       context_data = value;\n     }\n \n     return context_data;\n   }\n \n \n   hasDecimal(number) {\n     return number % 1 !== 0;\n   }\n \n   toggleFullScreen() {\n     this.isLoader = true;\n     this.isFullScreen = !this.isFullScreen;\n     const div = this.el.nativeElement.querySelector('.not-full-screen');\n     if (this.isFullScreen) {\n       this.renderer.addClass(div, 'full-screen');\n       setTimeout(() => {\n         this.isLoader = false;\n       }, 10);\n     } else {\n       this.renderer.removeClass(div, 'full-screen');\n       setTimeout(() => {\n         this.isLoader = false;\n       }, 10);\n     }\n   }\n \n \n \n \n \n   customizeText = ({ percentText, item: { argument } }) => `<span style='font-size: 28px'>${percentText}</span><br/>${argument}`;\n \n \n   // bubble chart\n \n   getBubbleChartData() {\n     this.heatChartDataSource = {};\n     const { result, uniqueDates } = this.generateData(this.bubbleChartData, this.chartConfig)\n     // result.forEach(element => {\n     //   element.dataset.sort((a, b) => moment(a.recordDate, 'YYYYMMDD').diff(moment(b.recordDate, 'YYYYMMDD')));\n     // });\n     // uniqueDates.sort();\n     this.heatChartDataSource[\"dataSet\"] = result;\n     this.heatChartDataSource[\"argumentValue\"] = uniqueDates;\n   }\n \n   generateData(data, chartConfig) {\n     const result = [];\n     const uniqueDates = new Set();\n     const dataSourceMap = {};\n \n     const sourceField = chartConfig.sourceField;\n     const argumentField = chartConfig.argumentField;\n     const valueField = chartConfig.chart_config[0].valueField;\n     const minBubbleSize = (this.chartConfig.minBubbleSize) ? parseInt(this.chartConfig.minBubbleSize) : 8;\n     const maxBubbleSize = (this.chartConfig.maxBubbleSize) ? parseInt(this.chartConfig.maxBubbleSize) : 20;\n \n     data.forEach(item => {\n       const sourceFieldValue = item[sourceField];\n       const argumentFieldValue = item[argumentField];\n       const { [sourceField]: _, [argumentField]: __, ...rest } = item;\n \n       if (!dataSourceMap[sourceFieldValue]) {\n         dataSourceMap[sourceFieldValue] = {\n           datasource: sourceFieldValue,\n           dataset: []\n         };\n       }\n       dataSourceMap[sourceFieldValue].dataset.push({\n         ...rest,\n         [argumentField]: moment(argumentFieldValue).format(this.chartDisplayDateFormat)\n       });\n       uniqueDates.add(moment(argumentFieldValue).format(this.chartDisplayDateFormat));\n     });\n \n     const uniqueDatesArray = Array.from(uniqueDates);\n \n     for (const key in dataSourceMap) {\n       const dataset = dataSourceMap[key].dataset;\n       const formattedDataset = this.getFormateDataByColorCode(dataset, valueField, minBubbleSize, maxBubbleSize);\n \n       const dateToItemMap = {};\n       formattedDataset.forEach(item => {\n         dateToItemMap[item[argumentField]] = item;\n       });\n \n       const completeDataset = uniqueDatesArray.map((date: any) => {\n \n         if (dateToItemMap[date]) {\n           return dateToItemMap[date];\n         } else {\n           return {\n             fileCount: 0,\n             [argumentField]: date,\n             [valueField]: 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   getFormateDataByColorCode(filedata, valueField, minBubbleSize, maxBubbleSize) {\n     filedata.forEach(item => {\n       item[valueField] = parseFloat(item[valueField]);\n     });\n \n     let maxRechargeCount = Math.max(...filedata.map(item => item[valueField]));\n     let minRechargeCount = Math.min(...filedata.map(item => item[valueField]));\n \n     let minColor = [43, 224, 91];\n     let maxColor = [65, 135, 24];\n     let hover = [135, 184, 106];\n \n     filedata.forEach(item => {\n       let size = this.mapRange(item[valueField], minRechargeCount, maxRechargeCount, minBubbleSize, maxBubbleSize);\n       item.size = size;\n       item.toolTip = (item[valueField]) ? item[valueField] : '0';\n       item.hover = `rgb(${hover.join(',')})`;\n       if (item[valueField] == 0 || item[valueField] == undefined) {\n         item.color = `rgb(${minColor.join(',')})`;\n       } else {\n         item.color = `rgb(${maxColor.join(',')})`;\n       }\n     });\n \n     return filedata;\n   }\n \n   mapRange(value, inMin, inMax, outMin, outMax) {\n     return ((value - inMin) * (outMax - outMin)) / (inMax - inMin) + outMin;\n   }\n \n \n\n  // customizeLabelText = (info: any) => `${info.valueText}`;\n\n\n}\n","<div class=\"not-full-screen\" (dblclick)=\"toggleFullScreen()\">\n    <ng-container *ngIf=\"page_config?.widGetConfig?.display\">\n        <app-title [title]=\"page_config.widGetConfig.widgetTitle\" [operators]=\"page_config.operations\"\n            [displayType]=\"'chart'\"></app-title>\n    </ng-container>\n    <div class=\"mx-2 p-2 bg-gray-200 dark:bg-gray-800 text-gray-900 dark:text-gray-100\">\n        <app-loader *ngIf=\"isLoader\"></app-loader>\n        <ng-container\n            *ngIf=\"chartConfig.chartType !== 'doughnut' && chartConfig.chartType !== 'pie' && chartConfig.chartType !== 'funnel' && chartConfig.chartType !== 'bubble'\">\n            \n            <dx-chart id=\"chart\"  [dataSource]=\"finalChartDataSource\" (onPointClick)=\"getAllChartPointClick($event)\" [palette]=\"chartConfig.palette\"\n                [title]=\"{ text: chartConfig.caption, font: { size: 14 } }\" *ngIf=\"!isLoader\"\n                [valueAxis]=\"chartConfig.valueAxisConfig\">\n                <ng-container *ngIf=\"chartConfig.size\">\n                    <dxo-size [height]=\"chartConfig.size\">\n                    </dxo-size>\n                </ng-container>\n\n                <ng-container *ngFor=\"let item of chartConfig.chart_config\">\n                    <ng-container *ngIf=\"item && item.axis\">\n                        <dxi-value-axis name=\"{{item.axis}}\" position=\"{{item.position}}\">\n                            <dxo-title text=\"{{item.name}}\"></dxo-title>\n                        </dxi-value-axis>\n                    </ng-container>\n\n                </ng-container>\n                <dxo-argument-axis>\n                    <dxo-label overlappingBehavior=\"rotate\" [rotationAngle]=\"270\"></dxo-label>\n                </dxo-argument-axis>\n                <dxo-tooltip [enabled]=\"true\" [shared]=\"true\" [customizeTooltip]=\"customizeTooltip\">\n                </dxo-tooltip>\n                <dxo-common-series-settings argumentField=\"{{chartConfig.argumentField}}\">\n                </dxo-common-series-settings>\n                <ng-container *ngFor=\"let item of chartConfig.chart_config\">\n                    <ng-container *ngIf=\"item && item.color\">\n                        <dxi-series type=\"{{item.type}}\" valueField=\"{{item.valueField}}\" axis=\"{{item.axis}}\"\n                            name=\"{{item.name}}\" color=\"{{item.color}}\">\n                        </dxi-series>\n                    </ng-container>\n                    <ng-container *ngIf=\"item && !item.color\">\n                        <dxi-series type=\"{{item.type}}\" valueField=\"{{item.valueField}}\" axis=\"{{item.axis}}\"\n                            name=\"{{item.name}}\">\n                        </dxi-series>\n                    </ng-container>\n\n                </ng-container>\n                <dxo-size [height]=\"chartHeight\">\n                </dxo-size>\n                <dxo-legend [visible]=\"chartConfig.legendDisplay\" verticalAlignment=\"{{chartConfig.verticalAlignment}}\"\n                    horizontalAlignment=\"{{chartConfig.horizontalAlignment}}\">\n                </dxo-legend>\n            </dx-chart>\n        </ng-container>\n\n\n\n        <ng-container *ngIf=\"chartConfig.chartType == 'doughnut' || chartConfig.chartType == 'pie'\">\n\n            <dx-pie-chart id=\"pie\" [type]=\"chartConfig.chartType\" [title]=\"{ text: chartConfig.caption, font: { size: 14 } }\"\n                [dataSource]=\"finalChartDataSource\" centerTemplate=\"centerTemplate\"\n                (onPointClick)=\"pointClickHandler($event)\" [palette]=\"chartConfig.palette\">\n\n                <ng-container *ngFor=\"let item of chartConfig.chart_config\">\n                    <ng-container *ngIf=\"item.color\">\n                        <dxi-series argumentField={{chartConfig.argumentField}} valueField=\"{{item.valueField}}\"\n                            name=\"{{item.name}}\" color=\"{{item.color}}\">\n                            <dxo-label [visible]=\"chartConfig.labelDisplay\" format=\"currency\">\n                                <dxo-connector [visible]=\"true\"></dxo-connector>\n                            </dxo-label>\n                        </dxi-series>\n                    </ng-container>\n                    <ng-container *ngIf=\"!item.color\">\n                        <dxi-series argumentField={{chartConfig.argumentField}} valueField=\"{{item.valueField}}\"\n                            name=\"{{item.name}}\">\n                            <dxo-label [visible]=\"chartConfig.labelDisplay\" format=\"currency\">\n                                <dxo-connector [visible]=\"true\"></dxo-connector>\n                            </dxo-label>\n                        </dxi-series>\n                    </ng-container>\n                </ng-container>\n                <ng-container *ngIf=\"chartConfig.size\">\n                    <dxo-size [height]=\"chartConfig.size\">\n                    </dxo-size>\n                </ng-container>\n                <dxo-legend [visible]=\"chartConfig.legendDisplay\"\n                    horizontalAlignment=\"{{chartConfig.horizontalAlignment}}\"\n                    verticalAlignment=\"{{chartConfig.verticalAlignment}}\"></dxo-legend>\n                <!-- <dxo-export [enabled]=\"true\"></dxo-export> -->\n                <dxo-tooltip [enabled]=\"true\" [customizeTooltip]=\"customizeTooltip\" format=\"currency\">\n                </dxo-tooltip>\n                <ng-container *ngIf=\"chartConfig.chartType == 'doughnut'\">\n                    <svg *dxTemplate=\"let pieChart of 'centerTemplate'\">\n                        <circle cx=\"100\" cy=\"100\" [attr.r]=\"pieChart.getInnerRadius() - 6\" fill=\"gray\" opacity=\"0.0001\">\n                        </circle>\n    \n                        <text text-anchor=\"middle\" style=\"font-size: 15px\" x=\"100\" y=\"100\" fill=\"#eee\">\n                            <tspan x=\"100\">{{ calculateTotal(pieChart) }}</tspan>\n                            <!-- display: inline -->\n                            <!-- <tspan x=\"100\" dy=\"20px\" style=\"font-weight: 600\"></tspan> -->\n                        </text>\n                    </svg>\n                </ng-container>\n            </dx-pie-chart>\n        </ng-container>\n\n        <ng-container *ngIf=\"chartConfig.chartType == 'funnel'\">\n            <dx-funnel id=\"funnel\" [dataSource]=\"finalChartDataSource\" argumentField=\"argument\" valueField=\"value\"\n                palette=\"Soft Pastel\">\n                <ng-container *ngIf=\"chartConfig.size\">\n                    <dxo-size [height]=\"chartConfig.size\">\n                    </dxo-size>\n                </ng-container>\n                <dxo-export [enabled]=\"false\"></dxo-export>\n                <dxo-tooltip [enabled]=\"true\"> </dxo-tooltip>\n                <dxo-item>\n                    <dxo-border [visible]=\"true\"> </dxo-border>\n                </dxo-item>\n                <dxo-label [visible]=\"true\" position=\"inside\" backgroundColor=\"none\"\n                    [customizeText]=\"customizeText\"></dxo-label>\n            </dx-funnel>\n\n        </ng-container>\n\n        <ng-container *ngIf=\"chartConfig.chartType == 'bubble'\">\n            <div class=\"mx-5 overflow-x-auto\">\n                <ng-container *ngFor=\"let item of heatChartDataSource.dataSet\">\n                    <div class=\"flex flex-row\">\n                        <div class=\"h-10 text-sm items-center min-w-12 max-w-[30%] justify-center flex\">\n                            {{item.datasource}}\n                        </div>\n                        <div class=\"inline-block \">\n                            <div class=\"flex flex-nowrap justify-center \">\n                                <ng-container *ngFor=\"let box of item.dataset\">\n                                    <div class=\"flex-shrink-0 min-w-10 max-w-[20%] h-10 text-sm cursor-pointer flex items-center justify-center text-gray-800\"\n                                        [matTooltip]=\"'Record Date: ' + box.recordDate + '\\nRecharge Count: ' + box.toolTip\"\n                                        matTooltipClass=\"custom-tooltip\">\n                                        <div class=\"rounded-full\" [ngStyle]=\"{\n                                                'background-color': box.isHovered ? 'rgb(135, 184, 106)' : box.color,\n                                                'width.px': box.size,\n                                                'hover': box.hover,\n                                                'height.px': box.size\n                                              }\" (mouseenter)=\"box.isHovered = true\"\n                                            (mouseleave)=\"box.isHovered = false\">\n                                        </div>\n                                    </div>\n                                </ng-container>\n                            </div>\n                        </div>\n                    </div>\n                </ng-container>\n                <div class=\"inline-block\">\n                    <div class=\"flex flex-nowrap justify-center\">\n                        <div class=\"flex-shrink-0 w-12 max-w-[20%] h-full flex items-center justify-center\"></div>\n                        <div *ngFor=\"let item of heatChartDataSource.argumentValue\"\n                            class=\"flex-shrink-0 w-10 max-w-[20%] min-h-14 flex text-sm items-center justify-center my-1\"\n                            [ngStyle]=\"{'height': 'auto'}\">\n                            <span class=\"text-rotate\">\n                                {{item}}\n                            </span>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        </ng-container>\n\n\n    </div>\n\n    <button *ngIf=\"isFullScreen\" class=\"close-button\" (click)=\"toggleFullScreen()\">Close</button>\n</div>"]}
412
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gamma-advance-chart.component.js","sourceRoot":"","sources":["../../../../../../../projects/gamma-app-controller/src/lib/shared/advanced-component/gamma-advance-chart/gamma-advance-chart.component.ts","../../../../../../../projects/gamma-app-controller/src/lib/shared/advanced-component/gamma-advance-chart/gamma-advance-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["\nimport { AfterViewInit, ChangeDetectorRef, Component, ElementRef, EventEmitter, Inject, Input, OnInit, Output, Renderer2 } from '@angular/core';\nimport { ToastrService } from 'ngx-toastr';\nimport { kpicommonService } from '../../kpi-comon-service';\nimport moment from '../../../application-controller/moment-helper';\nimport { CommonService } from '../../../application-controller/common';\nimport { APP_ENVIRONMENT } from '../../../application-controller/environment';\n\n@Component({\n  selector: 'app-gamma-advance-chart',\n  templateUrl: './gamma-advance-chart.component.html',\n})\nexport class GammaAdvanceChartComponent implements OnInit {\n  chartConfig: any = {};\n  page_config: any = {};\n  isLoader: boolean = true;\n  @Input() componentId: any;\n  // @Input() caption: any;\n  @Input() kpi_name: any;\n  // @Input() chartDataSource:any;\n  caption: any;\n  isChartvisible: boolean;\n  creatChartDataSource = undefined;\n  finalChartDataSource: any = [];\n  chartHeight: any;\n\n  isFullScreen: boolean = false;\n\n  heatChartDataSource: any;\n  bubbleChartData: any;\n  constructor(\n    private commonService: CommonService,\n    private toastr: ToastrService,\n    private kpiService: kpicommonService,\n    private renderer: Renderer2, private el: ElementRef,\n    private cdr: ChangeDetectorRef,\n    @Inject(APP_ENVIRONMENT) private environment: any\n  ) {\n\n  }\n  page_parms: any;\n  // chart_attr.legend[0]\n  chartOrderBy: boolean;\n  chartDisplayDateFormat: any;\n  @Output() public onChartPointClick: EventEmitter<any> = new EventEmitter();\n\n  @Input('chartDataSource')\n  set chartDataSource(value) {\n    this.creatChartDataSource = value;\n    // console.log(value);\n    if (this.creatChartDataSource === undefined || this.creatChartDataSource.length === 0) {\n      this.isChartvisible = false;\n      return;\n    } else {\n\n      this.isLoader = true;\n      this.page_config = value;\n      this.page_parms = value.titleParams;\n      this.chartOrderBy = (value.kpiConfig.descendingOrder) ? value.kpiConfig.descendingOrder : false;\n      this.chartDisplayDateFormat = (value.kpiConfig.displayDateFormat) ? value.kpiConfig.displayDateFormat : \"MM-DD\";\n      if (value.kpiConfig.dataSource && value.kpiConfig.dataSource.length !== 0) {\n        this.chartConfig = value.kpiConfig.dataConfig;\n        if (value.kpiConfig.formate == \"daily\") {\n\n          const sortedData = value.kpiConfig.dataSource\n            .filter(record => record.recordDate)\n            .sort((a, b) => moment(b.recordDate).diff(moment(a.recordDate)));\n\n          const mostRecentRecord = sortedData[0];\n          const filteredObjects = sortedData.filter(data => data.recordDate === value.endDate);\n          if (this.chartConfig.chartType == 'funnel') {\n            this.finalChartDataSource = Object.keys(mostRecentRecord).filter(key => key !== 'recordDate').map(key => ({\n              argument: key,\n              value: Math.abs(parseInt(mostRecentRecord[key]))\n            }));\n            console.log(this.finalChartDataSource)\n          } else {\n\n            this.getDailyChart(filteredObjects, value.kpiConfig.dataConfig);\n\n          }\n\n          this.isLoader = false;\n        } else if (value.kpiConfig.formate == \"monthly\") {\n          if (value.kpiConfig.dataSource && value.kpiConfig.dataSource.length !== 0) {\n\n            if (this.chartConfig.chartType == 'bubble') {\n              this.bubbleChartData = value.kpiConfig.dataSource;\n              this.getBubbleChartData();\n            } else {\n              if (this.chartOrderBy) {\n                let shortName = value.kpiConfig.dataConfig['argumentField'].toLowerCase();\n                if (shortName.includes('date')) {\n                  value.kpiConfig.dataSource = value.kpiConfig.dataSource\n                    .filter(record => record[value.kpiConfig.dataConfig['argumentField']])\n                    .sort((a, b) => moment(b[value.kpiConfig.dataConfig['argumentField']]).diff(moment(a[value.kpiConfig.dataConfig['argumentField']])));\n\n                }\n\n              }\n\n              this.getMonthlyChart(value.kpiConfig.dataSource, value.kpiConfig.dataConfig)\n              this.isChartvisible == true;\n            }\n\n          } else {\n            this.cdr.detectChanges();\n          }\n\n          this.isLoader = false;\n        } else if (value.kpiConfig.formate == \"hourly\") {\n          if (value.kpiConfig.dataSource && value.kpiConfig.dataSource.length !== 0) {\n            const sortedData = value.kpiConfig.dataSource\n              .filter(record => record.hour)\n              .sort((a, b) => moment(a.hour, 'hh').diff(moment(b.hour, 'hh')));\n            const mostRecentRecord = sortedData[0];\n            const filteredObjects = sortedData.filter(data => data.recordDate === mostRecentRecord.recordDate);\n\n            this.getHourChart(filteredObjects, value.kpiConfig.dataConfig)\n            this.isChartvisible == true;\n          } else {\n            this.cdr.detectChanges();\n          }\n\n          this.isLoader = false;\n        }\n\n      }\n      // else {\n      //   this.isLoader = false;\n      // }\n\n    }\n\n\n\n  }\n\n\n  ngOnInit(): void {\n\n  }\n\n  getHourChart(data, dataConfig) {\n    // const valueFields = dataConfig.chart_config.map(config => config.valueField);\n    if (data) {\n      data.forEach(val => {\n        if (val[dataConfig.argumentField].toString().length == 1) {\n          val[dataConfig.argumentField] = '0' + val[dataConfig.argumentField];\n        }\n        let label = val[dataConfig.argumentField].toString();\n        val[dataConfig.argumentField] = label\n      });\n      setTimeout(() => {\n        this.finalChartDataSource = data;\n      }, 500);\n    } else {\n      this.toastr.error(this.kpi_name + 'Chart Error');\n\n    }\n  }\n  getMonthlyChart(data, dataConfig) {\n    const valueFields = dataConfig.chart_config.map(config => config.valueField);\n    data.forEach((entry: any) => {\n      valueFields.forEach((field: any) => {\n        if (entry.hasOwnProperty(field)) {\n          if (typeof entry[field] === \"string\") {\n            entry[field] = Number(entry[field]);\n          }\n        }\n      });\n    });\n    if (data) {\n      let content = this.chartConfig.argumentField.toLowerCase();\n      if (content.includes('date')) {\n        const dataSource = data.map(obj => {\n          const newObj = { ...obj };\n          if (newObj.hasOwnProperty(this.chartConfig.argumentField)) {\n            newObj[this.chartConfig.argumentField] = moment(newObj[this.chartConfig.argumentField]).format(this.chartDisplayDateFormat);\n          }\n          return newObj;\n        });\n        this.finalChartDataSource = dataSource;\n      } else {\n        this.finalChartDataSource = data;\n      }\n    } else {\n      this.toastr.error(this.kpi_name + 'Chart Error');\n    }\n  }\n  getDailyChart(data, dataConfig) {\n    const valueFields = dataConfig.chart_config.map(config => config.valueField);\n    if (data) {\n      let content = this.chartConfig.argumentField.toLowerCase();\n      if (content.includes('date')) {\n        const dataSource = data.map(obj => {\n          const newObj = { ...obj };\n          if (newObj.hasOwnProperty(this.chartConfig.argumentField)) {\n            newObj[this.chartConfig.argumentField] = moment(newObj[this.chartConfig.argumentField]).format(this.chartDisplayDateFormat);\n          }\n          return newObj;\n        });\n        this.finalChartDataSource = dataSource;\n      } else {\n        this.finalChartDataSource = data;\n      }\n    } else {\n      this.toastr.error(this.kpi_name + ' Chart Error');\n    }\n  }\n\n\n  getReconDailyChart(data, dataConfig) {\n\n    this.finalChartDataSource = [];\n    const recon_key = dataConfig.reconKey;\n    const recon_column = dataConfig.reconColumns;\n    this.finalChartDataSource = this.getFinalData(data, recon_column);\n\n  }\n\n  getFinalData(mainData: any[], reconColumn: any[]): any[] {\n    mainData.forEach(data => {\n      reconColumn.forEach(column => {\n        const firstKeyValue = data[column.firstKey];\n        const secondKeyValue = data[column.secondKey];\n        const mouDiff = Math.abs(firstKeyValue - secondKeyValue);\n        data[column.finalKey] = mouDiff;\n      });\n    });\n\n    return mainData;\n  }\n\n  customizeTooltip = (info: any) => (\n    {\n\n      html: `<table style = width=100% height=30 border=0  style=\\'font-size: 13px\\'>\n    <tr><td class=\"text-gray-800 dark:text-gray-200 \" style=\\'text-align: left\\'> ${this.commonService.convertToTitleCase(this.chartConfig.argumentField)} :  ${info.argumentText} </td></tr>\n     <tr><td class=\"text-gray-800 dark:text-gray-200 \" style=\\'text-align: left; padding-top: 5px\\'> ${info.seriesName} :\n     ${this.getValue(info.seriesName, info.value)}  </td></tr>\n     </table>`,\n    });\n\n  // customizeTooltip = (info: any) => ({\n  //   html: `\n  //   <div class=\"w-full min-w-[200px] p-3 rounded-lg shadow-lg \n  //               bg-white dark:bg-gray-800 border border-gray-200 dark:border-gray-700\n  //               text-sm font-sans\">\n  //     <div class=\"text-gray-800 dark:text-gray-200 font-medium mb-2\">\n  //       ${this.commonService.convertToTitleCase(this.chartConfig.argumentField)}: ${info.argumentText}\n  //     </div>\n  //     <div class=\"text-gray-600 dark:text-gray-300\">\n  //       ${info.seriesName}: ${this.getValue(info.seriesName, info.value)}\n  //     </div>\n  //   </div>\n  // `,\n  // });\n\n  // customizeTooltip(arg) {\n  //   return { text: `${arg.argumentText}<br>${arg.seriesName}: ${arg.valueText}B` };\n  // }\n\n  calculateTotal(pieChart) {\n    const totalValue = pieChart.getAllSeries()[0].getVisiblePoints().reduce((s, p) => s + p.originalValue, 0);\n    return this.formatNumber(totalValue);\n  }\n\n  formatNumber(value) {\n    if (value >= 1e9) {\n      return (value / 1e9).toFixed(2) + 'B';\n    } else if (value >= 1e6) {\n      return (value / 1e6).toFixed(2) + 'M';\n    } else if (value >= 1e3) {\n      return (value / 1e3).toFixed(2) + 'K';\n    } else {\n      return value.toFixed(2);\n    }\n  }\n\n  pointClickHandler(arg) {\n    arg.target.select();\n  }\n  getAllChartPointClick(event) {\n\n    let title = this.page_config.kpiConfig.commonConfig['title'];\n    let title_datafield = this.page_config.kpiConfig.commonConfig['dataField'];\n\n    const title_params = (title_datafield) ? event.target.data[title_datafield] : \"\";\n    let widget_title = (title) ? title + title_params : title_params;\n\n    if ('recordDate' in event.target.data) {\n      const recordDate = event.target.data.recordDate;\n      if (this.chartDisplayDateFormat == \"MM-DD\") {\n        const fullDate = moment(recordDate, \"MM-DD\")\n          .year(moment().year())\n          .format(this.environment.dataFormat);\n        event.target.data.recordDate = fullDate;\n      }\n\n    }\n\n    let obj = {\n      data: event.target.data,\n      keyToPass: this.page_config.kpiConfig.keyToPass,\n      tableTitle: (this.page_parms) ? this.page_parms + widget_title : widget_title,\n      viewId: this.page_config.viewId,\n      drillDownType: \"natural\",\n      drilldownFrom: this.page_config.viewId,\n      drilldownTo: \"\",\n    }\n    this.onChartPointClick.emit(obj);\n\n    console.log(\"onchart click\", obj);\n\n  }\n\n  getValue(contextKey, value) {\n\n    let context_data: any;\n    const sml_key = contextKey.toLowerCase();\n\n    if (typeof value === \"number\") {\n      if (sml_key === \"count\" || sml_key === \"hour\" || sml_key === \"denomination\" || sml_key.includes(\"count\")) {\n        context_data = this.commonService.reformatNumberWithThousandSeparatorV3(value, 0);\n      } else if (sml_key.includes('volume') || sml_key.includes('upload') || sml_key.includes('download')) {\n        if (sml_key == 'billablevolume') {\n          context_data = this.commonService.formatBytsToGb(value * 1024, 2)\n        } else {\n          context_data = this.commonService.formatBytsToGb(value * 1024, 2);\n        }\n      } else if (sml_key == \"uplink\" || sml_key == \"downlink\") {\n        context_data = this.commonService.formatBytsToGb(value, 2);\n      } else if (this.hasDecimal(value)) {\n        context_data = this.commonService.reformatNumberWithThousandSeparatorV3(value, 2);\n      } else if (!this.hasDecimal(value)) {\n        context_data = this.commonService.reformatNumberWithThousandSeparatorV3(value, 0);\n      } else {\n        context_data = this.commonService.reformatNumberWithThousandSeparatorV3(value, 2);\n      }\n    } else {\n      context_data = value;\n    }\n\n    return context_data;\n  }\n\n\n  hasDecimal(number) {\n    return number % 1 !== 0;\n  }\n\n  toggleFullScreen() {\n    this.isLoader = true;\n    this.isFullScreen = !this.isFullScreen;\n    const div = this.el.nativeElement.querySelector('.not-full-screen');\n    if (this.isFullScreen) {\n      this.renderer.addClass(div, 'full-screen');\n      setTimeout(() => {\n        this.isLoader = false;\n      }, 10);\n    } else {\n      this.renderer.removeClass(div, 'full-screen');\n      setTimeout(() => {\n        this.isLoader = false;\n      }, 10);\n    }\n  }\n\n\n\n\n\n  customizeText = ({ percentText, item: { argument } }) => `<span style='font-size: 28px'>${percentText}</span><br/>${argument}`;\n\n\n  // bubble chart\n\n  getBubbleChartData() {\n    this.heatChartDataSource = {};\n    const { result, uniqueDates } = this.generateData(this.bubbleChartData, this.chartConfig)\n    // result.forEach(element => {\n    //   element.dataset.sort((a, b) => moment(a.recordDate, 'YYYYMMDD').diff(moment(b.recordDate, 'YYYYMMDD')));\n    // });\n    // uniqueDates.sort();\n    this.heatChartDataSource[\"dataSet\"] = result;\n    this.heatChartDataSource[\"argumentValue\"] = uniqueDates;\n  }\n\n  generateData(data, chartConfig) {\n    const result = [];\n    const uniqueDates = new Set();\n    const dataSourceMap = {};\n\n    const sourceField = chartConfig.sourceField;\n    const argumentField = chartConfig.argumentField;\n    const valueField = chartConfig.chart_config[0].valueField;\n    const minBubbleSize = (this.chartConfig.minBubbleSize) ? parseInt(this.chartConfig.minBubbleSize) : 8;\n    const maxBubbleSize = (this.chartConfig.maxBubbleSize) ? parseInt(this.chartConfig.maxBubbleSize) : 20;\n\n    data.forEach(item => {\n      const sourceFieldValue = item[sourceField];\n      const argumentFieldValue = item[argumentField];\n      const { [sourceField]: _, [argumentField]: __, ...rest } = item;\n\n      if (!dataSourceMap[sourceFieldValue]) {\n        dataSourceMap[sourceFieldValue] = {\n          datasource: sourceFieldValue,\n          dataset: []\n        };\n      }\n      dataSourceMap[sourceFieldValue].dataset.push({\n        ...rest,\n        [argumentField]: moment(argumentFieldValue).format(this.chartDisplayDateFormat)\n      });\n      uniqueDates.add(moment(argumentFieldValue).format(this.chartDisplayDateFormat));\n    });\n\n    const uniqueDatesArray = Array.from(uniqueDates);\n\n    for (const key in dataSourceMap) {\n      const dataset = dataSourceMap[key].dataset;\n      const formattedDataset = this.getFormateDataByColorCode(dataset, valueField, minBubbleSize, maxBubbleSize);\n\n      const dateToItemMap = {};\n      formattedDataset.forEach(item => {\n        dateToItemMap[item[argumentField]] = item;\n      });\n\n      const completeDataset = uniqueDatesArray.map((date: any) => {\n\n        if (dateToItemMap[date]) {\n          return dateToItemMap[date];\n        } else {\n          return {\n            fileCount: 0,\n            [argumentField]: date,\n            [valueField]: 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  getFormateDataByColorCode(filedata, valueField, minBubbleSize, maxBubbleSize) {\n    filedata.forEach(item => {\n      item[valueField] = parseFloat(item[valueField]);\n    });\n\n    let maxRechargeCount = Math.max(...filedata.map(item => item[valueField]));\n    let minRechargeCount = Math.min(...filedata.map(item => item[valueField]));\n\n    let minColor = [43, 224, 91];\n    let maxColor = [65, 135, 24];\n    let hover = [135, 184, 106];\n\n    filedata.forEach(item => {\n      let size = this.mapRange(item[valueField], minRechargeCount, maxRechargeCount, minBubbleSize, maxBubbleSize);\n      item.size = size;\n      item.toolTip = (item[valueField]) ? item[valueField] : '0';\n      item.hover = `rgb(${hover.join(',')})`;\n      if (item[valueField] == 0 || item[valueField] == undefined) {\n        item.color = `rgb(${minColor.join(',')})`;\n      } else {\n        item.color = `rgb(${maxColor.join(',')})`;\n      }\n    });\n\n    return filedata;\n  }\n\n  mapRange(value, inMin, inMax, outMin, outMax) {\n    return ((value - inMin) * (outMax - outMin)) / (inMax - inMin) + outMin;\n  }\n\n\n\n  // customizeLabelText = (info: any) => `${info.valueText}`;\n\n\n}\n","<div class=\"not-full-screen\" (dblclick)=\"toggleFullScreen()\">\n    <ng-container *ngIf=\"page_config?.widGetConfig?.display\">\n        <app-title [title]=\"page_config.widGetConfig.widgetTitle\" [operators]=\"page_config.operations\"\n            [displayType]=\"'chart'\"></app-title>\n    </ng-container>\n    <div class=\"mx-2 p-2 bg-gray-200 dark:bg-gray-800 text-gray-900 dark:text-gray-100\">\n        <app-loader *ngIf=\"isLoader\"></app-loader>\n        <ng-container\n            *ngIf=\"chartConfig.chartType !== 'doughnut' && chartConfig.chartType !== 'pie' && chartConfig.chartType !== 'funnel' && chartConfig.chartType !== 'bubble'\">\n            \n            <dx-chart id=\"chart\"  [dataSource]=\"finalChartDataSource\" (onPointClick)=\"getAllChartPointClick($event)\" [palette]=\"chartConfig.palette\"\n                [title]=\"{ text: chartConfig.caption, font: { size: 14 } }\" *ngIf=\"!isLoader\"\n                [valueAxis]=\"chartConfig.valueAxisConfig\">\n                <ng-container *ngIf=\"chartConfig.size\">\n                    <dxo-size [height]=\"chartConfig.size\">\n                    </dxo-size>\n                </ng-container>\n\n                <ng-container *ngFor=\"let item of chartConfig.chart_config\">\n                    <ng-container *ngIf=\"item && item.axis\">\n                        <dxi-value-axis name=\"{{item.axis}}\" position=\"{{item.position}}\">\n                            <dxo-title text=\"{{item.name}}\"></dxo-title>\n                        </dxi-value-axis>\n                    </ng-container>\n\n                </ng-container>\n                <dxo-argument-axis>\n                    <dxo-label overlappingBehavior=\"rotate\" [rotationAngle]=\"270\"></dxo-label>\n                </dxo-argument-axis>\n                <dxo-tooltip [enabled]=\"true\" [shared]=\"true\" [customizeTooltip]=\"customizeTooltip\">\n                </dxo-tooltip>\n                <dxo-common-series-settings argumentField=\"{{chartConfig.argumentField}}\">\n                </dxo-common-series-settings>\n                <ng-container *ngFor=\"let item of chartConfig.chart_config\">\n                    <ng-container *ngIf=\"item && item.color\">\n                        <dxi-series type=\"{{item.type}}\" valueField=\"{{item.valueField}}\" axis=\"{{item.axis}}\"\n                            name=\"{{item.name}}\" color=\"{{item.color}}\">\n                        </dxi-series>\n                    </ng-container>\n                    <ng-container *ngIf=\"item && !item.color\">\n                        <dxi-series type=\"{{item.type}}\" valueField=\"{{item.valueField}}\" axis=\"{{item.axis}}\"\n                            name=\"{{item.name}}\">\n                        </dxi-series>\n                    </ng-container>\n\n                </ng-container>\n                <dxo-size [height]=\"chartHeight\">\n                </dxo-size>\n                <dxo-legend [visible]=\"chartConfig.legendDisplay\" verticalAlignment=\"{{chartConfig.verticalAlignment}}\"\n                    horizontalAlignment=\"{{chartConfig.horizontalAlignment}}\">\n                </dxo-legend>\n            </dx-chart>\n        </ng-container>\n\n\n\n        <ng-container *ngIf=\"chartConfig.chartType == 'doughnut' || chartConfig.chartType == 'pie'\">\n\n            <dx-pie-chart id=\"pie\" [type]=\"chartConfig.chartType\" [title]=\"{ text: chartConfig.caption, font: { size: 14 } }\"\n                [dataSource]=\"finalChartDataSource\" centerTemplate=\"centerTemplate\"\n                (onPointClick)=\"pointClickHandler($event)\" [palette]=\"chartConfig.palette\">\n\n                <ng-container *ngFor=\"let item of chartConfig.chart_config\">\n                    <ng-container *ngIf=\"item.color\">\n                        <dxi-series argumentField={{chartConfig.argumentField}} valueField=\"{{item.valueField}}\"\n                            name=\"{{item.name}}\" color=\"{{item.color}}\">\n                            <dxo-label [visible]=\"chartConfig.labelDisplay\" format=\"currency\">\n                                <dxo-connector [visible]=\"true\"></dxo-connector>\n                            </dxo-label>\n                        </dxi-series>\n                    </ng-container>\n                    <ng-container *ngIf=\"!item.color\">\n                        <dxi-series argumentField={{chartConfig.argumentField}} valueField=\"{{item.valueField}}\"\n                            name=\"{{item.name}}\">\n                            <dxo-label [visible]=\"chartConfig.labelDisplay\" format=\"currency\">\n                                <dxo-connector [visible]=\"true\"></dxo-connector>\n                            </dxo-label>\n                        </dxi-series>\n                    </ng-container>\n                </ng-container>\n                <ng-container *ngIf=\"chartConfig.size\">\n                    <dxo-size [height]=\"chartConfig.size\">\n                    </dxo-size>\n                </ng-container>\n                <dxo-legend [visible]=\"chartConfig.legendDisplay\"\n                    horizontalAlignment=\"{{chartConfig.horizontalAlignment}}\"\n                    verticalAlignment=\"{{chartConfig.verticalAlignment}}\"></dxo-legend>\n                <!-- <dxo-export [enabled]=\"true\"></dxo-export> -->\n                <dxo-tooltip [enabled]=\"true\" [customizeTooltip]=\"customizeTooltip\" format=\"currency\">\n                </dxo-tooltip>\n                <ng-container *ngIf=\"chartConfig.chartType == 'doughnut'\">\n                    <svg *dxTemplate=\"let pieChart of 'centerTemplate'\">\n                        <circle cx=\"100\" cy=\"100\" [attr.r]=\"pieChart.getInnerRadius() - 6\" fill=\"gray\" opacity=\"0.0001\">\n                        </circle>\n    \n                        <text text-anchor=\"middle\" style=\"font-size: 15px\" x=\"100\" y=\"100\" fill=\"#eee\">\n                            <tspan x=\"100\">{{ calculateTotal(pieChart) }}</tspan>\n                            <!-- display: inline -->\n                            <!-- <tspan x=\"100\" dy=\"20px\" style=\"font-weight: 600\"></tspan> -->\n                        </text>\n                    </svg>\n                </ng-container>\n            </dx-pie-chart>\n        </ng-container>\n\n        <ng-container *ngIf=\"chartConfig.chartType == 'funnel'\">\n            <dx-funnel id=\"funnel\" [dataSource]=\"finalChartDataSource\" argumentField=\"argument\" valueField=\"value\"\n                palette=\"Soft Pastel\">\n                <ng-container *ngIf=\"chartConfig.size\">\n                    <dxo-size [height]=\"chartConfig.size\">\n                    </dxo-size>\n                </ng-container>\n                <dxo-export [enabled]=\"false\"></dxo-export>\n                <dxo-tooltip [enabled]=\"true\"> </dxo-tooltip>\n                <dxo-item>\n                    <dxo-border [visible]=\"true\"> </dxo-border>\n                </dxo-item>\n                <dxo-label [visible]=\"true\" position=\"inside\" backgroundColor=\"none\"\n                    [customizeText]=\"customizeText\"></dxo-label>\n            </dx-funnel>\n\n        </ng-container>\n\n        <ng-container *ngIf=\"chartConfig.chartType == 'bubble'\">\n            <div class=\"mx-5 overflow-x-auto\">\n                <ng-container *ngFor=\"let item of heatChartDataSource.dataSet\">\n                    <div class=\"flex flex-row\">\n                        <div class=\"h-10 text-sm items-center min-w-12 max-w-[30%] justify-center flex\">\n                            {{item.datasource}}\n                        </div>\n                        <div class=\"inline-block \">\n                            <div class=\"flex flex-nowrap justify-center \">\n                                <ng-container *ngFor=\"let box of item.dataset\">\n                                    <div class=\"flex-shrink-0 min-w-10 max-w-[20%] h-10 text-sm cursor-pointer flex items-center justify-center text-gray-800\"\n                                        [matTooltip]=\"'Record Date: ' + box.recordDate + '\\nRecharge Count: ' + box.toolTip\"\n                                        matTooltipClass=\"custom-tooltip\">\n                                        <div class=\"rounded-full\" [ngStyle]=\"{\n                                                'background-color': box.isHovered ? 'rgb(135, 184, 106)' : box.color,\n                                                'width.px': box.size,\n                                                'hover': box.hover,\n                                                'height.px': box.size\n                                              }\" (mouseenter)=\"box.isHovered = true\"\n                                            (mouseleave)=\"box.isHovered = false\">\n                                        </div>\n                                    </div>\n                                </ng-container>\n                            </div>\n                        </div>\n                    </div>\n                </ng-container>\n                <div class=\"inline-block\">\n                    <div class=\"flex flex-nowrap justify-center\">\n                        <div class=\"flex-shrink-0 w-12 max-w-[20%] h-full flex items-center justify-center\"></div>\n                        <div *ngFor=\"let item of heatChartDataSource.argumentValue\"\n                            class=\"flex-shrink-0 w-10 max-w-[20%] min-h-14 flex text-sm items-center justify-center my-1\"\n                            [ngStyle]=\"{'height': 'auto'}\">\n                            <span class=\"text-rotate\">\n                                {{item}}\n                            </span>\n                        </div>\n                    </div>\n                </div>\n            </div>\n        </ng-container>\n\n\n    </div>\n\n    <button *ngIf=\"isFullScreen\" class=\"close-button\" (click)=\"toggleFullScreen()\">Close</button>\n</div>"]}
@@ -9037,9 +9037,9 @@ class GammaAdvanceChartComponent {
9037
9037
  this.isFullScreen = false;
9038
9038
  this.onChartPointClick = new EventEmitter();
9039
9039
  this.customizeTooltip = (info) => ({
9040
- html: `<table width=100% height=30 border=0 style=\'font-size: 13px\'>
9041
- <tr><td style=\'text-align: left; color: white\'> ${this.commonService.convertToTitleCase(this.chartConfig.argumentField)} : ${info.argumentText} </td></tr>
9042
- <tr><td style=\'text-align: left; color: white; padding-top: 5px\'> ${info.seriesName} :
9040
+ html: `<table style = width=100% height=30 border=0 style=\'font-size: 13px\'>
9041
+ <tr><td class="text-gray-800 dark:text-gray-200 " style=\'text-align: left\'> ${this.commonService.convertToTitleCase(this.chartConfig.argumentField)} : ${info.argumentText} </td></tr>
9042
+ <tr><td class="text-gray-800 dark:text-gray-200 " style=\'text-align: left; padding-top: 5px\'> ${info.seriesName} :
9043
9043
  ${this.getValue(info.seriesName, info.value)} </td></tr>
9044
9044
  </table>`,
9045
9045
  });