gamma-app-controller 1.2.8 → 1.2.10
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/common.mjs +18 -13
- package/esm2020/lib/application-controller/support-components/dash-chart/dash-chart.component.mjs +20 -3
- package/esm2020/lib/shared/advanced-component/gamma-advance-chart/gamma-advance-chart.component.mjs +3 -3
- package/esm2020/lib/template-module/defaulLandingComponent/landing-component.component.mjs +408 -103
- package/esm2020/lib/template-module/defaulLandingComponent/landing.tokenStorage.servce.mjs +36 -0
- package/esm2020/lib/template-module/kpiWithSingleLayout/kpi-with-dataset.component.mjs +10 -1
- package/esm2020/public-api.mjs +2 -1
- package/fesm2015/gamma-app-controller.mjs +499 -124
- package/fesm2015/gamma-app-controller.mjs.map +1 -1
- package/fesm2020/gamma-app-controller.mjs +499 -133
- package/fesm2020/gamma-app-controller.mjs.map +1 -1
- package/lib/application-controller/common.d.ts +3 -2
- package/lib/application-controller/support-components/dash-chart/dash-chart.component.d.ts +1 -0
- package/lib/template-module/defaulLandingComponent/landing-component.component.d.ts +29 -1
- package/lib/template-module/defaulLandingComponent/landing.tokenStorage.servce.d.ts +12 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
package/esm2020/lib/shared/advanced-component/gamma-advance-chart/gamma-advance-chart.component.mjs
CHANGED
|
@@ -224,8 +224,8 @@ export class GammaAdvanceChartComponent {
|
|
|
224
224
|
arg.target.select();
|
|
225
225
|
}
|
|
226
226
|
getAllChartPointClick(event) {
|
|
227
|
-
let title = this.page_config.kpiConfig.
|
|
228
|
-
let title_datafield = this.page_config.kpiConfig.
|
|
227
|
+
let title = this.page_config.kpiConfig.commonConfig['title'];
|
|
228
|
+
let title_datafield = this.page_config.kpiConfig.commonConfig['dataField'];
|
|
229
229
|
const title_params = (title_datafield) ? event.target.data[title_datafield] : "";
|
|
230
230
|
let widget_title = (title) ? title + title_params : title_params;
|
|
231
231
|
if ('recordDate' in event.target.data) {
|
|
@@ -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.dataConfig.commonConfig['title'];\n     let title_datafield = this.page_config.kpiConfig.dataConfig.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-800\">\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)\"\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 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-800\">\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)\"\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>"]}
|