gamma-app-controller 2.0.18 → 2.0.19

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.
@@ -163,6 +163,11 @@ export class GeoMapComponent {
163
163
  this.tableDataConfig.chart_config = value.selectedWidgetConfig.dataConfig.chart_config;
164
164
  }
165
165
  else if (this.mapType == 'choroplethMap') {
166
+ if (value.selectedWidgetConfig['dataConfig']['isDataAggregation']) {
167
+ this.dataAggregationContainer = value.selectedWidgetConfig['dataConfig']['dataAggregationConfig']['dataAggregateColumes'];
168
+ this.dataAggregateGroupByColume = value.selectedWidgetConfig['dataConfig']['dataAggregationConfig']['aggregateFields'];
169
+ this.saveAggregationColume();
170
+ }
166
171
  this.choroplethMapConfig = value.selectedWidgetConfig.dataConfig;
167
172
  this.choroplethMapConfig.chart_config = value.selectedWidgetConfig.dataConfig.chart_config;
168
173
  this.tableDataConfig.chart_config = value.selectedWidgetConfig.dataConfig.chart_config;
@@ -557,4 +562,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
557
562
  type: Input,
558
563
  args: ['datasetmodal']
559
564
  }] } });
560
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"geo-map.component.js","sourceRoot":"","sources":["../../../../../../../projects/gamma-app-controller/src/lib/application-controller/support-components/geo-map/geo-map.component.ts","../../../../../../../projects/gamma-app-controller/src/lib/application-controller/support-components/geo-map/geo-map.component.html"],"names":[],"mappings":"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","sourcesContent":["\nimport { ChangeDetectorRef, Component, ComponentRef, ElementRef, EventEmitter, Input, OnInit, Output, ViewChild, ViewContainerRef } from '@angular/core';\nimport { ApplicationContentService } from '../../application-content.service';\nimport { ToastrService } from 'ngx-toastr';\nimport { CommonService } from '../../common';\n\n\n@Component({\n  selector: 'app-geo-map',\n  templateUrl: './geo-map.component.html',\n  styleUrls: ['./geo-map.component.scss']\n})\nexport class GeoMapComponent {\n  heatMapTypeDatasource = [\n    {\n      \"name\": \"Heat Map Only\",\n      \"value\": \"heatMapOnly\"\n    },\n    {\n      \"name\": \"Heat Map Marker\",\n      \"value\": \"heatMapMarker\"\n    },\n    {\n      \"name\": \"Heat Map And Heat Marker\",\n      \"value\": \"heatMapAndMarker\"\n    }\n  ]\n  chartViewType: any;\n  mapIconsDataSource = [\"assets/custom-marker..jpeg\"];\n  mapType: any = '';\n\n  chartViewTypeDataSource = [\n    { name: 'GEO Map', value: 'geoMap' },\n    { name: 'Heat Map', value: 'heatMap' },\n    { name: 'Bubble Map', value: 'bubbleMap' },\n    { name: 'Choropleth Map', value: 'choroplethMap' }\n  ];\n\n  regionData = [\"country\", \"city\"];\n  chartDataSourceForMap: any;\n  colors: string[] = []; // Array to hold selected colors\n  isJsonPreview: boolean;\n  dataSourseForTable: any = [];\n  jsaonDatasource: any;\n  configColume: any;\n  allConfiguredViews: any = [];\n  // groupOfViews: any;\n  viewProperties: any = {\n    enableClickEvent: false,\n    enableRightClickEvent: true,\n    clickEventOptions: {\n      associatedViews: [],\n      eventType: \"\"\n    }\n  };\n  optionalDrilDownDataSource: any = [];\n  table_columns_config = {\n    \"kpiConfig\": {\n      \"serviceId\": \"\",\n      \"api\": \"/kpi/trends/network/get-metric-data\",\n      \"displayType\": \"googleChart\",\n      \"formate\": \"\",\n      \"keyToPass\": [],\n      \"componentName\": \"GammaGeoChartComponent\",\n      \"dataConfig\": {}\n    },\n  };\n  heatMapConfig = {\n    \"chart_config\": [\n\n    ],\n    \"heatMapCategory\": \"\",\n    // \"centerLatitude\":\"\",\n    // \"centerLongitude\":\"\",\n    \"icon\": \"assets/custom-marker..jpeg\",\n    \"markerLatitude\": \"\",\n    \"markerLongitude\": \"\",\n    \"size\": '450',\n    \"zoom\": \"\"\n  }\n  bubbleMapConfig = {\n    \"chart_config\": [\n\n    ],\n    \"agrumentValue\": \"\",\n    \"bubbleColor\": \"#285e08\",\n    \"size\": '450',\n    \"bubbleMinimumSize\": \"5\",\n    \"bubbleMaximumSize\": \"15\",\n    \"markerLatitude\": \"\",\n    \"markerLongitude\": \"\",\n    \"sortBy\": \"\"\n    //  \"zoom\":\"\"\n  }\n  tableDataConfig = {\n\n    \"chart_config\": [\n\n    ],\n    \"region\": \"\",\n    \"regionCode\": \"US\",\n    // \"title\": \"\",\n    \"argumentField\": \"\",\n    \"chartValueField\": \"\",\n    \"size\": \"450\",\n    \"chartType\": \"geochart\",\n    \"backgroundColor\": \"#6c98e0\",\n    \"colors\": ['#003566', '#fd0000']\n\n  }\n\n\n  // for choroplethMap\n\n\n  choroplethMapConfig = {\n    chart_config: [\n      {\n        dataField: \"cnt\",\n        caption: \"Count\",\n        displayFor: \"map\",\n        enrichName: \"\"\n      }\n    ],\n    zoom: \"7\",\n    isValueFieldRangeSlider: true,\n    slideSpeed: 1000,\n    isDataAggregation: false,\n    dataAggregationConfig: {\n      \"dataAggregateColumes\": [],\n      \"aggregateFields\": []\n    },\n    sliderValueField: \"year\",\n    centerLat: \"1.3733\",\n    centerLng: \"32.2903\",\n    argumentField: \"district\",\n    gjsonFilePath: \"/assets/api-data/uganda_districts.geojson\",\n    size: \"450\",\n    chartType: \"choroplethMap\",\n    colorOne: '#089274',\n    colorTwo: '#f0f921',\n  }\n\n  isCenterdChoroplethMap: boolean = false;\n  centarLaitngObject = {\n    latKey: \"\",\n    lngKey: \"\"\n  }\n\n  enrichNameList = [\"abbreviateNumber\", \"getColorCodeSpan\", \"ThousandSeparator\", \"formatBytesv2\"]\n  selectedTableViewType: any;\n  isLoader: boolean = true;\n\n  selectedViewConfigs: any;\n  userOptionContainer: any = [];\n  previewData: any;\n\n  constructor(public commonService: CommonService, private cdr: ChangeDetectorRef, private service: ApplicationContentService, private taostr: ToastrService) { }\n\n  activeTab: string = 'basic';\n  @Output() public createOtherComponentView: EventEmitter<any> = new EventEmitter();\n  selectedViews = [];\n\n  @Input('datasetmodal')\n  set chartconfigData(value) {\n    if (value === undefined || value.length === 0) {\n      return;\n    } else {\n      this.jsaonDatasource = value.data[0];\n      this.configColume = Object.keys(value.data[0]);\n      this.dataSourseForTable = value.data;\n      this.selectedViewConfigs = value;\n      this.previewData = value.data;\n\n      this.selectedTableViewType = value.selectedViewType;\n      this.userOptionContainer = value.selectedWidgetConfig?.permissions ? value.selectedWidgetConfig.permissions : [];\n      if (value.selectedWidgetConfig) {\n\n        this.table_columns_config['kpiConfig'] = value.selectedWidgetConfig;\n        this.mapType = value.selectedWidgetConfig.dataConfig.mapType;\n        if (this.mapType == \"geoMap\") {\n          this.tableDataConfig = value.selectedWidgetConfig.dataConfig;\n          this.tableDataConfig.chart_config = value.selectedWidgetConfig.dataConfig.chart_config;\n\n        } else if (this.mapType == 'bubbleMap') {\n          this.bubbleMapConfig = value.selectedWidgetConfig.dataConfig;\n          this.bubbleMapConfig.chart_config = value.selectedWidgetConfig.dataConfig.chart_config;\n          this.tableDataConfig.chart_config = value.selectedWidgetConfig.dataConfig.chart_config;\n        } else if (this.mapType == 'choroplethMap') {\n          this.choroplethMapConfig = value.selectedWidgetConfig.dataConfig;\n          this.choroplethMapConfig.chart_config = value.selectedWidgetConfig.dataConfig.chart_config;\n          this.tableDataConfig.chart_config = value.selectedWidgetConfig.dataConfig.chart_config;\n        }\n        else {\n          this.heatMapConfig = value.selectedWidgetConfig.dataConfig;\n          this.heatMapConfig.chart_config = value.selectedWidgetConfig.dataConfig.chart_config;\n          this.tableDataConfig.chart_config = value.selectedWidgetConfig.dataConfig.chart_config;\n        }\n        if (value.selectedWidgetConfig.viewProperties && value.selectedWidgetConfig.viewProperties.clickEventOptions.associatedViews) {\n          this.viewProperties = value.selectedWidgetConfig.viewProperties;\n          this.viewProperties = {\n            \"enableClickEvent\": value.selectedWidgetConfig.viewProperties.enableClickEvent,\n            \"enableRightClickEvent\": value.selectedWidgetConfig.viewProperties.enableRightClickEvent\n          }\n\n          if (value.selectedWidgetConfig.viewProperties.enableClickEvent) {\n            this.viewProperties['clickEventOptions'] = {\n              \"eventType\": value.selectedWidgetConfig.viewProperties.clickEventOptions.eventType,\n              \"associatedViews\": value.selectedWidgetConfig.viewProperties.clickEventOptions.associatedViews\n            }\n          } else {\n            this.viewProperties['clickEventOptions'] = {}\n          }\n\n        }\n\n        this.cdr.detectChanges();\n      } else {\n        this.tableDataConfig.chart_config = value.columnData;\n        if (this.tableDataConfig.chart_config) {\n          this.tableDataConfig.chart_config.forEach(element => {\n            // element['color'] = '';\n            // element['isShowBar'] = true;\n          });\n\n        } else {\n          this.tableDataConfig.chart_config = [];\n          this.configColume.forEach(element => {\n            let obj = {\n              // \"visible\": true,\n              // \"isShowBar\": true,\n              \"dataField\": element,\n              \"caption\": this.commonService.convertString(element),\n              \"enrichName\": \"\",\n              \"displayFor\": \"map\",\n              // \"color\": \"\",\n            }\n\n            this.tableDataConfig.chart_config.push(obj);\n\n          });\n        }\n\n        this.cdr.detectChanges();\n      }\n    }\n  }\n\n\n  ngOnInit(): void {\n    this.isLoader = true;\n    this.service.getAppViewConfigs().subscribe({\n      next: (data: any) => {\n        this.allConfiguredViews = data;\n\n        this.isLoader = false;\n      }, error: (err: any) => {\n        this.taostr.error('Unexpected Server Exception. Please contact System Admin.', 'All Views')\n      }\n    })\n\n    this.optionalDrilDownDataSource = [\n      {\n        'viewId': \"\",\n        'filterCondition': \"\"\n      }\n    ]\n  }\n  addColumns() {\n    let obj = {\n      \"dataField\": \"\",\n      \"caption\": \"\",\n      \"enrichName\": \"\",\n      \"displayFor\": \"\",\n    }\n\n    this.tableDataConfig.chart_config.push(obj);\n  }\n\n  deleteColumns(i) {\n    this.tableDataConfig.chart_config.splice(i, 1)\n  }\n\n  getEnrichClassName(e, item) {\n    item.enrichName = e.value;\n\n  }\n\n\n  moveItemForColumns(index: number, direction: 'up' | 'down'): void {\n    // Prevent moving beyond array bounds\n    if (index < 0 || index >= this.tableDataConfig.chart_config.length) return;\n    const newPosition = direction === 'up' ? index - 1 : index + 1;\n    // Prevent moving beyond array bounds\n    if (newPosition < 0 || newPosition >= this.tableDataConfig.chart_config.length) return;\n\n    // Move item\n    const itemToMove = this.tableDataConfig.chart_config[index];\n    this.tableDataConfig.chart_config.splice(index, 1); // Remove item from current position\n    this.tableDataConfig.chart_config.splice(newPosition, 0, itemToMove); // Insert item in new position\n  }\n\n  getObjectKeys(obj: any): string[] {\n    return Object.keys(obj);\n  }\n  setActiveTab(tab: string) {\n    this.activeTab = tab;\n  }\n\n  getGroupColumns(columns) {\n    const groupedColumns = columns.reduce((acc, column) => {\n      let group = acc.find(item => item.caption === column.group);\n      if (!group) {\n        group = {\n          caption: column.group,\n          columns: []\n        };\n        acc.push(group);\n      }\n      group.columns.push({\n        dataField: column.dataField,\n        // visible: column.visible,\n        caption: column.caption\n      });\n      return acc;\n    }, []);\n    return groupedColumns;\n  }\n  geColumnsFromGroup(columns) {\n    const newColumns = [];\n\n    columns.forEach(group => {\n      group.columns.forEach(col => {\n        newColumns.push({\n          dataField: col.dataField,\n          // visible: col.visible,\n          caption: col.caption,\n        });\n      });\n    });\n    return newColumns;\n  }\n\n\n  getSaveChartConfig() {\n\n    if (this.mapType == 'geoMap') {\n      this.table_columns_config.kpiConfig['dataConfig'] = this.tableDataConfig;\n      this.table_columns_config.kpiConfig['dataConfig']['mapType'] = this.mapType;\n      if (this.viewProperties.clickEventOptions.eventType == 'optionalDrillDown') {\n        this.viewProperties['clickEventOptions']['associatedViews'] = this.optionalDrilDownDataSource;\n      }\n      this.table_columns_config.kpiConfig['viewProperties'] = this.viewProperties;\n      this.table_columns_config['permissions'] = this.userOptionContainer;\n\n      this.createOtherComponentView.emit(this.table_columns_config);\n    } else if (this.mapType == 'bubbleMap') {\n      this.table_columns_config.kpiConfig['dataConfig'] = this.bubbleMapConfig;\n      this.table_columns_config.kpiConfig['dataConfig']['chart_config'] = this.tableDataConfig.chart_config;\n      this.table_columns_config.kpiConfig['dataConfig']['mapType'] = this.mapType;\n\n      if (this.viewProperties.clickEventOptions.eventType == 'optionalDrillDown') {\n        this.viewProperties['clickEventOptions']['associatedViews'] = this.optionalDrilDownDataSource;\n      }\n\n      this.table_columns_config.kpiConfig['viewProperties'] = this.viewProperties;\n      this.table_columns_config.kpiConfig['dataSource'] = '';\n      this.table_columns_config['permissions'] = this.userOptionContainer;\n\n      this.createOtherComponentView.emit(this.table_columns_config);\n\n    } else if (this.mapType == 'choroplethMap') {\n      this.table_columns_config.kpiConfig['dataConfig'] = this.choroplethMapConfig;\n      this.table_columns_config.kpiConfig['dataConfig']['chart_config'] = this.tableDataConfig.chart_config;\n      this.table_columns_config.kpiConfig['dataConfig']['mapType'] = this.mapType;\n      if (this.viewProperties.clickEventOptions.eventType == 'optionalDrillDown') {\n        this.viewProperties['clickEventOptions']['associatedViews'] = this.optionalDrilDownDataSource;\n      }\n\n      this.table_columns_config.kpiConfig['viewProperties'] = this.viewProperties;\n      this.table_columns_config.kpiConfig['dataSource'] = '';\n      this.table_columns_config['permissions'] = this.userOptionContainer;\n\n      this.createOtherComponentView.emit(this.table_columns_config);\n\n    } else {\n      this.table_columns_config.kpiConfig['dataConfig'] = this.heatMapConfig;\n      this.table_columns_config.kpiConfig['dataConfig']['chart_config'] = this.tableDataConfig.chart_config;\n      this.table_columns_config.kpiConfig['dataConfig']['mapType'] = this.mapType;\n      if (this.viewProperties.clickEventOptions.eventType == 'optionalDrillDown') {\n        this.viewProperties['clickEventOptions']['associatedViews'] = this.optionalDrilDownDataSource;\n      }\n\n      this.table_columns_config.kpiConfig['viewProperties'] = this.viewProperties;\n      this.table_columns_config['permissions'] = this.userOptionContainer;\n\n      this.createOtherComponentView.emit(this.table_columns_config);\n    }\n\n    // alert(JSON.stringify(this.table_columns_config, null, 2));\n    // console.log(this.table_columns_config);\n    // console.log(this.table_columns_config);\n\n    // this.createOtherComponentView.emit(this.table_columns_config);\n    // this.table_columns_config.kpiConfig['dataSource']= this.dataSourseForTable;\n    // this.chartDataSourceForMap = this.table_columns_config;\n\n  }\n\n  deleteAssociatedParams(index) {\n    this.optionalDrilDownDataSource.splice(index, 1)\n  }\n\n  addAssociatedParams() {\n    this.optionalDrilDownDataSource.push({\n      'viewId': \"\",\n      'filterCondition': \"\"\n    })\n  }\n\n  getSelectedEventType(e) {\n\n    if (e.event) {\n      this.optionalDrilDownDataSource = [];\n      if (this.viewProperties.clickEventOptions.eventType == 'drilldown') {\n        this.table_columns_config.kpiConfig['viewProperties']['associatedViews'] = [];\n      }\n    }\n\n\n  }\n\n  resetViewProprstise() {\n    this.viewProperties = {\n      enableClickEvent: false,\n      enableRightClickEvent: true,\n      clickEventOptions: {\n        associatedViews: [],\n        eventType: \"\"\n      }\n    };\n  }\n\n  addColor() {\n    this.tableDataConfig.colors.push('#000000'); // Add default color\n  }\n\n  removeColor(index: number) {\n    this.tableDataConfig.colors.splice(index, 1);\n  }\n\n  onColorChange(value: string, index: number) {\n    this.tableDataConfig.colors[index] = value; // Update color at index\n  }\n\n  viewMapForTest() {\n    if (this.mapType == 'geoMap') {\n      this.table_columns_config.kpiConfig['dataConfig'] = this.tableDataConfig;\n      this.table_columns_config.kpiConfig['dataConfig']['mapType'] = this.mapType;\n    } else if (this.mapType == 'bubbleMap') {\n      this.table_columns_config.kpiConfig['dataConfig'] = this.bubbleMapConfig;\n      this.table_columns_config.kpiConfig['dataConfig']['chart_config'] = this.tableDataConfig.chart_config;\n      this.table_columns_config.kpiConfig['dataConfig']['mapType'] = this.mapType;\n    } else if (this.mapType == 'choroplethMap') {\n      this.table_columns_config.kpiConfig['dataConfig'] = this.choroplethMapConfig;\n      this.table_columns_config.kpiConfig['dataConfig']['chart_config'] = this.tableDataConfig.chart_config;\n      this.table_columns_config.kpiConfig['dataConfig']['mapType'] = this.mapType;\n    }\n    else {\n      this.table_columns_config.kpiConfig['dataConfig'] = this.heatMapConfig;\n      this.table_columns_config.kpiConfig['dataConfig']['chart_config'] = this.tableDataConfig.chart_config;\n      this.table_columns_config.kpiConfig['dataConfig']['mapType'] = this.mapType;\n    }\n\n    if (this.viewProperties.clickEventOptions.eventType == 'optionalDrillDown') {\n      this.viewProperties['clickEventOptions']['associatedViews'] = this.optionalDrilDownDataSource;\n    }\n\n    this.table_columns_config.kpiConfig['viewProperties'] = this.viewProperties;\n\n    this.table_columns_config.kpiConfig['dataSource'] = this.dataSourseForTable;\n    this.chartDataSourceForMap = this.table_columns_config;\n\n    this.isJsonPreview = true;\n\n  }\n\n  heatMapCategory(e) {\n    this.heatMapConfig.heatMapCategory = e.value;\n  }\n\n  changeMapType(event) {\n    if (event.event) {\n      this.heatMapConfig.heatMapCategory = '';\n    }\n  }\n\n\n\n  onLatLngKeyChange(event) {\n    const { latKey, lngKey } = this.centarLaitngObject;\n\n    if (!latKey || !lngKey) {\n      return;\n    }\n\n    this.calculateCenterFromDatasource();\n  }\n\n  calculateCenterFromDatasource() {\n    const latKey = this.centarLaitngObject.latKey;\n    const lngKey = this.centarLaitngObject.lngKey;\n\n    if (!latKey || !lngKey || !this.dataSourseForTable?.length) {\n      return;\n    }\n\n    let minLat = Infinity;\n    let maxLat = -Infinity;\n    let minLng = Infinity;\n    let maxLng = -Infinity;\n\n    this.dataSourseForTable.forEach(item => {\n      const lat = Number(item[latKey]);\n      const lng = Number(item[lngKey]);\n\n      if (!isNaN(lat) && !isNaN(lng)) {\n        minLat = Math.min(minLat, lat);\n        maxLat = Math.max(maxLat, lat);\n        minLng = Math.min(minLng, lng);\n        maxLng = Math.max(maxLng, lng);\n      }\n    });\n\n    const centerLat = (minLat + maxLat) / 2;\n    const centerLng = (minLng + maxLng) / 2;\n\n    // ✅ store as STRING\n    this.choroplethMapConfig['centerLat'] = centerLat.toFixed(6);\n    this.choroplethMapConfig['centerLng'] = centerLng.toFixed(6);\n  }\n\n\n\n\n\n  // data aggregation code\n\n  dataAggregationContainer = [];\n  dataAggregateGroupByColume: any = [];\n  addAggregationColume() {\n    this.dataAggregationContainer.push({\n      aggregateDataField: \"\",\n      aggregateFunctionType: \"\"\n    })\n  }\n\n  deleteAggregationColume(i) {\n    this.dataAggregationContainer.splice(i, 1)\n  }\n\n\n\n  onDataGroupByChange(event: any) {\n    if (this.choroplethMapConfig.isDataAggregation) {\n\n      this.dataAggregationContainer.push({\n        aggregateDataField: \"\",\n        aggregateFunctionType: \"\"\n      })\n    } else {\n      this.dataSourseForTable = this.previewData.slice(0, 10);\n      this.configColume = (this.previewData[0]) ? Object.keys(this.previewData[0]) : [];\n    }\n\n    this.table_columns_config.kpiConfig['dataConfig'] = this.choroplethMapConfig;\n    this.table_columns_config.kpiConfig['dataConfig']['chart_config'] = this.tableDataConfig.chart_config;\n    this.table_columns_config.kpiConfig['dataConfig']['mapType'] = this.mapType;\n\n    this.chartDataSourceForMap = { ...this.table_columns_config };\n  }\n\n  saveAggregationColume() {\n    if (this.choroplethMapConfig.isDataAggregation) {\n      const aggreationData = this.getGroupDataForChart(this.previewData, this.dataAggregationContainer, this.dataAggregateGroupByColume);\n      this.dataSourseForTable = aggreationData;\n      this.configColume = (aggreationData[0]) ? Object.keys(aggreationData[0]) : [];\n\n      if (this.choroplethMapConfig.isDataAggregation) {\n        this.choroplethMapConfig['dataAggregationConfig'] = {\n          \"dataAggregateColumes\": this.dataAggregationContainer,\n          \"aggregateFields\": this.dataAggregateGroupByColume\n        }\n      }\n\n      console.log(aggreationData);\n    }\n  }\n\n\n  getGroupDataForChart(data, aggregationConfig, groupByColumns) {\n    const groupMap = {};\n\n    data.forEach(row => {\n      const groupKey = groupByColumns.map(col => row[col]).join(\"||\");\n\n      if (!groupMap[groupKey]) {\n        groupMap[groupKey] = {};\n\n        groupByColumns.forEach(col => {\n          groupMap[groupKey][col] = row[col];\n        });\n\n        aggregationConfig.forEach(({ aggregateDataField, aggregateFunctionType }) => {\n          switch (aggregateFunctionType) {\n            case \"sum\":\n            case \"avg\":\n              groupMap[groupKey][aggregateDataField] = 0;\n              break;\n            case \"min\":\n              groupMap[groupKey][aggregateDataField] = Infinity;\n              break;\n            case \"max\":\n              groupMap[groupKey][aggregateDataField] = -Infinity;\n              break;\n            case \"count\":\n              groupMap[groupKey][aggregateDataField] = 0;\n              break;\n          }\n\n          if (aggregateFunctionType === \"avg\") {\n            groupMap[groupKey][`${aggregateDataField}__count`] = 0;\n          }\n        });\n      }\n\n      // Apply aggregations\n      aggregationConfig.forEach(({ aggregateDataField, aggregateFunctionType }) => {\n        const value = row[aggregateDataField];\n\n        switch (aggregateFunctionType) {\n          case \"sum\":\n            groupMap[groupKey][aggregateDataField] += value;\n            break;\n\n          case \"avg\":\n            groupMap[groupKey][aggregateDataField] += value;\n            groupMap[groupKey][`${aggregateDataField}__count`] += 1;\n            break;\n\n          case \"min\":\n            groupMap[groupKey][aggregateDataField] =\n              Math.min(groupMap[groupKey][aggregateDataField], value);\n            break;\n\n          case \"max\":\n            groupMap[groupKey][aggregateDataField] =\n              Math.max(groupMap[groupKey][aggregateDataField], value);\n            break;\n\n          case \"count\":\n            groupMap[groupKey][aggregateDataField] += 1;\n            break;\n        }\n      });\n    });\n\n    // Finalize averages\n    Object.values(groupMap).forEach(group => {\n      aggregationConfig.forEach(({ aggregateDataField, aggregateFunctionType }) => {\n        if (aggregateFunctionType === \"avg\") {\n          group[aggregateDataField] =\n            group[aggregateDataField] / group[`${aggregateDataField}__count`];\n          delete group[`${aggregateDataField}__count`];\n        }\n      });\n    });\n\n    return Object.values(groupMap);\n  }\n\n\n}\n","<div class=\"flex flex-wrap\">\n    <div class=\"w-full mx-2 border-r\">\n        <ng-container *ngIf=\"!isJsonPreview\">\n            <pre><code>{{jsaonDatasource | json}}</code></pre>\n        </ng-container>\n        <ng-container *ngIf=\"isJsonPreview\">\n            <app-gamma-geo-chart [chartDataSource]=\"chartDataSourceForMap\"></app-gamma-geo-chart>\n            <!-- <app-google-geo-map [chartDataSource]=\"chartDataSourceForMap\"></app-google-geo-map> -->\n\n            <div #dynamicContainer></div>\n\n        </ng-container>\n    </div>\n    <div class=\"w-full mx-2\">\n\n        <div class=\"mb-4 border-b border-gray-200 dark:border-gray-700\">\n            <ul class=\"flex flex-wrap -mb-px text-sm font-medium text-center\" role=\"tablist\">\n                <li class=\"me-2\" role=\"presentation\">\n                    <button class=\"inline-block p-4 border-b-2 rounded-t-lg\" [ngClass]=\"{ \n                                        'text-purple-600 border-purple-600 dark:text-purple-500 dark:border-purple-500': activeTab === 'basic',\n                                        'text-gray-500 dark:text-gray-400 border-transparent': activeTab !== 'basic' \n                                    }\" (click)=\"setActiveTab('basic')\" type=\"button\" role=\"tab\">\n                        Basic\n                    </button>\n                </li>\n                <li class=\"me-2\" role=\"presentation\">\n                    <button class=\"inline-block p-4 border-b-2 rounded-t-lg\" [ngClass]=\"{ \n                                        'text-purple-600 border-purple-600 dark:text-purple-500 dark:border-purple-500': activeTab === 'chart_config',\n                                        'text-gray-500 dark:text-gray-400 border-transparent': activeTab !== 'chart_config' \n                                    }\" (click)=\"setActiveTab('chart_config')\" type=\"button\" role=\"tab\">\n                        Chart Columns\n                    </button>\n                </li>\n                <li class=\"me-2\" role=\"presentation\">\n                    <button class=\"inline-block p-4 border-b-2 rounded-t-lg\" [ngClass]=\"{\n                                                        'text-purple-600 border-purple-600 dark:text-purple-500 dark:border-purple-500': activeTab === 'properties',\n                                                        'text-gray-500 dark:text-gray-400 border-transparent': activeTab !== 'properties'\n                                                    }\" (click)=\"setActiveTab('properties')\" type=\"button\" role=\"tab\">\n                        Properties\n                    </button>\n                </li>\n                <li class=\"me-2\" role=\"presentation\">\n                    <button class=\"inline-block p-4 border-b-2 rounded-t-lg\" [ngClass]=\"{\n                                        'text-purple-600 border-purple-600 dark:text-purple-500 dark:border-purple-500': activeTab === 'permission',\n                                        'text-gray-500 dark:text-gray-400 border-transparent': activeTab !== 'permission'\n                                    }\" (click)=\"setActiveTab('permission')\" type=\"button\" role=\"tab\">\n                        Manage Permissions\n                    </button>\n                </li>\n\n            </ul>\n        </div>\n\n        <div id=\"default-styled-tab-content\">\n            <div *ngIf=\"activeTab === 'basic'\">\n                <div class=\"flex flex-col flex-auto min-w-0 my-2\">\n                    <div class=\"text-sm py-1 font-extrabold border-b bg-gray-700 text-white px-2\"> Filter Title\n                        Config\n                    </div>\n                    <div class=\"flex pt-2 border-x border-b\">\n                        <div class=\"px-1 mb-1 w-1/3\">\n                            <div class=\"text-md mb-1\"> Map Library </div>\n                            <dx-select-box [searchEnabled]=\"true\" [items]=\"['Google Maps']\"></dx-select-box>\n                        </div>\n                        <div class=\"px-1 mb-1 w-1/3\">\n                            <div class=\"text-md mb-1\"> Select Map type </div>\n                            <dx-select-box [searchEnabled]=\"true\" [items]=\"chartViewTypeDataSource\" displayExpr=\"name\"\n                                valueExpr=\"value\" [(ngModel)]=\"mapType\"\n                                (onValueChanged)=\"changeMapType($event)\"></dx-select-box>\n                        </div>\n\n                        <ng-container *ngIf=\"mapType == 'heatMap'\">\n                            <div class=\"px-1 mb-1 w-1/3\">\n\n                                <div class=\"text-md mb-1\"> Heat Map Category </div>\n                                <dx-select-box [searchEnabled]=\"true\" [dataSource]=\"heatMapTypeDatasource\"\n                                    displayExpr=\"name\" valueExpr=\"value\" [(ngModel)]=\"heatMapConfig.heatMapCategory\"\n                                    (onValueChanged)=\"heatMapCategory($event)\"></dx-select-box>\n                            </div>\n                        </ng-container>\n                    </div>\n                    <ng-container *ngIf=\"mapType == 'geoMap'\">\n                        <div class=\"flex pt-2 border-x border-b\">\n                            <div class=\"px-1 mb-1 w-1/3\">\n                                <div class=\"text-md mb-1\"> Region </div>\n                                <dx-select-box [searchEnabled]=\"true\" [items]=\"regionData\"\n                                    [(ngModel)]=\"tableDataConfig.region\"></dx-select-box>\n                            </div>\n                            <div class=\"px-1 mb-1 w-1/3\" *ngIf=\"tableDataConfig.region == 'city'\">\n                                <div class=\"text-md mb-1\"> Type Region Code</div>\n                                <dx-text-box [(ngModel)]=\"tableDataConfig.regionCode\"></dx-text-box>\n                            </div>\n                        </div>\n                        <div class=\"pt-2 border-x border-b \">\n                            <div class=\"my-2 flex justify-between\">\n                                <!-- <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-1\"> Title</div>\n                                    <dx-text-box [(ngModel)]=\"tableDataConfig.title\"></dx-text-box>\n                                </div> -->\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-1\"> Argument Field</div>\n                                    <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                        [(ngModel)]=\"tableDataConfig.argumentField\"></dx-select-box>\n                                </div>\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-1\"> Chartvalu Field</div>\n                                    <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                        [(ngModel)]=\"tableDataConfig.chartValueField\"></dx-select-box>\n                                </div>\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-1\"> size</div>\n                                    <dx-text-box [(ngModel)]=\"tableDataConfig.size\"></dx-text-box>\n                                </div>\n\n                                <div class=\"px-1 mb-2 w-full\">\n                                    <div class=\"text-md mb-2\">Background Color</div>\n                                    <dx-color-box [(ngModel)]=\"tableDataConfig.backgroundColor\"></dx-color-box>\n                                </div>\n                                <!-- <div class=\"px-4 mt-6 w-full\">\n                                    <dx-check-box [value]=\"tableDataConfig.commonConfig.isSearchBox\"\n                                        [(ngModel)]=\"tableDataConfig.commonConfig.isSearchBox\"\n                                        text=\"Search Box\"></dx-check-box>\n    \n                                </div> -->\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-2\"> Display Formate </div>\n                                    <dx-select-box [items]=\"['daily','hourly','monthly']\"\n                                        [(ngModel)]=\"table_columns_config.kpiConfig.formate\"\n                                        [readOnly]=\"false\"></dx-select-box>\n                                </div>\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-2\"> Key To Pass </div>\n                                    <dx-tag-box [items]=\"configColume\"\n                                        [(ngModel)]=\"table_columns_config.kpiConfig.keyToPass\"></dx-tag-box>\n                                </div>\n                            </div>\n                        </div>\n                        <div class=\" pt-2 border-x border-b \">\n                            <div class=\"text-sm py-1 font-extrabold border-b bg-gray-700 text-white px-2\"> Colors\n                            </div>\n                            <div class=\"flex  flex-wrap px-1 mb-2 mt-2\">\n                                <div class=\"flex mr-2 mb-2\" *ngFor=\"let color of tableDataConfig.colors; let i = index\">\n                                    <div class=\"mr-2\">\n                                        <dx-color-box [(ngModel)]=\"tableDataConfig.colors[i]\"\n                                            (onValueChanged)=\"onColorChange($event.value, i)\"></dx-color-box>\n                                    </div>\n                                    <button class=\"{{commonService.btn_danger_sm}} cursor-pointer px-2\"\n                                        (click)=\"removeColor(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n                                    </button>\n                                    <!-- <div class=\"px-2\"> <button class=\"{{commonService.btn_danger_sm}}\" (click)=\"removeColor(i)\">Remove</button></div> -->\n                                </div>\n\n                            </div>\n                            <div class=\"flex flex-row justify-end my-2\">\n                                <button class=\"{{commonService.btn_success_sm}}\" (click)=\"addColor()\">Add Color</button>\n                            </div>\n                        </div>\n                    </ng-container>\n                    <ng-container *ngIf=\"mapType == 'choroplethMap'\">\n                        <div class=\"flex flex-row pt-2 border-x border-b\">\n                            <div class=\"px-1 mb-1 w-1/3\">\n                                <div class=\"text-md mb-1\"> Map Zoom </div>\n                                <dx-text-box [(ngModel)]=\"choroplethMapConfig.zoom\"></dx-text-box>\n                            </div>\n                            <div class=\"px-1 mb-2 mt-6 w-full\">\n                                <dx-check-box [(ngModel)]=\"isCenterdChoroplethMap\"\n                                    text=\"Centerd Position\"></dx-check-box>\n                            </div>\n\n                            <ng-container *ngIf=\"isCenterdChoroplethMap\">\n                                <div class=\"px-1 mb-1 w-1/3\">\n                                    <div class=\"text-md mb-1\"> Select Latitude Key</div>\n                                    <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                        [(ngModel)]=\"centarLaitngObject.latKey\"\n                                        (onValueChanged)=\"onLatLngKeyChange($event)\"></dx-select-box>\n                                </div>\n                                <div class=\"px-1 mb-1 w-1/3\">\n                                    <div class=\"text-md mb-1\"> Select Longitude Key</div>\n                                    <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                        [(ngModel)]=\"centarLaitngObject.lngKey\"\n                                        (onValueChanged)=\"onLatLngKeyChange($event)\"></dx-select-box>\n                                </div>\n\n                            </ng-container>\n\n                            <div class=\"px-1 mb-1 w-1/3\">\n                                <div class=\"text-md mb-1\"> Map Center Latitude</div>\n                                <dx-text-box [(ngModel)]=\"choroplethMapConfig.centerLat\"\n                                    [readOnly]=\"isCenterdChoroplethMap\"></dx-text-box>\n                            </div>\n                            <div class=\"px-1 mb-1 w-1/3\">\n                                <div class=\"text-md mb-1\"> Map Center Longitude</div>\n                                <dx-text-box [(ngModel)]=\"choroplethMapConfig.centerLng\"\n                                    [readOnly]=\"isCenterdChoroplethMap\"></dx-text-box>\n                            </div>\n\n\n                        </div>\n                        <div class=\"pt-2 border-x border-b \">\n                            <div class=\"my-2 flex flex-row justify-between\">\n\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-1\"> Argument Field</div>\n                                    <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                        [(ngModel)]=\"choroplethMapConfig.argumentField\"></dx-select-box>\n                                </div>\n\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-1\"> size</div>\n                                    <dx-text-box [(ngModel)]=\"choroplethMapConfig.size\"></dx-text-box>\n                                </div>\n\n                                <div class=\"px-1 mb-2 w-full\">\n                                    <div class=\"text-md mb-2\">Color One</div>\n                                    <dx-color-box [(ngModel)]=\"choroplethMapConfig.colorOne\"></dx-color-box>\n                                </div>\n\n                                <div class=\"px-1 mb-2 w-full\">\n                                    <div class=\"text-md mb-2\">Color Two</div>\n                                    <dx-color-box [(ngModel)]=\"choroplethMapConfig.colorTwo\"></dx-color-box>\n                                </div>\n\n\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-2\"> Display Formate </div>\n                                    <dx-select-box [items]=\"['daily','hourly','monthly']\"\n                                        [(ngModel)]=\"table_columns_config.kpiConfig.formate\"\n                                        [readOnly]=\"false\"></dx-select-box>\n                                </div>\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-2\"> Key To Pass </div>\n                                    <dx-tag-box [items]=\"configColume\"\n                                        [(ngModel)]=\"table_columns_config.kpiConfig.keyToPass\"></dx-tag-box>\n                                </div>\n\n                            </div>\n                            <div class=\"my-2 flex-row justify-between\">\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-1\"> Gjson File Path</div>\n                                    <dx-text-box [(ngModel)]=\"choroplethMapConfig.gjsonFilePath\"></dx-text-box>\n                                </div>\n\n                            </div>\n                            <div class=\"my-2 flex flex-row justify-between\">\n                                <div class=\"px-1 mb-2 mt-6 w-full\">\n                                    <dx-check-box [(ngModel)]=\"choroplethMapConfig.isValueFieldRangeSlider\"\n                                        text=\"Range Slider\"></dx-check-box>\n                                </div>\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-1\"> Slider Speed</div>\n                                    <dx-number-box [(ngModel)]=\"choroplethMapConfig.slideSpeed\"></dx-number-box>\n                                </div>\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-1\"> Value For Slider</div>\n                                    <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                        [(ngModel)]=\"choroplethMapConfig.sliderValueField\"></dx-select-box>\n                                </div>\n                            </div>\n                        </div>\n\n                        <div class=\"w-1/4 px-2 m-3\">\n                            <div class=\"text-md mb-1 mt-8\"></div>\n                            <dx-check-box [(ngModel)]=\"choroplethMapConfig.isDataAggregation\"\n                                (ngModelChange)=\"onDataGroupByChange($event)\"\n                                text=\"Apply Data Aggregation\"></dx-check-box>\n                        </div>\n\n                        <div class=\"flex flex-col rounded border p-3 m-6\" *ngIf=\"choroplethMapConfig.isDataAggregation\">\n                            <div class=\"px-1 my-4 w-1/3\">\n                                <div class=\"text-md mb-2\">Group By Columns</div>\n                                <dx-tag-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                    [(ngModel)]=\"dataAggregateGroupByColume\"></dx-tag-box>\n                            </div>\n                            <div class=\"border p-2\">\n                                <div class=\"my-2 flex flex-row border-b\"\n                                    *ngFor=\"let item of dataAggregationContainer; let i = index\">\n\n                                    <div class=\"px-1 mb-1 w-full\">\n                                        <div class=\"text-md mb-2\">Aggregation Columns</div>\n                                        <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                            [(ngModel)]=\"item.aggregateDataField\"></dx-select-box>\n                                    </div>\n                                    <div class=\" px-2 mb-1 w-full\">\n                                        <div class=\"text-md mb-2\">Function Type</div>\n                                        <dx-select-box [searchEnabled]=\"true\"\n                                            [items]=\"['sum','avg','min','max','count']\"\n                                            [(ngModel)]=\"item.aggregateFunctionType\"></dx-select-box>\n                                    </div>\n\n                                    <div class=\"text-center mt-6 w-1/6\">\n                                        <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n                                            (click)=\"deleteAggregationColume(i)\"><i class=\"fa fa-trash-o\"\n                                                aria-hidden=\"true\"></i>\n                                        </button>\n                                    </div>\n                                </div>\n                                <div class=\"flex flex-row justify-end my-2\">\n                                    <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\"\n                                        (click)=\"addAggregationColume()\">Add\n                                        Colume</button>\n                                    <button class=\"{{commonService.btn_success_sm}} cursor-pointer\"\n                                        (click)=\"saveAggregationColume()\">Save Aggregation</button>\n                                </div>\n                            </div>\n\n                        </div>\n\n                    </ng-container>\n\n                    <ng-container\n                        *ngIf=\"heatMapConfig.heatMapCategory == 'heatMapOnly' || heatMapConfig.heatMapCategory == 'heatMapMarker' || heatMapConfig.heatMapCategory == 'heatMapAndMarker'\">\n                        <div class=\"flex-col\">\n                            <div class=\"text-sm py-1 font-extrabold border-b bg-gray-700 text-white px-2\">\n                                Center Location Config\n                            </div>\n                            <div>\n                                <div class=\"flex pt-2 border-x border-b\">\n                                    <!-- <div class=\"px-1 mb-1 w-1/4\">\n                                        <div class=\"text-md mb-1\"> Latitude  </div>\n                                        <dx-text-box [(ngModel)]=\"heatMapConfig.centerLatitude\"></dx-text-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-1/4\">\n                                        <div class=\"text-md mb-1\"> Longitude </div>\n                                        <dx-text-box [(ngModel)]=\"heatMapConfig.centerLongitude\"></dx-text-box>\n                                    </div> -->\n                                    <div class=\"px-1 mb-1 w-1/4\"\n                                        *ngIf=\"heatMapConfig.heatMapCategory != 'heatMapAndMarker'\">\n                                        <div class=\"text-md mb-1\"> Zoom Label </div>\n                                        <dx-text-box [(ngModel)]=\"heatMapConfig.zoom\"></dx-text-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-1/4\">\n                                        <div class=\"text-md mb-1\"> Custom Icons </div>\n                                        <dx-text-box [(ngModel)]=\"heatMapConfig.icon\"></dx-text-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-1/4\">\n                                        <div class=\"text-md mb-1\"> size</div>\n                                        <dx-text-box [(ngModel)]=\"heatMapConfig.size\"></dx-text-box>\n                                    </div>\n                                </div>\n                            </div>\n                        </div>\n                        <div class=\"flex-col\">\n                            <div class=\"text-sm py-1 font-extrabold border-b bg-gray-700 text-white px-2\">\n                                Location Marker Config\n                            </div>\n                            <div>\n                                <div class=\"flex pt-2 border-x border-b\">\n                                    <div class=\"px-1 mb-1 w-1/3\">\n                                        <div class=\"text-md mb-1\"> Latitude </div>\n                                        <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                            [(ngModel)]=\"heatMapConfig.markerLatitude\"></dx-select-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-1/3\">\n                                        <div class=\"text-md mb-1\"> Longitude </div>\n                                        <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                            [(ngModel)]=\"heatMapConfig.markerLongitude\"></dx-select-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-full\">\n                                        <div class=\"text-md mb-2\"> Display Formate </div>\n                                        <dx-select-box [items]=\"['daily','hourly','monthly']\"\n                                            [(ngModel)]=\"table_columns_config.kpiConfig.formate\"\n                                            [readOnly]=\"false\"></dx-select-box>\n                                    </div>\n                                </div>\n                            </div>\n                        </div>\n                    </ng-container>\n                    <ng-container *ngIf=\"mapType == 'bubbleMap'\">\n                        <div class=\"flex-col\">\n                            <div class=\"text-sm py-1 font-extrabold border-b bg-gray-700 text-white px-2\">\n                                Bubble Map Config\n                            </div>\n                            <div>\n                                <div class=\"flex pt-2 border-x border-b\">\n                                    <div class=\"px-1 mb-1 w-1/3\">\n                                        <div class=\"text-md mb-1\"> Argument Value </div>\n                                        <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                            [(ngModel)]=\"bubbleMapConfig.agrumentValue\"></dx-select-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-1/4\">\n                                        <div class=\"text-md mb-1\"> Bubble Color </div>\n                                        <dx-color-box [(ngModel)]=\"bubbleMapConfig.bubbleColor\"></dx-color-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-1/4\">\n                                        <div class=\"text-md mb-1\">Bubble Minimum size</div>\n                                        <dx-text-box [(ngModel)]=\"bubbleMapConfig.bubbleMinimumSize\"></dx-text-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-1/4\">\n                                        <div class=\"text-md mb-1\">Bubble Maximum size</div>\n                                        <dx-text-box [(ngModel)]=\"bubbleMapConfig.bubbleMaximumSize\"></dx-text-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-1/4\">\n                                        <div class=\"text-md mb-1\"> size</div>\n                                        <dx-text-box [(ngModel)]=\"bubbleMapConfig.size\"></dx-text-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-1/4\">\n                                        <div class=\"text-md mb-1\"> Short By</div>\n                                        <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                            [(ngModel)]=\"bubbleMapConfig.sortBy\"></dx-select-box>\n                                    </div>\n                                    <!-- <div class=\"px-1 mb-1 w-1/4\" *ngIf=\"heatMapConfig.heatMapCategory != 'heatMapAndMarker'\">\n                                        <div class=\"text-md mb-1\"> Zoom Label  </div>\n                                        <dx-text-box [(ngModel)]=\"heatMapConfig.zoom\"></dx-text-box>\n                                    </div> -->\n                                </div>\n                            </div>\n                        </div>\n                        <div class=\"flex-col\">\n                            <div class=\"text-sm py-1 font-extrabold border-b bg-gray-700 text-white px-2\">\n                                Location Marker Config\n                            </div>\n                            <div>\n                                <div class=\"flex pt-2 border-x border-b\">\n                                    <div class=\"px-1 mb-1 w-1/3\">\n                                        <div class=\"text-md mb-1\"> Latitude </div>\n                                        <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                            [(ngModel)]=\"bubbleMapConfig.markerLatitude\"></dx-select-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-1/3\">\n                                        <div class=\"text-md mb-1\"> Longitude </div>\n                                        <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                            [(ngModel)]=\"bubbleMapConfig.markerLongitude\"></dx-select-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-full\">\n                                        <div class=\"text-md mb-2\"> Display Formate </div>\n                                        <dx-select-box [items]=\"['daily','hourly','monthly']\"\n                                            [(ngModel)]=\"table_columns_config.kpiConfig.formate\"\n                                            [readOnly]=\"false\"></dx-select-box>\n                                    </div>\n                                </div>\n                            </div>\n                        </div>\n                    </ng-container>\n\n\n                </div>\n\n\n\n            </div>\n            <div *ngIf=\"activeTab === 'chart_config'\">\n                <div class=\"h-full overflow-x-auto\">\n                    <div class=\"flex flex-col flex-auto min-w-0\">\n                        <div class=\"text-sm py-1 font-extrabold border-b bg-gray-700 text-white px-2\">\n                            Tooltip Columns\n                        </div>\n                        <div class=\"pt-2 border-x border-b \">\n                            <div class=\"my-2 border-b flex flex-row\"\n                                *ngFor=\"let item of tableDataConfig.chart_config; let i = index;\">\n                                <!-- <div class=\"px-1 mb-2 mt-6 w-full\">\n                                    <dx-check-box [value]=\"item.visible\" [(ngModel)]=\"item.visible\"\n                                        text=\"Visiblity\"></dx-check-box>\n                                </div> -->\n\n                                <div class=\"px-1 mb-2 w-full\">\n                                    <div class=\"text-md mb-2\"> Value Field</div>\n                                    <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                        [(ngModel)]=\"item.dataField\"></dx-select-box>\n                                </div>\n                                <div class=\"px-1 mb-2 w-full\">\n                                    <div class=\"text-md mb-2\"> Caption</div>\n                                    <dx-text-box [(ngModel)]=\"item.caption\"></dx-text-box>\n                                </div>\n\n\n                                <div class=\"px-1 mb-2 w-full\">\n                                    <div class=\"text-md mb-2\">Display For</div>\n                                    <dx-select-box [items]=\"['map', 'tooltip']\"\n                                        [(ngModel)]=\"item.displayFor\"></dx-select-box>\n                                </div>\n                                <div class=\"px-2 mb-2 w-full\">\n                                    <div class=\"text-md mb-2\"> UI Function</div>\n                                    <dx-select-box [items]=\"enrichNameList\" [(ngModel)]=\"item.enrichName\"\n                                        [searchEnabled]=\"true\"></dx-select-box>\n                                </div>\n\n                                <div class=\"text-center mt-8 w-full\">\n                                    <button *ngIf=\"i !== 0\" class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n                                        (click)=\"moveItemForColumns(i, 'up')\">\n                                        <i class=\"fa fa-arrow-up\" aria-hidden=\"true\"></i>\n                                    </button>\n\n                                    <button *ngIf=\"i !== tableDataConfig.chart_config.length - 1\"\n                                        class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n                                        (click)=\"moveItemForColumns(i, 'down')\">\n                                        <i class=\"fa fa-arrow-down\" aria-hidden=\"true\"></i>\n                                    </button>\n                                    <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n                                        (click)=\"deleteColumns(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n                                    </button>\n                                </div>\n\n                            </div>\n                        </div>\n                    </div>\n                    <div class=\"flex flex-row justify-end my-2\">\n                        <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\" (click)=\"addColumns()\">Add\n                            Columns</button>\n                    </div>\n                </div>\n            </div>\n            <div *ngIf=\"activeTab === 'properties'\">\n                <div class=\"h-full overflow-x-auto\">\n                    <app-loader *ngIf=\"isLoader\"></app-loader>\n                    <ng-container *ngIf=\"!isLoader\">\n                        <div class=\"flex flex-row justify-between border-b py-3\">\n                            <div class=\"mx-2\">\n                                <dx-check-box [value]=\"viewProperties.enableClickEvent\"\n                                    [(ngModel)]=\"viewProperties.enableClickEvent\"\n                                    text=\"Enable Click Event\"></dx-check-box>\n                            </div>\n                            <div class=\"mx-2\">\n                                <dx-check-box [value]=\"viewProperties.enableRightClickEvent\"\n                                    [(ngModel)]=\"viewProperties.enableRightClickEvent\"\n                                    text=\"Enable Right Click\"></dx-check-box>\n                            </div>\n                        </div>\n                        <div class=\"w-full p-2\" *ngIf=\"viewProperties.enableClickEvent\">\n\n                            <div class=\"flex flex-col flex-auto min-w-0 my-2\">\n                                <div class=\"text-sm py-1 font-extrabold border-b bg-gray-700 text-white px-2\"> Event\n                                    Type\n                                    Option\n                                </div>\n                                <div class=\"w-full p-3 border-x border-b \">\n                                    <div class=\"flex flex-row\">\n                                        <div class=\"w-full\">\n                                            <div class=\"text-md mb-2\"> Event Type</div>\n                                        </div>\n                                        <div class=\"w-full\">\n                                            <dx-select-box [items]=\"['drilldown','optionalDrillDown']\"\n                                                (onValueChanged)=\"getSelectedEventType($event)\"\n                                                [(ngModel)]=\"viewProperties.clickEventOptions.eventType\"></dx-select-box>\n                                        </div>\n                                    </div>\n                                    <ng-container *ngIf=\"viewProperties.clickEventOptions.eventType == 'drilldown'\">\n                                        <div class=\"flex flex-row justify-between mt-3\">\n                                            <div class=\"w-full\">\n                                                <div class=\"text-md mb-2\"> Associated Views</div>\n                                                <dx-tag-box [items]=\"allConfiguredViews\"\n                                                    [(ngModel)]=\"viewProperties.clickEventOptions.associatedViews\"\n                                                    valueExpr=\"viewId\" displayExpr=\"viewName\"\n                                                    [showSelectionControls]=\"true\" [searchEnabled]=\"true\"></dx-tag-box>\n                                            </div>\n                                        </div>\n                                    </ng-container>\n                                    <ng-container\n                                        *ngIf=\"viewProperties.clickEventOptions.eventType == 'optionalDrillDown'\">\n                                        <div class=\"flex flex-row justify-between mt-3\">\n                                            <div class=\"w-full\">\n                                                <ng-container\n                                                    *ngFor=\"let item of optionalDrilDownDataSource;let i = index;\">\n\n                                                    <div class=\"flex flex-row justify-between\">\n                                                        <div class=\"mx-2 w-full\">\n                                                            <div class=\"text-md mb-2\"> Associated Views</div>\n                                                            <dx-tag-box [items]=\"allConfiguredViews\"\n                                                                [(ngModel)]=\"item.viewId\" valueExpr=\"viewId\"\n                                                                displayExpr=\"viewName\" [showSelectionControls]=\"true\"\n                                                                [maxDisplayedTags]=\"2\"\n                                                                [searchEnabled]=\"true\"></dx-tag-box>\n\n                                                        </div>\n                                                        <div class=\"mx-2\">\n                                                            <div class=\"text-md mb-2\"> Associated Params</div>\n                                                            <dx-text-box\n                                                                [(ngModel)]=\"item.filterCondition\"></dx-text-box>\n                                                        </div>\n                                                        <div class=\"mx-2\">\n                                                            <button\n                                                                class=\"{{commonService.btn_danger_sm}} cursor-pointer mt-8\"\n                                                                (click)=\"deleteAssociatedParams(i)\"><i\n                                                                    class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n                                                            </button>\n                                                        </div>\n                                                    </div>\n                                                </ng-container>\n                                                <div class=\"flex flex-row justify-end mt-4\">\n                                                    <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\"\n                                                        (click)=\"addAssociatedParams()\">Add\n                                                        Params</button>\n                                                </div>\n                                            </div>\n                                        </div>\n                                    </ng-container>\n\n                                </div>\n                            </div>\n\n                        </div>\n                    </ng-container>\n                    <button class=\"{{commonService.btn_light_md}} cursor-pointer mt-2\"\n                        (click)=\"resetViewProprstise()\">Reset All</button>\n                </div>\n            </div>\n            <div *ngIf=\"activeTab === 'permission'\">\n                <div class=\"h-full overflow-x-auto\">\n                    <app-user-access [(userOptionContainer)]=\"userOptionContainer\">\n                    </app-user-access>\n                </div>\n            </div>\n\n        </div>\n\n\n    </div>\n</div>\n\n<div class=\"flex flex-row border-t pl-3\">\n    <div class=\"flex justify-start mx-1\">\n        <button class=\"{{commonService.btn_warning_md}} cursor-pointer mt-2\" (click)=\"viewMapForTest()\">\n            Preview</button>\n        <button class=\"{{commonService.btn_primary_md}} cursor-pointer mt-2\" (click)=\"isJsonPreview = false\">Data\n            Preview</button>\n    </div>\n    <div class=\"flex justify-end mx-1 flex-grow\">\n        <button class=\"{{commonService.btn_success_md}} cursor-pointer mt-2\"\n            (click)=\"getSaveChartConfig()\">Submit</button>\n    </div>\n</div>"]}
565
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"geo-map.component.js","sourceRoot":"","sources":["../../../../../../../projects/gamma-app-controller/src/lib/application-controller/support-components/geo-map/geo-map.component.ts","../../../../../../../projects/gamma-app-controller/src/lib/application-controller/support-components/geo-map/geo-map.component.html"],"names":[],"mappings":"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","sourcesContent":["\nimport { ChangeDetectorRef, Component, ComponentRef, ElementRef, EventEmitter, Input, OnInit, Output, ViewChild, ViewContainerRef } from '@angular/core';\nimport { ApplicationContentService } from '../../application-content.service';\nimport { ToastrService } from 'ngx-toastr';\nimport { CommonService } from '../../common';\n\n\n@Component({\n  selector: 'app-geo-map',\n  templateUrl: './geo-map.component.html',\n  styleUrls: ['./geo-map.component.scss']\n})\nexport class GeoMapComponent {\n  heatMapTypeDatasource = [\n    {\n      \"name\": \"Heat Map Only\",\n      \"value\": \"heatMapOnly\"\n    },\n    {\n      \"name\": \"Heat Map Marker\",\n      \"value\": \"heatMapMarker\"\n    },\n    {\n      \"name\": \"Heat Map And Heat Marker\",\n      \"value\": \"heatMapAndMarker\"\n    }\n  ]\n  chartViewType: any;\n  mapIconsDataSource = [\"assets/custom-marker..jpeg\"];\n  mapType: any = '';\n\n  chartViewTypeDataSource = [\n    { name: 'GEO Map', value: 'geoMap' },\n    { name: 'Heat Map', value: 'heatMap' },\n    { name: 'Bubble Map', value: 'bubbleMap' },\n    { name: 'Choropleth Map', value: 'choroplethMap' }\n  ];\n\n  regionData = [\"country\", \"city\"];\n  chartDataSourceForMap: any;\n  colors: string[] = []; // Array to hold selected colors\n  isJsonPreview: boolean;\n  dataSourseForTable: any = [];\n  jsaonDatasource: any;\n  configColume: any;\n  allConfiguredViews: any = [];\n  // groupOfViews: any;\n  viewProperties: any = {\n    enableClickEvent: false,\n    enableRightClickEvent: true,\n    clickEventOptions: {\n      associatedViews: [],\n      eventType: \"\"\n    }\n  };\n  optionalDrilDownDataSource: any = [];\n  table_columns_config = {\n    \"kpiConfig\": {\n      \"serviceId\": \"\",\n      \"api\": \"/kpi/trends/network/get-metric-data\",\n      \"displayType\": \"googleChart\",\n      \"formate\": \"\",\n      \"keyToPass\": [],\n      \"componentName\": \"GammaGeoChartComponent\",\n      \"dataConfig\": {}\n    },\n  };\n  heatMapConfig = {\n    \"chart_config\": [\n\n    ],\n    \"heatMapCategory\": \"\",\n    // \"centerLatitude\":\"\",\n    // \"centerLongitude\":\"\",\n    \"icon\": \"assets/custom-marker..jpeg\",\n    \"markerLatitude\": \"\",\n    \"markerLongitude\": \"\",\n    \"size\": '450',\n    \"zoom\": \"\"\n  }\n  bubbleMapConfig = {\n    \"chart_config\": [\n\n    ],\n    \"agrumentValue\": \"\",\n    \"bubbleColor\": \"#285e08\",\n    \"size\": '450',\n    \"bubbleMinimumSize\": \"5\",\n    \"bubbleMaximumSize\": \"15\",\n    \"markerLatitude\": \"\",\n    \"markerLongitude\": \"\",\n    \"sortBy\": \"\"\n    //  \"zoom\":\"\"\n  }\n  tableDataConfig = {\n\n    \"chart_config\": [\n\n    ],\n    \"region\": \"\",\n    \"regionCode\": \"US\",\n    // \"title\": \"\",\n    \"argumentField\": \"\",\n    \"chartValueField\": \"\",\n    \"size\": \"450\",\n    \"chartType\": \"geochart\",\n    \"backgroundColor\": \"#6c98e0\",\n    \"colors\": ['#003566', '#fd0000']\n\n  }\n\n\n  // for choroplethMap\n\n\n  choroplethMapConfig = {\n    chart_config: [\n      {\n        dataField: \"cnt\",\n        caption: \"Count\",\n        displayFor: \"map\",\n        enrichName: \"\"\n      }\n    ],\n    zoom: \"7\",\n    isValueFieldRangeSlider: true,\n    slideSpeed: 1000,\n    isDataAggregation: false,\n    dataAggregationConfig: {\n      \"dataAggregateColumes\": [],\n      \"aggregateFields\": []\n    },\n    sliderValueField: \"year\",\n    centerLat: \"1.3733\",\n    centerLng: \"32.2903\",\n    argumentField: \"district\",\n    gjsonFilePath: \"/assets/api-data/uganda_districts.geojson\",\n    size: \"450\",\n    chartType: \"choroplethMap\",\n    colorOne: '#089274',\n    colorTwo: '#f0f921',\n  }\n\n  isCenterdChoroplethMap: boolean = false;\n  centarLaitngObject = {\n    latKey: \"\",\n    lngKey: \"\"\n  }\n\n  enrichNameList = [\"abbreviateNumber\", \"getColorCodeSpan\", \"ThousandSeparator\", \"formatBytesv2\"]\n  selectedTableViewType: any;\n  isLoader: boolean = true;\n\n  selectedViewConfigs: any;\n  userOptionContainer: any = [];\n  previewData: any;\n\n  constructor(public commonService: CommonService, private cdr: ChangeDetectorRef, private service: ApplicationContentService, private taostr: ToastrService) { }\n\n  activeTab: string = 'basic';\n  @Output() public createOtherComponentView: EventEmitter<any> = new EventEmitter();\n  selectedViews = [];\n\n  @Input('datasetmodal')\n  set chartconfigData(value) {\n    if (value === undefined || value.length === 0) {\n      return;\n    } else {\n      this.jsaonDatasource = value.data[0];\n      this.configColume = Object.keys(value.data[0]);\n      this.dataSourseForTable = value.data;\n      this.selectedViewConfigs = value;\n      this.previewData = value.data;\n\n      this.selectedTableViewType = value.selectedViewType;\n      this.userOptionContainer = value.selectedWidgetConfig?.permissions ? value.selectedWidgetConfig.permissions : [];\n      if (value.selectedWidgetConfig) {\n\n        this.table_columns_config['kpiConfig'] = value.selectedWidgetConfig;\n        this.mapType = value.selectedWidgetConfig.dataConfig.mapType;\n        if (this.mapType == \"geoMap\") {\n          this.tableDataConfig = value.selectedWidgetConfig.dataConfig;\n          this.tableDataConfig.chart_config = value.selectedWidgetConfig.dataConfig.chart_config;\n\n        } else if (this.mapType == 'bubbleMap') {\n          this.bubbleMapConfig = value.selectedWidgetConfig.dataConfig;\n          this.bubbleMapConfig.chart_config = value.selectedWidgetConfig.dataConfig.chart_config;\n          this.tableDataConfig.chart_config = value.selectedWidgetConfig.dataConfig.chart_config;\n        } else if (this.mapType == 'choroplethMap') {\n\n          if (value.selectedWidgetConfig['dataConfig']['isDataAggregation']) {\n            this.dataAggregationContainer = value.selectedWidgetConfig['dataConfig']['dataAggregationConfig']['dataAggregateColumes'];\n            this.dataAggregateGroupByColume = value.selectedWidgetConfig['dataConfig']['dataAggregationConfig']['aggregateFields'];\n            this.saveAggregationColume();\n          }\n\n          this.choroplethMapConfig = value.selectedWidgetConfig.dataConfig;\n          this.choroplethMapConfig.chart_config = value.selectedWidgetConfig.dataConfig.chart_config;\n          this.tableDataConfig.chart_config = value.selectedWidgetConfig.dataConfig.chart_config;\n        }\n        else {\n          this.heatMapConfig = value.selectedWidgetConfig.dataConfig;\n          this.heatMapConfig.chart_config = value.selectedWidgetConfig.dataConfig.chart_config;\n          this.tableDataConfig.chart_config = value.selectedWidgetConfig.dataConfig.chart_config;\n        }\n        if (value.selectedWidgetConfig.viewProperties && value.selectedWidgetConfig.viewProperties.clickEventOptions.associatedViews) {\n          this.viewProperties = value.selectedWidgetConfig.viewProperties;\n          this.viewProperties = {\n            \"enableClickEvent\": value.selectedWidgetConfig.viewProperties.enableClickEvent,\n            \"enableRightClickEvent\": value.selectedWidgetConfig.viewProperties.enableRightClickEvent\n          }\n\n          if (value.selectedWidgetConfig.viewProperties.enableClickEvent) {\n            this.viewProperties['clickEventOptions'] = {\n              \"eventType\": value.selectedWidgetConfig.viewProperties.clickEventOptions.eventType,\n              \"associatedViews\": value.selectedWidgetConfig.viewProperties.clickEventOptions.associatedViews\n            }\n          } else {\n            this.viewProperties['clickEventOptions'] = {}\n          }\n\n        }\n\n        this.cdr.detectChanges();\n      } else {\n        this.tableDataConfig.chart_config = value.columnData;\n        if (this.tableDataConfig.chart_config) {\n          this.tableDataConfig.chart_config.forEach(element => {\n            // element['color'] = '';\n            // element['isShowBar'] = true;\n          });\n\n        } else {\n          this.tableDataConfig.chart_config = [];\n          this.configColume.forEach(element => {\n            let obj = {\n              // \"visible\": true,\n              // \"isShowBar\": true,\n              \"dataField\": element,\n              \"caption\": this.commonService.convertString(element),\n              \"enrichName\": \"\",\n              \"displayFor\": \"map\",\n              // \"color\": \"\",\n            }\n\n            this.tableDataConfig.chart_config.push(obj);\n\n          });\n        }\n\n        this.cdr.detectChanges();\n      }\n    }\n  }\n\n\n  ngOnInit(): void {\n    this.isLoader = true;\n    this.service.getAppViewConfigs().subscribe({\n      next: (data: any) => {\n        this.allConfiguredViews = data;\n\n        this.isLoader = false;\n      }, error: (err: any) => {\n        this.taostr.error('Unexpected Server Exception. Please contact System Admin.', 'All Views')\n      }\n    })\n\n    this.optionalDrilDownDataSource = [\n      {\n        'viewId': \"\",\n        'filterCondition': \"\"\n      }\n    ]\n  }\n  addColumns() {\n    let obj = {\n      \"dataField\": \"\",\n      \"caption\": \"\",\n      \"enrichName\": \"\",\n      \"displayFor\": \"\",\n    }\n\n    this.tableDataConfig.chart_config.push(obj);\n  }\n\n  deleteColumns(i) {\n    this.tableDataConfig.chart_config.splice(i, 1)\n  }\n\n  getEnrichClassName(e, item) {\n    item.enrichName = e.value;\n\n  }\n\n\n  moveItemForColumns(index: number, direction: 'up' | 'down'): void {\n    // Prevent moving beyond array bounds\n    if (index < 0 || index >= this.tableDataConfig.chart_config.length) return;\n    const newPosition = direction === 'up' ? index - 1 : index + 1;\n    // Prevent moving beyond array bounds\n    if (newPosition < 0 || newPosition >= this.tableDataConfig.chart_config.length) return;\n\n    // Move item\n    const itemToMove = this.tableDataConfig.chart_config[index];\n    this.tableDataConfig.chart_config.splice(index, 1); // Remove item from current position\n    this.tableDataConfig.chart_config.splice(newPosition, 0, itemToMove); // Insert item in new position\n  }\n\n  getObjectKeys(obj: any): string[] {\n    return Object.keys(obj);\n  }\n  setActiveTab(tab: string) {\n    this.activeTab = tab;\n  }\n\n  getGroupColumns(columns) {\n    const groupedColumns = columns.reduce((acc, column) => {\n      let group = acc.find(item => item.caption === column.group);\n      if (!group) {\n        group = {\n          caption: column.group,\n          columns: []\n        };\n        acc.push(group);\n      }\n      group.columns.push({\n        dataField: column.dataField,\n        // visible: column.visible,\n        caption: column.caption\n      });\n      return acc;\n    }, []);\n    return groupedColumns;\n  }\n  geColumnsFromGroup(columns) {\n    const newColumns = [];\n\n    columns.forEach(group => {\n      group.columns.forEach(col => {\n        newColumns.push({\n          dataField: col.dataField,\n          // visible: col.visible,\n          caption: col.caption,\n        });\n      });\n    });\n    return newColumns;\n  }\n\n\n  getSaveChartConfig() {\n\n    if (this.mapType == 'geoMap') {\n      this.table_columns_config.kpiConfig['dataConfig'] = this.tableDataConfig;\n      this.table_columns_config.kpiConfig['dataConfig']['mapType'] = this.mapType;\n      if (this.viewProperties.clickEventOptions.eventType == 'optionalDrillDown') {\n        this.viewProperties['clickEventOptions']['associatedViews'] = this.optionalDrilDownDataSource;\n      }\n      this.table_columns_config.kpiConfig['viewProperties'] = this.viewProperties;\n      this.table_columns_config['permissions'] = this.userOptionContainer;\n\n      this.createOtherComponentView.emit(this.table_columns_config);\n    } else if (this.mapType == 'bubbleMap') {\n      this.table_columns_config.kpiConfig['dataConfig'] = this.bubbleMapConfig;\n      this.table_columns_config.kpiConfig['dataConfig']['chart_config'] = this.tableDataConfig.chart_config;\n      this.table_columns_config.kpiConfig['dataConfig']['mapType'] = this.mapType;\n\n      if (this.viewProperties.clickEventOptions.eventType == 'optionalDrillDown') {\n        this.viewProperties['clickEventOptions']['associatedViews'] = this.optionalDrilDownDataSource;\n      }\n\n      this.table_columns_config.kpiConfig['viewProperties'] = this.viewProperties;\n      this.table_columns_config.kpiConfig['dataSource'] = '';\n      this.table_columns_config['permissions'] = this.userOptionContainer;\n\n      this.createOtherComponentView.emit(this.table_columns_config);\n\n    } else if (this.mapType == 'choroplethMap') {\n      this.table_columns_config.kpiConfig['dataConfig'] = this.choroplethMapConfig;\n      this.table_columns_config.kpiConfig['dataConfig']['chart_config'] = this.tableDataConfig.chart_config;\n      this.table_columns_config.kpiConfig['dataConfig']['mapType'] = this.mapType;\n      if (this.viewProperties.clickEventOptions.eventType == 'optionalDrillDown') {\n        this.viewProperties['clickEventOptions']['associatedViews'] = this.optionalDrilDownDataSource;\n      }\n\n      this.table_columns_config.kpiConfig['viewProperties'] = this.viewProperties;\n      this.table_columns_config.kpiConfig['dataSource'] = '';\n      this.table_columns_config['permissions'] = this.userOptionContainer;\n\n      this.createOtherComponentView.emit(this.table_columns_config);\n\n    } else {\n      this.table_columns_config.kpiConfig['dataConfig'] = this.heatMapConfig;\n      this.table_columns_config.kpiConfig['dataConfig']['chart_config'] = this.tableDataConfig.chart_config;\n      this.table_columns_config.kpiConfig['dataConfig']['mapType'] = this.mapType;\n      if (this.viewProperties.clickEventOptions.eventType == 'optionalDrillDown') {\n        this.viewProperties['clickEventOptions']['associatedViews'] = this.optionalDrilDownDataSource;\n      }\n\n      this.table_columns_config.kpiConfig['viewProperties'] = this.viewProperties;\n      this.table_columns_config['permissions'] = this.userOptionContainer;\n\n      this.createOtherComponentView.emit(this.table_columns_config);\n    }\n\n    // alert(JSON.stringify(this.table_columns_config, null, 2));\n    // console.log(this.table_columns_config);\n    // console.log(this.table_columns_config);\n\n    // this.createOtherComponentView.emit(this.table_columns_config);\n    // this.table_columns_config.kpiConfig['dataSource']= this.dataSourseForTable;\n    // this.chartDataSourceForMap = this.table_columns_config;\n\n  }\n\n  deleteAssociatedParams(index) {\n    this.optionalDrilDownDataSource.splice(index, 1)\n  }\n\n  addAssociatedParams() {\n    this.optionalDrilDownDataSource.push({\n      'viewId': \"\",\n      'filterCondition': \"\"\n    })\n  }\n\n  getSelectedEventType(e) {\n\n    if (e.event) {\n      this.optionalDrilDownDataSource = [];\n      if (this.viewProperties.clickEventOptions.eventType == 'drilldown') {\n        this.table_columns_config.kpiConfig['viewProperties']['associatedViews'] = [];\n      }\n    }\n\n\n  }\n\n  resetViewProprstise() {\n    this.viewProperties = {\n      enableClickEvent: false,\n      enableRightClickEvent: true,\n      clickEventOptions: {\n        associatedViews: [],\n        eventType: \"\"\n      }\n    };\n  }\n\n  addColor() {\n    this.tableDataConfig.colors.push('#000000'); // Add default color\n  }\n\n  removeColor(index: number) {\n    this.tableDataConfig.colors.splice(index, 1);\n  }\n\n  onColorChange(value: string, index: number) {\n    this.tableDataConfig.colors[index] = value; // Update color at index\n  }\n\n  viewMapForTest() {\n    if (this.mapType == 'geoMap') {\n      this.table_columns_config.kpiConfig['dataConfig'] = this.tableDataConfig;\n      this.table_columns_config.kpiConfig['dataConfig']['mapType'] = this.mapType;\n    } else if (this.mapType == 'bubbleMap') {\n      this.table_columns_config.kpiConfig['dataConfig'] = this.bubbleMapConfig;\n      this.table_columns_config.kpiConfig['dataConfig']['chart_config'] = this.tableDataConfig.chart_config;\n      this.table_columns_config.kpiConfig['dataConfig']['mapType'] = this.mapType;\n    } else if (this.mapType == 'choroplethMap') {\n      this.table_columns_config.kpiConfig['dataConfig'] = this.choroplethMapConfig;\n      this.table_columns_config.kpiConfig['dataConfig']['chart_config'] = this.tableDataConfig.chart_config;\n      this.table_columns_config.kpiConfig['dataConfig']['mapType'] = this.mapType;\n    }\n    else {\n      this.table_columns_config.kpiConfig['dataConfig'] = this.heatMapConfig;\n      this.table_columns_config.kpiConfig['dataConfig']['chart_config'] = this.tableDataConfig.chart_config;\n      this.table_columns_config.kpiConfig['dataConfig']['mapType'] = this.mapType;\n    }\n\n    if (this.viewProperties.clickEventOptions.eventType == 'optionalDrillDown') {\n      this.viewProperties['clickEventOptions']['associatedViews'] = this.optionalDrilDownDataSource;\n    }\n\n    this.table_columns_config.kpiConfig['viewProperties'] = this.viewProperties;\n\n    this.table_columns_config.kpiConfig['dataSource'] = this.dataSourseForTable;\n    this.chartDataSourceForMap = this.table_columns_config;\n\n    this.isJsonPreview = true;\n\n  }\n\n  heatMapCategory(e) {\n    this.heatMapConfig.heatMapCategory = e.value;\n  }\n\n  changeMapType(event) {\n    if (event.event) {\n      this.heatMapConfig.heatMapCategory = '';\n    }\n  }\n\n\n\n  onLatLngKeyChange(event) {\n    const { latKey, lngKey } = this.centarLaitngObject;\n\n    if (!latKey || !lngKey) {\n      return;\n    }\n\n    this.calculateCenterFromDatasource();\n  }\n\n  calculateCenterFromDatasource() {\n    const latKey = this.centarLaitngObject.latKey;\n    const lngKey = this.centarLaitngObject.lngKey;\n\n    if (!latKey || !lngKey || !this.dataSourseForTable?.length) {\n      return;\n    }\n\n    let minLat = Infinity;\n    let maxLat = -Infinity;\n    let minLng = Infinity;\n    let maxLng = -Infinity;\n\n    this.dataSourseForTable.forEach(item => {\n      const lat = Number(item[latKey]);\n      const lng = Number(item[lngKey]);\n\n      if (!isNaN(lat) && !isNaN(lng)) {\n        minLat = Math.min(minLat, lat);\n        maxLat = Math.max(maxLat, lat);\n        minLng = Math.min(minLng, lng);\n        maxLng = Math.max(maxLng, lng);\n      }\n    });\n\n    const centerLat = (minLat + maxLat) / 2;\n    const centerLng = (minLng + maxLng) / 2;\n\n    // ✅ store as STRING\n    this.choroplethMapConfig['centerLat'] = centerLat.toFixed(6);\n    this.choroplethMapConfig['centerLng'] = centerLng.toFixed(6);\n  }\n\n\n\n\n\n  // data aggregation code\n\n  dataAggregationContainer = [];\n  dataAggregateGroupByColume: any = [];\n  addAggregationColume() {\n    this.dataAggregationContainer.push({\n      aggregateDataField: \"\",\n      aggregateFunctionType: \"\"\n    })\n  }\n\n  deleteAggregationColume(i) {\n    this.dataAggregationContainer.splice(i, 1)\n  }\n\n\n\n  onDataGroupByChange(event: any) {\n    if (this.choroplethMapConfig.isDataAggregation) {\n\n      this.dataAggregationContainer.push({\n        aggregateDataField: \"\",\n        aggregateFunctionType: \"\"\n      })\n    } else {\n      this.dataSourseForTable = this.previewData.slice(0, 10);\n      this.configColume = (this.previewData[0]) ? Object.keys(this.previewData[0]) : [];\n    }\n\n    this.table_columns_config.kpiConfig['dataConfig'] = this.choroplethMapConfig;\n    this.table_columns_config.kpiConfig['dataConfig']['chart_config'] = this.tableDataConfig.chart_config;\n    this.table_columns_config.kpiConfig['dataConfig']['mapType'] = this.mapType;\n\n    this.chartDataSourceForMap = { ...this.table_columns_config };\n  }\n\n  saveAggregationColume() {\n    if (this.choroplethMapConfig.isDataAggregation) {\n      const aggreationData = this.getGroupDataForChart(this.previewData, this.dataAggregationContainer, this.dataAggregateGroupByColume);\n      this.dataSourseForTable = aggreationData;\n      this.configColume = (aggreationData[0]) ? Object.keys(aggreationData[0]) : [];\n\n      if (this.choroplethMapConfig.isDataAggregation) {\n        this.choroplethMapConfig['dataAggregationConfig'] = {\n          \"dataAggregateColumes\": this.dataAggregationContainer,\n          \"aggregateFields\": this.dataAggregateGroupByColume\n        }\n      }\n\n      console.log(aggreationData);\n    }\n  }\n\n\n  getGroupDataForChart(data, aggregationConfig, groupByColumns) {\n    const groupMap = {};\n\n    data.forEach(row => {\n      const groupKey = groupByColumns.map(col => row[col]).join(\"||\");\n\n      if (!groupMap[groupKey]) {\n        groupMap[groupKey] = {};\n\n        groupByColumns.forEach(col => {\n          groupMap[groupKey][col] = row[col];\n        });\n\n        aggregationConfig.forEach(({ aggregateDataField, aggregateFunctionType }) => {\n          switch (aggregateFunctionType) {\n            case \"sum\":\n            case \"avg\":\n              groupMap[groupKey][aggregateDataField] = 0;\n              break;\n            case \"min\":\n              groupMap[groupKey][aggregateDataField] = Infinity;\n              break;\n            case \"max\":\n              groupMap[groupKey][aggregateDataField] = -Infinity;\n              break;\n            case \"count\":\n              groupMap[groupKey][aggregateDataField] = 0;\n              break;\n          }\n\n          if (aggregateFunctionType === \"avg\") {\n            groupMap[groupKey][`${aggregateDataField}__count`] = 0;\n          }\n        });\n      }\n\n      // Apply aggregations\n      aggregationConfig.forEach(({ aggregateDataField, aggregateFunctionType }) => {\n        const value = row[aggregateDataField];\n\n        switch (aggregateFunctionType) {\n          case \"sum\":\n            groupMap[groupKey][aggregateDataField] += value;\n            break;\n\n          case \"avg\":\n            groupMap[groupKey][aggregateDataField] += value;\n            groupMap[groupKey][`${aggregateDataField}__count`] += 1;\n            break;\n\n          case \"min\":\n            groupMap[groupKey][aggregateDataField] =\n              Math.min(groupMap[groupKey][aggregateDataField], value);\n            break;\n\n          case \"max\":\n            groupMap[groupKey][aggregateDataField] =\n              Math.max(groupMap[groupKey][aggregateDataField], value);\n            break;\n\n          case \"count\":\n            groupMap[groupKey][aggregateDataField] += 1;\n            break;\n        }\n      });\n    });\n\n    // Finalize averages\n    Object.values(groupMap).forEach(group => {\n      aggregationConfig.forEach(({ aggregateDataField, aggregateFunctionType }) => {\n        if (aggregateFunctionType === \"avg\") {\n          group[aggregateDataField] =\n            group[aggregateDataField] / group[`${aggregateDataField}__count`];\n          delete group[`${aggregateDataField}__count`];\n        }\n      });\n    });\n\n    return Object.values(groupMap);\n  }\n\n\n}\n","<div class=\"flex flex-wrap\">\n    <div class=\"w-full mx-2 border-r\">\n        <ng-container *ngIf=\"!isJsonPreview\">\n            <pre><code>{{jsaonDatasource | json}}</code></pre>\n        </ng-container>\n        <ng-container *ngIf=\"isJsonPreview\">\n            <app-gamma-geo-chart [chartDataSource]=\"chartDataSourceForMap\"></app-gamma-geo-chart>\n            <!-- <app-google-geo-map [chartDataSource]=\"chartDataSourceForMap\"></app-google-geo-map> -->\n\n            <div #dynamicContainer></div>\n\n        </ng-container>\n    </div>\n    <div class=\"w-full mx-2\">\n\n        <div class=\"mb-4 border-b border-gray-200 dark:border-gray-700\">\n            <ul class=\"flex flex-wrap -mb-px text-sm font-medium text-center\" role=\"tablist\">\n                <li class=\"me-2\" role=\"presentation\">\n                    <button class=\"inline-block p-4 border-b-2 rounded-t-lg\" [ngClass]=\"{ \n                                        'text-purple-600 border-purple-600 dark:text-purple-500 dark:border-purple-500': activeTab === 'basic',\n                                        'text-gray-500 dark:text-gray-400 border-transparent': activeTab !== 'basic' \n                                    }\" (click)=\"setActiveTab('basic')\" type=\"button\" role=\"tab\">\n                        Basic\n                    </button>\n                </li>\n                <li class=\"me-2\" role=\"presentation\">\n                    <button class=\"inline-block p-4 border-b-2 rounded-t-lg\" [ngClass]=\"{ \n                                        'text-purple-600 border-purple-600 dark:text-purple-500 dark:border-purple-500': activeTab === 'chart_config',\n                                        'text-gray-500 dark:text-gray-400 border-transparent': activeTab !== 'chart_config' \n                                    }\" (click)=\"setActiveTab('chart_config')\" type=\"button\" role=\"tab\">\n                        Chart Columns\n                    </button>\n                </li>\n                <li class=\"me-2\" role=\"presentation\">\n                    <button class=\"inline-block p-4 border-b-2 rounded-t-lg\" [ngClass]=\"{\n                                                        'text-purple-600 border-purple-600 dark:text-purple-500 dark:border-purple-500': activeTab === 'properties',\n                                                        'text-gray-500 dark:text-gray-400 border-transparent': activeTab !== 'properties'\n                                                    }\" (click)=\"setActiveTab('properties')\" type=\"button\" role=\"tab\">\n                        Properties\n                    </button>\n                </li>\n                <li class=\"me-2\" role=\"presentation\">\n                    <button class=\"inline-block p-4 border-b-2 rounded-t-lg\" [ngClass]=\"{\n                                        'text-purple-600 border-purple-600 dark:text-purple-500 dark:border-purple-500': activeTab === 'permission',\n                                        'text-gray-500 dark:text-gray-400 border-transparent': activeTab !== 'permission'\n                                    }\" (click)=\"setActiveTab('permission')\" type=\"button\" role=\"tab\">\n                        Manage Permissions\n                    </button>\n                </li>\n\n            </ul>\n        </div>\n\n        <div id=\"default-styled-tab-content\">\n            <div *ngIf=\"activeTab === 'basic'\">\n                <div class=\"flex flex-col flex-auto min-w-0 my-2\">\n                    <div class=\"text-sm py-1 font-extrabold border-b bg-gray-700 text-white px-2\"> Filter Title\n                        Config\n                    </div>\n                    <div class=\"flex pt-2 border-x border-b\">\n                        <div class=\"px-1 mb-1 w-1/3\">\n                            <div class=\"text-md mb-1\"> Map Library </div>\n                            <dx-select-box [searchEnabled]=\"true\" [items]=\"['Google Maps']\"></dx-select-box>\n                        </div>\n                        <div class=\"px-1 mb-1 w-1/3\">\n                            <div class=\"text-md mb-1\"> Select Map type </div>\n                            <dx-select-box [searchEnabled]=\"true\" [items]=\"chartViewTypeDataSource\" displayExpr=\"name\"\n                                valueExpr=\"value\" [(ngModel)]=\"mapType\"\n                                (onValueChanged)=\"changeMapType($event)\"></dx-select-box>\n                        </div>\n\n                        <ng-container *ngIf=\"mapType == 'heatMap'\">\n                            <div class=\"px-1 mb-1 w-1/3\">\n\n                                <div class=\"text-md mb-1\"> Heat Map Category </div>\n                                <dx-select-box [searchEnabled]=\"true\" [dataSource]=\"heatMapTypeDatasource\"\n                                    displayExpr=\"name\" valueExpr=\"value\" [(ngModel)]=\"heatMapConfig.heatMapCategory\"\n                                    (onValueChanged)=\"heatMapCategory($event)\"></dx-select-box>\n                            </div>\n                        </ng-container>\n                    </div>\n                    <ng-container *ngIf=\"mapType == 'geoMap'\">\n                        <div class=\"flex pt-2 border-x border-b\">\n                            <div class=\"px-1 mb-1 w-1/3\">\n                                <div class=\"text-md mb-1\"> Region </div>\n                                <dx-select-box [searchEnabled]=\"true\" [items]=\"regionData\"\n                                    [(ngModel)]=\"tableDataConfig.region\"></dx-select-box>\n                            </div>\n                            <div class=\"px-1 mb-1 w-1/3\" *ngIf=\"tableDataConfig.region == 'city'\">\n                                <div class=\"text-md mb-1\"> Type Region Code</div>\n                                <dx-text-box [(ngModel)]=\"tableDataConfig.regionCode\"></dx-text-box>\n                            </div>\n                        </div>\n                        <div class=\"pt-2 border-x border-b \">\n                            <div class=\"my-2 flex justify-between\">\n                                <!-- <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-1\"> Title</div>\n                                    <dx-text-box [(ngModel)]=\"tableDataConfig.title\"></dx-text-box>\n                                </div> -->\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-1\"> Argument Field</div>\n                                    <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                        [(ngModel)]=\"tableDataConfig.argumentField\"></dx-select-box>\n                                </div>\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-1\"> Chartvalu Field</div>\n                                    <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                        [(ngModel)]=\"tableDataConfig.chartValueField\"></dx-select-box>\n                                </div>\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-1\"> size</div>\n                                    <dx-text-box [(ngModel)]=\"tableDataConfig.size\"></dx-text-box>\n                                </div>\n\n                                <div class=\"px-1 mb-2 w-full\">\n                                    <div class=\"text-md mb-2\">Background Color</div>\n                                    <dx-color-box [(ngModel)]=\"tableDataConfig.backgroundColor\"></dx-color-box>\n                                </div>\n                                <!-- <div class=\"px-4 mt-6 w-full\">\n                                    <dx-check-box [value]=\"tableDataConfig.commonConfig.isSearchBox\"\n                                        [(ngModel)]=\"tableDataConfig.commonConfig.isSearchBox\"\n                                        text=\"Search Box\"></dx-check-box>\n    \n                                </div> -->\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-2\"> Display Formate </div>\n                                    <dx-select-box [items]=\"['daily','hourly','monthly']\"\n                                        [(ngModel)]=\"table_columns_config.kpiConfig.formate\"\n                                        [readOnly]=\"false\"></dx-select-box>\n                                </div>\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-2\"> Key To Pass </div>\n                                    <dx-tag-box [items]=\"configColume\"\n                                        [(ngModel)]=\"table_columns_config.kpiConfig.keyToPass\"></dx-tag-box>\n                                </div>\n                            </div>\n                        </div>\n                        <div class=\" pt-2 border-x border-b \">\n                            <div class=\"text-sm py-1 font-extrabold border-b bg-gray-700 text-white px-2\"> Colors\n                            </div>\n                            <div class=\"flex  flex-wrap px-1 mb-2 mt-2\">\n                                <div class=\"flex mr-2 mb-2\" *ngFor=\"let color of tableDataConfig.colors; let i = index\">\n                                    <div class=\"mr-2\">\n                                        <dx-color-box [(ngModel)]=\"tableDataConfig.colors[i]\"\n                                            (onValueChanged)=\"onColorChange($event.value, i)\"></dx-color-box>\n                                    </div>\n                                    <button class=\"{{commonService.btn_danger_sm}} cursor-pointer px-2\"\n                                        (click)=\"removeColor(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n                                    </button>\n                                    <!-- <div class=\"px-2\"> <button class=\"{{commonService.btn_danger_sm}}\" (click)=\"removeColor(i)\">Remove</button></div> -->\n                                </div>\n\n                            </div>\n                            <div class=\"flex flex-row justify-end my-2\">\n                                <button class=\"{{commonService.btn_success_sm}}\" (click)=\"addColor()\">Add Color</button>\n                            </div>\n                        </div>\n                    </ng-container>\n                    <ng-container *ngIf=\"mapType == 'choroplethMap'\">\n                        <div class=\"flex flex-row pt-2 border-x border-b\">\n                            <div class=\"px-1 mb-1 w-1/3\">\n                                <div class=\"text-md mb-1\"> Map Zoom </div>\n                                <dx-text-box [(ngModel)]=\"choroplethMapConfig.zoom\"></dx-text-box>\n                            </div>\n                            <div class=\"px-1 mb-2 mt-6 w-full\">\n                                <dx-check-box [(ngModel)]=\"isCenterdChoroplethMap\"\n                                    text=\"Centerd Position\"></dx-check-box>\n                            </div>\n\n                            <ng-container *ngIf=\"isCenterdChoroplethMap\">\n                                <div class=\"px-1 mb-1 w-1/3\">\n                                    <div class=\"text-md mb-1\"> Select Latitude Key</div>\n                                    <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                        [(ngModel)]=\"centarLaitngObject.latKey\"\n                                        (onValueChanged)=\"onLatLngKeyChange($event)\"></dx-select-box>\n                                </div>\n                                <div class=\"px-1 mb-1 w-1/3\">\n                                    <div class=\"text-md mb-1\"> Select Longitude Key</div>\n                                    <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                        [(ngModel)]=\"centarLaitngObject.lngKey\"\n                                        (onValueChanged)=\"onLatLngKeyChange($event)\"></dx-select-box>\n                                </div>\n\n                            </ng-container>\n\n                            <div class=\"px-1 mb-1 w-1/3\">\n                                <div class=\"text-md mb-1\"> Map Center Latitude</div>\n                                <dx-text-box [(ngModel)]=\"choroplethMapConfig.centerLat\"\n                                    [readOnly]=\"isCenterdChoroplethMap\"></dx-text-box>\n                            </div>\n                            <div class=\"px-1 mb-1 w-1/3\">\n                                <div class=\"text-md mb-1\"> Map Center Longitude</div>\n                                <dx-text-box [(ngModel)]=\"choroplethMapConfig.centerLng\"\n                                    [readOnly]=\"isCenterdChoroplethMap\"></dx-text-box>\n                            </div>\n\n\n                        </div>\n                        <div class=\"pt-2 border-x border-b \">\n                            <div class=\"my-2 flex flex-row justify-between\">\n\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-1\"> Argument Field</div>\n                                    <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                        [(ngModel)]=\"choroplethMapConfig.argumentField\"></dx-select-box>\n                                </div>\n\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-1\"> size</div>\n                                    <dx-text-box [(ngModel)]=\"choroplethMapConfig.size\"></dx-text-box>\n                                </div>\n\n                                <div class=\"px-1 mb-2 w-full\">\n                                    <div class=\"text-md mb-2\">Color One</div>\n                                    <dx-color-box [(ngModel)]=\"choroplethMapConfig.colorOne\"></dx-color-box>\n                                </div>\n\n                                <div class=\"px-1 mb-2 w-full\">\n                                    <div class=\"text-md mb-2\">Color Two</div>\n                                    <dx-color-box [(ngModel)]=\"choroplethMapConfig.colorTwo\"></dx-color-box>\n                                </div>\n\n\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-2\"> Display Formate </div>\n                                    <dx-select-box [items]=\"['daily','hourly','monthly']\"\n                                        [(ngModel)]=\"table_columns_config.kpiConfig.formate\"\n                                        [readOnly]=\"false\"></dx-select-box>\n                                </div>\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-2\"> Key To Pass </div>\n                                    <dx-tag-box [items]=\"configColume\"\n                                        [(ngModel)]=\"table_columns_config.kpiConfig.keyToPass\"></dx-tag-box>\n                                </div>\n\n                            </div>\n                            <div class=\"my-2 flex-row justify-between\">\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-1\"> Gjson File Path</div>\n                                    <dx-text-box [(ngModel)]=\"choroplethMapConfig.gjsonFilePath\"></dx-text-box>\n                                </div>\n\n                            </div>\n                            <div class=\"my-2 flex flex-row justify-between\">\n                                <div class=\"px-1 mb-2 mt-6 w-full\">\n                                    <dx-check-box [(ngModel)]=\"choroplethMapConfig.isValueFieldRangeSlider\"\n                                        text=\"Range Slider\"></dx-check-box>\n                                </div>\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-1\"> Slider Speed</div>\n                                    <dx-number-box [(ngModel)]=\"choroplethMapConfig.slideSpeed\"></dx-number-box>\n                                </div>\n                                <div class=\"px-1 mb-1 w-full\">\n                                    <div class=\"text-md mb-1\"> Value For Slider</div>\n                                    <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                        [(ngModel)]=\"choroplethMapConfig.sliderValueField\"></dx-select-box>\n                                </div>\n                            </div>\n                        </div>\n\n                        <div class=\"w-1/4 px-2 m-3\">\n                            <div class=\"text-md mb-1 mt-8\"></div>\n                            <dx-check-box [(ngModel)]=\"choroplethMapConfig.isDataAggregation\"\n                                (ngModelChange)=\"onDataGroupByChange($event)\"\n                                text=\"Apply Data Aggregation\"></dx-check-box>\n                        </div>\n\n                        <div class=\"flex flex-col rounded border p-3 m-6\" *ngIf=\"choroplethMapConfig.isDataAggregation\">\n                            <div class=\"px-1 my-4 w-1/3\">\n                                <div class=\"text-md mb-2\">Group By Columns</div>\n                                <dx-tag-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                    [(ngModel)]=\"dataAggregateGroupByColume\"></dx-tag-box>\n                            </div>\n                            <div class=\"border p-2\">\n                                <div class=\"my-2 flex flex-row border-b\"\n                                    *ngFor=\"let item of dataAggregationContainer; let i = index\">\n\n                                    <div class=\"px-1 mb-1 w-full\">\n                                        <div class=\"text-md mb-2\">Aggregation Columns</div>\n                                        <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                            [(ngModel)]=\"item.aggregateDataField\"></dx-select-box>\n                                    </div>\n                                    <div class=\" px-2 mb-1 w-full\">\n                                        <div class=\"text-md mb-2\">Function Type</div>\n                                        <dx-select-box [searchEnabled]=\"true\"\n                                            [items]=\"['sum','avg','min','max','count']\"\n                                            [(ngModel)]=\"item.aggregateFunctionType\"></dx-select-box>\n                                    </div>\n\n                                    <div class=\"text-center mt-6 w-1/6\">\n                                        <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n                                            (click)=\"deleteAggregationColume(i)\"><i class=\"fa fa-trash-o\"\n                                                aria-hidden=\"true\"></i>\n                                        </button>\n                                    </div>\n                                </div>\n                                <div class=\"flex flex-row justify-end my-2\">\n                                    <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\"\n                                        (click)=\"addAggregationColume()\">Add\n                                        Colume</button>\n                                    <button class=\"{{commonService.btn_success_sm}} cursor-pointer\"\n                                        (click)=\"saveAggregationColume()\">Save Aggregation</button>\n                                </div>\n                            </div>\n\n                        </div>\n\n                    </ng-container>\n\n                    <ng-container\n                        *ngIf=\"heatMapConfig.heatMapCategory == 'heatMapOnly' || heatMapConfig.heatMapCategory == 'heatMapMarker' || heatMapConfig.heatMapCategory == 'heatMapAndMarker'\">\n                        <div class=\"flex-col\">\n                            <div class=\"text-sm py-1 font-extrabold border-b bg-gray-700 text-white px-2\">\n                                Center Location Config\n                            </div>\n                            <div>\n                                <div class=\"flex pt-2 border-x border-b\">\n                                    <!-- <div class=\"px-1 mb-1 w-1/4\">\n                                        <div class=\"text-md mb-1\"> Latitude  </div>\n                                        <dx-text-box [(ngModel)]=\"heatMapConfig.centerLatitude\"></dx-text-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-1/4\">\n                                        <div class=\"text-md mb-1\"> Longitude </div>\n                                        <dx-text-box [(ngModel)]=\"heatMapConfig.centerLongitude\"></dx-text-box>\n                                    </div> -->\n                                    <div class=\"px-1 mb-1 w-1/4\"\n                                        *ngIf=\"heatMapConfig.heatMapCategory != 'heatMapAndMarker'\">\n                                        <div class=\"text-md mb-1\"> Zoom Label </div>\n                                        <dx-text-box [(ngModel)]=\"heatMapConfig.zoom\"></dx-text-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-1/4\">\n                                        <div class=\"text-md mb-1\"> Custom Icons </div>\n                                        <dx-text-box [(ngModel)]=\"heatMapConfig.icon\"></dx-text-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-1/4\">\n                                        <div class=\"text-md mb-1\"> size</div>\n                                        <dx-text-box [(ngModel)]=\"heatMapConfig.size\"></dx-text-box>\n                                    </div>\n                                </div>\n                            </div>\n                        </div>\n                        <div class=\"flex-col\">\n                            <div class=\"text-sm py-1 font-extrabold border-b bg-gray-700 text-white px-2\">\n                                Location Marker Config\n                            </div>\n                            <div>\n                                <div class=\"flex pt-2 border-x border-b\">\n                                    <div class=\"px-1 mb-1 w-1/3\">\n                                        <div class=\"text-md mb-1\"> Latitude </div>\n                                        <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                            [(ngModel)]=\"heatMapConfig.markerLatitude\"></dx-select-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-1/3\">\n                                        <div class=\"text-md mb-1\"> Longitude </div>\n                                        <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                            [(ngModel)]=\"heatMapConfig.markerLongitude\"></dx-select-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-full\">\n                                        <div class=\"text-md mb-2\"> Display Formate </div>\n                                        <dx-select-box [items]=\"['daily','hourly','monthly']\"\n                                            [(ngModel)]=\"table_columns_config.kpiConfig.formate\"\n                                            [readOnly]=\"false\"></dx-select-box>\n                                    </div>\n                                </div>\n                            </div>\n                        </div>\n                    </ng-container>\n                    <ng-container *ngIf=\"mapType == 'bubbleMap'\">\n                        <div class=\"flex-col\">\n                            <div class=\"text-sm py-1 font-extrabold border-b bg-gray-700 text-white px-2\">\n                                Bubble Map Config\n                            </div>\n                            <div>\n                                <div class=\"flex pt-2 border-x border-b\">\n                                    <div class=\"px-1 mb-1 w-1/3\">\n                                        <div class=\"text-md mb-1\"> Argument Value </div>\n                                        <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                            [(ngModel)]=\"bubbleMapConfig.agrumentValue\"></dx-select-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-1/4\">\n                                        <div class=\"text-md mb-1\"> Bubble Color </div>\n                                        <dx-color-box [(ngModel)]=\"bubbleMapConfig.bubbleColor\"></dx-color-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-1/4\">\n                                        <div class=\"text-md mb-1\">Bubble Minimum size</div>\n                                        <dx-text-box [(ngModel)]=\"bubbleMapConfig.bubbleMinimumSize\"></dx-text-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-1/4\">\n                                        <div class=\"text-md mb-1\">Bubble Maximum size</div>\n                                        <dx-text-box [(ngModel)]=\"bubbleMapConfig.bubbleMaximumSize\"></dx-text-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-1/4\">\n                                        <div class=\"text-md mb-1\"> size</div>\n                                        <dx-text-box [(ngModel)]=\"bubbleMapConfig.size\"></dx-text-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-1/4\">\n                                        <div class=\"text-md mb-1\"> Short By</div>\n                                        <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                            [(ngModel)]=\"bubbleMapConfig.sortBy\"></dx-select-box>\n                                    </div>\n                                    <!-- <div class=\"px-1 mb-1 w-1/4\" *ngIf=\"heatMapConfig.heatMapCategory != 'heatMapAndMarker'\">\n                                        <div class=\"text-md mb-1\"> Zoom Label  </div>\n                                        <dx-text-box [(ngModel)]=\"heatMapConfig.zoom\"></dx-text-box>\n                                    </div> -->\n                                </div>\n                            </div>\n                        </div>\n                        <div class=\"flex-col\">\n                            <div class=\"text-sm py-1 font-extrabold border-b bg-gray-700 text-white px-2\">\n                                Location Marker Config\n                            </div>\n                            <div>\n                                <div class=\"flex pt-2 border-x border-b\">\n                                    <div class=\"px-1 mb-1 w-1/3\">\n                                        <div class=\"text-md mb-1\"> Latitude </div>\n                                        <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                            [(ngModel)]=\"bubbleMapConfig.markerLatitude\"></dx-select-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-1/3\">\n                                        <div class=\"text-md mb-1\"> Longitude </div>\n                                        <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                            [(ngModel)]=\"bubbleMapConfig.markerLongitude\"></dx-select-box>\n                                    </div>\n                                    <div class=\"px-1 mb-1 w-full\">\n                                        <div class=\"text-md mb-2\"> Display Formate </div>\n                                        <dx-select-box [items]=\"['daily','hourly','monthly']\"\n                                            [(ngModel)]=\"table_columns_config.kpiConfig.formate\"\n                                            [readOnly]=\"false\"></dx-select-box>\n                                    </div>\n                                </div>\n                            </div>\n                        </div>\n                    </ng-container>\n\n\n                </div>\n\n\n\n            </div>\n            <div *ngIf=\"activeTab === 'chart_config'\">\n                <div class=\"h-full overflow-x-auto\">\n                    <div class=\"flex flex-col flex-auto min-w-0\">\n                        <div class=\"text-sm py-1 font-extrabold border-b bg-gray-700 text-white px-2\">\n                            Tooltip Columns\n                        </div>\n                        <div class=\"pt-2 border-x border-b \">\n                            <div class=\"my-2 border-b flex flex-row\"\n                                *ngFor=\"let item of tableDataConfig.chart_config; let i = index;\">\n                                <!-- <div class=\"px-1 mb-2 mt-6 w-full\">\n                                    <dx-check-box [value]=\"item.visible\" [(ngModel)]=\"item.visible\"\n                                        text=\"Visiblity\"></dx-check-box>\n                                </div> -->\n\n                                <div class=\"px-1 mb-2 w-full\">\n                                    <div class=\"text-md mb-2\"> Value Field</div>\n                                    <dx-select-box [searchEnabled]=\"true\" [items]=\"configColume\"\n                                        [(ngModel)]=\"item.dataField\"></dx-select-box>\n                                </div>\n                                <div class=\"px-1 mb-2 w-full\">\n                                    <div class=\"text-md mb-2\"> Caption</div>\n                                    <dx-text-box [(ngModel)]=\"item.caption\"></dx-text-box>\n                                </div>\n\n\n                                <div class=\"px-1 mb-2 w-full\">\n                                    <div class=\"text-md mb-2\">Display For</div>\n                                    <dx-select-box [items]=\"['map', 'tooltip']\"\n                                        [(ngModel)]=\"item.displayFor\"></dx-select-box>\n                                </div>\n                                <div class=\"px-2 mb-2 w-full\">\n                                    <div class=\"text-md mb-2\"> UI Function</div>\n                                    <dx-select-box [items]=\"enrichNameList\" [(ngModel)]=\"item.enrichName\"\n                                        [searchEnabled]=\"true\"></dx-select-box>\n                                </div>\n\n                                <div class=\"text-center mt-8 w-full\">\n                                    <button *ngIf=\"i !== 0\" class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n                                        (click)=\"moveItemForColumns(i, 'up')\">\n                                        <i class=\"fa fa-arrow-up\" aria-hidden=\"true\"></i>\n                                    </button>\n\n                                    <button *ngIf=\"i !== tableDataConfig.chart_config.length - 1\"\n                                        class=\"{{commonService.btn_light_sm}} cursor-pointer mx-1\"\n                                        (click)=\"moveItemForColumns(i, 'down')\">\n                                        <i class=\"fa fa-arrow-down\" aria-hidden=\"true\"></i>\n                                    </button>\n                                    <button class=\"{{commonService.btn_danger_sm}} cursor-pointer\"\n                                        (click)=\"deleteColumns(i)\"><i class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n                                    </button>\n                                </div>\n\n                            </div>\n                        </div>\n                    </div>\n                    <div class=\"flex flex-row justify-end my-2\">\n                        <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\" (click)=\"addColumns()\">Add\n                            Columns</button>\n                    </div>\n                </div>\n            </div>\n            <div *ngIf=\"activeTab === 'properties'\">\n                <div class=\"h-full overflow-x-auto\">\n                    <app-loader *ngIf=\"isLoader\"></app-loader>\n                    <ng-container *ngIf=\"!isLoader\">\n                        <div class=\"flex flex-row justify-between border-b py-3\">\n                            <div class=\"mx-2\">\n                                <dx-check-box [value]=\"viewProperties.enableClickEvent\"\n                                    [(ngModel)]=\"viewProperties.enableClickEvent\"\n                                    text=\"Enable Click Event\"></dx-check-box>\n                            </div>\n                            <div class=\"mx-2\">\n                                <dx-check-box [value]=\"viewProperties.enableRightClickEvent\"\n                                    [(ngModel)]=\"viewProperties.enableRightClickEvent\"\n                                    text=\"Enable Right Click\"></dx-check-box>\n                            </div>\n                        </div>\n                        <div class=\"w-full p-2\" *ngIf=\"viewProperties.enableClickEvent\">\n\n                            <div class=\"flex flex-col flex-auto min-w-0 my-2\">\n                                <div class=\"text-sm py-1 font-extrabold border-b bg-gray-700 text-white px-2\"> Event\n                                    Type\n                                    Option\n                                </div>\n                                <div class=\"w-full p-3 border-x border-b \">\n                                    <div class=\"flex flex-row\">\n                                        <div class=\"w-full\">\n                                            <div class=\"text-md mb-2\"> Event Type</div>\n                                        </div>\n                                        <div class=\"w-full\">\n                                            <dx-select-box [items]=\"['drilldown','optionalDrillDown']\"\n                                                (onValueChanged)=\"getSelectedEventType($event)\"\n                                                [(ngModel)]=\"viewProperties.clickEventOptions.eventType\"></dx-select-box>\n                                        </div>\n                                    </div>\n                                    <ng-container *ngIf=\"viewProperties.clickEventOptions.eventType == 'drilldown'\">\n                                        <div class=\"flex flex-row justify-between mt-3\">\n                                            <div class=\"w-full\">\n                                                <div class=\"text-md mb-2\"> Associated Views</div>\n                                                <dx-tag-box [items]=\"allConfiguredViews\"\n                                                    [(ngModel)]=\"viewProperties.clickEventOptions.associatedViews\"\n                                                    valueExpr=\"viewId\" displayExpr=\"viewName\"\n                                                    [showSelectionControls]=\"true\" [searchEnabled]=\"true\"></dx-tag-box>\n                                            </div>\n                                        </div>\n                                    </ng-container>\n                                    <ng-container\n                                        *ngIf=\"viewProperties.clickEventOptions.eventType == 'optionalDrillDown'\">\n                                        <div class=\"flex flex-row justify-between mt-3\">\n                                            <div class=\"w-full\">\n                                                <ng-container\n                                                    *ngFor=\"let item of optionalDrilDownDataSource;let i = index;\">\n\n                                                    <div class=\"flex flex-row justify-between\">\n                                                        <div class=\"mx-2 w-full\">\n                                                            <div class=\"text-md mb-2\"> Associated Views</div>\n                                                            <dx-tag-box [items]=\"allConfiguredViews\"\n                                                                [(ngModel)]=\"item.viewId\" valueExpr=\"viewId\"\n                                                                displayExpr=\"viewName\" [showSelectionControls]=\"true\"\n                                                                [maxDisplayedTags]=\"2\"\n                                                                [searchEnabled]=\"true\"></dx-tag-box>\n\n                                                        </div>\n                                                        <div class=\"mx-2\">\n                                                            <div class=\"text-md mb-2\"> Associated Params</div>\n                                                            <dx-text-box\n                                                                [(ngModel)]=\"item.filterCondition\"></dx-text-box>\n                                                        </div>\n                                                        <div class=\"mx-2\">\n                                                            <button\n                                                                class=\"{{commonService.btn_danger_sm}} cursor-pointer mt-8\"\n                                                                (click)=\"deleteAssociatedParams(i)\"><i\n                                                                    class=\"fa fa-trash-o\" aria-hidden=\"true\"></i>\n                                                            </button>\n                                                        </div>\n                                                    </div>\n                                                </ng-container>\n                                                <div class=\"flex flex-row justify-end mt-4\">\n                                                    <button class=\"{{commonService.btn_primary_sm}} cursor-pointer\"\n                                                        (click)=\"addAssociatedParams()\">Add\n                                                        Params</button>\n                                                </div>\n                                            </div>\n                                        </div>\n                                    </ng-container>\n\n                                </div>\n                            </div>\n\n                        </div>\n                    </ng-container>\n                    <button class=\"{{commonService.btn_light_md}} cursor-pointer mt-2\"\n                        (click)=\"resetViewProprstise()\">Reset All</button>\n                </div>\n            </div>\n            <div *ngIf=\"activeTab === 'permission'\">\n                <div class=\"h-full overflow-x-auto\">\n                    <app-user-access [(userOptionContainer)]=\"userOptionContainer\">\n                    </app-user-access>\n                </div>\n            </div>\n\n        </div>\n\n\n    </div>\n</div>\n\n<div class=\"flex flex-row border-t pl-3\">\n    <div class=\"flex justify-start mx-1\">\n        <button class=\"{{commonService.btn_warning_md}} cursor-pointer mt-2\" (click)=\"viewMapForTest()\">\n            Preview</button>\n        <button class=\"{{commonService.btn_primary_md}} cursor-pointer mt-2\" (click)=\"isJsonPreview = false\">Data\n            Preview</button>\n    </div>\n    <div class=\"flex justify-end mx-1 flex-grow\">\n        <button class=\"{{commonService.btn_success_md}} cursor-pointer mt-2\"\n            (click)=\"getSaveChartConfig()\">Submit</button>\n    </div>\n</div>"]}