gamma-app-controller 1.1.12 → 1.1.15
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/application-controller/application-controller.module.mjs +15 -5
- package/esm2020/lib/application-controller/application-dataset-component/create-dataset/create-dataset.component.mjs +8 -1
- package/esm2020/lib/application-controller/application-dataset-component/create-dataset-sql/create-dataset-sql.component.mjs +18 -8
- package/esm2020/lib/application-controller/application-filter/application-filter.component.mjs +26 -17
- package/esm2020/lib/application-controller/application-view-components/create-comp-view/create-comp-view.component.mjs +10 -10
- package/esm2020/lib/application-controller/page-controller/page-config/page-config.component.mjs +23 -1
- package/esm2020/lib/application-controller/shared/advanced-component/gamma-advance-operator-table/gamma-advance-operator-table.component.mjs +1 -2
- package/esm2020/lib/application-controller/shared/advanced-component/gamma-heatmap/gamma-heatmap.component.mjs +328 -0
- package/esm2020/lib/application-controller/support-components/dash-table/dash-table.component.mjs +2 -2
- package/esm2020/lib/application-controller/support-components/dash-today-previous/dash-today-previous.component.mjs +2 -2
- package/esm2020/lib/application-controller/support-components/geo-map/geo-map.component.mjs +2 -2
- package/esm2020/lib/application-controller/support-components/heat-map/heat-map.component.mjs +556 -0
- package/esm2020/lib/application-controller/support-components/single-card/single-card.component.mjs +2 -3
- package/esm2020/lib/application-controller/support-components/table-with-bar/table-with-bar.component.mjs +2 -2
- package/esm2020/public-api.mjs +3 -1
- package/fesm2015/gamma-app-controller.mjs +958 -43
- package/fesm2015/gamma-app-controller.mjs.map +1 -1
- package/fesm2020/gamma-app-controller.mjs +959 -43
- package/fesm2020/gamma-app-controller.mjs.map +1 -1
- package/lib/application-controller/application-controller.module.d.ts +13 -11
- package/lib/application-controller/application-filter/application-filter.component.d.ts +3 -1
- package/lib/application-controller/application-view-components/create-comp-view/create-comp-view.component.d.ts +1 -0
- package/lib/application-controller/page-controller/page-config/page-config.component.d.ts +3 -0
- package/lib/application-controller/shared/advanced-component/gamma-heatmap/gamma-heatmap.component.d.ts +60 -0
- package/lib/application-controller/support-components/heat-map/heat-map.component.d.ts +99 -0
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
|
@@ -48,7 +48,6 @@ export class GammaAdvanceOperatorTableComponent {
|
|
|
48
48
|
const foundMatchObject = tableColumns.find(obj => obj.dataField === key);
|
|
49
49
|
if (foundMatchObject) {
|
|
50
50
|
if (foundMatchObject.enrichName && foundMatchObject.enrichName !== "") {
|
|
51
|
-
console.log(foundMatchObject.enrichName);
|
|
52
51
|
newObj[key] = this.callServiceFunction(foundMatchObject.enrichName, newObj[key]);
|
|
53
52
|
}
|
|
54
53
|
}
|
|
@@ -175,4 +174,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
175
174
|
type: Input,
|
|
176
175
|
args: ['chartDataSource']
|
|
177
176
|
}] } });
|
|
178
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gamma-advance-operator-table.component.js","sourceRoot":"","sources":["../../../../../../../../projects/gamma-app-controller/src/lib/application-controller/shared/advanced-component/gamma-advance-operator-table/gamma-advance-operator-table.component.ts","../../../../../../../../projects/gamma-app-controller/src/lib/application-controller/shared/advanced-component/gamma-advance-operator-table/gamma-advance-operator-table.component.html"],"names":[],"mappings":"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","sourcesContent":["\n\n\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport moment from './../../../moment-helper';\nimport { CommonService } from '../../../common';\n\n@Component({\n  selector: 'app-gamma-advance-operator-table',\n  templateUrl: './gamma-advance-operator-table.component.html',\n  styleUrls: ['./gamma-advance-operator-table.component.scss']\n})\nexport class GammaAdvanceOperatorTableComponent implements OnInit {\n\nisJsonPreview: boolean\n  dataSourseForTable: any = [];\n  jsaonDatasource: any;\n  configColume: any;\n  isLoader: boolean = true;\n  tableDataConfig: any = {};\n  enrichNameList = [\"formatBytes\", \"formatBytsToKb\", \"formatBytsToGb\", \"reformatNumberWithThousandSeparatorV3\"]\n  page_config: any;\n  page_parms: any;\n  page_selected_operator: any;\n\n  tableHeight: any;\n\n  \n  activeTab: string = 'basic';\n  @Output() public getTableConfigOutPut: EventEmitter<any> = new EventEmitter();\n  @Output() public oRowClick: EventEmitter<any> = new EventEmitter();\n  @Output() public onrightClickContextSelection: EventEmitter<any> = new EventEmitter();\n  @Input() rightClickEnable: boolean = true;\n\n  @Input('chartDataSource')\n  set chartDataSource(value) {\n    if (value === undefined || value.length === 0) {\n      return;\n    } else {\n      this.isLoader = true;\n      this.page_config = value;\n      this.page_parms = value.titleParams;\n      this.tableHeight = (value.kpiConfig.dataConfig.tableHeight && value.kpiConfig.dataConfig.tableHeight !== \"\")? this.setTableHeight(value.kpiConfig.dataConfig.tableHeight):'auto';\n\n      if (value.kpiConfig.dataSource && value.kpiConfig.dataSource.length !== 0) {\n\n        if (value.kpiConfig.formate == \"daily\") {\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 === mostRecentRecord.recordDate);\n          this.dataSourseForTable = filteredObjects;\n\n        } else if (value.kpiConfig.formate == \"monthly\") {\n          this.tableDataConfig = value.kpiConfig.dataConfig;\n\n          let tableColumns = (value.kpiConfig.dataConfig.columns) ? value.kpiConfig.dataConfig.columns : [];\n          if (tableColumns && tableColumns.length !== 0) {\n            const dataSource = value.kpiConfig.dataSource.map(obj => {\n              const newObj = { ...obj };\n              Object.keys(newObj).forEach(key => {\n\n                const foundMatchObject = tableColumns.find(obj => obj.dataField === key);\n                if (foundMatchObject) {\n                  if (foundMatchObject.enrichName && foundMatchObject.enrichName !== \"\") {\n                    console.log(foundMatchObject.enrichName);\n                    newObj[key] = this.callServiceFunction(foundMatchObject.enrichName, newObj[key])\n                  }\n                }\n\n\n                if (key.toLowerCase().includes('date') && newObj[key]) {\n                  newObj[key] = moment(newObj[key]).format(\"YYYY-MM-DD\");\n                }\n              });\n              return newObj;\n            });\n            this.dataSourseForTable = dataSource;\n          } else {\n            this.tableDataConfig.columns = (value.kpiConfig.dataSource && value.kpiConfig.dataSource.length !== 0) ? this.transformColumns(value.kpiConfig.dataSource[0]) : [];\n            this.dataSourseForTable = value.kpiConfig.dataSource;\n          }\n        }\n        setTimeout(() => {\n          this.isLoader = false;\n        }, 200);\n      } else {\n        setTimeout(() => {\n          this.dataSourseForTable = [];\n          this.tableDataConfig['columns'] = [];\n          this.isLoader = false;\n        }, 200);\n      }\n    }\n  }\n\n  constructor(public commonService: CommonService) { }\n\n  ngOnInit(): void {\n  }\n\n\n  transformColumns(mainobj: any): any[] {\n    return Object.keys(mainobj).map(key => {\n      return {\n        visible: true,\n        dataField: key,\n        caption: key\n      };\n    });\n  }\n\n\n\n  getObjectKeys(obj: any): string[] {\n    return Object.keys(obj);\n  }\n  setActiveTab(tab: string) {\n    this.activeTab = tab;\n  }\n\n  onRowClick(e) {\n\n    const title_params = e.data[this.page_config.kpiConfig.dataConfig.commonConfig['dataField']]\n    let title = this.page_config.kpiConfig.dataConfig.commonConfig['title'] + title_params;\n    let obj = {\n      data: e.data,\n      keyToPass: this.page_config.kpiConfig.keyToPass,\n      tableTitle: (this.page_parms) ? this.page_parms + title : title,\n      viewId: this.page_config.viewId,\n      drillDownType: \"natural\",\n      drilldownFrom: this.page_config.viewId,\n      drilldownTo: \"\",\n    }\n    this.oRowClick.emit(obj);\n  }\n\n  addMenuItems(e) {\n\n    const title_params = e.row.data[this.page_config.kpiConfig.dataConfig.commonConfig['dataField']]\n    let title = this.page_config.kpiConfig.dataConfig.commonConfig['title'] + title_params;\n\n    if (this.rightClickEnable && e.columnIndex == 0) {\n      if (e.target == 'content') {\n        if (!e.items) e.items = [];\n\n        this.page_config.kpiConfig.contextMenu.forEach(element => {\n          if (!this.page_config.kpiConfig.keyToPass.some(key => element.displayKey.includes(key))) {\n            e.items.push({\n              text: element.displayKey,\n              onItemClick: () => {\n                let rightclickData = {\n                  data: e.row.data,\n                  keyToPass: this.page_config.kpiConfig.keyToPass,\n                  tableTitle: (this.page_parms) ? this.page_parms + title : title,\n                  viewId: this.page_config.viewId,\n                  drillDownType: \"context\",\n                  drilldownFrom: this.page_config.viewId,\n                  drilldownTo: element.viewId,\n\n                }\n                this.onrightClickContextSelection.emit(rightclickData)\n              }\n            });\n          }\n        });\n      }\n    }\n  }\n\n  setTableHeight(value: any): any {\n  \n    const tableHeight = value;\n    if (tableHeight === 'auto') {\n      return 'auto';\n    }\n      const parsedHeight = Number(tableHeight);\n    if (!isNaN(parsedHeight) && parsedHeight > 0) {\n      return parsedHeight;\n    }\n  }\n\n\n\n  callServiceFunction(functionName: string, value): any {\n    if (typeof this.commonService[functionName] === \"function\") {\n      return this.commonService[functionName](value);\n    } else {\n      console.error(`Function ${functionName} not found in CommonService`);\n      return null;\n    }\n  }\n\n\n}\n","<div class=\"mx-2 bg-gray-800\">\n    <ng-container *ngIf=\"isLoader\">\n        <div class=\"flex justify-center items-start bg-gray-800 p-2\">\n            <app-loader></app-loader>\n        </div>\n    </ng-container>\n\n    <div class=\"mx-2 pb-2\">\n        <!-- <dx-data-grid [columnAutoWidth]=\"true\" (onRowClick)=\"onRowClick($event)\" [dataSource]=\"dataSourseForTable\"\n            [hoverStateEnabled]=\"true\" [selectedRowKeys]=\"[]\" [showBorders]=\"true\" [showColumnLines]=\"true\"\n            *ngIf=\"!isLoader\" [columns]=\"tableDataConfig.columns\" [showRowLines]=\"true\" id=\"gridContainer\"\n            (onContextMenuPreparing)=\"addMenuItems($event)\">\n            <dxo-search-panel [highlightCaseSensitive]=\"true\"\n                [visible]=\"tableDataConfig.searchPanel\"></dxo-search-panel>\n            <dxo-export [enabled]=\"true\" fileName=\"{{tableDataConfig.file_name}}\"\n                [customizeExcelCell]=\"commonService.customizeExcelCell\"></dxo-export>\n            <dxo-paging [pageSize]=\"tableDataConfig.numberOfRow\"></dxo-paging>\n            <dxo-pager [showInfo]=\"tableDataConfig.pageInfo\" [showPageSizeSelector]=\"true\"\n                [allowedPageSizes]=\"tableDataConfig.allowedPageSizes\">\n            </dxo-pager>\n            <ng-container *ngIf=\"tableDataConfig.columns && tableDataConfig.columns.length !== 0\">\n                <ng-container *ngFor=\"let item of tableDataConfig.columns\">\n                    <dxi-column *ngIf=\"item.dataField == 'recordDate'\" dataField=\"{{ item.dataField }}\"\n                        [caption]=\"item.caption\" [visible]=\"item.visible\" sortOrder=\"desc\"></dxi-column>\n                    <dxi-column *ngIf=\"item.dataField !== 'recordDate'\" format=\"#,##0.##\"\n                        [sortingMethod]=\"commonService.customValueSorter\" [cellTemplate]=\"item.dataField\"\n                        [caption]=\"item.caption\" dataField=\"{{ item.dataField }}\" alignment=\"left\"\n                        [visible]=\"item.visible\">\n                    </dxi-column>\n                </ng-container>\n                <ng-container *ngFor=\"let item of tableDataConfig.columns\">\n                    <div *dxTemplate=\"let data of item.dataField\">\n                        <span [innerHTML]=\"data.value\"></span>\n                    </div>\n                </ng-container>\n            </ng-container>\n\n        </dx-data-grid> -->\n        <dx-data-grid [columnAutoWidth]=\"true\" (onRowClick)=\"onRowClick($event)\" [dataSource]=\"dataSourseForTable\"\n            [hoverStateEnabled]=\"true\" [selectedRowKeys]=\"[]\" [showBorders]=\"true\" [showColumnLines]=\"true\" [height]=\"tableHeight\"\n            *ngIf=\"!isLoader\" [columns]=\"tableDataConfig.columns\" [showRowLines]=\"true\" id=\"gridContainer\"\n            (onContextMenuPreparing)=\"addMenuItems($event)\"\n            [customizeExportData]=\"commonService.removeHtmlContentFromData\">\n            <dxo-search-panel [highlightCaseSensitive]=\"true\"\n                [visible]=\"tableDataConfig.searchPanel\"></dxo-search-panel>\n            <dxo-export [enabled]=\"true\" fileName=\"{{tableDataConfig.file_name}}\"\n                [customizeExcelCell]=\"commonService.customizeExcelCell\"></dxo-export>\n            <dxo-paging [pageSize]=\"tableDataConfig.numberOfRow\"></dxo-paging>\n            <dxo-pager [showInfo]=\"tableDataConfig.pageInfo\" [showPageSizeSelector]=\"true\"\n                [allowedPageSizes]=\"tableDataConfig.allowedPageSizes\">\n            </dxo-pager>\n\n            <!-- <ng-container *ngFor=\"let item of tableDataConfig.columns\">\n                <dxi-column *ngIf=\"item.dataField == 'recordDate'\" dataField=\"{{ item.dataField }}\"\n                    [caption]=\"item.caption\" [visible]=\"item.visible\" sortOrder=\"desc\"></dxi-column>\n                <dxi-column *ngIf=\"item.dataField !== 'recordDate'\" [sortingMethod]=\"commonService.customValueSorter\"\n                    [cellTemplate]=\"item.dataField\" [caption]=\"item.caption\" dataField=\"{{ item.dataField }}\"\n                    alignment=\"left\" [visible]=\"item.visible\">\n                </dxi-column>\n            </ng-container> -->\n\n            <ng-container *ngFor=\"let item of tableDataConfig.columns\">\n                <!-- Check if column has nested columns (columnsOne structure) -->\n                <dxi-column *ngIf=\"item.columns; else flatColumn\" caption=\"{{ item.caption }}\">\n                    <ng-container *ngFor=\"let subItem of item.columns\">\n\n                        <dxi-column *ngIf=\"subItem.dataField == 'recordDate'\"  \n                        [dataField]=\"subItem.dataField\" [caption]=\"subItem.caption\"\n                            [visible]=\"subItem.visible\" alignment=\"left\" \n                            sortOrder=\"desc\"></dxi-column>\n\n                        <dxi-column *ngIf=\"subItem.dataField !== 'recordDate'\"  [dataField]=\"subItem.dataField\" [caption]=\"subItem.caption\"\n                            [visible]=\"subItem.visible\" alignment=\"right\" [cellTemplate]=\"item.dataField\"\n                            [sortingMethod]=\"commonService.customValueSorter\"></dxi-column>\n                    </ng-container>\n                </dxi-column>\n\n                <!-- Flat column structure (columnsTwo structure) -->\n                <ng-template #flatColumn>\n\n                    <dxi-column *ngIf=\"item.dataField == 'recordDate'\" dataField=\"{{ item.dataField }}\"\n                    [caption]=\"item.caption\" [visible]=\"item.visible\" sortOrder=\"desc\"></dxi-column>\n\n                <dxi-column *ngIf=\"item.dataField !== 'recordDate'\" [sortingMethod]=\"commonService.customValueSorter\"\n                    [cellTemplate]=\"item.dataField\" [caption]=\"item.caption\" dataField=\"{{ item.dataField }}\"\n                    alignment=\"right\" [visible]=\"item.visible\">\n                </dxi-column>\n\n\n                    <!-- <dxi-column [dataField]=\"item.dataField\" [caption]=\"item.caption\" [visible]=\"item.visible\"\n                        [cellTemplate]=\"item.dataField\" alignment=\"left\"\n                        [sortingMethod]=\"commonService.customValueSorter\"></dxi-column> -->\n                </ng-template>\n            </ng-container>\n\n            <ng-container *ngFor=\"let item of tableDataConfig.columns\">\n                <div *dxTemplate=\"let data of item.dataField\">\n                    <span [innerHTML]=\"data.value\"></span>\n                </div>\n            </ng-container>\n        </dx-data-grid>\n\n    </div>\n\n\n</div>"]}
|
|
177
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gamma-advance-operator-table.component.js","sourceRoot":"","sources":["../../../../../../../../projects/gamma-app-controller/src/lib/application-controller/shared/advanced-component/gamma-advance-operator-table/gamma-advance-operator-table.component.ts","../../../../../../../../projects/gamma-app-controller/src/lib/application-controller/shared/advanced-component/gamma-advance-operator-table/gamma-advance-operator-table.component.html"],"names":[],"mappings":"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","sourcesContent":["\n\n\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport moment from './../../../moment-helper';\nimport { CommonService } from '../../../common';\n\n@Component({\n  selector: 'app-gamma-advance-operator-table',\n  templateUrl: './gamma-advance-operator-table.component.html',\n  styleUrls: ['./gamma-advance-operator-table.component.scss']\n})\nexport class GammaAdvanceOperatorTableComponent implements OnInit {\n\nisJsonPreview: boolean\n  dataSourseForTable: any = [];\n  jsaonDatasource: any;\n  configColume: any;\n  isLoader: boolean = true;\n  tableDataConfig: any = {};\n  enrichNameList = [\"formatBytes\", \"formatBytsToKb\", \"formatBytsToGb\", \"reformatNumberWithThousandSeparatorV3\"]\n  page_config: any;\n  page_parms: any;\n  page_selected_operator: any;\n\n  tableHeight: any;\n\n  \n  activeTab: string = 'basic';\n  @Output() public getTableConfigOutPut: EventEmitter<any> = new EventEmitter();\n  @Output() public oRowClick: EventEmitter<any> = new EventEmitter();\n  @Output() public onrightClickContextSelection: EventEmitter<any> = new EventEmitter();\n  @Input() rightClickEnable: boolean = true;\n\n  @Input('chartDataSource')\n  set chartDataSource(value) {\n    if (value === undefined || value.length === 0) {\n      return;\n    } else {\n      this.isLoader = true;\n      this.page_config = value;\n      this.page_parms = value.titleParams;\n      this.tableHeight = (value.kpiConfig.dataConfig.tableHeight && value.kpiConfig.dataConfig.tableHeight !== \"\")? this.setTableHeight(value.kpiConfig.dataConfig.tableHeight):'auto';\n\n      if (value.kpiConfig.dataSource && value.kpiConfig.dataSource.length !== 0) {\n\n        if (value.kpiConfig.formate == \"daily\") {\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 === mostRecentRecord.recordDate);\n          this.dataSourseForTable = filteredObjects;\n\n        } else if (value.kpiConfig.formate == \"monthly\") {\n          this.tableDataConfig = value.kpiConfig.dataConfig;\n\n          let tableColumns = (value.kpiConfig.dataConfig.columns) ? value.kpiConfig.dataConfig.columns : [];\n          if (tableColumns && tableColumns.length !== 0) {\n            const dataSource = value.kpiConfig.dataSource.map(obj => {\n              const newObj = { ...obj };\n              Object.keys(newObj).forEach(key => {\n\n                const foundMatchObject = tableColumns.find(obj => obj.dataField === key);\n                if (foundMatchObject) {\n                  if (foundMatchObject.enrichName && foundMatchObject.enrichName !== \"\") {\n                    newObj[key] = this.callServiceFunction(foundMatchObject.enrichName, newObj[key])\n                  }\n                }\n\n\n                if (key.toLowerCase().includes('date') && newObj[key]) {\n                  newObj[key] = moment(newObj[key]).format(\"YYYY-MM-DD\");\n                }\n              });\n              return newObj;\n            });\n            this.dataSourseForTable = dataSource;\n          } else {\n            this.tableDataConfig.columns = (value.kpiConfig.dataSource && value.kpiConfig.dataSource.length !== 0) ? this.transformColumns(value.kpiConfig.dataSource[0]) : [];\n            this.dataSourseForTable = value.kpiConfig.dataSource;\n          }\n        }\n        setTimeout(() => {\n          this.isLoader = false;\n        }, 200);\n      } else {\n        setTimeout(() => {\n          this.dataSourseForTable = [];\n          this.tableDataConfig['columns'] = [];\n          this.isLoader = false;\n        }, 200);\n      }\n    }\n  }\n\n  constructor(public commonService: CommonService) { }\n\n  ngOnInit(): void {\n  }\n\n\n  transformColumns(mainobj: any): any[] {\n    return Object.keys(mainobj).map(key => {\n      return {\n        visible: true,\n        dataField: key,\n        caption: key\n      };\n    });\n  }\n\n\n\n  getObjectKeys(obj: any): string[] {\n    return Object.keys(obj);\n  }\n  setActiveTab(tab: string) {\n    this.activeTab = tab;\n  }\n\n  onRowClick(e) {\n\n    const title_params = e.data[this.page_config.kpiConfig.dataConfig.commonConfig['dataField']]\n    let title = this.page_config.kpiConfig.dataConfig.commonConfig['title'] + title_params;\n    let obj = {\n      data: e.data,\n      keyToPass: this.page_config.kpiConfig.keyToPass,\n      tableTitle: (this.page_parms) ? this.page_parms + title : title,\n      viewId: this.page_config.viewId,\n      drillDownType: \"natural\",\n      drilldownFrom: this.page_config.viewId,\n      drilldownTo: \"\",\n    }\n    this.oRowClick.emit(obj);\n  }\n\n  addMenuItems(e) {\n\n    const title_params = e.row.data[this.page_config.kpiConfig.dataConfig.commonConfig['dataField']]\n    let title = this.page_config.kpiConfig.dataConfig.commonConfig['title'] + title_params;\n\n    if (this.rightClickEnable && e.columnIndex == 0) {\n      if (e.target == 'content') {\n        if (!e.items) e.items = [];\n\n        this.page_config.kpiConfig.contextMenu.forEach(element => {\n          if (!this.page_config.kpiConfig.keyToPass.some(key => element.displayKey.includes(key))) {\n            e.items.push({\n              text: element.displayKey,\n              onItemClick: () => {\n                let rightclickData = {\n                  data: e.row.data,\n                  keyToPass: this.page_config.kpiConfig.keyToPass,\n                  tableTitle: (this.page_parms) ? this.page_parms + title : title,\n                  viewId: this.page_config.viewId,\n                  drillDownType: \"context\",\n                  drilldownFrom: this.page_config.viewId,\n                  drilldownTo: element.viewId,\n\n                }\n                this.onrightClickContextSelection.emit(rightclickData)\n              }\n            });\n          }\n        });\n      }\n    }\n  }\n\n  setTableHeight(value: any): any {\n  \n    const tableHeight = value;\n    if (tableHeight === 'auto') {\n      return 'auto';\n    }\n      const parsedHeight = Number(tableHeight);\n    if (!isNaN(parsedHeight) && parsedHeight > 0) {\n      return parsedHeight;\n    }\n  }\n\n\n\n  callServiceFunction(functionName: string, value): any {\n    if (typeof this.commonService[functionName] === \"function\") {\n      return this.commonService[functionName](value);\n    } else {\n      console.error(`Function ${functionName} not found in CommonService`);\n      return null;\n    }\n  }\n\n\n}\n","<div class=\"mx-2 bg-gray-800\">\n    <ng-container *ngIf=\"isLoader\">\n        <div class=\"flex justify-center items-start bg-gray-800 p-2\">\n            <app-loader></app-loader>\n        </div>\n    </ng-container>\n\n    <div class=\"mx-2 pb-2\">\n        <!-- <dx-data-grid [columnAutoWidth]=\"true\" (onRowClick)=\"onRowClick($event)\" [dataSource]=\"dataSourseForTable\"\n            [hoverStateEnabled]=\"true\" [selectedRowKeys]=\"[]\" [showBorders]=\"true\" [showColumnLines]=\"true\"\n            *ngIf=\"!isLoader\" [columns]=\"tableDataConfig.columns\" [showRowLines]=\"true\" id=\"gridContainer\"\n            (onContextMenuPreparing)=\"addMenuItems($event)\">\n            <dxo-search-panel [highlightCaseSensitive]=\"true\"\n                [visible]=\"tableDataConfig.searchPanel\"></dxo-search-panel>\n            <dxo-export [enabled]=\"true\" fileName=\"{{tableDataConfig.file_name}}\"\n                [customizeExcelCell]=\"commonService.customizeExcelCell\"></dxo-export>\n            <dxo-paging [pageSize]=\"tableDataConfig.numberOfRow\"></dxo-paging>\n            <dxo-pager [showInfo]=\"tableDataConfig.pageInfo\" [showPageSizeSelector]=\"true\"\n                [allowedPageSizes]=\"tableDataConfig.allowedPageSizes\">\n            </dxo-pager>\n            <ng-container *ngIf=\"tableDataConfig.columns && tableDataConfig.columns.length !== 0\">\n                <ng-container *ngFor=\"let item of tableDataConfig.columns\">\n                    <dxi-column *ngIf=\"item.dataField == 'recordDate'\" dataField=\"{{ item.dataField }}\"\n                        [caption]=\"item.caption\" [visible]=\"item.visible\" sortOrder=\"desc\"></dxi-column>\n                    <dxi-column *ngIf=\"item.dataField !== 'recordDate'\" format=\"#,##0.##\"\n                        [sortingMethod]=\"commonService.customValueSorter\" [cellTemplate]=\"item.dataField\"\n                        [caption]=\"item.caption\" dataField=\"{{ item.dataField }}\" alignment=\"left\"\n                        [visible]=\"item.visible\">\n                    </dxi-column>\n                </ng-container>\n                <ng-container *ngFor=\"let item of tableDataConfig.columns\">\n                    <div *dxTemplate=\"let data of item.dataField\">\n                        <span [innerHTML]=\"data.value\"></span>\n                    </div>\n                </ng-container>\n            </ng-container>\n\n        </dx-data-grid> -->\n        <dx-data-grid [columnAutoWidth]=\"true\" (onRowClick)=\"onRowClick($event)\" [dataSource]=\"dataSourseForTable\"\n            [hoverStateEnabled]=\"true\" [selectedRowKeys]=\"[]\" [showBorders]=\"true\" [showColumnLines]=\"true\" [height]=\"tableHeight\"\n            *ngIf=\"!isLoader\" [columns]=\"tableDataConfig.columns\" [showRowLines]=\"true\" id=\"gridContainer\"\n            (onContextMenuPreparing)=\"addMenuItems($event)\"\n            [customizeExportData]=\"commonService.removeHtmlContentFromData\">\n            <dxo-search-panel [highlightCaseSensitive]=\"true\"\n                [visible]=\"tableDataConfig.searchPanel\"></dxo-search-panel>\n            <dxo-export [enabled]=\"true\" fileName=\"{{tableDataConfig.file_name}}\"\n                [customizeExcelCell]=\"commonService.customizeExcelCell\"></dxo-export>\n            <dxo-paging [pageSize]=\"tableDataConfig.numberOfRow\"></dxo-paging>\n            <dxo-pager [showInfo]=\"tableDataConfig.pageInfo\" [showPageSizeSelector]=\"true\"\n                [allowedPageSizes]=\"tableDataConfig.allowedPageSizes\">\n            </dxo-pager>\n\n            <!-- <ng-container *ngFor=\"let item of tableDataConfig.columns\">\n                <dxi-column *ngIf=\"item.dataField == 'recordDate'\" dataField=\"{{ item.dataField }}\"\n                    [caption]=\"item.caption\" [visible]=\"item.visible\" sortOrder=\"desc\"></dxi-column>\n                <dxi-column *ngIf=\"item.dataField !== 'recordDate'\" [sortingMethod]=\"commonService.customValueSorter\"\n                    [cellTemplate]=\"item.dataField\" [caption]=\"item.caption\" dataField=\"{{ item.dataField }}\"\n                    alignment=\"left\" [visible]=\"item.visible\">\n                </dxi-column>\n            </ng-container> -->\n\n            <ng-container *ngFor=\"let item of tableDataConfig.columns\">\n                <!-- Check if column has nested columns (columnsOne structure) -->\n                <dxi-column *ngIf=\"item.columns; else flatColumn\" caption=\"{{ item.caption }}\">\n                    <ng-container *ngFor=\"let subItem of item.columns\">\n\n                        <dxi-column *ngIf=\"subItem.dataField == 'recordDate'\"  \n                        [dataField]=\"subItem.dataField\" [caption]=\"subItem.caption\"\n                            [visible]=\"subItem.visible\" alignment=\"left\" \n                            sortOrder=\"desc\"></dxi-column>\n\n                        <dxi-column *ngIf=\"subItem.dataField !== 'recordDate'\"  [dataField]=\"subItem.dataField\" [caption]=\"subItem.caption\"\n                            [visible]=\"subItem.visible\" alignment=\"right\" [cellTemplate]=\"item.dataField\"\n                            [sortingMethod]=\"commonService.customValueSorter\"></dxi-column>\n                    </ng-container>\n                </dxi-column>\n\n                <!-- Flat column structure (columnsTwo structure) -->\n                <ng-template #flatColumn>\n\n                    <dxi-column *ngIf=\"item.dataField == 'recordDate'\" dataField=\"{{ item.dataField }}\"\n                    [caption]=\"item.caption\" [visible]=\"item.visible\" sortOrder=\"desc\"></dxi-column>\n\n                <dxi-column *ngIf=\"item.dataField !== 'recordDate'\" [sortingMethod]=\"commonService.customValueSorter\"\n                    [cellTemplate]=\"item.dataField\" [caption]=\"item.caption\" dataField=\"{{ item.dataField }}\"\n                    alignment=\"right\" [visible]=\"item.visible\">\n                </dxi-column>\n\n\n                    <!-- <dxi-column [dataField]=\"item.dataField\" [caption]=\"item.caption\" [visible]=\"item.visible\"\n                        [cellTemplate]=\"item.dataField\" alignment=\"left\"\n                        [sortingMethod]=\"commonService.customValueSorter\"></dxi-column> -->\n                </ng-template>\n            </ng-container>\n\n            <ng-container *ngFor=\"let item of tableDataConfig.columns\">\n                <div *dxTemplate=\"let data of item.dataField\">\n                    <span [innerHTML]=\"data.value\"></span>\n                </div>\n            </ng-container>\n        </dx-data-grid>\n\n    </div>\n\n\n</div>"]}
|
|
@@ -0,0 +1,328 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import moment from './../../../moment-helper';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../../../common";
|
|
5
|
+
import * as i2 from "@angular/common";
|
|
6
|
+
import * as i3 from "../../loader/loader.component";
|
|
7
|
+
export class GammaHeatChartComponent {
|
|
8
|
+
constructor(commonService) {
|
|
9
|
+
this.commonService = commonService;
|
|
10
|
+
this.dataSourseForTable = [];
|
|
11
|
+
this.isLoader = true;
|
|
12
|
+
this.tableDataConfig = {};
|
|
13
|
+
this.enrichNameList = ["formatBytes", "formatBytsToKb", "formatBytsToGb", "reformatNumberWithThousandSeparatorV3", "formatBytesv2"];
|
|
14
|
+
this.activeTab = 'basic';
|
|
15
|
+
this.isAdvanceFilter = false;
|
|
16
|
+
this.isHeatMapClick = false;
|
|
17
|
+
this.heatChartDataSource = {};
|
|
18
|
+
this.chartDataForTooltip = {};
|
|
19
|
+
this.dataSourseForHeatMap = [];
|
|
20
|
+
this.viewProperties = {
|
|
21
|
+
enableClickEvent: false,
|
|
22
|
+
enableRightClickEvent: true,
|
|
23
|
+
clickEventOptions: {
|
|
24
|
+
associatedViews: [],
|
|
25
|
+
eventType: ""
|
|
26
|
+
}
|
|
27
|
+
};
|
|
28
|
+
this.optionalDrilDownDataSource = [];
|
|
29
|
+
this.allConfiguredViews = [];
|
|
30
|
+
this.colorArray = [];
|
|
31
|
+
this.firstColor = "rgba(45, 110, 18, 1)";
|
|
32
|
+
this.secondColor = "rgba(255, 204, 0, 1)";
|
|
33
|
+
this.singleColor = "rgba(255, 204, 0, 1)";
|
|
34
|
+
this.heatmapChartConfig = {};
|
|
35
|
+
this.getTableConfigOutPut = new EventEmitter();
|
|
36
|
+
this.oRowClick = new EventEmitter();
|
|
37
|
+
this.onrightClickContextSelection = new EventEmitter();
|
|
38
|
+
this.rightClickEnable = true;
|
|
39
|
+
}
|
|
40
|
+
set chartDataSource(value) {
|
|
41
|
+
if (value === undefined || value.length === 0) {
|
|
42
|
+
return;
|
|
43
|
+
}
|
|
44
|
+
else {
|
|
45
|
+
this.isLoader = true;
|
|
46
|
+
this.page_config = value;
|
|
47
|
+
this.page_parms = value.titleParams;
|
|
48
|
+
if (value.kpiConfig.dataSource && value.kpiConfig.dataSource.length !== 0) {
|
|
49
|
+
this.heatmapChartConfig = value.kpiConfig.dataConfig;
|
|
50
|
+
this.colorArray = value.kpiConfig.dataConfig.color;
|
|
51
|
+
this.getHeatmapData(value.kpiConfig.dataSource);
|
|
52
|
+
setTimeout(() => {
|
|
53
|
+
this.isLoader = false;
|
|
54
|
+
}, 200);
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
setTimeout(() => {
|
|
58
|
+
this.dataSourseForTable = [];
|
|
59
|
+
this.tableDataConfig['columns'] = [];
|
|
60
|
+
this.isLoader = false;
|
|
61
|
+
}, 200);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
ngOnInit() {
|
|
66
|
+
}
|
|
67
|
+
getHeatmapData(heatMapData) {
|
|
68
|
+
this.heatChartDataSource = {};
|
|
69
|
+
this.isAdvanceFilter = false;
|
|
70
|
+
if (heatMapData && heatMapData.length !== 0) {
|
|
71
|
+
if (this.heatmapChartConfig.chartFormat == "topx") {
|
|
72
|
+
const { result, uniqueDates } = this.generateDateWiseColorCodedData(heatMapData);
|
|
73
|
+
uniqueDates.sort();
|
|
74
|
+
this.heatChartDataSource.dataSet = this.getTransposedHeatmapData(result);
|
|
75
|
+
this.heatChartDataSource["argumentValue"] = uniqueDates;
|
|
76
|
+
}
|
|
77
|
+
else if ((this.heatmapChartConfig.chartFormat == "simple")) {
|
|
78
|
+
const { result, uniqueDates } = this.generateData(heatMapData);
|
|
79
|
+
uniqueDates.sort();
|
|
80
|
+
this.heatChartDataSource["dataSet"] = result;
|
|
81
|
+
this.heatChartDataSource["argumentValue"] = uniqueDates;
|
|
82
|
+
}
|
|
83
|
+
this.isHeatMapClick = false;
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
this.isHeatMapClick = false;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
getTransposedHeatmapData(dataSet) {
|
|
90
|
+
const transposed = [];
|
|
91
|
+
const maxBoxes = Math.max(...dataSet.map(item => item.dataset.length));
|
|
92
|
+
for (let i = 0; i < maxBoxes; i++) {
|
|
93
|
+
const row = [];
|
|
94
|
+
for (let j = 0; j < dataSet.length; j++) {
|
|
95
|
+
const box = dataSet[j].dataset[i];
|
|
96
|
+
row.push({
|
|
97
|
+
box: box || null,
|
|
98
|
+
date: dataSet[j].record_date
|
|
99
|
+
});
|
|
100
|
+
}
|
|
101
|
+
transposed.push(row);
|
|
102
|
+
}
|
|
103
|
+
return transposed;
|
|
104
|
+
}
|
|
105
|
+
generateDateWiseColorCodedData(data) {
|
|
106
|
+
const result = [];
|
|
107
|
+
const uniqueDates = new Set();
|
|
108
|
+
const allEntries = [];
|
|
109
|
+
const topArg = this.heatmapChartConfig.topArgument;
|
|
110
|
+
const leftArg = this.heatmapChartConfig.leftArgument;
|
|
111
|
+
const valueField = this.heatmapChartConfig.columns[0].dataField;
|
|
112
|
+
data.forEach(entry => {
|
|
113
|
+
const formattedDate = (moment(entry[topArg]).format('YYYY-MM-DD')) ? moment(entry[topArg]).format('YYYY-MM-DD') : topArg;
|
|
114
|
+
uniqueDates.add(formattedDate);
|
|
115
|
+
entry.resultDataset.forEach(item => {
|
|
116
|
+
allEntries.push({
|
|
117
|
+
[topArg]: formattedDate,
|
|
118
|
+
[leftArg]: item[`${leftArg}`],
|
|
119
|
+
[valueField]: item[`${valueField}`]
|
|
120
|
+
});
|
|
121
|
+
});
|
|
122
|
+
});
|
|
123
|
+
let coloredData;
|
|
124
|
+
if (this.heatmapChartConfig.type === 'gradient') {
|
|
125
|
+
coloredData = this.getFormateDataByColorCodeForGradient(allEntries, valueField);
|
|
126
|
+
}
|
|
127
|
+
else if (this.heatmapChartConfig.type === 'twoColor') {
|
|
128
|
+
coloredData = this.getFormateDataByColorCodeForWithTwoColor(allEntries, valueField);
|
|
129
|
+
}
|
|
130
|
+
else {
|
|
131
|
+
coloredData = this.getFormateDataByColorCodeForWithSingleColor(allEntries, valueField);
|
|
132
|
+
}
|
|
133
|
+
const dateMap = {};
|
|
134
|
+
coloredData.forEach(item => {
|
|
135
|
+
const date = item[topArg];
|
|
136
|
+
if (!dateMap[date]) {
|
|
137
|
+
dateMap[date] = [];
|
|
138
|
+
}
|
|
139
|
+
dateMap[date].push({
|
|
140
|
+
[leftArg]: item[leftArg],
|
|
141
|
+
[valueField]: item[valueField],
|
|
142
|
+
color: item.color,
|
|
143
|
+
[topArg]: date,
|
|
144
|
+
});
|
|
145
|
+
});
|
|
146
|
+
for (const date of Array.from(uniqueDates).sort()) {
|
|
147
|
+
result.push({
|
|
148
|
+
record_date: date,
|
|
149
|
+
dataset: dateMap[date] || []
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
return {
|
|
153
|
+
result,
|
|
154
|
+
uniqueDates: Array.from(uniqueDates).sort()
|
|
155
|
+
};
|
|
156
|
+
}
|
|
157
|
+
generateData(data) {
|
|
158
|
+
const result = [];
|
|
159
|
+
const uniqueDates = new Set();
|
|
160
|
+
const dataSourceMap = {};
|
|
161
|
+
const topArg = this.heatmapChartConfig.topArgument;
|
|
162
|
+
const leftArg = this.heatmapChartConfig.leftArgument;
|
|
163
|
+
data.forEach(item => {
|
|
164
|
+
const rowKey = item[leftArg];
|
|
165
|
+
const columnKey = moment(item[topArg]).format('YYYY-MM-DD');
|
|
166
|
+
if (!dataSourceMap[rowKey]) {
|
|
167
|
+
dataSourceMap[rowKey] = {
|
|
168
|
+
datasource: rowKey,
|
|
169
|
+
dataset: []
|
|
170
|
+
};
|
|
171
|
+
}
|
|
172
|
+
dataSourceMap[rowKey].dataset.push({
|
|
173
|
+
...item,
|
|
174
|
+
[topArg]: columnKey
|
|
175
|
+
});
|
|
176
|
+
uniqueDates.add(columnKey);
|
|
177
|
+
});
|
|
178
|
+
const uniqueDatesArray = Array.from(uniqueDates);
|
|
179
|
+
for (const key in dataSourceMap) {
|
|
180
|
+
const dataset = dataSourceMap[key].dataset;
|
|
181
|
+
let formattedDataset;
|
|
182
|
+
if (this.heatmapChartConfig.type == "gradient") {
|
|
183
|
+
formattedDataset = this.getFormateDataByColorCodeForGradient(dataset, this.heatmapChartConfig.columns[0].dataField);
|
|
184
|
+
}
|
|
185
|
+
else if (this.heatmapChartConfig.type == "twoColor") {
|
|
186
|
+
formattedDataset = this.getFormateDataByColorCodeForWithTwoColor(dataset, this.heatmapChartConfig.columns[0].dataField);
|
|
187
|
+
}
|
|
188
|
+
else {
|
|
189
|
+
formattedDataset = this.getFormateDataByColorCodeForWithSingleColor(dataset, this.heatmapChartConfig.columns[0].dataField);
|
|
190
|
+
}
|
|
191
|
+
const dateToItemMap = {};
|
|
192
|
+
formattedDataset.forEach(item => {
|
|
193
|
+
dateToItemMap[item[topArg]] = item;
|
|
194
|
+
});
|
|
195
|
+
const completeDataset = uniqueDatesArray.map((date) => {
|
|
196
|
+
if (dateToItemMap[date]) {
|
|
197
|
+
return dateToItemMap[date];
|
|
198
|
+
}
|
|
199
|
+
else {
|
|
200
|
+
return {
|
|
201
|
+
[topArg]: date,
|
|
202
|
+
avgSize: "No Data",
|
|
203
|
+
fileCount: 0,
|
|
204
|
+
fileSize: 0,
|
|
205
|
+
color: "rgb(242, 118, 109)"
|
|
206
|
+
};
|
|
207
|
+
}
|
|
208
|
+
});
|
|
209
|
+
result.push({
|
|
210
|
+
datasource: key,
|
|
211
|
+
dataset: completeDataset
|
|
212
|
+
});
|
|
213
|
+
}
|
|
214
|
+
return {
|
|
215
|
+
result: result,
|
|
216
|
+
uniqueDates: uniqueDatesArray
|
|
217
|
+
};
|
|
218
|
+
}
|
|
219
|
+
getFormateDataByColorCodeForGradient(filedata, column) {
|
|
220
|
+
filedata.forEach(item => {
|
|
221
|
+
item.avgSize = parseFloat(item[column]);
|
|
222
|
+
});
|
|
223
|
+
const maxAvgSize = Math.max(...filedata.map(item => item[column]));
|
|
224
|
+
const minAvgSize = Math.min(...filedata.map(item => item[column]));
|
|
225
|
+
const [minColorStr, maxColorStr] = this.colorArray || ["rgba(45, 110, 18,1)", "rgba(255, 204, 0,1)"];
|
|
226
|
+
const minColor = this.parseRGBA(minColorStr);
|
|
227
|
+
const maxColor = this.parseRGBA(maxColorStr);
|
|
228
|
+
filedata.forEach(item => {
|
|
229
|
+
item.color = this.calculateColor(item[column], minAvgSize, maxAvgSize, minColor, maxColor);
|
|
230
|
+
});
|
|
231
|
+
return filedata;
|
|
232
|
+
}
|
|
233
|
+
getFormateDataByColorCodeForWithTwoColor(filedata, column) {
|
|
234
|
+
filedata.forEach(item => {
|
|
235
|
+
item[column] = parseFloat(item[column]);
|
|
236
|
+
});
|
|
237
|
+
const [minColorStr, maxColorStr] = this.colorArray || ["rgba(45, 110, 18,1)", "rgba(255, 204, 0,1)"];
|
|
238
|
+
const minColor = this.parseRGBA(minColorStr);
|
|
239
|
+
const maxColor = this.parseRGBA(maxColorStr);
|
|
240
|
+
filedata.forEach(item => {
|
|
241
|
+
if (item[column] == 0) {
|
|
242
|
+
item.color = `rgb(${minColor.join(',')})`;
|
|
243
|
+
}
|
|
244
|
+
else {
|
|
245
|
+
item.color = `rgb(${maxColor.join(',')})`;
|
|
246
|
+
}
|
|
247
|
+
});
|
|
248
|
+
return filedata;
|
|
249
|
+
}
|
|
250
|
+
getFormateDataByColorCodeForWithSingleColor(filedata, column) {
|
|
251
|
+
filedata.forEach(item => {
|
|
252
|
+
item[column] = parseFloat(item[column]);
|
|
253
|
+
});
|
|
254
|
+
const [singleColor] = this.colorArray || ["rgba(255, 204, 0,1)"];
|
|
255
|
+
const minColor = this.parseRGBA(singleColor);
|
|
256
|
+
filedata.forEach(item => {
|
|
257
|
+
item.color = `rgb(${minColor.join(',')})`;
|
|
258
|
+
});
|
|
259
|
+
return filedata;
|
|
260
|
+
}
|
|
261
|
+
parseRGBA(colorStr) {
|
|
262
|
+
const values = colorStr.match(/[\d.]+/g)?.map(Number) || [];
|
|
263
|
+
if (values.length === 3)
|
|
264
|
+
values.push(1);
|
|
265
|
+
return [
|
|
266
|
+
values[0] ?? 0,
|
|
267
|
+
values[1] ?? 0,
|
|
268
|
+
values[2] ?? 0,
|
|
269
|
+
values[3] ?? 1
|
|
270
|
+
];
|
|
271
|
+
}
|
|
272
|
+
calculateColor(avgSize, minAvgSize, maxAvgSize, minColor, maxColor) {
|
|
273
|
+
if (minAvgSize != maxAvgSize) {
|
|
274
|
+
let gradient = (avgSize - minAvgSize) / (maxAvgSize - minAvgSize);
|
|
275
|
+
let color = minColor.map((channel, index) => {
|
|
276
|
+
return Math.round(channel + gradient * (maxColor[index] - channel));
|
|
277
|
+
});
|
|
278
|
+
return `rgb(${color.join(',')})`;
|
|
279
|
+
}
|
|
280
|
+
else {
|
|
281
|
+
return `rgb(${minColor.join(',')})`;
|
|
282
|
+
}
|
|
283
|
+
}
|
|
284
|
+
transformColumns(mainobj) {
|
|
285
|
+
return Object.keys(mainobj).map(key => {
|
|
286
|
+
return {
|
|
287
|
+
visible: true,
|
|
288
|
+
dataField: key,
|
|
289
|
+
caption: key
|
|
290
|
+
};
|
|
291
|
+
});
|
|
292
|
+
}
|
|
293
|
+
getObjectKeys(obj) {
|
|
294
|
+
return Object.keys(obj);
|
|
295
|
+
}
|
|
296
|
+
callServiceFunction(functionName, value) {
|
|
297
|
+
if (value !== undefined) {
|
|
298
|
+
if (typeof this.commonService[functionName] === "function") {
|
|
299
|
+
return this.commonService[functionName](value);
|
|
300
|
+
}
|
|
301
|
+
else {
|
|
302
|
+
console.error(`Function ${functionName} not found in CommonService`);
|
|
303
|
+
return null;
|
|
304
|
+
}
|
|
305
|
+
}
|
|
306
|
+
else {
|
|
307
|
+
return "No Data";
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
GammaHeatChartComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: GammaHeatChartComponent, deps: [{ token: i1.CommonService }], target: i0.ɵɵFactoryTarget.Component });
|
|
312
|
+
GammaHeatChartComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: GammaHeatChartComponent, selector: "app-gamma-heatmap", inputs: { rightClickEnable: "rightClickEnable", chartDataSource: "chartDataSource" }, outputs: { getTableConfigOutPut: "getTableConfigOutPut", oRowClick: "oRowClick", onrightClickContextSelection: "onrightClickContextSelection" }, ngImport: i0, template: "<div class=\"mx-2 bg-gray-800\">\n <app-loader *ngIf=\"isLoader\"></app-loader>\n <ng-container *ngIf=\"!isLoader\">\n <ng-container *ngIf=\"heatmapChartConfig.chartFormat == 'simple'\">\n <div class=\"mx-5 h-[60vh] overflow-x-auto\">\n <div class=\"inline-block\">\n <div class=\"flex flex-nowrap justify-center\">\n <div class=\"flex-shrink-0 w-64 max-w-[20%] h-10 flex items-center justify-center\"></div>\n <div *ngFor=\"let item of heatChartDataSource.argumentValue\"\n class=\"flex-shrink-0 min-w-22 max-w-[20%] h-8 text-sm flex items-center justify-center\">\n {{item}}\n </div>\n </div>\n </div>\n <ng-container *ngFor=\"let item of heatChartDataSource.dataSet\">\n <div class=\"flex flex-row\">\n <div class=\"h-8 flex text-sm items-center min-w-64 justify-end px-2 inline\">\n {{ item.datasource }}\n </div>\n <div class=\"inline-block\">\n <div class=\"flex flex-nowrap justify-start\">\n <ng-container *ngFor=\"let box of item.dataset\">\n <div class=\"flex-shrink-0 min-w-22 max-w-[20%] h-8 border-2 text-sm cursor-pointer flex items-center justify-center text-gray-800\"\n [ngStyle]=\"{ 'background-color': box.color }\"\n [attr.title]=\"'Record Date: ' + box[heatmapChartConfig.topArgument] + ', Value: ' + box[heatmapChartConfig.columns[0].dataField]\">\n {{ box[heatmapChartConfig.columns[0].dataField]}}\n </div>\n </ng-container>\n </div>\n </div>\n </div>\n </ng-container>\n </div>\n </ng-container>\n <ng-container *ngIf=\"heatmapChartConfig.chartFormat == 'topx'\">\n <div class=\"mx-5 h-[60vh] overflow-x-auto\">\n <div class=\"flex flex-row\">\n <ng-container *ngFor=\"let header of heatChartDataSource.argumentValue\">\n <div class=\"min-w-32 text-sm font-medium text-center mb-2\">\n {{ header }}\n </div>\n </ng-container>\n </div>\n\n <div *ngFor=\"let row of heatChartDataSource.dataSet\" class=\"flex flex-row\">\n <ng-container *ngFor=\"let cell of row\">\n <div *ngIf=\"cell.box\"\n class=\"h-8 border-2 text-sm cursor-pointer flex items-center justify-center text-gray-800 min-w-32\"\n [ngStyle]=\"{ 'background-color': cell.box.color }\"\n [attr.title]=\"'Record Date: ' + cell.box[heatmapChartConfig.topArgument] + ', Value: ' + cell.box[heatmapChartConfig.columns[0].dataField]\">\n {{ cell.box[heatmapChartConfig.leftArgument] }} ({{\n commonService.abbreviateNumber(cell.box[heatmapChartConfig.columns[0].dataField]) }})\n </div>\n <div *ngIf=\"!cell.box\" class=\"h-8 min-w-32\"></div>\n </ng-container>\n </div>\n </div>\n </ng-container>\n </ng-container>\n</div>", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3.LoaderComponent, selector: "app-loader" }] });
|
|
313
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: GammaHeatChartComponent, decorators: [{
|
|
314
|
+
type: Component,
|
|
315
|
+
args: [{ selector: 'app-gamma-heatmap', template: "<div class=\"mx-2 bg-gray-800\">\n <app-loader *ngIf=\"isLoader\"></app-loader>\n <ng-container *ngIf=\"!isLoader\">\n <ng-container *ngIf=\"heatmapChartConfig.chartFormat == 'simple'\">\n <div class=\"mx-5 h-[60vh] overflow-x-auto\">\n <div class=\"inline-block\">\n <div class=\"flex flex-nowrap justify-center\">\n <div class=\"flex-shrink-0 w-64 max-w-[20%] h-10 flex items-center justify-center\"></div>\n <div *ngFor=\"let item of heatChartDataSource.argumentValue\"\n class=\"flex-shrink-0 min-w-22 max-w-[20%] h-8 text-sm flex items-center justify-center\">\n {{item}}\n </div>\n </div>\n </div>\n <ng-container *ngFor=\"let item of heatChartDataSource.dataSet\">\n <div class=\"flex flex-row\">\n <div class=\"h-8 flex text-sm items-center min-w-64 justify-end px-2 inline\">\n {{ item.datasource }}\n </div>\n <div class=\"inline-block\">\n <div class=\"flex flex-nowrap justify-start\">\n <ng-container *ngFor=\"let box of item.dataset\">\n <div class=\"flex-shrink-0 min-w-22 max-w-[20%] h-8 border-2 text-sm cursor-pointer flex items-center justify-center text-gray-800\"\n [ngStyle]=\"{ 'background-color': box.color }\"\n [attr.title]=\"'Record Date: ' + box[heatmapChartConfig.topArgument] + ', Value: ' + box[heatmapChartConfig.columns[0].dataField]\">\n {{ box[heatmapChartConfig.columns[0].dataField]}}\n </div>\n </ng-container>\n </div>\n </div>\n </div>\n </ng-container>\n </div>\n </ng-container>\n <ng-container *ngIf=\"heatmapChartConfig.chartFormat == 'topx'\">\n <div class=\"mx-5 h-[60vh] overflow-x-auto\">\n <div class=\"flex flex-row\">\n <ng-container *ngFor=\"let header of heatChartDataSource.argumentValue\">\n <div class=\"min-w-32 text-sm font-medium text-center mb-2\">\n {{ header }}\n </div>\n </ng-container>\n </div>\n\n <div *ngFor=\"let row of heatChartDataSource.dataSet\" class=\"flex flex-row\">\n <ng-container *ngFor=\"let cell of row\">\n <div *ngIf=\"cell.box\"\n class=\"h-8 border-2 text-sm cursor-pointer flex items-center justify-center text-gray-800 min-w-32\"\n [ngStyle]=\"{ 'background-color': cell.box.color }\"\n [attr.title]=\"'Record Date: ' + cell.box[heatmapChartConfig.topArgument] + ', Value: ' + cell.box[heatmapChartConfig.columns[0].dataField]\">\n {{ cell.box[heatmapChartConfig.leftArgument] }} ({{\n commonService.abbreviateNumber(cell.box[heatmapChartConfig.columns[0].dataField]) }})\n </div>\n <div *ngIf=\"!cell.box\" class=\"h-8 min-w-32\"></div>\n </ng-container>\n </div>\n </div>\n </ng-container>\n </ng-container>\n</div>" }]
|
|
316
|
+
}], ctorParameters: function () { return [{ type: i1.CommonService }]; }, propDecorators: { getTableConfigOutPut: [{
|
|
317
|
+
type: Output
|
|
318
|
+
}], oRowClick: [{
|
|
319
|
+
type: Output
|
|
320
|
+
}], onrightClickContextSelection: [{
|
|
321
|
+
type: Output
|
|
322
|
+
}], rightClickEnable: [{
|
|
323
|
+
type: Input
|
|
324
|
+
}], chartDataSource: [{
|
|
325
|
+
type: Input,
|
|
326
|
+
args: ['chartDataSource']
|
|
327
|
+
}] } });
|
|
328
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gamma-heatmap.component.js","sourceRoot":"","sources":["../../../../../../../../projects/gamma-app-controller/src/lib/application-controller/shared/advanced-component/gamma-heatmap/gamma-heatmap.component.ts","../../../../../../../../projects/gamma-app-controller/src/lib/application-controller/shared/advanced-component/gamma-heatmap/gamma-heatmap.component.html"],"names":[],"mappings":"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","sourcesContent":["\n\n\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport moment from './../../../moment-helper';\nimport { CommonService } from '../../../common';\n\n@Component({\n  selector: 'app-gamma-heatmap',\n  templateUrl: './gamma-heatmap.component.html',\n})\nexport class GammaHeatChartComponent implements OnInit {\n  isJsonPreview: boolean\n  dataSourseForTable: any = [];\n  jsaonDatasource: any;\n  configColume: any;\n  isLoader: boolean = true;\n  tableDataConfig: any = {};\n  enrichNameList = [\"formatBytes\", \"formatBytsToKb\", \"formatBytsToGb\", \"reformatNumberWithThousandSeparatorV3\", \"formatBytesv2\"]\n  page_config: any;\n  page_parms: any;\n  page_selected_operator: any;\n  activeTab: string = 'basic';\n\n  tableHeight: any;\n\n\n  isAdvanceFilter: boolean = false;\n  isHeatMapClick: boolean = false;\n\n  heatChartDataSource: any = {};\n  chartDataForTooltip: any = {};\n\n\n\n  dataSourseForHeatMap: any = [];\n  selectedViewConfigs: any;\n\n  viewProperties: any = {\n    enableClickEvent: false,\n    enableRightClickEvent: true,\n    clickEventOptions: {\n      associatedViews: [],\n      eventType: \"\"\n    }\n  };\n  optionalDrilDownDataSource: any = [];\n  selectedTableViewType: any;\n\n  allConfiguredViews: any = [];\n  colorArray: any = [];\n  firstColor = \"rgba(45, 110, 18, 1)\";\n  secondColor = \"rgba(255, 204, 0, 1)\";\n  singleColor = \"rgba(255, 204, 0, 1)\";\n\n  heatmapChartConfig: any = {};\n  @Output() public getTableConfigOutPut: EventEmitter<any> = new EventEmitter();\n  @Output() public oRowClick: EventEmitter<any> = new EventEmitter();\n  @Output() public onrightClickContextSelection: EventEmitter<any> = new EventEmitter();\n  @Input() rightClickEnable: boolean = true;\n\n  @Input('chartDataSource')\n  set chartDataSource(value) {\n    if (value === undefined || value.length === 0) {\n      return;\n    } else {\n      this.isLoader = true;\n      this.page_config = value;\n      this.page_parms = value.titleParams;\n      if (value.kpiConfig.dataSource && value.kpiConfig.dataSource.length !== 0) {\n        \n        this.heatmapChartConfig = value.kpiConfig.dataConfig;\n        this.colorArray = value.kpiConfig.dataConfig.color;\n        this.getHeatmapData(value.kpiConfig.dataSource);\n        setTimeout(() => {\n          this.isLoader = false;\n        }, 200);\n      } else {\n        setTimeout(() => {\n          this.dataSourseForTable = [];\n          this.tableDataConfig['columns'] = [];\n          this.isLoader = false;\n        }, 200);\n      }\n    }\n  }\n\n  constructor(public commonService: CommonService) { }\n\n  ngOnInit(): void {\n  }\n\n  getHeatmapData(heatMapData) {\n\n     this.heatChartDataSource = {};\n        this.isAdvanceFilter = false;\n\n        if (heatMapData && heatMapData.length !== 0) {\n            if (this.heatmapChartConfig.chartFormat == \"topx\") {\n                const { result, uniqueDates } = this.generateDateWiseColorCodedData(heatMapData);\n                uniqueDates.sort();\n                this.heatChartDataSource.dataSet = this.getTransposedHeatmapData(result);\n                this.heatChartDataSource[\"argumentValue\"] = uniqueDates;\n            } else if ((this.heatmapChartConfig.chartFormat == \"simple\")) {\n                const { result, uniqueDates } = this.generateData(heatMapData);\n                uniqueDates.sort();\n                this.heatChartDataSource[\"dataSet\"] = result;\n                this.heatChartDataSource[\"argumentValue\"] = uniqueDates;\n            }\n\n            this.isHeatMapClick = false;\n        } else {\n            this.isHeatMapClick = false;\n        }\n\n    // this.heatChartDataSource = {};\n    // this.isAdvanceFilter = false;\n\n    // if (heatMapData && heatMapData.length !== 0) {\n    //   const { result, uniqueDates } = this.generateData(heatMapData)\n    //   uniqueDates.sort();\n    //   this.heatChartDataSource[\"dataSet\"] = result;\n    //   this.heatChartDataSource[\"argumentValue\"] = uniqueDates;\n    //   this.isHeatMapClick = false;\n    // } else {\n    //   this.isHeatMapClick = false;\n    // }\n\n\n  }\n\n   getTransposedHeatmapData(dataSet: any[]): any[] {\n          const transposed: any[] = [];\n          const maxBoxes = Math.max(...dataSet.map(item => item.dataset.length));\n  \n          for (let i = 0; i < maxBoxes; i++) {\n              const row: any[] = [];\n              for (let j = 0; j < dataSet.length; j++) {\n                  const box = dataSet[j].dataset[i];\n                  row.push({\n                      box: box || null,\n                      date: dataSet[j].record_date\n                  });\n              }\n              transposed.push(row);\n          }\n  \n          return transposed;\n      }\n  \n      generateDateWiseColorCodedData(data: any[]) {\n          const result: any[] = [];\n          const uniqueDates = new Set();\n          const allEntries: any[] = [];\n  \n          const topArg = this.heatmapChartConfig.topArgument;\n          const leftArg = this.heatmapChartConfig.leftArgument;\n          const valueField = this.heatmapChartConfig.columns[0].dataField;\n  \n          data.forEach(entry => {\n              const formattedDate = (moment(entry[topArg]).format('YYYY-MM-DD')) ? moment(entry[topArg]).format('YYYY-MM-DD') : topArg;\n              uniqueDates.add(formattedDate);\n  \n              entry.resultDataset.forEach(item => {\n                  allEntries.push({\n                      [topArg]: formattedDate,\n                      [leftArg]: item[`${leftArg}`],\n                      [valueField]: item[`${valueField}`]\n                  });\n              });\n          });\n  \n          let coloredData;\n          if (this.heatmapChartConfig.type === 'gradient') {\n              coloredData = this.getFormateDataByColorCodeForGradient(allEntries, valueField);\n          } else if (this.heatmapChartConfig.type === 'twoColor') {\n              coloredData = this.getFormateDataByColorCodeForWithTwoColor(allEntries, valueField);\n          } else {\n              coloredData = this.getFormateDataByColorCodeForWithSingleColor(allEntries, valueField);\n          }\n  \n          const dateMap: { [date: string]: any[] } = {};\n  \n          coloredData.forEach(item => {\n              const date: any = item[topArg];\n  \n              if (!dateMap[date]) {\n                  dateMap[date] = [];\n              }\n  \n              dateMap[date].push({\n                  [leftArg]: item[leftArg],\n                  [valueField]: item[valueField],\n                  color: item.color,\n                  [topArg]: date,\n              });\n          });\n  \n          // Step 4: Build final result\n          for (const date of Array.from(uniqueDates).sort() as string[]) {\n              result.push({\n                  record_date: date,\n                  dataset: dateMap[date] || []\n              });\n          }\n  \n          return {\n              result,\n              uniqueDates: Array.from(uniqueDates).sort()\n          };\n      }\n\n  generateData(data) {\n    const result = [];\n    const uniqueDates = new Set();\n    const dataSourceMap = {};\n    const topArg = this.heatmapChartConfig.topArgument;\n    const leftArg = this.heatmapChartConfig.leftArgument;\n\n    data.forEach(item => {\n      const rowKey = item[leftArg];\n      const columnKey = moment(item[topArg]).format('YYYY-MM-DD');\n\n      if (!dataSourceMap[rowKey]) {\n        dataSourceMap[rowKey] = {\n          datasource: rowKey,\n          dataset: []\n        };\n      }\n\n      dataSourceMap[rowKey].dataset.push({\n        ...item,\n        [topArg]: columnKey\n      });\n\n      uniqueDates.add(columnKey);\n    });\n\n    const uniqueDatesArray = Array.from(uniqueDates);\n\n    for (const key in dataSourceMap) {\n      const dataset = dataSourceMap[key].dataset;\n      let formattedDataset;\n\n      if (this.heatmapChartConfig.type == \"gradient\") {\n        formattedDataset = this.getFormateDataByColorCodeForGradient(dataset, this.heatmapChartConfig.columns[0].dataField);\n      } else if (this.heatmapChartConfig.type == \"twoColor\") {\n        formattedDataset = this.getFormateDataByColorCodeForWithTwoColor(dataset, this.heatmapChartConfig.columns[0].dataField);\n      } else {\n        formattedDataset = this.getFormateDataByColorCodeForWithSingleColor(dataset, this.heatmapChartConfig.columns[0].dataField);\n\n      }\n\n      const dateToItemMap = {};\n      formattedDataset.forEach(item => {\n        dateToItemMap[item[topArg]] = item;\n      });\n\n      const completeDataset = uniqueDatesArray.map((date: any) => {\n        if (dateToItemMap[date]) {\n          return dateToItemMap[date];\n        } else {\n          return {\n            [topArg]: date,\n            avgSize: \"No Data\",\n            fileCount: 0,\n            fileSize: 0,\n            color: \"rgb(242, 118, 109)\"\n          };\n        }\n      });\n\n      result.push({\n        datasource: key,\n        dataset: completeDataset\n      });\n    }\n\n    return {\n      result: result,\n      uniqueDates: uniqueDatesArray\n    };\n  }\n\n\n\n  getFormateDataByColorCodeForGradient(filedata, column) {\n    filedata.forEach(item => {\n      item.avgSize = parseFloat(item[column]);\n    });\n\n    const maxAvgSize = Math.max(...filedata.map(item => item[column]));\n    const minAvgSize = Math.min(...filedata.map(item => item[column]));\n\n    const [minColorStr, maxColorStr] = this.colorArray || [\"rgba(45, 110, 18,1)\", \"rgba(255, 204, 0,1)\"];\n    const minColor = this.parseRGBA(minColorStr);\n    const maxColor = this.parseRGBA(maxColorStr);\n\n    filedata.forEach(item => {\n      item.color = this.calculateColor(item[column], minAvgSize, maxAvgSize, minColor, maxColor);\n    });\n\n    return filedata;\n  }\n  getFormateDataByColorCodeForWithTwoColor(filedata, column) {\n    filedata.forEach(item => {\n      item[column] = parseFloat(item[column]);\n    });\n\n    const [minColorStr, maxColorStr] = this.colorArray || [\"rgba(45, 110, 18,1)\", \"rgba(255, 204, 0,1)\"];\n    const minColor = this.parseRGBA(minColorStr);\n    const maxColor = this.parseRGBA(maxColorStr);\n\n    filedata.forEach(item => {\n      if (item[column] == 0) {\n        item.color = `rgb(${minColor.join(',')})`;\n      } else {\n        item.color = `rgb(${maxColor.join(',')})`;\n      }\n\n    });\n\n    return filedata;\n  }\n  getFormateDataByColorCodeForWithSingleColor(filedata, column) {\n    filedata.forEach(item => {\n      item[column] = parseFloat(item[column]);\n    });\n\n    const [singleColor] = this.colorArray || [\"rgba(255, 204, 0,1)\"];\n    const minColor = this.parseRGBA(singleColor);\n\n    filedata.forEach(item => {\n      item.color = `rgb(${minColor.join(',')})`;\n    });\n\n    return filedata;\n  }\n\n  parseRGBA(colorStr: string): number[] {\n    const values = colorStr.match(/[\\d.]+/g)?.map(Number) || [];\n    if (values.length === 3) values.push(1);\n    return [\n      values[0] ?? 0,\n      values[1] ?? 0,\n      values[2] ?? 0,\n      values[3] ?? 1\n    ];\n  }\n\n  calculateColor(avgSize, minAvgSize, maxAvgSize, minColor, maxColor) {\n    if (minAvgSize != maxAvgSize) {\n      let gradient = (avgSize - minAvgSize) / (maxAvgSize - minAvgSize);\n      let color = minColor.map((channel, index) => {\n        return Math.round(channel + gradient * (maxColor[index] - channel));\n      });\n      return `rgb(${color.join(',')})`;\n    } else {\n      return `rgb(${minColor.join(',')})`\n    }\n\n  }\n\n\n\n  transformColumns(mainobj: any): any[] {\n    return Object.keys(mainobj).map(key => {\n      return {\n        visible: true,\n        dataField: key,\n        caption: key\n      };\n    });\n  }\n\n\n\n  getObjectKeys(obj: any): string[] {\n    return Object.keys(obj);\n  }\n\n\n  callServiceFunction(functionName: string, value): any {\n\n    if (value !== undefined) {\n      if (typeof this.commonService[functionName] === \"function\") {\n        return this.commonService[functionName](value);\n      } else {\n        console.error(`Function ${functionName} not found in CommonService`);\n        return null;\n      }\n    } else {\n      return \"No Data\"\n    }\n\n  }\n\n\n}\n","<div class=\"mx-2 bg-gray-800\">\n    <app-loader *ngIf=\"isLoader\"></app-loader>\n   <ng-container *ngIf=\"!isLoader\">\n             <ng-container *ngIf=\"heatmapChartConfig.chartFormat == 'simple'\">\n                <div class=\"mx-5 h-[60vh] overflow-x-auto\">\n                    <div class=\"inline-block\">\n                        <div class=\"flex flex-nowrap justify-center\">\n                            <div class=\"flex-shrink-0 w-64 max-w-[20%] h-10 flex items-center justify-center\"></div>\n                            <div *ngFor=\"let item of heatChartDataSource.argumentValue\"\n                                class=\"flex-shrink-0 min-w-22 max-w-[20%] h-8 text-sm flex items-center justify-center\">\n                                {{item}}\n                            </div>\n                        </div>\n                    </div>\n                    <ng-container *ngFor=\"let item of heatChartDataSource.dataSet\">\n                        <div class=\"flex flex-row\">\n                            <div class=\"h-8 flex text-sm items-center min-w-64 justify-end px-2 inline\">\n                                {{ item.datasource }}\n                            </div>\n                            <div class=\"inline-block\">\n                                <div class=\"flex flex-nowrap justify-start\">\n                                    <ng-container *ngFor=\"let box of item.dataset\">\n                                        <div class=\"flex-shrink-0 min-w-22 max-w-[20%] h-8 border-2 text-sm cursor-pointer flex items-center justify-center text-gray-800\"\n                                            [ngStyle]=\"{ 'background-color': box.color }\"\n                                            [attr.title]=\"'Record Date: ' + box[heatmapChartConfig.topArgument] + ', Value: ' + box[heatmapChartConfig.columns[0].dataField]\">\n                                            {{ box[heatmapChartConfig.columns[0].dataField]}}\n                                        </div>\n                                    </ng-container>\n                                </div>\n                            </div>\n                        </div>\n                    </ng-container>\n                </div>\n            </ng-container>\n            <ng-container *ngIf=\"heatmapChartConfig.chartFormat == 'topx'\">\n                <div class=\"mx-5 h-[60vh] overflow-x-auto\">\n                    <div class=\"flex flex-row\">\n                        <ng-container *ngFor=\"let header of heatChartDataSource.argumentValue\">\n                            <div class=\"min-w-32 text-sm font-medium text-center mb-2\">\n                                {{ header }}\n                            </div>\n                        </ng-container>\n                    </div>\n\n                    <div *ngFor=\"let row of heatChartDataSource.dataSet\" class=\"flex flex-row\">\n                        <ng-container *ngFor=\"let cell of row\">\n                            <div *ngIf=\"cell.box\"\n                                class=\"h-8 border-2 text-sm cursor-pointer flex items-center justify-center text-gray-800 min-w-32\"\n                                [ngStyle]=\"{ 'background-color': cell.box.color }\"\n                                [attr.title]=\"'Record Date: ' + cell.box[heatmapChartConfig.topArgument] + ', Value: ' + cell.box[heatmapChartConfig.columns[0].dataField]\">\n                                {{ cell.box[heatmapChartConfig.leftArgument] }} ({{\n                                commonService.abbreviateNumber(cell.box[heatmapChartConfig.columns[0].dataField]) }})\n                            </div>\n                            <div *ngIf=\"!cell.box\" class=\"h-8 min-w-32\"></div>\n                        </ng-container>\n                    </div>\n                </div>\n            </ng-container>\n        </ng-container>\n</div>"]}
|